| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 | 
							- <?php
 
- namespace app\api\controller;
 
- use think\Db;
 
- use think\facade\Lang;
 
- class Membervrbuy extends MobileMember
 
- {
 
-     public function initialize()
 
-     {
 
-         parent::initialize(); 
 
-         Lang::load(base_path() . 'home/lang/' . config('lang.default_lang') . '/buy.lang.php');
 
-     }
 
-     
 
-     public function buy_step1()
 
-     {
 
-         if (!$this->member_info['is_buylimit']) {
 
-             ds_json_encode(10001, lang('cart_buy_noallow'));
 
-         }
 
-         if (config('ds_config.member_auth') && $this->member_info['member_auth_state'] != 3) {
 
-             ds_json_encode(10001, lang('cart_buy_noauth'));
 
-         }
 
-         $extra = [];
 
-         
 
-         $pintuan_id = intval(input('param.pintuan_id'));
 
-         if ($pintuan_id > 0) {
 
-             $extra['pintuan_id'] = $pintuan_id;
 
-             
 
-             $extra['pintuangroup_id'] = empty(input('param.pintuangroup_id')) ? 0 : intval(input('param.pintuangroup_id'));
 
-         }
 
-         $logic_buyvirtual = model('buyvirtual', 'logic');
 
-         $result           = $logic_buyvirtual->getBuyStep2Data(input('post.goods_id'), input('post.quantity'), $this->member_info['member_id'], $extra);
 
-         if (!$result['code']) {
 
-             ds_json_encode(10001, $result['msg']);
 
-         } else {
 
-             $result                              = $result['data'];
 
-             $member_info                         = [];
 
-             $member_info['member_paypwd']        = $result['member_info']['member_paypwd'] ? true : false;
 
-             $member_info['member_mobile']        = $result['member_info']['member_mobile'];
 
-             $member_info['available_predeposit'] = $result['member_info']['available_predeposit'];
 
-             $member_info['available_rc_balance'] = $result['member_info']['available_rc_balance'];
 
-             unset($result['member_info']);
 
-             $result['member_info'] = $member_info;
 
-             if (isset($result['store_voucher_list']) && is_array($result['store_voucher_list']) && count($result['store_voucher_list']) > 0) {
 
-                 current($result['store_voucher_list']);
 
-                 $result['goods_info']['store_voucher_info']                         = reset($result['store_voucher_list']);
 
-                 $result['goods_info']['store_voucher_info']['voucher_price']        = ds_price_format($result['goods_info']['store_voucher_info']['voucher_price']);
 
-                 $result['goods_info']['store_voucher_info']['voucher_enddate_text'] = date('Y年m月d日', $result['goods_info']['store_voucher_info']['voucher_enddate']);
 
-             } else {
 
-                 $result['goods_info']['store_voucher_info'] = [];
 
-             }
 
-             $result['goods_info']['store_voucher_list'] = isset($result['store_voucher_list']) ? array_values($result['store_voucher_list']) : [];
 
-             ds_json_encode(10000, '', $result);
 
-         }
 
-     }
 
-     
 
-     public function buy_step2()
 
-     {
 
-         $logic_buyvirtual     = model('buyvirtual', 'logic');
 
-         $input                = [];
 
-         $input['goods_id']    = input('post.goods_id');
 
-         $input['quantity']    = input('post.quantity');
 
-         $input['buyer_phone'] = input('post.buyer_phone');
 
-         $input['buyer_msg']   = input('post.buyer_msg');
 
-         
 
-         $input['password'] = !empty(input('post.password')) ? input('post.password') : '';
 
-         
 
-         $input['rcb_pay'] = empty(input('post.rcb_pay')) ? '0' : '1';
 
-         
 
-         $input['pd_pay'] = empty(input('post.pd_pay')) ? '0' : '1';
 
-         $input['pintuan_id']      = input('post.pintuan_id');
 
-         $input['pintuangroup_id'] = input('post.pintuangroup_id');
 
-         $input['order_from'] = 2;
 
-         $input['voucher'] = input('post.voucher');
 
-         $result = $logic_buyvirtual->buyStep3($input, $this->member_info['member_id']);
 
-         if (!$result) {
 
-             return false;
 
-         } else {
 
-             $orderId = $result['data']['order_id'];
 
-             $orderModel = model('vrorder', 'model');
 
-             $orderInfo                      = $orderModel->getVrorderInfo([['order_id', '=', $orderId]]);
 
-             $result['data']['order_amount'] = $orderInfo['order_amount'] - $orderInfo['deduction_amount'];
 
-             if (!$result['code']) {
 
-                 ds_json_encode(10001, $result['msg']);
 
-             } else {
 
-                 ds_json_encode(10000, '', $result['data']);
 
-             }
 
-         }
 
-     }
 
-     
 
-     public function check_password()
 
-     {
 
-         if (empty(input('post.password'))) {
 
-             ds_json_encode(10001, lang('param_error'));
 
-         }
 
-         $member_model = model('member');
 
-         $member_info = $member_model->getMemberInfoByID($this->member_info['member_id']);
 
-         if ($member_info['member_paypwd'] == md5(input('post.password'))) {
 
-             ds_json_encode(10000, '', 1);
 
-         } else {
 
-             ds_json_encode(10001, lang('password_mistake'));
 
-         }
 
-     }
 
-     
 
-     public function change_address()
 
-     {
 
-         $logic_buy = model('buy', 'logic');
 
-         $city_id   = 0;
 
-         if (empty(input('post.city_id'))) {
 
-             $city_id = input('post.area_id');
 
-         }
 
-         $data = $logic_buy->changeAddr(input('post.freight_hash'), $city_id, input('post.area_id'), $this->member_info['member_id']);
 
-         if (!empty($data) && $data['state'] == 'success') {
 
-             ds_json_encode(10000, '', $data);
 
-         } else {
 
-             ds_json_encode(10001, lang('param_error'));
 
-         }
 
-     }
 
-     
 
-     public function pay()
 
-     {
 
-         $pay_sn      = input('post.pay_sn');
 
-         $condition   = [];
 
-         $condition[] = ['order_sn', '=', $pay_sn];
 
-         $order_info  = model('vrorder')->getVrorderInfo($condition);
 
-         $condition    = [];
 
-         $condition[]  = ['payment_platform', '=', 'h5'];
 
-         $payment_list = model('payment')->getPaymentOpenList($condition);
 
-         $pay_info['pay_amount']             = $order_info['order_amount'];
 
-         $pay_info['member_available_pd']    = $this->member_info['available_predeposit'];
 
-         $pay_info['member_available_rcb']   = $this->member_info['available_rc_balance'];
 
-         $pay_info['member_available_point'] = $this->member_info['point'];
 
-         $pay_info['member_paypwd'] = true;
 
-         if (empty($this->member_info['member_paypwd'])) {
 
-             $pay_info['member_paypwd'] = false;
 
-         }
 
-         $pay_info['pay_sn']       = $order_info['order_sn'];
 
-         $pay_info['payed_amount'] = $order_info['pd_amount'] + $order_info['rcb_amount'] + $order_info['deduction_amount'];
 
-         if ($pay_info['payed_amount'] > '0.00') {
 
-             $pay_info['pay_amount'] = round($pay_info['pay_amount'] - $pay_info['payed_amount'],2);
 
-         }
 
-         
 
-         if (empty($pay_info['pay_amount'])) {
 
-             ds_json_encode(12001, lang('pay_repeat'));
 
-         }
 
-         $pay_in["pay_info"]                 = $pay_info;
 
-         $pay_in["pay_info"]["payment_list"] = $payment_list;
 
-         ds_json_encode(10000, '', $pay_in);
 
-     }
 
-     
 
-     public function check_pd_pwd()
 
-     {
 
-         if ($this->member_info['member_paypwd'] != md5(input('post.password'))) {
 
-             ds_json_encode(10001, lang('payment_password_error'));
 
-         } else {
 
-             ds_json_encode(10000, '', 'OK');
 
-         }
 
-     }
 
- }
 
 
  |