123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499 |
- <?php
-
- defined('IN_IA') or exit('Access Denied');
-
- load()->model('module');
- load()->model('cloud');
- load()->model('cache');
- load()->classs('weixin.platform');
- load()->model('utility');
- load()->func('file');
- $uniacid = intval($_GPC['uniacid']);
- $acid = intval($_GPC['acid']);
- if (empty($uniacid) || empty($acid)) {
- $url = url('account/manage', array('account_type' => ACCOUNT_TYPE));
- itoast('请选择要编辑的' . ACCOUNT_TYPE_NAME, $url, 'error');
- }
- $defaultaccount = uni_account_default($uniacid);
- if (!$defaultaccount) {
- itoast('无效的acid', url('account/manage'), 'error');
- }
- $acid = $defaultaccount['acid'];
- $state = permission_account_user_role($_W['uid'], $uniacid);
- $dos = array('base', 'sms', 'modules_tpl');
-
- $role_permission = in_array($state, array(ACCOUNT_MANAGE_NAME_FOUNDER, ACCOUNT_MANAGE_NAME_OWNER, ACCOUNT_MANAGE_NAME_VICE_FOUNDER));
- if ($role_permission) {
- $do = in_array($do, $dos) ? $do : 'base';
- } elseif ($state == ACCOUNT_MANAGE_NAME_MANAGER) {
- if (ACCOUNT_TYPE == ACCOUNT_TYPE_APP_NORMAL || ACCOUNT_TYPE == ACCOUNT_TYPE_APP_AUTH) {
- header('Location: ' . url('wxapp/manage/display', array('uniacid' => $uniacid, 'acid' => $acid)));
- exit;
- } else {
- $do = in_array($do, $dos) ? $do : 'modules_tpl';
- }
- } else {
- itoast('您是该公众号的操作员,无权限操作!', url('account/manage'), 'error');
- }
-
- $_W['page']['title'] = '管理设置 - ' . ACCOUNT_TYPE_NAME . '管理';
- $headimgsrc = tomedia('headimg_'.$acid.'.jpg');
- $qrcodeimgsrc = tomedia('qrcode_'.$acid.'.jpg');
- $account = account_fetch($acid);
-
- if($do == 'base') {
- if (!$role_permission) {
- itoast('无权限操作!', url('account/post/modules_tpl', array('uniacid' => $uniacid, 'acid' => $acid)), 'error');
- }
- if($_W['ispost'] && $_W['isajax']) {
- if(!empty($_GPC['type'])) {
- $type = trim($_GPC['type']);
- } else {
- iajax(40035, '参数错误!', '');
- }
- switch ($type) {
- case 'qrcodeimgsrc':
- case 'headimgsrc':
- $image_type = array(
- 'qrcodeimgsrc' => ATTACHMENT_ROOT . 'qrcode_' . $acid . '.jpg',
- 'headimgsrc' => ATTACHMENT_ROOT . 'headimg_' . $acid . '.jpg'
- );
- $imgsrc = $_GPC['imgsrc'];
- if(!file_is_image($imgsrc)){
- $result = '';
- }
- $result = utility_image_rename($imgsrc, $image_type[$type]);
- break;
- case 'name':
- $uni_account = pdo_update('uni_account', array('name' => trim($_GPC['request_data'])), array('uniacid' => $uniacid));
- $account_wechats = pdo_update(uni_account_tablename(ACCOUNT_TYPE), array('name' => trim($_GPC['request_data'])), array('acid' => $acid, 'uniacid' => $uniacid));
- $result = ($uni_account && $account_wechats) ? true : false;
- break;
- case 'account' :
- $data = array('account' => trim($_GPC['request_data']));break;
- case 'original':
- $data = array('original' => trim($_GPC['request_data']));break;
- case 'level':
- $data = array('level' => intval($_GPC['request_data']));break;
- case 'key':
- $data = array('key' => trim($_GPC['request_data']));break;
- case 'secret':
- $data = array('secret' => trim($_GPC['request_data']));break;
- case 'token':
- $oauth = (array)uni_setting_load(array('oauth'), $uniacid);
- if($oauth['oauth'] == $acid && $account['level'] != 4) {
- $acid = pdo_fetchcolumn("SELECT acid FROM " . tablename('account_wechats') . " WHERE uniacid = :uniacid AND level = 4 AND secret != '' AND `key` != ''", array(':uniacid' => $uniacid));
- pdo_update('uni_settings', array('oauth' => iserializer(array('account' => $acid, 'host' => $oauth['oauth']['host']))), array('uniacid' => $uniacid));
- }
- $data = array('token' => trim($_GPC['request_data']));
- break;
- case 'encodingaeskey':
- $oauth = (array)uni_setting_load(array('oauth'), $uniacid);
- if($oauth['oauth'] == $acid && $account['level'] != 4) {
- $acid = pdo_fetchcolumn("SELECT acid FROM " . tablename('account_wechats') . " WHERE uniacid = :uniacid AND level = 4 AND secret != '' AND `key` != ''", array(':uniacid' => $uniacid));
- pdo_update('uni_settings', array('oauth' => iserializer(array('account' => $acid, 'host' => $oauth['oauth']['host']))), array('uniacid' => $uniacid));
- }
- $data = array('encodingaeskey' => trim($_GPC['request_data']));
- break;
- case 'jointype':
- $original_type = pdo_get('account', array('uniacid' => $uniacid), 'type');
- if ($original_type['type'] == ACCOUNT_NORMAL_LOGIN) {
- $result = true;
- } else {
- $update_type = pdo_update('account', array('type' => ACCOUNT_NORMAL_LOGIN), array('uniacid' => $uniacid));
- $result = $update_type ? true : false;
- }
- break;
- case 'highest_visit':
- if (user_is_vice_founder() || empty($_W['isfounder'])) {
- iajax(1, '只有创始人可以修改!');
- }
- $statistics_setting = (array)uni_setting_load(array('statistics'), $uniacid);
- if (!empty($statistics_setting['statistics'])) {
- $highest_visit = $statistics_setting['statistics'];
- $highest_visit['founder'] = intval($_GPC['request_data']);
- } else {
- $highest_visit = array('founder' => intval($_GPC['request_data']));
- }
- $result = pdo_update('uni_settings', array('statistics' => iserializer($highest_visit)), array('uniacid' => $uniacid));
- break;
- case 'endtime':
- $endtime = strtotime($_GPC['endtime']);
- if ($endtime <= 0) {
- iajax(1, '参数错误!');
- }
-
- $store_create_account_info = table('store')->StoreCreateAccountInfo($uniacid);
-
- if (user_is_founder($_W['uid'], true)) {
-
- if (!empty($store_create_account_info)) {
- pdo_update('site_store_create_account', array('endtime' => $endtime), array('uniacid' => $uniacid));
- }
-
- } else {
- $owner_id = pdo_getcolumn('uni_account_users', array('uniacid' => $uniacid, 'role' => 'owner'), 'uid');
- $user_endtime = pdo_getcolumn('users', array('uid' => $owner_id), 'endtime');
-
- if (!empty($store_create_account_info)) {
- $user_endtime = max($user_endtime, $store_create_account_info['endtime']);
- }
-
- if ($user_endtime < $endtime && !empty($user_endtime)) {
- iajax(1, '设置到期日期不能超过' . date('Y-m-d', $user_endtime));
- }
- }
- $result = pdo_update('account', array('endtime' => $endtime), array('uniacid' => $uniacid));
- break;
- case 'attachment_limit':
- if (user_is_vice_founder() || empty($_W['isfounder'])) {
- iajax(1, '只有创始人可以修改!');
- }
- $has_uniacid = pdo_getcolumn('uni_settings', array('uniacid' => $uniacid), 'uniacid');
- if ($_GPC['request_data'] < 0) {
- $attachment_limit = -1;
- } else {
- $attachment_limit = intval($_GPC['request_data']);
- }
- if (empty($has_uniacid)) {
- $result = pdo_insert('uni_settings', array('attachment_limit' => $attachment_limit, 'uniacid' => $uniacid));
- } else {
- $result = pdo_update('uni_settings', array('attachment_limit' => $attachment_limit), array('uniacid' => $uniacid));
- }
- break;
- }
- if(!in_array($type, array('qrcodeimgsrc', 'headimgsrc', 'name', 'endtime', 'jointype', 'highest_visit', 'attachment_limit'))) {
- $result = pdo_update(uni_account_tablename(ACCOUNT_TYPE), $data, array('acid' => $acid, 'uniacid' => $uniacid));
- }
- if($result) {
- cache_delete(cache_system_key('uniaccount', array('uniacid' => $uniacid)));
- cache_delete(cache_system_key('accesstoken', array('acid' => $acid)));
- cache_delete(cache_system_key('statistics', array('uniacid' => $uniacid)));
- iajax(0, '修改成功!', '');
- } else {
- iajax(1, '修改失败!', '');
- }
- }
-
- if ($_W['setting']['platform']['authstate']) {
- $account_platform = new WeixinPlatform();
- $preauthcode = $account_platform->getPreauthCode();
- if (is_error($preauthcode)) {
- $authurl = array(
- 'errno' => 1,
- 'url' => "{$preauthcode['message']}"
- );
- } else {
- $authurl = array(
- 'errno' => 0,
- 'url' => sprintf(ACCOUNT_PLATFORM_API_LOGIN, $account_platform->appid, $preauthcode, urlencode($GLOBALS['_W']['siteroot'] . 'index.php?c=account&a=auth&do=forward'), ACCOUNT_PLATFORM_API_LOGIN_ACCOUNT)
- );
- }
- }
- $account['start'] = date('Y-m-d', $account['starttime']);
- $account['end'] = $account['endtime'] == 0 ? '永久' : date('Y-m-d', $account['endtime']);
- $account['endtype'] = $account['endtime'] == 0 ? 1 : 2;
- $uni_setting = (array)uni_setting_load(array('statistics', 'attachment_limit', 'attachment_size'), $uniacid);
- $account['highest_visit'] = empty($uni_setting['statistics']['founder']) ? 0 : $uni_setting['statistics']['founder'];
- $account['attachment_size'] = round($uni_setting['attachment_size'] / 1024, 2);
-
- $attachment_limit = intval($uni_setting['attachment_limit']);
- if ($attachment_limit == 0) {
- $upload = setting_load('upload');
- $attachment_limit = empty($upload['upload']['attachment_limit']) ? 0 : intval($upload['upload']['attachment_limit']);
- }
- if ($attachment_limit <= 0) {
- $attachment_limit = -1;
- }
- $account['attachment_limit'] = intval($attachment_limit);
-
- $uniaccount = array();
- $uniaccount = pdo_get('uni_account', array('uniacid' => $uniacid));
-
- $account_api = uni_site_store_buy_goods($uniacid, STORE_TYPE_API);
-
- template('account/manage-base' . ACCOUNT_TYPE_TEMPLATE);
- }
-
- if($do == 'sms') {
- if (!$role_permission) {
- itoast('无权限操作!', url('account/post/modules_tpl', array('uniacid' => $uniacid, 'acid' => $acid)), 'error');
- }
- $settings = uni_setting($uniacid, array('notify'));
- $notify = $settings['notify'] ? $settings['notify'] : array();
-
- $sms_info = cloud_sms_info();
- $max_num = empty($sms_info['sms_count']) ? 0 : $sms_info['sms_count'];
- $signatures = $sms_info['sms_sign'];
-
- if ($_W['isajax'] && $_W['ispost'] && $_GPC['type'] == 'balance') {
- if ($max_num == 0) {
- iajax(-1, '您现有短信数量为0,请联系服务商购买短信!', '');
- }
- $balance = intval($_GPC['balance']);
- $notify['sms']['balance'] = $balance;
- $notify['sms']['balance'] = min(max(0, $notify['sms']['balance']), $max_num);
- $count_num = $max_num - $notify['sms']['balance'];
- $num = $notify['sms']['balance'];
- $notify = iserializer($notify);
- $updatedata['notify'] = $notify;
- $result = pdo_update('uni_settings', $updatedata , array('uniacid' => $uniacid));
- if($result){
- iajax(0, array('count' => $count_num, 'num' => $num), '');
- }else {
- iajax(1, '修改失败!', '');
- }
- }
- if($_W['isajax'] && $_W['ispost'] && $_GPC['type'] == 'signature') {
- if (!empty($_GPC['signature'])) {
- $signature = trim($_GPC['signature']);
- $setting = pdo_get('uni_settings', array('uniacid' => $uniacid));
- $notify = iunserializer($setting['notify']);
- $notify['sms']['signature'] = $signature;
-
- $notify = serialize($notify);
- $result = pdo_update('uni_settings', array('notify' => $notify), array('uniacid' => $uniacid));
- if($result) {
- iajax(0, '修改成功!', '');
- }else {
- iajax(1, '修改失败!', '');
- }
- }else {
- iajax(40035, '参数错误!', '');
- }
- }
-
- template('account/manage-sms' . ACCOUNT_TYPE_TEMPLATE);
- }
-
- if($do == 'modules_tpl') {
- $owner = $account->owner;
- if($_W['isajax'] && $_W['ispost'] && ($role_permission)) {
- if($_GPC['type'] == 'group') {
- $groups = $_GPC['groupdata'];
- if(!empty($groups)) {
- pdo_delete('uni_account_group', array('uniacid' => $uniacid));
- $group = pdo_get('users_group', array('id' => $owner['groupid']));
- $group['package'] = (array)iunserializer($group['package']);
- $group['package'] = array_unique($group['package']);
- foreach ($groups as $packageid) {
- if (!empty($packageid) && !in_array($packageid, $group['package'])) {
- pdo_insert('uni_account_group', array(
- 'uniacid' => $uniacid,
- 'groupid' => $packageid,
- ));
- }
- }
- cache_build_account_modules($uniacid);
- cache_build_account($uniacid);
- iajax(0, '修改成功!', '');
- }else {
- pdo_delete('uni_account_group', array('uniacid' => $uniacid));
- cache_build_account_modules($uniacid);
- cache_build_account($uniacid);
- iajax(0, '修改成功!', '');
- }
- }
-
- if($_GPC['type'] == 'extend') {
- $module = $_GPC['module'];
- $tpl = $_GPC['tpl'];
- if (!empty($module) || !empty($tpl)) {
- $data = array(
- 'modules' => array('modules' => array(), 'wxapp' => array(), 'webapp' => array(), 'xzapp' => array(), 'phoneapp' => array()),
- 'templates' => empty($tpl) ? '' : iserializer($tpl),
- 'uniacid' => $uniacid,
- 'name' => '',
- );
- switch ($defaultaccount['type']) {
- case ACCOUNT_TYPE_OFFCIAL_NORMAL:
- case ACCOUNT_TYPE_OFFCIAL_AUTH:
- $data['modules']['modules'] = $module;
- break;
- case ACCOUNT_TYPE_APP_NORMAL:
- case ACCOUNT_TYPE_APP_AUTH:
- case ACCOUNT_TYPE_WXAPP_WORK:
- $data['modules']['wxapp'] = $module;
- break;
- case ACCOUNT_TYPE_WEBAPP_NORMAL:
- $data['modules']['webapp'] = $module;
- break;
- case ACCOUNT_TYPE_XZAPP_NORMAL:
- case ACCOUNT_TYPE_XZAPP_AUTH:
- $data['modules']['xzapp'] = $module;
- break;
- case ACCOUNT_TYPE_PHONEAPP_NORMAL:
- $data['modules']['phoneapp'] = $module;
- break;
- case ACCOUNT_TYPE_ALIAPP_NORMAL:
- $data['modules']['aliapp'] = $module;
- break;
- }
- $data['modules'] = iserializer($data['modules']);
-
- $id = pdo_fetchcolumn("SELECT id FROM ".tablename('uni_group')." WHERE uniacid = :uniacid", array(':uniacid' => $uniacid));
- if (empty($id)) {
- pdo_insert('uni_group', $data);
- } else {
- pdo_update('uni_group', $data, array('id' => $id));
- }
- } else {
- pdo_delete('uni_group', array('uniacid' => $uniacid));
- }
- cache_build_account_modules($uniacid);
- cache_build_account($uniacid);
- iajax(0, '修改成功!', '');
- }
-
- if ($_GPC['type'] == 'store_endtime' && user_is_founder($_W['uid']) && !user_is_vice_founder()) {
- $order_id = intval($_GPC['order_id']);
- $new_endtime = safe_gpc_string($_GPC['new_time']);
- if (empty($order_id)) {
- iajax(-1, '参数错误!');
- }
- $condition = array('uniacid' => $uniacid, 'type' => STORE_ORDER_FINISH, 'id' => $order_id);
- $order_exist = pdo_get('site_store_order', $condition);
- if (!empty($order_exist)) {
- pdo_update('site_store_order', array('endtime' => strtotime($new_endtime)), $condition);
- } else {
- iajax(-1, '您未购买该权限组!');
- }
- iajax(0, '修改成功!', referer());
- }
-
-
- iajax(40035, '参数错误!', '');
- }
- $modules_tpl = $extend = array();
-
- $founders = explode(',', $_W['config']['setting']['founder']);
- if (in_array($_W['uid'], $founders)) {
- $uni_groups = uni_groups();
- }
- if (in_array($owner['uid'], $founders)) {
- $modules_tpl[] = array(
- 'id' => -1,
- 'name' => '所有服务',
- 'modules' => array(array('name' => 'all', 'title' => '所有模块')),
- 'templates' => array(array('name' => 'all', 'title' => '所有模板')),
- 'type' => 'default'
- );
- } else {
- if ($owner['founder_groupid'] == ACCOUNT_MANAGE_GROUP_VICE_FOUNDER) {
- $owner['group'] = pdo_get('users_founder_group', array('id' => $owner['groupid']), array('id', 'name', 'package'));
- } else {
- $owner['group'] = pdo_get('users_group', array('id' => $owner['groupid']), array('id', 'name', 'package'));
- }
-
- $owner['group']['package'] = (array)iunserializer($owner['group']['package']);
- if(!empty($owner['group']['package'])){
- foreach ($owner['group']['package'] as $package_value) {
- if($package_value == -1){
- $modules_tpl[] = array(
- 'id' => -1,
- 'name' => '所有服务',
- 'modules' => array(array('name' => 'all', 'title' => '所有模块')),
- 'templates' => array(array('name' => 'all', 'title' => '所有模板')),
- 'type' => 'default'
- );
- }elseif ($package_value == 0) {
-
- }else {
- $defaultmodule = current(uni_groups(array($package_value)));
- $defaultmodule['type'] = 'default';
- $defaultmodule['modules'] = $account->typeSign == 'account' ? $defaultmodule['modules'] : $defaultmodule[$account->typeSign];
- $modules_tpl[] = $defaultmodule;
- }
- }
- }
- $extendpackage = pdo_getall('uni_account_group', array('uniacid' => $uniacid), array(), 'groupid');
- if(!empty($extendpackage)) {
- foreach ($extendpackage as $extendpackage_val) {
- if($extendpackage_val['groupid'] == -1){
- $modules_tpl[] = array(
- 'id' => -1,
- 'name' => '所有服务',
- 'modules' => array(array('name' => 'all', 'title' => '所有模块')),
- 'templates' => array(array('name' => 'all', 'title' => '所有模板')),
- 'type' => 'extend' );
- }elseif ($extendpackage_val['groupid'] == 0) {
-
- }else {
- $ex_module = current(uni_groups(array($extendpackage_val['groupid'])));
- if (!empty($ex_module)) {
- $ex_module['type'] = 'extend';
- $modules_tpl[] = $ex_module;
- }
- }
- }
- }
- }
-
- $modules = user_modules($_W['uid']);
- $templates = pdo_getall('site_templates', array(), array('id', 'name', 'title'));
- $extend = pdo_get('uni_group', array('uniacid' => $uniacid));
- $extend_modules = iunserializer($extend['modules']);
- $extend['modules'] = array();
- foreach ($extend_modules as $modulenames) {
- if (!empty($modulenames)) {
- $extend['modules'] = $current_module_names = array_merge($extend['modules'], $modulenames);
- }
- }
- $extend['templates'] = iunserializer($extend['templates']);
- $canmodify = false;
-
- if ($_W['role'] == ACCOUNT_MANAGE_NAME_FOUNDER && !in_array($owner['uid'], $founders) || $_W['role'] == ACCOUNT_MANAGE_NAME_VICE_FOUNDER && $owner['uid'] != $_W['uid']) {
- $canmodify = true;
- }
-
-
- if (!empty($extend['modules'])) {
- $extend['modules'] = $current_module_names = array_unique($current_module_names);
- foreach ($extend['modules'] as $module_key => $module_val) {
- $extend['modules'][$module_key] = module_fetch($module_val);
- }
- }
- if (!empty($extend['templates'])) {
- $extend['templates'] = pdo_getall('site_templates', array('id' => $extend['templates']), array('id', 'name', 'title'));
- }
-
- $account_buy_modules = uni_site_store_buy_goods($uniacid,$_GPC['account_type']);
- if (!empty($account_buy_modules) && is_array($account_buy_modules)) {
- foreach ($account_buy_modules as &$module) {
- $module = module_fetch($module);
- $module['goods_id'] = pdo_getcolumn('site_store_goods', array('module' => $module['name'], 'status' => 1), 'id');
- $order_info = pdo_get('site_store_order', array('uniacid' => $uniacid, 'type' => STORE_ORDER_FINISH, 'goodsid' => $module['goods_id']), array('id', 'max(endtime) as endtime'));
- $module['order_id'] = $order_info['id'];
- $module['expire_time'] = $order_info['endtime'];
- }
- }
- unset($module);
- $store = table('store');
- $account_buy_group = uni_site_store_buy_goods($uniacid, STORE_TYPE_PACKAGE);
- $account_buy_package = array();
- if (is_array($account_buy_group) && !empty($account_buy_group)) {
- foreach ($account_buy_group as $group) {
- $account_buy_package[$group] = current(uni_groups(array($group)));
- $account_buy_package[$group]['goods_id'] = pdo_getcolumn('site_store_goods', array('module_group' => $group), 'id');
- $order_info = pdo_fetch(
- 'SELECT id, endtime from ' . tablename('site_store_order') . ' WHERE (uniacid = :uniacid OR wxapp = :wxapp) AND `type` = :status AND goodsid = :goodsid ORDER BY endtime DESC LIMIT 1'
- , array(':uniacid' => $uniacid, ':wxapp' => $uniacid, ':status' => STORE_ORDER_FINISH, ':goodsid' => $account_buy_package[$group]['goods_id'])
- );
- $account_buy_package[$group]['order_id'] = $order_info['id'];
- $account_buy_package[$group]['expire_time'] = $order_info['endtime'];
- if (TIMESTAMP > $account_buy_package[$group]['expire_time']) {
- $account_buy_package[$group]['expire'] = true;
- } else {
- $account_buy_package[$group]['expire'] = false;
- $account_buy_package[$group]['near_expire'] = strtotime('-1 week', $account_buy_package[$group]['expire_time']) < time() ? true : false;
- }
- $account_buy_package[$group]['expire_time'] = date('Y-m-d', $account_buy_package[$group]['expire_time']);
- }
- }
- unset($group);
-
- template('account/manage-modules-tpl');
- }
|