1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198 |
- <?php
- /**
- * [WeEngine System] Copyright (c) 2014 WE7.CC
- * WeEngine is NOT a free software, it under the license terms, visited http://www.we7.cc/ for more details.
- */
- defined('IN_IA') or exit('Access Denied');
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- define('CLOUD_GATEWAY_URL', $_URLTYPE.$_SERVER['HTTP_HOST']);
- define('CLOUD_GATEWAY_URL_NORMAL', $_URLTYPE.$_SERVER['HTTP_HOST']);
- function cloud_client_define() {
- return array(
- '/framework/function/communication.func.php',
- '/framework/model/cloud.mod.php',
- '/web/source/cloud/upgrade.ctrl.php',
- '/web/source/cloud/process.ctrl.php',
- '/web/source/cloud/dock.ctrl.php',
- '/web/themes/default/cloud/upgrade.html',
- '/web/themes/default/cloud/process.html'
- );
- }
-
- function _cloud_build_params() {
- global $_W;
- $pars = array();
- if (is_array($_W['setting']['site']) && !empty($_W['setting']['site']['url'])) {
- $pars['host'] = parse_url($_W['setting']['site']['url'], PHP_URL_HOST);
- }
- if (empty($pars['host'])) {
- $pars['host'] = $_SERVER['HTTP_HOST'];
- }
- $pars['family'] = IMS_FAMILY;
- $pars['version'] = IMS_VERSION;
- $pars['release'] = IMS_RELEASE_DATE;
- if (!empty($_W['setting']['site'])) {
- $pars['key'] = $_W['setting']['site']['key'];
- $pars['password'] = md5($_W['setting']['site']['key'] . $_W['setting']['site']['token']);
- }
- $clients = cloud_client_define();
- $string = '';
- foreach($clients as $cli) {
- $string .= md5_file(IA_ROOT . $cli);
- }
- $pars['client'] = md5($string);
- return $pars;
- }
-
- function _cloud_shipping_parse($dat, $file)
- {
-
-
- }
-
- function cloud_request($url, $post = '', $extra = array(), $timeout = 60) {
- global $_W;
- load()->func('communication');
- if (!empty($_W['setting']['cloudip']['ip']) && empty($extra['ip'])) {
- $extra['ip'] = $_SERVER['HTTP_HOST'];
- }
- return array();
- }
-
- function cloud_prepare() {
- global $_W;
- setting_load();
-
- return true;
- }
-
- function cloud_build()
- {
-
- return null;
- }
-
- function cloud_schema() {
- $pars = _cloud_build_params();
- $pars['method'] = 'application.schema';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/application.schema';
- $ret = _cloud_shipping_parse($dat, $file);
- if(!is_error($ret)) {
- $schemas = array();
- if(!empty($ret['schemas'])) {
- load()->func('db');
- foreach($ret['schemas'] as $remote) {
- $name = substr($remote['tablename'], 4);
- $local = db_table_schema(pdo(), $name);
- unset($remote['increment']);
- unset($local['increment']);
- if(empty($local)) {
- $schemas[] = $remote;
- } else {
- $diffs = db_schema_compare($local, $remote);
- if(!empty($diffs)) {
- $schemas[] = $remote;
- }
- }
- }
- }
- $ret['schemas'] = $schemas;
- }
- return $ret;
- }
-
- function cloud_download($path, $type = '') {
- $pars = _cloud_build_params();
- $pars['method'] = 'application.shipping';
- $pars['path'] = $path;
- $pars['type'] = $type;
- $pars['gz'] = function_exists('gzcompress') && function_exists('gzuncompress') ? 'true' : 'false';
- $pars['download'] = 'true';
- $headers = array('content-type' => 'application/x-www-form-urlencoded');
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, $headers, 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- if($dat['content'] == 'success') {
- return true;
- }
- $ret = @json_decode($dat['content'], true);
- if(is_error($ret)) {
- return $ret;
- } else {
- $post = $dat['content'];
- $data = base64_decode($post);
- if (base64_encode($data) !== $post) {
- $data = $post;
- }
- $ret = iunserializer($data);
- $gz = function_exists('gzcompress') && function_exists('gzuncompress');
- $file = base64_decode($ret['file']);
- if($gz) {
- $file = gzuncompress($file);
- }
- $_W['setting']['site']['token'] = authcode(cache_load('cloud:transtoken'), 'DECODE');
- $string = (md5($file) . $ret['path'] . $_W['setting']['site']['token']);
- if(!empty($_W['setting']['site']['token']) && md5($string) === $ret['sign']) {
- $error_file_list = array();
- if (!cloud_file_permission_pass($error_file_list)) {
- return error(-1, '请修复下列文件读写权限 : ' . implode('; ', $error_file_list));
- }
- $path = IA_ROOT . $ret['path'];
- load()->func('file');
- @mkdirs(dirname($path));
- if (file_put_contents($path, $file)) {
- if (!empty($ret['extend'])) {
- foreach ($ret['extend'] as $file) {
- $path = base64_decode($file['path']);
- $file = base64_decode($file['file']);
- if (empty($path) || empty($file)) {
- continue;
- }
- if($gz) {
- $file = gzuncompress($file);
- }
- $path = IA_ROOT . $path;
- @mkdirs(dirname($path));
- file_put_contents($path, $file);
- }
- }
- return true;
- } else {
- return error(-1, '写入失败');
- }
- }
- return error(-1, '写入失败');
- }
- }
-
- function cloud_m_prepare($name) {
- $pars['method'] = 'module.check';
- $pars['module'] = $name;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- if (is_error($dat)) {
- return $dat;
- }
- if ($dat['content'] == 'install-module-protect') {
- }
- return true;
- }
-
-
- function cloud_m_build($modulename, $type = '')
- {
-
- return null;
- }
-
-
- function cloud_m_query($module = array()) {
- $pars = _cloud_build_params();
- $pars['method'] = 'module.query';
- if (empty($module)) {
- $pars['module'] = cloud_extra_module();
- } else {
- if (!is_array($module)) {
- $module = array($module);
- }
- $pars['module'] = base64_encode(iserializer($module));
- }
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/module.query';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
-
- function cloud_m_bought() {
- $pars = _cloud_build_params();
- $pars['method'] = 'module.bought';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/module.bought';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
- function cloud_m_info($name) {
- $pars = _cloud_build_params();
- $pars['method'] = 'module.info';
- $pars['module'] = $name;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/module.info';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
-
-
- function cloud_m_upgradeinfo($name) {
- $module = pdo_fetch("SELECT name, version FROM ".tablename('modules')." WHERE name = '{$name}'");
- $pars = _cloud_build_params();
- $pars['method'] = 'module.info';
- $pars['module'] = $name;
- $pars['curversion'] = $module['version'];
- $pars['isupgrade'] = 1;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/module.info';
- $ret = _cloud_shipping_parse($dat, $file);
- if (!empty($ret) && !is_error($ret)) {
- $ret['site_branch'] = $ret['branches'][$ret['version']['branch_id']];
- $ret['from'] = 'cloud';
- foreach ($ret['branches'] as &$branch) {
- if ($branch['displayorder'] < $ret['site_branch']['displayorder'] || ($ret['site_branch']['displayorder'] == $ret['site_branch']['displayorder'] && $ret['site_branch']['id'] > intval($branch['id']))) {
- unset($module['branches'][$branch['id']]);
- continue;
- }
- $branch['id'] = intval($branch['id']);
- $branch['version']['description'] = preg_replace('/\n/', '<br/>', $branch['version']['description']);
- $branch['displayorder'] = intval($branch['displayorder']);
- $branch['day'] = intval(date('d', $branch['version']['createtime']));
- $branch['month'] = date('Y.m', $branch['version']['createtime']);
- $branch['hour'] = date('H:i', $branch['version']['createtime']);
- }
- unset($branch);
- }
- return $ret;
- }
-
- function cloud_t_prepare($name)
- {
-
- return true;
- }
-
-
- function cloud_t_query()
- {
- return null;
- }
-
- function cloud_t_info($name)
- {
-
- return null;
- }
-
- function cloud_t_build($name) {
- if (empty($name)) {
- return array();
- }
- $sql = 'SELECT * FROM ' . tablename('site_templates') . ' WHERE `name`=:name';
- $theme = pdo_fetch($sql, array(':name' => $name));
-
- $pars = _cloud_build_params();
- $pars['method'] = 'theme.build';
- $pars['theme'] = $name;
- if(!empty($theme)) {
- $pars['themeversion'] = $theme['version'];
- }
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/theme.build';
- $ret = _cloud_shipping_parse($dat, $file);
- if(!is_error($ret)) {
- $dir = IA_ROOT . '/app/themes/' . $name;
- $files = array();
- if(!empty($ret['files'])) {
- foreach($ret['files'] as $file) {
- $entry = $dir . $file['path'];
- if(!is_file($entry) || md5_file($entry) != $file['checksum']) {
- $files[] = '/'. $name . $file['path'];
- }
- }
- }
- $ret['files'] = $files;
- $ret['upgrade'] = true;
- $ret['type'] = 'theme';
- if(empty($theme)) {
- $ret['install'] = 1;
- }
- cache_write('cloud:transtoken', authcode($ret['token'], 'ENCODE'));
- }
- return $ret;
- }
-
-
- function cloud_t_upgradeinfo($name) {
- if (empty($name)) {
- return array();
- }
- $sql = 'SELECT `name`, `version` FROM ' . tablename('site_templates') . ' WHERE `name` = :name';
- $theme = pdo_fetch($sql, array(':name' => $name));
- $pars = _cloud_build_params();
- $pars['method'] = 'theme.upgrade';
- $pars['theme'] = $theme['name'];
- $pars['version'] = $theme['version'];
- $pars['isupgrade'] = 1;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/module.info';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
-
- function cloud_w_prepare($name) {
- $pars['method'] = 'webtheme.check';
- $pars['webtheme'] = $name;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- if (is_error($dat)) {
- return $dat;
- }
- if ($dat['content'] == 'install-webtheme-protect') {
- return error('-1', '此后台皮肤已设置版权保护,您只能通过云平台来安装。');
- }
- return true;
- }
-
-
- function cloud_w_query() {
- $pars = _cloud_build_params();
- $pars['method'] = 'webtheme.query';
- $pars['webtheme'] = cloud_extra_webtheme();
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/webtheme.query';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
-
- function cloud_w_info($name) {
- $pars = _cloud_build_params();
- $pars['method'] = 'webtheme.info';
- $pars['webtheme'] = $name;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/webtheme.info';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
-
- function cloud_w_build($name)
- {
- $sql = 'SELECT * FROM ' . tablename('webtheme_homepages') . ' WHERE `name`=:name';
- $webtheme = pdo_fetch($sql, array(':name' => $name));
-
- $pars = _cloud_build_params();
- $pars['method'] = 'webtheme.build';
- $pars['webtheme'] = $name;
- if(!empty($webtheme)) {
- $pars['webtheme_version'] = $webtheme['version'];
- }
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/webtheme.build';
- $ret = _cloud_shipping_parse($dat, $file);
- if(!is_error($ret)) {
- $dir = IA_ROOT . '/web/themes/' . $name;
- $files = array();
- if(!empty($ret['files'])) {
- foreach($ret['files'] as $file) {
- $entry = $dir . $file['path'];
- if(!is_file($entry) || md5_file($entry) != $file['checksum']) {
- $files[] = '/'. $name . $file['path'];
- }
- }
- }
- $ret['files'] = $files;
- $ret['upgrade'] = true;
- $ret['type'] = 'webtheme';
- if(empty($webtheme)) {
- $ret['install'] = 1;
- }
- cache_write('cloud:transtoken', authcode($ret['token'], 'ENCODE'));
- }
- return $ret;
- }
-
-
- function cloud_w_upgradeinfo($name)
- {
- $sql = 'SELECT `name`, `version` FROM ' . tablename('webtheme_homepages') . ' WHERE `name` = :name';
- $webtheme = pdo_fetch($sql, array(':name' => $name));
- $pars = _cloud_build_params();
- $pars['method'] = 'webtheme.upgrade';
- $pars['webtheme'] = $webtheme['name'];
- $pars['version'] = $webtheme['version'];
- $pars['isupgrade'] = 1;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- $file = IA_ROOT . '/data/webtheme.info';
- $ret = _cloud_shipping_parse($dat, $file);
- return $ret;
- }
- function cloud_sms_send($mobile, $content, $postdata = array(), $custom_sign = '') {
- global $_W;
-
- if(!preg_match('/^1\d{10}$/', $mobile) || empty($content)) {
- return error(1, '发送短信失败, 原因: 手机号错误或内容为空.');
- }
-
- if (empty($_W['uniacid'])) {
- $sms_info = cloud_sms_info();
- $balance = empty($sms_info['sms_count']) ? 0 : $sms_info['sms_count'];
- if (!empty($custom_sign)) {
- $sign = $custom_sign;
-
- }
-
- } else {
- $row = pdo_get('uni_settings' , array('uniacid' => $_W['uniacid']), array('notify'));
- $row['notify'] = @iunserializer($row['notify']);
-
- $config = $row['notify']['sms'];
- $balance = intval($config['balance']);
-
- $sign = $config['signature'];
- }
- if(empty($sign)) {
- $sign = '短信宝';
- }
- //判断剩余条数
- if($balance<1){
- return error(-1, '短信发送失败, 原因:余额不足');
- }
- //短信宝账号
- // $smsbao_info=pdo_get('uni_settings' , array('uniacid' => $_W['uniacid']), array('copyright'));
- //$smsbao_info=setting_load($key = 'copyright');
- $sms_param['u']=$_W['setting']['copyright']['sms_name'];
- $sms_param['p']=md5($_W['setting']['copyright']['sms_password']);
- $sms_param['m']=$mobile;
- $sms_param['c']='【'.$sign.'】'.$content;
- $statusStr = array(
- "0" => "短信发送成功",
- "-1" => "参数不全",
- "-2" => "服务器空间不支持,请确认支持curl或者fsocket,联系您的空间商解决或者更换空间!",
- "30" => "密码错误",
- "40" => "账号不存在",
- "41" => "余额不足",
- "42" => "帐户已过期",
- "43" => "IP地址限制",
- "50" => "内容含有敏感词"
- );
- $response = file_get_contents("http://api.smsbao.com/sms?".http_build_query($sms_param));
- if (trim($response)!='0') {
- return error($response, '短信发送失败, 原因:'.$statusStr[$response]);
- }
-
- if (trim($response)=='0') {
- if (!empty($_W['uniacid'])) {
- $row['notify']['sms']['balance'] = $row['notify']['sms']['balance'] - 1;
- if ($row['notify']['sms']['balance'] < 0) {
- $row['notify']['sms']['balance'] = 0;
- }
- pdo_update('uni_settings', array('notify' => iserializer($row['notify'])), array('uniacid' => $_W['uniacid']));
- uni_setting_save('notify', $row['notify']);
- }
-
- }
- return true;
- }
- /*function cloud_sms_send($mobile, $content, $postdata = array(), $custom_sign = '') {
- global $_W;
- if(!preg_match('/^1\d{10}$/', $mobile) || empty($content)) {
- return error(1, '发送短信失败, 原因: 手机号错误或内容为空.');
- }
-
- if (empty($_W['uniacid'])) {
- $sms_info = cloud_sms_info();
- $balance = empty($sms_info['sms_count']) ? 0 : $sms_info['sms_count'];
- if (!empty($custom_sign)) {
- $sign = $custom_sign;
- }
- } else {
- $row = pdo_get('uni_settings' , array('uniacid' => $_W['uniacid']), array('notify'));
- $row['notify'] = @iunserializer($row['notify']);
-
- $config = $row['notify']['sms'];
- $balance = intval($config['balance']);
-
- $sign = $config['signature'];
- }
- if(empty($sign)) {
- $sign = '涛盛微擎团队';
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'sms.sendnew';
- $pars['mobile'] = $mobile;
- $pars['uniacid'] = $_W['uniacid'];
- $pars['balance'] = $balance;
- $pars['sign'] = $sign;
- if (!empty($postdata)) {
- $pars['content'] = $content;
- $pars['postdata'] = $postdata;
- } else {
- $pars['content'] = "{$content} 【{$sign}】";
- }
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $response = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- if (is_error($response)) {
- return error($response['errno'], '短信发送失败, 原因:'.$response['message']);
- }
-
- $result = json_decode($response['content'], true);
-
- if (is_error($result)) {
- return error($result['errno'], $result['message']);
- }
- if (intval($result['errno']) != -1) {
- if (!empty($_W['uniacid'])) {
- $row['notify']['sms']['balance'] = $row['notify']['sms']['balance'] - 1;
- if ($row['notify']['sms']['balance'] < 0) {
- $row['notify']['sms']['balance'] = 0;
- }
- pdo_update('uni_settings', array('notify' => iserializer($row['notify'])), array('uniacid' => $_W['uniacid']));
- uni_setting_save('notify', $row['notify']);
- } else {
- $sms_info['sms_count'] = $sms_info['sms_count'] - 1;
- if ($sms_info['sms_count'] < 0) {
- $sms_info['sms_count'] = 0;
- }
- setting_save($sms_info, 'sms.info');
- }
- }
- return true;
- }
- */
- function cloud_sms_info() {
- global $_W;
-
- $data=array();
- //返回短信的剩余条数以及签名
- $sms_name=$_W['setting']['copyright']['sms_name'];
- $sms_password=md5($_W['setting']['copyright']['sms_password']);
- $res=file_get_contents("http://api.smsbao.com/query?u={$sms_name}&p={$sms_password}");
- $retArr = explode("\n", $res);
- $balanceArr = explode(",", $retArr[1]);
- $data['sms_count']=$retArr[0] == 0 ? $balanceArr[1]:0;
- return $data;
- }
- /*function cloud_sms_info() {
- global $_W;
-
- $pars = _cloud_build_params();
- $pars['method'] = 'sms.info';
- $dat = cloud_request($_SERVER['HTTP_HOST'], $pars);
- if ($dat['content'] == 'success') {
- $setting_key = "sms.info";
- $dat = setting_load($setting_key);
- return $dat[$setting_key];
- }
-
- return array();
- }
- */
-
- function cloud_extra_account() {
- $data = array();
- $data['accounts'] = pdo_fetchall("SELECT name, account, original FROM ".tablename('account_wechats') . " GROUP BY account");
- return serialize($data);
- }
-
-
- function cloud_extra_module() {
- $sql = 'SELECT `name` FROM ' . tablename('modules') . ' WHERE `type` <> :type';
- $modules = pdo_fetchall($sql, array(':type' => 'system'), 'name');
- if (!empty($modules)) {
- return base64_encode(iserializer(array_keys($modules)));
- } else {
- return '';
- }
- }
-
-
- function cloud_extra_theme() {
- $sql = 'SELECT `name` FROM ' . tablename('site_templates') . ' WHERE `name` <> :name';
- $themes = pdo_fetchall($sql, array(':name' => 'default'), 'name');
- if (!empty($themes)) {
- return base64_encode(iserializer(array_keys($themes)));
- } else {
- return '';
- }
- }
-
-
- function cloud_extra_webtheme() {
- $sql = 'SELECT `name` FROM ' . tablename('webtheme_templates') . ' WHERE `name` <> :name';
- $themes = pdo_fetchall($sql, array(':name' => 'default'), 'name');
- if (!empty($themes)) {
- return base64_encode(iserializer(array_keys($themes)));
- } else {
- return '';
- }
- }
-
-
- function cloud_cron_create($cron) {
- $pars = _cloud_build_params();
- $pars['method'] = 'cron.create';
- $pars['cron'] = base64_encode(iserializer($cron));
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $result = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- return _cloud_cron_parse($result);
- }
-
-
- function cloud_cron_update($cron) {
- $pars = _cloud_build_params();
- $pars['method'] = 'cron.update';
- $pars['cron'] = base64_encode(iserializer($cron));
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $result = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- return _cloud_cron_parse($result);
- }
-
-
- function cloud_cron_get($cron_id) {
- $pars = _cloud_build_params();
- $pars['method'] = 'cron.get';
- $pars['cron_id'] = $cron_id;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $result = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- return _cloud_cron_parse($result);
- }
-
-
- function cloud_cron_change_status($cron_id, $status) {
- $pars = _cloud_build_params();
- $pars['method'] = 'cron.status';
- $pars['cron_id'] = $cron_id;
- $pars['status'] = $status;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $result = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- return _cloud_cron_parse($result);
- }
-
-
- function cloud_cron_remove($cron_id) {
- $pars = _cloud_build_params();
- $pars['method'] = 'cron.remove';
- $pars['cron_id'] = $cron_id;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $result = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars);
- return _cloud_cron_parse($result);
- }
-
-
- function _cloud_cron_parse($result) {
- if (empty($result)) {
- return error(-1, '没有接收到服务器的传输的数据');
- }
- if ($result['content'] == 'blacklist') {
- return error(-1, '抱歉,您的站点已被列入云服务黑名单,云服务一切业务已被禁止,请联系微擎客服!');
- }
- $result = json_decode($result['content'], true);
- if (null === $result) {
- return error(-1, '云服务通讯发生错误,请稍后重新尝试!');
- }
- $result = $result['message'];
- if (is_error($result)) {
- return error(-1, $result['message']);
- }
- return $result;
- }
-
-
- function cloud_auth_url($forward, $data = array()){
- global $_W;
- if (!empty($_W['setting']['site']['url']) && !strexists($_W['siteroot'], $_W['setting']['site']['url'])) {
- $url = $_W['setting']['site']['url'];
- } else {
- $url = rtrim($_W['siteroot'], '/');
- }
- $auth = array();
- $auth['key'] = '';
- $auth['password'] = '';
- $auth['url'] = $url;
- $auth['referrer'] = intval($_W['config']['setting']['referrer']);
- $auth['version'] = IMS_VERSION;
- $auth['forward'] = $forward;
- $auth['family'] = IMS_FAMILY;
-
- if(!empty($_W['setting']['site']['key']) && !empty($_W['setting']['site']['token'])) {
- $auth['key'] = $_W['setting']['site']['key'];
- $auth['password'] = md5($_W['setting']['site']['key'] . $_W['setting']['site']['token']);
- }
- if ($data && is_array($data)) {
- $auth = array_merge($auth, $data);
- }
- $query = base64_encode(json_encode($auth));
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $auth_url = $_URLTYPE.$_SERVER['HTTP_HOST'] . $query;
-
- return $auth_url;
- }
-
-
- function cloud_module_setting_prepare($module, $binding) {
- global $_W;
- $auth = _cloud_build_params();
- $auth['arguments'] = array(
- 'binding' => $binding,
- 'acid' => $_W['uniacid'],
- 'type' => 'module',
- 'module' => $module,
- );
- $iframe_auth_url = cloud_auth_url('module', $auth);
-
- return $iframe_auth_url;
- }
-
-
- function cloud_resource_to_local($uniacid, $type, $url){
- global $_W;
-
- load()->func('file');
-
- $setting = $_W['setting']['upload'][$type];
-
- if (!file_is_image($url)) {
- return error(1, '远程图片后缀非法,请重新上传');;
- }
- if (substr($url, 0, 2) == '//') {
- $url = 'http:' . $url;
- }
- $pathinfo = pathinfo($url);
- $extension = $pathinfo['extension'];
- $originname = $pathinfo['basename'];
-
- $setting['folder'] = "{$type}s/{$uniacid}/".date('Y/m/');
-
- $originname = pathinfo($url, PATHINFO_BASENAME);
- $filename = file_random_name(ATTACHMENT_ROOT .'/'. $setting['folder'], $extension);
- $pathname = $setting['folder'] . $filename;
- $fullname = ATTACHMENT_ROOT . $pathname;
-
- mkdirs(dirname($fullname));
-
- load()->func('communication');
- $response = ihttp_get($url);
- if (is_error($response)) {
- return error(1, $response['message']);
- }
- if (file_put_contents($fullname, $response['content']) == false) {
- return error(1, '提取文件失败');
- }
-
- if (!empty($_W['setting']['remote']['type'])) {
- $remotestatus = file_remote_upload($pathname);
- if (is_error($remotestatus)) {
- return error(1, '远程附件上传失败,请检查配置并重新上传');
- } else {
- file_delete($pathname);
- }
- }
-
- $data = array(
- 'uniacid' => $uniacid,
- 'uid' => intval($_W['uid']),
- 'filename' => $originname,
- 'attachment' => $pathname,
- 'type' => $type == 'image' ? 1 : 2,
- 'createtime' => TIMESTAMP,
- );
- pdo_insert('core_attachment', $data);
-
- $data['url'] = tomedia($pathname);
- $data['id'] = pdo_insertid();
-
- return $data;
- }
-
- function cloud_bakup_files($files) {
- global $_W;
- if (empty($files)) {
- return false;
- }
- $map = json_encode($files);
- $hash = md5($map.$_W['config']['setting']['authkey']);
- if ($handle = opendir(IA_ROOT . '/data/patch/' . date('Ymd'))) {
- while (false !== ($patchpath = readdir($handle))) {
- if ($patchpath != '.' && $patchpath != '..') {
- if (strexists($patchpath, $hash)) {
- return false;
- }
- }
- }
- }
-
- $path = IA_ROOT . '/data/patch/' . date('Ymd') . '/' . date('Hi') . '_' . $hash;
- load()->func('file');
- if (!is_dir($path) && mkdirs($path)) {
- foreach ($files as $file) {
- if (file_exists(IA_ROOT . $file)) {
- mkdirs($path . '/' . dirname($file));
- file_put_contents($path . '/' . $file, file_get_contents(IA_ROOT . $file));
- }
- }
- file_put_contents($path . '/' . 'map.json', $map);
- }
- return false;
- }
-
-
- function cloud_flow_master_post($flow_master) {
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.master_post';
- $pars['flow_master'] = array(
- 'linkman' => $flow_master['linkman'],
- 'mobile' => $flow_master['mobile'],
- 'address' => $flow_master['address'],
- 'id_card_photo' => $flow_master['id_card_photo'], 'business_licence_photo' => $flow_master['business_licence_photo'], );
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- cache_delete("cloud:flow:master");
- $ret = @json_decode($dat['content'], true);
- return $ret;
- }
-
-
- function cloud_flow_master_get() {
- $cachekey = "cloud:flow:master";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['setting'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.master_get';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- if ($ret['status'] == '3') {
- cache_write($cachekey, array('expire' => TIMESTAMP + 300, 'setting' => $ret));
- } else if ($ret['status'] == '4') {
- cache_write($cachekey, array('expire' => TIMESTAMP + 12 * 3600, 'setting' => $ret));
- }
- return $ret;
- }
-
- function cloud_flow_uniaccount_post($uniaccount) {
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.uniaccount_post';
- $pars['uniaccount'] = array(
- 'uniacid' => $uniaccount['uniacid'],
- );
- isset($uniaccount['title']) && $pars['uniaccount']['title'] = $uniaccount['title'];
- isset($uniaccount['original']) && $pars['uniaccount']['original'] = $uniaccount['original'];
- isset($uniaccount['gh_type']) && $pars['uniaccount']['gh_type'] = $uniaccount['gh_type'];
- isset($uniaccount['ad_tags']) && $pars['uniaccount']['ad_tags'] = $uniaccount['ad_tags'];
- isset($uniaccount['enable']) && $pars['uniaccount']['enable'] = $uniaccount['enable'];
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- cache_delete("cloud:ad:uniaccount:{$uniaccount['uniacid']}");
- cache_delete("cloud:ad:uniaccount:list");
- $ret = @json_decode($dat['content'], true);
- return $ret;
- }
-
- function cloud_flow_uniaccount_get($uniacid) {
- $cachekey = "cloud:ad:uniaccount:{$uniacid}";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['setting'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.uniaccount_get';
- $pars['uniaccount'] = array(
- 'uniacid' => $uniacid,
- );
- $pars['md5'] = md5(base64_encode(serialize($pars['uniaccount'])));
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 600, 'setting' => $ret));
- return $ret;
- }
-
- function cloud_flow_uniaccount_list_get() {
- $cachekey = "cloud:ad:uniaccount:list";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['setting'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.uniaccount_list_get';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 600, 'setting' => $ret));
- return $ret;
- }
-
- function cloud_flow_ad_tag_list() {
- $cachekey = "cloud:ad:tags";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['items'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.ad_tag_list';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 6 * 3600, 'items' => $ret));
- return $ret;
- }
-
- function cloud_flow_ad_type_list() {
- $cachekey = "cloud:ad:type:list";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['items'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.ad_type_list';
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 3600, 'items' => $ret));
- return $ret;
- }
-
- function cloud_flow_app_post($uniacid, $module_name, $enable = 0, $ad_types = null) {
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.app_post';
- $pars['uniaccount_app'] = array(
- 'uniacid' => $uniacid,
- 'module' => $module_name,
- );
- if (!empty($enable)) {
- $pars['uniaccount_app']['enable'] = $enable; }
- if (is_array($ad_types)) {
- $pars['uniaccount_app']['ad_types'] = $ad_types; }
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- cache_delete("cloud:ad:app:list:{$uniacid}");
- $ret = @json_decode($dat['content'], true);
- return $ret;
- }
-
-
- function cloud_flow_app_list_get($uniacid) {
- $cachekey = "cloud:ad:app:list:{$uniacid}";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['setting'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.app_list_get';
- $pars['uniaccount'] = array(
- 'uniacid' => $uniacid,
- );
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 300, 'setting' => $ret));
- return $ret;
- }
-
- function cloud_flow_app_support_list($module_names) {
- if (empty($module_names)) {
- return array();
- }
- $cachekey = "cloud:ad:app:support:list";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['setting'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.app_support_list';
- $pars['modules'] = $module_names;
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 300, 'setting' => $ret));
- return $ret;
- }
-
- function cloud_flow_site_stat_day($condition) {
- $cachekey = "cloud:ad:site:finance";
- $cache = cache_load($cachekey);
- if(!empty($cache) && $cache['expire'] > TIMESTAMP) {
- return $cache['info'];
- }
- $pars = _cloud_build_params();
- $pars['method'] = 'flow.site_stat_day';
- $pars['condition'] = array();
- $pars['condition']['starttime'] = $condition['starttime'];
- $pars['condition']['endtime'] = $condition['endtime'];
- $pars['condition']['page'] = $condition['page'];
- $pars['condition']['size'] = $condition['size'];
-
- $_URLTYPE = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') || (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')) ? 'https://' : 'http://';
- $dat = cloud_request($_URLTYPE.$_SERVER['HTTP_HOST'], $pars, array(), 300);
- if(is_error($dat)) {
- return error(-1, '网络存在错误, 请稍后重试。' . $dat['message']);
- }
- $ret = @json_decode($dat['content'], true);
- cache_write($cachekey, array('expire' => TIMESTAMP + 300, 'info' => $ret));
- return $ret;
- }
- function cloud_build_transtoken() {
- $pars = _cloud_build_params();
- $pars['method'] = 'application.token';
- $dat = cloud_request(CLOUD_GATEWAY_URL_NORMAL, $pars);
- $file = IA_ROOT . '/data/application.build';
- $ret = _cloud_shipping_parse($dat, $file);
- cache_write('cloud:transtoken', authcode($ret['token'], 'ENCODE'));
- return $ret['token'];
- }
-
- function cloud_build_schemas($schemas) {
- $database = array();
- if (empty($schemas) || !is_array($schemas)) {
- return $database;
- }
- foreach ($schemas as $remote) {
- $row = array();
- $row['tablename'] = $remote['tablename'];
- $name = substr($remote['tablename'], 4);
- $local = db_table_schema(pdo(), $name);
- unset($remote['increment']);
- unset($local['increment']);
- if (empty($local)) {
- $row['new'] = true;
- } else {
- $row['new'] = false;
- $row['fields'] = array();
- $row['indexes'] = array();
- $diffs = db_schema_compare($local, $remote);
- if (!empty($diffs['fields']['less'])) {
- $row['fields'] = array_merge($row['fields'], $diffs['fields']['less']);
- }
- if (!empty($diffs['fields']['diff'])) {
- $row['fields'] = array_merge($row['fields'], $diffs['fields']['diff']);
- }
- if (!empty($diffs['indexes']['less'])) {
- $row['indexes'] = array_merge($row['indexes'], $diffs['indexes']['less']);
- }
- if (!empty($diffs['indexes']['diff'])) {
- $row['indexes'] = array_merge($row['indexes'], $diffs['indexes']['diff']);
- }
- $row['fields'] = implode($row['fields'], ' ');
- $row['indexes'] = implode($row['indexes'], ' ');
- }
- $database[] = $row;
- }
- return $database;
- }
-
- function cloud_file_permission_pass(&$error_file_list = array()) {
- $check_path = array(
- '/web/common',
- '/web/source',
- '/web/themes/default',
- '/web/themes/black',
- '/framework/class',
- '/framework/model',
- '/framework/function',
- '/framework/table',
- '/framework/library/agent',
- );
- $check_file = array(
- '/web/index.php',
- '/framework/bootstrap.inc.php',
- '/framework/version.inc.php',
- '/framework/const.inc.php',
- );
- $sub_paths = array();
- foreach ($check_path as $path) {
- $file_list = cloud_file_tree(IA_ROOT . $path);
- if (!empty($file_list)) {
- foreach ($file_list as $file) {
- if (is_file($file)) {
- $sub_path = pathinfo($file, PATHINFO_DIRNAME);
- if (empty($sub_paths[$sub_path])) {
- if (!cloud_path_is_writable($sub_path)) {
- $error_file_list[] = str_replace(IA_ROOT, '', $sub_path);
- }
- $sub_paths[$sub_path] = $sub_path;
- }
- }
- if (!is_writable($file)) {
- $error_file_list[] = str_replace(IA_ROOT, '', $file);
- }
- }
- }
- }
- foreach ($check_file as $file) {
- if (!is_writable(IA_ROOT . $file)) {
- $error_file_list[] = str_replace(IA_ROOT, '', $file);;
- }
- }
- return empty($error_file_list) ? true : false;
- }
- function cloud_file_tree($path, $include = array()) {
- $files = array();
- if (!empty($include)) {
- $ds = glob($path . '/{' . implode(',', $include) . '}', GLOB_BRACE);
- } else {
- $ds = glob($path . '/*');
- }
- if (is_array($ds)) {
- foreach ($ds as $entry) {
- if (is_file($entry)) {
- $files[] = $entry;
- }
- if (is_dir($entry)) {
- $rs = cloud_file_tree($entry);
- foreach ($rs as $f) {
- $files[] = $f;
- }
- }
- }
- }
- return $files;
- }
- function cloud_path_is_writable($dir) {
- $writeable = false;
- if (!is_dir($dir)) {
- @mkdir($dir, 0755);
- }
- if (is_dir($dir)) {
- if($fp = fopen("$dir/test.txt", 'w')) {
- fclose($fp);
- unlink("$dir/test.txt");
- $writeable = true;
- } else {
- $writeable = false;
- }
- }
- return $writeable;
- }
|