Download the PHP package bnsoftware/lti-1p3-tool without Composer
On this page you can find all versions of the php package bnsoftware/lti-1p3-tool. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package lti-1p3-tool
LTI 1.3 Tool Library
THIS IS A WORK IN PROGRESS - YOU SHOULD NOT USE THIS LIBRARY AT THIS TIME!!
If you're looking for a solid LTI v1.3 PHP package definitely check out packbackbooks/lti-1p3-tool created by Packback
A library used for building IMS-certified LTI 1.3 tool providers in PHP.
This library allows a tool provider (your app) to receive LTI launches from a tool consumer (i.e. LMS). It validates LTI launches and lets an application interact with services like the Names Roles Provisioning Service (to fetch a roster for an LMS course) and Assignment Grades Service (to update grades for students in a course in the LMS).
This library was forked from packbackbooks/lti-1p3-tool created by Packback, which was in turn forked from IMSGlobal/lti-1-3-php-library, initially created by @MartinLenord.
Installation
Run:
In your code, you will now be able to use classes in the BNSoftware\Lti1p3
namespace to access the library.
Configure JWT
Add the following when bootstrapping your app.
Implement Data Storage Interfaces
This library uses three methods for storing and accessing data: cache, cookie, and database. All three must be implemented in order for the library to work. You may create your own custom implementations so long as they adhere to the following interfaces:
BNSoftware\Lti1p3\Interfaces\ICache
BNSoftware\Lti1p3\Interfaces\ICookie
BNSoftware\Lti1p3\Interfaces\IDatabase
View the Laravel Implementation Guide to see examples (or copy/paste the code outright). Cache and Cookie storage have legacy implementations at BNSoftware\Lti1p3\ImsStorage\
if you do not wish to implement your own. However, you must implement your own database.
Create a JWKS endpoint
A JWKS (JSON Web Key Set) endpoint can be generated for either an individual registration or from an array of KID
s and private keys.
Documentation
The wiki provides more detailed information about how to use this library, including a Laravel Implementation Guide.
Contributing
For improvements, suggestions or bug fixes, make a pull request or an issue. Before opening a pull request, add automated tests for your changes, ensure that all tests pass, and any linting errors are fixed.
Testing
Automated tests can be run using the command:
Linting can be run using
All versions of lti-1p3-tool with dependencies
firebase/php-jwt Version ^5.5|^6.0
guzzlehttp/guzzle Version ^7.0.1
phpseclib/phpseclib Version ^3.0
ext-json Version *