Commit | Line | Data |
---|---|---|
b42b2bf9 H |
1 | <?php |
2 | /* INDEV / DO NOT TOUCH | dump_mail_xml button functionality in mailbox | maniax */ | |
3 | ||
4 | if (!defined('M_ENDL')) define('M_ENDL', chr(10)); | |
5 | ||
6 | function dmx_gen_entry($m_rec) { | |
7 | printf(' <mail id="%d">'.M_ENDL, $m_rec['mail_id']); | |
8 | printf(' <datetime>%s</datetime>'.M_ENDL, $m_rec['mail_timestamp']); | |
9 | printf(' <from id="%d"><![CDATA[%s]]></from>'.M_ENDL, $m_rec['mail_from'], htmlspecialchars($m_rec['mail_from_login'])); | |
10 | printf(' <to id="%d"><![CDATA[%s]]></to>'.M_ENDL, $m_rec['mail_to'], htmlspecialchars($m_rec['mail_to_login'])); | |
11 | echo ' <text><![CDATA['.M_ENDL; | |
12 | printf(' %s'.M_ENDL, $m_rec['mail_text']); | |
13 | echo ' ]]></text>'.M_ENDL; | |
14 | printf(' </mail>'.M_ENDL); | |
15 | } | |
16 | ||
17 | function dump_mail_xml($node_id) { | |
18 | global $node, $db, $error; | |
19 | ||
20 | $user_id = $_SESSION['user_id']; | |
21 | ||
22 | $gm_qs = sprintf('select mail.*, users_from.login as mail_from_login, users_to.login as mail_to_login from mail | |
23 | join users as users_from on users_from.user_id = mail.mail_from | |
24 | join users as users_to on users_to.user_id = mail.mail_to | |
25 | where mail_user = %d order by mail_id asc', $user_id); | |
26 | ||
27 | $m_set = $db->query($gm_qs); | |
28 | ||
29 | if (!empty($_POST['FORCE_OB']) && $_POST['FORCE_OB'] == 'true') ob_clean(); | |
30 | ||
31 | Header('Content-type:application/octet-stream'); | |
32 | Header(sprintf('Content-disposition:attachment;filename=maildump-%d.xml', $user_id)); | |
33 | ||
34 | echo '<?xml version="1.0"?>'.M_ENDL; | |
35 | printf('<!-- XML mail dump for user id %s, generated @ %s -->'.M_ENDL, $user_id, date('d-m-Y, H:i:s')); | |
36 | printf('<maillist owner="%d">'.M_ENDL, $user_id); | |
37 | while ($m_set->next()) | |
38 | dmx_gen_entry($m_set->getRecord()); | |
39 | printf('</maillist>'.M_ENDL); | |
40 | ||
41 | die(); | |
42 | } | |
43 | ?> | |
44 | ||
45 | ||
46 | ||
47 | ||
48 | ||
49 |