Copyright updated
[mailer.git] / 0.2.1 / inc / modules / admin / what-email_archiv.php
1 <?php\r
2 /************************************************************************\r
3  * MXChange v0.2.1                                    Start: 09/28/2003 *\r
4  * ===============                              Last change: 04/03/2004 *\r
5  *                                                                      *\r
6  * -------------------------------------------------------------------- *\r
7  * File              : what-email_archiv .php                           *\r
8  * -------------------------------------------------------------------- *\r
9  * Short description : See send emails details of ordered mails         *\r
10  * -------------------------------------------------------------------- *\r
11  * Kurzbeschreibung  : Alle  Mails ansehen die versand wurden           *\r
12  * -------------------------------------------------------------------- *\r
13  *                                                                      *\r
14  * -------------------------------------------------------------------- *\r
15  * Copyright (c) 2003 - 2008 by Roland Haeder                           *\r
16  * For more information visit: http://www.mxchange.org                  *\r
17  *                                                                      *\r
18  * This program is free software; you can redistribute it and/or modify *\r
19  * it under the terms of the GNU General Public License as published by *\r
20  * the Free Software Foundation; either version 2 of the License, or    *\r
21  * (at your option) any later version.                                  *\r
22  *                                                                      *\r
23  * This program is distributed in the hope that it will be useful,      *\r
24  * but WITHOUT ANY WARRANTY; without even the implied warranty of       *\r
25  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the        *\r
26  * GNU General Public License for more details.                         *\r
27  *                                                                      *\r
28  * You should have received a copy of the GNU General Public License    *\r
29  * along with this program; if not, write to the Free Software          *\r
30  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,               *\r
31  * MA  02110-1301  USA                                                  *\r
32  * -------------------------------------------------------------------- *\r
33  * Mod-Copyright (c) 2004 by Robert Niedziela                           *\r
34  * www.megacomputing.de                                                 *\r
35  ************************************************************************/\r
36 \r
37 // Some security stuff...\r
38 if ((ereg(basename(__FILE__), $_SERVER['PHP_SELF'])) || (!IS_ADMIN()))\r
39 {\r
40         $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4)."/security.php";\r
41         require($INC);\r
42 }\r
43 // Add description as navigation point\r
44 ADD_DESCR("admin", basename(__FILE__));\r
45 \r
46 //             0     1        2      3        4          5           6          7      8         9        10\r
47 $SQL = "SELECT id, sender, subject, text, receivers, payment_id, data_type, timestamp, url, target_send, cat_id\r
48  FROM "._MYSQL_PREFIX."_pool\r
49  WHERE data_type='SEND' OR data_type='DELETED'\r
50  ORDER BY timestamp DESC";\r
51 \r
52 // Check for maximum pages\r
53 $result_normal = SQL_QUERY($SQL, __FILE__, __LINE__);\r
54 \r
55 // Set offset an current page to default values\r
56 if (empty($_GET['page']))   $_GET['page']   = "1";\r
57 if (empty($_GET['offset'])) $_GET['offset'] = $CONFIG['mails_page'];\r
58 \r
59 // Add limitation to SQL string\r
60 $SQL .= " LIMIT ".($_GET['offset'] * $_GET['page'] - $_GET['offset']).", ".$_GET['offset'];\r
61 \r
62 // Run SQL query for normal mails\r
63 $result = SQL_QUERY($SQL, __FILE__, __LINE__);\r
64 \r
65 // Calculate pages\r
66 $PAGES = round(SQL_NUMROWS($result_normal) / $CONFIG['mails_page'] + 0.5);\r
67 SQL_FREERESULT($result_normal);\r
68 \r
69 if (SQL_NUMROWS($result) > 0)\r
70 {\r
71         // Mail orders are in pool so we can display them\r
72 \r
73         // Add navigation table rows\r
74         if ($PAGES > 1)\r
75         {\r
76                 define('__TOP_EMAIL_NAV'   , ADD_EMAIL_NAV($PAGES, $CONFIG['mails_page'], true , "3", true));\r
77                 define('__BOTTOM_EMAIL_NAV', ADD_EMAIL_NAV($PAGES, $CONFIG['mails_page'], false, "3", true));\r
78         }\r
79          else\r
80         {\r
81                 define('__TOP_EMAIL_NAV'   , "");\r
82                 define('__BOTTOM_EMAIL_NAV', "");\r
83         }\r
84 \r
85         $SW = 2; $OUT = "";\r
86         while ($pool = SQL_FETCHROW($result))\r
87         {\r
88                 // Check sent mails and clicks\r
89                 $result_mails = SQL_QUERY_ESC("SELECT max_rec, clicks FROM "._MYSQL_PREFIX."_user_stats WHERE pool_id=%d LIMIT 1",\r
90                  array(bigintval($pool[0])), __FILE__, __LINE__);\r
91                 list($sent, $clicks) = SQL_FETCHROW($result_mails);\r
92                 SQL_FREERESULT($result_mails);\r
93 \r
94                 // Unconfirmed mails\r
95                 $unconfirmed = $sent - $clicks;\r
96                 if ($unconfirmed > 0)\r
97                 {\r
98                         // Add link to list_unconfirmed what-file\r
99                         $unconfirmed = "<STRONG><A href=\"".URL."/modules.php?module=admin&amp;what=list_unconfirmed&amp;mid=".$pool[0]."\">".$unconfirmed."</A></STRONG>";\r
100                 }\r
101 \r
102                 // Prepare data for the row template\r
103                 $content = array(\r
104                         'sw'          => $SW,\r
105                         'u_link'      => ADMIN_USER_PROFILE_LINK($pool[1]),\r
106                         'subj'        => COMPILE_CODE($pool[2]),\r
107                         'text'        => COMPILE_CODE($pool[3]),\r
108                         'pay'         => GET_PAYMENT($pool[5]),\r
109                         'cat'         => GET_CATEGORY($pool[10]),\r
110                         'sent'        => $sent,\r
111                         'ruids'       => str_replace(";", ", ", $pool[4]),\r
112                         'unconfirmed' => $unconfirmed,\r
113                         'type'        => GET_POOL_TYPE($pool[6]),\r
114                         'tsend'       => $pool[9],\r
115                         'url'         => FRAMETESTER($pool[8]),\r
116                         'stamp'       => MAKE_DATETIME($pool[7], "0"),\r
117                         'mid'         => $pool[0],\r
118                 );\r
119 \r
120                 // Load row template and switch colors\r
121                 $OUT .= LOAD_TEMPLATE("admin_email_archiv_row", true, $content);\r
122                 $SW = 3 - $SW;\r
123         }\r
124 \r
125         // Free memory\r
126         SQL_FREERESULT($result);\r
127         define('__EMAIL_ROWS', $OUT);\r
128 \r
129         // Load main template\r
130         LOAD_TEMPLATE("admin_email_archiv");\r
131 }\r
132  else\r
133 {\r
134         // No mail orders fond\r
135         OUTPUT_HTML ("<SPAN class=\"admin_failed\">".ADMIN_NO_MAILS_IN_POOL."</SPAN>");\r
136 }\r
137 //\r
138 ?>\r