'index', 'header' => 'common/header', 'footer' => 'common/footer', 'slide' => 'common/slide', ); if(!empty($mapping[$filename])) { return $mapping[$filename]; } return ''; } function template_page($id, $flag = TEMPLATE_DISPLAY) { global $_W; $page = pdo_fetch("SELECT * FROM ".tablename('site_page')." WHERE id = :id LIMIT 1", array(':id' => $id)); if (empty($page)) { return error(1, 'Error: Page is not found'); } if (empty($page['html'])) { return ''; } $page['html'] = str_replace(array(' $page['description'], 'title' => $page['title'], 'imgUrl' => tomedia($page['params']['0']['params']['thumb']));; $compile = IA_ROOT . "/data/tpl/app/{$id}.{$_W['template']}.tpl.php"; $path = dirname($compile); if (!is_dir($path)) { load()->func('file'); mkdirs($path); } $content = template_parse($page['html']); if (!empty($page['params'][0]['params']['bgColor'])) { $content .= ''; } $GLOBALS['bottom_menu'] = $page['params'][0]['property'][0]['params']['bottom_menu']; file_put_contents($compile, $content); switch ($flag) { case TEMPLATE_DISPLAY: default: extract($GLOBALS, EXTR_SKIP); template('common/header'); include $compile; template('common/footer'); break; case TEMPLATE_FETCH: extract($GLOBALS, EXTR_SKIP); ob_clean(); ob_start(); include $compile; $contents = ob_get_contents(); ob_clean(); return $contents; break; case TEMPLATE_INCLUDEPATH: return $compile; break; } } function template($filename, $flag = TEMPLATE_DISPLAY) { global $_W, $_GPC; $source = IA_ROOT . "/app/themes/{$_W['template']}/{$filename}.html"; $compile = IA_ROOT . "/data/tpl/app/{$_W['template']}/{$filename}.tpl.php"; if(!is_file($source)) { $compatFilename = template_compat($filename); if(!empty($compatFilename)) { return template($compatFilename, $flag); } } if(!is_file($source)) { $source = IA_ROOT . "/app/themes/default/{$filename}.html"; $compile = IA_ROOT . "/data/tpl/app/default/{$filename}.tpl.php"; } if(!is_file($source)) { exit("Error: template source '{$filename}' is not exist!"); } $paths = pathinfo($compile); $compile = str_replace($paths['filename'], $_W['uniacid'] . '_' . intval($_GPC['t']) . '_' . $paths['filename'], $compile); if(DEVELOPMENT || !is_file($compile) || filemtime($source) > filemtime($compile)) { template_compile($source, $compile); } switch ($flag) { case TEMPLATE_DISPLAY: default: extract($GLOBALS, EXTR_SKIP); include $compile; break; case TEMPLATE_FETCH: extract($GLOBALS, EXTR_SKIP); ob_clean(); ob_start(); include $compile; $contents = ob_get_contents(); ob_clean(); return $contents; break; case TEMPLATE_INCLUDEPATH: return $compile; break; } } function template_compile($from, $to) { $path = dirname($to); if (!is_dir($path)) { load()->func('file'); mkdirs($path); } $content = template_parse(file_get_contents($from)); file_put_contents($to, $content); } function template_parse($str) { $check_repeat_template = array( "'common\\/header'", "'common\\/footer'", ); foreach ($check_repeat_template as $template) { if (preg_match_all('/{template\s+'.$template.'}/', $str, $match) > 1) { $replace = stripslashes($template); $str = preg_replace('/{template\s+'.$template.'}/i', 'template('.$replace.', TEMPLATE_INCLUDEPATH)) : (include template('.$replace.', TEMPLATE_INCLUDEPATH));?>', $str, 1); $str = preg_replace('/{template\s+'.$template.'}/i', '', $str); } } $str = preg_replace('//s', '{$1}', $str); $str = preg_replace('/{template\s+(.+?)}/', 'template($1, TEMPLATE_INCLUDEPATH)) : (include template($1, TEMPLATE_INCLUDEPATH));?>', $str); $str = preg_replace('/{php\s+(.+?)}/', '', $str); $str = preg_replace('/{if\s+(.+?)}/', '', $str); $str = preg_replace('/{else}/', '', $str); $str = preg_replace('/{else ?if\s+(.+?)}/', '', $str); $str = preg_replace('/{\/if}/', '', $str); $str = preg_replace('/{loop\s+(\S+)\s+(\S+)}/', '', $str); $str = preg_replace('/{loop\s+(\S+)\s+(\S+)\s+(\S+)}/', ' $3) { ?>', $str); $str = preg_replace('/{\/loop}/', '', $str); $str = preg_replace('/{(\$[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)}/', '', $str); $str = preg_replace('/{(\$[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff\[\]\'\"\$]*)}/', '', $str); $str = preg_replace('/{url\s+(\S+)}/', '', $str); $str = preg_replace('/{url\s+(\S+)\s+(array\(.+?\))}/', '', $str); $str = preg_replace('/{media\s+(\S+)}/', '', $str); $str = preg_replace_callback('/{data\s+(.+?)}/s', "moduledata", $str); $str = preg_replace_callback('/{hook\s+(.+?)}/s', "template_modulehook_parser", $str); $str = preg_replace('/{\/data}/', '', $str); $str = preg_replace('/{\/hook}/', '', $str); $str = preg_replace_callback('/<\?php([^\?]+)\?>/s', "template_addquote", $str); $str = preg_replace('/{([A-Z_\x7f-\xff][A-Z0-9_\x7f-\xff]*)}/s', '', $str); $str = str_replace('{##', '{', $str); $str = str_replace('##}', '}', $str); $business_stat_script = "", $str); } else { $str = str_replace('', "", $str); } $str = "" . $str; return $str; } function template_addquote($matchs) { $code = ""; $code = preg_replace('/\[([a-zA-Z0-9_\-\.\x7f-\xff]+)\](?![a-zA-Z0-9_\-\.\x7f-\xff\[\]]*[\'"])/s', "['$1']", $code); return str_replace('\\\"', '\"', $code); } function moduledata($params = '') { if (empty($params[1])) { return ''; } $params = explode(' ', $params[1]); if (empty($params)) { return ''; } $data = array(); foreach ($params as $row) { $row = explode('=', $row); $data[$row[0]] = str_replace(array("'", '"'), '', $row[1]); $row[1] = urldecode($row[1]); } $funcname = $data['func']; $assign = !empty($data['assign']) ? $data['assign'] : $funcname; $item = !empty($data['item']) ? $data['item'] : 'row'; $data['limit'] = !empty($data['limit']) ? $data['limit'] : 10; if (empty($data['return']) || $data['return'] == 'false') { $return = false; } else { $return = true; } $data['index'] = !empty($data['index']) ? $data['index'] : 'iteration'; if (!empty($data['module'])) { $modulename = $data['module']; } else { list($modulename) = explode('_', $data['func']); } $data['multiid'] = intval($_GET['t']); $data['uniacid'] = intval($_GET['i']); $data['acid'] = intval($_GET['j']); if (empty($modulename) || empty($funcname)) { return ''; } $variable = var_export($data, true); $variable = preg_replace("/'(\\$[a-zA-Z_\x7f-\xff\[\]\']*?)'/", '$1', $variable); $php = " \${$item}) { \$i++; \${$item}['{$data['index']}'] = \$i; "; } $php .= "?>"; return $php; } function modulefunc($modulename, $funcname, $params) { static $includes; $includefile = ''; if (!function_exists($funcname)) { if (!isset($includes[$modulename])) { if (!file_exists(IA_ROOT . '/addons/'.$modulename.'/model.php')) { return ''; } else { $includes[$modulename] = true; include_once IA_ROOT . '/addons/'.$modulename.'/model.php'; } } } if (function_exists($funcname)) { return call_user_func_array($funcname, array($params)); } else { return array(); } } function site_navs($params = array()) { global $_W, $multi, $cid, $ishomepage; $condition = array(); if(!$cid || !$ishomepage) { if (!empty($params['section'])) { $condition['section'] = intval($params['section']); } if(empty($params['multiid'])) { load()->model('account'); $setting = uni_setting($_W['uniacid']); $multiid = $setting['default_site']; } else{ $multiid = intval($params['multiid']); } $condition['position'] = 1; $condition['status'] = 1; $condition['uniacid'] = $_W['uniacid']; $condition['multiid'] = $multiid; $fields = array('id', 'name', 'description', 'url', 'icon', 'css', 'position', 'module'); $navs = pdo_getall('site_nav', $condition, $fields, '', array('section ASC', 'displayorder DESC', 'id DESC')); } else { $condition = array( 'parentid' => $cid, 'enabled' => 1, 'uniacid' => $_W['uniacid'] ); $navs = pdo_getall('site_category', $condition, array(), '', array('displayorder DESC', 'id DESC')); } if(!empty($navs)) { foreach ($navs as &$row) { if(!$cid || !$ishomepage) { if (!strexists($row['url'], 'tel:') && !strexists($row['url'], '://') && !strexists($row['url'], 'www') && !strexists($row['url'], 'i=')) { $row['url'] .= strexists($row['url'], '?') ? '&i='.$_W['uniacid'] : '?i='.$_W['uniacid']; } } else { if(empty($row['linkurl']) || (!strexists($row['linkurl'], 'http://') && !strexists($row['linkurl'], 'https://'))) { $row['url'] = murl('site/site/list', array('cid' => $row['id'])); } else { $row['url'] = $row['linkurl']; } } $row['css'] = iunserializer($row['css']); if(empty($row['css']['icon']['icon'])){ $row['css']['icon']['icon'] = 'fa fa-external-link'; } $row['css']['icon']['style'] = "color:{$row['css']['icon']['color']};font-size:{$row['css']['icon']['font-size']}px;"; $row['css']['name'] = "color:{$row['css']['name']['color']};"; $row['html'] = ''; $row['html'] .= ''; $row['html'] .= "{$row['name']}"; } unset($row); } return $navs; } function site_article($params = array()) { global $_GPC, $_W; extract($params); $pindex = max(1, intval($_GPC['page'])); if (!isset($limit)) { $psize = 10; } else { $psize = intval($limit); $psize = max(1, $limit); } $result = array(); $condition = " WHERE uniacid = :uniacid "; $pars = array(':uniacid' => $_W['uniacid']); if (!empty($cid)) { $category = pdo_getcolumn('site_category', array('id' => $cid, 'enabled' => 1), 'parentid'); if (!empty($category)) { $condition .= " AND ccate = :ccate "; $pars[':ccate'] = $cid; } else { $condition .= " AND pcate = :pcate AND (ccate = :ccate OR iscommend = '1')"; $pars[':pcate'] = $cid; $pars[':ccate'] = ARTICLE_CCATE; } } else { $category_list = pdo_getall('site_category', array('uniacid' => $_W['uniacid'], 'multiid' => $multiid), array(), 'id'); $category_list = implode(',', array_keys($category_list)); if (!empty($category_list)) { $condition .= " AND (pcate IN (". $category_list .") OR ccate IN (". $category_list .") OR pcate = 0 AND ccate = 0)"; } } if ($iscommend == 'true') { $condition .= " AND iscommend = '1'"; } if ($ishot == 'true') { $condition .= " AND ishot = '1'"; } $sql = "SELECT * FROM ".tablename('site_article'). $condition. ' ORDER BY displayorder DESC, id DESC LIMIT ' . ($pindex - 1) * $psize .',' .$psize; $result['list'] = pdo_fetchall($sql, $pars); $total = pdo_fetchcolumn('SELECT COUNT(*) FROM ' . tablename('site_article') . $condition, $pars); $result['pager'] = pagination($total, $pindex, $psize); if (!empty($result['list'])) { foreach ($result['list'] as &$row) { if(empty($row['linkurl'])) { $row['linkurl'] = murl('site/site/detail', array('id' => $row['id'], 'uniacid' => $_W['uniacid'])); } $row['thumb'] = tomedia($row['thumb']); } } return $result; } function site_category($params = array()) { global $_GPC, $_W; extract($params); if (!isset($parentid)) { $condition = ""; } else { $parentid = intval($parentid); $condition = " AND parentid = '$parentid'"; } $category = array(); $result = pdo_fetchall("SELECT * FROM ".tablename('site_category')." WHERE uniacid = '{$_W['uniacid']}' $condition ORDER BY parentid ASC, displayorder ASC, id ASC "); if (!empty($result)) { foreach ($result as $row) { if(empty($row['linkurl'])) { $row['linkurl'] = url('site/site/list', array('cid' =>$row['id'])); } $row['icon'] = tomedia($row['icon']); $row['css'] = iunserializer($row['css']); if(empty($row['css']['icon']['icon'])){ $row['css']['icon']['icon'] = 'fa fa-external-link'; } $row['css']['icon']['style'] = "color:{$row['css']['icon']['color']};font-size:{$row['css']['icon']['font-size']}px;"; $row['css']['name'] = "color:{$row['css']['name']['color']};"; if (!isset($parentid)) { if (empty($row['parentid'])) { $category[$row['id']] = $row; } else { $category[$row['parentid']]['children'][$row['id']] = $row; } } else { $category[] = $row; } } } return $category; } function site_slide_search($params = array()) { global $_W; if(empty($params['limit'])) { $params['limit'] = 8; } if(empty($params['multiid'])) { $multiid = pdo_fetchcolumn('SELECT default_site FROM ' . tablename('uni_settings') . ' WHERE uniacid = :id', array(':id' => $_W['uniacid'])); } else{ $multiid = intval($params['multiid']); } $sql = "SELECT * FROM " . tablename('site_slide') . " WHERE uniacid = '{$_W['uniacid']}' AND multiid = {$multiid} ORDER BY `displayorder` DESC, `id` DESC LIMIT " . intval($params['limit']); $list = pdo_fetchall($sql); if(!empty($list)) { foreach($list as &$row) { if (!strexists($row['url'], './')) { if (!strexists($row['url'], 'http')) { $row['url'] = '//' . $row['url']; } } $row['thumb'] = tomedia($row['thumb']); } } return $list; } function app_slide($params = array()) { return site_slide_search($params); } function site_widget_link($params = array()) { $params['widgetdata'] = urldecode($params['widgetdata']); $widget = json_decode($params['widgetdata'], true); $widgetparams = !empty($widget['params']) ? $widget['params'] : array(); $sql = 'SELECT * FROM ' .tablename('site_article')." WHERE uniacid = :uniacid "; $sqlparams = array(':uniacid' => $widget['uniacid']); if (!empty($widgetparams['selectCate']['pid'])) { $sql .= " AND pcate = :pid"; $sqlparams[':pid'] = $widgetparams['selectCate']['pid']; } if (!empty($widgetparams['selectCate']['cid'])) { $sql .= " AND ccate = :cid"; $sqlparams[':cid'] = $widgetparams['selectCate']['cid']; } if (!empty($widgetparams['iscommend'])) { $sql .= " AND iscommend = '1'"; } if (!empty($widgetparams['ishot'])) { $sql .= " AND ishot = '1'"; } if (!empty($widgetparams['isnew'])) { $sql .= " ORDER BY id DESC "; } if (!empty($widgetparams['pageSize'])) { $limit = intval($widgetparams['pageSize']); $sql .= " LIMIT {$limit}"; } $list = pdo_fetchall($sql, $sqlparams); if (!empty($list)) { foreach ($list as $i => &$row) { $row['title'] = cutstr($row['title'], 20, true); $row['thumb_url'] = tomedia($row['thumb']); $row['url'] = url('site/site/detail', array('id' => $row['id'])); } unset($row); } return (array)$list; } function site_quickmenu() { global $_W, $_GPC; if ($_GPC['c'] == 'mc' || $_GPC['c'] == 'activity') { $quickmenu = pdo_fetch("SELECT html, params FROM ".tablename('site_page')." WHERE uniacid = :uniacid AND type = '4' AND status = '1'", array(':uniacid' => $_W['uniacid'])); } elseif ($_GPC['c'] == 'auth') { return false; } else { $multiid = intval($_GPC['t']); if (empty($multiid) && !empty($_GPC['__multiid'])) { $id = intval($_GPC['__multiid']); $site_multi_info = pdo_get('site_multi', array('id' => $id,'uniacid' => $_W['uniacid'])); $multiid = empty($site_multi_info) ? '' : $id; } else { if(!($_GPC['c'] == 'home' && $_GPC['a'] == 'page')){ @isetcookie('__multiid', ''); } } if (empty($multiid)) { $setting = uni_setting($_W['uniacid'], array('default_site')); $multiid = $setting['default_site']; } $quickmenu = pdo_fetch("SELECT html, params FROM ".tablename('site_page')." WHERE multiid = :multiid AND type = '2' AND status = '1'", array(':multiid' => $multiid)); } if (empty($quickmenu)) { return false; } $quickmenu['params'] = json_decode($quickmenu['params'], true); if ($_GPC['c'] == 'home' && $_GPC['a'] != 'page' && empty($quickmenu['params']['position']['homepage'])) { return false; } if ($_GPC['c'] == 'home' && $_GPC['a'] == 'page' && empty($quickmenu['params']['position']['page'])) { return false; } if ($_GPC['c'] == 'site' && empty($quickmenu['params']['position']['article'])) { return false; } if (!empty($_GPC['m']) && !empty($quickmenu['params']['ignoreModules'][$_GPC['m']])) { return false; } echo $quickmenu['html']; echo ""; } function template_modulehook_parser($params = array()) { load()->model('module'); if (empty($params[1])) { return ''; } $params = explode(' ', $params[1]); if (empty($params)) { return ''; } $plugin = array(); foreach ($params as $row) { $row = explode('=', $row); $plugin[$row[0]] = str_replace(array("'", '"'), '', $row[1]); $row[1] = urldecode($row[1]); } $plugin_info = module_fetch($plugin['module']); if (empty($plugin_info)) { return false; } if (empty($plugin['return']) || $plugin['return'] == 'false') { } else { } if (empty($plugin['func']) || empty($plugin['module'])) { return false; } if (defined('IN_SYS')) { $plugin['func'] = "hookWeb{$plugin['func']}"; } else { $plugin['func'] = "hookMobile{$plugin['func']}"; } $plugin_module = WeUtility::createModuleHook($plugin_info['name']); if (method_exists($plugin_module, $plugin['func']) && $plugin_module instanceof WeModuleHook) { $hookparams = var_export($plugin, true); if (!empty($hookparams)) { $hookparams = preg_replace("/'(\\$[a-zA-Z_\x7f-\xff\[\]\']*?)'/", '$1', $hookparams); } else { $hookparams = 'array()'; } $php = " {$hookparams})); ?>"; return $php; } else { $php = ""; return $php; } }