danbelden/php-siren
Composer 安装命令:
composer require danbelden/php-siren
包简介
A PHP Library for handling Siren JSON hypermedia
README 文档
README
A PHP Library for handling Siren JSON hypermedia documents
Overview
This is a library based around the Siren hypermedia data standard:
It provides objects and validation for handling this structured data format.
Requires
PHP 5.3 and above.
Installation
Composer
To install this package with composer, run the following command:
composer require danbelden/php-siren "^1.0"
Documentation
Using the example target JSON defined in the standards:
$document = new Document();
$document->addClass('order');
$properties = [
'orderNumber' => 42,
'itemCount' => 3,
'status' => 'pending'
];
$document->setProperties($properties);
$entityOne = new Entity();
$entityOne->setClass([ 'items', 'collection' ])
->setRel([ 'http://x.io/rels/order-items' ])
->setHref('http://api.x.io/orders/42/items');
$entityTwoLink = new Link();
$entityTwoLink->setRel([ 'self' ])
->setHref('http://api.x.io/customers/pj123');
$entityTwo = new Entity();
$entityTwo->setClass([ 'info', 'customer' ])
->setRel([ 'http://x.io/rels/customer' ])
->setProperties([
'customerId' => 'pj123',
'name' => 'Peter Joseph'
])
->setLinks([ $entityTwoLink ]);
$entities = [ $entityOne, $entityTwo ];
$document->setEntities($entities);
$actionFieldOne = new Field();
$actionFieldOne->setName('orderNumber')
->setType('hidden')
->setValue('42');
$actionFieldTwo = new Field();
$actionFieldTwo->setName('productCode')
->setType('text');
$actionFieldThree = new Field();
$actionFieldThree->setName('quantity')
->setType('number');
$actionOne = new Action();
$actionOne->setName('add-item')
->setTitle('Add Item')
->setMethod('POST')
->setHref('http://api.x.io/orders/42/items')
->setType('application/x-www-form-urlencoded')
->setFields([ $actionFieldOne, $actionFieldTwo, $actionFieldThree ]);
$actions = [ $actionOne ];
$document->setActions($actions);
$linkOne = new Link();
$linkOne->setRel([ 'self' ])
->setHref('http://api.x.io/orders/42');
$linkTwo = new Link();
$linkTwo->setRel([ 'previous' ])
->setHref('http://api.x.io/orders/41');
$linkThree = new Link();
$linkThree->setRel([ 'next' ])
->setHref('http://api.x.io/orders/43');
$links = [ $linkOne, $linkTwo, $linkThree ];
$document->setLinks($links);
Enjoy.
统计信息
- 总下载量: 5.57k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2017-05-14