Skip to content

Latest commit

 

History

History
118 lines (81 loc) · 4.48 KB

INSTALLATION.md

File metadata and controls

118 lines (81 loc) · 4.48 KB

Installation

This document describes how to deploy your personal Rocketnotes installation in the cloud at AWS or run it locally with Docker.

Prerequisites

The following tools need to be installed on your system prior to build and deploy to AWS or to your own infrastructure:

git clone https://github.com/fynnfluegge/rocketnotes.git
cd rocketnotes
npm install

AWS hosting

Hosting on your own AWS account will cost you less than $1 per month under normal usage.

Prerequisites

The following tools need to be installed on your system prior to build and deploy to AWS:

Initial Setup

In order to deploy Rocketnotes at AWS you need an AWS Account and configure the AWS CLI locally with aws configure as usual. The deployment itself is very straight forward.

But First, there need to be an existing Cognito user pool and a Hosted Zone associated with your AWS account in the region where you are going to deploy against. You can create a Cognito user pool with a user domain and an app client with the aws console or also programmatically with the AWS CDK. You find an example how to do it with the cdk in Go here. If you want to create the cognito resources via the aws console, there are plenty of resources available how to do it. Here is a good guide to do so.

Second, you need an existing hosted zone in the target region of your AWS account. This requires a domain you are in charge of. How to create a hosted zone and configure Route 53 as a DNS service with your domain you will find here.

Deploy all AWS resources

The following environment variables are required for the deployment:

export AWS_ACCOUNT="<YOUR_AWS_ACCOUNT_ID>"
export AWS_REGION="<YOUR_AWS_REGION>"
export COGNITO_USER_POOL_ID="<YOUR_COGNITO_USER_POOL_ID>"
export COGNITO_APP_CLIENT_ID="<YOUR_COGNITO_APP_CLIENT_ID>"
export DOMAIN_NAME="<YOUR_DOMAIN_NAME>"
export DOMAIN="<YOUR_DOMAIN>"
export SUBDOMAIN="<YOUR_SUBDOMAIN>" # <- use "www" here if you don't have a subdomain configured in your hosted zone (e.g app)

NOTE: <YOUR_DOMAIN_NAME> is your domain without extension like ".com" while <YOUR_DOMAIN> is your domain with extension in this context.

Once your environment variables are specified run:

cd cdk
cdk deploy

The first deployment will take some minutes, since all the resources and lambda functions need to be initially created. If the deployment was successfull the api url should be logged in the console as HTTP API endpoint URL.

Build webapp

The Angular webapp need to be bundled in production mode. The following environment variables are required for the production build:

export REDIRECT_SIGN_IN="<YOUR_DOMAIN_URL>"
export REDIRECT_SIGN_OUT="<YOUR_DOMAIN_URL/logout>"
export AUTH_GUARD_REDIRECT="<AUTH_GUARD_REDIRECT_URL>" # <- "https://<YOUR_DOMAIN_NAME>.auth.<AWS_REGION>.amazoncognito.com/login?response_type=code&client_id=<YOUR_COGNITO_APP_CLIENT_ID>&redirect_uri=https://<YOUR_SUBDOMAIN>.<YOUR_DOMAIN>"
export API_URL="<YOUR_API_URL>" # <- HTTP API endpoint URL from deployment console log

Once your environment variables are specified run:

cd webapp
npm install
npm run build

Deploy webapp

Finally, the Angular app can be deployed to S3 with again:

cd cdk
cdk deploy

This deployment will only deploy the webapp build to the S3 bucket and will be much faster than the previous one.


Run on your local machine with Docker

git clone https://github.com/fynnfluegge/rocketnotes.git
cd rocketnotes
docker-compuse up -d

Docker-compose will create and start four containers with a docker network:

  • the DynamoDB with a volume listening on port 8041
  • the S3 mock listening on port 9091
  • the Angular app listening on port 3001
  • all the lambda functions in a single container listening on port 3002

On initial startup it may take a moment. Once it's done execute sh ./dynamodb-init.sh as a last step to initialize the dynamodb. Now you can open http://localhost:3001 in the browser and you should see the initially created Cheat Sheet document 🚀