awwar/php-http-entity-manager
最新稳定版本:1.0.0-rc
Composer 安装命令:
composer require awwar/php-http-entity-manager
包简介
Doctrine-like http client
README 文档
README
A library that allows you to work with external APIs in the same way that a Symfony Doctrine ORM works with databases.
for example:
$users = $this->httpEntityManager->getRepository(User::class); $admins = $this->httpEntityManager->getRepository(Admin::class); $sasha = $users->find(124); $alex = $admins->filterOne(['filter' => ['specialization' => 'cinema']]); $deal = Deal::create($sasha, $alex, "buying a movie ticket", 30); $sasha->getDeals()->add($deal); $alex->setSpecialization('cinema'); $this->httpEntityManager->persist($deal); $this->httpEntityManager->flush();
real requests:
# get customer curl --request GET \ --url 'https://api.mysite.com/users/124' # get responsible curl --request GET \ --url 'https://api.mysite.com/admins?filter[specialization]=cinema' # create deal curl --request POST \ --url https://api.mysite.com/deals/ \ --data '{ "amount": 30, "title": "buying a movie ticket", "relations": [ {"name": "customer", "id": 124} {"name": "responsible", "id": 555} ] ' # add created deal to customer curl --request PATCH \ --url https://api.mysite.com/users/124 \ --data '{ "relations": [ {"name": "deal", "id": 322} ] '
As we can see, all the changes were applied in the right order, and the changes by Alex did not apply at all, because we didn't change the value of his specialization. All thanks to UnitOfWork, which tracks changes and executes them in the right sequence and does not allow unnecessary changes that could affect system performance.
Looks simple? See more!
统计信息
- 总下载量: 10
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-04-02