Giter Club home page Giter Club logo

telnyx-php's Introduction

Telnyx PHP SDK

Build Status Latest Stable Version Total Downloads License Build Code Coverage

You can sign up for a Telnyx account at https://telnyx.com.

Installation

This library supports PHP 5.6 and above.

Installation of this module uses composer. For composer documentation, please refer to getcomposer.org.

$ composer require team-telnyx/telnyx-php

Dependencies

Some PHP extensions are required:

  • curl, although you can use your own non-cURL client if you prefer
  • json
  • mbstring (Multibyte String)

Composer will handle these dependencies. If you install manually, you'll want to make sure that these extensions are available.

Getting Started

Basic example:

use Telnyx;

Telnyx\Telnyx::setApiKey('sk_test_BQokikJOvBiI2HlWgH4olfQ2');
$order = Telnyx\NumberOrder::create(['phone_number' => '+18665552368']);
echo $order;

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.

use Telnyx;

// set up your tweaked Curl client
$curl = new Telnyx\HttpClient\CurlClient();
$curl->setTimeout(10); // default is Telnyx\HttpClient\CurlClient::DEFAULT_TIMEOUT
$curl->setConnectTimeout(5); // default is Telnyx\HttpClient\CurlClient::DEFAULT_CONNECT_TIMEOUT

echo $curl->getTimeout(); // 10
echo $curl->getConnectTimeout(); // 5

// tell Telnyx to use the tweaked client
Telnyx\ApiRequestor::setHttpClient($curl);

// use the Telnyx API client as you normally would

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.

// set up your tweaked Curl client
$curl = new \Telnyx\HttpClient\CurlClient([CURLOPT_PROXY => 'proxy.local:80']);
// tell Telnyx to use the tweaked client
\Telnyx\ApiRequestor::setHttpClient($curl);

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:

\Telnyx\Telnyx::setLogger($logger);

Accessing Response Data

You can access the data from the last API response on any object via getLastResponse().

$order = \Telnyx\NumberOrder::create(['phone_number' => '+18665552368']);
echo $order->getLastResponse()->headers['Request-Id'];

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:

$curl = new \Telnyx\HttpClient\CurlClient([CURLOPT_SSLVERSION => CURL_SSLVERSION_TLSv1]);
\Telnyx\ApiRequestor::setHttpClient($curl);

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:

\Telnyx\NumberOrder::all([], [
    'api_key' => 'sk_test_...'
]);

\Telnyx\NumberOrder::retrieve("ch_18atAXCdGbJFKhCuBAa4532Z", [
    'api_key' => 'sk_test_...'
]);

Automatic Retries

The library can be configured to automatically retry requests that fail due to an intermittent network problem:

\Telnyx\Telnyx::setMaxNetworkRetries(2);

Idempotency keys are added to requests to guarantee that retries are safe.

Development

Unit tests rely on a mock server so all unit tests are ran through docker. To run all unit tests execute:

docker-compose run --rm php composer test

Running unit tests with code coverage requires you build the docker composer with XDEBUG=1

docker-compose build --build-arg XDEBUG=1

then run the unit tests as

docker-compose run --rm php composer test-coverage

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:

use Telnyx;

Telnyx\Telnyx::setAppInfo("MyCustomPlugin", "1.2.3", "https://customplugin.yoursite.com");

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.

telnyx-php's People

Contributors

tomhanderson avatar eoghantelnyx avatar weroh avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.