Sellerdeposit.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. <?php
  2. /**
  3. * 预存款管理
  4. */
  5. namespace app\api\controller;
  6. use think\facade\Db;
  7. use think\facade\Lang;
  8. use app\common\model\Storedepositlog;
  9. use app\common\model\Storemoneylog;
  10. /**
  11. *
  12. *
  13. * ----------------------------------------------------------------------------
  14. *
  15. * 店铺保证金控制器
  16. */
  17. class Sellerdeposit extends MobileSeller
  18. {
  19. public function initialize()
  20. {
  21. parent::initialize();
  22. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/sellerdeposit.lang.php');
  23. }
  24. /**
  25. * @api {POST} api/Sellerdeposit/index 保证金变更日志
  26. * @apiVersion 1.0.0
  27. * @apiGroup Sellerdeposit
  28. *
  29. * @apiHeader {String} X-DS-KEY 卖家授权token
  30. *
  31. * @apiParam {String} query_start_date 开始时间 YYYY-MM-DD
  32. * @apiParam {String} query_end_date 结束时间 YYYY-MM-DD
  33. * @apiParam {String} storedepositlog_desc 日志详情
  34. * @apiParam {String} page 页码
  35. * @apiParam {String} pagesize 每页显示数量
  36. *
  37. * @apiSuccess {String} code 返回码,10000为成功
  38. * @apiSuccess {String} message 返回消息
  39. * @apiSuccess {Object} result 返回数据
  40. * @apiSuccess {Object[]} result.log_list 保证金列表 (返回字段参考storedepositlog表)
  41. * @apiSuccess {Int} result.page_total 总页数
  42. * @apiSuccess {Boolean} result.hasmore 是否有更多 true是false否
  43. */
  44. public function index()
  45. {
  46. $condition = array(array('store_id', '=', $this->store_info['store_id']));
  47. $query_start_date = input('param.query_start_date');
  48. $query_end_date = input('param.query_end_date');
  49. $if_start_date = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_start_date);
  50. $if_end_date = preg_match('/^20\d{2}-\d{2}-\d{2}$/', $query_end_date);
  51. $start_unixtime = $if_start_date ? strtotime($query_start_date) : null;
  52. $end_unixtime = $if_end_date ? (strtotime($query_end_date) + 86399) : null;
  53. if ($start_unixtime || $end_unixtime) {
  54. $condition[] = array('storedepositlog_add_time', 'between', array($start_unixtime, $end_unixtime));
  55. }
  56. $storedepositlog_desc = input('param.storedepositlog_desc');
  57. if ($storedepositlog_desc) {
  58. $condition[] = array('storedepositlog_desc', 'like', '%' . $storedepositlog_desc . '%');
  59. }
  60. $storedepositlog_model = model('storedepositlog');
  61. $log_list = $storedepositlog_model->getStoredepositlogList($condition, 10, '*', 'storedepositlog_id desc');
  62. $result = array_merge(array('log_list' => $log_list), mobile_page($storedepositlog_model->page_info));
  63. ds_json_encode(10000, lang('ds_common_op_succ'), $result);
  64. }
  65. /**
  66. * @api {POST} api/Sellerdeposit/withdraw_list 保证金提现列表
  67. * @apiVersion 1.0.0
  68. * @apiGroup Sellerdeposit
  69. *
  70. * @apiHeader {String} X-DS-KEY 卖家授权token
  71. *
  72. * @apiParam {Int} paystate_search 提现状态 0无效1有效2待审核3已同意4已拒绝5已缴纳6已取消
  73. * @apiParam {String} page 页码
  74. * @apiParam {String} pagesize 每页显示数量
  75. *
  76. * @apiSuccess {String} code 返回码,10000为成功
  77. * @apiSuccess {String} message 返回消息
  78. * @apiSuccess {Object} result 返回数据
  79. * @apiSuccess {Object[]} result.log_list 保证金列表 (返回字段参考storedepositlog表)
  80. * @apiSuccess {Int} result.page_total 总页数
  81. * @apiSuccess {Boolean} result.hasmore 是否有更多 true是false否
  82. */
  83. public function withdraw_list()
  84. {
  85. $condition = array(
  86. array('store_id', '=', $this->store_info['store_id']),
  87. array('storedepositlog_type', 'in', [Storedepositlog::TYPE_WITHDRAW, Storedepositlog::TYPE_RECHARGE]),
  88. );
  89. $paystate_search = input('param.paystate_search');
  90. if (isset($paystate_search) && $paystate_search !== '') {
  91. $condition[] = array('storedepositlog_state', '=', intval($paystate_search));
  92. }
  93. $storedepositlog_model = model('storedepositlog');
  94. $log_list = $storedepositlog_model->getStoredepositlogList($condition, 10, '*', 'storedepositlog_id desc');
  95. $result = array_merge(array('log_list' => $log_list), mobile_page($storedepositlog_model->page_info));
  96. ds_json_encode(10000, lang('ds_common_op_succ'), $result);
  97. }
  98. /**
  99. * @api {POST} api/Sellerdeposit/recharge_add 补缴店铺保证金
  100. * @apiVersion 1.0.0
  101. * @apiGroup Sellerdeposit
  102. *
  103. * @apiHeader {String} X-DS-KEY 卖家授权token
  104. *
  105. * @apiParam {Float} pdc_amount 补缴金额
  106. *
  107. * @apiSuccess {String} code 返回码,10000为成功
  108. * @apiSuccess {String} message 返回消息
  109. * @apiSuccess {Object} result 返回数据
  110. */
  111. public function recharge_add()
  112. {
  113. $storedepositlog_model = model('storedepositlog');
  114. $money = abs(floatval(input('post.pdc_amount')));
  115. if (!$money) {
  116. ds_json_encode(10001, lang('param_error'));
  117. }
  118. try {
  119. Db::startTrans();
  120. $data = array(
  121. 'store_id' => $this->store_info['store_id'],
  122. 'store_name' => $this->store_info['store_name'],
  123. 'storedepositlog_type' => Storedepositlog::TYPE_PAY,
  124. 'storedepositlog_state' => Storedepositlog::STATE_VALID,
  125. 'storedepositlog_add_time' => TIMESTAMP,
  126. );
  127. $data['store_avaliable_deposit'] = $money;
  128. $data['storedepositlog_desc'] = lang('sellerdeposit_recharge_deposit');
  129. $storedepositlog_model->changeStoredeposit($data);
  130. //从店铺资金中扣除
  131. $storemoneylog_model = model('storemoneylog');
  132. $data2 = array(
  133. 'store_id' => $this->store_info['store_id'],
  134. 'store_name' => $this->store_info['store_name'],
  135. 'storemoneylog_type' => Storemoneylog::TYPE_DEPOSIT_IN,
  136. 'storemoneylog_state' => Storemoneylog::STATE_VALID,
  137. 'storemoneylog_add_time' => TIMESTAMP,
  138. 'store_avaliable_money' => -$money,
  139. 'storemoneylog_desc' => $data['storedepositlog_desc'],
  140. );
  141. $storemoneylog_model->changeStoremoney($data2);
  142. Db::commit();
  143. } catch (\Exception $e) {
  144. Db::rollback();
  145. ds_json_encode(10001, $e->getMessage());
  146. }
  147. $this->recordSellerlog(lang('sellerdeposit_recharge_deposit'));
  148. ds_json_encode(10000, lang('ds_common_op_succ'));
  149. }
  150. /**
  151. * @api {POST} api/Sellerdeposit/withdraw_add 申请保证金提现
  152. * @apiVersion 1.0.0
  153. * @apiGroup Sellerdeposit
  154. *
  155. * @apiHeader {String} X-DS-KEY 卖家授权token
  156. *
  157. * @apiParam {Float} pdc_amount 提现金额
  158. *
  159. * @apiSuccess {String} code 返回码,10000为成功
  160. * @apiSuccess {String} message 返回消息
  161. * @apiSuccess {Object} result 返回数据
  162. */
  163. public function withdraw_add()
  164. {
  165. $data = [
  166. 'pdc_amount' => floatval(input('post.pdc_amount')),
  167. ];
  168. $sellerdeposit_validate = ds_validate('sellerdeposit');
  169. if (!$sellerdeposit_validate->scene('withdraw_add')->check($data)) {
  170. ds_json_encode(10001, $sellerdeposit_validate->getError());
  171. }
  172. $pdc_amount = $data['pdc_amount'];
  173. $storedepositlog_model = model('storedepositlog');
  174. $data = array(
  175. 'store_id' => $this->store_info['store_id'],
  176. 'store_name' => $this->store_info['store_name'],
  177. 'storedepositlog_type' => Storedepositlog::TYPE_WITHDRAW,
  178. 'storedepositlog_state' => Storedepositlog::STATE_WAIT,
  179. 'storedepositlog_add_time' => TIMESTAMP,
  180. );
  181. $data['store_avaliable_deposit'] = -$pdc_amount;
  182. $data['store_freeze_deposit'] = $pdc_amount;
  183. $data['storedepositlog_desc'] = lang('sellerdeposit_apply_withdraw') . lang('sellerdeposit_avaliable_money');
  184. try {
  185. Db::startTrans();
  186. $storedepositlog_model->changeStoredeposit($data);
  187. Db::commit();
  188. $this->recordSellerlog(lang('sellerdeposit_apply_withdraw'));
  189. ds_json_encode(10000, lang('ds_common_op_succ'));
  190. } catch (\Exception $e) {
  191. Db::rollback();
  192. ds_json_encode(10001, $e->getMessage());
  193. }
  194. }
  195. }