2022-09-09 16:42:55 +08:00
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* Created by PhpStorm.
|
|
|
|
|
* User: whwyy
|
|
|
|
|
* Date: 2018/3/26 0026
|
|
|
|
|
* Time: 10:23
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace wchat\common;
|
|
|
|
|
|
2023-11-14 00:45:54 +08:00
|
|
|
use Kiri\Client;
|
|
|
|
|
|
2022-09-09 16:42:55 +08:00
|
|
|
abstract class Multiprogramming implements Progaram
|
|
|
|
|
{
|
2023-11-14 00:45:54 +08:00
|
|
|
protected static ?Multiprogramming $instance = null;
|
2022-09-09 16:42:55 +08:00
|
|
|
|
2023-11-14 00:45:54 +08:00
|
|
|
protected int $errorCode = 0;
|
|
|
|
|
protected string $errorMsg = '';
|
2022-09-09 16:42:55 +08:00
|
|
|
|
|
|
|
|
|
2023-11-14 01:08:06 +08:00
|
|
|
protected string $host = 'api.weixin.qq.com';
|
|
|
|
|
|
|
|
|
|
|
2023-11-13 23:52:41 +08:00
|
|
|
/**
|
2023-11-14 00:06:57 +08:00
|
|
|
* @var AppConfig
|
2023-11-13 23:52:41 +08:00
|
|
|
*/
|
2023-11-14 00:06:57 +08:00
|
|
|
protected AppConfig $payConfig;
|
2023-11-13 23:52:41 +08:00
|
|
|
|
|
|
|
|
|
2023-11-14 00:45:54 +08:00
|
|
|
/**
|
|
|
|
|
* @param $message
|
|
|
|
|
* @param int $code
|
|
|
|
|
* @return Result
|
|
|
|
|
*/
|
|
|
|
|
protected function sendError($message, int $code = 500): Result
|
|
|
|
|
{
|
|
|
|
|
return new Result(code: $code, message: $message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $code
|
|
|
|
|
*/
|
|
|
|
|
public function setErrorCode($code)
|
|
|
|
|
{
|
|
|
|
|
$this->errorCode = $code;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param $message
|
|
|
|
|
*/
|
|
|
|
|
public function setErrorMessage($message)
|
|
|
|
|
{
|
|
|
|
|
$this->errorMsg = $message;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return int
|
|
|
|
|
*/
|
|
|
|
|
public function getErrorCode(): int
|
|
|
|
|
{
|
|
|
|
|
return $this->errorCode;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function getErrorMessage(): string
|
|
|
|
|
{
|
|
|
|
|
return $this->errorMsg;
|
|
|
|
|
}
|
|
|
|
|
|
2023-11-13 23:52:41 +08:00
|
|
|
/**
|
2023-11-14 00:06:57 +08:00
|
|
|
* @return AppConfig
|
2023-11-13 23:52:41 +08:00
|
|
|
*/
|
2023-11-14 00:06:57 +08:00
|
|
|
public function getPayConfig(): AppConfig
|
2023-11-13 23:52:41 +08:00
|
|
|
{
|
|
|
|
|
return $this->payConfig;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2023-11-14 00:06:57 +08:00
|
|
|
* @param AppConfig $payConfig
|
2023-11-13 23:52:41 +08:00
|
|
|
*/
|
2023-11-14 00:06:57 +08:00
|
|
|
public function setPayConfig(AppConfig $payConfig): void
|
2023-11-13 23:52:41 +08:00
|
|
|
{
|
|
|
|
|
$this->payConfig = $payConfig;
|
|
|
|
|
}
|
|
|
|
|
|
2022-09-09 16:42:55 +08:00
|
|
|
|
2023-11-14 00:45:54 +08:00
|
|
|
/**
|
|
|
|
|
* @param string $requestUrl
|
|
|
|
|
* @param mixed $body
|
2023-11-14 01:08:06 +08:00
|
|
|
* @param string $contentType
|
2023-11-14 00:45:54 +08:00
|
|
|
* @return Result
|
|
|
|
|
*/
|
2023-11-14 01:08:06 +08:00
|
|
|
protected function post(string $requestUrl, mixed $body, string $contentType = 'application/application'): Result
|
2023-11-14 00:45:54 +08:00
|
|
|
{
|
2023-11-14 01:08:06 +08:00
|
|
|
return $this->request('post', $requestUrl, $body, $contentType);
|
2023-11-14 00:45:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $requestUrl
|
|
|
|
|
* @param mixed $body
|
|
|
|
|
* @return Result
|
|
|
|
|
*/
|
2023-11-14 01:08:06 +08:00
|
|
|
protected function get(string $requestUrl, mixed $body, string $contentType = 'application/application'): Result
|
2023-11-14 00:45:54 +08:00
|
|
|
{
|
2023-11-14 01:08:06 +08:00
|
|
|
return $this->request('get', $requestUrl, $body, $contentType);
|
2023-11-14 00:45:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $requestUrl
|
|
|
|
|
* @param mixed $body
|
|
|
|
|
* @return Result
|
|
|
|
|
*/
|
|
|
|
|
protected function upload(string $requestUrl, mixed $body): Result
|
|
|
|
|
{
|
|
|
|
|
return $this->request('upload', $requestUrl, $body);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $method
|
|
|
|
|
* @param string $requestUrl
|
|
|
|
|
* @param $body
|
2023-11-14 01:08:06 +08:00
|
|
|
* @param string $contentType
|
2023-11-14 00:45:54 +08:00
|
|
|
* @return Result
|
|
|
|
|
*/
|
2023-11-14 01:08:06 +08:00
|
|
|
private function request(string $method, string $requestUrl, $body, string $contentType = 'application/application'): Result
|
2023-11-14 00:45:54 +08:00
|
|
|
{
|
2023-11-14 01:12:03 +08:00
|
|
|
$client = new Client($this->host, 443, true);
|
|
|
|
|
$proxyHost = $this->payConfig->getProxyHost();
|
|
|
|
|
$proxyPort = $this->payConfig->getProxyPort();
|
2023-11-14 00:45:54 +08:00
|
|
|
if (!empty($proxyHost) && $proxyPort > 0) {
|
|
|
|
|
$client->withProxyHost($proxyHost)->withProxyPort($proxyPort);
|
|
|
|
|
}
|
|
|
|
|
if ($method == 'post') {
|
2023-11-14 01:08:06 +08:00
|
|
|
$client->withHeader(['Content-Type' => $contentType]);
|
2023-11-14 00:45:54 +08:00
|
|
|
$client->post($requestUrl, $body);
|
|
|
|
|
} else if ($method == 'upload') {
|
|
|
|
|
$client->upload($requestUrl, $body);
|
|
|
|
|
} else {
|
2023-11-14 01:08:06 +08:00
|
|
|
$client->withHeader(['Content-Type' => $contentType]);
|
2023-11-14 00:45:54 +08:00
|
|
|
$client->get($requestUrl, $body);
|
|
|
|
|
}
|
|
|
|
|
$client->close();
|
|
|
|
|
if (!in_array($client->getStatusCode(), [101, 200, 201])) {
|
|
|
|
|
return new Result(code: 505, message: $client->getBody());
|
|
|
|
|
}
|
|
|
|
|
$body = json_decode($client->getBody(), true);
|
|
|
|
|
if (!is_null($body)) {
|
|
|
|
|
return new Result(code: $body['errcode'], message: $body['errmsg']);
|
|
|
|
|
} else {
|
|
|
|
|
return new Result(code: 0, data: $client->getBody());
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-09-09 16:42:55 +08:00
|
|
|
|
|
|
|
|
}
|