예제 #1
0
 /**
  * Create template parser
  *
  * @return template
  */
 function &set_template($params = array())
 {
     require_once dirname(__FILE__) . '/vivvo_xml_template.php';
     $sm = vivvo_lite_site::get_instance();
     if (!$this->_parent_template) {
         $this->_parent_template = $sm->get_template();
     }
     $this->_template = new template(null, $this->_parent_template);
     if (!empty($params)) {
         if (!empty($params['template']) && file_exists(VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $params['template'])) {
             $this->_template->set_template_file(VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $params['template']);
             $sm->debug_push("tpl:", VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $params['template']);
         } elseif (!empty($params['template']) && file_exists(VIVVO_FS_TEMPLATE_ROOT . $params['template'])) {
             $this->_template->set_template_file(VIVVO_FS_TEMPLATE_ROOT . $params['template']);
             $sm->debug_push("tpl:", VIVVO_FS_TEMPLATE_ROOT . $params['template']);
         } elseif (isset($params['template_string'])) {
             $this->_template->set_string_template($params['template_string']);
         } else {
             $this->_template->set_template_file(VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $this->_default_template_file);
             $sm->debug_push("tpl:", VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $this->_default_template_file);
         }
     } else {
         $this->_template->set_template_file(VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $this->_default_template_file);
         $sm->debug_push("tpl:", VIVVO_FS_TEMPLATE_ROOT . VIVVO_TEMPLATE_DIR . $this->_default_template_file);
     }
     return $this->_template;
 }
예제 #2
0
 function forgot_mail($username, $email)
 {
     if (!$this->check_token()) {
         return false;
     }
     if (!vivvo_hooks_manager::call('login_forgotMail', array(&$username, &$email))) {
         return vivvo_hooks_manager::get_status();
     }
     if (isset($_SESSION['vivvo']['register_time']) && $_SESSION['vivvo']['register_time'] + 60 > VIVVO_START_TIME) {
         $this->set_error_code(2755);
         return false;
     }
     require_once VIVVO_FS_INSTALL_ROOT . 'lib/vivvo/core/Users.class.php';
     $lang = vivvo_lang::get_instance();
     $user_list = new Users_list();
     if (!$username && !$email) {
         $this->set_error_code(2712);
         return false;
     } else {
         if ($username) {
             $user_list->search(array('search_username' => $username));
             $user = current($user_list->list);
         } elseif ($email) {
             $user_list->search(array('search_email_address' => $email));
             $user = current($user_list->list);
         }
         if ($user) {
             $search = array('(', ')', '<', '>', '@', ';', ':', '\\', '"', '.', '[', ']');
             $replace = array(' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ');
             $vivvo_website_title = str_replace($search, $replace, VIVVO_WEBSITE_TITLE);
             $vivvo_website_title = "=?UTF-8?B?" . base64_encode($vivvo_website_title) . "?=";
             $headers['From'] = $vivvo_website_title . '<' . VIVVO_EMAIL_SEND_FROM . '>';
             $recipients = array();
             $recipients[] = $user->email_address;
             $headers['Subject'] = "=?UTF-8?B?" . base64_encode(VIVVO_EMAIL_FORGOT_SUBJECT) . "?=";
             $headers['Content-Type'] = "text/plain; charset=UTF-8;";
             $body_template = new template();
             $template_sting = xml_template_node::xmlentities_decode(VIVVO_EMAIL_FORGOT_BODY);
             $body_template->set_string_template($template_sting);
             $confirm_url = make_absolute_url('login.html?activation_key=' . md5($user->username . $user->email_address . $user->password));
             $body_template->assign('activation_url', $confirm_url);
             $body_template->assign('user', $user);
             $body = $body_template->get_output() . "\n\n";
             if (VIVVO_EMAIL_SMTP_PHP == 1) {
                 $mail_object = new Mail();
                 $mail_object->send($recipients, $headers, $body);
             } else {
                 $mail_options['driver'] = 'smtp';
                 $mail_options['host'] = VIVVO_EMAIL_SMTP_HOST;
                 $mail_options['port'] = VIVVO_EMAIL_SMTP_PORT;
                 $mail_options['localhost'] = 'localhost';
                 if (VIVVO_EMAIL_SMTP_PASSWORD != '' && VIVVO_EMAIL_SMTP_USERNAME != '') {
                     $mail_options['auth'] = true;
                     $mail_options['username'] = VIVVO_EMAIL_SMTP_PASSWORD;
                     $mail_options['password'] = VIVVO_EMAIL_SMTP_USERNAME;
                 } else {
                     $mail_options['auth'] = false;
                     $mail_options['username'] = '';
                     $mail_options['password'] = '';
                 }
                 $mail_object = Mail::factory('smtp', $mail_options);
                 $mail_object->send($recipients, $headers, $body);
             }
         }
         $_SESSION['vivvo']['register_time'] = time();
         return true;
     }
 }
