Monica can be deployed on Heroku using the button below:
Before deployment, Heroku will ask you to define a few variables.
- Please ensure to enter a custom
APP_KEY
when asked (if, for example, you have thepwgen
utility installed, you could copy and paste the output ofpwgen -s 32 1
). - In addition, you can edit the email address Monica will send emails to (
MAIL_FROM_ADDRESS
), the name of the sender (MAIL_FROM_NAME
) and some other important variables on that screen.
After deployment, click on to open the dashboard of your new application:
Click on Heroku Scheduler to open scheduler dashboard. Create a new job, and defines a new job to run this command every 10 minutes or every hour at 00 minutes:
php artisan schedule:run
You are now able to open the application and register a new user.
Your Monica instance will use a ClearDB Ignite plan (free) by default. Additional environment variables, such as details of the mail server, can be added after setup through the Heroku interface. Monica doesn't require a lot of power - it will run perfectly fine on the free plan provided by Heroku.
After deployment, the configuration of your app should look like this:
Note that when you deploy with the "Deploy to Heroku" purple button, only 1 dyno ("web") is activated while the "queue" one is not. That is OK - the "queue" dyno is only helpful if you set QUEUE_DRIVER=database
(default is 'sync').
In order to generate personal access tokens from the UI, you need to:
- Install the Heroku CLI and log in.
- From your command line, run
heroku run bash -a <APP-ID>
- Run
php artisan passport:keys
php artisan passport:client --personal --no-interaction
This command will generate encryption keys in the storage
directory.
The two keys oauth-private.key
and oauth-public.key
cannot be backup and recreate in heroku directly.
- Still in the Heroku CLI, run this command to output the private key:
sed ':a;N;$!ba;s/\n/\\n/g' ~/storage/oauth-private.key
Copy the output to a new Heroku environment variable called PASSPORT_PRIVATE_KEY
- Do the same thing with the contents of the public key:
sed ':a;N;$!ba;s/\n/\\n/g' ~/storage/oauth-public.key
Copy its contents to a new Heroku environment variable called PASSPORT_PUBLIC_KEY
Once Heroku is re-deploy, you should be able to use the 'Create new token' function in https://XXX.herokuapp.com/settings/api
Once you have the token, you can use the API with a command line:
curl -H "Authorization: Bearer API_TOKEN" https://XXX.herokuapp.com/api
If everything is well, this call will return:
{"success":{"message":"Welcome to Monica"}}
- Still in the Heroku CLI, run this command to generate a password grant client:
php artisan passport:client --password --no-interaction
- This will display a client ID and secret:
Password grant client created successfully.
Client ID: 5
Client secret: zsfOHGnEbadlBP8kLsjOV8hMpHAxb0oAhenfmSqq
- Copy the two values into two new environment variable of your
.env
file:- The value of client ID in a
MOBILE_CLIENT_ID
variable - The value of client secret in a
MOBILE_CLIENT_SECRET
variable
- The value of client ID in a
- No upload of photos for your contacts. Heroku doesn't support storage.
- No email by default - email configuration isn't required to use Monica on Heroku, but it's recommended. The easiest way to go about this is to use Mailgun's free email add-on on Heroku:
- Sign up for Mailgun (the free plan should be sufficient)
- Add a custom domain in mailgun.
- Add the "To" and "From" e-mail addresses you're going to use as verified e-mail addresses on mailgun, and then actually verifying them.
- Upgrade mailgun by entering a credit card (there is no charge, but they do require you enter it so you'll be upgraded to some other tier that enables you to actually send messages).
- Verify the custom domain via DNS (there are instructions on their site)
- In Heroku, go to your app, then to the Settings tab. In it, you will have a button that reads "Reveal Config Vars". Click it, and change the following vars:
MAIL_DRIVER
:mailgun
MAILGUN_DOMAIN
: your Mailgun domainMAILGUN_SECRET
: your Mailgun API key — find it hereMAIL_FROM_ADDRESS
: email address to use for 'from' email (could just use your own)MAIL_FROM_NAME
: name of the 'from' user (could just use "Monica")
You can update your Monica instance to the latest version by cloning the repository and pushing it to Heroku git.
Clone the Monica repository to your local environment by git clone https://github.com/monicahq/monica
, and add heroku git repository by heroku git:remote -a (heroku app name)
. Then, push to heroku by git push heroku master
. Heroku will build and update the repository, automatically.