X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=plugins%2Fnewmail%2Ffunctions.php;h=482f7197b9ef3543b9b3cdf43cf1f88342c82500;hb=e3812cb291b353059283c0f321a8f6151e50c976;hp=72712d411071f6d76015327d0cc71c6f8ed17c7a;hpb=fb88325503a9c0c1169966960b0a2f0e4883dc30;p=squirrelmail.git diff --git a/plugins/newmail/functions.php b/plugins/newmail/functions.php index 72712d41..482f7197 100644 --- a/plugins/newmail/functions.php +++ b/plugins/newmail/functions.php @@ -1,13 +1,26 @@ _("NewMail Options"), + 'url' => sqm_baseuri() . 'plugins/newmail/newmail_opt.php', + 'desc' => _("This configures settings for playing sounds and/or showing popup windows when new mail arrives."), + 'js' => TRUE + ); +} + +/** + * Save newmail plugin settings + */ +function newmail_sav_function() { + global $data_dir, $username, $_FILES, $newmail_uploadsounds; + + if ( sqgetGlobalVar('submit_newmail', $submit, SQ_POST) ) { + $media_enable = ''; + $media_popup = ''; + $media_allbox = ''; + $media_recent = ''; + $media_changetitle = ''; + $media_sel = ''; + $popup_width = ''; + $popup_height = ''; + + sqgetGlobalVar('media_enable', $media_enable, SQ_POST); + sqgetGlobalVar('media_popup', $media_popup, SQ_POST); + sqgetGlobalVar('media_allbox', $media_allbox, SQ_POST); + sqgetGlobalVar('media_recent', $media_recent, SQ_POST); + sqgetGlobalVar('media_changetitle', $media_changetitle, SQ_POST); + sqgetGlobalVar('popup_width', $popup_width, SQ_POST); + sqgetGlobalVar('popup_height', $popup_height, SQ_POST); + + // sanitize height and width + $popup_width = (int) $popup_width; + if ($popup_width<=0) $popup_width=200; + $popup_height = (int) $popup_height; + if ($popup_height<=0) $popup_height=130; + + setPref($data_dir,$username,'newmail_enable',$media_enable); + setPref($data_dir,$username,'newmail_popup', $media_popup); + setPref($data_dir,$username,'newmail_allbox',$media_allbox); + setPref($data_dir,$username,'newmail_recent',$media_recent); + setPref($data_dir,$username,'newmail_changetitle',$media_changetitle); + setPref($data_dir,$username,'newmail_popup_width',$popup_width); + setPref($data_dir,$username,'newmail_popup_height',$popup_height); + + if( sqgetGlobalVar('media_sel', $media_sel, SQ_POST) && + $media_sel == '(none)' ) { + removePref($data_dir,$username,'newmail_media'); + } else { + setPref($data_dir,$username,'newmail_media',$media_sel); + } + + // process uploaded file + if ($newmail_uploadsounds && isset($_FILES['media_file']['tmp_name']) && $_FILES['media_file']['tmp_name']!='') { + // set temp file and get media file name + $newmail_tempmedia=getHashedDir($username, $data_dir) . "/$username.tempsound"; + $newmail_mediafile=getHashedFile($username, $data_dir, $username . '.sound'); + if (move_uploaded_file($_FILES['media_file']['tmp_name'], $newmail_tempmedia)) { + // new media file is in $newmail_tempmedia + if (file_exists($newmail_mediafile)) unlink($newmail_mediafile); + if (! rename($newmail_tempmedia,$newmail_mediafile)) { + // remove (userfile), if file rename fails + removePref($data_dir,$username,'newmail_media'); + } else { + // store media type + if (isset($_FILES['media_file']['type']) && isset($_FILES['media_file']['name'])) { + setPref($data_dir,$username,'newmail_userfile_type', + newmail_get_mediatype($_FILES['media_file']['type'],$_FILES['media_file']['name'])); + } else { + removePref($data_dir,$username,'newmail_userfile_type'); + } + // store file name + if (isset($_FILES['media_file']['name'])) { + setPref($data_dir,$username,'newmail_userfile_name',basename($_FILES['media_file']['name'])); + } else { + setPref($data_dir,$username,'newmail_userfile_name','mediafile.unknown'); + } + } + } + } + } +} + +/** + * Load newmail plugin settings + */ +function newmail_pref_function() { + global $username,$data_dir; + global $newmail_media,$newmail_enable,$newmail_popup,$newmail_allbox; + global $newmail_recent, $newmail_changetitle; + global $newmail_userfile_type, $newmail_userfile_name; + global $newmail_popup_width, $newmail_popup_height; + + $newmail_recent = getPref($data_dir,$username,'newmail_recent'); + $newmail_enable = getPref($data_dir,$username,'newmail_enable'); + $newmail_media = getPref($data_dir, $username, 'newmail_media', '(none)'); + // remove full location from setting (since SM 1.5.1 plugin uses only filename). + if ($newmail_media!='(none)') + $newmail_media = basename($newmail_media); + + $newmail_popup = getPref($data_dir, $username, 'newmail_popup'); + $newmail_popup_width = getPref($data_dir, $username, 'newmail_popup_width',200); + $newmail_popup_height = getPref($data_dir, $username, 'newmail_popup_height',130); + $newmail_allbox = getPref($data_dir, $username, 'newmail_allbox'); + $newmail_changetitle = getPref($data_dir, $username, 'newmail_changetitle'); + + $newmail_userfile_type = getPref($data_dir, $username, 'newmail_userfile_type'); + $newmail_userfile_name = getPref($data_dir,$username,'newmail_userfile_name',''); +} + +/** + * Set loadinfo data + * + * Used by option page when saving settings. + */ +function newmail_set_loadinfo_function() { + global $optpage, $optpage_name; + if ($optpage=='newmail') { + $optpage_name=_("NewMail Options"); + } +} + +/** + * Insert needed data in left_main + */ +function newmail_plugin_function() { + global $username, $newmail_media, $newmail_enable, $newmail_popup, + $newmail_recent, $newmail_changetitle, $imapConnection, $PHP_SELF; + global $newmail_mmedia, $newmail_allowsound; + global $newmail_userfile_type; + global $newmail_popup_width, $newmail_popup_height; + + if ($newmail_enable == 'on' || + $newmail_popup == 'on' || + $newmail_changetitle) { + + // open a connection on the imap port (143) + + $boxes = sqimap_mailbox_list($imapConnection); + $delimeter = sqimap_get_delimiter($imapConnection); + + $status = 0; + $totalNew = 0; + + for ($i = 0;$i < count($boxes); $i++) { + + $mailbox = $boxes[$i]['formatted']; + + if (! isset($boxes[$i]['unseen'])) { + $boxes[$i]['unseen'] = ''; + } + if ($boxes[$i]['flags']) { + $noselect = false; + for ($h = 0; $h < count($boxes[$i]['flags']); $h++) { + if (strtolower($boxes[$i]["flags"][$h]) == 'noselect') { + $noselect = TRUE; + } + } + if (! $noselect) { + $status += CheckNewMailboxSound($imapConnection, + $mailbox, + $boxes[$i]['unformatted'], + $delimeter, + $boxes[$i]['unseen'], + $totalNew); + } + } else { + $status += CheckNewMailboxSound($imapConnection, + $mailbox, + $boxes[$i]['unformatted'], + $delimeter, + $boxes[$i]['unseen'], + $totalNew); + } + } + + // sqimap_logout($imapConnection); + + // If we found unseen messages, then we + // will play the sound as follows: + + if ($newmail_changetitle) { + echo "\n"; + } + + // create media output if there are new email messages + if ($newmail_allowsound && $totalNew > 0 && $newmail_enable == 'on' && $newmail_media != '' ) { + echo newmail_create_media_tags($newmail_media); + } + + if ($totalNew > 0 && $newmail_popup == 'on') { + // Idea by: Nic Wolfe (Nic@TimelapseProductions.com) + // Web URL: http://fineline.xs.mw + // More code from Tyler Akins + echo "\n"; + } + } +} + +// ----- end of hooked functions ----- + +/** + * Checks if mailbox contains new messages. + * + * @param stream $imapConnection + * @param string $mailbox FIXME: option is not used + * @param string $real_box unformated mailbox name + * @param string $delimeter FIXME: option is not used + * @param string $unseen FIXME: option is not used + * @param integer $total_new number of new messages + * @return bool true, if there are new messages + */ +function CheckNewMailboxSound($imapConnection, $mailbox, $real_box, $delimeter, $unseen, &$total_new) { + global $trash_folder, $sent_folder, + $unseen_notify, $newmail_allbox, + $newmail_recent; + + $mailboxURL = urlencode($real_box); + + // Skip folders for Sent and Trash + if ($real_box == $sent_folder || + $real_box == $trash_folder) { + return 0; + } + + if (($unseen_notify == 2 && $real_box == 'INBOX') || + ($unseen_notify == 3 && ($newmail_allbox == 'on' || + $real_box == 'INBOX'))) { + $status = sqimap_status_messages( $imapConnection, $real_box); + if($newmail_recent == 'on') { + $total_new += $status['RECENT']; + } else { + $total_new += $status['UNSEEN']; + } + if ($total_new) { + return 1; + } + } + return 0; +} + /** * Function tries to detect if file contents match declared file type * @@ -141,13 +428,15 @@ function newmail_media_objects($object,$types,$path,$args=array(),$extra='',$add if (isset($newmail_mediacompat_mode) && $newmail_mediacompat_mode) $ret.= newmail_media_embed($object,$types[0],$path,$args,$addsuffix); - // add $extra code inside objects + // add $extra code inside objects if ($extra!='') $ret.=$extra . "\n"; + // close embed tags if (isset($newmail_mediacompat_mode) && $newmail_mediacompat_mode) $ret.= newmail_media_embed_close($types[0]); + // close w3.org nested objects foreach (array_reverse($types) as $type) { $ret.= newmail_media_object_close($type); } @@ -163,8 +452,10 @@ function newmail_media_objects($object,$types,$path,$args=array(),$extra='',$add * specifications. * * Warnings: - * * Returned string does not contain html closing tag. - * * This is internal function, use newmail_media_objects() instead + * * @link http://www.w3.org/TR/html4/struct/objects.html#edef-OBJECT W3.org specs * @param string $object object name * @param integer $type media object type @@ -229,6 +520,7 @@ function newmail_media_object($object,$type,$path,$args=array(),$addsuffix=true) * @param array $args media object attributes * @param bool $addsuffix controls addition of suffix to media object url * @return string object html tags and attributes required by selected media type. + * @todo add ogg and svg support */ function newmail_media_object_ie($object,$type,$path,$args=array(),$addsuffix) { $ret_ie=''; @@ -270,7 +562,7 @@ function newmail_media_object_ie($object,$type,$path,$args=array(),$addsuffix) { /** * Creates embed tags of multimedia object - * + * * docs about embed * Apple: http://www.apple.com/quicktime/authoring/embed.html * @@ -311,11 +603,33 @@ function newmail_media_embed($object,$type,$path,$args=array(),$addsuffix=true) .' name="' . $object .'" ' . "\n" .' type="audio/x-wav">' . "\n"; break; + case SM_NEWMAIL_FILETYPE_SVG: + if ($addsuffix) $suffix='.svg'; + $ret_embed='' . "\n"; + break; case SM_NEWMAIL_FILETYPE_OGG: + if ($addsuffix) $suffix='.ogg'; + $ret_embed='' . "\n"; + break; case SM_NEWMAIL_FILETYPE_MP3: - case SM_NEWMAIL_FILETYPE_SVG: + if ($addsuffix) $suffix='.mp3'; + $ret_embed='' . "\n"; + break; default: - $ret_embed=''; + $ret_embed=''; } return $ret_embed; } @@ -323,7 +637,7 @@ function newmail_media_embed($object,$type,$path,$args=array(),$addsuffix=true) /** * Adds closing tags for ie object * Warning: - * * This is internal function, use newmail_media_objects() instead + * * This is internal function, use newmail_media_objects() instead * @param integer $type media object type * @return string closing tag of media object */ @@ -338,7 +652,7 @@ function newmail_media_object_ie_close($type) { case SM_NEWMAIL_FILETYPE_OGG: case SM_NEWMAIL_FILETYPE_SVG: default: - $ret_end=''; + $ret_end=''; } return $ret_end; } @@ -346,7 +660,7 @@ function newmail_media_object_ie_close($type) { /** * Adds closing tags for object * Warning: - * * This is internal function, use newmail_media_objects() instead + * * This is internal function, use newmail_media_objects() instead * @param integer $type media object type * @return string closing tag of media object */ @@ -361,7 +675,7 @@ function newmail_media_object_close($type) { $ret_end="\n"; break; default: - $ret_end=''; + $ret_end=''; } return $ret_end; } @@ -369,7 +683,7 @@ function newmail_media_object_close($type) { /** * Adds closing tags for object * Warning: - * * This is internal function, use newmail_media_objects() instead + * * This is internal function, use newmail_media_objects() instead * @param integer $type media object type * @return string closing tag of media object */ @@ -378,13 +692,13 @@ function newmail_media_embed_close($type) { switch ($type) { case SM_NEWMAIL_FILETYPE_SWF: case SM_NEWMAIL_FILETYPE_WAV: - $ret_end="\n"; - break; case SM_NEWMAIL_FILETYPE_OGG: case SM_NEWMAIL_FILETYPE_MP3: case SM_NEWMAIL_FILETYPE_SVG: + $ret_end="\n"; + break; default: - $ret_end=''; + $ret_end=''; } return $ret_end; } @@ -393,14 +707,14 @@ function newmail_media_embed_close($type) { * Converts media attributes to string * Warning: * * attribute values are automatically sanitized by htmlspecialchars() - * * This is internal function, use newmail_media_objects() instead + * * This is internal function, use newmail_media_objects() instead * @param array $args array with object attributes * @return string string with object attributes */ function newmail_media_prepare_args($args) { $ret_args=''; foreach ($args as $arg => $value) { - $ret_args.= $arg . '="' . htmlspecialchars($value) . '" '; + $ret_args.= $arg . '="' . htmlspecialchars($value) . '" '; } return $ret_args; }