This commit is contained in:
2021-09-29 15:41:13 +08:00
parent be4cb23bb9
commit 42abe70f99
9 changed files with 189 additions and 615 deletions
+22 -29
View File
@@ -7,11 +7,14 @@
*/
declare(strict_types=1);
namespace Http\Client;
namespace Http\Handler\Client;
use Exception;
use Http\Message\Response;
use Http\Message\Stream;
use JetBrains\PhpStorm\Pure;
use Swoole\Coroutine\Http\Client as SClient;
use Psr\Http\Message\ResponseInterface;
use Swoole\Coroutine\Http\Client as SwowClient;
/**
* Class Client
@@ -24,12 +27,12 @@ class Client extends ClientAbstracts
* @param string $method
* @param $path
* @param array $params
* @return array|string|Result
* @return ResponseInterface
* @throws Exception
*/
public function request(string $method, $path, array $params = []): array|string|Result
public function request(string $method, $path, array $params = []): ResponseInterface
{
return $this->setMethod($method)
return $this->withMethod($method)
->coroutine(
$this->matchHost($path),
$this->paramEncode($params)
@@ -40,33 +43,23 @@ class Client extends ClientAbstracts
/**
* @param $url
* @param array|string $data
* @return array|string|Result
* @return ResponseInterface
* @throws Exception 使用swoole协程方式请求
*/
private function coroutine($url, array|string $data = []): array|string|Result
private function coroutine($url, array|string $data = []): ResponseInterface
{
try {
$client = $this->generate_client($data, ...$url);
$this->setData('');
if ($client->statusCode < 0) {
throw new Exception($client->errMsg);
}
$body = $this->resolve($client->getHeaders(), $client->body);
if (in_array($client->getStatusCode(), [200, 201])) {
return $this->structure($body, $data, $client->getHeaders());
}
if (is_string($body)) {
$message = 'Request error code ' . $client->getStatusCode();
} else {
$message = $this->searchMessageByData($body);
}
return $this->fail($client->getStatusCode(), $message, $body, $client->getHeaders());
return (new Response())->withStatus($client->getStatusCode())
->withHeaders($client->getHeaders())
->withBody(new Stream($client->getBody()));
} catch (\Throwable $exception) {
$this->addError($exception, 'rpc');
return $this->fail(500, $exception->getMessage(), [
'file' => $exception->getFile(),
'line' => $exception->getLine()
], []);
return (new Response())->withStatus(-1)->withHeaders([])
->withBody(new Stream(jTraceEx($exception)));
}
}
@@ -76,18 +69,18 @@ class Client extends ClientAbstracts
* @param $host
* @param $isHttps
* @param $path
* @return SClient
* @return SwowClient
*/
private function generate_client($data, $host, $isHttps, $path): SClient
private function generate_client($data, $host, $isHttps, $path): SwowClient
{
if ($isHttps || $this->isSSL()) {
$client = new SClient($host, 443, true);
$client = new SwowClient($host, 443, true);
} else {
$client = new SClient($host, $this->getPort(), false);
$client = new SwowClient($host, $this->getPort(), false);
}
$client->set($this->settings());
if (!empty($this->getAgent())) {
$this->addHeader('User-Agent', $this->getAgent());
$this->withAddedHeader('User-Agent', $this->getAgent());
}
$client->setHeaders($this->getHeader());
$client->setMethod(strtoupper($this->getMethod()));
@@ -98,12 +91,12 @@ class Client extends ClientAbstracts
/**
* @param SClient $client
* @param SwowClient $client
* @param $path
* @param $data
* @return string
*/
private function setParams(SClient $client, $path, $data): string
private function setParams(SwowClient $client, $path, $data): string
{
if ($this->isGet()) {
if (!empty($data)) $path .= '?' . $data;
+84 -224
View File
@@ -1,13 +1,17 @@
<?php
namespace Http\Client;
namespace Http\Handler\Client;
use Closure;
use Http\Handler\Context;
use Http\Message\Stream;
use JetBrains\PhpStorm\Pure;
use Kiri\Abstracts\Component;
use Kiri\Core\Help;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\StreamInterface;
use Swoole\Coroutine\System;
defined('SPLIT_URL') or define('SPLIT_URL', '/(http[s]?:\/\/)?(([\w\-_]+\.)+\w+(:\d+)?)((\/[a-zA-Z0-9\-]+)+[\/]?(\?[a-zA-Z]+=.*)?)?/');
@@ -15,7 +19,7 @@ defined('SPLIT_URL') or define('SPLIT_URL', '/(http[s]?:\/\/)?(([\w\-_]+\.)+\w+(
/**
* Class ClientAbstracts
* @package Http\Client
* @package Http\Handler\Client
*/
abstract class ClientAbstracts extends Component implements IClient
{
@@ -34,23 +38,18 @@ abstract class ClientAbstracts extends Component implements IClient
private int $timeout = 0;
private ?Closure $callback = null;
private string $method = 'get';
private bool $isSSL = false;
private string $agent = '';
private string $errorCodeField = '';
private string $errorMsgField = '';
private bool $use_swoole = false;
private string $ssl_cert_file = '';
private string $ssl_key_file = '';
private string $ca = '';
private int $port = 80;
/** @var string $_message 错误信息 */
private string $_message = '';
private string $_data = '';
private StreamInterface $_data;
private int $connect_timeout = 1;
@@ -58,24 +57,18 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @return static
*/
#[Pure] public static function NewRequest(): static
public static function NewRequest(): static
{
return new static();
}
protected function cleanData(): void
{
$this->_data = '';
}
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function post(string $path, array $params = []): array|int|string|Result
public function post(string $path, array $params = []): ResponseInterface
{
return $this->request(self::POST, $path, $params);
}
@@ -84,9 +77,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function put(string $path, array $params = []): array|int|string|Result
public function put(string $path, array $params = []): ResponseInterface
{
return $this->request(self::PUT, $path, $params);
}
@@ -94,19 +87,21 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $contentType
* @return ClientAbstracts
*/
public function setContentType(string $contentType): void
public function withContentType(string $contentType): static
{
$this->header['Content-Type'] = $contentType;
return $this;
}
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function head(string $path, array $params = []): array|int|string|Result
public function head(string $path, array $params = []): ResponseInterface
{
return $this->request(self::HEAD, $path, $params);
}
@@ -115,9 +110,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function get(string $path, array $params = []): array|int|string|Result
public function get(string $path, array $params = []): ResponseInterface
{
return $this->request(self::GET, $path, $params);
}
@@ -125,9 +120,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function option(string $path, array $params = []): array|int|string|Result
public function option(string $path, array $params = []): ResponseInterface
{
return $this->request(self::OPTIONS, $path, $params);
}
@@ -135,9 +130,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function delete(string $path, array $params = []): array|int|string|Result
public function delete(string $path, array $params = []): ResponseInterface
{
return $this->request(self::DELETE, $path, $params);
}
@@ -145,9 +140,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function options(string $path, array $params = []): array|int|string|Result
public function options(string $path, array $params = []): ResponseInterface
{
return $this->request(self::OPTIONS, $path, $params);
@@ -156,9 +151,9 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $path
* @param array $params
* @return array|int|string|Result
* @return ResponseInterface
*/
public function upload(string $path, array $params = []): array|int|string|Result
public function upload(string $path, array $params = []): ResponseInterface
{
return $this->request(self::UPLOAD, $path, $params);
}
@@ -175,7 +170,7 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @return int
*/
protected function getHostPort(): int
#[Pure] protected function getHostPort(): int
{
if (!empty($this->getPort())) {
return $this->getPort();
@@ -188,14 +183,15 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $host
* @return ClientAbstracts
*/
public function setHost(string $host): void
public function withHost(string $host): static
{
$this->host = $host;
if ($this->use_swoole) {
if (Context::inCoroutine()) {
$this->host = System::gethostbyname($host);
}
$this->addHeader('Host', $host);
return $this->withAddedHeader('Host', $host);
}
/**
@@ -208,35 +204,39 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param array $header
* @return ClientAbstracts
*/
public function setHeader(array $header): void
public function withHeader(array $header): static
{
$this->header = $header;
return $this;
}
/**
* @param array $header
* @return array
* @return ClientAbstracts
*/
public function setHeaders(array $header): array
public function withHeaders(array $header): static
{
if (empty($header)) {
return [];
return $this;
}
foreach ($header as $key => $val) {
$this->header[$key] = $val;
}
return $this->header;
return $this;
}
/**
* @param $key
* @param $value
* @return ClientAbstracts
*/
public function addHeader($key, $value): void
public function withAddedHeader($key, $value): static
{
$this->header[$key] = $value;
return $this;
}
/**
@@ -249,26 +249,22 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param int $value
* @return ClientAbstracts
*/
public function setTimeout(int $value): void
public function withTimeout(int $value): static
{
$this->timeout = $value;
return $this;
}
/**
* @return Closure|null
*/
public function getCallback(): ?Closure
{
return $this->callback;
}
/**
* @param Closure|null $value
* @return ClientAbstracts
*/
public function setCallback(?Closure $value): void
public function withCallback(?Closure $value): static
{
$this->callback = $value;
return $this;
}
/**
@@ -283,7 +279,7 @@ abstract class ClientAbstracts extends Component implements IClient
* @param string $value
* @return static
*/
public function setMethod(string $value): static
public function withMethod(string $value): static
{
$this->method = $value;
return $this;
@@ -299,10 +295,12 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param bool $isSSL
* @return ClientAbstracts
*/
public function setIsSSL(bool $isSSL): void
public function withIsSSL(bool $isSSL): static
{
$this->isSSL = $isSSL;
return $this;
}
/**
@@ -315,59 +313,14 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $agent
* @return ClientAbstracts
*/
public function setAgent(string $agent): void
public function withAgent(string $agent): static
{
$this->agent = $agent;
return $this;
}
/**
* @return string
*/
public function getErrorCodeField(): string
{
return $this->errorCodeField;
}
/**
* @param string $errorCodeField
*/
public function setErrorCodeField(string $errorCodeField): void
{
$this->errorCodeField = $errorCodeField;
}
/**
* @return string
*/
public function getErrorMsgField(): string
{
return $this->errorMsgField;
}
/**
* @param string $errorMsgField
*/
public function setErrorMsgField(string $errorMsgField): void
{
$this->errorMsgField = $errorMsgField;
}
/**
* @return bool
*/
public function isUseSwoole(): bool
{
return $this->use_swoole;
}
/**
* @param bool $use_swoole
*/
public function setUseSwoole(bool $use_swoole): void
{
$this->use_swoole = $use_swoole;
}
/**
* @return string
@@ -379,10 +332,12 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $ssl_cert_file
* @return ClientAbstracts
*/
public function setSslCertFile(string $ssl_cert_file): void
public function withSslCertFile(string $ssl_cert_file): static
{
$this->ssl_cert_file = $ssl_cert_file;
return $this;
}
/**
@@ -395,10 +350,12 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $ssl_key_file
* @return ClientAbstracts
*/
public function setSslKeyFile(string $ssl_key_file): void
public function withSslKeyFile(string $ssl_key_file): static
{
$this->ssl_key_file = $ssl_key_file;
return $this;
}
/**
@@ -411,16 +368,18 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param string $ssl_key_file
* @return static
*/
public function setCa(string $ssl_key_file): void
public function withCa(string $ssl_key_file): static
{
$this->ca = $ssl_key_file;
return $this;
}
/**
* @return int
*/
public function getPort(): int
#[Pure] public function getPort(): int
{
if ($this->isSSL()) {
return 443;
@@ -433,42 +392,34 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param int $port
* @return ClientAbstracts
*/
public function setPort(int $port): void
public function withPort(int $port): static
{
$this->port = $port;
return $this;
}
/**
* @return string
*/
public function getMessage(): string
{
return $this->_message;
}
/**
* @param string $message
* @return StreamInterface
*/
public function setMessage(string $message): void
{
$this->_message = $message;
}
/**
* @return string
*/
public function getData(): string
public function getData(): StreamInterface
{
return $this->_data;
}
/**
* @param string $data
* @param string|StreamInterface $data
* @return ClientAbstracts
*/
public function setData(string $data): void
public function withBody(string|StreamInterface $data): static
{
if (is_string($data)) {
$data = new Stream($data);
}
$this->_data = $data;
return $this;
}
/**
@@ -482,7 +433,7 @@ abstract class ClientAbstracts extends Component implements IClient
/**
* @param int $connect_timeout
*/
public function setConnectTimeout(int $connect_timeout): void
public function withConnectTimeout(int $connect_timeout): void
{
$this->connect_timeout = $connect_timeout;
}
@@ -517,7 +468,7 @@ abstract class ClientAbstracts extends Component implements IClient
* @param $url
* @return bool
*/
#[Pure] protected function isHttp($url): bool
protected function isHttp($url): bool
{
return str_starts_with($url, 'http://');
}
@@ -526,7 +477,7 @@ abstract class ClientAbstracts extends Component implements IClient
* @param $url
* @return bool
*/
#[Pure] protected function isHttps($url): bool
protected function isHttps($url): bool
{
return str_starts_with($url, 'https://');
}
@@ -594,78 +545,6 @@ abstract class ClientAbstracts extends Component implements IClient
}
/**
* @param $body
* @param $_data
* @param array $header
* @param int $statusCode
* @return mixed 构建返回体
* 构建返回体
*/
protected function structure($body, $_data, $header = [], $statusCode = 200): mixed
{
if ($this->callback instanceof Closure) {
$result = call_user_func($this->callback, $body, $_data, $header);
} else {
$result = $this->parseResult($body, $header, $statusCode);
}
return $result;
}
/**
* @param $body
* @param $header
* @param $statusCode
* @return Result
*/
private function parseResult($body, $header, $statusCode): Result
{
if (is_string($body)) {
$result['code'] = 0;
$result['message'] = '';
} else {
$result['code'] = $body[$this->errorCodeField] ?? 0;
$result['message'] = $this->searchMessageByData($body);
}
$result['data'] = $body;
$result['header'] = $header;
$result['httpStatus'] = $statusCode;
return new Result($result);
}
/**
* @param $body
* @return mixed
*/
protected function searchMessageByData($body): mixed
{
$parent = [];
if (empty($this->errorMsgField)) {
return 'system success.';
}
$explode = explode('.', $this->errorMsgField);
if (!isset($body[$explode[0]])) {
return 'system success.';
}
foreach ($explode as $item) {
if (empty($item)) {
continue;
}
if (empty($parent)) {
$parent = $body[$item];
continue;
}
if (is_string($parent) || !isset($parent[$item])) {
break;
}
$parent = $parent[$item];
}
return !empty($parent) ? $parent : 'system success.';
}
/**
* @return bool
* check isPost Request
@@ -755,7 +634,7 @@ abstract class ClientAbstracts extends Component implements IClient
$host = $this->getHost();
if ($string == '/') {
$string = '';
} else if (strpos($string, '/') !== 0) {
} else if (!str_starts_with($string, '/')) {
$string = '/' . $string;
}
return [$host, $this->isSSL(), $string];
@@ -767,7 +646,7 @@ abstract class ClientAbstracts extends Component implements IClient
* @param $params
* @return string
*/
#[Pure] protected function joinGetParams($path, $params): string
protected function joinGetParams($path, $params): string
{
if (empty($params)) {
return $path;
@@ -778,29 +657,10 @@ abstract class ClientAbstracts extends Component implements IClient
if (str_contains($path, '?')) {
[$path, $getParams] = explode('?', $path);
}
if (!isset($getParams) || empty($getParams)) {
if (empty($getParams)) {
return $path . '?' . $params;
}
return $path . '?' . $params . '&' . $getParams;
}
/**
* @param $code
* @param $message
* @param $data
* @param $header
* @return Result
*/
protected function fail($code, $message, $data = [], $header = []): Result
{
return new Result([
'code' => $code,
'message' => $message,
'data' => $data,
'header' => $header,
]);
}
}
+18 -43
View File
@@ -1,17 +1,20 @@
<?php
declare(strict_types=1);
namespace Http\Client;
namespace Http\Handler\Client;
use CurlHandle;
use Exception;
use Http\Message\Response;
use Http\Message\Stream;
use JetBrains\PhpStorm\Pure;
use Psr\Http\Message\ResponseInterface;
/**
* Class Curl
* @package Http\Client
* @package Http\Handler\Client
*/
class Curl extends ClientAbstracts
{
@@ -20,10 +23,10 @@ class Curl extends ClientAbstracts
* @param $method
* @param $path
* @param array $params
* @return Result|array|string
* @return ResponseInterface
* @throws Exception
*/
public function request($method, $path, array $params = []): Result|array|string
public function request($method, $path, array $params = []): ResponseInterface
{
if ($method == self::GET) {
$path = $this->joinGetParams($path, $params);
@@ -131,67 +134,39 @@ class Curl extends ClientAbstracts
/**
* @param $curl
* @return Result|bool|array|string
* @return ResponseInterface
* @throws Exception
*/
private function execute($curl): Result|bool|array|string
private function execute($curl): ResponseInterface
{
$output = curl_exec($curl);
curl_close($curl);
if ($output === false) {
$response = $this->fail(400, curl_error($curl));
$response = (new Response())->withStatus(400)->withBody(new Stream(curl_error($curl)));
} else {
$response = $this->parseResponse($curl, $output);
$response = $this->explode($output);
}
$this->cleanData();
return $response;
}
/**
* @param $curl
* @param $output
* @param array $params
* @return mixed
* @return ResponseInterface
* @throws Exception
*/
private function parseResponse($curl, $output, array $params = []): mixed
private function explode($output): ResponseInterface
{
curl_close($curl);
if ($output === FALSE) {
return $this->fail(500, $output);
}
[$header, $body, $status] = $this->explode($output);
if ($status != 200 && $status != 201) {
$data = $this->fail($status, $body, [], $header);
} else {
$data = $this->structure($body, $params, $header);
}
return $data;
}
/**
* @param $output
* @return array
* @throws Exception
*/
private function explode($output): array
{
if (empty($output) || !str_contains($output, "\r\n\r\n")) {
throw new Exception('Get data null.');
}
[$header, $body] = explode("\r\n\r\n", $output, 2);
if ($header == 'HTTP/1.1 100 Continue') {
[$header, $body] = explode("\r\n\r\n", $body, 2);
}
$header = explode("\r\n", $header);
$status = explode(' ', array_shift($header));
$status = (int)explode(' ', trim($header[0]))[1];
$header = $this->headerFormat($header);
return [$header, $this->resolve($header, $body), $status];
return (new Response())->withStatus(intval($status[1]))->withHeaders($this->headerFormat($header))
->withBody(new Stream($body));
}
/**
@@ -204,7 +179,7 @@ class Curl extends ClientAbstracts
foreach ($headers as $val) {
$trim = explode(': ', trim($val));
$_tmp[strtolower($trim[0])] = $trim[1] ?? '';
$_tmp[strtolower($trim[0])] = [$trim[1] ?? ''];
}
return $_tmp;
}
-64
View File
@@ -1,64 +0,0 @@
<?php
namespace Http\Client;
use JetBrains\PhpStorm\Pure;
use Kiri\Abstracts\Component;
use ReflectionException;
use Swoole\Coroutine;
/**
* Class ClientDriver
* @package Http\Client
* @mixin Client
*/
class HttpClient extends Component
{
/**
* @return IClient
*/
public static function NewRequest(): IClient
{
if (Coroutine::getCid() > -1) {
return Client::NewRequest();
}
return Curl::NewRequest();
}
/**
* @return Curl
*/
#[Pure] public function getCurl(): Curl
{
return Curl::NewRequest();
}
/**
* @return Client
*/
#[Pure] public function getCoroutine(): Client
{
return Client::NewRequest();
}
/**
* @param string $name
* @param array $arguments
* @return void
*/
public function __call(string $name, array $arguments)
{
if (!method_exists($this, $name)) {
return static::NewRequest()->{$name}(...$arguments);
}
return $this->{$name}(...$arguments);
}
}
+1 -1
View File
@@ -1,7 +1,7 @@
<?php
declare(strict_types=1);
namespace Http\Client;
namespace Http\Handler\Client;
use Exception;
+51 -77
View File
@@ -1,10 +1,12 @@
<?php
namespace Http\Client;
namespace Http\Handler\Client;
use Closure;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\StreamInterface;
interface IClient
{
@@ -13,205 +15,177 @@ interface IClient
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function get(string $path, array $params = []): Result|int|array|string;
public function get(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function post(string $path, array $params = []): Result|int|array|string;
public function post(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function delete(string $path, array $params = []): Result|int|array|string;
public function delete(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function options(string $path, array $params = []): Result|int|array|string;
public function options(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function upload(string $path, array $params = []): Result|int|array|string;
public function upload(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function put(string $path, array $params = []): Result|int|array|string;
public function put(string $path, array $params = []): ResponseInterface;
/**
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function head(string $path, array $params = []): Result|int|array|string;
public function head(string $path, array $params = []): ResponseInterface;
/**
* @param string $method
* @param string $path
* @param array $params
* @return array|Result|int|string
* @return ResponseInterface
*/
public function request(string $method, string $path, array $params = []): Result|array|int|string;
public function request(string $method, string $path, array $params = []): ResponseInterface;
/**
* @param string $host
* @return mixed
* @return static
*/
public function setHost(string $host): void;
public function withHost(string $host): static;
/**
* @param array $header
* @return mixed
* @return static
*/
public function setHeader(array $header): void;
public function withHeader(array $header): static;
/**
* @param array $header
* @return mixed
* @return static
*/
public function setHeaders(array $header): array;
public function withHeaders(array $header): static;
/**
* @param string $key
* @param string $value
* @return mixed
* @return static
*/
public function addHeader(string $key, string $value): void;
public function withAddedHeader(string $key, string $value): static;
/**
* @param int $value
* @return mixed
* @return static
*/
public function setTimeout(int $value): void;
public function withTimeout(int $value): static;
/**
* @param Closure|null $value
* @return mixed
* @return static
*/
public function setCallback(?Closure $value): void;
public function withCallback(?Closure $value): static;
/**
* @param string $value
* @return static
*/
public function setMethod(string $value): static;
public function withMethod(string $value): static;
/**
* @param bool $isSSL
* @return mixed
* @return static
*/
public function setIsSSL(bool $isSSL): void;
public function withIsSSL(bool $isSSL): static;
/**
* @param string $agent
* @return mixed
* @return static
*/
public function setAgent(string $agent): void;
/**
* @param string $errorCodeField
* @return mixed
*/
public function setErrorCodeField(string $errorCodeField): void;
/**
* @param string $errorMsgField
* @return mixed
*/
public function setErrorMsgField(string $errorMsgField): void;
/**
* @param bool $use_swoole
* @return mixed
*/
public function setUseSwoole(bool $use_swoole): void;
public function withAgent(string $agent): static;
/**
* @param string $ssl_cert_file
* @return mixed
* @return static
*/
public function setSslCertFile(string $ssl_cert_file): void;
public function withSslCertFile(string $ssl_cert_file): static;
/**
* @param string $ssl_key_file
* @return mixed
* @return static
*/
public function setSslKeyFile(string $ssl_key_file): void;
public function withSslKeyFile(string $ssl_key_file): static;
/**
* @param string $ssl_key_file
* @return mixed
* @return static
*/
public function setCa(string $ssl_key_file): void;
public function withCa(string $ssl_key_file): static;
/**
* @param int $port
* @return mixed
* @return static
*/
public function setPort(int $port): void;
public function withPort(int $port): static;
/**
* @param string $message
* @return mixed
* @param string|StreamInterface $data
* @return static
*/
public function setMessage(string $message): void;
/**
* @param string $data
* @return mixed
*/
public function setData(string $data): void;
public function withBody(string|StreamInterface $data): static;
/**
* @param int $connect_timeout
* @return mixed
* @return static
*/
public function setConnectTimeout(int $connect_timeout): void;
public function withConnectTimeout(int $connect_timeout): static;
/**
* @param string $contentType
* @return mixed
* @return static
*/
public function setContentType(string $contentType): void;
public function withContentType(string $contentType): static;
}
-175
View File
@@ -1,175 +0,0 @@
<?php
declare(strict_types=1);
namespace Http\Client;
use Exception;
use JetBrains\PhpStorm\Pure;
/**
* Class Result
*
* @package app\components
*
* @property $code
* @property $message
* @property $count
* @property $data
*/
class Result
{
public int|string $code;
public string $message;
public int $count = 0;
public mixed $data;
public ?array $header;
public int $httpStatus = 200;
public int $startTime = 0;
public int $requestTime = 0;
public float $runTime = 0;
/**
* Result constructor.
* @param array $data
*/
public function __construct(array $data)
{
$this->setAssignment($data);
}
/**
* @param $data
* @return $this
*/
public function setAssignment($data): static
{
foreach ($data as $key => $val) {
if (!property_exists($this, $key)) {
continue;
}
$this->$key = $val;
}
return $this;
}
/**
* @param $name
* @return mixed
*/
public function __get($name): mixed
{
return $this->$name;
}
/**
* @param $name
* @param $value
*/
public function __set($name, $value)
{
$this->$name = $value;
}
/**
* @return array
*/
public function getHeaders(): array
{
$_tmp = [];
if (!is_array($this->header)) {
return $_tmp;
}
foreach ($this->header as $key => $val) {
if ($key == 0) {
$_tmp['pro'] = $val;
} else {
if (str_contains($val, ': ')) {
$trim = explode(': ', $val);
$_tmp[strtolower($trim[0])] = $trim[1];
} else {
$_tmp[$key] = $val;
}
}
}
return $_tmp;
}
/**
* @return array
*/
public function getTime(): array
{
return [
'startTime' => $this->startTime,
'requestTime' => $this->requestTime,
'runTime' => $this->runTime,
];
}
/**
* @param $key
* @param $data
* @return $this
* @throws Exception
*/
public function setAttr($key, $data): static
{
if (!property_exists($this, $key)) {
throw new Exception('未查找到相应对象属性');
}
$this->$key = $data;
return $this;
}
/**
* @param int $status
* @return bool
*/
#[Pure] public function isResultsOK(int $status = 0): bool
{
if (!$this->httpIsOk()) {
return false;
}
return $this->code === $status;
}
/**
* @return bool
*/
public function httpIsOk(): bool
{
return in_array($this->httpStatus, [100, 101, 200, 201, 202, 203, 204, 205, 206]);
}
/**
* @return mixed
*/
public function getBody(): mixed
{
return $this->data;
}
/**
* @return string
*/
public function getMessage(): string
{
return $this->message;
}
/**
* @return string|int
*/
public function getCode(): string|int
{
return $this->code;
}
}
+11
View File
@@ -194,6 +194,17 @@ trait Message
}
/**
* @param array $headers
* @return static
*/
public function withHeaders(array $headers): static
{
$this->headers = $headers;
return $this;
}
/**
* @param $name
* @param $value
+2 -2
View File
@@ -7,8 +7,8 @@ namespace Kiri\Abstracts;
use Annotation\Annotation as SAnnotation;
use Database\Connection;
use Database\DatabasesProviders;
use Http\Client\Client;
use Http\Client\Curl;
use Http\Handler\Client\Client;
use Http\Handler\Client\Curl;
use Http\Handler\Router;
use Server\Server;
use Kiri\Crontab\Producer;