fulfillment / api-wrapper
A barebones wrapper for the FDC api to facailitate easier authentication and communication
Installs: 22 680
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 6
Forks: 1
Open Issues: 1
Requires
- foxxmd/php-utilities: dev-master
- guzzlehttp/guzzle: ~6.0
- league/climate: ~3.2
- vlucas/phpdotenv: 2.*
This package is auto-updated.
Last update: 2025-01-09 23:38:27 UTC
README
A barebones wrapper to ease authentication and low-level communication with FDC API
Example
use Fulfillment\Api\Api; $data = [ 'endpoint' => $endPoint, 'clientId' => $clientId, 'clientSecret' => $clientSecret, 'accessToken' => $accessToken, 'username' => $username, 'password' => $password ]; $apiClient = new Api($data); $newPostageClient = [ 'email' => 'some@email.com', 'clientId' => 2 ]; $returnedUser = $apiClient->post('users', $newPostageClient); //POST request with body as json $apiClient->get('users', ['clientId' => '2']); //GET request with query string ?clientId=2
Installation
composer require fulfillment/api-wrapper
Configuration
Authentication Configuration
Minimum requirements for auth -- you must have:
- client id
- client secret
- username
- password
- scope -- To use provide multiple scopes pass each scope delimited by a space EX
oms postage
AND/OR
- access token
Note that if the access token expires re-authentication cannot occur if credentials are not present.
Auth can be parsed using several options:
Array
$data = [ 'endpoint' => $endPoint, 'clientId' => $clientId, 'clientSecret' => $clientSecret, 'accessToken' => $accessToken, 'username' => $username, 'password' => $password, 'scope' => 'oms' ]; $apiClient = new Api($config)
DotEnv
Use a .env
file compatible with phpdotenv library. Simply specify the absolute path to the folder containing your .env
file as an argument in the constructor.
$fileLocation = __DIR__ . DIRECTORY_SEPARATOR . '.env'; $apiClient = new Api($fileLocation);
Environmental Variables
Use environmental variables (available in $_ENV
)
- USERNAME
- PASSWORD
- CLIENT_ID
- CLIENT_SECRET
- ACCESS_TOKEN
- API_ENDPOINT
- SCOPE
$apiClient = new Api();
NOTE: If an access token is generated the package will store a copy of the token either at __DIR__ . /logs
or the location returned by storage_path('logs/')
Logging Configuration
The package defaults to console output or file if STDOUT is not available. You may use your own logger by passing an object that implements League\CLImate\Util\Writer\WriterInterface
$apiClient = new Api($config, $logger);
Guzzle Configuration
You may use your own guzzle
instance by passing it into the constructor
$apiClient = new Api($config, $logger, $guzzle)
If no instance is passed a new one is created.
Usage
If credentials are provided the client can(will) authenticate itself if an access token is not present or invalid.
Basic requests are by using HTTP verbs methods:
- get($url, $queryString = null)
- post($url, $body, $queryString = null)
- patch($url, $body, $queryString = null)
- delete($url, $queryString = null)
$apiClient->get($url, $queryString); $apiClient->post($url, $body, $queryString); $apiClient->patch($url, $body, $queryString); $apiClient->delete($url, $queryString);
- $url is the relative url from the endpoint, it is concatenated before the request is sent --
$fullURl = $endPoint . '/' . $url;
- $body is an array or object that can be jsonified.
- $queryString is represented as a key/value array --
$queryString = ['myKey' => 'myValue']
is equivalent tohttp://endpoint/url?myKey=myValue
Helpers
Two functions are available to make response parsing more convenient:
parseError
This function will json decode RequestException
thrown by Guzzle and return the error object used by FDC as a standard object.
RequestParser::parseError($r)
getErrorCode
This will do the same as above will be only return an error code if one is present on the error.
RequestParser::getErrorCode($r)