Download the PHP package webinarium/linode-api without Composer
On this page you can find all versions of the php package webinarium/linode-api. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Table of contents
Download webinarium/linode-api
More information about webinarium/linode-api
Files in webinarium/linode-api
Download webinarium/linode-api
More information about webinarium/linode-api
Files in webinarium/linode-api
Vendor webinarium
Package linode-api
Short Description Linode API Client Library
License MIT
Homepage https://github.com/webinarium/linode-api
Package linode-api
Short Description Linode API Client Library
License MIT
Homepage https://github.com/webinarium/linode-api
Please rate this library. Is it a good library?
Informations about the package linode-api
Linode API Client Library
This package provides a PHP client library for Linode API. The library is up-to-date with API 4.171.0 released on 2024-02-01.
Requirements
PHP needs to be a minimum version of PHP 8.1.
Installation
The recommended way to install is via Composer:
Usage
Basic Usage
Access to all API endpoints goes through an instance of `LinodeClient` class, which you have to create first: The example above creates an unauthenticated client which is enough to access few public endpoints like _regions_ or _kernels_. To access your private data you need to provide `LinodeClient` with your access token: Access token can be a manually generated _Personal Access Token_ or a retrieved one from OAuth workflow. You can use [oauth2-linode](https://github.com/webinarium/oauth2-linode) library to authenticate in Linode using OAuth.
Errors
Any API request to Linode can fail. In this case Linode API returns list of errors, each consists of `reason` (a human-readable error message, always included) and `field` (a specific field in the submitted JSON, `null` when not applicable). The library throws a `LinodeException` each time a request is failed. The message of the exception is always a message of the first error in the errors list. You can also get all errors from the exception using its `getErrors` function.
Entities and Repositories
The library provides an _entity_ class for every object returned by Linode API - _linodes_, _images_, _nodebalancers_, whatever. All entities are read-only, the data are accessible through properties. Also, there is a dedicated repository for entity of each type. Most of the repositories are available through the `LinodeClient` class: Some entities are nested, for example `DomainRecord` objects always belong to some `Domain` object. A repository for such nested entities should be taken from corresponding parent entity. The `LinodeClient` class contains repositories for root entities only. To make it easier to find corresponding entity and repository, the library sources are structured the same way as the original API documentation.
Repositories and Collections
Each repository implements `Linode\RepositoryInterface` and provides two following functions. The `find` function searches for an entity by its ID: The `findAll` function returns all entities of the type as a `Linode\EntityCollection` object. Such object implements standard `Countable` and `Iterator` interfaces:
Pagination
When you are retrieving a list of objects from Linode API, the API returns the list paginated. To make your life easier, the library manages the pagination for you internally, so you can work with a list of entities as with a simple array. For example, let's assume you have 270 linodes in your account and need to enumerate their labels: When you call `findAll` function in this example, only first 100 entities are loaded (100 is a default page size in the API). Once you reach 101st entity in your enumeration, the library makes another call for next 100 linodes, and so on. As result, the library will make three API requests for your 270 linodes, but it's completely transparent for you. Of course, extra requests are performed only when needed, so if you break your enumeration in the middle, remaining entities won't be requested at all. Also, the retrieved entities are cached per collection, so it's safe to enumerate the same collection multiple times:
Sorting
The Linode API supports sorting of the requested objects, which can be specified in two optional parameters of the `findAll` function: The first parameter is the name of the field to sort entities by. Every entity class contains useful constants so you don't have to hardcode field names. The second parameter is a sorting direction and equals to `Linode\RepositoryInterface::SORT_ASC` if omitted.
Filtering (simple queries)
The Linode API supports filtering of the requested objects, which is addressed by the same `Linode\RepositoryInterface` interface via `findBy`, `findOneBy`, and `query` functions. The `findBy` function accepts array of criterias as the first parameter. All the criterias are joined via logical `AND` operation. Second and third parameters of the function are for sorting and work exactly as the corresponding parameters of the `findAll` function. The `findBy` function returns a collection, which can be empty if nothing is found. When you need to retrieve a single object using filters, you may use the `findOneBy` function, which accepts an array of criterias as the only parameter. If nothing is found, the function returns `null`. If more than one entity is found, the function raises a `LinodeException`.
Filtering (complex queries)
The last of functions mentioned above - `query` - lets you make complex requests using query language of the Linode API. The API query language assumes you convert your conditions to JSON, which actually makes them hard to read, debug, and maintain. For example, current API documentation suggests the following JSON object to get all Linode Types which are either _standard_ or _highmem_ class, or have between 12 and 20 vcpus: The `query` function lets you write your conditions using more human-readable expressions which are passed as a string to the first parameter. The above example can be implemented as following: All Linode API operators are supported by the library using following lexems:
== | equals |
!= | doesn't equal |
< | is greater than |
<= | is less than or equal to |
> | is greater than |
>= | is greater than or equal to |
~ | contains a substring |
Development
Contributing
Please see CONTRIBUTING for details.
Credits
License
The MIT License (MIT). Please see License File for more information.
All versions of linode-api with dependencies
PHP Build Version
Package Version
Requires
php Version
^8.1
ext-json Version *
guzzlehttp/guzzle Version ^7.8
psr/http-message Version ^2.0
symfony/expression-language Version ^6.4
ext-json Version *
guzzlehttp/guzzle Version ^7.8
psr/http-message Version ^2.0
symfony/expression-language Version ^6.4
The package webinarium/linode-api contains the following files
Loading the files please wait ....