adrotec/webapi-bundle
Unmaintained Symfony 2 bundle for building web APIs with breeze.server.php. Registers an adrotec_webapi service to map request resources to entities and handle API requests, while overriding some JMSSerializerBundle behaviors (naming, lazy loading, etc.).
This project is no longer maintained. We will not be accepting pull requests, addressing issues, nor making future releases.
This is a Symfony 2bundle to create Web APIs with breeze.server.php
"require": {
"adrotec/webapi-bundle": "dev-master",
"symfony/validator": "dev-master"
}
"symfony/validator": "dev-master" is required for validations with breeze.server.php to work properly
AppKernel.php<?php
// app/AppKernel.php
public function registerBundles()
{
$bundles = array(
// ...
new JMS\SerializerBundle\JMSSerializerBundle(),
new Adrotec\WebApiBundle\AdrotecWebApiBundle(),
// ...
);
}
The order is important here because AdrotecWebApiBundle overrides some of the JMSSerializerBundle behaviours. E.g: Naming strategy, Lazy loading, etc.
Add routing configuration
# src/EmpDirectory/Bundle/Resources/config/routing.yml
emp_directory_api:
path: /api/{resource}
defaults: { _controller: EmpDirectoryBundle:Api:api }
the request parameter {resource} is important here, since it is used by the library to identify the current request resource.
The bundle exposes a service named adrotec_webapi which you can use in your controller.
// src/EmpDirectory/Bundle/Controller/ApiController.php
namespace EmpDirectory\Bundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
class ApiController extends Controller
{
public function apiAction(Request $request)
{
$api = $this->container->get('adrotec_webapi');
$api->addResources(array(
'Employees' => 'EmpDirectory\Bundle\Entity\Employee',
'Departments' => 'EmpDirectory\Bundle\Entity\Department',
'Jobs' => 'EmpDirectory\Bundle\Entity\Job',
));
// $request->attributes->set($request->attributes->get('resource'));
$response = $api->handle($request);
return $response;
}
}
How can I help you explore Laravel packages today?