PHPackages                             longhornopen/lti - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [API Development](/categories/api)
4. /
5. longhornopen/lti

ActiveLibrary[API Development](/categories/api)

longhornopen/lti
================

PHP class library for building LTI integrations

v5.3.2.1(2mo ago)233.4k↓16.8%31LGPL-3.0-or-laterPHPPHP &gt;=8.1

Since Apr 3Pushed 2mo ago1 watchersCompare

[ Source](https://github.com/longhornopen/LTI-PHP)[ Packagist](https://packagist.org/packages/longhornopen/lti)[ Docs](https://github.com/celtic-project/LTI-PHP)[ RSS](/packages/longhornopen-lti/feed)WikiDiscussions master Synced 2d ago

READMEChangelog (10)Dependencies (6)Versions (16)Used By (1)

This set of PHP classes encapsulates the code required by an LTI compliant tool provider to communicate with an LTI tool consumer. It includes support for LTI 1.1 and the unofficial extensions to Basic LTI, as well as the registration process and services of LTI 1.2/2.0, and the new security model introduced by LTI 1.3. The Names and Role Provisioning service and the Assignment and Grade services (Line Item, Result and Score) are also supported using either of the LTI security models.

These classes are designed as an update to the [LTI Tool Provider class library](http://www.spvsoftwareproducts.com/php/lti_tool_provider/) and a replacement for the library at  which is no longer supported.

Whilst supporting LTI is relatively simple, the benefits to using a class library like this one are:

- the abstraction layer provided by the classes keeps the LTI communications separate from the application code;
- the code can be re-used between multiple tool providers;
- LTI data is transformed into useful objects and missing data automatically replaced with sensible defaults;
- the outcomes service function uses LTI 1.1 or the unofficial outcomes extension according to whichever is supported by the tool consumer;
- the unofficial extensions for memberships and setting services are supported;
- additional functionality is included to:
    - enable/disable a consumer key;
    - set start and end times for enabling access for each consumer key;
    - set up arrangements such that users from different resource links can all collaborate together within a single tool provider link;
- LTI applications can take advantage of LTI updates with minimal impact on their code.

The GitHub repository provides access to the [source files](https://github.com/celtic-project/LTI-PHP) and [documentation](https://github.com/celtic-project/LTI-PHP/wiki). The example [Rating LTI application](https://github.com/celtic-project/Rating-PHP) is based on this library to further illustrate how it can be used.

###  Health Score

52

—

FairBetter than 96% of packages

Maintenance83

Actively maintained with recent releases

Popularity33

Limited adoption so far

Community17

Small or concentrated contributor base

Maturity62

Established project with proven stability

 Bus Factor1

Top contributor holds 92.7% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~91 days

Recently: every ~42 days

Total

13

Last Release

88d ago

Major Versions

v4.10.1.3 → v5.0.0.02023-10-05

PHP version history (2 changes)v4.10.1PHP &gt;=5.6.0

v5.0.0.0PHP &gt;=8.1

### Community

Maintainers

![](https://www.gravatar.com/avatar/f2fa468439b186a7e503b68200ef2583816c247e0431153b47298e607d41619a?d=identicon)[longhornopen](/maintainers/longhornopen)

---

Top Contributors

[![spvickers](https://avatars.githubusercontent.com/u/3266092?v=4)](https://github.com/spvickers "spvickers (394 commits)")[![chrispittman](https://avatars.githubusercontent.com/u/918414?v=4)](https://github.com/chrispittman "chrispittman (20 commits)")[![scollovati](https://avatars.githubusercontent.com/u/20740642?v=4)](https://github.com/scollovati "scollovati (8 commits)")[![Izumi-kun](https://avatars.githubusercontent.com/u/1062584?v=4)](https://github.com/Izumi-kun "Izumi-kun (2 commits)")[![abertranb](https://avatars.githubusercontent.com/u/854229?v=4)](https://github.com/abertranb "abertranb (1 commits)")

---

Tags

LTI

### Embed Badge

![Health badge](/badges/longhornopen-lti/health.svg)

```
[![Health](https://phpackages.com/badges/longhornopen-lti/health.svg)](https://phpackages.com/packages/longhornopen-lti)
```

###  Alternatives

[statamic/cms

The Statamic CMS Core Package

4.8k3.6M985](/packages/statamic-cms)[darkaonline/l5-swagger

OpenApi or Swagger integration to Laravel

3.0k37.6M134](/packages/darkaonline-l5-swagger)[knuckleswtf/scribe

Generate API documentation for humans from your Laravel codebase.✍

2.3k14.2M63](/packages/knuckleswtf-scribe)[firefly-iii/data-importer

Firefly III Data Import Tool.

8045.8k](/packages/firefly-iii-data-importer)[celtic/lti

PHP class library for building LTI integrations

60312.6k9](/packages/celtic-lti)[packbackbooks/lti-1p3-tool

A library used for building IMS-certified LTI 1.3 tool providers in PHP.

53491.7k2](/packages/packbackbooks-lti-1p3-tool)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
