AmazonCore
in package
The main core of the Amazon class.
The Amazon classes are divided up into groups, with each group having its own abstract core class. This core is the class that each of the other cores extend from. It contains a number of methods shared by all cores, such as logging, throttling, and signature generation.
The general flow for using a class in this library is as follows:
- Create an object (or objects) of the desired type.
- Set the request parameters using "set_____" functions. Some classes allow you to set parameters when constructing the object. Some classes don't need any parameters, and a few don't have any at all.
- Send the request to Amazon using the class's unique function. (Usually "fetch___") If not enough parameters have been set, the request will not go through.
- Retrieve the data received with "get____" functions. Some classes can be iterated through using foreach.
- Repeat. Please note that performing Amazon actions sometimes alters or removes parameters previously set, so it is recommended that you set all of the desired parameters again before making a second action, or better yet, use a new object. The exception to this is follow-up actions, which rely on the data previously received from Amazon and do not require any parameters.
- Constructor - Some classes let you pass an extra value when creating the class in order to automatically set one of the parameters necessary for the class. Other than that, all of the classes are created the same way and have the same options for setting mock mode and other testing features.
- Set an Option Flag - These are functions for toggling a setting that only has an On or Off setting. The single value they take is usually a boolean (or sometimes a string with the words "true" or "false") and the value is often optional. If no value is passed, the setting will be enabled. Passing a value of false is the only way to deactivate the option afterwards.
- Set Single Value - These are functions meant for setting a parameter that uses only a single value. For example, setting a shipment ID to receive the items for. They typically require only a single parameter, usually a string. Occasionally, the function will require a number, or a specific string value. In these cases, the function will not set the parameter if the value is incorrect.
- Set Multiple Values - These are functions for setting options that can take a list of values. These functions can take either an array of values, or a single string. If this function is used a second time, the first list of values will be completely removed and replaced with the new values.
- Set Time Options - A number of classes have functions for setting time limit options. This is typically a pair of time points, but depending on the class, it may only need one. All values passed to these functions are passed through strtotime before being used, so a wide variety of values is accepted. For more information on what is acceptible, see the documentation for strtotime.
- Amazon Actions - These are functions with names like "fetch____" or "cancel___", and they are what send the request to Amazon. No parameter is ever needed, and the output is always only to indicate if the action was successful.
- Retrieve Value from a Single Object - These functions are for retrieving data sent by Amazon from a class that is not dedicated to a list of information. No parameters are needed.
- Retrieve Value from a List Object - These functions are also for retrieving data, but from classes that contain a list of different information sets. These functions can take an integer for a list index, which then returns the value from the specified entry. If no index is given, it defaults to returning the first entry in the list. In the case of complex lists, sometimes a second index may be used.
- Retrieve a List Entry - These functions return either part of or all of a class object's data list. An optional index can be passed to return a particular data set. If no index is given, the entire list of data is returned. Keep in mind that the arrays returned by these functions are usually pretty large.
- Follow-Up Actions - There are only a few of these functions, and are mostly "fetchItems" functions for lists of orders or shipments. These functions send a request to Amazon for every entry in the object's data list. Please note that these functions will generally take a while to perform and will return a lot of data. These are the only non-"get" functions that will return the information.
Table of Contents
- $config : mixed
- $env : mixed
- $marketplaceId : mixed
- $mockFiles : mixed
- $mockIndex : mixed
- $mockMode : mixed
- $options : mixed
- $proxyInfo : mixed
- $rawResponses : mixed
- $storeName : mixed
- $throttleCount : mixed
- $throttleGroup : mixed
- $throttleLimit : mixed
- $throttleSafe : mixed
- $throttleStop : mixed
- $throttleTime : mixed
- $urlbase : mixed
- $urlbranch : mixed
- fetchURL() : array<string|int, mixed>
- Get url or send POST data
- getLastResponse() : array<string|int, mixed>|bool
- Gives the latest response data received from Amazon.
- getOptions() : array<string|int, mixed>
- Returns options array.
- getRawResponses() : array<string|int, mixed>|bool
- Gives all response code received from Amazon.
- getThrottleCountForLastRequest() : int
- Gives the number of times the last call to sendRequest was throttled
- setConfig() : mixed
- setMock() : mixed
- Enables or disables Mock Mode for the object.
- setStore() : mixed
- Sets the store values.
- setThrottleStop() : mixed
- Enables or disables the throttle stop.
- __construct() : mixed
- AmazonCore constructor sets up key information used in all Amazon requests.
- _calculateStringToSignV2() : string
- generates the string to sign, copied from Amazon
- _getParametersAsString() : string
- Fuses all of the parameters together into a string, copied from Amazon
- _sign() : string
- Runs the hash, copied from Amazon
- _signParameters() : string
- validates signature and sets up signing of them, copied from Amazon
- _urlencode() : string
- Reformats the provided string using rawurlencode while also replacing ~, copied from Amazon
- checkResponse() : bool
- Checks whether or not the response is OK.
- checkToken() : bool
- Checks for a token and changes the proper options
- fetchMockFile() : SimpleXMLObject|string|bool
- Fetches the given mock file, or attempts to.
- fetchMockResponse() : bool|array<string|int, mixed>
- Generates a fake HTTP response using the mock file list.
- genQuery() : string
- Handles generation of the signed query string.
- genTime() : string
- Generates timestamp in ISO8601 format.
- log() : bool
- Writes a message to the log.
- resetMock() : mixed
- Sets mock index back to 0.
- sendRequest() : array<string|int, mixed>
- Sends a request to Amazon via cURL
- sleep() : mixed
- Sleeps for the throttle time and records to the log.
Properties
$config
protected
mixed
$config
$env
protected
mixed
$env
$marketplaceId
protected
mixed
$marketplaceId
$mockFiles
protected
mixed
$mockFiles
$mockIndex
protected
mixed
$mockIndex
= 0
$mockMode
protected
mixed
$mockMode
= false
$options
protected
mixed
$options
$proxyInfo
protected
mixed
$proxyInfo
= []
$rawResponses
protected
mixed
$rawResponses
= []
$storeName
protected
mixed
$storeName
$throttleCount
protected
mixed
$throttleCount
= 0
$throttleGroup
protected
mixed
$throttleGroup
$throttleLimit
protected
mixed
$throttleLimit
$throttleSafe
protected
mixed
$throttleSafe
$throttleStop
protected
mixed
$throttleStop
= false
$throttleTime
protected
mixed
$throttleTime
$urlbase
protected
mixed
$urlbase
$urlbranch
protected
mixed
$urlbranch
Methods
fetchURL()
Get url or send POST data
public
fetchURL(string $url, array<string|int, mixed> $param) : array<string|int, mixed>
Parameters
- $url : string
- $param : array<string|int, mixed>
-
['Header'] $param['Post']
Return values
array<string|int, mixed> —$return['ok'] 1 - success, (0,-1) - fail $return['body'] - response $return['error'] - error, if "ok" is not 1 $return['head'] - http header
getLastResponse()
Gives the latest response data received from Amazon.
public
getLastResponse([int $i = null ]) : array<string|int, mixed>|bool
Response arrays contain the following keys:
- head - The raw HTTP head, including the response code and content length
- body - The raw HTTP body, which will almost always be in XML format
- code - The HTTP response code extracted from the head for convenience
- answer - The HTTP response message extracted from the head for convenience
- ok - Contains a 1 if the response was normal, or 0 if there was a problem
- headarray - An associative array of the head data, for convenience
Parameters
- $i : int = null
-
[optional]
If set, retrieves the specific response instead of the last one. If the index for the response is not used, FALSE will be returned.
Return values
array<string|int, mixed>|bool —associative array of HTTP response or FALSE if not set yet
getOptions()
Returns options array.
public
getOptions() : array<string|int, mixed>
Gets the options for the object, for debugging or recording purposes. Note that this also includes key information such as your Amazon Access Key ID.
Return values
array<string|int, mixed> —All of the options for the object.
getRawResponses()
Gives all response code received from Amazon.
public
getRawResponses() : array<string|int, mixed>|bool
Tags
Return values
array<string|int, mixed>|bool —list of associative arrays of HTTP response or FALSE if not set yet
getThrottleCountForLastRequest()
Gives the number of times the last call to sendRequest was throttled
public
getThrottleCountForLastRequest() : int
Tags
Return values
int —setConfig()
public
setConfig() : mixed
Return values
mixed —setMock()
Enables or disables Mock Mode for the object.
public
setMock([bool $b = true ][, array<string|int, mixed>|string|int $files = null ]) : mixed
Use this method when you want to test your object without sending actual requests to Amazon. When Mock Mode is enabled, responses are pulled from files you specify instead of sending the request. Be careful, as this means that the parameters you send will not necessarily match the response you get back. The files are pulled in order of the list, looping back to the first file after the last file is used. The log records every time a file is set or used, or if the file is missing. This method is also used to set response codes used by certain functions. Mock Mode is particularly useful when you need to test functions such as canceling orders or adding new products.
Parameters
- $b : bool = true
-
[optional]
When set to TRUE, Mock Mode is enabled for the object. Defaults to TRUE.
- $files : array<string|int, mixed>|string|int = null
-
[optional]
The list of files (or single file) to be used with Mock Mode. If a single string is given, this method will put it into an array. Integers can also be given, for use in fetchMockResponse. These numbers should only be response codes, such as 200 or 404.
Return values
mixed —setStore()
Sets the store values.
public
setStore(string $s) : mixed
This method sets a number of key values from the config file. These values include your Merchant ID, Access Key ID, and Secret Key, and are critical for making requests with Amazon. If the store cannot be found in the config file, or if any of the key values are missing, the incident will be logged.
Parameters
- $s : string
-
The store name to look for.
Tags
Return values
mixed —setThrottleStop()
Enables or disables the throttle stop.
public
setThrottleStop([bool $b = true ]) : mixed
When the throttle stop is enabled, throttled requests will not be repeated. This setting is off by default.
Parameters
- $b : bool = true
-
Defaults to TRUE.
Return values
mixed —__construct()
AmazonCore constructor sets up key information used in all Amazon requests.
protected
__construct(string $s[, bool $mock = false ][, array<string|int, mixed>|string $m = null ]) : mixed
This constructor is called when initializing all objects in this library. The parameters are passed by the child objects' constructors.
Parameters
- $s : string
-
Name for the store you want to use as seen in the config file. If this is not set to a valid name, none of these objects will work.
- $mock : bool = false
-
[optional]
This is a flag for enabling Mock Mode. When this is set to TRUE, the object will fetch responses from files you specify instead of sending the requests to Amazon. The log will indicate whether mock mode is on or off each time an object is initialized. This defaults to FALSE.
- $m : array<string|int, mixed>|string = null
-
[optional]
The files (or file) to use in Mock Mode. When Mock Mode is enabled, the object will retrieve one of these files from the list to use as a response. See setMock for more information.
Return values
mixed —_calculateStringToSignV2()
generates the string to sign, copied from Amazon
protected
_calculateStringToSignV2(array<string|int, mixed> $parameters) : string
Parameters
- $parameters : array<string|int, mixed>
Return values
string —_getParametersAsString()
Fuses all of the parameters together into a string, copied from Amazon
protected
_getParametersAsString(array<string|int, mixed> $parameters) : string
Parameters
- $parameters : array<string|int, mixed>
Return values
string —_sign()
Runs the hash, copied from Amazon
protected
_sign(string $data, string $key, string $algorithm) : string
Parameters
- $data : string
- $key : string
- $algorithm : string
-
'HmacSHA1' or 'HmacSHA256'
Tags
Return values
string —_signParameters()
validates signature and sets up signing of them, copied from Amazon
protected
_signParameters(array<string|int, mixed> $parameters, string $key) : string
Parameters
- $parameters : array<string|int, mixed>
- $key : string
Tags
Return values
string —signed string
_urlencode()
Reformats the provided string using rawurlencode while also replacing ~, copied from Amazon
protected
_urlencode(string $value) : string
Almost the same as using rawurlencode
Parameters
- $value : string
Return values
string —checkResponse()
Checks whether or not the response is OK.
protected
checkResponse(array<string|int, mixed> $r) : bool
Verifies whether or not the HTTP response has the 200 OK code. If the code is not 200, the incident and error message returned are logged.
Parameters
- $r : array<string|int, mixed>
-
The HTTP response array. Expects the array to have the fields code, body, and error.
Return values
bool —TRUE if the status is 200 OK, FALSE otherwise.
checkToken()
Checks for a token and changes the proper options
protected
checkToken(SimpleXMLObject $xml) : bool
Parameters
- $xml : SimpleXMLObject
-
response data
Return values
bool —FALSE if no XML data
fetchMockFile()
Fetches the given mock file, or attempts to.
protected
fetchMockFile([bool $load = true ]) : SimpleXMLObject|string|bool
This method is only called when Mock Mode is enabled. This is where files from the mock file list are retrieved and passed back to the caller. The success or failure of the operation will be recorded in the log, including the name and path of the file involved. For retrieving response codes, see fetchMockResponse.
Parameters
- $load : bool = true
-
[optional]
Set this to FALSE to prevent the method from loading the file's contents into a SimpleXMLObject. This is for when the contents of the file are not in XML format, or if you simply want to retrieve the raw string of the file.
Return values
SimpleXMLObject|string|bool —A SimpleXMLObject holding the contents of the file, or a string of said contents if $load is set to FALSE. The return will be FALSE if the file cannot be fetched for any reason.
fetchMockResponse()
Generates a fake HTTP response using the mock file list.
protected
fetchMockResponse() : bool|array<string|int, mixed>
This method uses the response codes in the mock file list to generate an HTTP response. The success or failure of this operation will be recorded in the log, including the response code returned. This is only used by a few operations. The response array will contain the following fields:
- head - ignored, but set for the sake of completion
- body - empty XML, also ignored
- code - the response code fetched from the list
- answer - answer message
- error - error message, same value as answer, not set if status is 200
- ok - 1 or 0, depending on if the status is 200
Return values
bool|array<string|int, mixed> —An array containing the HTTP response, or simply the value FALSE if the response could not be found or does not match the list of valid responses.
genQuery()
Handles generation of the signed query string.
protected
genQuery() : string
This method uses the secret key from the config file to generate the signed query string. It also handles the creation of the timestamp option prior.
Tags
Return values
string —query string to send to cURL
genTime()
Generates timestamp in ISO8601 format.
protected
genTime([string $time = false ]) : string
This method creates a timestamp from the provided string in ISO8601 format. The string given is passed through strtotime before being used. The value returned is actually 30 seconds early, to prevent it from tripping up Amazon. If no time is given, the current time is used.
Parameters
- $time : string = false
-
[optional]
The time to use. Since this value is passed through strtotime first, values such as "-1 hour" are fine. Defaults to the current time.
Return values
string —Unix timestamp of the time, minus 30 seconds.
log()
Writes a message to the log.
protected
log(string $msg[, string $level = 'Info' ]) : bool
This method adds a message line to the log file defined by the config. This includes the priority level, user IP, and a backtrace of the call.
Parameters
- $msg : string
-
The message to write to the log.
- $level : string = 'Info'
-
[optional]
The priority level of the message. This is merely for the benefit of the user and does not affect how the code runs. The values used in this library are "Info", "Warning", "Urgent", and "Throttle".
Tags
Return values
bool —FALSE if the message is empty, NULL if logging is muted
resetMock()
Sets mock index back to 0.
protected
resetMock([bool $mute = false ]) : mixed
This method is used for returning to the beginning of the mock file list.
Parameters
- $mute : bool = false
-
[optional]
Set to TRUE to prevent logging.
Return values
mixed —sendRequest()
Sends a request to Amazon via cURL
protected
sendRequest(string $url[, array<string|int, mixed> $param = [] ]) : array<string|int, mixed>
This method will keep trying if the request was throttled.
Parameters
- $url : string
-
URL to feed to cURL
- $param : array<string|int, mixed> = []
-
parameter array to feed to cURL
Return values
array<string|int, mixed> —cURL response array
sleep()
Sleeps for the throttle time and records to the log.
protected
sleep() : mixed