creads/api2symfony-bundle
最新稳定版本:1.0.0
Composer 安装命令:
composer require creads/api2symfony-bundle
包简介
A Symfony2 bundle to automatically generate controllers from standard API specifications (RAML, Blueprint, Swagger...)
README 文档
README
A Symfony2 bundle to automatically generate controllers from standard API specifications (RAML, Blueprint, Swagger...)
BUT... We only support the following specification formats now:
- RAML
But we'd like to also support:
- Blueprint
- Swagger
This bundle uses the api2symfony library.
Installation
Using composer:
composer require creads/api2symfony-bundle 1.0.*@dev
Register the bundle by updating AppKernel.php:
<?php
// in AppKernel::registerBundles()
if (in_array($this->getEnvironment(), ['dev', 'test'])) {
// ...
$bundles[] = new Creads\Api2SymfonyBundle\Api2SymfonyBundle();
// ...
};
Use case
The bundle provides a command:
app/console.php api2symfony:generate:raml path/to/api.raml Some\\Namespace
Example
php app/console.php api2symfony:generate:raml path/to/api.raml Acme\\DemoBundle
New controller dumped at app/cache/dev/api2symfony/Acme/DemoBundle/1_0_1_alpha/PostsController.php
#%RAML 0.8 title: Api Example version: 1.0.1-alpha /posts: description: Collection of available post resource get: description: Get a list of post post: description: Create a new post /{id}: displayName: Post get: description: Get a single post responses: 200: body: application/json: example: | { "title": "An amazing news" } delete: description: Delete a specific post /comments: description: Collection of available post's comments displayName: Comments get: description: Get list of comment for given post post: description: Comment a post
Generated code:
<?php namespace Acme\DemoBundle\1_0_1_alpha; use Symfony\Bundle\FrameworkBundle\Controller\Controller; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method; /** * Collection of available post resource * * This is an auto generated class provided by Creads\Api2Symfony PHP library. */ class PostsController extends Controller { /** * Get a list of post * * @Route("/posts", name="get_posts") * @Method({"GET"}) */ public function getPostsAction() { } /** * Create a new post * * @Route("/posts", name="post_posts") * @Method({"POST"}) */ public function postPostsAction() { } /** * Get a single post * * @Route("/posts/{id}", name="get_posts_post") * @Method({"GET"}) */ public function getPostsPostAction($id) { return new Response('{"title": "An amazing news"}', 200, array('Content-Type' => 'application/json')); } /** * Delete a specific post * * @Route("/posts/{id}", name="delete_posts_post") * @Method({"DELETE"}) */ public function deletePostsPostAction($id) { } /** * Get list of comment for given post * * @Route("/posts/{id}/comments", name="get_posts_post_comments") * @Method({"GET"}) */ public function getPostsPostCommentsAction($id) { } /** * Comment a post * * @Route("/posts/{id}/comments", name="post_posts_post_comments") * @Method({"POST"}) */ public function postPostsPostCommentsAction($id) { } }
统计信息
- 总下载量: 570
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 52
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2014-12-15