Recharge.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. <?php
  2. namespace app\api\controller;
  3. use think\facade\Lang;
  4. use think\facade\Db;
  5. /**
  6. * ============================================================================
  7. *
  8. * ============================================================================
  9. *
  10. * ----------------------------------------------------------------------------
  11. *
  12. * ============================================================================
  13. * 充值控制器
  14. */
  15. class Recharge extends MobileMember {
  16. public function initialize() {
  17. parent::initialize();
  18. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/predeposit.lang.php');
  19. }
  20. /**
  21. * @api {POST} api/Recharge/index 新增充值信息
  22. * @apiVersion 1.0.0
  23. * @apiGroup Recharge
  24. *
  25. * @apiHeader {String} X-DS-KEY 用户授权token
  26. *
  27. * @apiParam {Float} pdr_amount 充值金额
  28. *
  29. * @apiSuccess {String} code 返回码,10000为成功
  30. * @apiSuccess {String} message 返回消息
  31. * @apiSuccess {Object} result 返回数据
  32. * @apiSuccess {String} result.pay_sn 支付单号
  33. */
  34. public function index() {
  35. $pdr_amount = abs(floatval(input('post.pdr_amount')));
  36. if ($pdr_amount <= 0) {
  37. ds_json_encode(10001, lang('param_error'));
  38. } else {
  39. $predeposit_model = model('predeposit');
  40. $data = array();
  41. $data['pdr_sn'] = $pay_sn = makePaySn($this->member_info['member_id']);
  42. $data['pdr_member_id'] = $this->member_info['member_id'];
  43. $data['pdr_member_name'] = $this->member_info['member_name'];
  44. $data['pdr_amount'] = $pdr_amount;
  45. $data['pdr_addtime'] = TIMESTAMP;
  46. $insert = $predeposit_model->addPdRecharge($data);
  47. if ($insert) {
  48. ds_json_encode(10000, '', array('pay_sn' => $pay_sn));
  49. } else {
  50. ds_json_encode(10001, lang('ds_common_op_fail'));
  51. }
  52. }
  53. }
  54. /**
  55. * @api {POST} api/Recharge/pd_cash_add 申请提现
  56. * @apiVersion 1.0.0
  57. * @apiGroup Recharge
  58. *
  59. * @apiHeader {String} X-DS-KEY 用户授权token
  60. *
  61. * @apiParam {String} pdc_bank_name 银行名称
  62. * @apiParam {String} pdc_bank_no 银行卡号
  63. * @apiParam {String} pdc_bank_user 银行用户名
  64. * @apiParam {String} password 支付密码
  65. * @apiParam {Float} pdc_amount 提现金额
  66. *
  67. * @apiSuccess {String} code 返回码,10000为成功
  68. * @apiSuccess {String} message 返回消息
  69. * @apiSuccess {Object} result 返回数据
  70. */
  71. public function pd_cash_add() {
  72. $pdc_amount = abs(floatval(input('post.pdc_amount')));
  73. $memberbank_id = intval(input('param.memberbank_id'));
  74. if ($memberbank_id > 0) {
  75. $memberbank = model('memberbank')->getMemberbankInfo(array('member_id' => session('member_id'), 'memberbank_id' => $memberbank_id));
  76. if (empty($memberbank)) {
  77. ds_json_encode(10001, lang('param_error'));
  78. }
  79. $pdc_bank_type = $memberbank['memberbank_type'];
  80. $pdc_bank_name = $memberbank['memberbank_type'] == 'alipay' ? lang('pay_method_alipay') : $memberbank['memberbank_name'];
  81. $pdc_bank_no = $memberbank['memberbank_no'];
  82. $pdc_bank_user = $memberbank['memberbank_truename'];
  83. } elseif ($memberbank_id == -1) {//使用微信
  84. $member_wxinfo = unserialize($this->member_info['member_wxinfo']);
  85. if (!empty($member_wxinfo) && is_array($member_wxinfo) && isset($member_wxinfo['member_wxopenid']) && $member_wxinfo['member_wxopenid']) {
  86. $pdc_bank_type = 'weixin';
  87. $pdc_bank_name = lang('pay_method_wechat');
  88. $pdc_bank_no = $member_wxinfo['member_wxopenid'];
  89. $pdc_bank_user = $member_wxinfo['nickname'];
  90. } else {
  91. ds_json_encode(10001, lang('param_error'));
  92. }
  93. } else {
  94. ds_json_encode(10001, lang('param_error'));
  95. }
  96. $data = [
  97. 'pdc_amount' => $pdc_amount,
  98. 'pdc_bank_type' => $pdc_bank_type,
  99. 'pdc_bank_name' => $pdc_bank_name,
  100. 'pdc_bank_no' => $pdc_bank_no,
  101. 'pdc_bank_user' => $pdc_bank_user,
  102. 'password' => input('post.password')
  103. ];
  104. $recharge_validate = ds_validate('predeposit');
  105. if (!$recharge_validate->scene('pd_cash_add')->check($data)) {
  106. ds_json_encode(10001, $recharge_validate->getError());
  107. }
  108. $predeposit_model = model('predeposit');
  109. $member_model = model('member');
  110. $memberinfo = $member_model->getMemberInfoByID($this->member_info['member_id']);
  111. //验证支付密码
  112. if (md5(input('post.password')) != $memberinfo['member_paypwd']) {
  113. ds_json_encode(10001, lang('payment_password_error'));
  114. }
  115. //验证金额是否足够
  116. if (floatval($memberinfo['available_predeposit']) < $pdc_amount) {
  117. ds_json_encode(10001, lang('predeposit_cash_shortprice_error'));
  118. }
  119. //是否超过提现周期
  120. $last_withdraw = $predeposit_model->getPdcashInfo(array(array('pdc_member_id', '=', $this->member_info['member_id']), array('pdc_payment_state', 'in', [0, 1]), array('pdc_addtime', '>', TIMESTAMP - intval(config('ds_config.member_withdraw_cycle')) * 86400)));
  121. if ($last_withdraw) {
  122. ds_json_encode(10001, lang('predeposit_last_withdraw_time_error') . date('Y-m-d', $last_withdraw['pdc_addtime'] + (intval(config('ds_config.member_withdraw_cycle')) * 86400)));
  123. }
  124. //是否不小于最低提现金额
  125. if ($pdc_amount < floatval(config('ds_config.member_withdraw_min'))) {
  126. ds_json_encode(10001, lang('predeposit_withdraw_min') . config('ds_config.member_withdraw_min') . lang('ds_yuan'));
  127. }
  128. //是否不超过最高提现金额
  129. if ($pdc_amount > floatval(config('ds_config.member_withdraw_max'))) {
  130. ds_json_encode(10001, lang('predeposit_withdraw_max') . config('ds_config.store_withdraw_max') . lang('ds_yuan'));
  131. }
  132. try {
  133. Db::startTrans();
  134. $pdc_sn = makePaySn($memberinfo['member_id']);
  135. $data = array();
  136. $data['pdc_sn'] = $pdc_sn;
  137. $data['pdc_member_id'] = $memberinfo['member_id'];
  138. $data['pdc_member_name'] = $memberinfo['member_name'];
  139. $data['pdc_bank_type'] = $pdc_bank_type;
  140. $data['pdc_amount'] = $pdc_amount;
  141. $data['pdc_bank_name'] = $pdc_bank_name;
  142. $data['pdc_bank_no'] = $pdc_bank_no;
  143. $data['pdc_bank_user'] = $pdc_bank_user;
  144. $data['pdc_addtime'] = TIMESTAMP;
  145. $data['pdc_payment_state'] = 0;
  146. $insert = $predeposit_model->addPdcash($data);
  147. if (!$insert) {
  148. throw new \think\Exception(lang('predeposit_cash_add_fail'), 10006);
  149. }
  150. //冻结可用预存款
  151. $data = array();
  152. $data['member_id'] = $memberinfo['member_id'];
  153. $data['member_name'] = $memberinfo['member_name'];
  154. $data['amount'] = $pdc_amount;
  155. $data['order_sn'] = $pdc_sn;
  156. $predeposit_model->changePd('cash_apply', $data);
  157. Db::commit();
  158. } catch (\Exception $e) {
  159. Db::rollback();
  160. ds_json_encode(10001, $e->getMessage());
  161. }
  162. ds_json_encode(10000, lang('ds_common_op_succ'), array('status' => 'ok'));
  163. }
  164. /**
  165. * @api {POST} api/Recharge/recharge_order 获取充值信息
  166. * @apiVersion 1.0.0
  167. * @apiGroup Recharge
  168. *
  169. * @apiHeader {String} X-DS-KEY 用户授权token
  170. *
  171. * @apiParam {String} paysn 充值单号
  172. *
  173. * @apiSuccess {String} code 返回码,10000为成功
  174. * @apiSuccess {String} message 返回消息
  175. * @apiSuccess {Object} result 返回数据
  176. * @apiSuccess {Object} result.payment_list 返回数据
  177. * @apiSuccess {String} result.payment_list.payment_code 支付方式代码
  178. * @apiSuccess {String} result.payment_list.payment_name 支付方式名称
  179. * @apiSuccess {Object} result.pdinfo 充值信息 (返回字段参考pdrecharge表)
  180. * @apiSuccess {Object} result.base_site_url 域名
  181. */
  182. public function recharge_order() {
  183. $pay_sn = input('param.paysn');
  184. if (!preg_match('/^\d{20}$/', $pay_sn)) {
  185. ds_json_encode(10001, lang('param_error'));
  186. exit();
  187. }
  188. //查询支付单信息
  189. $predeposit_model = model('predeposit');
  190. $pd_info = $predeposit_model->getPdRechargeInfo(array('pdr_sn' => $pay_sn, 'pdr_member_id' => $this->member_info['member_id']));
  191. if (empty($pd_info)) {
  192. ds_json_encode(10001, lang('recharge_info_not_exist'));
  193. exit();
  194. }
  195. if (intval($pd_info['pdr_payment_state'])) {
  196. ds_json_encode(10001, lang('payment_repeat'));
  197. exit();
  198. }
  199. $payment_model = model('payment');
  200. $condition = array();
  201. $condition[] = array('payment_platform','=','h5');
  202. $payment_list = $payment_model->getPaymentOpenList($condition);
  203. $payment_array = array();
  204. if (!empty($payment_list)) {
  205. foreach ($payment_list as $value) {
  206. $payment_array[] = array('payment_code' => $value['payment_code'], 'payment_name' => $value['payment_name']);
  207. }
  208. } else {
  209. ds_json_encode(10001, lang('predeposit_payment_error'));
  210. exit();
  211. }
  212. unset($pd_info['pdr_payment_code']);
  213. unset($pd_info['pdr_trade_sn']);
  214. unset($pd_info['pdr_payment_state']);
  215. unset($pd_info['pdr_paymenttime']);
  216. unset($pd_info['pdr_admin']);
  217. ds_json_encode(10000, '', array('payment_list' => $payment_array, 'pdinfo' => $pd_info, 'base_site_url' => BASE_SITE_URL));
  218. }
  219. public function member_v() {
  220. $member_info = array();
  221. $member_info['user_name'] = $this->member_info['member_name'];
  222. $member_info['avator'] = get_member_avatar_for_id($this->member_info['member_id']);
  223. $member_info['point'] = $this->member_info['member_points'];
  224. $member_gradeinfo = model('member')->getOneMemberGrade(intval($this->member_info['member_exppoints']));
  225. $member_info['level_name'] = $member_gradeinfo['level_name'];
  226. $member_info['favorites_store'] = model('favorites')->getStoreFavoritesCountByMemberId($this->member_info['member_id']);
  227. $member_info['favorites_goods'] = model('favorites')->getGoodsFavoritesCountByMemberId($this->member_info['member_id']);
  228. $member_info['member_id'] = $this->member_info['member_id']; //
  229. $member_info['member_id_64'] = base64_encode(intval($this->member_info['member_id']) * 1); //
  230. $list_setting = rkcache('config', true);
  231. $member_info['vip_1fee'] = $list_setting['vip_1fee'];
  232. $member_info['vip_2fee'] = $list_setting['vip_2fee'];
  233. ds_json_encode(10000, '', array('member_info' => $member_info));
  234. }
  235. /**
  236. * 在线升级到会员级别
  237. */
  238. public function recharge_vip1() {
  239. $pdr_amount = abs(floatval(input('post.pdr_amount')));
  240. $list_setting = rkcache('config', true);
  241. if ($pdr_amount <= 0 || $pdr_amount != abs(floatval($list_setting['vip_1fee']))) {
  242. ds_json_encode(10001, lang('param_error'));
  243. exit();
  244. }
  245. $predeposit_model = model('predeposit');
  246. $data = array();
  247. $data['pdr_sn'] = $pay_sn = makePaySn($this->member_info['member_id']);
  248. $data['pdr_member_id'] = $this->member_info['member_id'];
  249. $data['pdr_member_name'] = $this->member_info['member_name'];
  250. $data['pdr_amount'] = $pdr_amount;
  251. $data['pdr_addtime'] = TIMESTAMP;
  252. $data['pdr_vipid'] = '1';
  253. $insert = $predeposit_model->addVipRecharge($data);
  254. if ($insert) {
  255. ds_json_encode(10000, '', array('pay_sn' => $pay_sn));
  256. } else {
  257. ds_json_encode(10001, lang('ds_common_op_fail'));
  258. }
  259. }
  260. public function recharge_vip2() {
  261. $pdr_amount = abs(floatval(input('post.pdr_amount')));
  262. $list_setting = rkcache('config', true);
  263. if ($pdr_amount <= 0 || $pdr_amount != abs(floatval($list_setting['vip_2fee']))) {
  264. ds_json_encode(10001, lang('param_error'));
  265. exit();
  266. }
  267. $predeposit_model = model('predeposit');
  268. $data = array();
  269. $data['pdr_sn'] = $pay_sn = makePaySn($this->member_info['member_id']);
  270. $data['pdr_member_id'] = $this->member_info['member_id'];
  271. $data['pdr_member_name'] = $this->member_info['member_name'];
  272. $data['pdr_amount'] = $pdr_amount;
  273. $data['pdr_addtime'] = TIMESTAMP;
  274. $data['pdr_vipid'] = '2';
  275. $insert = $predeposit_model->addVipRecharge($data);
  276. if ($insert) {
  277. ds_json_encode(10000, '', array('pay_sn' => $pay_sn));
  278. } else {
  279. ds_json_encode(10001, lang('ds_common_op_fail'));
  280. }
  281. }
  282. public function viprecharge_order() {
  283. $pay_sn = input('post.paysn');
  284. if (!preg_match('/^\d{20}$/', $pay_sn)) {
  285. ds_json_encode(10001, lang('param_error'));
  286. exit();
  287. }
  288. //查询支付单信息
  289. $predeposit_model = model('predeposit');
  290. $pd_info = $predeposit_model->getVipRechargeInfo(array('pdr_sn' => $pay_sn, 'pdr_member_id' => $this->member_info['member_id']));
  291. if (empty($pd_info)) {
  292. ds_json_encode(10001, lang('recharge_info_not_exist'));
  293. exit();
  294. }
  295. if (intval($pd_info['pdr_payment_state'])) {
  296. ds_json_encode(10001, lang('payment_repeat'));
  297. exit();
  298. }
  299. $payment_model = model('payment');
  300. $condition = array();
  301. $condition[] = array('payment_platform','=','h5');
  302. $payment_list = $payment_model->getPaymentOpenList($condition);
  303. $payment_array = array();
  304. if (!empty($payment_list)) {
  305. foreach ($payment_list as $value) {
  306. $payment_array[] = array('payment_code' => $value['payment_code'], 'payment_name' => $value['payment_name']);
  307. }
  308. } else {
  309. ds_json_encode(10001, lang('predeposit_payment_error'));
  310. exit();
  311. }
  312. unset($pd_info['pdr_payment_code']);
  313. unset($pd_info['pdr_trade_sn']);
  314. unset($pd_info['pdr_payment_state']);
  315. unset($pd_info['pdr_paymenttime']);
  316. unset($pd_info['pdr_admin']);
  317. ds_json_encode(10000, '', array('payment_list' => $payment_array, 'pdinfo' => $pd_info));
  318. }
  319. }