示例#1
0
 /**
  * Parse skinvar membermailform
  */
 function parse_membermailform($rows = 10, $cols = 40, $desturl = '')
 {
     global $member, $CONF, $memberid;
     if ($desturl == '') {
         if ($CONF['URLMode'] == 'pathinfo') {
             $desturl = createMemberLink($memberid);
         } else {
             $desturl = $CONF['IndexURL'] . createMemberLink($memberid);
         }
     }
     $message = postVar('message');
     $frommail = postVar('frommail');
     $this->formdata = array('url' => htmlspecialchars($desturl), 'actionurl' => htmlspecialchars($CONF['ActionURL'], ENT_QUOTES), 'memberid' => $memberid, 'rows' => $rows, 'cols' => $cols, 'message' => htmlspecialchars($message, ENT_QUOTES), 'frommail' => htmlspecialchars($frommail, ENT_QUOTES));
     if ($member->isLoggedIn()) {
         $this->doForm('membermailform-loggedin');
     } else {
         if ($CONF['NonmemberMail']) {
             $this->doForm('membermailform-notloggedin');
         } else {
             $this->doForm('membermailform-disallowed');
         }
     }
 }
示例#2
0
 function _genarateObjectLink($data, $scatFlag = '')
 {
     global $CONF, $manager, $blog;
     $ext = substr(serverVar('REQUEST_URI'), -4);
     if ($ext == '.rdf' || $ext == '.xml') {
         $CONF['URLMode'] = 'pathinfo';
     }
     if ($CONF['URLMode'] != 'pathinfo') {
         return;
     }
     $query = 'SELECT %s as result FROM %s WHERE %s = "%s"';
     switch ($data[0]) {
         case 'b':
             if ($data[2] == 'n') {
                 $bid = getBlogIDFromName($data[1]);
             } else {
                 $bid = $data[1];
             }
             $blog_id = intval($bid);
             $param = array('blog', 'bnumber', $blog_id);
             if (!$this->_isValid($param)) {
                 $url = _NOT_VALID_BLOG;
             } else {
                 $url = $this->_generateBlogLink($blog_id) . '/';
             }
             break;
         case 'c':
             if ($data[2] == 'n') {
                 $cid = getCatIDFromName($data[1]);
             } else {
                 $cid = $data[1];
             }
             $cat_id = intval($cid);
             $param = array('category', 'catid', $cat_id);
             if (!$this->_isValid($param)) {
                 $url = _NOT_VALID_CAT;
             } else {
                 $url = createCategoryLink($cat_id);
             }
             break;
         case 's':
             $mcategories = $this->pluginCheck('MultipleCategories');
             if ($mcategories) {
                 if ($data[2] == 'n') {
                     $temp = $this->quote_smart($data[1]);
                     $sque = sprintf($query, 'scatid', _C_SUBCAT_TABLE, 'sname', $temp);
                     $scid = quickQuery($sque);
                 } else {
                     $scid = $data[1];
                 }
                 $sub_id = intval($scid);
                 $param = array('plug_multiple_categories_sub', 'scatid', $sub_id);
                 if (!$this->_isValid($param)) {
                     $url = _NOT_VALID_SUBCAT;
                 } else {
                     $cqe = sprintf($query, 'catid', _C_SUBCAT_TABLE, 'scatid', $sub_id);
                     $cid = quickQuery($cqe);
                     $cid = intval($cid);
                     if (method_exists($mcategories, "getRequestName")) {
                         $subrequest = $mcategories->getRequestName();
                     }
                     if (!$subrequest) {
                         $subrequest = 'subcatid';
                     }
                     $linkParam = array($subrequest => $sub_id);
                     $url = createCategoryLink($cid, $linkParam);
                 }
             }
             break;
         case 'i':
             $param = array('item', 'inumber', intval($data[1]));
             if (!$this->_isValid($param)) {
                 $url = _NOT_VALID_ITEM;
             } else {
                 if ($scatFlag) {
                     global $catid, $subcatid;
                     if (!empty($catid)) {
                         $linkparams['catid'] = intval($catid);
                     }
                     if (!empty($subcatid)) {
                         $mcategories = $this->pluginCheck('MultipleCategories');
                         if ($mcategories) {
                             if (method_exists($mcategories, 'getRequestName')) {
                                 $subrequest = $mcategories->getRequestName();
                             } else {
                                 $subrequest = 'subcatid';
                             }
                         }
                         $linkparams[$subrequest] = intval($subcatid);
                     }
                     $url = createItemLink(intval($data[1]), $linkparams);
                 } else {
                     $blink = $this->_generateBlogLink(getBlogIDFromItemID(intval($data[1])));
                     $i_query = 'SELECT obj_name as result ' . 'FROM %s ' . 'WHERE obj_param = "item" ' . 'AND      obj_id = %d';
                     $i_query = sprintf($i_query, _CUSTOMURL_TABLE, intval($data[1]));
                     $path = quickQuery($i_query);
                     if ($path) {
                         if ($data[2] == 'path') {
                             $url = $path;
                         } else {
                             $url = $blink . '/' . $path;
                         }
                     } else {
                         if ($data[2] == 'path') {
                             $url = $CONF['ItemKey'] . '/' . intval($data[1]);
                         } else {
                             $url = $blink . '/' . $CONF['ItemKey'] . '/' . intval($data[1]);
                         }
                     }
                 }
             }
             break;
         case 'm':
             if ($data[2] == 'n') {
                 $data[1] = $this->quote_smart($data[1]);
                 $mque = sprintf($query, 'mnumber', sql_table('member'), 'mname', $data[1]);
                 $mid = quickQuery($mque);
             } else {
                 $mid = $data[1];
             }
             $member_id = intval($mid);
             $param = array('member', 'mnumber', $member_id);
             if (!$this->_isValid($param)) {
                 $url = _NOT_VALID_MEMBER;
             } else {
                 $url = createMemberLink($member_id);
             }
             break;
     }
     return $url;
 }
示例#3
0
 /**
  *  Sends a message from the current member to the member given as argument
  */
 function sendMessage()
 {
     global $CONF, $member;
     $error = $this->validateMessage();
     if ($error != '') {
         return array('message' => $error);
     }
     if (!$member->isLoggedIn()) {
         $fromMail = postVar('frommail');
         $fromName = _MMAIL_FROMANON;
     } else {
         $fromMail = $member->getEmail();
         $fromName = $member->getDisplayName();
     }
     $tomem = new MEMBER();
     $tomem->readFromId(postVar('memberid'));
     $message = _MMAIL_MSG . ' ' . $fromName . "\n" . '(' . _MMAIL_FROMNUC . ' ' . $CONF['IndexURL'] . ") \n\n" . _MMAIL_MAIL . " \n\n" . postVar('message');
     $message .= getMailFooter();
     $title = _MMAIL_TITLE . ' ' . $fromName;
     mb_language('ja');
     mb_internal_encoding(_CHARSET);
     @mb_send_mail($tomem->getEmail(), $title, $message, "From: " . $fromMail);
     if (postVar('url')) {
         redirect(postVar('url'));
     } else {
         $CONF['MemberURL'] = $CONF['IndexURL'];
         if ($CONF['URLMode'] == 'pathinfo') {
             $url = createLink('member', array('memberid' => $tomem->getID(), 'name' => $tomem->getDisplayName()));
         } else {
             $url = $CONF['IndexURL'] . createMemberLink($tomem->getID());
         }
         redirect($url);
     }
     exit;
 }