晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/self/root/home/stando/www/wp-content/plugins/w3-total-cache/ |
Upload File : |
<?php
namespace W3TC;
/**
* StackPath REST Client Library
*/
class Cdn_StackPath2_Api {
private $client_id;
private $client_secret;
private $stack_id;
private $access_token;
private $on_new_access_token;
public function __construct( $config ) {
$this->client_id = $config['client_id'];
$this->client_secret = $config['client_secret'];
$this->stack_id = isset( $config['stack_id'] ) ? $config['stack_id'] : '';
$this->access_token =
isset( $config['access_token'] ) ? $config['access_token'] : '';
$this->on_new_access_token =
isset( $config['on_new_access_token'] ) ? $config['on_new_access_token'] : null;
}
public function authenticate() {
$request_json = array(
'client_id' => $this->client_id,
'client_secret' => $this->client_secret,
'grant_type' => 'client_credentials'
);
$result = wp_remote_post(
'https://gateway.stackpath.com/identity/v1/oauth2/token',
array(
'headers' => array(
'Accept' => 'application/json',
'Content-Type' => 'application/json'
),
'body' => json_encode( $request_json )
)
);
$r = $this->_decode_response( $result );
if ( $r['auth_required'] ) {
throw new \Exception( 'Authentication failed' );
}
if ( !isset( $r['response_json']['access_token'] ) ) {
throw new \Exception(
'Unexpected authentication response: access token not found' );
}
$this->access_token = $r['response_json']['access_token'];
return $this->access_token;
}
public function site_list() {
return $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites" );
}
public function site_get( $site_id ) {
return $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites/$site_id" );
}
public function site_create( $data ) {
return $this->_wp_remote_post(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites", $data );
}
public function site_metrics( $site_id, $days ) {
$d = new \DateTime();
$end_date = $d->format( 'Y-m-d' ) . 'T00:00:00Z';
$start_date = $d->sub( new \DateInterval( 'P' . $days . 'D' ) )->format( 'Y-m-d' ) . 'T00:00:00Z';
return $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/metrics",
array(
'site_id' => $site_id,
'start_date' => $start_date,
'end_date' => $end_date,
'platforms' => 'CDS',
'granularity' => 'P1D'
)
);
}
public function purge( $data ) {
return $this->_wp_remote_post(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/purge", $data );
}
public function site_dns_targets_get( $site_id ) {
return $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites/$site_id/dns/targets" );
}
private function site_scope_get_by_platform( $site_id, $platform ) {
$scopes = $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites/$site_id/scopes" );
foreach ( $scopes['results'] as $scope ) {
if ( $scope['platform'] == $platform )
return $scope;
}
return null;
}
public function site_cds_get( $site_id ) {
$scope = $this->site_scope_get_by_platform( $site_id, 'CDS' );
$scope_id = $scope['id'];
return $this->_wp_remote_get(
"https://gateway.stackpath.com/cdn/v1/stacks/$this->stack_id/sites/$site_id/scopes/$scope_id/configuration" );
}
public function stacks_list() {
return $this->_wp_remote_get( 'https://gateway.stackpath.com/stack/v1/stacks' );
}
public function stack_get( $stack_id ) {
return $this->_wp_remote_get( "https://gateway.stackpath.com/stack/v1/stacks/$stack_id" );
}
private function _decode_response( $result ) {
if ( is_wp_error( $result ) )
throw new \Exception( 'Failed to reach API endpoint' );
$response_json = @json_decode( $result['body'], true );
if ( is_null( $response_json ) )
throw new \Exception(
'Failed to reach API endpoint, got unexpected response ' .
$result['body'] );
if ( $result['response']['code'] == '401' ) {
return array(
'auth_required' => true,
'response_json' => array()
);
}
if ( $result['response']['code'] != '200' && $result['response']['code'] != '201' ) {
if ( isset( $response_json['message'] ) ) {
throw new \Exception( $response_json['message'] );
} else {
throw new \Exception( 'response code ' .
$result['response']['code'] . ' with ' . $result['body'] );
}
}
return array(
'auth_required' => false,
'response_json' => $response_json
);
}
private function _wp_remote_get( $url, $data = array() ) {
//var_dump( $url );
//var_dump( array( 'headers' => 'authorization: Bearer ' . $this->access_token ) );
if ( !empty( $this->access_token ) ) {
$result = wp_remote_get(
$url . ( empty( $data ) ? '' : '?' . http_build_query( $data ) ),
array(
'headers' => 'authorization: Bearer ' . $this->access_token
)
);
$r = self::_decode_response( $result );
if ( !$r['auth_required'] ) {
return $r['response_json'];
}
}
$this->authenticate();
if ( !is_null( $this->on_new_access_token ) ) {
call_user_func( $this->on_new_access_token, $this->access_token );
}
return $this->_wp_remote_get( $url, $data );
}
private function _wp_remote_post( $url, $data ) {
if ( !empty( $this->access_token ) ) {
add_filter( 'http_request_timeout', array( $this, 'filter_timeout_time' ) );
add_filter( 'https_ssl_verify', array( $this, 'https_ssl_verify' ) );
$result = wp_remote_post( $url, array(
'headers' => array(
'authorization' => 'Bearer ' . $this->access_token,
'Accept' => 'application/json',
'Content-Type' => 'application/json'
),
'body' => json_encode( $data )
) );
remove_filter( 'https_ssl_verify', array( $this, 'https_ssl_verify' ) );
remove_filter( 'http_request_timeout', array( $this, 'filter_timeout_time' ) );
$r = self::_decode_response( $result );
if ( !$r['auth_required'] ) {
return $r['response_json'];
}
}
$this->authenticate();
if ( !is_null( $this->on_new_access_token ) ) {
call_user_func( $this->on_new_access_token, $this->access_token );
}
return $this->_wp_remote_post( $url, $data );
}
/**
* Increase http request timeout to 60 seconds
*/
public function filter_timeout_time($time) {
return 600;
}
/**
* Don't check certificate, some users have limited CA list
*/
public function https_ssl_verify($v) {
return false;
}
}