get('query');
$csql = new \ciy\sql('ap_transfer');
$liid = objint($query, 'liid');
if ($liid > 0)
$csql->where('accounttype', $liid);
$val = objstr($query, 'id');
if (!empty($val) && $val[0] == 'P')
$csql->where('id', substr($val, 1));
$csql->wherenumrange('amount', objstr($query, 'amount_1'), objstr($query, 'amount_2'), 100);
$csql->where('tranaccount like', objstr($query, 'tranaccount'));
$csql->where('tranname like', objstr($query, 'tranname'));
$csql->where('tranidid like', objstr($query, 'tranidid'));
$csql->where('memo like', objstr($query, 'memo'));
$csql->wheredaterange('addtimes', objstr($query, 'addtimes'));
$csql->where('apiuser', objstr($query, 'apiuser'));
$order = objstr($query, 'order', 'id desc');
$csql->order($order);
$query['order'] = $order;
return [$query, $csql];
}
public static function json_list() {
global $db;
$rsuser = verifyfast();
$post = new \ciy\post();
list($where, $csql) = self::setwhere($db, $post);
$csql->where('orderstatus', 10);
$pageno = $post->getint('pageno', 1);
$pagecount = $post->getint('pagecount', 10);
$csql->limit($pageno, $pagecount);
$mainrowcount = $post->getint('count');
$rows = $db->get($csql, $mainrowcount);
if ($rows === false)
return errjson($db->error);
$ret = array('where' => $where, 'pageno' => $pageno, 'pagecount' => $pagecount, 'count' => $mainrowcount, 'list' => $rows);
if ($post->getbool('field')) {
$field = array();
$fshow = $db->getfield($field, 'ap_transfer');
foreach ($field as $fr => $v) {
if (get('_' . $fr))
$field[$fr]['c'] = ',' . $field[$fr]['c'];
if ($fr == 'merchantid')
$field[$fr]['c'] = ',' . $field[$fr]['c'];
}
$field['orderstatus']['c'] = '';
$field['fee']['c'] = '';
$field['wano']['c'] = '';
$field['uptimes']['c'] = '';
$field['orderno']['c'] = '';
$field['pubkeyid']['c'] = '';
$field['signtimes']['c'] = '';
$field['tranreceipt']['c'] = '';
$field['errmsg']['c'] = '';
$ret['field'] = $field;
$ret['fshow'] = $fshow;
}
if ($post->getbool('once')) {
$ret['once'] = array();
$input = array();
$input[] = array('type' => 'input', 'form' => 'id', 'name' => '流水号', 'prop' => ' style="width:8em;"');
$input[] = array('type' => 'num', 'form' => 'amount', 'name' => '金额', 'prop' => ' style="width:4em;"');
$input[] = array('type' => 'input', 'form' => 'tranaccount', 'name' => '账号', 'prop' => ' style="width:8em;"');
$input[] = array('type' => 'input', 'form' => 'tranname', 'name' => '姓名', 'prop' => ' style="width:8em;"');
$input[] = array('type' => 'input', 'form' => 'tranidid', 'name' => '身份证号', 'prop' => ' style="width:8em;"');
$input[] = array('type' => 'input', 'form' => 'memo', 'name' => '备注', 'prop' => ' style="width:8em;"');
$input[] = array('type' => 'daterange', 'form' => 'addtimes', 'name' => '创建时间');
$input[] = array('type' => 'select', 'form' => 'apiuser', 'name' => '操作人', 'all' => '全部', 'select' => 'meruser');
$ret['once']['input'] = $input;
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$ret['once']['merchant'] = $db->getone($csql);
$csql = new \ciy\sql('hf_merchantpubkey');
$csql->where('merchantid', $rsuser['s_b']);
$ret['once']['hf_merchantpubkey'] = $db->get($csql);
// if($ret['once']['merchant']['safecase'] > 10){
// $csql = new \ciy\sql('hf_merchantuser');
// $csql->where('id', $ret['once']['merchant']['s_b']);
// $ret['once']['merchant'] = $db->getone($csql);
// }
}
return succjson($ret);
}
public static function json_update() {
global $db;
$rsuser = verifyfast();
//if (nopower($db, $rsuser['id'], 'p u'))
// return errjson('您未被授权操作');
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$merchantrow = $db->getone($csql);
$post = new \ciy\post();
$id = $post->getint('id');
$data = array();
$data['accounttype'] = $post->getint('accounttype');
$data['amount'] = $post->getint('amount');
$data['tranaccount'] = $post->get('tranaccount');
$data['tranname'] = $post->get('tranname');
$data['tranidid'] = $post->get('tranidid');
$data['memo'] = $post->get('memo');
$retchk = check_transtr($data['amount'], $data['accounttype'], $data['tranaccount'], $data['tranname'], $data['tranidid'], $data['memo'], $merchantrow['safecase']);
if (is_string($retchk))
return errjson($retchk);
if ($id > 0) {
$csql = new \ciy\sql('ap_transfer');
$csql->where('merchantid', $rsuser['s_b']);
$csql->where('id', $id);
$datarow = $db->getone($csql);
if (!is_array($datarow))
return errjson('数据不存在');
}
try {
$db->begin();
$updata = self::updatedata($db, $rsuser, $id, $data, $merchantrow);
$db->commit();
} catch (\Exception $ex) {
$db->rollback();
savelogfile('err_db', $ex->getMessage());
return errjson($ex->getMessage());
}
$ret['data'] = $updata;
return succjson($ret);
}
public static function json_multiedit() {
global $db;
$rsuser = verifyfast();
//if (nopower($db, $rsuser['id'], 'p u'))
// return errjson('您未被授权操作');
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$merchantrow = $db->getone($csql);
$post = new \ciy\post();
$count = $post->getint('count');
$datas = array();
for ($i = 0; $i < $count; $i++) {
if ($post->get('accounttype_' . $i) == '')
continue;
$data = array();
$data['accounttype'] = $post->getint('accounttype_' . $i);
$data['accounttype'] = ($data['accounttype'] == 1 ? 20 : 10);
$data['amount'] = $post->getint('amount_' . $i);
$data['tranaccount'] = $post->get('tranaccount_' . $i);
$data['tranname'] = $post->get('tranname_' . $i);
$data['tranidid'] = $post->get('tranidid_' . $i);
$data['memo'] = $post->get('memo_' . $i);
$retchk = check_transtr($data['amount'], $data['accounttype'], $data['tranaccount'], $data['tranname'], $data['tranidid'], $data['memo'], $merchantrow['safecase']);
if (is_string($retchk))
return errjson('第' . ($i + 1) . '行,' . $retchk);
$datas[] = $data;
}
try {
$db->begin();
foreach ($datas as $data) {
self::updatedata($db, $rsuser, 0, $data, $merchantrow);
}
$db->commit();
} catch (\Exception $ex) {
$db->rollback();
savelogfile('err_db', $ex->getMessage());
return errjson($ex->getMessage());
}
return succjson();
}
static function updatedata($db, $rsuser, $id, $data, $merchantrow) {
$updata = array();
$updata['amount'] = $data['amount'];
$updata['accounttype'] = $data['accounttype'];
$updata['tranaccount'] = $data['tranaccount'];
$updata['tranname'] = $data['tranname'];
$updata['tranidid'] = $data['tranidid'];
$updata['memo'] = $data['memo'];
$updata['apiuser'] = $rsuser['id'];
$csql = new \ciy\sql('ap_transfer');
if ($id > 0) {
$csql->where('id', $id);
if ($db->update($csql, $updata) === false)
throw new \Exception('更新失败:' . $db->error);
} else {
$updata['providerid'] = $rsuser['s_a'];
$updata['merchantid'] = $rsuser['s_b'];
$updata['thirdno'] = '';
$updata['orderstatus'] = 10;
$updata['iswa'] = $merchantrow['bwa'];
$updata['wano'] = '';
$updata['addtimes'] = tostamp();
$updata['signtimes'] = 0;
$updata['uptimes'] = 0;
$updata['orderno'] = '';
$updata['payfundno'] = '';
$updata['signature'] = '';
$updata['pubkeyid'] = 0;
$updata['fee'] = 0;
$updata['tranreceipt'] = 10;
$updata['errmsg'] = '';
if ($db->insert($csql, $updata) === false)
throw new \Exception('新增失败:' . $db->error);
$id = $db->insert_id();
}
$updata['id'] = $id;
return $updata;
}
public static function json_del() {
global $db;
$rsuser = verifyfast();
//if (nopower($db, $rsuser['id'], 'p d'))
// return errjson('您未被授权操作');
$post = new \ciy\post();
$ids = $post->get('ids');
if (empty($ids))
return errjson('请选择至少一条');
$csql = new \ciy\sql('ap_transfer');
$csql->where('merchantid', $rsuser['s_b']);
$csql->where('id in', $ids);
$rows = $db->get($csql);
$vids = array();
try {
$db->begin();
foreach ($rows as $row) {
if ($row['orderstatus'] != 10)
continue;
$delid = $row['id'];
//delcheck($db, $delid, 'tablexx', 'xxid', '管理员');
//delall($db, $delid, 'tablexx', 'xxid', '运动员'); //deltimeall
delme($db, $delid, 'ap_transfer');
$vids[] = $delid;
}
$db->commit();
} catch (\Exception $ex) {
$db->rollback();
savelogfile('err_db', $ex->getMessage());
return errjson($ex->getMessage());
}
$ret['ids'] = $vids;
return succjson($ret);
}
public static function json_getdopay() {
global $db;
$rsuser = verifyfast();
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$merchantrow = $db->getone($csql);
$csql = new \ciy\sql('ap_transfer');
$csql->where('merchantid', $rsuser['s_b']);
$csql->where('orderstatus', 10);
$orderrows = $db->get($csql);
$ret['datas'] = array();
$money = 0;
foreach ($orderrows as $orderrow) {
$money += $orderrow['amount'];
$ret['datas'][] = array(
'id' => $orderrow['id'],
'hash' => hash('sha256', signorder($orderrow))
);
}
$ret['total'] = count($orderrows);
$ret['money'] = $money;
$ret['safecase'] = $merchantrow['safecase'];
if ($ret['safecase'] > 0) {
$csql = new \ciy\sql('hf_merchantuser');
$csql->where('id', $rsuser['id']);
$userrow = $db->getone($csql);
if ($userrow['pubkeyid'] > 0) {
$csql = new \ciy\sql('hf_merchantpubkey');
$csql->where('id', $userrow['pubkeyid']);
$csql->where('safecase', $merchantrow['safecase']);
$pubkeyrow = $db->getone($csql);
$ret['pubkey'] = $pubkeyrow['pubkey'];
}
}
return succjson($ret);
}
public static function json_dopay() {
global $db;
$rsuser = verifyfast();
$post = new \ciy\post();
//if (nopower($db, $rsuser['id'], 'p d'))
// return errjson('您未被授权操作');
$csql = new \ciy\sql('hf_merchantuser');
$csql->where('id', $rsuser['id']);
$userrow = $db->getone($csql);
if (empty($userrow['password']))
return errjson('请先设置初始登录密码');
$csql = new \ciy\sql('hf_merchantalipaycharge');
$csql->where('merchantid', $userrow['merchantid']);
$csql->where('addtimes<', time() - 60);
$csql->where('orderstatus<100');
if (toint($db->get1($csql)) > 0)//检查商户余额,结合本次下单金额与手续费欠费金额,是否低于,低于提示。
return errjson('有未结算的手续费,请稍后下单,请稍后下单或检查账户余额');
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $userrow['merchantid']);
$merchantrow = $db->getone($csql);
if (!is_array($merchantrow))
return errjson('商户不存在');
$tp = date('H') * 3600 + date('i') * 60 + date('s') + 1;
if ($merchantrow['stpt'] < $merchantrow['endpt']) {
if ($tp < $merchantrow['stpt'] || $tp > $merchantrow['endpt'])
return errjson('当前时间不在服务时间范围内');
} else {
if ($tp < $merchantrow['stpt'] && $tp > $merchantrow['endpt'])
return errjson('当前时间不在服务时间范围内');
}
if ($merchantrow['saasstatus'] != 10)
return errjson('商户已被暂停服务');
$csql = new \ciy\sql('hf_providerbase');
$csql->where('id', $merchantrow['providerid']);
$providerrow = $db->getone($csql);
if (!is_array($providerrow))
return errjson('服务商不存在');
if ($providerrow['providerstatus'] != 10)
return errjson('转账服务暂停,请联系服务商!');
if ($providerrow['depositmoney'] <= 0)
return errjson('转账服务暂停,请联系服务商');
$signs = $post->get('sign');
if ($merchantrow['safecase'] == 10) {
if (empty($userrow['password2']))
return errjson('请先在右上角下拉菜单中,设置安全密码');
$authtime = $post->getint('auth');
if (abs($authtime / 1000 - tostamp()) > 300) {
return errjson('您的本地时间与服务器时间相差超过5分钟,请调整本机时间。
服务器时间: ' . date('Y-m-d H:i:s') . '
您本机时间: ' . date('Y-m-d H:i:s', $authtime / 1000));
}
if ($post->get('pass') != sha512($userrow['password2'] . $authtime)) {
sleep(2);
return errjson('安全密码错误');
}
sleep(1);
} else {
$csql = new \ciy\sql('hf_merchantpubkey');
$csql->where('id', $userrow['pubkeyid']);
$pubkeyrow = $db->getone($csql);
if (!is_array($pubkeyrow))
return errjson('未找到数字证书');
if ($merchantrow['safecase'] == 20) {
$retsign = verifysign_web3($pubkeyrow['pubkey'], $signs);
if (is_string($retsign))
return errjson($retsign);
}
if ($merchantrow['safecase'] == 30) {
$retsign = verifysign_vn($pubkeyrow['pubkey'], $signs);
if (is_string($retsign))
return errjson($retsign);
}
}
try {
$db->begin();
foreach ($signs as $sign) {
$updata = array();
$updata['orderstatus'] = 20;
$updata['apiuser'] = $rsuser['id'];
if ($merchantrow['safecase'] > 10) {
$updata['signtimes'] = tostamp();
$updata['signature'] = $sign['sign'];
$updata['pubkeyid'] = $userrow['pubkeyid'];
}
$csql = new \ciy\sql('ap_transfer');
$csql->where('id', $sign['id']);
$csql->where('orderstatus', 10);
if ($db->update($csql, $updata) === false)
throw new \Exception('转账失败:' . $db->error);
}
$db->commit();
} catch (\Exception $ex) {
$db->rollback();
savelogfile('err_db', $ex->getMessage());
return errjson($ex->getMessage());
}
return succjson();
}
public static function json_importxls_in() {
global $db;
$rsuser = verifyfast();
//if (nopower($db, $rsuser['id'], 'p i'))
// return errjson('您未被授权操作');
$post = new \ciy\post();
$file = PATH_WEB . '/ud' . $post->get('file');
if (!file_exists($file))
return errjson('文件不存在');
require_once PATH_ROOT . '../libs/phpoffice/autoload.php';
$spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($file);
$sheet = $spreadsheet->getActiveSheet();
$datas = $sheet->toArray('', true, true, false);
$datacnt = count($datas);
if ($datacnt < 2)
return errjson('数据为空');
$html = '';
$headsn = array();
$headsn[] = '行码.id';
$headsn[] = '账号类型.accounttype';
$headsn[] = '金额.amount';
$headsn[] = '账号.tranaccount';
$headsn[] = '姓名.tranname';
$headsn[] = '身份证号.tranidid';
$headsn[] = '备注.memo';
$xlsidx = 1;
if (empty($datas[0][count($headsn) - 1]))
$xlsidx = 2;
$heads = array();
foreach ($headsn as $_head) {
$hd = explode('.', $_head);
if (count($hd) < 2)
continue;
$heads[] = array(
'idx' => array_search($hd[0], $datas[$xlsidx - 1]),
'fld' => $hd[1],
'name' => $hd[0]
);
}
$code_accounttype = getcatas($db, 'accounttype');
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$merchantrow = $db->getone($csql);
$html .= '
| # | '; foreach ($heads as $arr) { $html .= '' . $arr['name'] . ' | '; } $html .= '' . $lineidx . ' | ';
$bempty = true;
$unqs = array();
$csql = new \ciy\sql('ap_transfer');
$data = array();
foreach ($heads as $arr) {
$name = $arr['name'];
$errmsg = ''; //数据有误,显示红色说明
$showdat = ''; //显示在表格中的数据
if ($arr['idx'] > -1)
$showdat = trim($datas[$rowidx][$arr['idx']]);
if ($showdat == '--')
$showdat = '';
$value = $showdat; //在表单中的数据(转换后)
$ext = ''; //扩展表单
if ($name == '行码') {
if (empty($showdat)) {
$value = 0;
$showdat = '新增';
} else {
$id = deid($showdat);
if ($id == 0)
$errmsg = $name . '解析错误';
else {
$csqlchk = new \ciy\sql('ap_transfer');
$csqlchk->where('id', $id);
$chkrow = $db->getone($csqlchk);
if (!is_array($chkrow))
$errmsg = $name . '在数据库中不存在';
if ($chkrow['orderstatus'] != 10)
$errmsg = $name . '状态错误';
$value = $id;
}
}
} else if ($name == '账号类型') {
if (empty($showdat)) {
$errmsg = $name . '为必填项';
} else {
$value = dcode($code_accounttype, $showdat);
$data['accounttype'] = $data;
if ($value == -1)
$errmsg = $name . '文字与系统数据不匹配';
}
} else if ($name == '金额') {
$showdat = str_replace(',', '', $showdat);
if (!is_numeric($showdat))
$errmsg = $name . '不是数字';
else
$value = toint((float)$showdat * 100);
$data['amount'] = $value;
if ($value < 0.1)
$errmsg = $name . '不能小于0.1元';
} else if ($name == '账号') {
if (empty($showdat)) {
$errmsg = $name . '必填';
}
$data['tranaccount'] = $showdat;
} else if ($name == '姓名') {
if (empty($showdat)) {
$errmsg = $name . '必填';
}
$data['tranname'] = $showdat;
} else if ($name == '身份证号') {
if (empty($showdat)) {
$value = '';
}
$data['tranidid'] = $showdat;
} else if ($name == '备注') {
if (empty($showdat)) {
$value = '';
}
$data['memo'] = $showdat;
}
if (!empty($showdat))
$bempty = false;
if (empty($errmsg))
$hrhtml .= '' . $showdat . '' . $ext . ' | ';
else
$hrhtml .= '' . $showdat . ' | ';
}
if ($bempty)
continue;
$retchk = check_transtr($data['amount'], $data['accounttype'], $data['tranaccount'], $data['tranname'], $data['tranidid'], $data['memo'], $merchantrow['safecase']);
if (is_string($retchk))
$firsthtml = '重复 | ';
else if (count($unqs) > 0) {
$unq = implode('|', $unqs);
if (in_array($unq, $uniques))
$firsthtml = '重复 | ';
else {
$uniques[] = $unq;
$csql->column('id');
$chkid = toint($db->get1($csql));
if ($chkid > 0 && (($id > 0 && $chkid != $id) || $id == 0))
$firsthtml = '重复 | ';
}
}
$html .= '
|---|---|
共' . $cnt . '条数据';
return succjson(array('html' => $html, 'count' => $cnt));
}
public static function json_importxls_data() {
global $db;
$rsuser = verifyfast();
//if (nopower($db, $rsuser['id'], 'p i'))
// return errjson('您未被授权操作');
$csql = new \ciy\sql('hf_merchantbase');
$csql->where('id', $rsuser['s_b']);
$merchantrow = $db->getone($csql);
$post = new \ciy\post();
$total = $post->getint('total');
try {
$db->begin();
for ($i = 1; $i <= $total; $i++) {
$id = $post->getint('id_' . $i);
$data = array();
$data['accounttype'] = $post->get('accounttype_' . $i);
$data['amount'] = $post->get('amount_' . $i);
$data['tranaccount'] = $post->get('tranaccount_' . $i);
$data['tranname'] = $post->get('tranname_' . $i);
$data['tranidid'] = $post->get('tranidid_' . $i);
$data['memo'] = $post->get('memo_' . $i);
self::updatedata($db, $rsuser, $id, $data, $merchantrow);
}
$db->commit();
} catch (\Exception $ex) {
$db->rollback();
savelogfile('err_db', $ex->getMessage());
return errjson($ex->getMessage());
}
return succjson();
}
}