violines/rest-bundle

violines/rest-bundle 是一个用于创建 REST API 的 Symfony 扩展包。它专注于 HTTP 标准,并集成了 symfony/serializer 和 symfony/validator。

安装: 184

依赖: 0

建议者: 0

安全: 0

星星: 35

关注者: 4

分支: 1

开放问题: 2

类型:symfony-bundle

v0.8.1 2022-03-09 13:05 UTC

This package is auto-updated.

Last update: 2024-09-09 18:38:54 UTC


README

violines/rest-bundle 是一个用于创建 REST API 的 Symfony 扩展包。它专注于 HTTP 标准,并集成了 symfony/serializer 和 symfony/validator。

build Code Coverage Mutation testing badge type coverage Technical Debt Software License Wiki Docs

功能

  • 请求体或查询字符串到对象的转换
  • 从对象构建响应
  • 可配置的内容协商
  • 事件以控制 symfony/serializer 上下文
  • symfony/validator 的集成
  • 错误处理
  • 可选日志记录

兼容于...

  • Symphony 5.4 + 6
  • PHP 8 + 8.1

设计用于...

应用领域驱动设计原则、六边形架构或类似概念的现代化架构。

安装

composer require violines/rest-bundle

它是如何工作的?

  1. 创建任何 PHP 类(实体、DTO、命令、查询等)并添加 #[HttpApi] 属性或 @HttpApi 注解
  2. 使用 symfony/serializer 或 symfony/validator 中的任何属性属性/注解
  3. 将此 PHP 类声明为控制器参数的类型
  4. 在控制器中返回此 PHP 类的实例

案例展示

在以下链接下找到使用示例:https://github.com/violines/rest-bundle-showcase

示例

<?php

declare(strict_types=1);

namespace App\Entity;

#[Violines\RestBundle\HttpApi\HttpApi]
final class Order
{
    public $amount;
    public $articles;
}

// Or use Doctrine Annotations (requires separate install):
// In order to use Annotations you have to install `doctrine/annotations` via `composer require doctrine/annotations`

/**
 * @Violines\RestBundle\HttpApi\HttpApi
 */
final class Order {}
<?php

declare(strict_types=1);

namespace App\Controller;

use App\Exception\AuthenticationFailedException;
use App\Entity\Order;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;

class OrderController
{
    /**
     * @return Order[]
     */
    #[Route('/orders', methods: ['GET'], name: 'find_orders')]
    public function findOrders(): array
    {
        return $this->orderRepository->findOrders();
    }

    #[Route('/order/{id}', methods: ['GET'], name: 'find_order')]
    public function findOrder(int $id): Order
    {
        $order = $this->orderRepository->find($id);

        if (null === $order) {
            throw NotFoundException::id($id);
        }

        return $order;
    }

    /**
     * @param Order[] $orders
     */
    #[Route('/orders/create', methods: ['POST'], name: 'create_orders')]
    public function createOrders(Order ...$orders): Response
    {
        $this->orderRepository->createOrders($orders);

        return new Response(null, Response::HTTP_CREATED);
    }

    #[Route('/order/create', methods: ['POST'], name: 'create_order')]
    public function createOrder(Order $order): Response
    {
        $this->orderRepository->create($order);

        return new Response(null, Response::HTTP_CREATED);
    }
}

维基

欲了解更多详情,请查阅 violines/rest-bundle 维基

开发设置

  1. 将 docker/.env.dist 复制到 docker/.env 并根据需要调整
  2. cd docker/
  3. 拉取最新镜像:docker-compose pull
  4. 创建容器:docker-compose up -d
  5. 使用 docker-compose exec php80 composer run test 运行测试