Skip to content

project-sunbird/sunbird-ed-installer

Repository files navigation

sunbird-ed-installer

Installing sunbird on Azure

Pre-requisites

  1. Domain Name
  2. SSL Certificate(FullChain -> private key and Certificate+CA_Bundle). Fullchain is mandatory, else installation will fail.

Required CLI tools

  1. Azure CLI (https://learn.microsoft.com/en-us/cli/azure/install-azure-cli)
  2. jq (https://jqlang.github.io/jq/download/)
  3. rclone (https://rclone.org/)
  4. Terraform (https://developer.hashicorp.com/terraform/tutorials/aws-get-started/install-cli)
  5. Terragrunt (https://terragrunt.gruntwork.io/docs/getting-started/install/)
  6. Linux / Macos / Gitbash (Windows)
  7. Python 3
  8. PyJwt python package (you can using using pip)
  9. kubectl
  10. helm
  11. Postman CLI (https://learning.postman.com/docs/getting-started/installation/installation-and-updates/)

Note:

We will copy your existing files in the below location with a .bak extension and create overwrite the below files

  • ~/.config/rclone/rclone.conf

  • ~/.kube/config

  • In the below instructions demo is the environement name. You can change it as per your need. For example - dev, stage etc.

  • Clone the repo git clone https://github.com/project-sunbird/sunbird-ed-installer.git

  • Copy the template directory cd terraform/azure && cp -r template demo

  • Fill the variables in demo/environment.hcl

  • Fill the variables in demo/global-values.yaml

  • Run az login --tenant AZURE_TENANT_ID

  • Run time ./install.sh

Mandatory variables in environment.hcl

Name Description
environment Environment name (between 1 - 9 charcaters). Example: dev, stage
random_string Alphanumeric random string (between 12 - 24) characters. Example: U2PNfwcz6rb9756ZwAwZ

Mandatory variables in global-values.yaml

Name Description
domain Domain name
proxy_private_key SSL private key
proxy_certificate SSL public key

Installation Steps

  1. Create environment folder
cd terraform/<cloud>
cp -rf template dev
cd dev
  1. Update required values in environment.hcl and global-values.yaml files
  2. Run bash install.sh

Default users in the instance

This installation setup creates the following default users with different roles. Feel free to update the password using "Forgot password" option or create new users using API's

Role Email/User Name Password
Admin [email protected] Admin@123
Content Creator [email protected] Creator@123
Content Reviewer [email protected] Reviewer@123
Book Creator [email protected] Bookcreator@123
Book Reviewer [email protected] bookReviewer@123
Public User 1 [email protected] User1@123
Public User 2 [email protected] User2@123