forked from tcdirectmail/tcdirectmail
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathclass.tx_tcdirectmail_scheduler.php
100 lines (83 loc) · 3.01 KB
/
class.tx_tcdirectmail_scheduler.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
/***************************************************************
* Copyright notice
*
* (c) 2011 Jose Antonio Guerra <[email protected]>
* All rights reserved
*
* This script is part of the TYPO3 project. The TYPO3 project is
* free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* The GNU General Public License can be found at
* http://www.gnu.org/copyleft/gpl.html.
*
* This script is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* This copyright notice MUST APPEAR in all copies of the script!
***************************************************************/
/**
* Class tx_directmail_scheduler
*
* @author Jose Antonio Guerra <[email protected]>
* @package TYPO3
* @subpackage tx_dollytcdirectmail
*/
class tx_tcdirectmail_scheduler extends tx_scheduler_Task {
/**
* Function executed from scheduler.
* Send the newsletter
*/
public function execute() {
/***************** Send script ********************/
/* List pages NOT to send */
$res = $GLOBALS['TYPO3_DB']->sql_query('SELECT pid FROM tx_tcdirectmail_lock WHERE stoptime = 0');
$pids[] = -1;
while (list($pid) = $GLOBALS['TYPO3_DB']->sql_fetch_row($res)) {
$pids[] = $pid;
}
$pids = implode(',', $pids);
/* Get a ready-to-send page */
$res = $GLOBALS['TYPO3_DB']->sql_query('SELECT *
FROM pages
WHERE tx_tcdirectmail_senttime <= UNIX_TIMESTAMP()
AND tx_tcdirectmail_senttime > 0
AND doktype = 189
AND uid NOT IN (' . $pids . ')
AND deleted = 0
AND hidden = 0
LIMIT 1');
if ($page = $GLOBALS['TYPO3_DB']->sql_fetch_assoc($res)) {
$begintime = time();
/* Lock the page */
$GLOBALS['TYPO3_DB']->exec_INSERTquery('tx_tcdirectmail_lock',
array('pid' => $page['uid'],
'begintime' => $begintime,
'stoptime' => 0));
$lockid = $GLOBALS['TYPO3_DB']->sql_insert_id();
tx_tcdirectmail_tools::createSpool($page, $begintime);
/* Unlock the page */
tx_tcdirectmail_tools::setScheduleAfterSending ($page);
$GLOBALS['TYPO3_DB']->exec_UPDATEquery('tx_tcdirectmail_lock', 'uid = ' . $lockid, array('stoptime' => time()));
}
/* Get all test pages */
$res = $GLOBALS['TYPO3_DB']->sql_query('SELECT *
FROM pages
WHERE tx_tcdirectmail_dotestsend = 1
AND deleted = 0
AND hidden = 0
AND doktype = 189');
/* Each pages */
while ($page = $GLOBALS['TYPO3_DB']->sql_fetch_assoc($res)) {
tx_tcdirectmail_tools::mailForTest($page);
$GLOBALS['TYPO3_DB']->sql_query('UPDATE pages SET tx_tcdirectmail_dotestsend = 0 WHERE uid = ' . $page[uid]);
}
tx_tcdirectmail_tools::runSpool();
return TRUE;
}
}