Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/clone/wp-conte.../themes/Divi/core/componen.../api
File: Service.php
<?php
[0] Fix | Delete
[1] Fix | Delete
/**
[2] Fix | Delete
* High level, generic, wrapper for interacting with a external, 3rd-party API.
[3] Fix | Delete
*
[4] Fix | Delete
* @since 1.1.0
[5] Fix | Delete
*
[6] Fix | Delete
* @package ET\Core\API
[7] Fix | Delete
*/
[8] Fix | Delete
abstract class ET_Core_API_Service {
[9] Fix | Delete
[10] Fix | Delete
/**
[11] Fix | Delete
* @var ET_Core_Data_Utils
[12] Fix | Delete
*/
[13] Fix | Delete
protected static $_;
[14] Fix | Delete
[15] Fix | Delete
/**
[16] Fix | Delete
* URL to request an OAuth access token.
[17] Fix | Delete
*
[18] Fix | Delete
* @since 1.1.0
[19] Fix | Delete
* @var string
[20] Fix | Delete
*/
[21] Fix | Delete
public $ACCESS_TOKEN_URL;
[22] Fix | Delete
[23] Fix | Delete
/**
[24] Fix | Delete
* URL to authorize an application using OAuth.
[25] Fix | Delete
*
[26] Fix | Delete
* @since 1.1.0
[27] Fix | Delete
* @var string
[28] Fix | Delete
*/
[29] Fix | Delete
public $AUTHORIZATION_URL;
[30] Fix | Delete
[31] Fix | Delete
/**
[32] Fix | Delete
* General failure message (translated & escaped).
[33] Fix | Delete
*
[34] Fix | Delete
* @since 1.1.0
[35] Fix | Delete
* @var string
[36] Fix | Delete
*/
[37] Fix | Delete
public $FAILURE_MESSAGE;
[38] Fix | Delete
[39] Fix | Delete
/**
[40] Fix | Delete
* URL to request an OAuth request token.
[41] Fix | Delete
*
[42] Fix | Delete
* @since 1.1.0
[43] Fix | Delete
* @var string
[44] Fix | Delete
*/
[45] Fix | Delete
public $REQUEST_TOKEN_URL;
[46] Fix | Delete
[47] Fix | Delete
/**
[48] Fix | Delete
* Callback URL for OAuth Authorization.
[49] Fix | Delete
*
[50] Fix | Delete
* @since 1.1.0
[51] Fix | Delete
* @var string
[52] Fix | Delete
*/
[53] Fix | Delete
public $REDIRECT_URL;
[54] Fix | Delete
[55] Fix | Delete
/**
[56] Fix | Delete
* The base url for the service.
[57] Fix | Delete
*
[58] Fix | Delete
* @since 1.1.0
[59] Fix | Delete
* @var string
[60] Fix | Delete
*/
[61] Fix | Delete
public $BASE_URL;
[62] Fix | Delete
[63] Fix | Delete
/**
[64] Fix | Delete
* Instance of the OAuth wrapper class initialized for this service.
[65] Fix | Delete
*
[66] Fix | Delete
* @since 1.1.0
[67] Fix | Delete
* @var ET_Core_API_OAuthHelper
[68] Fix | Delete
*/
[69] Fix | Delete
public $OAuth_Helper;
[70] Fix | Delete
[71] Fix | Delete
/**
[72] Fix | Delete
* The form fields (shown in the dashboard) for the service account.
[73] Fix | Delete
*
[74] Fix | Delete
* @since 1.1.0
[75] Fix | Delete
* @var array
[76] Fix | Delete
*/
[77] Fix | Delete
public $account_fields;
[78] Fix | Delete
[79] Fix | Delete
/**
[80] Fix | Delete
* Each service can have multiple sets of credentials (accounts). This identifies which
[81] Fix | Delete
* account an instance of this class will provide access to.
[82] Fix | Delete
*
[83] Fix | Delete
* @since 1.1.0
[84] Fix | Delete
* @var string
[85] Fix | Delete
*/
[86] Fix | Delete
public $account_name;
[87] Fix | Delete
[88] Fix | Delete
/**
[89] Fix | Delete
* Custom HTTP headers that should be added to all requests made to this service's API.
[90] Fix | Delete
*
[91] Fix | Delete
* @since 1.1.0
[92] Fix | Delete
* @var array
[93] Fix | Delete
*/
[94] Fix | Delete
public $custom_headers;
[95] Fix | Delete
[96] Fix | Delete
/**
[97] Fix | Delete
* The service's data. Typically this will be IDs, tokens, secrets, etc used for API authentication.
[98] Fix | Delete
*
[99] Fix | Delete
* @since 1.1.0
[100] Fix | Delete
* @var string[]
[101] Fix | Delete
*/
[102] Fix | Delete
public $data;
[103] Fix | Delete
[104] Fix | Delete
/**
[105] Fix | Delete
* The mapping of the key names we use to store the service's data to the key names used by the service's API.
[106] Fix | Delete
*
[107] Fix | Delete
* @since 1.1.0
[108] Fix | Delete
* @var string[]
[109] Fix | Delete
*/
[110] Fix | Delete
public $data_keys;
[111] Fix | Delete
[112] Fix | Delete
/**
[113] Fix | Delete
* An instance of our HTTP Interface (utility class).
[114] Fix | Delete
*
[115] Fix | Delete
* @since 1.1.0
[116] Fix | Delete
* @var ET_Core_HTTPInterface
[117] Fix | Delete
*/
[118] Fix | Delete
public $http;
[119] Fix | Delete
[120] Fix | Delete
/**
[121] Fix | Delete
* If service uses HTTP Basic Auth, an array with details needed to generate the auth header, false otherwise.
[122] Fix | Delete
*
[123] Fix | Delete
* @since 1.1.0
[124] Fix | Delete
* @var bool|array {
[125] Fix | Delete
* Details needed to generate the HTTP Auth header.
[126] Fix | Delete
*
[127] Fix | Delete
* @type string $username The data key name who's value should be used as the username, or a value to use instead.
[128] Fix | Delete
* @type string $password The data key name who's value should be used as the password, or a value to use instead.
[129] Fix | Delete
* }
[130] Fix | Delete
*/
[131] Fix | Delete
public $http_auth = false;
[132] Fix | Delete
[133] Fix | Delete
/**
[134] Fix | Delete
* Maximum number of accounts user is allowed to add for the service.
[135] Fix | Delete
*
[136] Fix | Delete
* @since 4.0.7
[137] Fix | Delete
* @var int
[138] Fix | Delete
*/
[139] Fix | Delete
public $max_accounts;
[140] Fix | Delete
[141] Fix | Delete
/**
[142] Fix | Delete
* The service's proper name (will be shown in the UI).
[143] Fix | Delete
*
[144] Fix | Delete
* @since 1.1.0
[145] Fix | Delete
* @var string
[146] Fix | Delete
*/
[147] Fix | Delete
public $name;
[148] Fix | Delete
[149] Fix | Delete
/**
[150] Fix | Delete
* The OAuth version (if the service uses OAuth).
[151] Fix | Delete
*
[152] Fix | Delete
* @since 1.1.0
[153] Fix | Delete
* @var string
[154] Fix | Delete
*/
[155] Fix | Delete
public $oauth_version;
[156] Fix | Delete
[157] Fix | Delete
/**
[158] Fix | Delete
* The OAuth verifier key (if the service uses OAuth along with verifier keys).
[159] Fix | Delete
*
[160] Fix | Delete
* @since 1.1.0
[161] Fix | Delete
* @var string
[162] Fix | Delete
*/
[163] Fix | Delete
public $oauth_verifier;
[164] Fix | Delete
[165] Fix | Delete
/**
[166] Fix | Delete
* The name and version of the theme/plugin that created this class instance.
[167] Fix | Delete
* Should be formatted like this: `Divi/3.0.23`.
[168] Fix | Delete
*
[169] Fix | Delete
* @since 1.1.0
[170] Fix | Delete
* @var string
[171] Fix | Delete
*/
[172] Fix | Delete
public $owner;
[173] Fix | Delete
[174] Fix | Delete
/**
[175] Fix | Delete
* Convenience accessor for {@link self::http->request}
[176] Fix | Delete
*
[177] Fix | Delete
* @since 1.1.0
[178] Fix | Delete
* @var \ET_Core_HTTPRequest?
[179] Fix | Delete
*/
[180] Fix | Delete
public $request;
[181] Fix | Delete
[182] Fix | Delete
/**
[183] Fix | Delete
* Convenience accessor for {@link self::http->response}
[184] Fix | Delete
*
[185] Fix | Delete
* @since 1.1.0
[186] Fix | Delete
* @var \ET_Core_HTTPResponse?
[187] Fix | Delete
*/
[188] Fix | Delete
public $response;
[189] Fix | Delete
[190] Fix | Delete
/**
[191] Fix | Delete
* For services that return JSON responses, this is the top-level/root key for the returned data.
[192] Fix | Delete
*
[193] Fix | Delete
* @since 1.1.0
[194] Fix | Delete
* @var string
[195] Fix | Delete
*/
[196] Fix | Delete
public $response_data_key;
[197] Fix | Delete
[198] Fix | Delete
/**
[199] Fix | Delete
* The service type (email, social, etc).
[200] Fix | Delete
*
[201] Fix | Delete
* @since 1.1.0
[202] Fix | Delete
* @var string
[203] Fix | Delete
*/
[204] Fix | Delete
public $service_type;
[205] Fix | Delete
[206] Fix | Delete
/**
[207] Fix | Delete
* The slug for this service (not shown in the UI).
[208] Fix | Delete
*
[209] Fix | Delete
* @since 1.1.0
[210] Fix | Delete
* @var string
[211] Fix | Delete
*/
[212] Fix | Delete
public $slug;
[213] Fix | Delete
[214] Fix | Delete
/**
[215] Fix | Delete
* Whether or not the service uses OAuth.
[216] Fix | Delete
*
[217] Fix | Delete
* @since 1.1.0
[218] Fix | Delete
* @var bool
[219] Fix | Delete
*/
[220] Fix | Delete
public $uses_oauth;
[221] Fix | Delete
[222] Fix | Delete
/**
[223] Fix | Delete
* ET_Core_API_Service constructor.
[224] Fix | Delete
*
[225] Fix | Delete
* @since 1.1.0
[226] Fix | Delete
*
[227] Fix | Delete
* @param string $owner {@see self::owner}
[228] Fix | Delete
* @param string $account_name The name of the service account that the instance will provide access to.
[229] Fix | Delete
* @param string $api_key The api key for the account. Optional (can be set after instantiation).
[230] Fix | Delete
*/
[231] Fix | Delete
public function __construct( $owner = 'ET_Core', $account_name = '', $api_key = '' ) {
[232] Fix | Delete
$this->account_name = str_replace( '.', '', sanitize_text_field( $account_name ) );
[233] Fix | Delete
$this->owner = sanitize_text_field( $owner );
[234] Fix | Delete
$this->account_fields = $this->get_account_fields();
[235] Fix | Delete
[236] Fix | Delete
$this->data = $this->_get_data();
[237] Fix | Delete
$this->data_keys = $this->get_data_keymap();
[238] Fix | Delete
$this->oauth_verifier = '';
[239] Fix | Delete
[240] Fix | Delete
$this->http = new ET_Core_HTTPInterface( $this->owner );
[241] Fix | Delete
[242] Fix | Delete
self::$_ = $this->data_utils = new ET_Core_Data_Utils();
[243] Fix | Delete
[244] Fix | Delete
$this->FAILURE_MESSAGE = esc_html__( 'API request failed, please try again.', 'et_core' );
[245] Fix | Delete
$this->API_KEY_REQUIRED = esc_html__( 'API request failed. API Key is required.', 'et_core' );
[246] Fix | Delete
[247] Fix | Delete
if ( '' !== $api_key ) {
[248] Fix | Delete
$this->data['api_key'] = sanitize_text_field( $api_key );
[249] Fix | Delete
$this->save_data();
[250] Fix | Delete
}
[251] Fix | Delete
[252] Fix | Delete
if ( $this->uses_oauth && $this->is_authenticated() ) {
[253] Fix | Delete
$this->_initialize_oauth_helper();
[254] Fix | Delete
}
[255] Fix | Delete
}
[256] Fix | Delete
[257] Fix | Delete
/**
[258] Fix | Delete
* Generates a HTTP Basic Auth header and adds it to the current request object. Uses the value
[259] Fix | Delete
* of {@link self::http_auth} to determine the correct values to use for the username and password.
[260] Fix | Delete
*/
[261] Fix | Delete
protected function _add_http_auth_header_to_request() {
[262] Fix | Delete
$username_key = $this->http_auth['username'];
[263] Fix | Delete
$password_key = $this->http_auth['password'];
[264] Fix | Delete
[265] Fix | Delete
$username = isset( $this->data[ $username_key ] ) ? $this->data[ $username_key ] : $username_key;
[266] Fix | Delete
$password = isset( $this->data[ $password_key ] ) ? $this->data[ $password_key ] : $password_key;
[267] Fix | Delete
[268] Fix | Delete
$this->request->HEADERS['Authorization'] = 'Basic ' . base64_encode( "{$username}:{$password}" );
[269] Fix | Delete
}
[270] Fix | Delete
[271] Fix | Delete
/**
[272] Fix | Delete
* Exchange a request/verifier token for an access token. This is the last step in the OAuth authorization process.
[273] Fix | Delete
* If successful, the access token will be saved and used for future calls to the API.
[274] Fix | Delete
*
[275] Fix | Delete
* @return bool Whether or not authentication was successful.
[276] Fix | Delete
*/
[277] Fix | Delete
private function _do_oauth_access_token_request() {
[278] Fix | Delete
if ( ! $this->_initialize_oauth_helper() ) {
[279] Fix | Delete
return false;
[280] Fix | Delete
}
[281] Fix | Delete
[282] Fix | Delete
$args = array();
[283] Fix | Delete
[284] Fix | Delete
if ( '' !== $this->oauth_verifier ) {
[285] Fix | Delete
$args['oauth_verifier'] = $this->oauth_verifier;
[286] Fix | Delete
}
[287] Fix | Delete
[288] Fix | Delete
$this->request = $this->http->request = $this->OAuth_Helper->prepare_access_token_request( $args );
[289] Fix | Delete
[290] Fix | Delete
$this->request->HEADERS['Content-Type'] = 'application/x-www-form-urlencoded';
[291] Fix | Delete
[292] Fix | Delete
$this->http->make_remote_request();
[293] Fix | Delete
$this->response = $this->http->response;
[294] Fix | Delete
[295] Fix | Delete
if ( $this->response->ERROR ) {
[296] Fix | Delete
return false;
[297] Fix | Delete
}
[298] Fix | Delete
[299] Fix | Delete
$this->OAuth_Helper->process_authentication_response( $this->response, $this->http->expects_json );
[300] Fix | Delete
[301] Fix | Delete
if ( null === $this->OAuth_Helper->token ) {
[302] Fix | Delete
return false;
[303] Fix | Delete
}
[304] Fix | Delete
[305] Fix | Delete
$this->data['access_key'] = $this->OAuth_Helper->token->key;
[306] Fix | Delete
$this->data['access_secret'] = $this->OAuth_Helper->token->secret;
[307] Fix | Delete
$this->data['is_authorized'] = true;
[308] Fix | Delete
[309] Fix | Delete
if ( ! empty( $this->OAuth_Helper->token->refresh_token ) ) {
[310] Fix | Delete
$this->data['refresh_token'] = $this->OAuth_Helper->token->refresh_token;
[311] Fix | Delete
}
[312] Fix | Delete
[313] Fix | Delete
return true;
[314] Fix | Delete
}
[315] Fix | Delete
[316] Fix | Delete
/**
[317] Fix | Delete
* The service's private data.
[318] Fix | Delete
*
[319] Fix | Delete
* @see self::$_data
[320] Fix | Delete
* @internal
[321] Fix | Delete
* @since 1.1.0
[322] Fix | Delete
*
[323] Fix | Delete
* @return array
[324] Fix | Delete
*/
[325] Fix | Delete
protected function _get_data() {
[326] Fix | Delete
return (array) get_option( "et_core_api_{$this->service_type}_options" );
[327] Fix | Delete
}
[328] Fix | Delete
[329] Fix | Delete
/**
[330] Fix | Delete
* Initializes {@link self::OAuth_Helper}
[331] Fix | Delete
*
[332] Fix | Delete
* @return bool `true` if successful, `false` otherwise.
[333] Fix | Delete
*/
[334] Fix | Delete
protected function _initialize_oauth_helper() {
[335] Fix | Delete
if ( null !== $this->OAuth_Helper ) {
[336] Fix | Delete
return true;
[337] Fix | Delete
}
[338] Fix | Delete
[339] Fix | Delete
$urls = array(
[340] Fix | Delete
'access_token_url' => $this->ACCESS_TOKEN_URL,
[341] Fix | Delete
'request_token_url' => $this->REQUEST_TOKEN_URL,
[342] Fix | Delete
'authorization_url' => $this->AUTHORIZATION_URL,
[343] Fix | Delete
'redirect_url' => $this->REDIRECT_URL,
[344] Fix | Delete
);
[345] Fix | Delete
[346] Fix | Delete
$this->OAuth_Helper = new ET_Core_API_OAuthHelper( $this->data, $urls, $this->owner );
[347] Fix | Delete
[348] Fix | Delete
return null !== $this->OAuth_Helper;
[349] Fix | Delete
}
[350] Fix | Delete
[351] Fix | Delete
/**
[352] Fix | Delete
* Returns the currently known custom fields for this service.
[353] Fix | Delete
*
[354] Fix | Delete
* @return array
[355] Fix | Delete
*/
[356] Fix | Delete
protected function _get_custom_fields() {
[357] Fix | Delete
return empty( $this->data['custom_fields'] ) ? array() : $this->data['custom_fields'];
[358] Fix | Delete
}
[359] Fix | Delete
[360] Fix | Delete
/**
[361] Fix | Delete
* Initiate OAuth Authorization Flow
[362] Fix | Delete
*
[363] Fix | Delete
* @return array|bool
[364] Fix | Delete
*/
[365] Fix | Delete
public function authenticate() {
[366] Fix | Delete
et_core_nonce_verified_previously();
[367] Fix | Delete
[368] Fix | Delete
if ( '1.0a' === $this->oauth_version || ( '2.0' === $this->oauth_version && ! empty( $_GET['code'] ) ) ) {
[369] Fix | Delete
$authenticated = $this->_do_oauth_access_token_request();
[370] Fix | Delete
[371] Fix | Delete
if ( $authenticated ) {
[372] Fix | Delete
$this->save_data();
[373] Fix | Delete
return true;
[374] Fix | Delete
}
[375] Fix | Delete
} else if ( '2.0' === $this->oauth_version ) {
[376] Fix | Delete
$nonce = wp_create_nonce( 'et_core_api_service_oauth2' );
[377] Fix | Delete
$args = array(
[378] Fix | Delete
'client_id' => $this->data['api_key'],
[379] Fix | Delete
'response_type' => 'code',
[380] Fix | Delete
'state' => rawurlencode( "ET_Core|{$this->name}|{$this->account_name}|{$nonce}" ),
[381] Fix | Delete
'redirect_uri' => $this->REDIRECT_URL,
[382] Fix | Delete
);
[383] Fix | Delete
[384] Fix | Delete
$this->save_data();
[385] Fix | Delete
[386] Fix | Delete
return array( 'redirect_url' => add_query_arg( $args, $this->AUTHORIZATION_URL ) );
[387] Fix | Delete
}
[388] Fix | Delete
[389] Fix | Delete
return false;
[390] Fix | Delete
}
[391] Fix | Delete
[392] Fix | Delete
/**
[393] Fix | Delete
* Remove the service account from the database. This cannot be undone. The instance
[394] Fix | Delete
* will no longer be usable after a call to this method.
[395] Fix | Delete
*
[396] Fix | Delete
* @since 1.1.0
[397] Fix | Delete
*/
[398] Fix | Delete
abstract public function delete();
[399] Fix | Delete
[400] Fix | Delete
/**
[401] Fix | Delete
* Get the form fields to show in the WP Dashboard for this service's accounts.
[402] Fix | Delete
*
[403] Fix | Delete
* @since 1.1.0
[404] Fix | Delete
*
[405] Fix | Delete
* @return array
[406] Fix | Delete
*/
[407] Fix | Delete
abstract public function get_account_fields();
[408] Fix | Delete
[409] Fix | Delete
/**
[410] Fix | Delete
* Get an array that maps our data keys to those returned by the 3rd-party service's API.
[411] Fix | Delete
*
[412] Fix | Delete
* @since 1.1.0
[413] Fix | Delete
*
[414] Fix | Delete
* @param array $keymap A mapping of our data key addresses to those of the service, organized by type/category.
[415] Fix | Delete
*
[416] Fix | Delete
* @return array[] {
[417] Fix | Delete
*
[418] Fix | Delete
* @type array $key_type {
[419] Fix | Delete
*
[420] Fix | Delete
* @type string $our_key_address The corresponding key address on the service.
[421] Fix | Delete
* ...
[422] Fix | Delete
* }
[423] Fix | Delete
* ...
[424] Fix | Delete
* }
[425] Fix | Delete
*/
[426] Fix | Delete
abstract public function get_data_keymap( $keymap = array() );
[427] Fix | Delete
[428] Fix | Delete
/**
[429] Fix | Delete
* Get error message for a response that has an ERROR status. If possible the provider's
[430] Fix | Delete
* error message will be returned. Otherwise the HTTP error status description will be returned.
[431] Fix | Delete
*
[432] Fix | Delete
* @return string
[433] Fix | Delete
*/
[434] Fix | Delete
public function get_error_message() {
[435] Fix | Delete
if ( ! empty( $this->data_keys['error'] ) ) {
[436] Fix | Delete
$data = $this->transform_data_to_our_format( $this->response->DATA, 'error' );
[437] Fix | Delete
return isset( $data['error_message'] ) ? $data['error_message'] : '';
[438] Fix | Delete
}
[439] Fix | Delete
[440] Fix | Delete
return $this->response->ERROR_MESSAGE;
[441] Fix | Delete
}
[442] Fix | Delete
[443] Fix | Delete
/**
[444] Fix | Delete
* Whether or not the current account has been authenticated with the service's API.
[445] Fix | Delete
*
[446] Fix | Delete
* @return bool
[447] Fix | Delete
*/
[448] Fix | Delete
public function is_authenticated() {
[449] Fix | Delete
return isset( $this->data['is_authorized'] ) && in_array( $this->data['is_authorized'], array( true, 'true' ) );
[450] Fix | Delete
}
[451] Fix | Delete
[452] Fix | Delete
/**
[453] Fix | Delete
* Makes a remote request using the current {@link self::http->request}. Automatically
[454] Fix | Delete
* handles custom headers and OAuth when applicable.
[455] Fix | Delete
*/
[456] Fix | Delete
public function make_remote_request() {
[457] Fix | Delete
if ( ! empty( $this->custom_headers ) ) {
[458] Fix | Delete
$this->http->request->HEADERS = array_merge( $this->http->request->HEADERS, $this->custom_headers );
[459] Fix | Delete
}
[460] Fix | Delete
[461] Fix | Delete
if ( $this->uses_oauth ) {
[462] Fix | Delete
$oauth2 = '2.0' === $this->oauth_version;
[463] Fix | Delete
$this->http->request = $this->OAuth_Helper->prepare_oauth_request( $this->http->request, $oauth2 );
[464] Fix | Delete
} else if ( $this->http_auth ) {
[465] Fix | Delete
$this->_add_http_auth_header_to_request();
[466] Fix | Delete
}
[467] Fix | Delete
[468] Fix | Delete
$this->request = $this->http->request;
[469] Fix | Delete
[470] Fix | Delete
$this->http->make_remote_request();
[471] Fix | Delete
[472] Fix | Delete
$this->response = $this->http->response;
[473] Fix | Delete
}
[474] Fix | Delete
[475] Fix | Delete
/**
[476] Fix | Delete
* Convenience accessor for {@link self::http->prepare_request()}
[477] Fix | Delete
*
[478] Fix | Delete
* @param string $url
[479] Fix | Delete
* @param string $method
[480] Fix | Delete
* @param bool $is_auth
[481] Fix | Delete
* @param mixed $body
[482] Fix | Delete
* @param bool $json_body
[483] Fix | Delete
* @param bool $ssl_verify
[484] Fix | Delete
*/
[485] Fix | Delete
public function prepare_request( $url, $method = 'GET', $is_auth = false, $body = null, $json_body = false, $ssl_verify = true ) {
[486] Fix | Delete
$this->http->prepare_request( $url, $method, $is_auth, $body, $json_body, $ssl_verify );
[487] Fix | Delete
$this->request = $this->http->request;
[488] Fix | Delete
}
[489] Fix | Delete
[490] Fix | Delete
/**
[491] Fix | Delete
* Save this service's data to the database.
[492] Fix | Delete
*
[493] Fix | Delete
* @return mixed
[494] Fix | Delete
*/
[495] Fix | Delete
abstract public function save_data();
[496] Fix | Delete
[497] Fix | Delete
/**
[498] Fix | Delete
* Set the account name for the instance. Changing the accounts name affects the
[499] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function