Membervrbuy.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. <?php
  2. namespace app\api\controller;
  3. use think\Db;
  4. use think\facade\Lang;
  5. /**
  6. * ============================================================================
  7. * DSMall多用户商城
  8. * ============================================================================
  9. * 版权所有 2014-2028 长沙德尚网络科技有限公司,并保留所有权利。
  10. * 网站地址: http://www.csdeshang.com
  11. * ----------------------------------------------------------------------------
  12. * 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用 .
  13. * 不允许对程序代码以任何形式任何目的的再发布。
  14. * ============================================================================
  15. * 虚拟购买控制器
  16. */
  17. class Membervrbuy extends MobileMember
  18. {
  19. public function initialize()
  20. {
  21. parent::initialize(); // TODO: Change the autogenerated stub
  22. Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/buy.lang.php');
  23. }
  24. /**
  25. * @api {POST} api/Membervrbuy/buy_step1 虚拟商品购买第一步,设置接收手机号
  26. * @apiVersion 1.0.0
  27. * @apiGroup Membervrbuy
  28. *
  29. * @apiHeader {String} X-DS-KEY 用户授权token
  30. *
  31. * @apiParam {Int} goods_id 商品ID
  32. * @apiParam {Int} quantity 数量
  33. *
  34. * @apiSuccess {String} code 返回码,10000为成功
  35. * @apiSuccess {String} message 返回消息
  36. * @apiSuccess {Object} result 返回数据
  37. * @apiSuccess {Object} result.member_info 用户信息
  38. * @apiSuccess {Boolean} result.member_info.member_paypwd 是否已设置支付密码 true是false否
  39. * @apiSuccess {String} result.member_info.member_mobile 手机号
  40. * @apiSuccess {Float} result.member_info.available_predeposit 可用预存款余额
  41. * @apiSuccess {Float} result.member_info.available_rc_balance 可用充值卡余额
  42. */
  43. public function buy_step1()
  44. {
  45. if (!$this->member_info['is_buylimit']) {
  46. ds_json_encode(10001, lang('cart_buy_noallow'));
  47. }
  48. if (config('ds_config.member_auth') && $this->member_info['member_auth_state'] != 3) {
  49. ds_json_encode(10001, lang('cart_buy_noauth'));
  50. }
  51. $extra = [];
  52. //额外数据用来处理拼团等其他活动
  53. $pintuan_id = intval(input('param.pintuan_id'));
  54. if ($pintuan_id > 0) {
  55. $extra['pintuan_id'] = $pintuan_id;#拼团ID
  56. #是否为开团订单
  57. $extra['pintuangroup_id'] = empty(input('param.pintuangroup_id')) ? 0 : intval(input('param.pintuangroup_id'));
  58. }
  59. $logic_buyvirtual = model('buyvirtual', 'logic');
  60. $result = $logic_buyvirtual->getBuyStep2Data(input('post.goods_id'), input('post.quantity'), $this->member_info['member_id'], $extra);
  61. if (!$result['code']) {
  62. ds_json_encode(10001, $result['msg']);
  63. } else {
  64. $result = $result['data'];
  65. $member_info = [];
  66. $member_info['member_paypwd'] = $result['member_info']['member_paypwd'] ? true : false;
  67. $member_info['member_mobile'] = $result['member_info']['member_mobile'];
  68. $member_info['available_predeposit'] = $result['member_info']['available_predeposit'];
  69. $member_info['available_rc_balance'] = $result['member_info']['available_rc_balance'];
  70. unset($result['member_info']);
  71. $result['member_info'] = $member_info;
  72. if (isset($result['store_voucher_list']) && is_array($result['store_voucher_list']) && count($result['store_voucher_list']) > 0) {
  73. current($result['store_voucher_list']);
  74. $result['goods_info']['store_voucher_info'] = reset($result['store_voucher_list']);
  75. $result['goods_info']['store_voucher_info']['voucher_price'] = ds_price_format($result['goods_info']['store_voucher_info']['voucher_price']);
  76. $result['goods_info']['store_voucher_info']['voucher_enddate_text'] = date('Y年m月d日', $result['goods_info']['store_voucher_info']['voucher_enddate']);
  77. } else {
  78. $result['goods_info']['store_voucher_info'] = [];
  79. }
  80. $result['goods_info']['store_voucher_list'] = isset($result['store_voucher_list']) ? array_values($result['store_voucher_list']) : [];
  81. ds_json_encode(10000, '', $result);
  82. }
  83. }
  84. /**
  85. * @api {POST} api/Membervrbuy/buy_step1 虚拟订单第二步,产生订单
  86. * @apiVersion 1.0.0
  87. * @apiGroup Membervrbuy
  88. *
  89. * @apiHeader {String} X-DS-KEY 用户授权token
  90. *
  91. * @apiParam {Int} goods_id 商品ID
  92. * @apiParam {Int} quantity 数量
  93. * @apiParam {String} buyer_phone 手机号
  94. * @apiParam {String} buyer_msg 买家留言
  95. * @apiParam {String} password 密码
  96. * @apiParam {String} rcb_pay 使用充值卡支付0是/1否
  97. * @apiParam {String} pd_pay 使用预存款支付0是/1否
  98. *
  99. * @apiSuccess {String} code 返回码,10000为成功
  100. * @apiSuccess {String} message 返回消息
  101. * @apiSuccess {Object} result 返回数据
  102. * @apiSuccess {Int} result.order_id 订单ID
  103. * @apiSuccess {String} result.order_sn 订单编号
  104. */
  105. public function buy_step2()
  106. {
  107. $logic_buyvirtual = model('buyvirtual', 'logic');
  108. $input = [];
  109. $input['goods_id'] = input('post.goods_id');
  110. $input['quantity'] = input('post.quantity');
  111. $input['buyer_phone'] = input('post.buyer_phone');
  112. $input['buyer_msg'] = input('post.buyer_msg');
  113. //支付密码
  114. $input['password'] = !empty(input('post.password')) ? input('post.password') : '';
  115. //是否使用充值卡支付0是/1否
  116. $input['rcb_pay'] = empty(input('post.rcb_pay')) ? '0' : '1';
  117. //是否使用预存款支付0是/1否
  118. $input['pd_pay'] = empty(input('post.pd_pay')) ? '0' : '1';
  119. $input['pintuan_id'] = input('post.pintuan_id');
  120. $input['pintuangroup_id'] = input('post.pintuangroup_id');
  121. $input['order_from'] = 2;
  122. $input['voucher'] = input('post.voucher');
  123. $result = $logic_buyvirtual->buyStep3($input, $this->member_info['member_id']);
  124. if (!$result) {
  125. return false;
  126. } else {
  127. $orderId = $result['data']['order_id'];
  128. $orderModel = model('vrorder', 'model');
  129. $orderInfo = $orderModel->getVrorderInfo([['order_id', '=', $orderId]]);
  130. $result['data']['order_amount'] = $orderInfo['order_amount'] - $orderInfo['deduction_amount'];
  131. if (!$result['code']) {
  132. ds_json_encode(10001, $result['msg']);
  133. } else {
  134. ds_json_encode(10000, '', $result['data']);
  135. }
  136. }
  137. }
  138. /**
  139. * 验证密码
  140. */
  141. public function check_password()
  142. {
  143. if (empty(input('post.password'))) {
  144. ds_json_encode(10001, lang('param_error'));
  145. }
  146. $member_model = model('member');
  147. $member_info = $member_model->getMemberInfoByID($this->member_info['member_id']);
  148. if ($member_info['member_paypwd'] == md5(input('post.password'))) {
  149. ds_json_encode(10000, '', 1);
  150. } else {
  151. ds_json_encode(10001, lang('password_mistake'));
  152. }
  153. }
  154. /**
  155. * 更换收货地址
  156. */
  157. public function change_address()
  158. {
  159. $logic_buy = model('buy', 'logic');
  160. $city_id = 0;
  161. if (empty(input('post.city_id'))) {
  162. $city_id = input('post.area_id');
  163. }
  164. $data = $logic_buy->changeAddr(input('post.freight_hash'), $city_id, input('post.area_id'), $this->member_info['member_id']);
  165. if (!empty($data) && $data['state'] == 'success') {
  166. ds_json_encode(10000, '', $data);
  167. } else {
  168. ds_json_encode(10001, lang('param_error'));
  169. }
  170. }
  171. /**
  172. * @api {POST} api/Membervrbuy/pay 支付方式
  173. * @apiVersion 1.0.0
  174. * @apiGroup Membervrbuy
  175. *
  176. * @apiHeader {String} X-DS-KEY 用户授权token
  177. *
  178. * @apiParam {String} pay_sn 支付单号
  179. *
  180. * @apiSuccess {String} code 返回码,10000为成功
  181. * @apiSuccess {String} message 返回消息
  182. * @apiSuccess {Object} result 返回数据
  183. * @apiSuccess {Float} result.pay_info 支付信息
  184. * @apiSuccess {Float} result.pay_info.member_available_pd 预存款余额
  185. * @apiSuccess {Float} result.pay_info.member_available_rcb 充值卡余额
  186. * @apiSuccess {Boolean} result.pay_info.member_paypwd 已设置支付密码 true是false否
  187. * @apiSuccess {Float} result.pay_info.pay_amount 支付金额
  188. * @apiSuccess {String} result.pay_info.pay_sn 支付单号
  189. * @apiSuccess {Float} result.pay_info.payed_amount 已支付金额
  190. * @apiSuccess {Object[]} result.pay_info.payment_list 支付方式列表
  191. * @apiSuccess {String} result.pay_info.payment_list.payment_code 支付方式代码
  192. * @apiSuccess {String} result.pay_info.payment_list.payment_name 支付方式名称
  193. * @apiSuccess {String} result.pay_info.payment_list.payment_platform 支付方式适用平台
  194. */
  195. public function pay()
  196. {
  197. $pay_sn = input('post.pay_sn');
  198. $condition = [];
  199. $condition[] = ['order_sn', '=', $pay_sn];
  200. $order_info = model('vrorder')->getVrorderInfo($condition);
  201. $condition = [];
  202. $condition[] = ['payment_platform', '=', 'h5'];
  203. $payment_list = model('payment')->getPaymentOpenList($condition);
  204. $pay_info['pay_amount'] = $order_info['order_amount'];
  205. $pay_info['member_available_pd'] = $this->member_info['available_predeposit'];
  206. $pay_info['member_available_rcb'] = $this->member_info['available_rc_balance'];
  207. $pay_info['member_available_point'] = $this->member_info['point'];
  208. $pay_info['member_paypwd'] = true;
  209. if (empty($this->member_info['member_paypwd'])) {
  210. $pay_info['member_paypwd'] = false;
  211. }
  212. $pay_info['pay_sn'] = $order_info['order_sn'];
  213. $pay_info['payed_amount'] = $order_info['pd_amount'] + $order_info['rcb_amount'] + $order_info['deduction_amount'];
  214. if ($pay_info['payed_amount'] > '0.00') {
  215. $pay_info['pay_amount'] = round($pay_info['pay_amount'] - $pay_info['payed_amount'],2);
  216. }
  217. //如果线上线下支付金额都为0,转到支付成功页
  218. if (empty($pay_info['pay_amount'])) {
  219. ds_json_encode(12001, lang('pay_repeat'));
  220. }
  221. $pay_in["pay_info"] = $pay_info;
  222. $pay_in["pay_info"]["payment_list"] = $payment_list;
  223. ds_json_encode(10000, '', $pay_in);
  224. }
  225. /**
  226. * 支付密码确认
  227. */
  228. public function check_pd_pwd()
  229. {
  230. if ($this->member_info['member_paypwd'] != md5(input('post.password'))) {
  231. ds_json_encode(10001, lang('payment_password_error'));
  232. } else {
  233. ds_json_encode(10000, '', 'OK');
  234. }
  235. }
  236. }