cloudcreativity / laravel-json-api by lindyhopchris

JSON API (jsonapi.org) support for Laravel applications.
941,360
781
31
Package Data
Maintainer Username: lindyhopchris
Maintainer Contact: info@cloudcreativity.co.uk (Cloud Creativity Ltd)
Package Create Date: 2015-09-08
Package Last Update: 2024-03-14
Home Page: http://laravel-json-api.readthedocs.io/en/latest/
Language: PHP
License: Apache-2.0
Last Refreshed: 2024-12-19 03:18:59
Package Statistics
Total Downloads: 941,360
Monthly Downloads: 6,888
Daily Downloads: 260
Total Stars: 781
Total Watchers: 31
Total Forks: 109
Total Open Issues: 27

Build Status

cloudcreativity/laravel-json-api

Build feature-rich and standards-compliant APIs in Laravel.

This package provides all the capabilities you need to add JSON API compliant APIs to your application. Extensive support for the specification, including:

  • Fetching resources
  • Fetching relationships
  • Inclusion of related resources (compound documents)
  • Sparse fieldsets.
  • Sorting.
  • Pagination.
  • Filtering
  • Creating resources.
  • Updating resources.
  • Updating relationships.
  • Deleting resources.
  • Validation of:
    • JSON API documents; and
    • Query parameters.

The following additional features are also supported:

  • Full support for Eloquent resources, with features such as:
    • Automatic eager loading when including related resources.
    • Easy relationship end-points.
    • Soft-deleting and restoring Eloquent resources.
    • Page and cursor based pagination.
  • Asynchronous processing.
  • Support multiple media-types within your API.
  • Generators for all the classes you need to add a resource to your API.

Installation instructions and documentation are available on Read the Docs.

Credit where credit is due: this package is based on the framework agnostic package neomerx/json-api.

What is JSON API?

From jsonapi.org

If you've ever argued with your team about the way your JSON responses should be formatted, JSON API is your anti-bikeshedding weapon.

By following shared conventions, you can increase productivity, take advantage of generalized tooling, and focus on what matters: your application. Clients built around JSON API are able to take advantage of its features around efficiently caching responses, sometimes eliminating network requests entirely.

For full information on the spec, plus examples, see http://jsonapi.org.

Demo

A demo application is available at here.

Laravel Versions

| Laravel | This Package | EOL? | | --- | --- | --- | | 5.8.* | ^1.0 | - | | 5.7.* | ^1.0 | - | | 5.6.* | ^1.0 | - | | 5.5.* | ^1.0 | - | | 5.4.* | 1.0.0-beta.3 | EOL |

Make sure you consult the Upgrade Guide when upgrading.

Lumen

Currently we have not integrated the package with Lumen. We do not have any active projects that use Lumen, so if you do and can help, please let us know on this issue.

Documentation

Documentation is available on Read the Docs.

License

Apache License (Version 2.0). Please see License File for more information.

Installation

Installation is via composer. See the documentation for complete instructions.

Contributing

Contributions are absolutely welcome. Ideally submit a pull request, even more ideally with unit tests. Please note the following:

  • Bug Fixes - submit a pull request against the master branch.
  • Enhancements / New Features - submit a pull request against the develop branch.

We recommend submitting an issue before taking the time to put together a pull request.