Browse Source

add bjb probiders and merchant info update

ayHaru 4 years ago
parent
commit
ef0d998932

+ 48 - 0
helper/refill/bjb/RefillCallBack.php

@@ -0,0 +1,48 @@
+<?php
+
+
+namespace refill\bjb;
+
+require_once(BASE_HELPER_PATH . '/refill/bjb/config.php');
+
+
+use refill;
+
+class RefillCallBack implements refill\IRefillCallBack
+{
+    public function verify($params): bool
+    {
+        $sign = $this->sign($params);
+        if ($params['sgn'] == $sign) {
+            return true;
+        } else {
+            return false;
+        }
+    }
+
+    private function sign($params)
+    {
+        $content = $params['ord'] . $params['state'] . config::KEY;
+        return strtoupper(md5($content));
+    }
+
+    public function notify($params)
+    {
+        $status = intval($params['state']);
+        $order_sn = $params['ord'];
+        $order_info = Model('vr_order')->getOrderInfo(['order_sn' => $order_sn]);
+        if (empty($order_info)) {
+            return [false, false, false];
+        }
+        $order_id = $order_info['order_id'];
+        $data['ch_trade_no'] = $params['bz'];
+        Model('refill_order')->edit($order_id, $data);
+        if ($status === 1) {
+            return [$order_id, true, false];
+        } elseif ($status == 2) {
+            return [$order_id, false, true];
+        } else {
+            return [$order_id, false, false];
+        }
+    }
+}

+ 89 - 0
helper/refill/bjb/RefillPhone.php

@@ -0,0 +1,89 @@
+<?php
+namespace refill\bjb;
+
+require_once(BASE_HELPER_PATH . '/refill/bjb/config.php');
+
+use refill;
+use Log;
+
+class RefillPhone extends refill\IRefillPhone
+{
+    public function __construct($cfgs)
+    {
+        parent::__construct($cfgs);
+    }
+
+    private function req_params(int $phone, int $amount ,string $order_sn)
+    {
+        $params['usr'] = config::USR;
+        $params['mob'] = $phone;
+        $params['amt'] = $amount;
+        $params['ord'] = $order_sn;
+        $params['tim'] = date("YmdHis");
+        $params['yysid'] = 0;
+        $params['hmlx'] = 0;
+        return $params;
+    }
+
+    public function add($card_no, $card_type,$amount,$params)
+    {
+        $order_sn = $params['order_sn'];
+        $params = $this->req_params($card_no,$amount,$order_sn);
+        $sign = $this->sign($params);
+        $params['sgn'] = $sign;
+        $resp = http_request(config::PAY_PHONE_URL,$params,'GET');
+        if($resp === false) {
+            return [false,'系统错误'];
+        }
+        else
+        {
+            Log::record($resp,Log::DEBUG);
+            $resp = explode('|' , $resp);
+            if($resp[0] == 0) {
+                return [true,''];
+            }
+            else {
+                return [false,$resp[1]];
+            }
+        }
+    }
+    public function query($refill_info)
+    {
+        $params['order_number'] = $refill_info['ch_trade_no'];
+        $params['tradeNo'] = $refill_info['order_sn'];
+
+        $time = time();
+        $api_user_name = config::API_USER_NAME;
+        $sign = $this->sign($time);
+
+        $header = [
+            'Content-Type: application/json',
+            "API-USER-NAME: {$api_user_name}",
+            "API-NAME: OrderQuery",
+            "API-TIMESTAMP: {$time}",
+            "API-SIGNATURE: {$sign}",
+        ];
+        $resp = http_post_data(config::REQUEST_URL,json_encode($params),$header);
+        if($resp === false) {
+            return [false,'系统错误'];
+        }
+        else
+        {
+            Log::record($resp,Log::DEBUG);
+            $resp = json_decode($resp,true);
+            if($resp['ack'] == 'success') {
+                return [true,$resp['message']];
+            }
+            else {
+                return [false,$resp['message']];
+            }
+        }
+    }
+
+    private function sign($params)
+    {
+        $key = config::KEY;
+        $content = $params['usr'] . $params['ord'] . $params['mob'] . $params['amt'] . $params['tim'] . $key;
+        return strtoupper(md5($content));
+    }
+}

+ 13 - 0
helper/refill/bjb/config.php

