Skip to content

Instantly share code, notes, and snippets.

@pengjiayou
Forked from dovy/Sendy.md
Created November 30, 2016 04:55
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save pengjiayou/5382037cb41c7b8cb8046289a037ec57 to your computer and use it in GitHub Desktop.
Save pengjiayou/5382037cb41c7b8cb8046289a037ec57 to your computer and use it in GitHub Desktop.
{
"require": {
"php": ">=5.5.0",
"ext-gettext": "*"
}
}

Sendy

Sendy is a self hosted email newsletter application that lets you send trackable emails via Amazon Simple Email Service (SES).

Heroku

You can deploy Sendy on Heroku using the following instructions (I assume you've already installed the heroku toolbelt).

  1. On Heroku, create a new app.
  2. Clone that app to your desktop git clone git@heroku.com:YOURAPP.git -o heroku
  3. Add the free cleardb addon to your project heroku addons:add cleardb
  4. Add the included composer.json file to the root of your cloned directory.
  5. Customise the includes/config.php and include the following snippet to use the ClearDB addon previously selected on Heroku:
   <?php
   define('APP_PATH', 'http://yourdomain.com');

   $url_cleardb = parse_url(getenv("CLEARDB_DATABASE_URL"));

   /*  MySQL database connection credentials  */
   $dbHost = $url_cleardb['host']; //MySQL Hostname
   $dbUser = $url_cleardb['user']; //MySQL Username
   $dbPass = $url_cleardb['pass']; //MySQL Password
   $dbName = substr($url_cleardb["path"],1); //MySQL Database Name

All these settings are necessary to Heroku to automatically hook up the ClearDB add-on. More on the settings here.

  1. Commit all the changes and push to Heroku:
   git add -A .
   git commit -am "Sendy customised for heroku deployment"
   git push heroku master
  1. Follow the remaining Sendy setup steps (http://sendy.co/get-started) starting with Step 5.

Seting up Cron

Cron will make your experience much nicer, and not lock up your site.

  1. Add the heroku scheduler: heroku addons:add scheduler:standard
  2. Open the scheduler: heroku addons:open scheduler
  3. Create two jobs, each with a frequency of 10 mins, and 1x dyno
  • Task 1: php autoresponders.php > /dev/null 2>&1
  • Task 2: php scheduled.php > /dev/null 2>&1

FAQs

You can add your own domain/subdomain easily: heroku domains:add YOUR.DOMAIN.COM Then go to your Domain Registrant and add a CNAME with the value of your app:

Record Name Target
CNAME YOUR YOUR-APP.herokuapp.com.

Replacing of course the name to match the subdomain of your choosing, and appending to your domain record.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment