STEER Education are in the process of developing an API to access the assessment results for pupils. I am helping them with this as we have already many of the building blocks in place with Cranleigh School's Pastoral Module.
This package is a PHP wrapper to the STEER API. Any suggestions or improvements are welcome both in terms of data output and the fluency of interacting with the code.
This package requires PHP 8.2 and above.
You can install the package via composer:
composer require fredbradley/php-steer-api
You will need to add the following to your .env
file:
STEER_API_KEY=
STEER_SUBSCRIPTION_KEY=
STEER_BASE_URL=
The config file is publishable, but you shouldn't need to change anything.
The package will automatically register the SteerConnector
class as a singleton. You can then use the SteerConnector
class as a dependency in your classes.
There is a facade that goes with the package if that's how you choose to work. Example:
use FredBradley\PhpSteerApi\Facades\Steer;
use FredBradley\PhpSteerApi\QueryBuilder;
// Set the Query Builder
$query = (new QueryBuilder())->setYear(2022);
// Get the Data
$data = Steer::getAssessmentData($query)->object();
$service = new \FredBradley\PhpSteerApi\SteerConnector($apiKey, $subscriptionKey, $baseUrl);
$service
->getAssessmentData(
filters: [
"house" => "Hufflepuff",
"year" => 10
],
year: 2019
)
->object();
This will return an object with a data
property which is an array of objects. Each object is the STEER tracking
assessment result.
The second argument in getAssessmentData
(year
) is optional and will default to the current academic year if not set. The STEER API carries data for 5 yars.
Filters available are:
house
- filter by house namecampus
- filter by campus nameyear
- filter by year groupmis_id
- filter by pupil's MIS IDgender
- filter by gender (desired value ism
orf
)round
- filter by round (as in the round of assessment)
With no filters set, the API will return all results for the current academic year.
See the example output here.
This package uses the Saloon API package to make the HTTP requests. You can read more about that package here.
By default the package will cache unique results (based on query) for 10 minutes. It uses the Local Filesystem cache driver from Saloon. You can read more about that here.
composer pest
Please see CHANGELOG for more information what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email code@fredbradley.co.uk instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.