Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jwarwick/student_list
School directory CRM
https://github.com/jwarwick/student_list
Last synced: about 2 months ago
JSON representation
School directory CRM
- Host: GitHub
- URL: https://github.com/jwarwick/student_list
- Owner: jwarwick
- License: mit
- Created: 2021-06-23T14:14:30.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-08-19T15:53:42.000Z (5 months ago)
- Last Synced: 2024-08-20T19:06:23.126Z (5 months ago)
- Language: Elixir
- Size: 653 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# StudentList
Web application to create student directories.
## Local Dev Installation
```
% mix ecto.create
% mix ecto.migrate
% mix phx.server
```## Environment Variables
Needed for Production builds
`DATABASE_URL`, `SECRET_KEY_BASE`, `MAILGUN_API_KEY`, `MAILGUN_DOMAIN`, `HOST`## Gigalixir Deployment
This project was built to run on [Gigalixir](https://www.gigalixir.com/). The [Getting Started Guide](https://gigalixir.readthedocs.io/en/latest/getting-started-guide.html) is a good starting point for account creation, etc.To deploy there, follow these steps:
```
% gigalixir create
% gigalixir pg:create --free # should create a production db for a real project
% gigalixir config:set HOST="my-directory.org"
% gigalixir config:set MAILGUN_DOMAIN="my-directory.org"
% gigalixir config:set MAILGUN_API_KEY="XXXXXXXXXXXXXXXXXX"
% git push gigalixir
% gigalixir run mix ecto.create
% gigalixir run mix ecto.migrate
# Gigalixir provides the DATABASE_URL and SECRET_KEY_BASE environment variables by default% gigalixir domains:add my-directory.org
% gigalixir domains:add www.my-directory.org
```To see the status of your app:
```
% gigalixir ps
{
"cloud": "gcp",
"pods": [
{
"lastState": {},
"name": "navy-XXXXXXXX-borer-XXXXXXXXXX-XXXXXX",
"sha": "XXXXXXXXXXXX",
"status": "Healthy",
"version": "11"
}
],
"region": "v2018-us-central1",
"replicas_desired": 1,
"replicas_running": 1,
"size": 0.3,
"stack": "gigalixir-20",
"unique_name": "navy-XXXXXXXX-borer"
}
```To see system logs:
```
% gigalixir logs
```## Site Account Creation
When the server is started, if no users are present in the database, the `Registration` page will be available at `/users/register`. This account will be an admin account and can finish the server setup.
At setup time, under `Site Configuration`, create a `support_email` key to be displayed in the main page header. Set a value that is forwarded by your email service provider.
## Testing
Several tools are part of the `dev` build which validate the code:
```
% mix test
% mix credo
% mix sobelow
% mix dialyzer
```## Issues
Ran into a few problems during initial project creation:
- There is a bug with `node_sass`, needed to install `phoenix` from the main repo: .
- `mix ecto.migrate` did not work after running ` mix phx.gen.auth Accounts User users`. The create extension citext was failing because the user did not have `SUPERUSER` permissions. To fix, manually connect to the db as a superuser and create the extension:
```
% psql -U jwarwick student_list_dev
student_list_dev=# CREATE EXTENSION citext;
```## LICENSE
Software released under the [MIT License](LICENSE.txt).
Moose favicon from , released under [Creative Commons Zero 1.0 Public Domain License](https://creativecommons.org/publicdomain/zero/1.0/)