Your team will need a server. To set one up, follow the Prerequisites instructions in the devpi document.

If your team already has a devpi server, then it should be listed in the :doc`checklist`.


To set-up your workstation for development:

Development Environment

To deploy a site from scratch:


Purchase a domain name from

Set the name servers e.g. in Point the domain to the DNS server:

Google Mail

If your customer would like to use Google Mail

Cloud Server

Create a cloud server for your project: Digital Ocean or Rackspace.

Set-up the basic DNS records e.g.



Don’t forget to add a CNAME entry for the www subdomain.

If you are using mailgun for your project, then enable it: Mailgun


Your site doesn’t yet have https enabled, so for the Action on the mailgun route, use http (not https).


Set-up your pillar Site - Configuration


Set-up your site with ssl: False

Transfer the pillar to the salt master and then Salt - Provision

Create the database for your project: Database

Release your project: Release

Deploy your project to the server: Deploy

Mailgun Testing

If you are using Mailgun…

Check the mailgun domain to make sure the DNS records are set-up correctly.

Send a test email to your site e.g.

Log into your cloud server and check the email was received e.g:

ssh drop-temp
sudo -i -u web shell
from mailgun_incoming.models import IncomingEmail
for mail in IncomingEmail.objects.all().order_by('-id'): print(mail.subject, mail.body_plain)


Create an SSL certificate: Create SSL Certificate.

Read any emails using your mail client - or for Mailgun - the python code in the previous step.


If using then send emails to webmaster.

Copy the SSL certificate to the server: Install SSL Certificate

After installing the certificate, run a salt 'drop-temp' state.highstate for your server so the site is set-up correctly for SSL.



If you are using Mailgun, change the Action on the route filter to use https: Mailgun