123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- <?php
- /* For licensing terms, see /license.txt */
- use ChamiloSession as Session;
- /**
- * This script contains the code to edit and send an e-mail to one of
- * the platform's users.
- * It can be called from the JavaScript library email_links.lib.php which
- * overtakes the mailto: links to use the internal interface instead.
- *
- * @author Yannick Warnier <ywarnier@beeznest.org>
- * @author Julio Montoya <gugli100@gmail.com> Updating form with formvalidator
- */
- require_once __DIR__.'/../inc/global.inc.php';
- if (empty(api_get_user_id())) {
- api_not_allowed(true);
- }
- $_user = api_get_user_info();
- $originUrl = Session::read('origin_url');
- if (empty($originUrl)) {
- Session::write('origin_url', $_SERVER['HTTP_REFERER']);
- }
- $action = isset($_GET['action']) ? $_GET['action'] : null;
- $form = new FormValidator('email_editor', 'post');
- $form->addElement('hidden', 'dest');
- $form->addElement('text', 'email_address', get_lang('Receiver'));
- $form->addElement('text', 'email_title', get_lang('Subject'));
- $form->freeze('email_address');
- $form->addElement('textarea', 'email_text', get_lang('E-mail content'), ['rows' => '6']);
- $form->addRule('email_address', get_lang('Required field'), 'required');
- $form->addRule('email_title', get_lang('Required field'), 'required');
- $form->addRule('email_text', get_lang('Required field'), 'required');
- $form->addRule('email_address', get_lang('The email address is not complete or contains some invalid characters'), 'email');
- $form->addButtonSend(get_lang('Send mail'));
- switch ($action) {
- case 'subscribe_me_to_session':
- $sessionName = isset($_GET['session']) ? Security::remove_XSS($_GET['session']) : null;
- $objTemplate = new Template();
- $objTemplate->assign('session_name', $sessionName);
- $objTemplate->assign('user', api_get_user_info());
- $mailTemplate = $objTemplate->get_template('mail/subscribe_me_to_session.tpl');
- $emailDest = api_get_setting('emailAdministrator');
- $emailTitle = get_lang('Request subscription');
- $emailText = $objTemplate->fetch($mailTemplate);
- break;
- default:
- $emailDest = isset($_REQUEST['dest']) ? Security::remove_XSS($_REQUEST['dest']) : '';
- $emailTitle = isset($_REQUEST['subject']) ? Security::remove_XSS($_REQUEST['subject']) : '';
- $emailText = isset($_REQUEST['body']) ? Security::remove_XSS($_REQUEST['body']) : '';
- break;
- }
- $defaults = [
- 'dest' => $emailDest,
- 'email_address' => $emailDest,
- 'email_title' => $emailTitle,
- 'email_text' => $emailText,
- ];
- $form->setDefaults($defaults);
- if ($form->validate()) {
- $values = $form->getSubmitValues();
- $text = Security::remove_XSS($values['email_text'])."\n\n---\n".get_lang('E-mail sent from the platform').' '.api_get_path(WEB_PATH);
- $email_administrator = Security::remove_XSS($values['dest']);
- $title = Security::remove_XSS($values['email_title']);
- if (!empty($_user['mail'])) {
- api_mail_html(
- '',
- $email_administrator,
- $title,
- $text,
- api_get_person_name($_user['firstname'], $_user['lastname']),
- '',
- [
- 'reply_to' => [
- 'mail' => $_user['mail'],
- 'name' => api_get_person_name($_user['firstname'], $_user['lastname']),
- ],
- ]
- );
- } else {
- api_mail_html(
- '',
- $email_administrator,
- $title,
- $text,
- get_lang('Anonymous')
- );
- }
- $orig = Session::read('origin_url');
- Session::erase('origin_url');
- header('Location:'.$orig);
- exit;
- }
- Display::display_header(get_lang('Send email'));
- $form->display();
- Display::display_footer();
|