Output complex, flexible, AJAX/RESTful data structures.

Daniel Supernault faff10c9f3 Update ArraySerializer 6 år sedan
src faff10c9f3 Update ArraySerializer 6 år sedan
test 4862136c1e Make attributes an empty object if there are no attributes. 6 år sedan
.gitattributes 219022e303 Update .gitattributes 9 år sedan
.gitignore a2bd78c535 Cheer up SensionLab insight. 10 år sedan
.scrutinizer.yml c270763a8a Fix: Only collect and report coverage once 9 år sedan
.travis.yml 757944242c Start testing on PHP 7.2 7 år sedan
CHANGELOG.md d40b1b4c97 Update CHANGELOG.md 7 år sedan
CONDUCT.md cfd631188c added conduct, updated changelog. 9 år sedan
CONTRIBUTING.md aa50771989 update github url in CONTRIBUTING.md 10 år sedan
Guardfile 630bee69f6 Whitespace fixes 10 år sedan
LICENSE 246a9a2198 New email 9 år sedan
README.md 4c24a1468f Update README.md 8 år sedan
composer.json 9a6712f380 Update composer.json 6 år sedan
phpunit.xml.dist 4f486dad2c Added some stubs for more realistic tests. 10 år sedan

README.md

Fractal

Latest Version Software License Build Status Coverage Status Quality Score Total Downloads

Fractal provides a presentation and transformation layer for complex data output, the like found in RESTful APIs, and works really well with JSON. Think of this as a view layer for your JSON/YAML/etc.

When building an API it is common for people to just grab stuff from the database and pass it to json_encode(). This might be passable for "trivial" APIs but if they are in use by the public, or used by mobile applications then this will quickly lead to inconsistent output.

Goals

  • Create a protective shield between source data and output, so schema changes do not affect users
  • Systematic type-casting of data, to avoid foreach()ing through and (bool)ing everything
  • Include (a.k.a embedding, nesting or side-loading) relationships for complex data structures
  • Work with standards like HAL and JSON-API but also allow custom serialization
  • Support the pagination of data results, for small and large data sets alike
  • Generally ease the subtle complexities of outputting data in a non-trivial API

This package is compliant with PSR-1, PSR-2 and PSR-4. If you notice compliance oversights, please send a patch via pull request.

Install

Via Composer

$ composer require league/fractal

Requirements

The following versions of PHP are supported by this version.

  • PHP 5.4
  • PHP 5.5
  • PHP 5.6
  • PHP 7.0
  • PHP 7.1
  • HHVM

Documentation

Fractal has full documentation, powered by Jekyll.

Contribute to this documentation in the gh-pages branch.

Todo

  • add HAL serializers

Testing

$ phpunit

Contributing

Please see CONTRIBUTING and CONDUCT for details.

Credits

License

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