brainstream/nylas-php

Nylas PHP SDK for api version 3

V1.0.0 2024-10-30 06:19 UTC

This package is auto-updated.

Last update: 2025-01-07 12:22:35 UTC


README

This is the GitHub repository for the Nylas PHP SDK.

The Nylas Communications Platform provides REST APIs for Email, Calendar, and Contacts, and the Nylas SDK is the quickest way to build your integration using PHP.

Here are some resources to help you get started:

⚙️ Install

This library is available on https://packagist.org/packages/brainstream/nylas-php
You can install it by running

composer require brainstream/nylas-php

⚡️Usage

To use this SDK, you must first get a free Nylas account.

Then, follow the Quickstart guide to set up your first app and get your API keys.

🚀 Making Your First Request

You use the NylasClient object to make requests to the Nylas API. The SDK is organized into different resources, each of which has methods to make requests to the API. Each resource is available through the NylasClient object configured with your API key.

For example, first configure client object like below:

use Nylas\Client;

require __DIR__ . '/vendor/autoload.php';

$options = [
    'api_key'   => 'NYLAS_API_KEY',
    'client_id' => 'NYLAS_CLIENT_ID',
    'region'    => 'NYLAS_REGION', // optional - Default "us"
];

$nylasClient = new Client($options);

Then use it for make consecutive api requests.

Administrative Api info.

Application api

Application api could be like:

try {
    $applications = $nylasClient->Administration->Application->list();
    print_r($applications);
} catch (GuzzleException) {}

Authentication api

Nylas support 2 types of user authentication

  1. Nylas hosted auth(OAuth 2.0)
  2. Custom auth

Grant api

Grants associate with an application. It could be like:

try {
    $grants = $nylasClient->Administration->Grants->list();
    print_r($grants);
} catch (GuzzleException) {}

Connectors api

Connectors(providers) of an application.

try {
    $connectors = $nylasClient->Administration->Connectors->list();
    print_r($connectors);
} catch (GuzzleException) {}

Connectors Credential api

try {
    $credentials = $nylasClient->Administration->ConnectorsCredentials->list(
        PROVIDER_STRING
    );
    print_r($credentials);
} catch (GuzzleException) {}

//NOTE: Replace "PROVIDER_STRING" with real provider string

Email, Calender and Draft apis usage

Email api

try {
    $messages = $nylasClient->Messages->Message->list(
        GRANT_ID_STRING
    );
    print_r($messages);
} catch (GuzzleException) {}

//NOTE: Replace "GRANT_ID_STRING" with real grant id

Calendar api

try {
    $calendars = $nylasClient->Calendars->Calendar->list(
        GRANT_ID_STRING
    );
    print_r($calendars);
} catch (GuzzleException) {}

//NOTE: Replace "GRANT_ID_STRING" with real grant id

Drafts api

try {
    $drafts = $nylasClient->Drafts->Draft->list(
        GRANT_ID_STRING
    );
    print_r($drafts);
} catch (GuzzleException) {}

//NOTE: Replace "GRANT_ID_STRING" with real grant id

Launching the tests

  1. Initialise composer dependency by composer install
  2. Add your Nylas App. info in tests/AbsCase.php
  3. Launch the test with composer run-script test
  4. Another way to run tests: ./tests/do.sh foo.php --filter fooMethod, see tests/do.sh

Acknowledgements

This project is based on lanlin/nylas-php, which is licensed under the MIT License. The original code has been modified and is also available under the MIT License.

📝License

This project is licensed under the MIT License. See the LICENSE file for details.

Contact us

If you need additional assistance, drop us an email at info@brainstream.tech.