forked from nodesman/wp-autoresponder
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmanage.php
182 lines (161 loc) · 5.06 KB
/
manage.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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
<?php
$request = $_GET['wpr-manage'];
if (empty($request))
{
error("We're unable to identify your subscription to help you manage it. Please copy the full URL and paste it in the browser.");
}
$plainstring = base64_decode($request);
$parts = explode("%$%",$plainstring);
$sid = $parts[0];
$nid = $parts[1];
$hash = $parts[2];
function show_unsubscribed()
{
require "templates/unsubscribed.html";
}
function confirm_unsubscription($nid,$sid,$hash)
{
global $wpdb;
$query = "SELECT * FROM ".$wpdb->prefix."wpr_subscribers where id='$sid' and hash='$hash' and active=1 and confirmed=1;";
$subscriber = $wpdb->get_results($query);
if (count($subscriber) > 0)
{
$newsletter = _wpr_newsletter_get($nid);
$subscriber = _wpr_subscriber_get($sid);
$query = "select b.* from ".$wpdb->prefix."wpr_subscribers a, ".$wpdb->prefix."wpr_newsletters b where b.id=a.nid and a.email='".$subscriber->email."' and a.active=1 and a.confirmed=1;";
$newsletters = $wpdb->get_results($query);
?>
<div style="font-family:Verdana, Geneva, sans-serif; font-size:12px; padding:20px; margin-left: auto; margin-right: auto; width:300px; background-color:#f0f0f0; border: 1px solid #c0c0c0;"><form action="<?php print $_SERVER['REQUEST_URI'] ?>" method="post">
<input type="hidden" name="confirmed" value="true">
You are about to unsubscribe from:<br><br />
<input type="hidden" name="email" value="<?php echo $subscriber->email ?>" />
<?php
foreach ($newsletters as $newsletter)
{
?>
<div class="newsletter"><input type="checkbox" name="newsletter[]" checked="checked" value="<?php echo $newsletter->id ?>" id="nl_<?php echo $newsletter->id ?>" /> <label for="nl_<?php echo $newsletter->id ?>"><?php echo $newsletter->name ?> Newsletter<br />
<blockquote>
<?php
//get blog subscriptions
$query = "select * from ".$wpdb->prefix."wpr_blog_subscription where type='cat' sid=$sid";
$bsubs = $wpdb->get_results($query);
foreach ($bsubs as $sub)
{
$cat = get_category($sub->eid);
?>
You will stop receiving posts from the <?php echo $cat->name ?> category.<br />
<?php
}
$query = "select * from ".$wpdb->prefix."wpr_blog_subscription where type='all' sid='$sid'";
$bsubs = $wpdb->get_results($query);
if (count($bsubs) >0)
{
?>
New articles posted on the blog will not be delivered.<br />
<?php
}
//get post series
$query = "SELECT b.* FROM ".$wpdb->prefix."wpr_followup_subscriptions a, wpr_post_series b where type='postseries' and sid='$sid' and b.id=a.eid;";
$pssubs = $wpdb->get_results($query);
if (count($pssubs) >0)
{
?>
<?php
}
foreach ($pssubs as $sub)
{
"You will stop receiving ".$sub->name." post series<br>";
}
?>
</blockquote>
</label><br>
<?php echo $newsletter->description ?><br />
<?php
}
?>
Are you sure you want to unsubscribe from the above newsletter(s)?
<br />
<br />
<div align="center">
<input type="submit" value="Unsubscribe"> <input type="button" onclick="window.location='/'" value="Cancel"></div>
</form></div>
<?php
}
else // who? what?
{
header("HTTP/1.0 404 Not Found");
exit;
}
}
if (isset($_POST['confirmed']) && $_POST['confirmed'] == "true")
{
//delete autoresponders
$email = wpr_manage_sanitize($_POST['email']);
if (empty($email))
{
error("No email address was specified.");
}
if (is_array($_POST['newsletter']))
{
foreach ($_POST['newsletter'] as $nid)
{
$nid = (int) $nid;
if ($nid == 0)
{
continue;
}
global $wpdb;
$query = "SELECT id from ".$wpdb->prefix."wpr_subscribers where nid=$nid and email='$email'";
$sub = $wpdb->get_results($query);
if (count($sub) == 0)
continue;
$sid = $sub[0]->id;
//delete follow ups.
$query = "DELETE FROM ".$wpdb->prefix."wpr_followup_subscriptions where sid='$sid'";
$wpdb->query($query);
//delete blog subscriptions
$query = "DELETE FROM ".$wpdb->prefix."wpr_blog_subscription where sid='$sid'";
$wpdb->query($query);
//delete custom field values.
$query = "DELETE FROM ".$wpdb->prefix."wpr_custom_fields_values where sid='$sid'";
$wpdb->query($query);
//unsubscribe
$query = "UPDATE ".$wpdb->prefix."wpr_subscribers set active=0 WHERE id='$sid'";
$wpdb->query($query);
}
show_unsubscribed();
}
else
{
error("No newsletter was mentiond to unsubscribe");
}
}
else
{
confirm_unsubscription($nid,$sid,$hash);
}
function error($error)
{
?>
<div style="font-family: Arial">
<h2 align="center">An Error Has Occured</h2>
<div align="center">
<div style="width: 400px; padding: 10px; text-align: left; background-color: #336699; color: #fff; font-weight:bold; font-family: Arial; border: 1px solid #ccc;"> <?php echo $error ?> </div>
<a href="javascript:window.history.go(-1);">Click Here To Go Back</a> </div>
</div>
<?php
exit;
}
function wpr_manage_sanitize($string)
{
$string = strip_tags($string);
$string = trim($string);
if (get_magic_quotes_gpc())
{
return $string;
}
else
{
return addslashes($string);
}
}