Download the PHP package telnyx/telnyx-php without Composer
On this page you can find all versions of the php package telnyx/telnyx-php. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download telnyx/telnyx-php
More information about telnyx/telnyx-php
Files in telnyx/telnyx-php
Package telnyx-php
Short Description Telnyx PHP Library
License MIT
Homepage https://telnyx.com/
Informations about the package telnyx-php
Telnyx PHP SDK
The Telnyx PHP library provides convenient access to the Telnyx API from applications written in PHP. It includes a pre-defined set of classes for API resources that initialize themselves dynamically from API responses.
The library also provides other features. For example:
- Easy configuration path for fast setup and use.
- Helpers for pagination.
- Built-in mechanisms for the serialization of parameters according to the expectations of Telnyx's API.
You can sign up for a Telnyx account at telnyx.com.
Requirements
PHP 5.6.0 and later.
Composer
You can install the bindings via Composer. Run the following command:
Manual Installation
If you do not wish to use Composer, you can download the latest release. Then, to use the bindings, include the init.php
file.
Dependencies
Some PHP extensions are required:
Composer will handle these dependencies. If you install manually, you'll want to make sure that these extensions are available.
Getting Started
Basic example:
Documentation
Please see https://developers.telnyx.com/docs/api/v2/overview for up-to-date documentation.
Custom Request Timeouts
To modify request timeouts (connect or total, in seconds) you'll need to tell the API client to use a CurlClient other than its default. You'll set the timeouts in that CurlClient.
Custom cURL Options (proxies)
Need to set a proxy for your requests? Pass in the requisite CURLOPT_*
array to the CurlClient constructor, using the same syntax as curl_stopt_array()
. This will set the default cURL options for each HTTP request made by the SDK, though many more common options (e.g. timeouts; see above on how to set those) will be overridden by the client even if set here.
Alternately, a callable can be passed to the CurlClient constructor that returns the above array based on request inputs. See testDefaultOptions()
in tests/CurlClientTest.php
for an example of this behavior. Note that the callable is called at the beginning of every API request, before the request is sent.
Configuring a Logger
The library does minimal logging, but it can be configured
with a PSR-3
compatible logger so that messages
end up there instead of error_log
:
Accessing Response Data
You can access the data from the last API response on any object via getLastResponse()
.
SSL / TLS Compatibility issues
Telnyx's API now requires that all connections use TLS 1.2. Some systems (most notably some older CentOS and RHEL versions) are capable of using TLS 1.2 but will use TLS 1.0 or 1.1 by default.
The recommended course of action is to upgrade your cURL and OpenSSL packages so that TLS 1.2 is used by default, but if that is not possible, you might be able to solve the issue by setting the CURLOPT_SSLVERSION
option to either CURL_SSLVERSION_TLSv1
or CURL_SSLVERSION_TLSv1_2
:
Per-request Configuration
For apps that need to use multiple keys during the lifetime of a process it's also possible to set a per-request key and/or account:
Automatic Retries
The library can be configured to automatically retry requests that fail due to an intermittent network problem:
Development
Unit tests rely on a mock server so all unit tests are ran through docker. To run all unit tests execute:
Running unit tests with code coverage requires you build the docker container with XDEBUG=1
then run the unit tests as
Plugin Developers
Are you writing a plugin that integrates Telnyx and embeds our library? Then please use the setAppInfo
function to identify your plugin. For example:
The method should be called once before any request is sent to the API. The second and third parameters are optional.
SSL / TLS Configuration Option
See the "SSL / TLS compatibility issues" paragraph above for full context. If you want to
ensure that your plugin can be used on all systems, you should add a configuration option
to let your users choose between different values for
CURLOPT_SSLVERSION
: none (default), CURL_SSLVERSION_TLSv1
and CURL_SSLVERSION_TLSv1_2
.
Acknowledgments
The contributors and maintainers of Telnyx PHP would like to extend their deep gratitude to the authors of Stripe PHP, upon which this project is based. Thank you for developing such elegant, usable, and extensible code and for sharing it with the community.
All versions of telnyx-php with dependencies
ext-curl Version *
ext-json Version *
ext-mbstring Version *
paragonie/sodium_compat Version ^1.13