Download the PHP package paknahad/jsonapi-bundle without Composer

On this page you can find all versions of the php package paknahad/jsonapi-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package jsonapi-bundle

Latest Stable Version test workflow License: MIT Total Downloads

JsonApiBundle For Symfony

JsonApiBundle is a Symfony bundle. It is the fastest way to generate API based on JsonApi using woohoolabs/yin Library.

Installing

  1. Install symfony

  2. Install the maker bundle

  3. Install the bundle

    For Symfony 4 use:

  4. Add below line to config/bundles.php

Usage

  1. Use below command to generate entities one by one:

    for example, Book and Author entity is as follows:

  2. Generate CRUD API:

  3. You can find the generated "collections" for postman and swagger in the following path and then test the API:

Features

Pagination

Sorting

Relationships

multiple relationships

Search

As the JSON API specification does not specify exactly how filtering should work different methods of filtering can be used. Each method is supplied with a Finder service. Each registered Finder will be able to append conditions to the search query. If you register multiple Finders they are all active at the same time. This enables your API to support multiple filtering methods.

Basic Finder.

A basic Finder is included in this library offering simple filtering capabilities:

This request will return all the books that author's name begin with hamid

Below line has additional condition: books which have "php" in their title.

Setting a default filter on the IndexAction

By using you can get access on the query object. use "r" alias for referring to the current entity. in this example the "r" refers to the "ProjectEntity"

Other Finders

Currently, the following Finders are available via other bundles:

Creating a custom Finder

A Finder can be registered via a service tag in the services definition. The tag paknahad.json_api.finder must be added to the service for the Finder to be resigered.

Example:

Each Finder must implement the Paknahad\JsonApiBundle\Helper\Filter\FinderInterface interface. Take a look at \Paknahad\JsonApiBundle\Helper\Filter\Finder for an implementation example.

If you need more control over the finders, you can instead use \Paknahad\JsonApiBundle\Helper\Filter\FinderSupportsInterface interface and implement conditional logic inside supports() method:

Validation

Error on validating associations

Validate attributes if you have defined validators on entities.

Error handler

All errors such as:

has responses like this:

NOTICE: the "meta" field gets filled just on development environment.

Configuration

You can configure this bundle with following options:

Supported documentation schemas are openapi and swagger. If you want to generate controllers in a different namespace, for example Controller\Api you can use controllerNamespace configuration option. To prefix Api routes you can use Symfony routes configuration:


All versions of jsonapi-bundle with dependencies

PHP Build Version
Package Version
Requires php Version >=7.1.3
ext-json Version *
sensio/framework-extra-bundle Version ^5.5|^6.0
symfony/orm-pack Version ^1.0|^2.0
symfony/proxy-manager-bridge Version ^4.4|^5.0|^6.0
symfony/psr-http-message-bridge Version ^2.0
symfony/validator Version ^4.4|^5.0|^6.0
doctrine/inflector Version ^2.0
woohoolabs/yin Version ^4.3
nyholm/psr7 Version ^1.4
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package paknahad/jsonapi-bundle contains the following files

Loading the files please wait ....