定制 fredbradley/php-steer-api 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

fredbradley/php-steer-api

最新稳定版本:v1.0.5

Composer 安装命令:

composer require fredbradley/php-steer-api

包简介

A PHP Wrapper for the STEER Tracking API

README 文档

README

with Laravel Discovery Support

Latest Version on Packagist Total Downloads GitHub Actions

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.

Installation & Requirements

This package requires PHP 8.2 and above.

You can install the package via composer:

composer require fredbradley/php-steer-api

Usage

If within a Laravel Application with Laravel Discovery turned on

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.

Dependency Injection

The package will automatically register the SteerConnector class as a singleton. You can then use the SteerConnector class as a dependency in your classes.

Facade

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();

If using as a standalone package in any PHP application

$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 name
  • campus - filter by campus name
  • year - filter by year group
  • mis_id - filter by pupil's MIS ID
  • gender - filter by gender (desired value is m or f)
  • 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.

Caching

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.

Testing

composer pest

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security related issues, please email code@fredbradley.co.uk instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 813
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-10-26