<?php
defined('IN_IA') or exit('Access Denied');
function app_navs($type = 'home', $multiid = 0, $section = 0) {
global $_W;
$pos = array();
$pos['home'] = 1;
$pos['profile'] = 2;
$pos['shortcut'] = 3;
if (empty($multiid) && $type != 'profile') {
load()->model('account');
$setting = uni_setting($_W['uniacid'], array('default_site'));
$multiid = $setting['default_site'];
}
$site_nav_table = table('site_nav');
$site_nav_table->searchWithMultiid(intval($multiid));
$site_nav_table->searchWithPosition($pos[$type]);
$site_nav_table->searchWithStatus(1);
$site_nav_table->searchWithUniacid($_W['uniacid']);
$site_nav_table->orderby(array('displayorder' => 'DESC', 'id' => 'ASC'));
$navs = $site_nav_table->getall();
if (!empty($navs)) {
foreach ($navs as &$row) {
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']}";
}
if (is_serialized($row['css'])) {
$row['css'] = iunserializer($row['css']);
}
if (empty($row['css'])) {
$row['css'] = array(
'icon' => array(
'icon' => 'fa fa-external-link',
'font-size' => '35px',
'color' => '',
),
'name' => array('color' => ''),
);
}
if (empty($row['css']['icon']['icon'])) {
$row['css']['icon']['icon'] = 'fa fa-external-link';
}
if ($row['position'] == '3') {
if (!empty($row['css'])) {
unset($row['css']['icon']['font-size']);
}
}
$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']};";
}
unset($row);
}
return $navs;
}
function app_update_today_visit($module_name) {
global $_W;
$module_name = trim($module_name);
if (empty($module_name) || !in_array($_W['account']['type'], array(ACCOUNT_TYPE_OFFCIAL_NORMAL, ACCOUNT_TYPE_OFFCIAL_AUTH, ACCOUNT_TYPE_WEBAPP_NORMAL))) {
return false;
}
$today = date('Ymd');
$stat_visit_teble = table('stat_visit');
$stat_visit_teble->searchWithDate($today);
$stat_visit_teble->searchWithModule($module_name);
$stat_visit_teble->searchWithType('app');
$stat_visit_teble->searchWithUnacid($_W['uniacid']);
$today_exist = $stat_visit_teble->get();
if (empty($today_exist)) {
$insert_data = array(
'uniacid' => $_W['uniacid'],
'module' => $module_name,
'type' => 'app',
'date' => $today,
'count' => 1,
'ip_count' => 0
);
pdo_insert('stat_visit', $insert_data);
$today_exist = $insert_data;
$today_exist['id'] = pdo_insertid();
} else {
$data = array('count' => $today_exist['count'] + 1);
pdo_update('stat_visit' , $data, array('id' => $today_exist['id']));
}
$yestoday = date('Ymd', strtotime('-1 day'));
$cache_key = cache_system_key('delete_visit_ip', array('date' => $yestoday));
$is_delete_visit_ip = cache_load($cache_key);
if (empty($is_delete_visit_ip)) {
pdo_delete('stat_visit_ip', $yestoday);
cache_write($cache_key, true);
}
if (!empty($today_exist['id'])) {
$ip = ip2long(getip());
$stat_ip_visit_table = table('stat_visit_ip');
$stat_ip_visit_table->searchWithIp($ip);
$stat_ip_visit_table->searchWithDate($today);
$ip_today_exist = $stat_ip_visit_table->get();
if (empty($ip_today_exist)) {
$ip_insert_data = array(
'ip' => $ip,
'uniacid' => $_W['uniacid'],
'module' => $module_name,
'type' => 'app',
'date' => $today,
);
pdo_insert('stat_visit_ip', $ip_insert_data);
pdo_update('stat_visit', array('ip_count' => $today_exist['ip_count'] + 1), array('id' => $today_exist['id']));
}
}
return true;
}
function app_pass_visit_limit($uniacid = 0) {
global $_W;
if (strpos($_W['siteurl'], 'api.php?') === false && ($_W['isajax'] || $_W['ispost'] || strpos($_W['siteurl'], 'c=utility&a=visit') !== false)) {
return false;
}
$uniacid = intval($uniacid) > 0 ? intval($uniacid) : $_W['uniacid'];
$limit = uni_setting_load('statistics', $uniacid);
$limit = $limit['statistics'];
if (empty($limit)) {
return false;
}
$cachekey = cache_system_key('statistics', array('uniacid' => $uniacid));
$cache = cache_load($cachekey);
if (!empty($cache) && ($cache['time'] + $limit['interval'] > TIMESTAMP)) {
return $cache['limit'];
}
$data = array('time'=> TIMESTAMP, 'limit' => false);
$today_num = app_today_visit($uniacid);
if (!empty($limit['founder'])) {
$order_num = 0;
$orders = table('store')->apiOrderWithUniacid($uniacid);
if (!empty($orders)) {
foreach ($orders as $order) {
$order_num += $order['duration'] * $order['api_num'] * 10000;
}
}
$before_num = app_month_visit_till_today($uniacid);
if ($limit['founder'] + $order_num <= $before_num + $today_num) {
$data['limit'] = true;
cache_write($cachekey, $data);
return true;
}
}
if (!empty($limit['owner']) && $today_num > $limit['owner']) {
$data['limit'] = true;
cache_write($cachekey, $data);
return true;
}
if (!empty($limit['founder']) && ($before_num + $today_num) > $limit['founder']) {
$limit['use'] = !empty($limit['use']) ? (intval($limit['use']) + 1) : 1;
uni_setting_save('statistics', $limit);
}
cache_write($cachekey, $data);
return false;
}
function app_month_visit_till_today($uniacid = 0) {
global $_W;
$result = 0;
$uniacid = intval($uniacid) > 0 ? intval($uniacid) : $_W['uniacid'];
$today = date('Ymd');
$cachekey = cache_system_key('uniacid_visit', array('uniacid' => $uniacid, 'today' => $today));
$cache = cache_load($cachekey);
if (!empty($cache)) {
return $cache;
}
$start = date('Ym01', strtotime(date("Ymd")));
$end = date('Ymd', strtotime('-1 day'));
$stat_visit_teble = table('stat_visit');
$stat_visit_teble->searchWithGreaterThenDate($start);
$stat_visit_teble->searchWithLessThenDate($end);
$stat_visit_teble->searchWithType('app');
$stat_visit_teble->searchWithUnacid($uniacid);
$visit = $stat_visit_teble->getall();
if (!empty($visit)) {
foreach ($visit as $val) {
$result += $val['count'];
}
}
cache_write($cachekey, $result);
return $result;
}
function app_today_visit($uniacid = 0) {
global $_W;
$result = 0;
$uniacid = intval($uniacid) > 0 ? intval($uniacid) : $_W['uniacid'];
$stat_visit_teble = table('stat_visit');
$stat_visit_teble->searchWithDate(date('Ymd'));
$stat_visit_teble->searchWithType('app');
$stat_visit_teble->searchWithUnacid($uniacid);
$today = $stat_visit_teble->getall();
if (!empty($today)) {
foreach ($today as $val) {
$result += $val['count'];
}
}
return $result;
}