Skip to content

Commit

Permalink
Merge branch 'main' into patch-1
Browse files Browse the repository at this point in the history
  • Loading branch information
toleabivol authored Dec 28, 2023
2 parents 167745d + 08514e7 commit 36d72b4
Show file tree
Hide file tree
Showing 8 changed files with 207 additions and 5 deletions.
12 changes: 12 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,18 @@ All notable changes to this project will be documented in this file.

This project adheres to [Semantic Versioning](http://semver.org/).

[2023-12-06] Version 8.1.1
--------------------------
**Library - Chore**
- [PR #1105](https://github.com/sendgrid/sendgrid-php/pull/1105): updated php-http-client version to enable setHost. Thanks to [@tiwarishubham635](https://github.com/tiwarishubham635)!


[2023-12-01] Version 8.1.0
--------------------------
**Library - Feature**
- [PR #1104](https://github.com/sendgrid/sendgrid-php/pull/1104): Added Data residency for eu and global region. Thanks to [@tiwarishubham635](https://github.com/tiwarishubham635)!


[2022-08-10] Version 8.0.1
--------------------------
**Library - Docs**
Expand Down
2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
MIT License

Copyright (C) 2022, Twilio SendGrid, Inc. <[email protected]>
Copyright (C) 2023, Twilio SendGrid, Inc. <[email protected]>

Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,9 @@ Add Twilio SendGrid to your `composer.json` file. If you are not using [Composer

### Alternative: Install package from zip

If you are not using Composer, simply download and install the **[latest packaged release of the library as a zip](https://github.com/sendgrid/sendgrid-php/releases/download/8.0.1/sendgrid-php.zip)**.
If you are not using Composer, simply download and install the **[latest packaged release of the library as a zip](https://github.com/sendgrid/sendgrid-php/releases/download/8.1.1/sendgrid-php.zip)**.

[**⬇︎ Download Packaged Library ⬇︎**](https://github.com/sendgrid/sendgrid-php/releases/download/8.0.1/sendgrid-php.zip)
[**⬇︎ Download Packaged Library ⬇︎**](https://github.com/sendgrid/sendgrid-php/releases/download/8.1.1/sendgrid-php.zip)

Previous versions of the library can be downloaded directly from [GitHub](https://github.com/sendgrid/sendgrid-php/releases).

Expand Down
18 changes: 18 additions & 0 deletions USE_CASES.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ This documentation provides examples for specific use cases. Please [open an iss
- [Send an Email to Multiple Recipients](#send-an-email-to-multiple-recipients)
- [Send Multiple Emails to Multiple Recipients](#send-multiple-emails-to-multiple-recipients)
- [Send Multiple Emails with Personalizations](#multiple-email-personalizations)
- [Set Region](#set-region)
- [Transactional Templates](#transactional-templates)
- [Legacy Templates](#legacy-templates)
- [Send an Email With Twilio Email (Pilot)](#send-an-email-with-twilio-email-pilot)
Expand Down Expand Up @@ -1174,6 +1175,23 @@ try {
}
```

<a name="set-region"></a>
# Set Region
The SendGrid object can also be used to set the region to "eu", which will send the request to https://api.eu.sendgrid.com/. By default, it is set to https://api.sendgrid.com/, e.g.

```php
<?php
// Uncomment next line if you're not using a dependency loader (such as Composer)
// require_once '<PATH TO>/sendgrid-php.php';

$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("eu");

OR

$sendgrid->setDataResidency("global");
```

<a name="transactional-templates"></a>
# Transactional Templates

Expand Down
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
],
"require": {
"php": ">=7.3",
"sendgrid/php-http-client": "~3.10",
"sendgrid/php-http-client": "4.1.0",
"starkbank/ecdsa": "0.*",
"ext-curl": "*",
"ext-json": "*",
Expand Down
75 changes: 75 additions & 0 deletions examples/dataresidency/setregion.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
<?php
// index.php
require_once __DIR__ . '/../../sendgrid-php.php';

use SendGrid\Mail\Mail;
use SendGrid\Mail\Personalization;
use SendGrid\Mail\To;
$exceptionMessage = 'Caught exception: ';

////////////////////////////////////////////////////
// Set data residency to navigate to a region/edge. #
// sending to global data residency

$email = buildHelloEmail();
$sendgrid = buildSendgridObject("global");

try {
$response = $sendgrid->client->mail()->send()->post($email);
print $response->statusCode() . "\n";
print_r($response->headers());
print $response->body() . "\n";
} catch (Exception $e) {
echo $exceptionMessage, $e->getMessage(), "\n";
}

////////////////////////////////////////////////////
// sending to EU data residency

$sendgrid_eu = buildSendgridObject("eu");

try {
$response = $sendgrid_eu->client->mail()->send()->post($email);
print $response->statusCode() . "\n";
print_r($response->headers());
print $response->body() . "\n";
} catch (Exception $e) {
echo $exceptionMessage, $e->getMessage(), "\n";
}

////////////////////////////////////////////////////
// not configuring any region defaults to global
$sendgrid_default = new \SendGrid(getenv('SENDGRID_API_KEY'));
try {
$response = $sendgrid_default->client->mail()->send()->post($email);
print $response->statusCode() . "\n";
print_r($response->headers());
print $response->body() . "\n";
} catch (Exception $e) {
echo $exceptionMessage, $e->getMessage(), "\n";
}

function buildHelloEmail(): Mail
{
$email = new Mail();
$email->setFrom("[email protected]", "test");
$email->setSubject("Sending with Twilio SendGrid is Fun");
$email->addTo("[email protected]", "test");
$email->addContent("text/plain", "and easy to do anywhere, even with PHP");
$email->addContent(
"text/html", "<strong>and easy to do anywhere, even with PHP</strong>"
);
$objPersonalization = new Personalization();

$objTo = new To('[email protected]', 'foo bar');
$objPersonalization->addTo($objTo);
$email->addPersonalization($objPersonalization);
return $email;
}

function buildSendgridObject($region): SendGrid
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency($region);
return $sendgrid;
}
27 changes: 26 additions & 1 deletion lib/BaseSendGridClientInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,20 @@
abstract class BaseSendGridClientInterface
{
/** @var string SendGrid API library version */
const VERSION = '8.0.1';
const VERSION = '8.1.1';

/** @var Client SendGrid HTTP Client library */
public $client;

/** @var string SendGrid version */
public $version = self::VERSION;

/** @var allowedRegionsHostMap regions specific hosts */
public $allowedRegionsHostMap = [
"eu" => "https://api.eu.sendgrid.com",
"global" => "https://api.sendgrid.com",
];

/**
* Set up the HTTP Client.
*
Expand Down Expand Up @@ -62,4 +68,23 @@ public function send(Mail $email)
{
return $this->client->mail()->send()->post($email);
}

/*
* Client libraries contain setters for specifying region/edge.
* This allows support global and eu regions only. This set will likely expand in the future.
* Global should be the default
* Global region means the message should be sent through:
* HTTP: api.sendgrid.com
* EU region means the message should be sent through:
* HTTP: api.eu.sendgrid.com
*/
public function setDataResidency($region): void
{
if (array_key_exists($region, $this->allowedRegionsHostMap)) {
$this->client->setHost($this->allowedRegionsHostMap[$region]);
} else {
throw new InvalidArgumentException("region can only be \"eu\" or \"global\"");
}
}

}
72 changes: 72 additions & 0 deletions test/unit/DataResidencyTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
<?php
/**
* This file tests email address encoding.
*/

namespace SendGrid\Tests\Unit;

use InvalidArgumentException;
use PHPUnit\Framework\TestCase;


/**
* This class tests Data residency
*
* @package SendGrid\Tests
*/
class DataResidencyTest extends TestCase
{
public function testSetResidencyEu()
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("eu");
self::assertEquals("https://api.eu.sendgrid.com", $sendgrid->client->getHost());
}

public function testSetResidencyGlobal()
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("global");
self::assertEquals("https://api.sendgrid.com", $sendgrid->client->getHost());
}

public function testSetResidencyOverrideHost()
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->client->setHost("https://test.api.com");
$sendgrid->setDataResidency("eu");
self::assertEquals("https://api.eu.sendgrid.com", $sendgrid->client->getHost());
}

public function testSetResidencyOverrideDataResidency()
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("eu");
$sendgrid->client->setHost("https://test.api.com");
self::assertEquals("https://test.api.com", $sendgrid->client->getHost());
}

public function testSetResidencyIncorrectRegion()
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage("region can only be \"eu\" or \"global\"");

$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("foo");
}

public function testSetResidencyNullRegion()
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage("region can only be \"eu\" or \"global\"");

$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
$sendgrid->setDataResidency("");
}

public function testSetResidencyDefaultRegion()
{
$sendgrid = new \SendGrid(getenv('SENDGRID_API_KEY'));
self::assertEquals("https://api.sendgrid.com", $sendgrid->client->getHost());
}
}

0 comments on commit 36d72b4

Please sign in to comment.