4 * setup.php -- Sent Subfolders Setup File
6 * This is a standard SquirrelMail 1.2 API for plugins.
8 * @copyright © 1999-2007 The SquirrelMail Project Team
9 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
12 * @subpackage sent_subfolders
15 function sent_subfolders_check_handleAsSent_do() {
16 global $handleAsSent_result, $sent_subfolders_base,
19 // FIXME: hardcoded folder
20 $sent_subfolders_base = 'INBOX.Sent';
21 $args = func_get_arg(0);
22 sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION
);
24 /* Only check the folder string if we have been passed a mailbox. */
25 if ($use_sent_subfolders && (count($args) > 1)) {
26 /* Chop up the folder strings as needed. */
27 $base_str = $sent_subfolders_base . $delimiter;
28 $mbox_str = substr($args[1], 0, strlen($base_str));
30 /* Perform the comparison. */
31 $handleAsSent_result =
32 ( $handleAsSent_result
33 ||
($base_str == $mbox_str)
34 ||
($sent_subfolders_base == $args[1])
40 * Loads sent_subfolders settings
42 function sent_subfolders_load_prefs_do() {
43 global $use_sent_subfolders, $data_dir, $username,
44 $sent_subfolders_setting, $sent_subfolders_base;
46 $use_sent_subfolders = getPref
47 ($data_dir, $username, 'use_sent_subfolders', SMPREF_OFF
);
49 $sent_subfolders_setting = getPref
50 ($data_dir, $username, 'sent_subfolders_setting', SMPREF_SENT_SUBFOLDERS_DISABLED
);
52 $sent_subfolders_base = getPref
53 ($data_dir, $username, 'sent_subfolders_base', SMPREF_NONE
);
57 * Adds sent_subfolders options in folder preferences
59 function sent_subfolders_optpage_loadhook_folders_do() {
60 global $username, $optpage_data, $imapServerAddress, $imapPort, $show_contain_subfolders_option;
62 /* Get some imap data we need later. */
63 $imapConnection = sqimap_login($username, false, $imapServerAddress, $imapPort, 0);
64 $boxes = sqimap_mailbox_list($imapConnection);
65 sqimap_logout($imapConnection);
67 /* Load the Sent Subfolder Options into an array. */
68 $optgrp = _("Sent Subfolders Options");
72 'name' => 'sent_subfolders_setting',
73 'caption' => _("Use Sent Subfolders"),
74 'type' => SMOPT_TYPE_STRLIST
,
75 'refresh' => SMOPT_REFRESH_FOLDERLIST
,
76 'posvals' => array(SMPREF_SENT_SUBFOLDERS_DISABLED
=> _("Disabled"),
77 SMPREF_SENT_SUBFOLDERS_MONTHLY
=> _("Monthly"),
78 SMPREF_SENT_SUBFOLDERS_QUARTERLY
=> _("Quarterly"),
79 SMPREF_SENT_SUBFOLDERS_YEARLY
=> _("Yearly")),
80 'save' => 'save_option_sent_subfolders_setting'
83 $filtered_folders=array_filter($boxes, "filter_folders");
84 $sent_subfolders_base_values = array('whatever'=>$filtered_folders);
87 'name' => 'sent_subfolders_base',
88 'caption' => _("Base Sent Folder"),
89 'type' => SMOPT_TYPE_FLDRLIST
,
90 'refresh' => SMOPT_REFRESH_FOLDERLIST
,
91 'posvals' => $sent_subfolders_base_values,
92 'folder_filter' => 'noinferiors'
95 if ($show_contain_subfolders_option) {
97 'name' => 'sent_subfolders_warning',
98 'caption' => _("Warning"),
99 'type' => SMOPT_TYPE_COMMENT
,
100 'comment' => _("There are some restrictions in Sent Subfolder options.")
104 /* Add our option data to the global array. */
105 $optpage_data['grps'][SMOPT_GRP_SENT_SUBFOLDERS
] = $optgrp;
106 $optpage_data['vals'][SMOPT_GRP_SENT_SUBFOLDERS
] = $optvals;
110 * Defines folder filtering rules
112 * Callback function that should exclude some folders from folder listing.
113 * @param array $fldr list of folders. See sqimap_mailbox_list
114 * @return boolean returns true, if folder has to included in folder listing
117 function filter_folders($fldr) {
118 return strtolower($fldr['unformatted'])!='inbox';
122 * Saves sent_subfolder_options
124 function save_option_sent_subfolders_setting($option) {
125 global $data_dir, $username, $use_sent_subfolders;
127 /* Set use_sent_subfolders as either on or off. */
128 if ($option->new_value
== SMPREF_SENT_SUBFOLDERS_DISABLED
) {
129 setPref($data_dir, $username, 'use_sent_subfolders', SMPREF_OFF
);
131 setPref($data_dir, $username, 'use_sent_subfolders', SMPREF_ON
);
132 setPref($data_dir, $username, 'move_to_sent', SMPREF_ON
);
135 /* Now just save the option as normal. */
136 save_option($option);
140 * Update sent_subfolders settings
142 * function updates default sent folder value and
143 * creates required imap folders
145 function sent_subfolders_update_sentfolder_do() {
146 global $sent_folder, $username;
147 global $sent_subfolders_base, $sent_subfolders_setting;
148 global $data_dir, $imapServerAddress, $imapPort;
149 global $use_sent_subfolders, $move_to_sent;
151 sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION
);
153 if ($use_sent_subfolders ||
$move_to_sent) {
156 $quarter = sent_subfolder_getQuarter($month);
159 * Regarding the structure we've got three main possibilities.
160 * One sent holder. level 0.
161 * Multiple year holders with messages in it. level 1.
162 * Multiple year folders with holders in it. level 2.
165 switch ($sent_subfolders_setting) {
166 case SMPREF_SENT_SUBFOLDERS_YEARLY
:
168 $sent_subfolder = $sent_subfolders_base . $delimiter
171 case SMPREF_SENT_SUBFOLDERS_QUARTERLY
:
173 $sent_subfolder = $sent_subfolders_base . $delimiter
175 . $delimiter . $quarter;
176 $year_folder = $sent_subfolders_base . $delimiter
179 case SMPREF_SENT_SUBFOLDERS_MONTHLY
:
181 $sent_subfolder = $sent_subfolders_base . $delimiter
183 . $delimiter . $month;
184 $year_folder = $sent_subfolders_base. $delimiter . $year;
186 case SMPREF_SENT_SUBFOLDERS_DISABLED
:
189 $sent_subfolder = $sent_folder;
190 $year_folder = $sent_folder;
193 /* If this folder is NOT the current sent folder, update stuff. */
194 if ($sent_subfolder != $sent_folder) {
195 /* Auto-create folders, if they do not yet exist. */
196 if ($sent_subfolder != 'none') {
197 /* Create the imap connection. */
198 $ic = sqimap_login($username, false, $imapServerAddress, $imapPort, 10);
202 * If sent_subfolder can't store messages (noselect) ||
203 * year_folder can't store subfolders (noinferiors) in level=2 setup ||
204 * subfolder_base can't store subfolders (noinferiors), setup is broken
206 if (sqimap_mailbox_is_noselect($ic,$sent_subfolder,$boxes) ||
207 ($level==2 && sqimap_mailbox_is_noinferiors($ic,$year_folder,$boxes)) ||
208 sqimap_mailbox_is_noinferiors($ic,$sent_subfolders_base,$boxes)) {
209 error_box(_("Sent Subfolders plugin is misconfigured."));
212 /* Auto-create the year folder, if it does not yet exist. */
213 if (!sqimap_mailbox_exists($ic, $year_folder)) {
214 sqimap_mailbox_create($ic, $year_folder, 'noselect');
215 // TODO: safety check for imap servers that can't create subfolders
217 } else if (!sqimap_mailbox_is_subscribed($ic, $year_folder)) {
218 sqimap_subscribe($ic, $year_folder);
222 /* Auto-create the subfolder, if it does not yet exist. */
223 if (!sqimap_mailbox_exists($ic, $sent_subfolder)) {
224 sqimap_mailbox_create($ic, $sent_subfolder, '');
225 } else if (!sqimap_mailbox_is_subscribed($ic, $sent_subfolder)) {
226 sqimap_subscribe($ic, $sent_subfolder);
228 /* Update sent_folder setting. */
229 //setPref($data_dir, $username, 'sent_folder', $sent_subfolder);
230 //setPref($data_dir, $username, 'move_to_sent', SMPREF_ON);
231 $sent_folder = $sent_subfolder;
232 $move_to_sent = SMPREF_ON
;
234 /* Close the imap connection. */
243 * Sets quarter subfolder names
245 * @param string $month numeric month
246 * @return string quarter name (Q + number)
248 function sent_subfolder_getQuarter($month) {
274 /* Return the current quarter. */
275 return ('Q' . $result);
279 * detects if mailbox is part of sent_subfolders
281 * @param string $mb imap folder name
282 * @return boolean 1 - is part of sent_subfolders, 0 - is not part of sent_subfolders
284 function sent_subfolders_special_mailbox_do($mb) {
285 global $data_dir, $username;
287 sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION
);
289 $use_sent_subfolders = getPref
290 ($data_dir, $username, 'use_sent_subfolders', SMPREF_OFF
);
291 $sent_subfolders_base = getPref($data_dir, $username, 'sent_subfolders_base', 'na');
294 * If sent_subfolders are used and mailbox is equal to subfolder base
295 * or mailbox matches subfolder base + delimiter.
297 if ($use_sent_subfolders == SMPREF_ON
&&
298 ($mb == $sent_subfolders_base ||
stristr($mb,$sent_subfolders_base . $delimiter) ) ) {