@@ -0,0 +1,13 @@
+<?php
+
+
+namespace refill\bjb;
+
+
+class config
+{
+    const PAY_PHONE_URL = 'http://47.96.37.53:806/webInface/PayPhone.ashx';
+    const USR= '13699279618';
+    const KEY = 'd2dba2c0870b03a21ffd59df9c0cc774';
+    const API_IP = NET_IP;
+}

+ 67 - 1
mobile/control/merchant_info.php

@@ -25,6 +25,31 @@ class merchant_infoControl extends mbMerchantControl
         return self::outsuccess($merchant_info);
     }
 
+    public function homeOp()
+    {
+        $mchid = $this->mchid();
+        $model_merchant = Model('merchant');
+        $merchant_info = $model_merchant->getMerchantInfo(['mchid' => $mchid], 'mchid,admin_id,name');
+        $model_member = Model('member');
+        $member_info = $model_member->getMemberInfo(['member_id' => $merchant_info['admin_id']], 'available_predeposit');
+        $merchant_info['available_predeposit'] = $member_info['available_predeposit'];
+
+        $cond['mchid'] = $mchid;
+        $cond['inner_status'] = 0;
+        $beginToday = mktime(0, 0, 0, date('m'), date('d'), date('Y'));
+        $endToday = mktime(0, 0, 0, date('m'), date('d') + 1, date('Y')) - 1;
+        $cond['refill_order.order_time'] = ['between', [$beginToday, $endToday]];
+        $todayStatistics = $this->MerchantOrderStatistics($cond);
+        $beginThisWeek = mktime(0, 0, 0, date('m'), date('d') - date('w') + 1, date('y'));
+        $endThisWeek = time();
+        $cond['refill_order.order_time'] = ['between', [$beginThisWeek, $endThisWeek]];
+        $weeksStatistics = $this->WeeksMerchantOrderStatistics($cond);
+        $result['merchant_info'] = $merchant_info;
+        $result['todayStatistics'] = $todayStatistics;
+        $result['weeksStatistics'] = $weeksStatistics;
+        return self::outsuccess($result);
+    }
+
     public function addipOp()
     {
         $mchid = $this->mchid();
@@ -149,7 +174,7 @@ class merchant_infoControl extends mbMerchantControl
             if (isset($value['lg_add_time'])) {
                 $value['lg_add_time'] = date('Y-m-d H:i:s', $value['lg_add_time']);
             }
-            switch ($value['lg_type']){
+            switch ($value['lg_type']) {
                 case 'order_pay':
                     $value['lg_type_text'] = '下单减款';
                     break;
@@ -179,4 +204,45 @@ class merchant_infoControl extends mbMerchantControl
         }
         return $data;
     }
+
+    private function WeeksMerchantOrderStatistics($cond)
+    {
+        $data = [];
+        for ($i = 0; $i < 7; $i++) {
+            $begin = mktime(0, 0, 0, date('m'), date('d') - $i, date('Y'));
+            $end = mktime(0, 0, 0, date('m'), date('d') - $i + 1, date('Y')) - 1;
+            $cond['refill_order.order_time'] = ['between', [$begin, $end]];
+            $OrderStatistics = $this->MerchantOrderStatistics($cond);
+            $data[] = $OrderStatistics;
+        }
+        return $data;
+    }
+
+    private function MerchantOrderStatistics($cond)
+    {
+        $model_refill_order = Model('refill_order');
+        $orders = $model_refill_order->getMerchantOrderList($cond);
+        if (empty($orders)) {
+            $data['count'] = $data['successCount'] = $data['errorCount'] = $data['otherCount'] = $data['amountCount'] = 0;
+            return $data;
+        }
+        $count = count($orders);
+        $successCount = $errorCount = $otherCount = $amountCount = 0;
+        foreach ($orders as $order) {
+            if ($order['order_state'] == ORDER_STATE_CANCEL) {
+                $errorCount++;
+            } elseif ($order['order_state'] == ORDER_STATE_SUCCESS) {
+                $successCount++;
+                $amountCount += $order['mch_amount'];
+            } else {
+                $otherCount++;
+            }
+        }
+        $data['count'] = $count;
+        $data['successCount'] = $successCount;
+        $data['errorCount'] = $errorCount;
+        $data['otherCount'] = $otherCount;
+        $data['amountCount'] = $amountCount;
+        return $data;
+    }
 }