|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Admin\Controller;
|
|
|
|
/**
|
|
|
|
* 后台首页控制器
|
|
|
|
* @author 麦当苗儿 <zuojiazi@vip.qq.com>
|
|
|
|
*/
|
|
|
|
class ToolController extends ThinkController {
|
|
|
|
public $pay_type = [
|
|
|
|
0 => ['name' => '支付宝', 'paytag' => 'alipay' ],
|
|
|
|
1 => ['name' => '微信', 'paytag' => 'wxpay'],
|
|
|
|
2 => ['name' => '易宝', 'paytag' => 'yeepay'],
|
|
|
|
3 => ['name' => '双乾', 'paytag' => 'sqpay'],
|
|
|
|
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
*保存设置
|
|
|
|
*/
|
|
|
|
public function saveTool($value='')
|
|
|
|
{
|
|
|
|
$name = $_POST['name'];
|
|
|
|
$config = I('config');
|
|
|
|
|
|
|
|
$data = array('config'=>json_encode($config),'template'=>$_POST['template'],'status'=>$_POST['status']);
|
|
|
|
$map['name']=$name;
|
|
|
|
|
|
|
|
$day_pay = $config['day_pay_limit'];
|
|
|
|
$month_pay = $config['month_pay_limit'];
|
|
|
|
if(!empty($day_pay) && !empty($month_pay)) {
|
|
|
|
if($month_pay / date('t') > $day_pay) {
|
|
|
|
$this->error('月支付限量较日支付限量过大');
|
|
|
|
} elseif ($month_pay < $day_pay) {
|
|
|
|
$this->error('月支付限量不能小于日支付限量');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if($_POST['status']==1&&$name=="weixin"){
|
|
|
|
$map_['name']=array("in",'wei_xin,wei_xin_app,weixin_gf');
|
|
|
|
M('tool','tab_')->where($map_)->setField('status','0');
|
|
|
|
}
|
|
|
|
if($_POST['status']==1&&$name=="wei_xin"||$name=="wei_xin_app"){
|
|
|
|
$map_['name']=['in','weixin,weixin_gf'];
|
|
|
|
M('tool','tab_')->where($map_)->setField('status','0');
|
|
|
|
}
|
|
|
|
if($_POST['status']==1&&$name=="weixin_gf"){
|
|
|
|
$map_['name']=array("in",'wei_xin,wei_xin_app,weixin');
|
|
|
|
M('tool','tab_')->where($map_)->setField('status','0');
|
|
|
|
}
|
|
|
|
if (isset($config['channel_rate']) && ($config['channel_rate'] > 100 || !is_numeric($config['channel_rate']))) {
|
|
|
|
$this->error('请输入正确的渠道费率');
|
|
|
|
}
|
|
|
|
if (isset($config['channel_rate'])) $config['channel_rate'] = round($config['channel_rate'], 2);
|
|
|
|
|
|
|
|
$flag = M('Tool','tab_')->where($map)->setField($data);
|
|
|
|
if($flag !== false){
|
|
|
|
$config['status']=$_POST['status'];
|
|
|
|
$this->set_config($name,$config);
|
|
|
|
\Think\Log::actionLog('Tool/saveTool','Tool',1);
|
|
|
|
$this->success('保存成功');
|
|
|
|
}else{
|
|
|
|
$this->error('保存失败');
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 给图片添加水印
|
|
|
|
* @author 鹿文学
|
|
|
|
* @date 2018-05-03
|
|
|
|
*/
|
|
|
|
public function addWatermarkOnPic() {
|
|
|
|
// watermark
|
|
|
|
$tool = M('tool',"tab_")->field('config,status')->where(['name'=>'watermark'])->find();
|
|
|
|
|
|
|
|
if(empty($tool)){$this->error('没有此设置');}
|
|
|
|
|
|
|
|
if($tool['status']==0) {$this->error('添加水印已关闭');exit;}
|
|
|
|
|
|
|
|
$piclist = M('picture')->field('path,url,water')->where(['status'=>1,'water'=>array('neq','')])->select();
|
|
|
|
|
|
|
|
if (!is_array($piclist)) {$this->error('没有图片需要添加');exit;}
|
|
|
|
|
|
|
|
$water = json_decode($tool['config'],true);
|
|
|
|
|
|
|
|
$temp = explode(',',$water['position']);
|
|
|
|
$position = 3*$temp[0]+$temp[1]+1;
|
|
|
|
|
|
|
|
|
|
|
|
$image = new \Think\Image();
|
|
|
|
|
|
|
|
if ($water['types']==1) { // 文字
|
|
|
|
|
|
|
|
$offset = array(
|
|
|
|
$water['hoffset']?$water['hoffset']:0,
|
|
|
|
$water['voffset']?$water['voffset']:0
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach ($piclist as $k => $v) {
|
|
|
|
|
|
|
|
$image->open(ROOTTT.$v['path'])->text($water['font_text'],FONTS.$water['font'],$water['font_size'],$water['font_color'],$position,$offset)->save(ROOTTT.$v['water'],$image->type(),$water['quality']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} else { // 图片
|
|
|
|
|
|
|
|
foreach ($piclist as $k => $v) {
|
|
|
|
|
|
|
|
|
|
|
|
$img_url=M('picture')->find($water['icon']);
|
|
|
|
$img_url=$img_url['path'];
|
|
|
|
$image->open(ROOTTT.$v['path'])->water(ROOTTT.$img_url,$position,$water['transparency'])->save(ROOTTT.$v['water'],$image->type(),$water['quality']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->success('水印添加成功');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function save($config){
|
|
|
|
$name = $_POST['name'];
|
|
|
|
$a = $this->set_config($name,$config);
|
|
|
|
if ($a){
|
|
|
|
return true;
|
|
|
|
}else{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*显示扩展设置信息
|
|
|
|
*/
|
|
|
|
protected function BaseConfig($name='')
|
|
|
|
{
|
|
|
|
$map['name'] = array('in',$name);
|
|
|
|
$tool = M('tool',"tab_")->where($map)->select();
|
|
|
|
if(empty($tool)){$this->error('没有此设置');}
|
|
|
|
foreach ($tool as $key => $val) {
|
|
|
|
$this->assign($tool[$key]['name'],json_decode($tool[$key]['config'],true));
|
|
|
|
unset($tool[$key]['config']);
|
|
|
|
$this->assign($tool[$key]['name']."_data",$tool[$key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* 打款设置
|
|
|
|
*/
|
|
|
|
public function transfer_set()
|
|
|
|
{
|
|
|
|
$this->BaseConfig("transfer_set");
|
|
|
|
$this->meta_title = '打款设置';
|
|
|
|
//TODO:获取 当前账号余额
|
|
|
|
$money = 10000;
|
|
|
|
$this->assign("money",$money);
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function saveTransferSet()
|
|
|
|
{
|
|
|
|
$name = $_POST['name'];
|
|
|
|
$config = I('config');
|
|
|
|
if(empty($config['user_id']) || empty($config['user_num']) || empty($config['phone'])){
|
|
|
|
$this->error('会员id,打款账号,打款验证手机号 均不允许为空');
|
|
|
|
}
|
|
|
|
if(!checkPhone($config['phone'])) {
|
|
|
|
$this->error('联系电话格式不正确');
|
|
|
|
}
|
|
|
|
$data = array('config'=>json_encode($config));
|
|
|
|
$map['name']=$name;
|
|
|
|
|
|
|
|
$flag = M('Tool','tab_')->where($map)->setField($data);
|
|
|
|
if($flag !== false){
|
|
|
|
$this->success('保存成功');
|
|
|
|
}else{
|
|
|
|
$this->error('保存失败');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*短信设置
|
|
|
|
*/
|
|
|
|
public function smsset($value='')
|
|
|
|
{
|
|
|
|
$this->BaseConfig("sms_set,alidayu,jiguang,alidayunew,zhongwang,juhedata");
|
|
|
|
$this->meta_title = '短信设置';
|
|
|
|
|
|
|
|
$this->m_title = '短信设置';
|
|
|
|
$url = 'Tool/smsset';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*防沉迷设置
|
|
|
|
*/
|
|
|
|
public function age($value='')
|
|
|
|
{
|
|
|
|
$this->BaseConfig("tool_age,juhe_age");
|
|
|
|
$this->meta_title = '实名认证';
|
|
|
|
|
|
|
|
$this->m_title = '实名认证';
|
|
|
|
$url = 'Tool/age';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*文件存储
|
|
|
|
*/
|
|
|
|
public function storage($value='')
|
|
|
|
{
|
|
|
|
$str = "oss_storage,qiniu_storage,cos_storage,bos_storage,ks3_storage";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '文件存储';
|
|
|
|
|
|
|
|
$this->m_title = '文件存储';
|
|
|
|
$url = 'Tool/storage';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*动态密保
|
|
|
|
*/
|
|
|
|
public function cooperate($value='')
|
|
|
|
{
|
|
|
|
$str = "set_cooperate";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '动态密保';
|
|
|
|
|
|
|
|
$this->m_title = '动态密保';
|
|
|
|
$url = 'Tool/cooperate';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*支付设置
|
|
|
|
*/
|
|
|
|
public function payset($value='')
|
|
|
|
{
|
|
|
|
$str = "alipay,weixin,wei_xin,wei_xin_app,jubaobar,weixin_gf,jft,jft_wap,goldpig,ptb_pay,bind_pay,sqpay,heepay,yeepay,ptb_pay";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '支付设置';
|
|
|
|
|
|
|
|
$this->m_title = '支付设置';
|
|
|
|
$url = 'Tool/payset';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*邮件设置
|
|
|
|
*/
|
|
|
|
public function email($value='')
|
|
|
|
{
|
|
|
|
$str = "email_set";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '邮件设置';
|
|
|
|
|
|
|
|
$this->m_title = '邮件设置';
|
|
|
|
$url = 'Tool/email';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*第三方登录设置
|
|
|
|
*/
|
|
|
|
public function qq_thirdparty($value='')
|
|
|
|
{
|
|
|
|
$str = "qq_login,weixin_login,fb_login,gg_login";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
|
|
|
|
$this->m_title = '第三方登录';
|
|
|
|
$url = 'Tool/qq_thirdparty';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*第三方登录设置
|
|
|
|
*/
|
|
|
|
public function wx_thirdparty($value='')
|
|
|
|
{
|
|
|
|
$str = "weixin_login";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*第三方登录设置
|
|
|
|
*/
|
|
|
|
public function wb_thirdparty($value='')
|
|
|
|
{
|
|
|
|
$str = "sina_login";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*第三方登录设置
|
|
|
|
*/
|
|
|
|
public function bd_thirdparty($value='')
|
|
|
|
{
|
|
|
|
$str = "baidu_login";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*畅言设置
|
|
|
|
*/
|
|
|
|
public function changyan($value=''){
|
|
|
|
$str = "changyan";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '畅言设置';
|
|
|
|
|
|
|
|
$this->m_title = '畅言设置';
|
|
|
|
$url = 'Tool/changyan';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*聚宝云
|
|
|
|
*/
|
|
|
|
public function saveTool_jubaobar(){
|
|
|
|
$name = $_POST['name'];
|
|
|
|
$config = I('config');
|
|
|
|
$data = array('config'=>json_encode($config),'template'=>$_POST['template'],'status'=>$_POST['status']);
|
|
|
|
$map['name']=$name;
|
|
|
|
$flag = M('Tool','tab_')->where($map)->setField($data);
|
|
|
|
if($flag !== false){
|
|
|
|
$this->set_config($name,$config);
|
|
|
|
$this->update_xml($config['key']);
|
|
|
|
$this->success('保存成功');
|
|
|
|
}else{
|
|
|
|
$this->error('保存失败');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*修改 聚宝云 安全口令
|
|
|
|
*/
|
|
|
|
private function update_xml($key=""){
|
|
|
|
// $file = $_SERVER['DOCUMENT_ROOT'].'Application/Sdk/SecretKey/jubaopay/jubaopay.ini';
|
|
|
|
$file = './Application/Sdk/SecretKey/jubaopay/jubaopay.ini';
|
|
|
|
//创建DOMDocument的对象
|
|
|
|
$dom = new \DOMDocument('1.0');
|
|
|
|
//载入mainchart.xml文件
|
|
|
|
$dom->load($file);
|
|
|
|
$dom->getElementsByTagName('psw')->item(0)->nodeValue = $key;
|
|
|
|
$dom->save($file);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*设置config
|
|
|
|
*/
|
|
|
|
private function set_config($name="",$config=""){
|
|
|
|
$config_file ="./Application/Common/Conf/pay_config.php";
|
|
|
|
if(file_exists($config_file)){
|
|
|
|
$configs=include $config_file;
|
|
|
|
}else {
|
|
|
|
$configs=array();
|
|
|
|
}
|
|
|
|
#定义一个数组
|
|
|
|
$data = array();
|
|
|
|
#给数组赋值
|
|
|
|
$data[$name] = $config;
|
|
|
|
$configs=array_merge($configs,$data);
|
|
|
|
$result = file_put_contents($config_file, "<?php\treturn " . var_export($configs, true) . ";");
|
|
|
|
|
|
|
|
$ageConfigJson = json_encode($config);
|
|
|
|
M('tool', 'tab_')->where([
|
|
|
|
'name' => $name
|
|
|
|
])->save([
|
|
|
|
'config' => $ageConfigJson,
|
|
|
|
'type' => 1,
|
|
|
|
'status' => isset($config['status']) ? $config['status'] : $config['bat']
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function ios_game(){
|
|
|
|
if($_GET['t']==1){
|
|
|
|
$url="qq";
|
|
|
|
}elseif($_GET['t']==2){
|
|
|
|
$url="wx";
|
|
|
|
}elseif($_GET['t']==3){
|
|
|
|
$url="wb";
|
|
|
|
}else{
|
|
|
|
$url="bd";
|
|
|
|
}
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$this->assign('thirdparty',$url."_thirdparty");
|
|
|
|
$this->assign('param_lists',$url."_param_lists");
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function qq_param_lists(){
|
|
|
|
if(isset($_GET['game_id'])){
|
|
|
|
$map['game_id']=$_GET['game_id'];
|
|
|
|
}
|
|
|
|
$map['type']=1;
|
|
|
|
$model = array(
|
|
|
|
'm_name' => 'param',
|
|
|
|
'map' => $map,
|
|
|
|
'fields'=>'id,game_id,openid,key,callback,status,create_time',
|
|
|
|
'order' =>'id desc',
|
|
|
|
'title' => "第三方登录",
|
|
|
|
'template_list' =>'qq_param_lists',
|
|
|
|
);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$user = A('User','Event');
|
|
|
|
$user->user_join_($model,$_GET['p']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function wx_param_lists(){
|
|
|
|
if(isset($_GET['game_id'])){
|
|
|
|
$map['game_id']=$_GET['game_id'];
|
|
|
|
}
|
|
|
|
$map['type']=2;
|
|
|
|
$model = array(
|
|
|
|
'm_name' => 'param',
|
|
|
|
'map' => $map,
|
|
|
|
'fields'=>'id,game_id,wx_appid,appsecret,callback,status,create_time',
|
|
|
|
'order' =>'id desc',
|
|
|
|
'title' => "第三方登录",
|
|
|
|
'template_list' =>'wx_param_lists',
|
|
|
|
);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$user = A('User','Event');
|
|
|
|
$user->user_join_($model,$_GET['p']);
|
|
|
|
|
|
|
|
}
|
|
|
|
public function wb_param_lists(){
|
|
|
|
if(isset($_GET['game_id'])){
|
|
|
|
$map['game_id']=$_GET['game_id'];
|
|
|
|
}
|
|
|
|
$map['type']=3;
|
|
|
|
$model = array(
|
|
|
|
'm_name' => 'param',
|
|
|
|
'map' => $map,
|
|
|
|
'field'=>'id,game_id,appkey,scope,callback,status,create_time',
|
|
|
|
'order' =>'id desc',
|
|
|
|
'title' => "第三方登录",
|
|
|
|
'template_list' =>'wb_param_lists',
|
|
|
|
);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$user = A('User','Event');
|
|
|
|
$user->user_join_($model,$_GET['p']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function bd_param_lists(){
|
|
|
|
if(isset($_GET['game_id'])){
|
|
|
|
$map['game_id']=$_GET['game_id'];
|
|
|
|
}
|
|
|
|
$map['type']=4;
|
|
|
|
$model = array(
|
|
|
|
'm_name' => 'param',
|
|
|
|
'map' => $map,
|
|
|
|
'field'=>'id,game_id,openid,key,callback,status,create_time',
|
|
|
|
'order' =>'id desc',
|
|
|
|
'title' => "第三方登录",
|
|
|
|
'template_list' =>'bd_param_lists',
|
|
|
|
);
|
|
|
|
$this->meta_title = '第三方登录';
|
|
|
|
$user = A('User','Event');
|
|
|
|
$user->user_join_($model,$_GET['p']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function add_thirdparty(){
|
|
|
|
if(IS_POST){
|
|
|
|
if($_POST['type']==1){
|
|
|
|
if(empty($_POST['openid'])){
|
|
|
|
$this->error('openid不能为空');exit;
|
|
|
|
}
|
|
|
|
if(empty($_POST['key'])){
|
|
|
|
$this->error('安全校验码不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="qq_param_lists";
|
|
|
|
}elseif($_POST['type']==2){
|
|
|
|
if(empty($_POST['wx_appid'])){
|
|
|
|
$this->error('APPID不能为空');exit;
|
|
|
|
}
|
|
|
|
if(empty($_POST['appsecret'])){
|
|
|
|
$this->error('APPSECRET不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="wx_param_lists";
|
|
|
|
}elseif($_POST['type']==3){
|
|
|
|
if(empty($_POST['appkey'])||empty($_POST['scope'])){
|
|
|
|
$this->error('参数不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="wb_param_lists";
|
|
|
|
}else{
|
|
|
|
if(empty($_POST['clientid'])){
|
|
|
|
$this->error('参数不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="bd_param_lists";
|
|
|
|
}
|
|
|
|
|
|
|
|
$find=M('param','tab_')->where(['game_id'=>$_POST['game_id'],'type'=>$_POST['type']])->find();
|
|
|
|
if(null!==$find){
|
|
|
|
$this->error('该游戏已经设置过参数');exit;
|
|
|
|
}
|
|
|
|
if($_POST['game_id']==0){
|
|
|
|
$count=M('param','tab_')->where(['game_id'=>['gt',0],'type'=>$_POST['type']])->count();
|
|
|
|
if($count>=1){
|
|
|
|
$this->error('如需设置全部游戏 请先将其他游戏数据删除');exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$add=M('param','tab_')->add($_POST);
|
|
|
|
if($add){
|
|
|
|
$this->success('新增成功',U($url));
|
|
|
|
}else{
|
|
|
|
$this->error('新增失败',U($url));
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
|
|
|
|
switch($_GET['type']) {
|
|
|
|
case 1:$this->meta_title = '第三方登录';break;
|
|
|
|
case 2:$this->meta_title = '第三方登录';break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function edit_thirdparty($id){
|
|
|
|
if(IS_POST){
|
|
|
|
if($_POST['type']==1){
|
|
|
|
if(empty($_POST['openid'])){
|
|
|
|
$this->error('openid不能为空');exit;
|
|
|
|
}
|
|
|
|
if(empty($_POST['key'])) {
|
|
|
|
$this->error('安全校验码不能为空');exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$url="qq_param_lists";
|
|
|
|
}elseif($_POST['type']==2){
|
|
|
|
if(empty($_POST['wx_appid'])){
|
|
|
|
$this->error('APPID不能为空');exit;
|
|
|
|
}
|
|
|
|
if(empty($_POST['appsecret'])){
|
|
|
|
$this->error('APPSECRET不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="wx_param_lists";
|
|
|
|
}elseif($_POST['type']==3){
|
|
|
|
if(empty($_POST['appkey'])||empty($_POST['scope'])){
|
|
|
|
$this->error('参数不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="wb_param_lists";
|
|
|
|
}else{
|
|
|
|
if(empty($_POST['clientid'])){
|
|
|
|
$this->error('参数不能为空');exit;
|
|
|
|
}
|
|
|
|
$url="bd_param_lists";
|
|
|
|
}
|
|
|
|
|
|
|
|
$add=M('param','tab_')->save($_POST);
|
|
|
|
if($add){
|
|
|
|
$this->success('修改成功',U($url));
|
|
|
|
}else{
|
|
|
|
$this->error('修改失败',U($url));
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
$find=M('param','tab_')->where(['id'=>$id])->find();
|
|
|
|
$this->assign('data',$find);
|
|
|
|
switch($_GET['type']) {
|
|
|
|
case 1:$this->meta_title = '第三方登录';break;
|
|
|
|
case 2:$this->meta_title = '第三方登录';break;
|
|
|
|
|
|
|
|
}
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 删除
|
|
|
|
* @author 麦当苗儿 <zuojiazi@vip.qq.com>
|
|
|
|
*/
|
|
|
|
public function del(){
|
|
|
|
$id = array_unique((array)I('ids',0));
|
|
|
|
|
|
|
|
if ( empty($id) ) {
|
|
|
|
$this->error('请选择要操作的数据!');
|
|
|
|
}
|
|
|
|
$map = array('id' => array('in', $id) );
|
|
|
|
if(M('param','tab_')->where($map)->delete()){
|
|
|
|
$this->success('删除成功');
|
|
|
|
} else {
|
|
|
|
$this->error('删除失败!');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function changeStatus($field = null,$value=null)
|
|
|
|
{
|
|
|
|
$id = array_unique((array)I('id', 0));
|
|
|
|
$id = is_array($id) ? implode(',', $id) : $id;
|
|
|
|
if (empty($id)) {
|
|
|
|
$this->error('请选择要操作的数据!');
|
|
|
|
}
|
|
|
|
$map['id'] = array('in', $id);
|
|
|
|
$result = M('param','tab_')->where($map)->setField($field,$value);
|
|
|
|
$msg = $value == 0?"关闭":"开启";
|
|
|
|
if($result !== false){
|
|
|
|
$this->success($msg.'成功');
|
|
|
|
}else{
|
|
|
|
$this->error($msg.'失败');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* 水印
|
|
|
|
*/
|
|
|
|
public function watermark() {
|
|
|
|
|
|
|
|
$this->BaseConfig("watermark");
|
|
|
|
|
|
|
|
$this->meta_title = '水印设置';
|
|
|
|
|
|
|
|
$this->m_title = '水印设置';
|
|
|
|
$url = 'Tool/watermark';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 支付宝参数设置
|
|
|
|
* @author 鹿文学
|
|
|
|
*/
|
|
|
|
public function alipay_param($value='') {
|
|
|
|
$str = "alipay_param";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '支付宝认证';
|
|
|
|
|
|
|
|
$this->m_title = '支付宝认证';
|
|
|
|
$url = 'Tool/alipay_param';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 用户VIP设置
|
|
|
|
* @author 鹿文学
|
|
|
|
*/
|
|
|
|
public function vip($value='') {
|
|
|
|
$str = "viplevel";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '用户VIP设置';
|
|
|
|
|
|
|
|
$this->m_title = '用户VIP设置';
|
|
|
|
$url = 'Tool/vip';
|
|
|
|
$this->m_url = $url;
|
|
|
|
$this->assign('commonset',M('Kuaijieicon')->where(['url'=>$url,'status'=>1])->find());
|
|
|
|
|
|
|
|
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*公司信息列表
|
|
|
|
*/
|
|
|
|
public function company_info()
|
|
|
|
{
|
|
|
|
$model = M('company_info', 'tab_');
|
|
|
|
$map = [];
|
|
|
|
$id = intval(I('id', 0));
|
|
|
|
if (!empty($id)) {
|
|
|
|
$map['tab_company_info.id'] = $id;
|
|
|
|
$parameter['id'] = $id;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (isset($_REQUEST['partner']) && $_REQUEST['partner'] !== '') {
|
|
|
|
$map['p.partner'] = ["like","%{$_REQUEST['partner']}%"];
|
|
|
|
}
|
|
|
|
|
|
|
|
$page = intval(I('get.p', 0));
|
|
|
|
$page = $page ? $page : 1; //默认显示第一页数据
|
|
|
|
$row = intval(I('row', 0));
|
|
|
|
$row = empty($row) ? 10 : $row;//每页条数
|
|
|
|
|
|
|
|
$data = $model->alias('p')
|
|
|
|
->field('p.id,p.partner,p.status,p.create_time,link_man,link_phone,address,company_tax_no,payee_name,
|
|
|
|
bank_account,opening_bank,m.nickname')
|
|
|
|
->join('left join sys_member as m on m.uid = p.uid')
|
|
|
|
->where($map)
|
|
|
|
->order('id desc')
|
|
|
|
->page($page, $row)
|
|
|
|
->select();
|
|
|
|
|
|
|
|
/* 查询记录总数 */
|
|
|
|
$count = $model
|
|
|
|
->alias('p')
|
|
|
|
->where($map)
|
|
|
|
->count();
|
|
|
|
|
|
|
|
if (!empty($data)) {
|
|
|
|
foreach ($data as &$list) {
|
|
|
|
$list['status'] = ($list['status'] == 0) ? '已关闭' : '已开启';
|
|
|
|
$list['create_time'] = date('Y-m-d H:i:s', $list['create_time']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//分页
|
|
|
|
$parameter['p'] = $page;
|
|
|
|
$parameter['row'] = $row;
|
|
|
|
$page = set_pagination($count, $row, $parameter);
|
|
|
|
if ($page) {
|
|
|
|
$this->assign('_page', $page);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->assign('listData', $data);
|
|
|
|
$this->assign('count', $count);
|
|
|
|
$this->meta_title = '公司信息管理';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
//添加
|
|
|
|
public function company_add()
|
|
|
|
{
|
|
|
|
if ($_POST) {
|
|
|
|
$partner = I('post.partner', '');
|
|
|
|
$status = intval(I('post.status', 1));
|
|
|
|
|
|
|
|
if (empty($partner)) {
|
|
|
|
$this->error('请输入公司名称');
|
|
|
|
}
|
|
|
|
if (empty(I('link_man'))) {
|
|
|
|
$this->error('请输入联系人');
|
|
|
|
}
|
|
|
|
if (empty(I('link_phone'))) {
|
|
|
|
$this->error('请输入联系电话');
|
|
|
|
}
|
|
|
|
if (!in_array($status, [0, 1])) {
|
|
|
|
$this->error('参数异常');
|
|
|
|
}
|
|
|
|
if (!empty(I('fax_ratio'))) {
|
|
|
|
if(!preg_match('/^[0-9]+(.[0-9]{1,3})?$/', I('fax_ratio'))){
|
|
|
|
$this->error('税率只能数字');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
$model = M('company_info', 'tab_');
|
|
|
|
$map['partner'] = $partner;
|
|
|
|
$res = $model->where($map)->getField('id');
|
|
|
|
if ($res) {
|
|
|
|
$this->error('公司名称已存在');
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!checkPhone(I('link_phone'))) {
|
|
|
|
$this->error('联系电话格式不正确');
|
|
|
|
}
|
|
|
|
// $res2 = $model->where(['link_phone' => I('link_phone')])->getField('id');
|
|
|
|
// if ($res2) {
|
|
|
|
// $this->error('已存在此联系电话');
|
|
|
|
// }
|
|
|
|
$time = time();
|
|
|
|
$save['partner'] = $partner;
|
|
|
|
$save['status'] = $status;
|
|
|
|
|
|
|
|
$save['link_man'] = I('link_man');
|
|
|
|
$save['link_phone'] = I('link_phone');
|
|
|
|
$save['address'] = I('address');
|
|
|
|
$save['company_tax_no'] = I('company_tax_no');
|
|
|
|
$save['payee_name'] = I('payee_name');
|
|
|
|
$save['bank_account'] = I('bank_account');
|
|
|
|
$save['opening_bank'] = I('opening_bank');
|
|
|
|
$save['fax_ratio'] = I('fax_ratio');
|
|
|
|
$save['ali_account'] = I('ali_account');
|
|
|
|
$save['invoice_item'] = I('invoice_item');
|
|
|
|
$save['invoice_type'] = I('invoice_type');
|
|
|
|
$save['register_address'] = I('register_address');
|
|
|
|
$save['register_phone'] = I('register_phone');
|
|
|
|
|
|
|
|
$save['uid'] = UID;
|
|
|
|
$save['create_time'] = $time;
|
|
|
|
$save['last_up_time'] = $time;
|
|
|
|
|
|
|
|
$res = $model->add($save);
|
|
|
|
if ($res) {
|
|
|
|
\Think\Log::actionLog('company/add', 'company_info', $res);
|
|
|
|
$this->success('保存成功', U('company_info'));
|
|
|
|
} else {
|
|
|
|
$this->error('保存失败');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$this->meta_title = '新增公司';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//编辑
|
|
|
|
public function company_edit()
|
|
|
|
{
|
|
|
|
$model = M('company_info', 'tab_');
|
|
|
|
|
|
|
|
if ($_POST) {
|
|
|
|
$partner = I('post.partner', '');
|
|
|
|
$status = intval(I('post.status', 1));
|
|
|
|
$id = intval(I('post.id', 0));
|
|
|
|
|
|
|
|
if (empty($partner)) {
|
|
|
|
$this->error('请输入合作方名称');
|
|
|
|
}
|
|
|
|
if (empty(I('link_man'))) {
|
|
|
|
$this->error('请输入联系人');
|
|
|
|
}
|
|
|
|
if (empty(I('link_phone'))) {
|
|
|
|
$this->error('请输入联系电话');
|
|
|
|
}
|
|
|
|
if (!in_array($status, [0, 1])) {
|
|
|
|
$this->error('参数异常');
|
|
|
|
}
|
|
|
|
if (!empty(I('fax_ratio'))) {
|
|
|
|
if(!preg_match('/^[0-9]+(.[0-9]{1,3})?$/', I('fax_ratio'))){
|
|
|
|
$this->error('税率只能数字');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = $model
|
|
|
|
->field('id,partner,link_man,link_phone,address,company_tax_no,payee_name,bank_account,opening_bank')
|
|
|
|
->find($id);
|
|
|
|
if (empty($data)) {
|
|
|
|
$this->error('数据异常');
|
|
|
|
}
|
|
|
|
|
|
|
|
$map['partner'] = $partner;
|
|
|
|
$res = $model->where($map)->getField('id');
|
|
|
|
if ($res && $res != $id) {
|
|
|
|
$this->error('公司名称已存在');
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!checkPhone(I('link_phone'))) {
|
|
|
|
$this->error('联系电话格式不正确');
|
|
|
|
}
|
|
|
|
// $res2 = $model->where([
|
|
|
|
// 'link_phone' => I('link_phone'),
|
|
|
|
// 'id' => ['neq', $id]
|
|
|
|
// ])->getField('id');
|
|
|
|
|
|
|
|
// if ($res2) {
|
|
|
|
// $this->error('已存在此联系电话');
|
|
|
|
// }
|
|
|
|
$time = time();
|
|
|
|
$save['id'] = $id;
|
|
|
|
$save['partner'] = $partner;
|
|
|
|
|
|
|
|
$save['link_man'] = I('link_man');
|
|
|
|
$save['link_phone'] = I('link_phone');
|
|
|
|
$save['address'] = I('address');
|
|
|
|
$save['company_tax_no'] = I('company_tax_no');
|
|
|
|
$save['payee_name'] = I('payee_name');
|
|
|
|
$save['bank_account'] = I('bank_account');
|
|
|
|
$save['opening_bank'] = I('opening_bank');
|
|
|
|
|
|
|
|
$save['fax_ratio'] = I('fax_ratio');
|
|
|
|
$save['ali_account'] = I('ali_account');
|
|
|
|
$save['invoice_item'] = I('invoice_item');
|
|
|
|
$save['invoice_type'] = I('invoice_type');
|
|
|
|
$save['register_address'] = I('register_address');
|
|
|
|
$save['register_phone'] = I('register_phone');
|
|
|
|
|
|
|
|
$save['status'] = $status;
|
|
|
|
$save['last_up_time'] = $time;
|
|
|
|
$res = $model->save($save);
|
|
|
|
if ($res === false) {
|
|
|
|
$this->error('保存失败');
|
|
|
|
} else {
|
|
|
|
\Think\Log::actionLog('company/edit', 'company_info', $id);
|
|
|
|
$this->success('保存成功', U('company_info'));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$id = intval(I('get.id', 0));
|
|
|
|
$map['id'] = $id;
|
|
|
|
$data = $model
|
|
|
|
->field('*')
|
|
|
|
->find($id);
|
|
|
|
if (empty($data)) {
|
|
|
|
$this->error('数据异常', U('company_info'));
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->assign('company_info', $data);
|
|
|
|
$this->meta_title = '编辑公司';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//删除
|
|
|
|
public function company_del()
|
|
|
|
{
|
|
|
|
if (!empty($_POST['ids'])) {
|
|
|
|
if (!is_array($_POST['ids'])) {
|
|
|
|
$this->error('参数异常');
|
|
|
|
}
|
|
|
|
|
|
|
|
$id = implode(',', $_POST['ids']);
|
|
|
|
} else {
|
|
|
|
$id = intval(I('get.id', 0));
|
|
|
|
if ($id == 0) {
|
|
|
|
$this->error('参数异常');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$res = M('company_info', 'tab_')->delete($id);
|
|
|
|
if ($res === false) {
|
|
|
|
$this->error('删除失败');
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->success('删除成功', U('company_info'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*公司信息管理(旧版备份)
|
|
|
|
*/
|
|
|
|
public function company_info_old()
|
|
|
|
{
|
|
|
|
$str = "company_info";
|
|
|
|
$this->BaseConfig($str);
|
|
|
|
$this->meta_title = '公司信息管理';
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function limitPay($page = 1) {
|
|
|
|
$page = intval(I('get.p', 0));
|
|
|
|
$page = $page ? $page : 1; //默认显示第一页数据
|
|
|
|
$row = intval(I('row', 0));
|
|
|
|
$row = empty($row) ? 10 : $row;//每页条数
|
|
|
|
|
|
|
|
$payType = $_REQUEST['pay_type'];
|
|
|
|
$limit_type = $_REQUEST['limit_type'];
|
|
|
|
|
|
|
|
$limit_time_type = $_REQUEST['limit_time_type'];
|
|
|
|
$map = [];
|
|
|
|
if (!empty($payType)) {
|
|
|
|
$map['pay_type'] = $payType;
|
|
|
|
$parameter['pay_type'] = $payType;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($limit_type)) {
|
|
|
|
$map['limit_type'] = $limit_type;
|
|
|
|
$parameter['limit_type'] = $limit_type;
|
|
|
|
}
|
|
|
|
$datas = M('pay_limit_conf', 'tab_')
|
|
|
|
->where($map)
|
|
|
|
->order('id desc')
|
|
|
|
->page($page, $row)
|
|
|
|
->select();
|
|
|
|
|
|
|
|
/* 查询记录总数 */
|
|
|
|
$count = M('pay_limit_conf', 'tab_')
|
|
|
|
->where($map)
|
|
|
|
->count();
|
|
|
|
foreach ($datas as $key => $data) {
|
|
|
|
$limit_rule = '';
|
|
|
|
if (!empty(intval($data['user_total_limit']))) {
|
|
|
|
$limit_rule .= '玩家全渠道总流水限额'.$data['user_total_limit']."    ";
|
|
|
|
}
|
|
|
|
if (!empty(intval($data['total_limit']))) {
|
|
|
|
$limit_rule .= '全渠道总流水限额'.$data['total_limit']."    ";
|
|
|
|
}
|
|
|
|
if (!empty(intval($data['user_one_limit']))) {
|
|
|
|
$limit_rule .= '玩家单笔限制'.$data['user_one_limit'];
|
|
|
|
}
|
|
|
|
if ($limit_rule == '') {
|
|
|
|
$limit_rule = '暂无规则';
|
|
|
|
}
|
|
|
|
if ($data['limit_time_type'] == 'day') {
|
|
|
|
$data['limit_time_type'] = '每日,';
|
|
|
|
$remarkStr = '';
|
|
|
|
}
|
|
|
|
if ($data['limit_time_type'] == 'week') {
|
|
|
|
$data['limit_time_type'] = '每周,';
|
|
|
|
if ($data['limit_time_type_remark'] == 1) $remarkStr = "周一";
|
|
|
|
if ($data['limit_time_type_remark'] == 2) $remarkStr = "周二";
|
|
|
|
if ($data['limit_time_type_remark'] == 3) $remarkStr = "周三";
|
|
|
|
if ($data['limit_time_type_remark'] == 4) $remarkStr = "周四";
|
|
|
|
if ($data['limit_time_type_remark'] == 5) $remarkStr = "周五";
|
|
|
|
if ($data['limit_time_type_remark'] == 6) $remarkStr = "周六";
|
|
|
|
if ($data['limit_time_type_remark'] == 7) $remarkStr = "周七";
|
|
|
|
|
|
|
|
}
|
|
|
|
if ($data['limit_time_type'] == 'month') {
|
|
|
|
$data['limit_time_type'] = '每月,';
|
|
|
|
$remarkStr = $data['limit_time_type_remark'].'日';
|
|
|
|
}
|
|
|
|
if ($data['limit_time_type'] == 'fix') {
|
|
|
|
$data['limit_time_type'] = '特殊,';
|
|
|
|
$remarks = str_split($data['limit_time_type_remark'], 1);
|
|
|
|
$remarkStr = '';
|
|
|
|
foreach($remarks as $keyR => $remark) {
|
|
|
|
if ($keyR == 3 || $keyR == 5){
|
|
|
|
$remarkStr .= $remark. '-';
|
|
|
|
}else {
|
|
|
|
$remarkStr .= $remark;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($data['limit_type'] == 'force') {
|
|
|
|
$datas[$key]['limit_type'] = '强制限制';
|
|
|
|
}
|
|
|
|
if ($data['limit_type'] == 'obstacles') {
|
|
|
|
$datas[$key]['limit_type'] = '支付体验障碍';
|
|
|
|
}
|
|
|
|
if ($data['pay_type'] == 'alipay') {
|
|
|
|
$pay_type = '支付宝';
|
|
|
|
}
|
|
|
|
if ($data['pay_type'] == 'wxpay') {
|
|
|
|
$pay_type = '微信';
|
|
|
|
}
|
|
|
|
if ($data['pay_type'] == 'yeepay') {
|
|
|
|
$pay_type = '易宝';
|
|
|
|
}
|
|
|
|
if ($data['pay_type'] == 'sqpay') {
|
|
|
|
$pay_type = '双乾';
|
|
|
|
}
|
|
|
|
$start_timeArr = str_split($data['start_time'], 1);
|
|
|
|
$startTimeStr = '';
|
|
|
|
foreach ($start_timeArr as $timeKey => $start_time) {
|
|
|
|
if ($timeKey == 1 || $timeKey == 3) {
|
|
|
|
$startTimeStr .= $start_time.':';
|
|
|
|
}else {
|
|
|
|
$startTimeStr .= $start_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$end_timeArr = str_split($data['end_time'], 1);
|
|
|
|
$endTimeStr = '';
|
|
|
|
foreach ($end_timeArr as $timeKey1 => $end_time) {
|
|
|
|
if ($timeKey1 == 1 || $timeKey1 == 3) {
|
|
|
|
$endTimeStr .= $end_time. ':';
|
|
|
|
}else {
|
|
|
|
$endTimeStr .= $end_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$datas[$key]['pay_type'] = $pay_type;
|
|
|
|
$datas[$key]['limit_rule'] = $limit_rule;
|
|
|
|
$datas[$key]['limit_time'] = $data['limit_time_type'] .$remarkStr.' '.$startTimeStr.'~'.$endTimeStr;
|
|
|
|
|
|
|
|
}
|
|
|
|
//分页
|
|
|
|
$parameter['p'] = $page;
|
|
|
|
$parameter['row'] = $row;
|
|
|
|
$page = set_pagination($count, $row, $parameter);
|
|
|
|
if ($page) {
|
|
|
|
$this->assign('_page', $page);
|
|
|
|
}
|
|
|
|
if (empty($payType)) {
|
|
|
|
$this->assign('pay_type', " ");
|
|
|
|
}else {
|
|
|
|
$this->assign('pay_type', $payType);
|
|
|
|
}
|
|
|
|
if (empty($limit_type)) {
|
|
|
|
$this->assign('limit_type', " ");
|
|
|
|
}else {
|
|
|
|
$this->assign('limit_type', $limit_type);
|
|
|
|
}
|
|
|
|
$this->assign('datas', $datas);
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function addLimitPay() {
|
|
|
|
if ($_POST) {
|
|
|
|
$pay_type = $_REQUEST['pay_type'];
|
|
|
|
$total_limit = empty($_REQUEST['total_limit']) ? 0 : $_REQUEST['total_limit'];
|
|
|
|
$user_total_limit = empty($_REQUEST['user_total_limit']) ? 0 : $_REQUEST['user_total_limit'];
|
|
|
|
$user_one_limit = empty($_REQUEST['user_one_limit']) ? 0 : $_REQUEST['user_one_limit'];
|
|
|
|
$limit_type = $_REQUEST['limit_type'];
|
|
|
|
$status = $_REQUEST['status'];
|
|
|
|
$startTime = '';
|
|
|
|
$endTime = '';
|
|
|
|
if (empty($pay_type)) {
|
|
|
|
return $this->error('限制支付渠道不能为空');
|
|
|
|
}
|
|
|
|
if (empty(intval($total_limit))&&empty(intval($user_total_limit))&&empty(intval($user_one_limit))) {
|
|
|
|
return $this->error('限额不能为空');
|
|
|
|
}
|
|
|
|
if (!is_numeric($total_limit) || !is_numeric($user_total_limit) || !is_numeric($user_one_limit) || $total_limit < 0 ||$user_total_limit < 0 ||$user_one_limit < 0 ) {
|
|
|
|
return $this->error('限制金额出错');
|
|
|
|
}
|
|
|
|
if (intval($total_limit) > 1000000000000.00 || intval($user_total_limit) > 1000000000000.00 ||intval($user_one_limit) > 1000000000000.00) {
|
|
|
|
return $this->error('限制金额超出范围');
|
|
|
|
}
|
|
|
|
if (empty($limit_type)) {
|
|
|
|
return $this->error('限制方式不能为空');
|
|
|
|
}
|
|
|
|
|
|
|
|
$paramsName = $status.'_start';
|
|
|
|
for ($i = 1; $i < 13; $i++) {
|
|
|
|
$name = $paramsName.$i;
|
|
|
|
if ($_REQUEST[$name] == '') {
|
|
|
|
return $this->error('时间选择不能为空');
|
|
|
|
}else {
|
|
|
|
if ($i < 7) {
|
|
|
|
$startTime .= $_REQUEST[$name];
|
|
|
|
}else {
|
|
|
|
$endTime .= $_REQUEST[$name];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->checkTimeFormat($i, $startTime, $endTime, $_REQUEST[$name]);
|
|
|
|
|
|
|
|
}
|
|
|
|
$start_timeArr = str_split($startTime, 1);
|
|
|
|
$startTimeStr = '';
|
|
|
|
foreach ($start_timeArr as $timeKey => $start_time) {
|
|
|
|
if ($timeKey == 1 || $timeKey == 3) {
|
|
|
|
$startTimeStr .= $start_time.':';
|
|
|
|
}else {
|
|
|
|
$startTimeStr .= $start_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$st = '2020-03-23'.' '.$startTimeStr;
|
|
|
|
$startTimeStamp = strtotime($st);
|
|
|
|
|
|
|
|
$end_timeArr = str_split($endTime, 1);
|
|
|
|
$endTimeStr = '';
|
|
|
|
foreach ($end_timeArr as $timeKey1 => $end_time) {
|
|
|
|
if ($timeKey1 == 1 || $timeKey1 == 3) {
|
|
|
|
$endTimeStr .= $end_time.':';
|
|
|
|
}else {
|
|
|
|
$endTimeStr .= $end_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$et = '2020-03-23'.' '.$endTimeStr;
|
|
|
|
$endTimeStamp = strtotime($et);
|
|
|
|
if ($startTimeStamp >= $endTimeStamp) {
|
|
|
|
return $this->error('开始时间不能大于结束时间');
|
|
|
|
}
|
|
|
|
switch($status) {
|
|
|
|
case 'daily':
|
|
|
|
$limit_time_type = 'day';
|
|
|
|
break;
|
|
|
|
case 'week':
|
|
|
|
$limit_time_type = 'week';
|
|
|
|
if (empty($_REQUEST['week_remark'])) {
|
|
|
|
return $this->error('每周限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$data['limit_time_type_remark'] = $_REQUEST['week_remark'];
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'month':
|
|
|
|
$limit_time_type = 'month';
|
|
|
|
if (empty($_REQUEST['month_remark'])) {
|
|
|
|
return $this->error('每月限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$data['limit_time_type_remark'] = $_REQUEST['month_remark'];
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'day':
|
|
|
|
$limit_time_type = 'fix';
|
|
|
|
if (empty($_REQUEST['day_remark'])) {
|
|
|
|
return $this->error('每月限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$fixStr = str_replace('-','',$_REQUEST['day_remark']);
|
|
|
|
$data['limit_time_type_remark'] = $fixStr;
|
|
|
|
$data['fix_date'] = $fixStr;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (!is_numeric($startTime) || !is_numeric($endTime)) {
|
|
|
|
$this->error('时间格式出错');
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['pay_type'] = $pay_type;
|
|
|
|
$data['limit_type'] = $limit_type;
|
|
|
|
$data['limit_time_type'] = $limit_time_type;
|
|
|
|
$data['start_time'] = $startTime;
|
|
|
|
$data['end_time'] = $endTime;
|
|
|
|
$data['total_limit'] = $total_limit;
|
|
|
|
$data['user_total_limit'] = $user_total_limit;
|
|
|
|
$data['user_one_limit'] = $user_one_limit;
|
|
|
|
$data['create_time'] = time();
|
|
|
|
$res = M('pay_limit_conf', 'tab_')->add($data);
|
|
|
|
|
|
|
|
if($res) {
|
|
|
|
$this->success('新增成功',U('limitPay'));
|
|
|
|
}
|
|
|
|
}else {
|
|
|
|
// $id = $_REQUEST['id'];
|
|
|
|
// $limitConf = M('pay_limit_conf', 'tab_')->where(['id'=>$id])->find();
|
|
|
|
// if (empty($limitConf)) {
|
|
|
|
// return $this->error('未找到该条信息');
|
|
|
|
// }
|
|
|
|
// foreach ($limitConf as $key => $conf) {
|
|
|
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
$monthDay = $this->getMonthDay();
|
|
|
|
$this->assign('monthday', $monthDay);
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function editLimitPay() {
|
|
|
|
if ($_POST) {
|
|
|
|
$id = $_REQUEST['id'];
|
|
|
|
$pay_type = $_POST['pay_type'];
|
|
|
|
$total_limit = $_POST['total_limit'];
|
|
|
|
$user_total_limit = $_POST['user_total_limit'];
|
|
|
|
$user_one_limit = $_POST['user_one_limit'];
|
|
|
|
$limit_type = $_POST['limit_type'];
|
|
|
|
$status = $_POST['status'];
|
|
|
|
$startTime = '';
|
|
|
|
$endTime = '';
|
|
|
|
if (empty(intval($total_limit))&&empty(intval($user_total_limit))&&empty(intval($user_one_limit))) {
|
|
|
|
return $this->error('限额不能为空');
|
|
|
|
}
|
|
|
|
if (!is_numeric($total_limit) || !is_numeric($user_total_limit) || !is_numeric($user_one_limit) || $total_limit < 0 ||$user_total_limit < 0 ||$user_one_limit < 0 ) {
|
|
|
|
return $this->error('限额金额出错');
|
|
|
|
}
|
|
|
|
if (empty($id)) {
|
|
|
|
return $this->error('编辑信息出错');
|
|
|
|
}
|
|
|
|
if (intval($total_limit) > 1000000000000.00 || intval($user_total_limit) > 1000000000000.00 ||intval($user_one_limit) > 1000000000000.00) {
|
|
|
|
return $this->error('限制金额超出范围');
|
|
|
|
}
|
|
|
|
|
|
|
|
$confInfo = M('pay_limit_conf', 'tab_')->where(['id'=>$id])->find();
|
|
|
|
$confInfo['pay_type'] = $pay_type;
|
|
|
|
$confInfo['total_limit'] = $total_limit;
|
|
|
|
$confInfo['user_total_limit'] = $user_total_limit;
|
|
|
|
$confInfo['user_one_limit'] = $user_one_limit;
|
|
|
|
$confInfo['limit_type'] = $limit_type;
|
|
|
|
$paramsName = $status.'_start';
|
|
|
|
for ($i = 1; $i < 13; $i++) {
|
|
|
|
$name = $paramsName.$i;
|
|
|
|
if ($_REQUEST[$name] == '') {
|
|
|
|
return $this->error('时间选择不能为空');
|
|
|
|
}else {
|
|
|
|
if ($i < 7) {
|
|
|
|
$startTime .= $_REQUEST[$name];
|
|
|
|
}else {
|
|
|
|
$endTime .= $_REQUEST[$name];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->checkTimeFormat($i, $startTime, $endTime, $_REQUEST[$name]);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
$st = '2020-03-23'.' '.$startTimeStr;
|
|
|
|
$startTimeStamp = strtotime($st);
|
|
|
|
|
|
|
|
$end_timeArr = str_split($endTime, 1);
|
|
|
|
$endTimeStr = '';
|
|
|
|
foreach ($end_timeArr as $timeKey1 => $end_time) {
|
|
|
|
if ($timeKey1 == 1 || $timeKey1 == 3) {
|
|
|
|
$endTimeStr .= $end_time.':';
|
|
|
|
}else {
|
|
|
|
$endTimeStr .= $end_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$et = '2020-03-23'.' '.$endTimeStr;
|
|
|
|
$endTimeStamp = strtotime($et);
|
|
|
|
if ($startTimeStamp >= $endTimeStamp) {
|
|
|
|
return $this->error('开始时间不能大于结束时间');
|
|
|
|
}
|
|
|
|
$confInfo['start_time'] = $startTime;
|
|
|
|
$confInfo['end_time'] = $endTime;
|
|
|
|
switch($status) {
|
|
|
|
case 'daily':
|
|
|
|
$limit_time_type = 'day';
|
|
|
|
$confInfo['limit_time_type_remark'] = "";
|
|
|
|
$confInfo['fix_date'] = '';
|
|
|
|
break;
|
|
|
|
case 'week':
|
|
|
|
$limit_time_type = 'week';
|
|
|
|
if (empty($_REQUEST['week_remark'])) {
|
|
|
|
return $this->error('每周限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$confInfo['limit_time_type_remark'] = $_REQUEST['week_remark'];
|
|
|
|
}
|
|
|
|
$confInfo['fix_date'] = '';
|
|
|
|
break;
|
|
|
|
case 'month':
|
|
|
|
$limit_time_type = 'month';
|
|
|
|
if (empty($_REQUEST['month_remark'])) {
|
|
|
|
return $this->error('每月限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$confInfo['limit_time_type_remark'] = $_REQUEST['month_remark'];
|
|
|
|
}
|
|
|
|
$confInfo['fix_date'] = '';
|
|
|
|
break;
|
|
|
|
case 'day':
|
|
|
|
$limit_time_type = 'fix';
|
|
|
|
if (empty($_REQUEST['day_remark'])) {
|
|
|
|
return $this->error('每月限制时间未确定');
|
|
|
|
}else {
|
|
|
|
$fixStr = str_replace('-','',$_REQUEST['day_remark']);
|
|
|
|
$confInfo['limit_time_type_remark'] = $fixStr;
|
|
|
|
$confInfo['fix_date'] = $fixStr;
|
|
|
|
}
|
|
|
|
// $confInfo['limit_time_type_remark'] = $_REQUEST['day_remark'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$confInfo['limit_time_type'] = $limit_time_type;
|
|
|
|
$update = M('pay_limit_conf', 'tab_')->where(['id'=>$id])->save($confInfo);
|
|
|
|
if ($update) {
|
|
|
|
$this->success('编辑成功',U('limitPay'));
|
|
|
|
}else {
|
|
|
|
$this->error('未修改资料,请确认');
|
|
|
|
}
|
|
|
|
|
|
|
|
}else {
|
|
|
|
$id = $_REQUEST['id'];
|
|
|
|
$data = M('pay_limit_conf', 'tab_')->where(['id'=>$id])->find();
|
|
|
|
$start_time = $data['start_time'];
|
|
|
|
|
|
|
|
$end_time = $data['end_time'];
|
|
|
|
$monthDay = $this->getMonthDay();
|
|
|
|
if ($data['limit_time_type'] == 'fix') {
|
|
|
|
$remarks = str_split($data['limit_time_type_remark'], 1);
|
|
|
|
$remarkStr = '';
|
|
|
|
foreach($remarks as $keyR => $remark) {
|
|
|
|
if ($keyR == 3 || $keyR == 5){
|
|
|
|
$remarkStr .= $remark. '-';
|
|
|
|
}else {
|
|
|
|
$remarkStr .= $remark;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$data['limit_time_type_remark'] = $remarkStr;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->assign('monthday', $monthDay);
|
|
|
|
$this->assign('startTime', $start_time);
|
|
|
|
$this->assign('endTime', $end_time);
|
|
|
|
$this->assign('data', $data);
|
|
|
|
// var_dump($this->pay_type);die();
|
|
|
|
$this->assign('pay_type', $this->pay_type);
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function delLimitPay($id) {
|
|
|
|
$res = M('pay_limit_conf', 'tab_')->where(['id'=>$id])->delete();
|
|
|
|
if($res) {
|
|
|
|
$this->success('删除成功',U('limitPay'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMonthDay() {
|
|
|
|
$arr = [];
|
|
|
|
for ($i = 1;$i < 32; $i++ ) {
|
|
|
|
$arr[] = $i;
|
|
|
|
}
|
|
|
|
return $arr;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function checkTimeFormat($i, $startTime = '' , $endTime = '', $name) {
|
|
|
|
if ($i == 2) {
|
|
|
|
if ($startTime < 0 || $startTime > 23) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($i == 3 || $i == 5) {
|
|
|
|
if ($name < 0 || $name > 5) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($i == 4 || $i == 6) {
|
|
|
|
if ($name < 0 || $name > 9) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($i == 8) {
|
|
|
|
if ($endTime < 0 || $endTime > 23) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($i == 9 || $i == 11) {
|
|
|
|
if ($name < 0 || $name > 5) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($i == 10 || $i == 12) {
|
|
|
|
if ($name < 0 || $name > 9) {
|
|
|
|
return $this->error("时间选择出错");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function cmdTasksList()
|
|
|
|
{
|
|
|
|
$params = I('get.');
|
|
|
|
$page = $params['p'] ? intval($params['p']) : 1;
|
|
|
|
$row = $params['row'] ? intval($params['row']) : 10;
|
|
|
|
$status = [
|
|
|
|
'0'=>"待处理",
|
|
|
|
'1'=>"处理中",
|
|
|
|
'2'=>'处理成功',
|
|
|
|
'3'=>'处理失败'
|
|
|
|
];
|
|
|
|
|
|
|
|
$where = [
|
|
|
|
"_string"=>"1 = 1"
|
|
|
|
];
|
|
|
|
if(isset($params['status'])){
|
|
|
|
$where['c.status'] = $params['status'];
|
|
|
|
}
|
|
|
|
if(isset($params['type'])){
|
|
|
|
$where['c.type'] = $params['type'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$records = M("cmd_tasks","tab_")->alias("c")->join("sys_member m on c.uid = m.uid","left")
|
|
|
|
->field("c.*,ifnull(m.nickname,'system') admin_username")
|
|
|
|
->page($page,$row)
|
|
|
|
->where($where)
|
|
|
|
->order("id desc")
|
|
|
|
->select();
|
|
|
|
foreach ($records as $k => &$v) {
|
|
|
|
$v['params'] = str_replace(' 2>&1','',stristr($v['params'],"php "));
|
|
|
|
|
|
|
|
$v['status_str'] = $status[$v['status']];
|
|
|
|
if($v['schedule_time'] == 0){
|
|
|
|
$v['schedule_time'] = "立即执行";
|
|
|
|
}else{
|
|
|
|
$v['schedule_time'] = date("Y-m-d H:i:s", $v['schedule_time']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if($v['start_time'] == 0){
|
|
|
|
$v['start_time'] = "--";
|
|
|
|
}else{
|
|
|
|
$v['start_time'] = date("Y-m-d H:i:s", $v['start_time']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if($v['end_time'] == 0){
|
|
|
|
$v['end_time'] = "--";
|
|
|
|
}else{
|
|
|
|
$v['end_time'] = date("Y-m-d H:i:s", $v['end_time']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$v['created_time'] = date("Y-m-d H:i:s", $v['created_time']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->assign('records', $records);
|
|
|
|
|
|
|
|
$count = M("cmd_tasks","tab_")->alias("c")->where($where)->count();
|
|
|
|
// dd($count);
|
|
|
|
$params['p'] = $page;
|
|
|
|
$params['row'] = $row;
|
|
|
|
$page = set_pagination($count, $row, $params);
|
|
|
|
if ($page) {
|
|
|
|
$this->assign('_page', $page);
|
|
|
|
}
|
|
|
|
$this->display();
|
|
|
|
}
|
|
|
|
public function cmdTasksDel()
|
|
|
|
{
|
|
|
|
$id = $_REQUEST['id'];
|
|
|
|
$res = M("cmd_tasks","tab_")->where("id = {$id}")->delete();
|
|
|
|
if($res !== false){
|
|
|
|
$this->ajaxReturn(array("success"=>"ok","code"=>0));
|
|
|
|
}else{
|
|
|
|
$this->ajaxReturn(array("error"=>"database error","code"=>2000));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|