Constable is part of the thoughtbot Elixir family of projects.
Constable is a Phoenix app for posting announcements and having discussions. To learn more about Phoenix, check out Programming Phoenix
Use bin/console
to start the console. Use bin/console staging|production
to
start the console in staging or production.
Users are deactivated if they leave thoughtbot. Sometimes someone with the same first name joins thoughtbot later and inherits the deactivated email so we need to reactivate the email.
- Run
bin/console production
- Run
Constable.User.reactivate("[email protected]")
To set up your development environment, there are a few steps you'll need to follow.
You need to have Erlang, Elixir, Node and ChromeDriver installed. This section describes the easiest way to do that.
If you're on OS X and using Homebrew, run brew install node
to get nodejs.
Once node is installed, run npm -g install chromedriver
.
Finally, install the asdf package manager, which will read the
.tool-versions
file from the repo to install the correct versions of Erlang
and Elixir. Downloading and installing Erlang might take a while, so be patient
on first run. You should be able to run asdf install
from the project directly
to install the required packages.
Run:
# Will grab all Elixir and NPM dependencies and then setup the database
$ bin/setup
Once all the dependencies have been installed, you can start the Phoenix server with:
$ mix phx.server
You can edit the email contents from web/templates/email
.
You can preview templates by going to localhost:4000/emails/#{template_name}
.
You can find a list of templates in the EmailPreviewController
.
You can view sent emails in development by going to localhost:4000/sent_emails
Run mix test
Run mix dialyzer.plt
to build the lookup table for static analysis. Then run
mix dialyzer
to run analysis. If your dependencies or your elixir version
change, delete .dialyzer.plt
and run mix dialyzer.plt
to rebuild it.
There are still a lot of warnings that are not fixable, but occasionally some real errors are found by dialyzer
- If you have not run
bin/setup
yet, run it to add the correct git remotes. - Run
bin/deploy (staging|production)
Constable is setup with support for Heroku Review Apps.
Google enforces a white list of OAuth redirect URLs, so for review apps we
redirect the OAuth flow through the Constable oauth redirector which then
redirects back to the correct review app. This is configured with the
OAUTH_REDIRECT_OVERRIDE
environment variable.
Constable is Copyright (c) 2015-2016 Blake Williams, Paul Smith, and thoughtbot, inc. It is free software, and may be redistributed under the AGPL license detailed in the LICENSE file.
Constable is maintained and funded by thoughtbot, inc. The names and logos for thoughtbot are trademarks of thoughtbot, inc.
We love open source software, Elixir, and Phoenix. Work with thoughtbot's Elixir development team to design, develop, and grow your product.