2017 © Pedro Peláez
 

symfony-bundle responsebuilder-bundle

Allows you easily create JSON/XML API response from the different types of objects.

image

itr/responsebuilder-bundle

Allows you easily create JSON/XML API response from the different types of objects.

  • Saturday, November 16, 2013
  • by itrdev
  • Repository
  • 2 Watchers
  • 0 Stars
  • 24 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

API Response Builder Bundle

Symfony bundle that allows you easily create JSON/XML API response from the different types of objects., (*1)

Getting Started

Composer

The best way to install ResponseBuilderBundle is through Composer., (*2)

  • Add itr/responsebuilder-bundle as a dependency in your project's composer.json file:
{
    "require": {
        "itr/responsebuilder-bundle": "dev-master"
    }
}
  • Install your dependencies:

``` bash $ php composer.phar update itr/responsebuilder-bundle, (*3)


- Enable the bundle ``` php <?php // app/AppKernel.php public function registerBundles() { $bundles = array( // ... new Itr\ResponseBuilderBundle\ItrResponseBuilderBundle(), ); }

Configuration

You can specify default builder format in your config.yml file: ``` yml itr_response_builder: default_format: json # default_format: json, (*4)

Basic Usage
===========
### ResponseBuilder

You can get ResponseBuilderFactory class directly:
``` php
<?php
    // creates factory object
    $responseBuilderFactory = new ResponseBuilderFactory('json');
    // gets default builder (here default format is json)
    $responseBuilder = $responseBuilderFactory->getDefault();
    // gets builder by specified format
    $responseBuilder = $responseBuilder->getBuilderForFormat('yml');

Or from service container for example from symfony controller: ``` php <?php $responseBuilderFactory = $this->get('response_builder_factory'); // gets default builder (default format could be specified in the configurations file like described above) $responseBuilder = $responseBuilderFactory->getDefault();, (*5)

### ParameterBag

- Simple example:

``` php
<?php
    $pb = new ParameterBag();
    $pb->{'level.second.third'} = 'hi';
    $array = $pb->toArray();
    // array('level' => array('second' => array('third' => 'hi'));

    $responseBuilderFactory = $this->get('response_builder_factory');
    $responseBuilder = $responseBuilderFactory->getDefault();
    // return Response object with parameter bag processed into specified format (json or xml)
    $response = $responseBuilder->build($pb);
  • Simple Doctrine entity example:

Let say we have account entity like this: ``` php <?php class Account { private $id;, (*6)

    private $username;

    private $email;

    // getters and setters below
    ...
}

Now you can process it this way: ``` php <?php $account = new Account(); $account->setUsername('noname'); $account->setEmail('test@example.com'); $account->setPassword('123456'); $pb = new ParameterBag(); $pb->{'account'} = $account; $array = $pb->toArray(); /* Account entity processed as array: array('account' => array( 'username' => 'noname', 'email' => 'test@example.com', 'password' => '123456', ); */ // then you can change any value by accessing it directly by its path: $pb->{'account.username'} = 'some new username'; $responseBuilderFactory = $this->get('response_builder_factory'); $responseBuilder = $responseBuilderFactory->getDefault(); $response = $responseBuilder->build($pb);
  • Complex Doctrine entity example:

Let say account also have reference on a profile object: ``` php <?php class Account { private $id;, (*7)

    private $username;

    private $email;

    // Profile
    private $profile;

    // getters and setters below
    ...
}

Profile entity: ``` php <?php class Profile { private $id; private $fullname; private $age; // getters and setters below ... }

Processing entity with subentity: ``` php <?php $profile = new Profile(); $profile->setFullname('Jack Jonson'); $profile->setAge(37);, (*8)

$account = new Account();
$account->setUsername('noname');
$account->setEmail('test@example.com');
$account->setPassword('123456');
$account->setProfile($profile);

$pb = new ParameterBag();
$pb->{'account'} = $account;
$array = $pb->toArray();

/*
    Entity with sub entity will be processed like this:

    array('account' => array(
            'username' => 'noname',
            'email' => 'test@example.com',
            'password' => '123456',
            'profile' => array(
                'fullname' => 'Jack Jonson',
                'age' => 37,
            )
    );
*/

```, (*9)

TODO

  • ParameterBag code refactoring.

The Versions

16/11 2013

dev-master

9999999-dev

Allows you easily create JSON/XML API response from the different types of objects.

  Sources   Download

MIT

The Requires

 

The Development Requires

api json xml doctrine response