chrgriffin / wave-api
Simple PHP client to utilize Webaim's WAVE API.
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/chrgriffin/wave-api
Requires
- php: ^7.1
- guzzlehttp/guzzle: ^6.3
Requires (Dev)
- phpunit/phpunit: ^7.5
This package is auto-updated.
Last update: 2025-10-08 09:19:26 UTC
README
wave-api is a strongly typed package for interacting with Webaim's WAVE API.
Requirements
wave-api requires PHP 7.1 or greater. You will also need to create an account with the WAVE API in order to use it.
Installation
You can install via composer:
composer install chrgriffin/wave-api
Usage
Basic Usage
Using the client is extremely simple:
require_once './vendor/autoload.php'; use ChrGriffin\WaveApi\Client as WaveClient; $wave = new WaveClient('my-api-key'); $response = $wave->analyze('my-url');
Additional Parameters
If you want to specify optional parameters, such as viewportwidth, reporttype, or format, there are multiple ways to do so.
Firstly, you can specify any additional parameters when instantiating the client:
$wave = new WaveClient('my-api-key', [ 'viewportwidth' => 1440, 'reporttype' => 2, 'format' => 'json' ]);
Secondly, you can specify any additional parameters when making the request:
$response = $wave->analyze('my-url', [ 'viewportwidth' => 1440, 'reporttype' => 2, 'format' => 'json' ]);
Or thirdly, you can chain multiple setters:
$wave->setViewportwidth(1440) ->setReporttype(2) ->setFormat('json') ->analyze('my-url);
Response Format
The format parameter has two valid options: json and xml. Setting this parameter will change the response type:
- if format is
json, then$wave->analyze()will return a\stdClassobject - if format is
xml, then$wave->analyze()will return a\SimpleXMLElementobject
Documentation
Available Methods
getClient() : GuzzleHttp\Client(by default)setClient($client) : ChrGriffin\WaveApi\Client$client: Replace the default GuzzleHttp client with your own.
getKey() : stringsetKey(string $key) : ChrGriffin\WaveApi\Client$key: Your WAVE API key.
getFormat() : string(jsonby default)setFormat(string $format) : ChrGriffin\WaveApi\Client$format: The desired report format. An exception will be thrown if the value is neitherjsonnorxml.
getViewportwidth() : intsetViewportwidth(int $viewportwidth) : ChrGriffin\WaveApi\Client$viewportwidth: The desired viewport width when analyzing.
getEvaldelay() : intsetEvaldelay(int $evaldelay) : ChrGriffin\WaveApi\Client$evaldelay: The desired number of milliseconds to wait before analyzing.
getReporttype() : intsetReporttype(int $reporttype) : ChrGriffin\WaveApi\Client$reporttype: The desired report type. An exception will be thrown if the value is none of1,2, or3.
getUsername() : stringsetUsername(string $username) : ChrGriffin\WaveApi\Client$username: The desired username for basic HTTP authentication to the given URL.
getPassword() : stringsetPassword(string $password) : ChrGriffin\WaveApi\Client$password: The desired password for basic HTTP authentication to the given URL.
getResponseContents() : null|\stdClass|\SimpleXMLElement_(will be null before a request is made)setParams(array $params) : ChrGriffin\WaveApi\Client$params: An associative array of any or all paramaters. Valid paramaters:format : string(must be one ofjsonorxml)viewportwidth : intevaldelay : intreporttype : int(must be one of1,2, or3)username : stringpassword : string
analyze(string $url, array $params = []) : \stdClass|\SimpleXMLElement$url: The desired URL to analyze.$params: An associative array of any or all paramaters. Valid paramaters:format : string(must be one ofjsonorxml)viewportwidth : intevaldelay : intreporttype : int(must be one of1,2, or3)username : stringpassword : string
Exceptions
- A
\TypeErrorwill be thrown whenever an invalidly typed parameter is passed to a method (refer to the above documentation for valid types). - A
ChrGriffin\WaveApi\Exceptions\InvalidArgumentException(extends\InvalidArgumentException)will be thrown in the following instances:- Trying to set
formatto an invalid value (not one ofxmlorjson). - Trying to set
reporttypeto an invalid value (not one of1,2, or3). - Trying to set a parameter that doesn't exist.
- Trying to set
- A
ChrGriffin\WaveApi\Exceptions\ResponseExceptionwill be thrown when the WAVE API responds with an error. The error, if provided, will be the exception's message.