Download the PHP package lekoala/silverstripe-sparkpost without Composer

On this page you can find all versions of the php package lekoala/silverstripe-sparkpost. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package silverstripe-sparkpost

SilverStripe SparkPost module

Build Status Scrutinizer Code Quality Code Coverage Build Status codecov.io

Latest Stable Version Total Downloads License Monthly Downloads Daily Downloads

Setup

Define in your .env file the following variable

SPARKPOST_API_KEY='YOUR_API_KEY_HERE'

or by defining the api key in your config.yml

This module uses a custom client (not the official PHP SDK).

You can also autoconfigure the module with the following environment variables

# Will log emails in the temp folders
SPARKPOST_ENABLE_LOGGING=true
# Will disable sending (useful in development)
SPARKPOST_SENDING_DISABLED=true

By defining the Api Key, the module will register a new transport that will be used to send all emails.

If you're using the SparkPost EU service you can change the API endpoint

# Will use https://api.eu.sparkpost.com/api/v1
SPARKPOST_EU=true

Register the new mailer

If you define the SPARKPOST_API_KEY variable, the mailer transport will be automatically registered.

Otherwise, you need to call the following line:

Admin sender

By default in SilverStripe, emails without a from email will use the Email::admin_email value.

This is not convenient for websites using a value taken from the SiteConfig, as resolved with SparkPostHelper::resolveDefaultFromEmail.

The SparkPostApiTransport can automatically take care of that and replace any admin email with the set value using the following config flag:

Make sure to set this after having processed the sparkpost config.

Check if emails can be used as sender

As a convenience, this library offers an utility SparkPostHelper::isEmailDomainReady to help you determine if an email is ready to be used as a sender.

Please note that this function makes an api call so you may not want to use this to often. It is a better to use this on verification screens or as part of a validation workflow.

Subaccounts support

If you use a master api key, but need to limit data access, you can configure a subaccount id

SPARKPOST_SUBACCOUNT_ID=1234;

or through the YML config.

SparkPost integration

This module create a new admin section that allows you to:

NOTE : Make sure that you have a valid api key (not a subaccount key) to access features related to installation of the webhook through the CMS.

Note that by default the messages are cached (or not) according to config. You can disable this with the following env key

SPARKPOST_DISABLE_CACHE=true

Setting tags or metadata

By using custom headers you can pass parameters to the api by following the same principle than the SMTP api.

The main way to pass parameters is to add a json encoded string through the X-MSYS-API header, but you can also use that Mandrill compatiblity layer.

For full details, look at the documentation

Webhooks

From the SparkPost Admin, you can setup a webhook for your website. This webhook will be called and SparkPostController will take care of handling all events for you. It is registered under the __sparkpost/ route.

By default, SparkPostController will do nothing. Feel free to add your own extensions to SparkPostController to define your own rules, like "Send an email to the admin when a receive a spam complaint".

SparkPostController provides the following extension point for all events:

And the following extensions points depending on the type of the event:

You can also inspect the whole payload and the batch id with

You can test if your extension is working properly by visiting /__sparkpost/test if your site is in dev mode. It will load sample data from the API.

Please ensure that the url for the webhook is properly configured if required by using the following configuration

You can also define the following environment variable to log all incoming payload into a given directory. Make sure the directory exists. It is relative to your base folder.

SPARKPOST_WEBHOOK_LOG_DIR='_incoming'

Please also pay attention to the fact that the webhook is called for ALL events of your SparkPost account, regardless of the fact of which API key generated the transmission.

To help you overcome this, if a subaccount id is defined, events will be filtered according to this subaccount.

Preventing spam

Make sure you have properly configured your SPF and DKIM records for your domain.

mydomain.com   TXT   "v=spf1 include:myauthorizeddomain.com include:sparkpostmail.com ~all”

Create a DMARC record. See why this is important.

_dmarc.mydomain.com. 3600 IN TXT "v=DMARC1; p=quarantine; sp=quarantine; rf=afrf; pct=100; ri=86400;"

Leave provide_plain option to true or provide plain content for your emails

Use Mail Tester to troubleshoot your issues

Inlining styles

Although SparkPost can inline styles for you, it may not work properly for complex style sheet, such as Foundation Emails. This is why the package pelago\emogrifier is not required by default and styles are inlined in php to get the best results.

If you want to restore built-in functionnality, use this:

Migration from Swift Mailer

SilverStripe 5 replaced swift mailer by symfony/mailer

Make sure to read the docs https://docs.silverstripe.org/en/5/developer_guides/email/ https://symfony.com/doc/current/mailer.html

Compatibility

Tested with SilverStripe 5+

For 4.9+ compatibility, use branch 3

For 4.x compatibility, use branch 2

For 3.x compatibility, use branch 1

Maintainer

LeKoala - [email protected]


All versions of silverstripe-sparkpost with dependencies

PHP Build Version
Package Version
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package lekoala/silverstripe-sparkpost contains the following files

Loading the files please wait ....