diff options
Diffstat (limited to 'BSF/admin/notification_by_mail.php')
-rw-r--r-- | BSF/admin/notification_by_mail.php | 738 |
1 files changed, 738 insertions, 0 deletions
diff --git a/BSF/admin/notification_by_mail.php b/BSF/admin/notification_by_mail.php new file mode 100644 index 000000000..fc0a2d637 --- /dev/null +++ b/BSF/admin/notification_by_mail.php @@ -0,0 +1,738 @@ +<?php +// +-----------------------------------------------------------------------+ +// | Piwigo - a PHP based picture gallery | +// +-----------------------------------------------------------------------+ +// | Copyright(C) 2008 Piwigo Team http://piwigo.org | +// | Copyright(C) 2003-2008 PhpWebGallery Team http://phpwebgallery.net | +// | Copyright(C) 2002-2003 Pierrick LE GALL http://le-gall.net/pierrick | +// +-----------------------------------------------------------------------+ +// | This program is free software; you can redistribute it and/or modify | +// | it under the terms of the GNU General Public License as published by | +// | the Free Software Foundation | +// | | +// | This program is distributed in the hope that it will be useful, but | +// | WITHOUT ANY WARRANTY; without even the implied warranty of | +// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | +// | General Public License for more details. | +// | | +// | You should have received a copy of the GNU General Public License | +// | along with this program; if not, write to the Free Software | +// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, | +// | USA. | +// +-----------------------------------------------------------------------+ + +// +-----------------------------------------------------------------------+ +// | include | +// +-----------------------------------------------------------------------+ + +if (!defined('PHPWG_ROOT_PATH')) +{ + die ("Hacking attempt!"); +} + +include_once(PHPWG_ROOT_PATH.'admin/include/functions.php'); +include_once(PHPWG_ROOT_PATH.'admin/include/functions_notification_by_mail.inc.php'); +include_once(PHPWG_ROOT_PATH.'admin/include/tabsheet.class.php'); +include_once(PHPWG_ROOT_PATH.'include/common.inc.php'); +include_once(PHPWG_ROOT_PATH.'include/functions_notification.inc.php'); +include_once(PHPWG_ROOT_PATH.'include/functions_mail.inc.php'); + +// +-----------------------------------------------------------------------+ +// | Check Access and exit when user status is not ok | +// +-----------------------------------------------------------------------+ +check_status(ACCESS_ADMINISTRATOR); + +// +-----------------------------------------------------------------------+ +// | Initialization | +// +-----------------------------------------------------------------------+ +$base_url = get_root_url().'admin.php'; +$must_repost = false; + +// +-----------------------------------------------------------------------+ +// | functions | +// +-----------------------------------------------------------------------+ + +/* + * Do timeout treatment in order to finish to send mails + * + * @param $post_keyname: key of check_key post array + * @param check_key_treated: array of check_key treated + * @return none + */ +function do_timeout_treatment($post_keyname, $check_key_treated = array()) +{ + global $env_nbm, $base_url, $page, $must_repost; + + if ($env_nbm['is_sendmail_timeout']) + { + if (isset($_POST[$post_keyname])) + { + $post_count = count($_POST[$post_keyname]); + $treated_count = count($check_key_treated); + if ($treated_count != 0) + { + $time_refresh = ceil((get_moment() - $env_nbm['start_time']) * $post_count / $treated_count); + } + else + { + $time_refresh = 0; + } + $_POST[$post_keyname] = array_diff($_POST[$post_keyname], $check_key_treated); + + $must_repost = true; + array_push($page['errors'], + l10n_dec('nbm_background_treatment_redirect_second', + 'nbm_background_treatment_redirect_seconds', + $time_refresh)); + } + } + +} + +/* + * Get the authorized_status for each tab + * return corresponding status + */ +function get_tab_status($mode) +{ + $result = ACCESS_WEBMASTER; + switch ($mode) + { + case 'param': + case 'subscribe': + $result = ACCESS_WEBMASTER; + break; + case 'send': + $result = ACCESS_ADMINISTRATOR; + break; + default: + $result = ACCESS_WEBMASTER; + break; + } + return $result; +} + +/* + * Inserting News users + */ +function insert_new_data_user_mail_notification() +{ + global $conf, $page, $env_nbm; + + // Set null mail_address empty + $query = ' +update + '.USERS_TABLE.' +set + '.$conf['user_fields']['email'].' = null +where + trim('.$conf['user_fields']['email'].') = \'\';'; + pwg_query($query); + + // null mail_address are not selected in the list + $query = ' +select + u.'.$conf['user_fields']['id'].' as user_id, + u.'.$conf['user_fields']['username'].' as username, + u.'.$conf['user_fields']['email'].' as mail_address +from + '.USERS_TABLE.' as u left join '.USER_MAIL_NOTIFICATION_TABLE.' as m on u.'.$conf['user_fields']['id'].' = m.user_id +where + u.'.$conf['user_fields']['email'].' is not null and + m.user_id is null +order by + user_id;'; + + $result = pwg_query($query); + + if (mysql_num_rows($result) > 0) + { + $inserts = array(); + $check_key_list = array(); + + while ($nbm_user = mysql_fetch_array($result)) + { + // Calculate key + $nbm_user['check_key'] = find_available_check_key(); + + // Save key + array_push($check_key_list, $nbm_user['check_key']); + + // Insert new nbm_users + array_push + ( + $inserts, + array + ( + 'user_id' => $nbm_user['user_id'], + 'check_key' => $nbm_user['check_key'], + 'enabled' => 'false' // By default if false, set to true with specific functions + ) + ); + + array_push + ( + $page['infos'], + sprintf( + l10n('nbm_user_x_added'), + $nbm_user['username'], + get_email_address_as_display_text($nbm_user['mail_address']) + ) + ); + } + + // Insert new nbm_users + mass_inserts(USER_MAIL_NOTIFICATION_TABLE, array('user_id', 'check_key', 'enabled'), $inserts); + // Update field enabled with specific function + $check_key_treated = do_subscribe_unsubscribe_notification_by_mail + ( + true, + $conf['nbm_default_value_user_enabled'], + $check_key_list + ); + + // On timeout simulate like tabsheet send + if ($env_nbm['is_sendmail_timeout']) + { + $quoted_check_key_list = quote_check_key_list(array_diff($check_key_list, $check_key_treated)); + if (count($quoted_check_key_list) != 0 ) + { + $query = 'delete from '.USER_MAIL_NOTIFICATION_TABLE.' where check_key in ('.implode(",", $quoted_check_key_list).');'; + $result = pwg_query($query); + + redirect($base_url.get_query_string_diff(array(), false), l10n('nbm_redirect_msg')); + } + } + } +} + +/* + * Apply global functions to mail content + * return customize mail content rendered + */ +function render_global_customize_mail_content($customize_mail_content) +{ + global $conf; + + if ($conf['nbm_send_html_mail'] and !(strpos($customize_mail_content, '<') === 0)) + { + // On HTML mail, detects if the content are HTML format. + // If it's plain text format, convert content to readable HTML + return nl2br(htmlspecialchars($customize_mail_content)); + } + else + { + return $customize_mail_content; + } +} + +/* + * Send mail for notification to all users + * Return list of "selected" users for 'list_to_send' + * Return list of "treated" check_key for 'send' + */ +function do_action_send_mail_notification($action = 'list_to_send', $check_key_list = array(), $customize_mail_content = '') +{ + global $conf, $page, $user, $lang_info, $lang, $env_nbm; + $return_list = array(); + + if (in_array($action, array('list_to_send', 'send'))) + { + list($dbnow) = mysql_fetch_row(pwg_query('SELECT NOW();')); + + $is_action_send = ($action == 'send'); + + // disabled and null mail_address are not selected in the list + $data_users = get_user_notifications('send', $check_key_list); + + // List all if it's define on options or on timeout + $is_list_all_without_test = ($env_nbm['is_sendmail_timeout'] or $conf['nbm_list_all_enabled_users_to_send']); + + // Check if exist news to list user or send mails + if ((!$is_list_all_without_test) or ($is_action_send)) + { + if (count($data_users) > 0) + { + $datas = array(); + + if (!isset($customize_mail_content)) + { + $customize_mail_content = $conf['nbm_complementary_mail_content']; + } + + $customize_mail_content = + trigger_event('nbm_render_global_customize_mail_content', $customize_mail_content); + + + // Prepare message after change language + if ($is_action_send) + { + $msg_break_timeout = l10n('nbm_break_timeout_send_mail'); + } + else + { + $msg_break_timeout = l10n('nbm_break_timeout_list_user'); + } + + // Begin nbm users environment + begin_users_env_nbm($is_action_send); + + foreach ($data_users as $nbm_user) + { + if ((!$is_action_send) and check_sendmail_timeout()) + { + // Stop fill list on 'list_to_send', if the quota is override + array_push($page['infos'], $msg_break_timeout); + break; + } + if (($is_action_send) and check_sendmail_timeout()) + { + // Stop fill list on 'send', if the quota is override + array_push($page['errors'], $msg_break_timeout); + break; + } + + // set env nbm user + set_user_on_env_nbm($nbm_user, $is_action_send); + + if ($is_action_send) + { + set_make_full_url(); + // Fill return list of "treated" check_key for 'send' + array_push($return_list, $nbm_user['check_key']); + + if ($conf['nbm_send_detailed_content']) + { + $news = news($nbm_user['last_send'], $dbnow, false, $conf['nbm_send_html_mail']); + $exist_data = count($news) > 0; + } + else + { + $exist_data = news_exists($nbm_user['last_send'], $dbnow); + } + + if ($exist_data) + { + $subject = '['.$conf['gallery_title'].']: '.l10n('nbm_object_news'); + + // Assign current var for nbm mail + assign_vars_nbm_mail_content($nbm_user); + + if (!is_null($nbm_user['last_send'])) + { + $env_nbm['mail_template']->assign + ( + 'content_new_elements_between', + array + ( + 'DATE_BETWEEN_1' => $nbm_user['last_send'], + 'DATE_BETWEEN_2' => $dbnow, + ) + ); + } + else + { + $env_nbm['mail_template']->assign + ( + 'content_new_elements_single', + array + ( + 'DATE_SINGLE' => $dbnow, + ) + ); + } + + if ($conf['nbm_send_detailed_content']) + { + $env_nbm['mail_template']->assign('global_new_lines', $news); + } + + $nbm_user_customize_mail_content = + trigger_event('nbm_render_user_customize_mail_content', + $customize_mail_content, $nbm_user); + if (!empty($nbm_user_customize_mail_content)) + { + $env_nbm['mail_template']->assign + ( + 'custom_mail_content', $nbm_user_customize_mail_content + ); + } + + if ($conf['nbm_send_html_mail'] and $conf['nbm_send_recent_post_dates']) + { + $recent_post_dates = get_recent_post_dates_array( + $conf['recent_post_dates']['NBM']); + foreach ($recent_post_dates as $date_detail) + { + $env_nbm['mail_template']->append + ( + 'recent_posts', + array + ( + 'TITLE' => get_title_recent_post_date($date_detail), + 'HTML_DATA' => get_html_description_recent_post_date($date_detail) + ) + ); + } + } + + $env_nbm['mail_template']->assign + ( + array + ( + 'GOTO_GALLERY_TITLE' => $conf['gallery_title'], + 'GOTO_GALLERY_URL' => $conf['gallery_url'], + 'SEND_AS_NAME' => $env_nbm['send_as_name'], + ) + ); + + if (pwg_mail + ( + format_email($nbm_user['username'], $nbm_user['mail_address']), + array + ( + 'from' => $env_nbm['send_as_mail_formated'], + 'subject' => $subject, + 'email_format' => $env_nbm['email_format'], + 'content' => $env_nbm['mail_template']->parse('notification_by_mail', true), + 'content_format' => $env_nbm['email_format'], + 'template' => $nbm_user['template'], + 'theme' => $nbm_user['theme'] + ) + )) + { + inc_mail_sent_success($nbm_user); + + $data = array('user_id' => $nbm_user['user_id'], + 'last_send' => $dbnow); + array_push($datas, $data); + } + else + { + inc_mail_sent_failed($nbm_user); + } + + unset_make_full_url(); + } + } + else + { + if (news_exists($nbm_user['last_send'], $dbnow)) + { + // Fill return list of "selected" users for 'list_to_send' + array_push($return_list, $nbm_user); + } + } + + // unset env nbm user + unset_user_on_env_nbm(); + } + + // Restore nbm environment + end_users_env_nbm(); + + if ($is_action_send) + { + mass_updates( + USER_MAIL_NOTIFICATION_TABLE, + array( + 'primary' => array('user_id'), + 'update' => array('last_send') + ), + $datas + ); + + display_counter_info(); + } + } + else + { + if ($is_action_send) + { + array_push($page['errors'], l10n('nbm_no_user_to send_notifications_by_mail')); + } + } + } + else + { + // Quick List, don't check news + // Fill return list of "selected" users for 'list_to_send' + $return_list = $data_users; + } + } + + // Return list of "selected" users for 'list_to_send' + // Return list of "treated" check_key for 'send' + return $return_list; +} + +// +-----------------------------------------------------------------------+ +// | Main | +// +-----------------------------------------------------------------------+ +if (!isset($_GET['mode'])) +{ + $page['mode'] = 'send'; +} +else +{ + $page['mode'] = $_GET['mode']; +} + +// +-----------------------------------------------------------------------+ +// | Check Access and exit when user status is not ok | +// +-----------------------------------------------------------------------+ +check_status(get_tab_status($page['mode'])); + + +// +-----------------------------------------------------------------------+ +// | Add event handler | +// +-----------------------------------------------------------------------+ +add_event_handler('nbm_render_global_customize_mail_content', 'render_global_customize_mail_content'); +trigger_action('nbm_event_handler_added'); + + +// +-----------------------------------------------------------------------+ +// | Insert new users with mails | +// +-----------------------------------------------------------------------+ +if (!isset($_POST) or (count($_POST) ==0)) +{ + // No insert data in post mode + insert_new_data_user_mail_notification(); +} + +// +-----------------------------------------------------------------------+ +// | Treatment of tab post | +// +-----------------------------------------------------------------------+ +switch ($page['mode']) +{ + case 'param' : + { + if (isset($_POST['param_submit']) and !is_adviser()) + { + $updated_param_count = 0; + // Update param + $result = pwg_query('select param, value from '.CONFIG_TABLE.' where param like \'nbm\\_%\''); + while ($nbm_user = mysql_fetch_array($result)) + { + if (isset($_POST[$nbm_user['param']])) + { + $value = $_POST[$nbm_user['param']]; + + $query = ' +update +'.CONFIG_TABLE.' +set + value = \''. str_replace("\'", "''", $value).'\' +where + param = \''.$nbm_user['param'].'\';'; + pwg_query($query); + $updated_param_count += 1; + } + } + + array_push($page['infos'], + l10n_dec('nbm_updated_param_count', 'nbm_updated_params_count', + $updated_param_count)); + + // Reload conf with new values + load_conf_from_db('param like \'nbm\\_%\''); + } + } + case 'subscribe' : + { + if (!is_adviser()) + { + if (isset($_POST['falsify']) and isset($_POST['cat_true'])) + { + $check_key_treated = unsubscribe_notification_by_mail(true, $_POST['cat_true']); + do_timeout_treatment('cat_true', $check_key_treated); + } + else + if (isset($_POST['trueify']) and isset($_POST['cat_false'])) + { + $check_key_treated = subscribe_notification_by_mail(true, $_POST['cat_false']); + do_timeout_treatment('cat_false', $check_key_treated); + } + } + break; + } + + case 'send' : + { + if (isset($_POST['send_submit']) and isset($_POST['send_selection']) and isset($_POST['send_customize_mail_content']) and !is_adviser()) + { + $check_key_treated = do_action_send_mail_notification('send', $_POST['send_selection'], stripslashes($_POST['send_customize_mail_content'])); + do_timeout_treatment('send_selection', $check_key_treated); + } + } +} + +// +-----------------------------------------------------------------------+ +// | template initialization | +// +-----------------------------------------------------------------------+ +$template->set_filenames +( + array + ( + 'double_select' => 'admin/double_select.tpl', + 'notification_by_mail'=>'admin/notification_by_mail.tpl' + ) +); + +$template->assign +( + array + ( + 'U_HELP' => add_url_params(get_root_url().'popuphelp.php', array('page' => 'notification_by_mail')), + 'F_ACTION'=> $base_url.get_query_string_diff(array()) + ) +); + +if (is_autorize_status(ACCESS_WEBMASTER)) +{ + // TabSheet + $tabsheet = new tabsheet(); + // TabSheet initialization + $tabsheet->add('param', l10n('nbm_param_mode'), + add_url_params($base_url.get_query_string_diff(array('mode', 'select')), + array('mode' => 'param'))); + $tabsheet->add('subscribe', l10n('nbm_subscribe_mode'), + add_url_params($base_url.get_query_string_diff(array('mode', 'select')), + array('mode' => 'subscribe'))); + $tabsheet->add('send', l10n('nbm_send_mode'), + add_url_params($base_url.get_query_string_diff(array('mode', 'select')), + array('mode' => 'send'))); + // TabSheet selection + $tabsheet->select($page['mode']); + // Assign tabsheet to template + $tabsheet->assign(); +} + +if ($must_repost) +{ + // Get name of submit button + $repost_submit_name = ''; + if (isset($_POST['falsify'])) + { + $repost_submit_name = 'falsify'; + } + elseif (isset($_POST['trueify'])) + { + $repost_submit_name = 'trueify'; + } + elseif (isset($_POST['send_submit'])) + { + $repost_submit_name = 'send_submit'; + } + + $template->assign('REPOST_SUBMIT_NAME', $repost_submit_name); +} + +switch ($page['mode']) +{ + case 'param' : + { + $template->assign( + $page['mode'], + array( + 'SEND_HTML_MAIL' => $conf['nbm_send_html_mail'], + 'SEND_MAIL_AS' => $conf['nbm_send_mail_as'], + 'SEND_DETAILED_CONTENT' => $conf['nbm_send_detailed_content'], + 'COMPLEMENTARY_MAIL_CONTENT' => $conf['nbm_complementary_mail_content'], + 'SEND_RECENT_POST_DATES' => $conf['nbm_send_recent_post_dates'], + )); + break; + } + + case 'subscribe' : + { + $template->assign( $page['mode'], true ); + + $template->assign( + array( + 'L_CAT_OPTIONS_TRUE' => l10n('nbm_subscribe_col'), + 'L_CAT_OPTIONS_FALSE' => l10n('nbm_unsubscribe_col') + ) + ); + + $data_users = get_user_notifications('subscribe'); + + $opt_true = array(); + $opt_true_selected = array(); + $opt_false = array(); + $opt_false_selected = array(); + foreach ($data_users as $nbm_user) + { + if (get_boolean($nbm_user['enabled'])) + { + $opt_true[ $nbm_user['check_key'] ] = $nbm_user['username'].'['.get_email_address_as_display_text($nbm_user['mail_address']).']'; + if ((isset($_POST['falsify']) and isset($_POST['cat_true']) and in_array($nbm_user['check_key'], $_POST['cat_true']))) + { + $opt_true_selected[] = $nbm_user['check_key']; + } + } + else + { + $opt_false[ $nbm_user['check_key'] ] = $nbm_user['username'].'['.get_email_address_as_display_text($nbm_user['mail_address']).']'; + if (isset($_POST['trueify']) and isset($_POST['cat_false']) and in_array($nbm_user['check_key'], $_POST['cat_false'])) + { + $opt_false_selected[] = $nbm_user['check_key']; + } + } + } + $template->assign( array( + 'category_option_true' => $opt_true, + 'category_option_true_selected' => $opt_true_selected, + 'category_option_false' => $opt_false, + 'category_option_false_selected' => $opt_false_selected, + ) + ); + $template->assign_var_from_handle('DOUBLE_SELECT', 'double_select'); + break; + } + + case 'send' : + { + $tpl_var = array('users'=> array() ); + + $data_users = do_action_send_mail_notification('list_to_send'); + + $tpl_var['CUSTOMIZE_MAIL_CONTENT'] = + isset($_POST['send_customize_mail_content']) + ? stripslashes($_POST['send_customize_mail_content']) + : $conf['nbm_complementary_mail_content']; + + if (count($data_users)) + { + foreach ($data_users as $nbm_user) + { + if ( + (!$must_repost) or // Not timeout, normal treatment + (($must_repost) and in_array($nbm_user['check_key'], $_POST['send_selection'])) // Must be repost, show only user to send + ) + { + $tpl_var['users'][] = + array( + 'ID' => $nbm_user['check_key'], + 'CHECKED' => ( // not check if not selected, on init select<all + isset($_POST['send_selection']) and // not init + !in_array($nbm_user['check_key'], $_POST['send_selection']) // not selected + ) ? '' : 'checked="checked"', + 'USERNAME'=> $nbm_user['username'], + 'EMAIL' => get_email_address_as_display_text($nbm_user['mail_address']), + 'LAST_SEND'=> $nbm_user['last_send'] + ); + } + } + } + $template->assign($page['mode'], $tpl_var); + break; + } +} + +// +-----------------------------------------------------------------------+ +// | Sending html code | +// +-----------------------------------------------------------------------+ +$template->assign_var_from_handle('ADMIN_CONTENT', 'notification_by_mail'); + +?>
\ No newline at end of file |