diff --git a/Application/Base/Tool/GameResource/YhxxjClient.class.php b/Application/Base/Tool/GameResource/YhxxjClient.class.php new file mode 100644 index 000000000..d00032c9e --- /dev/null +++ b/Application/Base/Tool/GameResource/YhxxjClient.class.php @@ -0,0 +1,196 @@ + ['uri' => '/apip/payWM450S00/testingOrder', 'method' => 'post'], + ]; + + public function __construct($game = null) + { + $this->client = new Client([ + 'base_uri' => $this->baseUrl, + 'timeout' => 10.0, + ]); + } + + public function api($name, array $params = []) + { + $this->currentName = $name; + $api = $this->apis[$name] ?? null; + if (is_null($api)) { + throw new \Exception('接口不存在'); + } + $params[static::SIGN_NAME] = $this->sign($name, $params); + + // 发放道具接口特殊处理 + if ($name == 'send-props') { + $params = ['data' => json_encode($params)]; + } + try { + return $this->request($api, $params); + } catch (\Exception $e) { + $env = C('APP_ENV', null, 'prod'); + Log::error($this->logTag . $e->getMessage()); + return ['code' => 3, 'msg' => '接口请求错误。' . ($env == 'prod' ? '' : $e->getMessage()) , 'data' => []]; + } + } + + public function request($api, $params) + { + if ($api['method'] == 'get') { + return $this->get($api['uri'], $params); + } else { + return $this->post($api['uri'], $params); + } + } + + protected function post($uri, array $params = []) + { + $response = $this->client->post($uri, [ + 'verify' => false, + 'form_params' => $params, + ]); + $result = (string)$response->getBody(); + Log::info($this->logTag . $uri . ' -- '. json_encode($params) . ' -- '. $result); + if ($this->currentName == 'send-testing') { + return $this->prepareResult($result); + } + return json_decode($result, true); + } + + protected function get($uri, array $params = []) + { + $response = $this->client->get($uri, [ + 'verify' => false, + 'query' => $params, + ]); + $result = (string)$response->getBody(); + Log::info($this->logTag . $uri . ' -- '. json_encode($params) . ' -- '. $result); + if ($this->currentName == 'send-testing') { + return $this->prepareResult($result); + } + return json_decode($result, true); + } + + protected function prepareResult($result) + { + if ($result == 'SUCCESS') { + return [ + 'code' => 0, + 'msg' => $result, + ]; + } else { + return [ + 'code' => 1, + 'msg' => $result, + ]; + } + } + + protected function sign($name, $params) + { + return md5( + $params['appId'] . + $params['orderNum'] . + $params['userId'] . + $params['moneyYuan'] . + $params['serviceId'] . + $params['roleId'] . + $params['time'] . + static::SIGN_KEY + ); + } + + protected function generateOrderNumber($order, $index = 0) + { + $length = 8 - strlen(strval($order['id'])); + $indexLength = 3 - strlen(strval($index)); + return date('Ymd') . str_repeat('0', $length) . $order['id'] . str_repeat('0', $indexLength) . $index; + } + + protected function getCommonResult($result, $successCode = 0) + { + if ($result['code'] == $successCode) { + return [ + 'status' => true, + 'message' => $result['msg'], + 'result' => $result + ]; + } else { + return [ + 'status' => false, + 'message' => $result['msg'], + 'result' => $result + ]; + } + } + + public function apply($order, $role) + { + $data = [ + 'appId' => static::APP_ID, + 'userId' => $role['user_id'], + 'serviceId' => $role['server_id'], + 'roleId' => $role['role_id'], + 'moneyYuan' => $order['ref_amount'], + 'orderNum' => $order['order_no'], + 'time' => time(), + ]; + + $result = $this->api('send-testing', $data); + return $this->getCommonResult($result); + } + + public function getResourceTypes($deviceType) + { + if ($deviceType == 'andriod') { + return [['id' => 1, 'name' => '通用', 'device_type' => 'andriod']]; + } elseif ($deviceType == 'ios') { + return [['id' => 2, 'name' => '通用', 'device_type' => 'ios']]; + } + } + + public function getResources($typeId, $deviceType) + { + return [ + 1 => ['ref_id' => 1, 'name' => '60元宝', 'amount' => 6], + 2 => ['ref_id' => 2, 'name' => '300元宝', 'amount' => 30], + 3 => ['ref_id' => 3, 'name' => '980元宝', 'amount' => 98], + 4 => ['ref_id' => 4, 'name' => '1280元宝', 'amount' => 128], + 5 => ['ref_id' => 5, 'name' => '1980元宝', 'amount' => 198], + 6 => ['ref_id' => 6, 'name' => '3280元宝', 'amount' => 328], + 7 => ['ref_id' => 7, 'name' => '6480元宝', 'amount' => 648], + 8 => ['ref_id' => 8, 'name' => '10000元宝', 'amount' => 1000], + 9 => ['ref_id' => 9, 'name' => '20000元宝', 'amount' => 2000], + 10 => ['ref_id' => 10, 'name' => '30000元宝', 'amount' => 3000], + 11 => ['ref_id' => 11, 'name' => '50000元宝', 'amount' => 5000], + 12 => ['ref_id' => 12, 'name' => '100000元宝', 'amount' => 10000], + 13 => ['ref_id' => 13, 'name' => '200000元宝', 'amount' => 20000], + ]; + } +} \ No newline at end of file