To build locally during development, there are three main steps:
- Registering your client in your local database
- rendering the config file (either from vault or by hand-crafting)
- building an app
Each developer has their own auth0 client. You must register your client id and secret in your local database manually--without liquibase--so that our official dev/test/prod environments are not polluted with developer-specific clients. To register your client, do the following:
- Login to the auth0 console and find your client
- Copy the
client ID
andClient Secret
fields - Encrypt the value of Client Secret using the
AesUtil.java
from ddp-study-server repo with passing these variables.
-es [secret-to-encrypt]
4.Paste the id and secret fields into this snippet of SQL, and run it in your local mysql db:
insert into auth0_tenant (auth0_domain, management_client_id, management_client_secret)
values ('https://ddp-dev.auth0.com/', '[client id of management application]',
'[encrypted secret of management application]');
insert into client ( is_revoked, auth0_client_id, auth0_signing_secret)
values ( 0, '[client id]', '[encrypted value of client secret]');
After your local client is registered, you also need to grant it access to the study you're interested in.
insert into client__umbrella_study (client_id, umbrella_study_id)
values ((select client_id from client where auth0_client_id = '[client id]'),
(select umbrella_study_id from umbrella_study where guid = '[the study guid]'))
The pepperConfig.js
file is generated by running the DSDE toolbox script to translate ctmpl
template file into
javascript config files (make sure Ruby and Docker are installed in order to run the script). You must build these config files from the top-level directory (pepper-angular) like so:
# generate study specific configs. Note semi-redundant args for angular dir, image name, and study guid
./build-study.sh [version] [env] . angio ANGIO --config
./build-study.sh [version] [env] . atcp atcp --config
./build-study.sh [version] [env] . brain cmi-brain --config
./build-study.sh [version] [env] . mbc cmi-mbc --config
./build-study.sh [version] [env] . mpc cmi-mpc --config
./build-study.sh [version] [env] . osteo CMI-OSTEO --config
./build-study.sh [version] [env] . prion PRION --config
./build-study.sh [version] [env] . rgp RGP --config
./build-study.sh [version] [env] . testboston testboston --config
./build-study.sh [version] [env] . pancan cmi-pancan --config
There is another way to get the pepperConfig.js file from the development environment: You can go to the project that you require, then open dev-tools and navigate to the network tab. The file can then be copied and pasted into your local environment.
Do not commit rendered ddpConfig.js
and pepperConfig.js
files.
Once rendered, you can hand-edit the pepper-angular/ddp-workspace/projects/[ddp-angio | ddp-brain | ddp-mbc]/src/assets/config/pepperConfig.js
on-the-fly during front-end development via ng serve
to alter your auth0 client and enable local registration for local development, editing it like so:
- Find
DDP_ENV['basePepperUrl']
orbasePepperUrl
and change the value to"http://localhost:[<port> value from local backend config]"
- Find
DDP_ENV['auth0ClientId']
orauth0ClientId
and change the value to your local dev auth0 client id - Find
doLocalRegistration
and change the value totrue
- Install nvm to manage different versions of node and npm
nvm use 12.20.0
npm install -g @angular/[email protected]
(if you're working on different angular projects, you may first need anpm uninstall -g @angular/cli
)cd ddp-workspace
npm cache clean
,rm -fr node_modules
andrm -fr dist
(can often be skipped)npm install
(this can often be skipped, but must be done at least once. If you get an error similar to "code: ERESOLVE - ERESOLVE could not resolve", you can try by executingnpm install --legacy-peer-deps
)ng serve [your app]
(sandbox-app, basil-app, ddp-angio, ddp-brain, ddp-mbc)
Finally...Point your local browser to localhost
We build docker images which we then use for deployment so that we build the app once and then move images around through different environnments.
The build creates a single image that contains both the SDK and the test app. We build these two things together for better development velocity.
docker-compose build
The image builds the sdk and the test app, then starts a container and maps it to port 80 so you can see the component showcase test app.
Because there are private credentials in the build script, you must first render the build script using our vault utility, then set the rendered file as executable, and finally run the script.
docker run --rm -v $PWD:/working -e VAULT_TOKEN=$(cat ~/.vault-token) -e ENVIRONMENT=dev -e VERSION=v1 -e OUT_PATH=./output-config -e INPUT_PATH=./config broadinstitute/dsde-toolbox:dev render-templates.sh
chmod +x output-config/deploy_to_artifactory.sh
docker run --rm -v $(pwd)/output-config/deploy_to_artifactory.sh:/deploy_to_artifactory.sh webui_demo-webapp /deploy_to_artifactory.sh
The version is controlled via sdk package.json and toolkit package.json. Whatever version is set there is what gets published to artifactory. If you attempt to re-publish a version that already exists, npm will fail. Be sure that you're always publishing a new version.