afosto / data
Afosto data models for the API
Installs: 717
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:package
Requires
- afosto/bp: ^2.0
Requires (Dev)
- filp/whoops: ^2.1
- symfony/console: ^3.2
- symfony/var-dumper: ^3.2
This package is auto-updated.
Last update: 2024-11-23 21:26:00 UTC
README
Abstraction of the data models that are to be used to interact with our API. Currently this package has support for the following 'Operations':
More operations are to be included soon. If you see a great usecase for this but need more information just contact us at support@afosto.com.
##Why
There already is an Api Client, why do I need this package? Well have concluded that the api client as it is right now it to tightly coupled with the API and interacting with it. This package is part of a bigger idea that we want to decouple parts that might be usefull for interaction with the API.
For instance you can already use the separated oauth-client to solve your problems in obtaining authentication for the API.
Getting Started
Simply follow the installation instructions.
Prerequisites
What things you need to install the software and how to install them
- PHP5.5+
- Composer (for installation)
Installing
Installing is easy through Composer.
composer require afosto/data
Examples
Now to build a product model:
$product = new Product();
Set the values inline:
$product->weight = 10; $product->supplier = new Supplier(); $product->supplier->id = 1; $product->supplier->name = 'TestSupplier';
Or use setAttributes to set data based on an input array
$item = new Item(); $item->setAttributes([ 'sku' => 'TEST-SKU-234', 'ean' => '234554245', 'prices' => [ [ 'price_gross' => 23.54, 'tax_class' => [ 'id' => 2, ], ], ], ]); $product->items[] = $item;
Optionally validate the newly generated model:
$product->validate();
Returns the structured data as an array:
$product->getAttributes();
Versioning
We use SemVer for versioning. For the versions available, see the tags on this repository.
License
This project is licensed under the Apache License 2.0 - see the LICENSE.md file for details