Download the PHP package apigee/apigee-client-php without Composer
On this page you can find all versions of the php package apigee/apigee-client-php. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download apigee/apigee-client-php
More information about apigee/apigee-client-php
Files in apigee/apigee-client-php
Package apigee-client-php
Short Description Client library for connecting to the Apigee Edge API.
License Apache-2.0
Homepage http://github.com/apigee/apigee-client-php
Informations about the package apigee-client-php
Apigee Edge Client Library for PHP
The Apigee API Client Library for PHP makes it easy to develop PHP clients that call the Apigee Edge/ X Management API. The Apigee API Client Library for PHP enables you to interact with the API using objects instead of coding to handle the HTTP request and response calls directly.
Specifically, the Apigee API Client Library for PHP provides access to Apigee Edge and Apigee Management APIs in the following categories:
Apigee Edge
- API Products
- Apps
- Apps: Company
- Apps: Developer
- Companies
- Company App Keys
- Company Developers
- Developer App Keys
- Developers
- Stats
Apigee
- API Products
- Apps
- Apps: AppGroup
- Apps: Developer
- AppGroup
- AppGroup App Keys
- Developer App Keys
- Developers
- Stats
For more information about the Apigee Edge and Apigee Management APIs, see Getting started with the Apigee Edge Management APIs and Getting started with the Apigee Management APIs in the Apigee documentation.
The Apigee API Client Library for PHP, built using the HTTPlug library, provides an HTTP client implementation-independent library. You choose the client that best fits your project requirements.
If you need PHP < 7.1 or Monetization API support please install the older edge-php-sdk version. We are planning to add Monetization API support to this library in the near future.
Edge for Private Cloud
Core Persistent Services (CPS) is not available on Private Cloud installations.
The PHP API client supports pagination on listing API endpoints (ex.: List Developers). If CPS is not available the PHP API client simulates the pagination feature and it triggers an E_USER_NOTICE level error to let developers know that the paginated result is generated by PHP and not the Management API server.
This notice can be suppressed in multiple ways. You can suppress it by changing PHP's error_reporting
configuration to
suppress all E_NOTICE level errors with changing its value to E_ALL | ~E_NOTICE
for example. You can also suppress only the notice generated by the PHP API client by setting the APIGEE_EDGE_PHP_CLIENT_SUPPRESS_CPS_SIMULATION_NOTICE
environment variable value to a falsy value, for example: APIGEE_EDGE_PHP_CLIENT_SUPPRESS_CPS_SIMULATION_NOTICE=1
.
Support for Apigee hybrid orgs: GA Release
Support for Apigee hybrid API has been added to this library and is now considered to be production ready. If you run into any problems, add an issue to our GitHub issue queue.
Installing the client library
You must install an HTTP client or adapter before you install the Apigee API Client Library for PHP. For a complete list of available clients and adapters, see Clients & Adapters in the PHP-HTTP documentation.
To install the client library using Guzzle 6, enter the following commands:
Usage examples
Basic API usage
Advanced examples
- Create new developer app with a custom- and an auto-generated credential
- Developer app analytics
- List entities (developers, api products, developer apps, etc.)
Unit Tests
Setup the test suite using Composer if it has not already done:
Run it using PHPUnit:
Testing of new changes does not require Apigee Edge connection. By default, unit tests are using the content of the offline-test-data folder to make testing quicker and easier. If you would like to run units tests with a real Apigee Edge instance you have to specify the following environment variables (without brackets):
There are multiple ways to set these environment variables, but probably the easiest is creating a copy from the
phpunit.xml.dist file as phpunit.xml and uncomment the env
elements inside the
It is also possible to create and use your own data set. If you would like to use your own offline test data set then
you just need to define the APIGEE_EDGE_PHP_CLIENT_OFFLINE_TEST_DATA_FOLDER
environment variable set its value to the parent
folder of your own test data set.
PS.: Some unit tests cannot be executed when the offline test data set is in use, those are automatically marked as skipped.
Our Backward Compatibility (BC) Promise
This library follows the Semantic Versioning strategy. It means only major releases (such as 3.0, 4.0 etc.) are allowed to break backward compatibility and we do our best to keep it this way. The PHP API Client has to be compatible with the latest versions of the supported Apigee Edge APIs. As you can see, almost every class implements at least one interface in this library, therefore, we would like to suggest to rely on interface definitions instead of concrete classes if you build something on the top of this library. Also, prefer encapsulation over inheritance if you extend our classes. We will release a new major version from this library if a change in a supported Apigee Edge API cannot be implemented in the PHP API client without changing an interface.
Support
This project, which connects Drupal 8 with Apigee Edge, is supported by Google. Use our project's issue queue to report any questions, issues, or feedback.
Contributions
We would love to accept contributions to this project, please see the contribution guidelines for this project for more details.
All versions of apigee-client-php with dependencies
ext-json Version *
ext-openssl Version *
ext-reflection Version *
fightbulc/moment Version ^1.26
firebase/php-jwt Version ^6.0
league/period Version ^5.2
php-http/client-common Version ^2.0
php-http/client-implementation Version ^1.0
php-http/discovery Version ^1.18
php-http/httplug Version ^2.0
php-http/message Version ^1.13
php-http/message-factory Version ^1.0
phpdocumentor/reflection-docblock Version ^5.0
psr/http-message Version ^1.0 || ^2.0
symfony/options-resolver Version ^6.4.8
symfony/property-access Version ^6.4.9
symfony/property-info Version ^6.4.9
symfony/serializer Version ^6.4.9