Title
Subtitle
TOC
About ● Features ● How It Works ● Installation ● Development ● Contact
A 1-5 sentence summary of what the app is.
1-3 sentences ideal.
Markdown tip: Add two spaces at the end of a line to create a line break.
Try the Demo!
About
● See Website ●
(Inspired by app name)
Describe overview of app, themes and philosophy, inspiration, audience, or whatever... 1-2 paragraphs
Features
- Key action word a feature here.
- Emphasize action for this feature.
- Feature 3 highlights this benefit.
For the Future
An optional brief note describing scheduling or other planning details.
- Major (high priority) A major feature
- Major A major feature
- Minor (low priority) A minor feature
- Maybe Undecided ideas or brainstorming
1. Step One
- To do a thing, follow this step.
- *TIP This is a helpful tip.*
- *NOTE This is note about something.*
- *WARNING! This is a warning!*
Optional Special Section!
For any additional asides. Maybe illustrating a specific example, a table of information, a code snippet, or 'fun facts' or quotes!
- A list
- could be
- nice too
Header A Header B A B
How to Use Feature ABC
Repeat the pattern.
Troubleshooting Z
Repeat the pattern.
Installation
- Create a new postgres database and owner.
- Create a
.env
file matching the.env.example
file and your new postgres information. - Migrate the database with
npx sequelize-cli db:migrate
. - Seed the migration with
npx sequelize-cli db:seed:all
. - Run locally with
npm start
.
Get started on Heroku - Account, Database, Config Vars
- Install the Heroku CLI, if you haven't done so already.
- Create a free Heroku account.
- Login and create a new Heroku app.
- Navigate to the Resources tab an set up a 'Heroku Postgres' database for the app.
- Select the 'Hobby Dev - Free' plan.
- Navigate to the Settings tab. Click 'Reveal Config Vars'. Set the environment variables needed to run the app.
- NOTE NEVER check in
.env
files or any private keys. Environment variables set in an.env
file won't work in Heroku anyway. - NOTE See the
DATABASE_URL
is already set. This is done when the Heroku Postgres database was set up. Therefore,DB_USERNAME
,DB_PASSWORD
, andDB_DATABASE
arent' required.
Configure the app to use the Heroku Postgres database
There are two ways to configure the production
environment:
- With dotenv and a
.sequelizerc
file that points to aconfig/database.js
file. - The Sequelize CLI's auto-generated
config.json
file.
With .sequelizerc and dotenv
Update the config/database.js
file with a production
key like so.
// config/database.js
// ...
module.exports = {
development: {
// ...
},
production: {
use_env_variable: 'DATABASE_URL',
dialect: 'postgres',
dialectOptions: { ssl: true },
seederStorage: 'sequelize'
}
};
With Sequelize CLI's config.json
Change the production
entry to look like this:
"production": {
"dialect": "postgres",
"seederStorage": "sequelize",
"use_env_variable": "DATABASE_URL"
}
➤ Push to Heroku
- In the root of the app's repo directory, log into Heroku with
heroku login
. - Add a new remote to GitHub configuration with
heroku git:remote -a <<app-name-here>>
. - Add all changes with
git add .
. - Commit changes with
git commit -m "<<Add message here>>"
. (Optionally,git commit -am
Adds and commits in one command.) - Push changes to Heroku with
git push Heroku
. - You should see a successful build image.
remote: -----> Launching...
remote: Released v5
remote: https://«your-app-name».herokuapp.com/ deployed to Heroku
remote:
remote: Verifying deploy... done.
To https://git.heroku.com/«app-name-here».git
➤ Run migrations on Heroku
- To migrate your Heroku Postgres database, run the migration command prefaced with
heroku run
inside the repo.
heroku run npx sequelize-cli db:migrate
- To seed, preface the seed command with
heroku run
as well.
heroku run npx sequelize-cli db:seed:all
- To roll back, instead of dropping the database, first try to migrate down and up (shown below). If this doesn't work, reset the entire database by removing and adding the 'Heroku Postgres' add-on again, then migrating and seeding as the first time.
heroku run npx sequelize-cli db:seed:undo:all
heroku run npx sequelize-cli db:migrate:undo:all
heroku run npx sequelize-cli db:migrate
heroku run npx sequelize-cli db:seed:all
➤ Development
DEV TOC
Technologies ● Concept ● Models ● Routes ● Wireframes ● Code Highlights ● Dev Snapshots
[See full dev notes HERE]
The full notes on this project's development are kept in a separate document linked above.
It details the technical aspects of this project's development.
A few sample snapshots are below from the development process.
➤Contact
Thank you very much for your interest in this project.
Feel free to reach out to provide feedback, bug reports, or anything else :) .
Bryan Guner
(Full-stack software developer)