2022-08-01 10:56:16 -07:00
# US Notify API
2015-11-20 10:51:08 +00:00
2022-10-20 14:05:23 -04:00
This project is the core of [Notify ](https://notifications-admin.app.cloud.gov/ ). It's cloned from the brilliant work of the team at [GOV.UK Notify ](https://github.com/alphagov/notifications-api ), cheers!
2022-08-01 10:50:50 -07:00
2022-10-20 14:05:23 -04:00
This repo contains:
2022-07-14 13:36:05 -05:00
2022-10-20 14:05:23 -04:00
- A public-facing REST API for Notify, which teams can integrate with using [API clients built by UK ](https://www.notifications.service.gov.uk/documentation )
- An internal-only REST API built using Flask to manage services, users, templates, etc., which the [admin UI ](http://github.com/18F/notifications-admin ) talks to)
2022-10-26 14:05:37 +00:00
- Asynchronous workers built using Celery to put things on queues and read them off to be processed, sent to providers, updated, etc.
2015-11-20 10:51:08 +00:00
2022-10-26 15:45:45 +00:00
Our other repositories are:
- [notifications-admin ](https://github.com/GSA/notifications-admin )
- [notifications-utils ](https://github.com/GSA/notifications-utils )
- [us-notify-compliance ](https://github.com/GSA/us-notify-compliance/ )
- [notify-python-demo ](https://github.com/GSA/notify-python-demo )
2022-10-20 14:05:23 -04:00
## Local setup
2022-08-05 02:22:21 +00:00
2023-03-14 15:36:32 -04:00
### Common steps
2023-05-02 10:25:02 -04:00
On MacOS, using [Homebrew ](https://brew.sh/ ) for package management is highly recommended. This helps avoid some known installation issues.
2023-03-14 15:36:32 -04:00
1. Install pre-requisites for setup:
* [jq ](https://stedolan.github.io/jq/ ): `brew install jq`
* [terraform ](https://www.terraform.io/ ): `brew install terraform` or `brew install tfenv` and use `tfenv` to install `terraform ~> 1.4.0`
* [cf-cli@8 ](https://docs.cloudfoundry.org/cf-cli/install-go-cli.html ): `brew install cloudfoundry/tap/cf-cli@8`
2023-05-02 10:25:02 -04:00
* [postgresql ](https://www.postgresql.org/ ): `brew install postgresql@15` (Homebrew requires a version pin, but any recent version will work)
* [redis ](https://redis.io/ ): `brew install redis`
* [pyenv ](https://github.com/pyenv/pyenv ): `brew install pyenv`
2023-09-29 10:36:39 -04:00
* [poetry ](https://python-poetry.org/docs/#installation ): `brew install poetry`
2023-03-14 15:36:32 -04:00
1. [Log into cloud.gov ](https://cloud.gov/docs/getting-started/setup/#set-up-the-command-line ): `cf login -a api.fr.cloud.gov --sso`
1. Ensure you have access to the `notify-local-dev` and `notify-staging` spaces in cloud.gov
1. Run the development terraform with:
```
$ cd terraform/development
$ ./run.sh
```
1. If you want to send data to New Relic from your local develpment environment, set `NEW_RELIC_LICENSE_KEY` within `.env`
2023-09-29 10:36:39 -04:00
1. Start Postgres && Redis
2023-03-14 15:36:32 -04:00
2023-09-29 10:36:39 -04:00
```
brew services start postgresql@15
brew services start redis
```
2022-08-05 02:22:21 +00:00
2023-09-29 10:36:39 -04:00
1. Install
2023-03-07 09:56:12 -05:00
1. Run the project setup
`make bootstrap`
2023-09-29 10:36:39 -04:00
1. Run the web server and background workers
2022-08-05 02:22:21 +00:00
2022-11-01 09:54:31 -04:00
`make run-procfile`
2022-08-05 02:22:21 +00:00
2022-11-01 09:54:31 -04:00
1. Or run them individually:
2022-08-01 10:50:50 -07:00
2022-11-01 09:54:31 -04:00
* Run Flask (web server)
2022-08-22 14:25:39 -05:00
2022-11-01 09:54:31 -04:00
`make run-flask`
2022-11-01 09:35:55 -04:00
2022-11-01 09:54:31 -04:00
* Run Celery (background worker)
`make run-celery`
2022-11-01 09:35:55 -04:00
2023-05-02 10:25:02 -04:00
### Known installation issues
On M1 Macs, if you get a `fatal error: 'Python.h' file not found` message, try a different method of installing Python. Installation via `pyenv` is known to work.
A direct installation of PostgreSQL will not put the `createdb` command on your `$PATH` . It can be added there in your shell startup script, or a Homebrew-managed installation of PostgreSQL will take care of it.
2023-08-22 17:36:00 -04:00
## Documentation
2023-09-18 16:50:52 -04:00
- [Infrastructure overview ](./docs/all.md#infrastructure-overview )
- [GitHub Repositories ](./docs/all.md#github-repositories )
- [Terraform ](./docs/all.md#terraform )
- [AWS ](./docs/all.md#aws )
- [New Relic ](./docs/all.md#new-relic )
- [Onboarding ](./docs/all.md#onboarding )
- [Setting up the infrastructure ](./docs/all.md#setting-up-the-infrastructure )
- [Using the logs ](./docs/all.md#using-the-logs )
- [Testing ](./docs/all.md#testing )
- [CI testing ](./docs/all.md#ci-testing )
- [Manual testing ](./docs/all.md#manual-testing )
- [To run a local OWASP scan ](./docs/all.md#to-run-a-local-owasp-scan )
- [Deploying ](./docs/all.md#deploying )
- [Egress Proxy ](./docs/all.md#egress-proxy )
- [Managing environment variables ](./docs/all.md#managing-environment-variables )
- [Sandbox environment ](./docs/all.md#sandbox-environment )
- [Database management ](./docs/all.md#database-management )
- [Initial state ](./docs/all.md#initial-state )
- [Data Model Diagram ](./docs/all.md#data-model-diagram )
- [Migrations ](./docs/all.md#migrations )
- [Purging user data ](./docs/all.md#purging-user-data )
- [One-off tasks ](./docs/all.md#one-off-tasks )
- [How messages are queued and sent ](./docs/all.md#how-messages-are-queued-and-sent )
- [Writing public APIs ](./docs/all.md#writing-public-apis )
- [Overview ](./docs/all.md#overview )
- [Documenting APIs ](./docs/all.md#documenting-apis )
- [New APIs ](./docs/all.md#new-apis )
- [API Usage ](./docs/all.md#api-usage )
- [Connecting to the API ](./docs/all.md#connecting-to-the-api )
- [Postman Documentation ](./docs/all.md#postman-documentation )
- [Using OpenAPI documentation ](./docs/all.md#using-openapi-documentation )
- [Queues and tasks ](./docs/all.md#queues-and-tasks )
- [Priority queue ](./docs/all.md#priority-queue )
- [Celery scheduled tasks ](./docs/all.md#celery-scheduled-tasks )
- [US Notify ](./docs/all.md#us-notify )
- [System Description ](./docs/all.md#system-description )
- [Run Book ](./docs/all.md#run-book )
- [ Alerts, Notifications, Monitoring ](./docs/all.md#-alerts-notifications-monitoring )
- [ Restaging Apps ](./docs/all.md#-restaging-apps )
- [ Smoke-testing the App ](./docs/all.md#-smoke-testing-the-app )
- [ Configuration Management ](./docs/all.md#-configuration-management )
- [ DNS Changes ](./docs/all.md#-dns-changes )
- [Exporting test results for compliance monitoring ](./docs/all.md#exporting-test-results-for-compliance-monitoring )
- [ Known Gotchas ](./docs/all.md#-known-gotchas )
- [ User Account Management ](./docs/all.md#-user-account-management )
- [ SMS Phone Number Management ](./docs/all.md#-sms-phone-number-management )
- [Data Storage Policies \& Procedures ](./docs/all.md#data-storage-policies--procedures )
- [Potential PII Locations ](./docs/all.md#potential-pii-locations )
- [Data Retention Policy ](./docs/all.md#data-retention-policy )
2023-08-22 17:36:00 -04:00
2022-10-28 16:20:41 -04:00
## License && public domain
2022-11-10 12:33:25 -05:00
Work through [commit `e604385` ](https://github.com/GSA/notifications-api/commit/e604385e0cf4c2ab8c6451b7120ceb196cce21b5 ) is licensed by the UK government under the MIT license. Work after that commit is in the worldwide public domain. See [LICENSE.md ](./LICENSE.md ) for more information.
2022-10-28 16:20:41 -04:00
## Contributing
2023-09-29 10:36:39 -04:00
As stated in [CONTRIBUTING.md ](CONTRIBUTING.md ), all contributions to this project will be released under the CC0 dedication. By submitting a pull request, you are agreeing to comply with this waiver of copyright interest.