afosto/data

Afosto data models for the API

Installs: 334

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:package

0.1.0 2017-04-20 13:32 UTC

This package is auto-updated.

Last update: 2024-03-23 20:05:29 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