예제 #3
0
 /**
  * Creates string output for every VTE template element, and common html tag,
  * that need to be parsed for the final HTML content.
  *
  * @return string    Parsed HTML string
  */
 function get_output()
 {
     $output = '';
     if ($this->_type == 'CDATA' || $this->_type == 'after_schock') {
         return $this->_value;
     }
     // non-vte tags
     if (substr($this->_type, 0, 4) != 'vte:' and $this->_type != 'comment') {
         return $this->get_output_default();
     }
     if ($this->_type == 'comment') {
         $output = '';
         if (preg_match('/\\{/', $this->_value)) {
             $split_tpl = preg_split('/({.*?})/', $this->_value, -1, PREG_SPLIT_DELIM_CAPTURE);
             if (is_array($split_tpl) && !empty($split_tpl)) {
                 foreach ($split_tpl as $v) {
                     $output .= preg_match('/\\{/', trim($v)) ? $this->param_value($v) : $v;
                 }
                 unset($v);
             }
         } else {
             $output .= $this->_value;
         }
         return $output;
     }
     switch ($this->_type) {
         case 'vte:else':
             return '';
         case 'vte:if':
             $countinue = false;
             if (!empty($this->attributes['isset'])) {
                 $countinue = $this->_template->has_value($this->attributes['isset']);
             } else {
                 if (preg_match('/(\'[^\']*\'|\\"[^"]*\\"|-?\\d+|true|false|\\{[\\w\\.\\[\\]\\|:,\\-]+\\})\\s*(=|==|!=|&lt;|&gt;|&lt;=|&gt;=|lt|lte|gt|gte|eq|neq|in)\\s*(\'[^\']*\'|\\"[^"]*\\"|-?\\d+|true|false|\\{[\\w\\.\\[\\]\\|:,\\-]+\\})/i', $this->attributes['test'], $if_statment)) {
                     $variable =& $this->param_value($if_statment[1]);
                     $value =& $this->param_value($if_statment[3]);
                     switch ($if_statment[2]) {
                         case 'eq':
                         case '=':
                         case '==':
                             if ($variable == $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'neq':
                         case '!=':
                             if ($variable != $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'lt':
                         case '&lt;':
                             if ($variable < $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'lte':
                         case '&lt;=':
                             if ($variable <= $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'gt':
                         case '&gt;':
                             if ($variable > $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'gte':
                         case '&gt;=':
                             if ($variable >= $value) {
                                 $countinue = true;
                             }
                             break;
                         case 'in':
                             if (is_string($variable) or is_numeric($variable) or is_bool($variable)) {
                                 if (is_string($value) and $value != '') {
                                     $value = explode(',', $value);
                                     if (in_array($variable, $value)) {
                                         $countinue = true;
                                     }
                                 } elseif (is_array($value) and !empty($value)) {
                                     if (in_array($variable, $value)) {
                                         $countinue = true;
                                     }
                                 }
                             }
                             break;
                     }
                 } elseif (preg_match('/^!(\\{[\\*\\w\\.\\[\\]\\|:,\\-\']+\\})$/i', $this->attributes['test'], $if_statment)) {
                     $variable =& $this->param_value($if_statment[1]);
                     if (empty($variable)) {
                         $countinue = true;
                     }
                 } elseif (preg_match('/^(\\{[\\*\\w\\.\\[\\]\\|:,\\-\']+\\})$/i', $this->attributes['test'], $if_statment)) {
                     $variable =& $this->param_value($if_statment[1]);
                     if (!empty($variable)) {
                         $countinue = true;
                     }
                 }
             }
             if ($countinue) {
                 //$output .= $this->nodes_output();
                 if (is_array($this->_nodes)) {
                     foreach ($this->_nodes as $k => $node) {
                         $output .= $this->_nodes[$k]->get_output();
                     }
                 }
             } else {
                 $else_node =& $this->get_child_by_tag('vte:else');
                 if ($else_node) {
                     //$output = $else_node->nodes_output();
                     $output = '';
                     if (is_array($else_node->_nodes)) {
                         foreach ($else_node->_nodes as $k => $node) {
                             $output .= $else_node->_nodes[$k]->get_output();
                         }
                     }
                 }
             }
             return $output;
         case 'vte:for':
             $output = '';
             if (isset($this->attributes['from'])) {
                 $array = $this->param_value($this->attributes['from']);
             } else {
                 $array = false;
             }
             $key = false;
             if (isset($this->attributes['key'])) {
                 $key = $this->attributes['key'];
             }
             $start = isset($this->attributes['start']) ? intval($this->get_attribute_output('start')) : 1;
             $step = isset($this->attributes['step']) ? intval($this->get_attribute_output('step')) : 1;
             if ($step == 0) {
                 $step = 1;
             }
             if (is_array($array) && !empty($array)) {
                 $count = count($array);
                 $loop = isset($this->attributes['loop']) ? intval($this->get_attribute_output('loop')) + $start : $count;
             } else {
                 $loop = isset($this->attributes['loop']) ? intval($this->get_attribute_output('loop')) + $start : 0;
             }
             if ($key !== false && $loop != 0) {
                 for ($j = $start; $j <= $loop; $j = $j + $step) {
                     $this->_template->assign($key, $j);
                     $this->_template->assign($key . '_count', $loop);
                     if (is_array($this->_nodes)) {
                         foreach ($this->_nodes as $k => $node) {
                             $output .= $this->_nodes[$k]->get_output();
                         }
                     }
                 }
             }
             return $output;
         case 'vte:foreach':
             if (isset($this->attributes['from'])) {
                 $array = $this->param_value($this->attributes['from']);
             } else {
                 $array = false;
             }
             $key = false;
             if (isset($this->attributes['key'])) {
                 $key = $this->attributes['key'];
             }
             if (is_array($array) && !empty($array)) {
                 $item_name = $this->attributes['item'];
                 $count = count($array);
                 $start = isset($this->attributes['start']) ? intval($this->get_attribute_output('start')) : 1;
                 $loop = isset($this->attributes['loop']) ? intval($this->get_attribute_output('loop')) + $start - 1 : $count;
                 $step = isset($this->attributes['step']) ? intval($this->get_attribute_output('step')) : 1;
                 if ($start > $count) {
                     return '';
                 }
                 $index = 0;
                 $internal_index = $start;
                 reset($array);
                 do {
                     $current_key = key($array);
                     if ($index >= $start - 1 && $index < $loop) {
                         if ($key) {
                             $this->_template->assign($key, $internal_index);
                             $this->_template->assign($key . '_count', $loop);
                         }
                         $this->_template->assign($item_name, $array[$current_key]);
                         //$output .= $this->nodes_output();
                         if (is_array($this->_nodes)) {
                             foreach ($this->_nodes as $k => $node) {
                                 $output .= $this->_nodes[$k]->get_output();
                             }
                         }
                         $internal_index += $step;
                     }
                     $index++;
                     for ($i = 1; $i < $step; $i++) {
                         if (!next($array)) {
                             break;
                         }
                         $index++;
                     }
                 } while (next($array));
             } else {
                 $else_node = $this->get_child_by_tag('vte:else');
                 if ($else_node) {
                     $output = '';
                     if (is_array($else_node->_nodes)) {
                         foreach ($else_node->_nodes as $k => $node) {
                             $output .= $else_node->_nodes[$k]->get_output();
                         }
                     }
                 }
             }
             return $output;
         case 'vte:literal':
             $output = '';
             if (is_array($this->_nodes) && !empty($this->_nodes)) {
                 foreach ($this->_nodes as $k => $node) {
                     $output .= $this->_nodes[$k]->get_literal_output();
                 }
             }
             return $output;
         case 'vte:variable':
             $output = '';
             $content = '';
             if (isset($this->attributes['name']) && !empty($this->attributes['name'])) {
                 $literal = isset($this->attributes['literal']) && $this->attributes['literal'] == 1;
                 if (isset($this->attributes['value'])) {
                     $content = $literal ? $this->attributes['value'] : $this->get_attribute_output('value');
                 } elseif (is_array($this->_nodes) && !empty($this->_nodes)) {
                     foreach ($this->_nodes as $k => $node) {
                         $content .= $literal ? $this->_nodes[$k]->get_literal_output() : $this->_nodes[$k]->get_output();
                     }
                 }
                 if (isset($this->attributes['json']) && $this->attributes['json'] == 1) {
                     $content = json_decode($content, true);
                 }
                 if (isset($this->attributes['global']) && $this->attributes['global'] == 1) {
                     vivvo_lite_site::get_instance()->get_template()->assign($this->attributes['name'], $content);
                 } else {
                     $this->_template->assign($this->attributes['name'], $content);
                 }
             }
             return $output;
         case 'vte:header':
             $output = '';
             if (isset($this->attributes['type'])) {
                 $sm =& $this->_template->get_site_manager();
                 $header =& $sm->get_header_manager();
                 if ($this->attributes['type'] == 'script') {
                     if (isset($this->attributes['href'])) {
                         $header->add_script($this->get_attribute_output('href'));
                     }
                 } elseif ($this->attributes['type'] == 'css') {
                     if (isset($this->attributes['href'])) {
                         $media = 'screen';
                         if (isset($this->attributes['media'])) {
                             $media = $this->attributes['media'];
                         }
                         $header->add_css($this->get_attribute_output('href'), $media);
                     }
                 } elseif ($this->attributes['type'] == 'description') {
                     $header->add_description($this->get_attribute_output('value'));
                 } elseif ($this->attributes['type'] == 'keyword') {
                     $header->add_keyword($this->get_attribute_output('value'));
                 } elseif ($this->attributes['type'] == 'feed') {
                     if (isset($this->attributes['href'])) {
                         $title = '';
                         if (isset($this->attributes['title'])) {
                             $title = $this->get_attribute_output('title');
                         }
                         $header->add_rss($this->get_attribute_output('href'), $title);
                     }
                 }
             }
             return $output;
         case 'vte:lang':
             $output = '';
             if (isset($this->attributes['src']) && !empty($this->attributes['src'])) {
                 $sm =& $this->_template->get_site_manager();
                 $lang =& $sm->get_lang();
                 if (defined('VIVVO_ADMIN_LANG')) {
                     $lang->load_lang(VIVVO_ADMIN_LANG, $this->attributes['src']);
                 } else {
                     $lang->load_lang(VIVVO_DEFAULT_LANG, $this->attributes['src']);
                 }
             }
             return $output;
         case 'vte:include':
             $output = '';
             if (isset($this->attributes['file'])) {
                 $cache_output = '';
                 $href = $this->get_attribute_output('file');
                 if (isset($this->attributes['nocache']) && $this->attributes['nocache'] == 1) {
                     $cache_output = '<!--NoCache ' . substr($href, strlen(VIVVO_TEMPLATE_DIR)) . '-->';
                 }
                 if (is_file(VIVVO_FS_TEMPLATE_ROOT . $href)) {
                     $used_file = VIVVO_FS_TEMPLATE_ROOT . $href;
                     $output = file_get_contents(VIVVO_FS_TEMPLATE_ROOT . $href);
                 }
                 if (!isset($this->attributes['parse']) || $this->attributes['parse'] != 'off') {
                     $sm =& $this->_template->get_site_manager();
                     $tmp_tpl =& new template($sm, $this->_template);
                     if (isset($used_file)) {
                         $tmp_tpl->set_template_file($used_file);
                         $sm->debug_push("tpl:", $used_file);
                     }
                     $tmp_tpl->set_string_template($output);
                     if (!empty($this->attributes)) {
                         foreach ($this->attributes as $k => $v) {
                             if (preg_match('/^\\{[^\\}]*\\}$/', $v)) {
                                 $tmp_tpl->assign($k, $this->param_value($v));
                             } else {
                                 $tmp_tpl->assign($k, $this->get_attribute_output($k));
                             }
                         }
                     }
                     $output = $tmp_tpl->get_output();
                     $tmp_tpl->__destruct();
                 }
                 $cache_output .= $output;
                 if (isset($this->attributes['nocache']) && $this->attributes['nocache'] == 1) {
                     $cache_output .= '<!--NoCache-->';
                 }
                 $output = $cache_output;
             } elseif (isset($this->attributes['href'])) {
                 //include url
                 $output = @file_get_contents($this->attributes['href']);
             }
             return $output;
         case 'vte:param':
             return '';
         case 'vte:attribute':
             if (is_a($this->parent, 'xml_template_node')) {
                 $value = trim($this->nodes_output());
                 $name = $this->attributes['name'];
                 if (!empty($value) && !empty($name)) {
                     $this->parent->attributes[$name] = $value;
                 } else {
                     unset($this->parent->attributes[$name]);
                 }
             }
             return '';
         case 'vte:cdata':
             return '<![CDATA[' . $this->nodes_output() . ']]>';
         case 'vte:params':
             $params = array();
             if (is_array($this->_nodes) && !empty($this->_nodes)) {
                 foreach ($this->_nodes as $k => $v) {
                     if ($this->_nodes[$k]->_type == 'vte:param') {
                         if (preg_match('/^\\{[^\\}]*\\}$/', $this->_nodes[$k]->attributes['value'])) {
                             $params[$this->_nodes[$k]->attributes['name']] =& $this->param_value($this->_nodes[$k]->attributes['value']);
                         } else {
                             $params[$this->_nodes[$k]->attributes['name']] = $this->xmlentities_decode($this->_nodes[$k]->get_attribute_output('value'));
                         }
                     }
                 }
             }
             return $params;
         case 'vte:load':
             $module_name = $this->attributes['module'];
             if (isset($module_name) && trim($module_name) != '') {
                 $params = array();
                 if (isset($this->attributes['params'])) {
                     $params = $this->param_value($this->attributes['params']);
                 } elseif (!empty($this->attributes)) {
                     foreach ($this->attributes as $k => $v) {
                         if (preg_match('/^\\{[^\\}]*\\}$/', $v)) {
                             $params[$k] =& $this->param_value($v);
                         } else {
                             $params[$k] = $this->xmlentities_decode($this->get_attribute_output($k));
                         }
                     }
                 }
                 $site_manager =& $this->_template->get_site_manager();
                 return $site_manager->get_module_output($module_name, $params, $this->_template);
             }
             return '';
         case 'vte:box':
             $module_name = $this->attributes['module'];
             if (isset($module_name) && trim($module_name) != '') {
                 if (isset($this->attributes['params'])) {
                     $params = $this->param_value($this->attributes['params']);
                 }
                 $params_node = $this->get_child_by_tag('vte:params');
                 if (empty($params) || !is_array($params)) {
                     $params = array();
                 }
                 if ($params_node) {
                     $params = array_merge($params, $params_node->get_output());
                 }
                 $site_manager =& $this->_template->get_site_manager();
                 $template_node = $this->get_child_by_tag('vte:template');
                 if ($this->_type == 'vte:box' && $template_node) {
                     $params['template_string'] = $template_node->get_literal_output();
                 }
                 return $site_manager->get_module_output($module_name, $params, $this->_template);
             }
             return '';
         case 'vte:template':
             $output = '';
             if (!empty($this->attributes['template_string'])) {
                 $template = new template(null, $this);
                 $template->set_string_template($this->param_value($this->attributes['template_string']));
                 foreach ($this->attributes as $name => $value) {
                     $template->assign($name, $this->param_value($value));
                 }
                 $output = $template->get_output();
             } else {
                 if (!empty($this->attributes['recursive'])) {
                     $literal = '';
                     if (is_array($this->_nodes) && !empty($this->_nodes)) {
                         foreach ($this->_nodes as $k => $node) {
                             $literal .= $this->_nodes[$k]->get_literal_output();
                         }
                     }
                     $this->_template->assign('template_string', $literal);
                 }
                 if (is_array($this->_nodes)) {
                     foreach ($this->_nodes as $k => $node) {
                         $output .= $this->_nodes[$k]->get_output();
                     }
                 }
             }
             return $output;
         case 'vte:value':
             return $this->param_value($this->attributes['select']);
         default:
             return $this->get_output_default();
     }
 }
예제 #4
0
 function email_to_a_friend($article_id, $to, $bcc, $your_email, $message)
 {
     require_once VIVVO_FS_FRAMEWORK . 'PEAR/Mail.php';
     if (!vivvo_hooks_manager::call('article_mail', array(&$article_id, &$to, &$bcc, &$your_email, &$message))) {
         return vivvo_hooks_manager::get_status();
     }
     if (VIVVO_EMAIL_ENABLE == 1) {
         if (isset($_SESSION['vivvo']['email_to_friend_time']) && $_SESSION['vivvo']['email_to_friend_time'] + VIVVO_EMAIL_FLOOD_CHECK > VIVVO_START_TIME) {
             $this->set_error_code(2202);
             return false;
         }
         $article_list = new Articles_list();
         $article = $article_list->get_article_by_id($article_id);
         $lang = vivvo_lang::get_instance();
         if ($article !== false) {
             $to = strip_tags($to);
             $bcc = strip_tags($bcc);
             if (!preg_match('/^[a-zA-Z0-9_\\-\\/\\.]+@[a-zA-Z0-9_\\-\\/]{2,}([\\.][a-zA-Z0-9_\\-\\/]{2,}){1,}$/', $your_email)) {
                 $this->set_error_code(2032);
                 return false;
             }
             if (!preg_match('/^[a-zA-Z0-9_\\-\\/\\.]+@[a-zA-Z0-9_\\-\\/]{2,}([\\.][a-zA-Z0-9_\\-\\/]{2,}){1,}$/', $bcc)) {
                 $bcc = '';
             }
             if (VIVVO_EMAIL_SEND_BCC) {
                 if ($bcc) {
                     $bcc .= ', ' . VIVVO_EMAIL_SEND_BCC;
                 } else {
                     $bcc = VIVVO_EMAIL_SEND_BCC;
                 }
             }
             if (VIVVO_EMAIL_SEND_CC) {
                 $headers['Cc'] = VIVVO_EMAIL_SEND_CC;
             }
             if (preg_match('/^[a-zA-Z0-9_\\-\\/\\.]+@[a-zA-Z0-9_\\-\\/]{2,}([\\.][a-zA-Z0-9_\\-\\/]{2,}){1,}$/', $to)) {
                 $body_template = new template();
                 $template_sting = xml_template_node::xmlentities_decode(VIVVO_EMAIL_TO_A_FRIEND_BODY);
                 $body_template->set_string_template($template_sting);
                 $body_template->assign('article', $article);
                 $body_template->assign('user_email_address', $your_email);
                 $body_template->assign('message', $message);
                 $body = $body_template->get_output() . "\n\n";
                 $headers['From'] = $your_email;
                 $recipients = array();
                 $recipients[] = $to;
                 if ($bcc != '') {
                     $headers['Bcc'] = $bcc;
                 }
                 $headers['Subject'] = "=?UTF-8?B?" . base64_encode(VIVVO_EMAIL_TO_A_FRIEND_SUBJECT) . "?=";
                 $headers['Content-Type'] = "text/plain; charset=UTF-8;";
                 if (VIVVO_EMAIL_SMTP_PHP == 1) {
                     $mail_object = new Mail();
                     $mail_object->send($to, $headers, $body);
                 } else {
                     $mail_options['driver'] = 'smtp';
                     $mail_options['host'] = VIVVO_EMAIL_SMTP_HOST;
                     $mail_options['port'] = VIVVO_EMAIL_SMTP_PORT;
                     $mail_options['localhost'] = 'localhost';
                     if (VIVVO_EMAIL_SMTP_PASSWORD != '' && VIVVO_EMAIL_SMTP_USERNAME != '') {
                         $mail_options['auth'] = true;
                         $mail_options['username'] = VIVVO_EMAIL_SMTP_USERNAME;
                         $mail_options['password'] = VIVVO_EMAIL_SMTP_PASSWORD;
                     } else {
                         $mail_options['auth'] = false;
                         $mail_options['username'] = '';
                         $mail_options['password'] = '';
                     }
                     $mail_object = Mail::factory('smtp', $mail_options);
                     $mail_object->send($to, $headers, $body);
                 }
                 $article->set_emailed($article->emailed + 1);
                 $this->_post_master->set_data_object($article);
                 if ($this->_post_master->sql_update()) {
                     $_SESSION['vivvo']['email_to_friend_time'] = time();
                     return true;
                 } else {
                     $this->set_error_code(2033);
                     return false;
                 }
             } else {
                 $this->set_error_code(2034);
                 return false;
             }
         } else {
             $this->set_error_code(2035);
             return false;
         }
     }
 }
예제 #5
0
 /**
  * Generates box output
  *
  * @param	array	$params		Parameters passed from VTE
  */
 public function generate_output($params = array())
 {
     if (empty($params['name']) or empty(self::$hooks[$params['name']])) {
         return;
     }
     !empty($params['template_set']) or $params['template_set'] = self::$template_set;
     if (empty($params['template_string'])) {
         $filename = VIVVO_FS_TEMPLATE_ROOT . "templates/_system/hooks/{$params['template_set']}/{$params['name']}.xml";
         if (is_file($filename)) {
             $params['template_string'] = file_get_contents($filename);
         } else {
             return;
         }
     }
     if (!$this->_parent_template) {
         $this->_parent_template = vivvo_lite_site::get_instance()->get_template();
     }
     $output = '';
     foreach (self::$hooks[$params['name']] as &$hook) {
         $template = new template(vivvo_lite_site::get_instance(), $this->_parent_template);
         $template->set_string_template($params['template_string']);
         if (!empty($hook['handler'])) {
             if (!$hook['handler']['loaded']) {
                 if (is_file(VIVVO_FS_INSTALL_ROOT . $hook['handler']['file'])) {
                     include_once VIVVO_FS_INSTALL_ROOT . $hook['handler']['file'];
                 }
                 if (!empty($hook['handler']['class'])) {
                     if (class_exists($hook['handler']['class']) and in_array($hook['handler']['function'], get_class_methods($hook['handler']['class']))) {
                         $hook['handler']['function'] = array($hook['handler']['class'], $hook['handler']['function']);
                         $hook['handler']['loaded'] = true;
                     }
                 } else {
                     if (function_exists($hook['handler']['function'])) {
                         $hook['handler']['loaded'] = true;
                     }
                 }
             }
             if ($hook['handler']['loaded']) {
                 $ret = call_user_func_array($hook['handler']['function'], array($template, $params, &$hook, $hook['handler']['params']));
                 if ($ret !== true) {
                     $output .= $ret;
                     continue;
                 }
             }
         }
         if (!empty($hook['params'])) {
             if (!empty($hook['params']['lang_file'])) {
                 vivvo_lang::get_instance()->load_lang(defined('VIVVO_ADMIN_LANG') ? VIVVO_ADMIN_LANG : VIVVO_DEFAULT_LANG, $template->eval_string($hook['params']['lang_file']));
             }
             foreach ($hook['params'] as $name => $value) {
                 $value = $template->eval_string($value);
                 $template->assign($name, $value);
             }
             $output .= $template->get_output();
         }
     }
     unset($hook);
     $this->set_template(array('template_string' => '<vte:value select="{output}" />'));
     $this->_template->assign('output', $output);
 }
예제 #6
0
    function send_newsletter($newsletter_id)
    {
        $sm = vivvo_lite_site::get_instance();
        $db = $sm->get_db();
        if ($sm->user) {
            if ($sm->user->is_admin()) {
                $newsletter_list = new newsletter_list();
                $newsletter = $newsletter_list->get_newsletter_by_id($newsletter_id);
                if ($newsletter !== false) {
                    if ($newsletter->test == 1) {
                        $to = $newsletter->test_email;
                        if ($newsletter->vte_template == '1') {
                            $body_template = new template();
                            $template_sting = xml_template_node::xmlentities_decode($newsletter->body);
                            $body_template->set_string_template($template_sting);
                            $body = $body_template->get_output() . "\n\n";
                        } else {
                            $body = xml_template_node::xmlentities_decode($newsletter->body);
                        }
                        $unsubscribe_url = VIVVO_PROXY_URL . 'newsletter/index.html?&action=newsletter&cmd=subscriberUnSubscribe&dack=' . md5('test');
                        if (!preg_match('/^[^:]+:/', $unsubscribe_url)) {
                            $unsubscribe_url = VIVVO_URL . $unsubscribe_url;
                        }
                        $body = $body . "\n\n\n" . VIVVO_PLUGIN_NEWSLETTER_UNSUBSCRIBE_TEXT . "\n" . $unsubscribe_url;
                        $from = VIVVO_ADMINISTRATORS_EMAIL;
                        $search = array('(', ')', '<', '>', '@', ';', ':', '\\', '"', '.', '[', ']');
                        $replace = array(' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ');
                        $from_name = str_replace($search, $replace, VIVVO_WEBSITE_TITLE);
                        $from_name = "=?UTF-8?B?" . base64_encode($from_name) . "?=";
                        $from_params = !empty($from_name) ? '"' . $from_name . '" <' . $from . '>' : '<' . $from . '>';
                        $headers['From'] = $from_params;
                        $recipients = array();
                        $recipients[] = $to;
                        $subject = "=?UTF-8?B?" . base64_encode($newsletter->subject) . "?=";
                        $headers['Subject'] = $subject;
                        $headers['Content-Type'] = "text/plain; charset=UTF-8;";
                        if (VIVVO_EMAIL_SMTP_PHP == 1) {
                            $mail_object = new Mail();
                            $mail_object->send($to, $headers, $body);
                        } else {
                            $mail_options['driver'] = 'smtp';
                            $mail_options['host'] = VIVVO_EMAIL_SMTP_HOST;
                            $mail_options['port'] = VIVVO_EMAIL_SMTP_PORT;
                            $mail_options['localhost'] = 'localhost';
                            if (VIVVO_EMAIL_SMTP_PASSWORD != '' && VIVVO_EMAIL_SMTP_USERNAME != '') {
                                $mail_options['auth'] = true;
                                $mail_options['username'] = VIVVO_EMAIL_SMTP_USERNAME;
                                $mail_options['password'] = VIVVO_EMAIL_SMTP_PASSWORD;
                            } else {
                                $mail_options['auth'] = false;
                                $mail_options['username'] = '';
                                $mail_options['password'] = '';
                            }
                            $mail_object =& Mail::factory('smtp', $mail_options);
                            $mail_object->send($to, $headers, $body);
                        }
                    } else {
                        $container_options = array('type' => 'mdb2', 'dsn' => VIVVO_DB_TYPE . '://' . VIVVO_DB_USER . ':' . VIVVO_DB_PASSWORD . '@' . VIVVO_DB_HOST . '/' . VIVVO_DB_DATABASE, 'mail_table' => VIVVO_DB_PREFIX . 'mail_queue');
                        $mail_options['driver'] = 'smtp';
                        $mail_options['host'] = VIVVO_EMAIL_SMTP_HOST;
                        $mail_options['port'] = VIVVO_EMAIL_SMTP_PORT;
                        $mail_options['localhost'] = 'localhost';
                        if (VIVVO_EMAIL_SMTP_PASSWORD != '' && VIVVO_EMAIL_SMTP_USERNAME != '') {
                            $mail_options['auth'] = true;
                            $mail_options['username'] = VIVVO_EMAIL_SMTP_USERNAME;
                            $mail_options['password'] = VIVVO_EMAIL_SMTP_PASSWORD;
                        } else {
                            $mail_options['auth'] = false;
                            $mail_options['username'] = '';
                            $mail_options['password'] = '';
                        }
                        $mail_queue = new Mail_Queue($container_options, $mail_options);
                        $from = VIVVO_ADMINISTRATORS_EMAIL;
                        $search = array('(', ')', '<', '>', '@', ';', ':', '\\', '"', '.', '[', ']');
                        $replace = array(' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ');
                        $from_name = str_replace($search, $replace, VIVVO_WEBSITE_TITLE);
                        $from_name = "=?UTF-8?B?" . base64_encode($from_name) . "?=";
                        $from_params = !empty($from_name) ? '"' . $from_name . '" <' . $from . '>' : '<' . $from . '>';
                        if ($newsletter->vte_template == '1') {
                            $body_template = new template();
                            $template_sting = xml_template_node::xmlentities_decode($newsletter->body);
                            $body_template->set_string_template($template_sting);
                            $body = $body_template->get_output() . "\n\n";
                        } else {
                            $body = xml_template_node::xmlentities_decode($newsletter->body);
                        }
                        $groups = explode(',', $newsletter->groups);
                        foreach ($groups as $key) {
                            if ($key == -1) {
                                $res =& $db->query('SELECT email, ip, time FROM ' . VIVVO_DB_PREFIX . 'maillist WHERE `confirm` = \'1\'');
                                if (!is_a($res, 'mdb2_error')) {
                                    while ($row = $res->fetchRow(MDB2_FETCHMODE_ASSOC)) {
                                        $subject = "=?UTF-8?B?" . base64_encode($newsletter->subject) . "?=";
                                        $recipient = $row['email'];
                                        $hdrs = array('From' => $from_params, 'To' => $recipient, 'Subject' => $subject, 'Content-Type' => "text/plain; charset=UTF-8;");
                                        $body_all = $body . "\n\n\n" . VIVVO_PLUGIN_NEWSLETTER_UNSUBSCRIBE_TEXT . "\n" . VIVVO_URL . 'newsletter/index.html?action=newsletter&cmd=subscriberUnSubscribe&dack=' . md5($row['ip'] . $row['time'] . $row['email']);
                                        $mail_queue->put($from, $recipient, $hdrs, $body_all);
                                    }
                                }
                            } elseif ($key >= 0) {
                                $res = $db->query('SELECT email_address, userid, created FROM ' . VIVVO_DB_PREFIX . 'users as u
														INNER JOIN ' . VIVVO_DB_PREFIX . 'group_user  as gu
														ON gu.user_id=u.userid
														WHERE gu.group_id = \'' . $key . '\' and `subscriber` = \'1\'');
                                if (!is_a($res, 'mdb2_error')) {
                                    while ($row = $res->fetchRow(MDB2_FETCHMODE_ASSOC)) {
                                        $recipient = $row['email_address'];
                                        $subject = "=?UTF-8?B?" . base64_encode($newsletter->subject) . "?=";
                                        $hdrs = array('From' => $from_params, 'To' => $recipient, 'Subject' => $subject, 'Content-Type' => "text/plain; charset=UTF-8;");
                                        $unsubscribe_url = VIVVO_PROXY_URL . 'newsletter/index.html?action=newsletter&cmd=userUnSubscribe&dack=' . md5($row['email_address'] . $row['userid'] . $row['created']);
                                        if (!preg_match('/^[^:]+:/', $unsubscribe_url)) {
                                            $unsubscribe_url = VIVVO_URL . $unsubscribe_url;
                                        }
                                        $body_all = $body . "\n\n\n" . VIVVO_PLUGIN_NEWSLETTER_UNSUBSCRIBE_TEXT . "\n" . $unsubscribe_url;
                                        $mail_queue->put($from, $recipient, $hdrs, $body_all);
                                    }
                                }
                            }
                        }
                    }
                    return true;
                } else {
                    $this->set_error_code(10225);
                    return false;
                }
            } else {
                $this->set_error_code(10226);
                return false;
            }
        } else {
            $this->set_error_code(10227);
            return false;
        }
    }