Welcome to your Scribble Stadium API. Use this to start the project using nodejs, express and common industry standards.
This repository assumes a handful of industry practices and standards. We strive to keep you on the bleeding edge of the industry and as a result, we have made some opinions for you so that you don't have to; you're welcome.
- Node
- Express
- PostgreSQL
- Knex
There is a glossary of standard terms that are to be used when discussing Scribble Stadium and when writing code available here - Glossary. Using the agreed upon terms will help developers to be understood and maintain consistency.
PORT- API port (optional, but helpful with FE running as well)- The following ports are whitelisted for use with okta
- 3000
- 8000
- 8080
- The following ports are whitelisted for use with okta
DS_API_URL- URL to a data science api. (eg. https://ds-bw-test.herokuapp.com/)DS_API_TOKEN- authorization header token for data science api (eg. SUPERSECRET)DATABASE_URL- connection string for postgres database using the knex url formatTEST_DATABASE_URL- connection string for postgres test database using the knex url formatNODE_ENV- The environment to use for knex scripts, should be development on local and production on live serverAWS_ACCESS_KEY_ID- A special access key from AWSAWS_SECRET_ACCESS_KEY- A secret AWS access key that should not be shared with anyoneCI_DATABASE_URL- the URL of the web-hosted database (I used ElephantSQL) that your CI tests are ran on. This must be set in order to use theknex:ciscript in thepackage.json!S3_BUCKET- the name of the S3 bucket used for file storageAUTH0_CLIENT_ID- the Auth0 client idAUTH0_DOMAIN- the Auth0 domainAUTH0_AUDIENCE- the Auth0 audience
See .env.sample for example values
There are 3 options to get postgresql installed locally [Choose one]:
- Use docker. Install for your platform
- run:
docker-compose up -dto start up the postgresql database and pgadmin. - Open a browser to pgadmin and you should see the Dev server already defined.
- If you need to start over you will need to delete the folder
$ rm -rf ./data/pgas this is where all of the server data is stored.- if the database
api-devwas not created then start over.When using Docker, you will need to manually create your test database, called
api-test
- if the database
- run:
- Download and install postgresql directly from the main site
- make note of the port, username and password you use to setup the database.
- Connect your client to the server manually using the values previously mentioned
- You will need to create a database manually using a client.
- Make sure to update the DATABASE_URL connection string with the values for username/password, databasename and server port (if not 5432).
Make sure you create
api-devto run any queries in Postman or through the swagger documentation, as well as a database calledapi-testto run the Jest tests
- Setup a free account at ElephantSQL
- Sign up for a free
Tiney Turtleplan - copy the URL to the DATABASE_URL .env variable
- make sure to add
?ssl=trueto the end of this urlyou'll need separate databases for Jest testing (
api-test) and Postman/Swagger endpoint testing (api-dev)
- Sign up for a free
- create your project repo by forking or using this as a template.
- run:
npm installto download all dependencies. - run:
cp .env.sample .envand update the enviornment variables to match your local setup. - run:
npm run knex migrate:latestto create the starting schema. - run:
npm run knex seed:runto populate your db with some data. - run:
npm run teststo confirm all is setup and tests pass. - run:
npm run watch:devto start nodemon in local dev enviornment.
Make sure to update the details of the app name, description and version in the
package.jsonandconfig/jsdoc.jsfiles.