Files
notifications-admin/README.md

104 lines
2.7 KiB
Markdown
Raw Normal View History

2015-11-20 10:31:28 +00:00
# notifications-admin
2015-11-18 16:32:15 +00:00
GOV.UK Notify admin application.
2015-11-23 14:37:29 +00:00
2016-02-03 15:18:57 +00:00
## Features of this application
- Register and manage users
- Create and manage services
- Send batch emails and SMS by uploading a CSV
2016-02-03 15:18:57 +00:00
- Show history of notifications
2016-02-03 15:18:57 +00:00
## First-time setup
2017-04-18 14:04:10 +01:00
Brew is a package manager for OSX. The following command installs brew:
```shell
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
```
Languages needed
2016-08-17 15:59:16 +01:00
- Python 3.4
- [Node](https://nodejs.org/) 10.15.3 or greater
- [npm](https://www.npmjs.com/) 6.4.1 or greater
2017-04-18 14:04:10 +01:00
```shell
brew install node
```
[NPM](npmjs.org) is Node's package management tool. `n` is a tool for managing
different versions of Node. The following installs `n` and uses the long term support (LTS)
version of Node.
```shell
npm install -g n
n lts
npm rebuild node-sass
```
2016-08-17 15:59:16 +01:00
The app runs within a virtual environment. We use mkvirtualenv for easier working with venvs
```shell
2016-08-17 15:59:16 +01:00
pip install virtualenvwrapper
2016-02-03 15:18:57 +00:00
mkvirtualenv -p /usr/local/bin/python3 notifications-admin
```
Install dependencies and build the frontend assets:
```shell
2016-08-17 15:59:16 +01:00
workon notifications-admin
2016-02-03 15:18:57 +00:00
./scripts/bootstrap.sh
```
## Rebuilding the frontend assets
2016-02-03 15:18:57 +00:00
If you want the front end assets to re-compile on changes, leave this running
in a separate terminal from the app
```shell
npm run watch
```
2015-12-10 16:47:29 +00:00
## Create a local environment.sh file containing the following:
```
echo "
export NOTIFY_ENVIRONMENT='development'
export FLASK_APP=application.py
export FLASK_DEBUG=1
export WERKZEUG_DEBUG_PIN=off
"> environment.sh
```
## AWS credentials
2016-08-17 15:59:16 +01:00
Your aws credentials should be stored in a folder located at `~/.aws`. Follow [Amazon's instructions](http://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html#cli-config-files) for storing them correctly
2016-02-03 15:18:57 +00:00
## Running the application
```shell
workon notifications-admin
./scripts/run_app.sh
```
Then visit [localhost:6012](http://localhost:6012)
## Updating application dependencies
`requirements.txt` file is generated from the `requirements-app.txt` in order to pin
versions of all nested dependencies. If `requirements-app.txt` has been changed (or
we want to update the unpinned nested dependencies) `requirements.txt` should be
regenerated with
```
make freeze-requirements
```
`requirements.txt` should be committed alongside `requirements-app.txt` changes.
2018-12-21 12:54:19 +00:00
## Working with static assets
2018-12-21 12:54:19 +00:00
When running locally static assets are served by Flask at http://localhost:6012/static/…
When running on preview, staging and production theres a bit more to it:
2018-12-21 12:54:19 +00:00
![notify-static-after](https://user-images.githubusercontent.com/355079/50343595-6ea5de80-051f-11e9-85cf-2c20eb3cdefa.png)