diff options
Diffstat (limited to 'BSF/admin/notification_by_mail.php')
-rw-r--r-- | BSF/admin/notification_by_mail.php | 738 |
1 files changed, 0 insertions, 738 deletions
diff --git a/BSF/admin/notification_by_mail.php b/BSF/admin/notification_by_mail.php deleted file mode 100644 index fc0a2d637..000000000 --- a/BSF/admin/notification_by_mail.php +++ /dev/null @@ -1,738 +0,0 @@ -<?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 |