forked from ccraig/cpoMMo
-
Notifications
You must be signed in to change notification settings - Fork 51
/
activate.php
105 lines (93 loc) · 2.86 KB
/
activate.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
100
101
102
103
104
<?php
/**
* Original Code Copyright (C) 2005, 2006, 2007, 2008 Brice Burgess <[email protected]>
* released originally under GPLV2
*
* This file is part of poMMo.
*
* poMMo 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 3 of the License, or
* (at your option) any later version.
*
* poMMo 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.
*
* You should have received a copy of the GNU General Public License
* along with Pommo. If not, see <http://www.gnu.org/licenses/>.
*
* This fork is from https://github.com/soonick/poMMo
* Please see docs/contribs for Contributors
*
*/
/**********************************
INITIALIZATION METHODS
*********************************/
require 'bootstrap.php';
require_once Pommo::$_baseDir.'classes/Pommo_Subscribers.php';
require_once Pommo::$_baseDir . 'classes/Pommo_Helper_Messages.php';
Pommo::init(array('authLevel' => 0,'noSession' => true));
$logger = Pommo::$_logger;
$dbo = Pommo::$_dbo;
/**********************************
SETUP TEMPLATE, PAGE
*********************************/
require_once Pommo::$_baseDir.'classes/Pommo_Template.php';
$view = new Pommo_Template();
// make sure email/login is valid
$subscriber = current(Pommo_Subscribers::get(array (
'email' => (empty($_REQUEST['email'])) ? '0' : $_REQUEST['email'], 'status' => 1
)));
if (empty($subscriber))
{
Pommo::redirect('login.php');
}
// see if an activation email was sent to this subscriber in the last 2 minutes;
$query =
'SELECT
*
FROM
'.$dbo->table['scratch']."
WHERE
`type`=1
AND `int`=%i
AND `time` > (NOW() - INTERVAL 2 MINUTE)
LIMIT 1";
$query = $dbo->prepare($query,array($subscriber['id']));
$test = $dbo->query($query,0);
// attempt to send activation code if once has not recently been sent
if (empty($test))
{
$code = Pommo_Subscribers::getActCode($subscriber);
if (Pommo_Helper_Messages::sendMessage(array (
'to' => $subscriber['email'],
'code' => $code,
'type' => 'activate')))
{
$view->assign('sent', true);
// timestamp this activation email
$query = "
INSERT INTO ".$dbo->table['scratch']."
SET
`type`=1,
`int`=%i";
$query = $dbo->prepare($query,array($subscriber['id']));
$dbo->query($query);
// remove ALL activation email timestamps older than 2 minutes
$query = "
DELETE FROM
".$dbo->table['scratch']."
WHERE
`type`=1
AND `time` < (NOW() - INTERVAL 2 MINUTE)";
$query = $dbo->prepare($query,array());
$dbo->query($query);
}
}
else {
$view->assign('sent', false);
}
$view->assign('email', $subscriber['email']);
$view->display('user/activate');