- Create a Scratch Org
sfdx force:org:create -s -f config/project-scratch-def.json -a routeplannerdemo
- Push Source to Org
sfdx force:source:push -f
- Assign Permission Sets
sfdx force:user:permset:assign -n RoutePlanner
sfdx force:user:permset:assign -n Functions
- Import Sample Data
sfdx force:data:tree:import -p data/Account-Service__c-plan.json
- Create a Compute Environment to Deploy Functions
sf env create compute -o routeplannerdemo -a routeplannerenv
- Deploy Functions
sf deploy functions -o routeplannerdemo
- Create Heroku Application for Data Resources
heroku create <app-name>
- Add Heroku User Collaborator to Functions Account
sf env compute collaborator add --heroku-user [email protected]
- Create Postgres and Redis Resources
heroku addons:create heroku-postgresql:hobby-dev
heroku addons:create heroku-redis:hobby-dev
- Attach Data Resources to Compute Environment
heroku addons:attach <example-postgres-database> --app <example-compute-environment-name>
heroku addons:attach <example-redis-database> --app <example-compute-environment-name>
- Deploy MQTT Heroku App
Setup Monorepo and Node.js Buildpacks:
heroku buildpacks:add https://github.com/lstoll/heroku-buildpack-monorepo -a <app-name>
heroku buildpacks:add heroku/nodejs -a <app-name>
Deploy Application using the Monorepo buildpack
heroku config:set APP_BASE=apps/pulsar-mqtt-broker
git push https://git.heroku.com/<heroku-app-name>.git main
- Setup
MQTT_URL
env variable
sf env var set MQTT_URL=wss://<heroku-app-name>.herokuapp.com
- Load Charging Stations Dataset
cd scripts
npm install
heroku config --shell -a <app-name> > .env
node create-db.js