diff --git a/.config/README.md b/.config/README.md deleted file mode 100644 index 0183c517b4..0000000000 --- a/.config/README.md +++ /dev/null @@ -1,3 +0,0 @@ -# Configuration - -Overall configuration for the solution, used in our GitHub Actions Pipeline diff --git a/.config/config.json b/.config/config.json deleted file mode 100644 index 035648c7a3..0000000000 --- a/.config/config.json +++ /dev/null @@ -1,89 +0,0 @@ -{ - "name": "biohubbc", - "namespaceSuffix": "af2668", - "namespace": { - "tools": "tools", - "dev": "dev", - "test": "test", - "prod": "prod" - }, - "version": "1.0.0", - "timezone": { - "db": "America/Vancouver", - "api": "America/Vancouver" - }, - "module": { - "db": "biohubbc-db", - "api": "biohubbc-api", - "app": "biohubbc-app" - }, - "staticUrls": { - "dev": "dev-biohubbc.apps.silver.devops.gov.bc.ca", - "test": "test-biohubbc.apps.silver.devops.gov.bc.ca", - "prod": "biohubbc.apps.silver.devops.gov.bc.ca", - "prodVanityUrl": "sims.nrs.gov.bc.ca" - }, - "staticUrlsAPI": { - "dev": "api-dev-biohubbc.apps.silver.devops.gov.bc.ca", - "test": "api-test-biohubbc.apps.silver.devops.gov.bc.ca", - "prod": "api-biohubbc.apps.silver.devops.gov.bc.ca" - }, - "siteminderLogoutURL": { - "dev": "https://logontest7.gov.bc.ca/clp-cgi/logoff.cgi", - "test": "https://logontest7.gov.bc.ca/clp-cgi/logoff.cgi", - "prod": "https://logon7.gov.bc.ca/clp-cgi/logoff.cgi" - }, - "sso": { - "dev": { - "host": "https://dev.loginproxy.gov.bc.ca/auth", - "realm": "standard", - "clientId": "sims-4461", - "keycloakSecret": "keycloak", - "serviceClient": { - "serviceClientName": "sims-svc-4464", - "keycloakSecretServiceClientPasswordKey": "sims_svc_client_password" - }, - "cssApi": { - "cssApiTokenUrl": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", - "cssApiClientId": "service-account-team-1190-4229", - "cssApiHost": "https://api.loginproxy.gov.bc.ca/api/v1", - "keycloakSecretCssApiSecretKey": "css_api_client_secret", - "cssApiEnvironment": "dev" - } - }, - "test": { - "host": "https://test.loginproxy.gov.bc.ca/auth", - "realm": "standard", - "clientId": "sims-4461", - "keycloakSecret": "keycloak", - "serviceClient": { - "serviceClientName": "sims-svc-4464", - "keycloakSecretServiceClientPasswordKey": "sims_svc_client_password" - }, - "cssApi": { - "cssApiTokenUrl": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", - "cssApiClientId": "service-account-team-1190-4229", - "cssApiHost": "https://api.loginproxy.gov.bc.ca/api/v1", - "keycloakSecretCssApiSecretKey": "css_api_client_secret", - "cssApiEnvironment": "test" - } - }, - "prod": { - "host": "https://loginproxy.gov.bc.ca/auth", - "realm": "standard", - "clientId": "sims-4461", - "keycloakSecret": "keycloak", - "serviceClient": { - "serviceClientName": "sims-svc-4464", - "keycloakSecretServiceClientPasswordKey": "sims_svc_client_password" - }, - "cssApi": { - "cssApiTokenUrl": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", - "cssApiClientId": "service-account-team-1190-4229", - "cssApiHost": "https://api.loginproxy.gov.bc.ca/api/v1", - "keycloakSecretCssApiSecretKey": "css_api_client_secret", - "cssApiEnvironment": "prod" - } - } - } -} diff --git a/.github/workflows/cleanClosedPR.yml b/.github/workflows/cleanClosedPR.yml index dd49ecd25d..16904da8be 100644 --- a/.github/workflows/cleanClosedPR.yml +++ b/.github/workflows/cleanClosedPR.yml @@ -51,24 +51,24 @@ jobs: working-directory: "app/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=pr # Clean the database build/deployment artifacts - name: Clean Database Artifacts working-directory: "database/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=pr # Clean the api deployment artifacts - name: Clean API Deployment working-directory: "api/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=pr # Clean the reamaining build/deployment artifacts - name: Clean remaining Artifacts diff --git a/.github/workflows/cleanMergedPR.yml b/.github/workflows/cleanMergedPR.yml index 680c34c0b3..5f1a1f00f5 100644 --- a/.github/workflows/cleanMergedPR.yml +++ b/.github/workflows/cleanMergedPR.yml @@ -56,7 +56,7 @@ jobs: run: | npm ci DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr # Clean the database build/deployment artifacts - name: Clean Database Artifacts @@ -64,7 +64,7 @@ jobs: run: | npm ci DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr # Clean the api deployment artifacts - name: Clean API Deployment @@ -72,7 +72,7 @@ jobs: run: | npm ci DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr # Clean the reamaining build/deployment artifacts - name: Clean remaining Artifacts diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index c0a4ae674c..dbf1160c2d 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -46,7 +46,8 @@ jobs: # Set to `true` if the latest commit message contains `ignore-skip` anywhere in the message OR the base branch # is dev, test, or prod. # Used to disable duplicate action skipping, if needed. - ignore_skip: ${{ contains(steps.head_commit_message.outputs.commit_message, 'ignore-skip') || + ignore_skip: + ${{ contains(steps.head_commit_message.outputs.commit_message, 'ignore-skip') || github.head_ref == 'dev' || github.head_ref == 'test' || github.head_ref == 'prod' }} steps: - id: skip_check @@ -129,6 +130,29 @@ jobs: with: node-version: 14 + # Fetch the pipeline config map from Openshift + getPipelineConfigMap: + name: Get Pipeline Config + runs-on: ubuntu-latest + timeout-minutes: 20 + if: ${{ github.event.pull_request.merged == false }} + env: + PR_NUMBER: ${{ github.event.number }} + outputs: + pipeline_config: ${{ steps.get_config.outputs.pipeline_config }} + steps: + # Log in to OpenShift. + # Note: The secrets needed to log in are NOT available if the PR comes from a FORK. + # PR's must originate from a branch off the original repo or else all openshift `oc` commands will fail. + - name: Log in to OpenShift + run: oc login --token=${{ secrets.TOOLS_SA_TOKEN }} --server=https://api.silver.devops.gov.bc.ca:6443 + + # Fetch config map named 'sims-pipeline-config' from the tools environment and store in 'pipeline_config' variable for use by subsequent jobs + - name: Fetch pipeline config map + id: "get_config" + run: | + echo "pipeline_config=$( oc -n af2668-tools get configmap sims-pipeline-config -o jsonpath={.data.config} | jq -c )" >> "$GITHUB_OUTPUT" + # Build the web frontend app image buildAPP: name: Build APP Image @@ -142,9 +166,11 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} APP_NAME: "biohubbc-app" + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo - skipDuplicateActions + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -189,7 +215,7 @@ jobs: - name: Build APP Image working-directory: app/.pipeline/ run: | - DEBUG=* npm run build -- --pr=$PR_NUMBER + DEBUG=* npm run build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=build # Build the Database image buildDatabase: @@ -204,9 +230,11 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} APP_NAME: "biohubbc-db" + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo - skipDuplicateActions + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -251,7 +279,7 @@ jobs: - name: Build Database Image working-directory: database/.pipeline/ run: | - DEBUG=* npm run db:build -- --pr=$PR_NUMBER + DEBUG=* npm run db:build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=build # Build the Database Setup image buildDatabaseSetup: @@ -265,9 +293,11 @@ jobs: fromJSON(needs.skipDuplicateActions.outputs.paths_result).database.skipped_by.branch != github.head_ref ) }} env: PR_NUMBER: ${{ github.event.number }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo - skipDuplicateActions + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -306,7 +336,7 @@ jobs: - name: Build Database Setup Image working-directory: database/.pipeline/ run: | - DEBUG=* npm run db-setup:build -- --pr=$PR_NUMBER + DEBUG=* npm run db-setup:build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=build # Build the API image buildAPI: @@ -321,9 +351,11 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} APP_NAME: "biohubbc-api" + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo - skipDuplicateActions + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -368,7 +400,7 @@ jobs: - name: Build API Image working-directory: api/.pipeline/ run: | - DEBUG=* npm run build -- --pr=$PR_NUMBER + DEBUG=* npm run build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=build # Deploy APP image deployAPP: @@ -382,7 +414,10 @@ jobs: fromJSON(needs.skipDuplicateActions.outputs.paths_result).app.skipped_by.branch != github.head_ref ) }} env: PR_NUMBER: ${{ github.event.number }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: + - skipDuplicateActions + - getPipelineConfigMap - buildAPP steps: # Install Node - for `node` and `npm` commands @@ -422,7 +457,7 @@ jobs: - name: Deploy APP Image working-directory: app/.pipeline run: | - DEBUG=* npm run deploy -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=deploy # Deploy Database image deployDatabase: @@ -436,7 +471,10 @@ jobs: fromJSON(needs.skipDuplicateActions.outputs.paths_result).database.skipped_by.branch != github.head_ref ) }} env: PR_NUMBER: ${{ github.event.number }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: + - skipDuplicateActions + - getPipelineConfigMap - buildDatabase steps: # Install Node - for `node` and `npm` commands @@ -476,7 +514,7 @@ jobs: - name: Deploy Database Image working-directory: database/.pipeline/ run: | - DEBUG=* npm run db:deploy -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run db:deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=deploy # Deploy Database image deployDatabaseSetup: @@ -490,7 +528,10 @@ jobs: fromJSON(needs.skipDuplicateActions.outputs.paths_result).database.skipped_by.branch != github.head_ref ) }} env: PR_NUMBER: ${{ github.event.number }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: + - skipDuplicateActions + - getPipelineConfigMap - buildDatabaseSetup - deployDatabase steps: @@ -531,7 +572,7 @@ jobs: - name: Deploy Database Setup Image working-directory: database/.pipeline/ run: | - DEBUG=* npm run db-setup:deploy -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run db-setup:deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=deploy # Deploy API image deployAPI: @@ -547,7 +588,10 @@ jobs: fromJSON(needs.skipDuplicateActions.outputs.paths_result).api.skipped_by.branch != github.head_ref ) }} env: PR_NUMBER: ${{ github.event.number }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: + - skipDuplicateActions + - getPipelineConfigMap - buildAPI - deployDatabase steps: @@ -588,7 +632,7 @@ jobs: - name: Deploy API Image working-directory: api/.pipeline/ run: | - DEBUG=* npm run deploy -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=pr --phase=deploy # Report the overall status of all jobs. # Why? Skipped jobs are not considered successes when specifying requird jobs in the GitHub PR settings. Rather than @@ -605,6 +649,7 @@ jobs: - checkEnv - skipDuplicateActions - checkoutRepo + - getPipelineConfigMap - buildAPP - buildDatabase - buildDatabaseSetup diff --git a/.github/workflows/deployStatic.yml b/.github/workflows/deployStatic.yml index 16cce447ba..4f7d143c3d 100644 --- a/.github/workflows/deployStatic.yml +++ b/.github/workflows/deployStatic.yml @@ -85,6 +85,29 @@ jobs: path: ${{ github.workspace }}/* key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ github.sha }} + # Fetch the pipeline config map from Openshift + getPipelineConfigMap: + name: Get Pipeline Config + runs-on: ubuntu-latest + timeout-minutes: 20 + if: ${{ github.event.pull_request.merged == false }} + env: + PR_NUMBER: ${{ github.event.number }} + outputs: + pipeline_config: ${{ steps.get_config.outputs.pipeline_config }} + steps: + # Log in to OpenShift. + # Note: The secrets needed to log in are NOT available if the PR comes from a FORK. + # PR's must originate from a branch off the original repo or else all openshift `oc` commands will fail. + - name: Log in to OpenShift + run: oc login --token=${{ secrets.TOOLS_SA_TOKEN }} --server=https://api.silver.devops.gov.bc.ca:6443 + + # Fetch config map named 'sims-pipeline-config' from the tools environment and store in 'pipeline_config' variable for use by subsequent jobs + - name: Fetch pipeline config map + id: "get_config" + run: | + echo "pipeline_config=$( oc -n af2668-tools get configmap sims-pipeline-config -o jsonpath={.data.config} | jq -c )" >> "$GITHUB_OUTPUT" + # Build the web frontend app image buildAPP: name: Build APP Image @@ -94,8 +117,10 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -133,7 +158,7 @@ jobs: - name: Build APP Image working-directory: "app/.pipeline/" run: | - DEBUG=* npm run build -- --pr=$PR_NUMBER --branch=$BRANCH --type=static + DEBUG=* npm run build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=build --branch=$BRANCH # Build the Database image buildDatabase: @@ -144,8 +169,10 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -183,7 +210,7 @@ jobs: - name: Build Database Image working-directory: "database/.pipeline/" run: | - DEBUG=* npm run db:build -- --pr=$PR_NUMBER --branch=$BRANCH --type=static + DEBUG=* npm run db:build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=build --branch=$BRANCH # Build the Database Setup image buildDatabaseSetup: @@ -194,8 +221,10 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -233,7 +262,7 @@ jobs: - name: Build Database Setup Image working-directory: "database/.pipeline/" run: | - DEBUG=* npm run db-setup:build -- --pr=$PR_NUMBER --branch=$BRANCH --type=static + DEBUG=* npm run db-setup:build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=build --branch=$BRANCH # Build the API image buildAPI: @@ -244,8 +273,10 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - checkoutRepo + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -283,7 +314,7 @@ jobs: - name: Build API Image working-directory: "api/.pipeline/" run: | - DEBUG=* npm run build -- --pr=$PR_NUMBER --branch=$BRANCH --type=static + DEBUG=* npm run build -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=build --branch=$BRANCH # Deploy APP image deployAPP: @@ -294,9 +325,11 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - scaleDownPods - buildAPP + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -334,7 +367,7 @@ jobs: - name: Deploy APP Image working-directory: "app/.pipeline" run: | - DEBUG=* npm run deploy -- --pr=$PR_NUMBER --env=$BRANCH --branch=$BRANCH --type=static + DEBUG=* npm run deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=deploy --branch=$BRANCH # Deploy Database image deployDatabase: @@ -345,9 +378,11 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - scaleDownPods - buildDatabase + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -385,7 +420,7 @@ jobs: - name: Deploy Database Image working-directory: "database/.pipeline/" run: | - DEBUG=* npm run db:deploy -- --pr=$PR_NUMBER --env=$BRANCH --branch=$BRANCH --type=static + DEBUG=* npm run db:deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=deploy --branch=$BRANCH # Deploy Database setup image deployDatabaseSetup: @@ -396,10 +431,12 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - scaleDownPods - buildDatabaseSetup - deployDatabase + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -437,7 +474,7 @@ jobs: - name: Deploy Database Setup Image working-directory: "database/.pipeline/" run: | - DEBUG=* npm run db-setup:deploy -- --pr=$PR_NUMBER --env=$BRANCH --branch=$BRANCH --type=static + DEBUG=* npm run db-setup:deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=deploy --branch=$BRANCH # Deploy API image deployAPI: @@ -448,10 +485,12 @@ jobs: env: PR_NUMBER: ${{ github.event.number }} BRANCH: ${{ github.base_ref }} + PIPELINE_CONFIG: ${{ needs.getPipelineConfigMap.outputs.pipeline_config }} needs: - scaleDownPods - buildAPI - deployDatabase + - getPipelineConfigMap steps: # Install Node - for `node` and `npm` commands - name: Setup Node.js @@ -489,7 +528,7 @@ jobs: - name: Deploy API Image working-directory: "api/.pipeline/" run: | - DEBUG=* npm run deploy -- --pr=$PR_NUMBER --env=$BRANCH --branch=$BRANCH --type=static + DEBUG=* npm run deploy -- --pr=$PR_NUMBER --config=$PIPELINE_CONFIG --env=$BRANCH --phase=deploy --branch=$BRANCH # Clean build/deployment artifacts clean: @@ -538,24 +577,24 @@ jobs: working-directory: "app/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=deploy # Clean the database build/deployment artifacts - name: Clean Database Artifacts working-directory: "database/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=deploy # Clean the api deployment artifacts - name: Clean API Deployment working-directory: "api/.pipeline/" run: | npm ci - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=build - DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=dev + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=build + DEBUG=* npm run clean -- --pr=$PR_NUMBER --env=pr --phase=deploy # Clean the reamaining build/deployment artifacts - name: Clean remaining Artifacts diff --git a/.pipeline/configMaps/README.md b/.pipeline/configMaps/README.md new file mode 100644 index 0000000000..72ad12e30b --- /dev/null +++ b/.pipeline/configMaps/README.md @@ -0,0 +1,40 @@ +# Openshift Config Map + +`sims-pipeline-config.json` is a working sample of the config map that should be created in the tools environment. + +Note: The exact values in the sample config map may fall out of sync with what is in Openshift, as changes to values are made directly in Openshift (ex: updating cpu/memory limits in OpenShift, etc). + +Note: Config maps should never contain secrets, passwords, or other sensitive values. They are not protected in OpenShift and their values may appear in logs, etc. Sensitive data should always be stored in Openshift secrets. + +## Create Config Map in Openshift + +Under the tools environment: `af2668-tools` + +#### Option 1 + +Under `Workloads` -> `ConfigMaps` + +1. Click `Create ConfigMap` +2. Set field values as follows: + - **name:** `sims-pipeline-config` + - **immutable:** `false` (leave unchecked) + - **key:** `config` + - **value:** A JSON object containing the config map settings. +3. Click `Create` + +#### Option 2 + +1. Click the plus icon `(+)` in the Openshift header (next to your user name in the top right corner). +2. Copy/paste the entire contents of the sample `sims.configmap.yaml` (make changes as needed now, or update afterwards) +3. Click `Create` + +## Updating Config Map in Openshift + +Under the tools environment: `af2668-tools` + +Under `Workloads` -> `ConfigMaps` + +1. Click on target config map +2. Click `Actions` -> `Edit ConfigMap` +3. Update the `value`, making changes to the JSON object as needed. +4. Click `Save` diff --git a/.pipeline/configMaps/sims.configmap.yaml b/.pipeline/configMaps/sims.configmap.yaml new file mode 100644 index 0000000000..ad9b0d48cf --- /dev/null +++ b/.pipeline/configMaps/sims.configmap.yaml @@ -0,0 +1,504 @@ +kind: ConfigMap +apiVersion: v1 +metadata: + name: sims-pipeline-config + namespace: af2668-tools + annotations: + description: | + This config map is required by the sims pipeline. It provides all of the configuration settings and environment + variables required by the pipeline. This config is designed to exist, in the tools namespace, and + provide all of the configuration settings required by the pipeline for all environments (PR, DEV, TEST, PROD). +immutable: false +data: + config: | + { + "name": "biohubbc", + "version": "1.0.0", + "module": { + "db": "biohubbc-db", + "api": "biohubbc-api", + "app": "biohubbc-app" + }, + "api": { + "pr": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "3Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "MAX_REQ_BODY_SIZE": "52428800", + "TZ": "America/Vancouver", + "BACKBONE_INTERNAL_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BACKBONE_INTAKE_PATH": "/api/submission/intake", + "BACKBONE_ARTIFACT_INTAKE_PATH": "/api/artifact/intake", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BACKBONE_INTAKE_ENABLED": true, + "BCTW_API_HOST": "https://moe-bctw-api-dev.apps.silver.devops.gov.bc.ca", + "CB_API_HOST": "https://moe-critterbase-api-dev.apps.silver.devops.gov.bc.ca/api", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": "10", + "MAX_UPLOAD_FILE_SIZE": "52428800", + "S3_KEY_PREFIX": "sims-pr", + "LOG_LEVEL": "debug", + "API_RESPONSE_VALIDATION_ENABLED": true, + "DATABASE_RESPONSE_VALIDATION_ENABLED": true, + "ENABLE_FILE_VIRUS_SCAN": true, + "CLAMAV_HOST": "clamav", + "CLAMAV_PORT": "3310", + "NODE_OPTIONS": "--max_old_space_size=2250", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "3Gi", + "REPLICAS": "1", + "REPLICAS_MAX": "1" + } + }, + "dev": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "3Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "API_HOST": "api-dev-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "dev-biohubbc.apps.silver.devops.gov.bc.ca", + "MAX_REQ_BODY_SIZE": "52428800", + "TZ": "America/Vancouver", + "BACKBONE_INTERNAL_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BACKBONE_INTAKE_PATH": "/api/submission/intake", + "BACKBONE_ARTIFACT_INTAKE_PATH": "/api/artifact/intake", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BACKBONE_INTAKE_ENABLED": true, + "BCTW_API_HOST": "https://moe-bctw-api-dev.apps.silver.devops.gov.bc.ca", + "CB_API_HOST": "https://moe-critterbase-api-dev.apps.silver.devops.gov.bc.ca/api", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": "10", + "MAX_UPLOAD_FILE_SIZE": "52428800", + "S3_KEY_PREFIX": "sims", + "LOG_LEVEL": "debug", + "API_RESPONSE_VALIDATION_ENABLED": true, + "DATABASE_RESPONSE_VALIDATION_ENABLED": true, + "ENABLE_FILE_VIRUS_SCAN": true, + "CLAMAV_HOST": "clamav", + "CLAMAV_PORT": "3310", + "NODE_OPTIONS": "--max_old_space_size=3000", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "600m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "4Gi", + "REPLICAS": "1", + "REPLICAS_MAX": "2" + } + }, + "test": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "3Gi" + }, + "deploy": { + "NAMESPACE": "af2668-test", + "NODE_ENV": "production", + "API_HOST": "api-test-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "test-biohubbc.apps.silver.devops.gov.bc.ca", + "MAX_REQ_BODY_SIZE": "52428800", + "TZ": "America/Vancouver", + "BACKBONE_INTERNAL_API_HOST": "https://api-test-biohub-platform.apps.silver.devops.gov.bc.ca", + "BACKBONE_INTAKE_PATH": "/api/submission/intake", + "BACKBONE_ARTIFACT_INTAKE_PATH": "/api/artifact/intake", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BACKBONE_INTAKE_ENABLED": true, + "BCTW_API_HOST": "https://moe-bctw-api-test.apps.silver.devops.gov.bc.ca", + "CB_API_HOST": "https://moe-critterbase-api-test.apps.silver.devops.gov.bc.ca/api", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": "10", + "MAX_UPLOAD_FILE_SIZE": "52428800", + "S3_KEY_PREFIX": "sims", + "LOG_LEVEL": "info", + "API_RESPONSE_VALIDATION_ENABLED": true, + "DATABASE_RESPONSE_VALIDATION_ENABLED": true, + "ENABLE_FILE_VIRUS_SCAN": true, + "CLAMAV_HOST": "clamav", + "CLAMAV_PORT": "3310", + "NODE_OPTIONS": "--max_old_space_size=3000", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "4Gi", + "REPLICAS": "2", + "REPLICAS_MAX": "2" + } + }, + "prod": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "3Gi" + }, + "deploy": { + "NAMESPACE": "af2668-prod", + "NODE_ENV": "production", + "API_HOST": "api-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "biohubbc.apps.silver.devops.gov.bc.ca", + "APP_VANITY_URL": "biohubbc.nrs.gov.bc.ca", + "MAX_REQ_BODY_SIZE": "52428800", + "TZ": "America/Vancouver", + "BACKBONE_INTERNAL_API_HOST": "https://api-biohub-platform.apps.silver.devops.gov.bc.ca", + "BACKBONE_INTAKE_PATH": "/api/submission/intake", + "BACKBONE_ARTIFACT_INTAKE_PATH": "/api/artifact/intake", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BACKBONE_INTAKE_ENABLED": false, + "BCTW_API_HOST": "https://moe-bctw-api-prod.apps.silver.devops.gov.bc.ca", + "CB_API_HOST": "https://moe-critterbase-api-prod.apps.silver.devops.gov.bc.ca/api", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": "10", + "MAX_UPLOAD_FILE_SIZE": "52428800", + "S3_KEY_PREFIX": "sims", + "LOG_LEVEL": "warn", + "API_RESPONSE_VALIDATION_ENABLED": false, + "DATABASE_RESPONSE_VALIDATION_ENABLED": false, + "ENABLE_FILE_VIRUS_SCAN": true, + "CLAMAV_HOST": "clamav", + "CLAMAV_PORT": "3310", + "NODE_OPTIONS": "--max_old_space_size=6000", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1750m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "8Gi", + "REPLICAS": "2", + "REPLICAS_MAX": "2" + } + } + }, + "app": { + "pr": { + "build": { + "NAMESPACE": "af2668-tools", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "SITEMINDER_LOGOUT_URL": "https://logontest7.gov.bc.ca/clp-cgi/logoff.cgi", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": 10, + "MAX_UPLOAD_FILE_SIZE": 52428800, + "REACT_APP_BIOHUB_FEATURE_FLAG": "true", + "BACKBONE_PUBLIC_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "300m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "500Mi", + "REPLICAS": "1", + "REPLICAS_MAX": "1" + } + }, + "dev": { + "build": { + "NAMESPACE": "af2668-tools", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "API_HOST": "api-dev-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "dev-biohubbc.apps.silver.devops.gov.bc.ca", + "SITEMINDER_LOGOUT_URL": "https://logontest7.gov.bc.ca/clp-cgi/logoff.cgi", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": 10, + "MAX_UPLOAD_FILE_SIZE": 52428800, + "REACT_APP_BIOHUB_FEATURE_FLAG": "true", + "BACKBONE_PUBLIC_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "300m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "500Mi", + "REPLICAS": "1", + "REPLICAS_MAX": "2" + } + }, + "test": { + "build": { + "NAMESPACE": "af2668-tools", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-test", + "NODE_ENV": "production", + "API_HOST": "api-test-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "test-biohubbc.apps.silver.devops.gov.bc.ca", + "SITEMINDER_LOGOUT_URL": "https://logontest7.gov.bc.ca/clp-cgi/logoff.cgi", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": 10, + "MAX_UPLOAD_FILE_SIZE": 52428800, + "REACT_APP_BIOHUB_FEATURE_FLAG": "true", + "BACKBONE_PUBLIC_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "500Mi", + "REPLICAS": "2", + "REPLICAS_MAX": "2" + } + }, + "prod": { + "build": { + "NAMESPACE": "af2668-tools", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1500m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-prod", + "NODE_ENV": "production", + "API_HOST": "api-biohubbc.apps.silver.devops.gov.bc.ca", + "APP_HOST": "biohubbc.apps.silver.devops.gov.bc.ca", + "APP_VANITY_URL": "biohubbc.nrs.gov.bc.ca", + "SITEMINDER_LOGOUT_URL": "https://logon7.gov.bc.ca/clp-cgi/logoff.cgi", + "OBJECT_STORE_SECRET": "biohubbc-object-store", + "MAX_UPLOAD_NUM_FILES": 10, + "MAX_UPLOAD_FILE_SIZE": 52428800, + "REACT_APP_BIOHUB_FEATURE_FLAG": "false", + "BACKBONE_PUBLIC_API_HOST": "https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca", + "BIOHUB_TAXON_PATH": "/api/taxonomy/taxon", + "BIOHUB_TAXON_TSN_PATH": "/api/taxonomy/taxon/tsn", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "1Gi", + "REPLICAS": "2", + "REPLICAS_MAX": "2" + } + } + }, + "database": { + "pr": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "SOURCE_CONTEXT_DIR": "database", + "DB_SETUP_DOCKERFILE_PATH": "./.docker/db/Dockerfile.setup", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "1.5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "TZ": "America/Vancouver", + "DB_SCHEMA": "biohub", + "DB_SCHEMA_DAPI_V1": "biohub_dapi_v1", + "SEED_PROJECT_USER_IDENTIFIER": "1", + "SEED_NUM_PROJECTS": "2", + "SEED_NUM_SURVEYS_PER_PROJECT": "2", + "SEED_NUM_OBSERVATIONS_PER_SURVEY": "2", + "SEED_NUM_SUBCOUNTS_PER_OBSERVATION": "1", + "VOLUME_CAPACITY": "500Mi", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "400m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "2Gi", + "REPLICAS": "1" + } + }, + "dev": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "SOURCE_CONTEXT_DIR": "database", + "DB_SETUP_DOCKERFILE_PATH": "./.docker/db/Dockerfile.setup", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "1.5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-dev", + "NODE_ENV": "development", + "TZ": "America/Vancouver", + "DB_SCHEMA": "biohub", + "DB_SCHEMA_DAPI_V1": "biohub_dapi_v1", + "SEED_PROJECT_USER_IDENTIFIER": "1", + "SEED_NUM_PROJECTS": "2", + "SEED_NUM_SURVEYS_PER_PROJECT": "2", + "SEED_NUM_OBSERVATIONS_PER_SURVEY": "2", + "SEED_NUM_SUBCOUNTS_PER_OBSERVATION": "1", + "VOLUME_CAPACITY": "3Gi", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "600m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "4Gi", + "REPLICAS": "1" + } + }, + "test": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "SOURCE_CONTEXT_DIR": "database", + "DB_SETUP_DOCKERFILE_PATH": "./.docker/db/Dockerfile.setup", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "1.5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-test", + "NODE_ENV": "production", + "TZ": "America/Vancouver", + "DB_SCHEMA": "biohub", + "DB_SCHEMA_DAPI_V1": "biohub_dapi_v1", + "SEED_PROJECT_USER_IDENTIFIER": "1", + "SEED_NUM_PROJECTS": "0", + "SEED_NUM_SURVEYS_PER_PROJECT": "0", + "SEED_NUM_OBSERVATIONS_PER_SURVEY": "0", + "SEED_NUM_SUBCOUNTS_PER_OBSERVATION": "0", + "VOLUME_CAPACITY": "20Gi", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "2000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "5Gi", + "REPLICAS": "1" + } + }, + "prod": { + "build": { + "NAMESPACE": "af2668-tools", + "TZ": "America/Vancouver", + "SOURCE_CONTEXT_DIR": "database", + "DB_SETUP_DOCKERFILE_PATH": "./.docker/db/Dockerfile.setup", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "1000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "1.5Gi" + }, + "deploy": { + "NAMESPACE": "af2668-prod", + "NODE_ENV": "production", + "TZ": "America/Vancouver", + "DB_SCHEMA": "biohub", + "DB_SCHEMA_DAPI_V1": "biohub_dapi_v1", + "SEED_PROJECT_USER_IDENTIFIER": "1", + "SEED_NUM_PROJECTS": "0", + "SEED_NUM_SURVEYS_PER_PROJECT": "0", + "SEED_NUM_OBSERVATIONS_PER_SURVEY": "0", + "SEED_NUM_SUBCOUNTS_PER_OBSERVATION": "0", + "VOLUME_CAPACITY": "20Gi", + "CPU_REQUEST": "50m", + "CPU_LIMIT": "4000m", + "MEMORY_REQUEST": "100Mi", + "MEMORY_LIMIT": "10Gi", + "REPLICAS": "1" + } + } + }, + "sso": { + "pr": { + "KEYCLOAK_HOST": "https://dev.loginproxy.gov.bc.ca/auth", + "KEYCLOAK_REALM": "standard", + "KEYCLOAK_CLIENT_ID": "sims-4461", + "KEYCLOAK_SECRET": "sims-keycloak", + "serviceClient": { + "KEYCLOAK_ADMIN_USERNAME": "sims-svc-4464", + "KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY": "sims_svc_client_password" + }, + "cssApi": { + "KEYCLOAK_API_TOKEN_URL": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", + "KEYCLOAK_API_CLIENT_ID": "service-account-team-1190-4229", + "KEYCLOAK_API_HOST": "https://api.loginproxy.gov.bc.ca/api/v1", + "KEYCLOAK_API_CLIENT_SECRET_KEY": "css_api_client_secret", + "KEYCLOAK_API_ENVIRONMENT": "dev" + } + }, + "dev": { + "KEYCLOAK_HOST": "https://dev.loginproxy.gov.bc.ca/auth", + "KEYCLOAK_REALM": "standard", + "KEYCLOAK_CLIENT_ID": "sims-4461", + "KEYCLOAK_SECRET": "sims-keycloak", + "serviceClient": { + "KEYCLOAK_ADMIN_USERNAME": "sims-svc-4464", + "KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY": "sims_svc_client_password" + }, + "cssApi": { + "KEYCLOAK_API_TOKEN_URL": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", + "KEYCLOAK_API_CLIENT_ID": "service-account-team-1190-4229", + "KEYCLOAK_API_HOST": "https://api.loginproxy.gov.bc.ca/api/v1", + "KEYCLOAK_API_CLIENT_SECRET_KEY": "css_api_client_secret", + "KEYCLOAK_API_ENVIRONMENT": "dev" + } + }, + "test": { + "KEYCLOAK_HOST": "https://test.loginproxy.gov.bc.ca/auth", + "KEYCLOAK_REALM": "standard", + "KEYCLOAK_CLIENT_ID": "sims-4461", + "KEYCLOAK_SECRET": "sims-keycloak", + "serviceClient": { + "KEYCLOAK_ADMIN_USERNAME": "sims-svc-4464", + "KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY": "sims_svc_client_password" + }, + "cssApi": { + "KEYCLOAK_API_TOKEN_URL": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", + "KEYCLOAK_API_CLIENT_ID": "service-account-team-1190-4229", + "KEYCLOAK_API_HOST": "https://api.loginproxy.gov.bc.ca/api/v1", + "KEYCLOAK_API_CLIENT_SECRET_KEY": "css_api_client_secret", + "KEYCLOAK_API_ENVIRONMENT": "test" + } + }, + "prod": { + "KEYCLOAK_HOST": "https://loginproxy.gov.bc.ca/auth", + "KEYCLOAK_REALM": "standard", + "KEYCLOAK_CLIENT_ID": "sims-4461", + "KEYCLOAK_SECRET": "sims-keycloak", + "serviceClient": { + "KEYCLOAK_ADMIN_USERNAME": "sims-svc-4464", + "KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY": "sims_svc_client_password" + }, + "cssApi": { + "KEYCLOAK_API_TOKEN_URL": "https://loginproxy.gov.bc.ca/auth/realms/standard/protocol/openid-connect/token", + "KEYCLOAK_API_CLIENT_ID": "service-account-team-1190-4229", + "KEYCLOAK_API_HOST": "https://api.loginproxy.gov.bc.ca/api/v1", + "KEYCLOAK_API_CLIENT_SECRET_KEY": "css_api_client_secret", + "KEYCLOAK_API_ENVIRONMENT": "prod" + } + } + } + } diff --git a/Makefile b/Makefile index 28fe0a8c4e..8a542e78b7 100644 --- a/Makefile +++ b/Makefile @@ -299,6 +299,34 @@ pipeline-install: ## Runs `npm install` for all projects @echo "===============================================" @cd database/.pipeline && npm install && cd ../.. +pipeline-lint-fix: ## Runs `npm run lint-fix ` for all projects + @echo "===============================================" + @echo "Running /api/.pipeline lint-fix" + @echo "===============================================" + @cd api/.pipeline && npm run lint-fix && cd ../.. + @echo "===============================================" + @echo "Running /app/.pipeline lint-fix" + @echo "===============================================" + @cd app/.pipeline && npm run lint-fix && cd ../.. + @echo "===============================================" + @echo "Running /database/.pipeline lint-fix" + @echo "===============================================" + @cd database/.pipeline && npm run lint-fix && cd ../.. + +pipeline-format-fix: ## Runs `npm run format-fix` for all projects + @echo "===============================================" + @echo "Running /api/.pipeline format-fix" + @echo "===============================================" + @cd api/.pipeline && npm run format-fix && cd ../.. + @echo "===============================================" + @echo "Running /app/.pipeline format-fix" + @echo "===============================================" + @cd app/.pipeline && npm run format-fix && cd ../.. + @echo "===============================================" + @echo "Running /database/.pipeline format-fix" + @echo "===============================================" + @cd database/.pipeline && npm run format-fix && cd ../.. + ## ------------------------------------------------------------------------------ ## Run `docker logs -f` commands for all projects ## - You can include additional parameters by appaending an `args` param diff --git a/api/.pipeline/config.js b/api/.pipeline/config.js index 9091a706f2..8d2f8ab61b 100644 --- a/api/.pipeline/config.js +++ b/api/.pipeline/config.js @@ -1,178 +1,138 @@ 'use strict'; -let options = require('pipeline-cli').Util.parseArguments(); +const PipelineCli = require('pipeline-cli'); +const { processOptions } = require('./utils/utils'); -// The root config for common values -const config = require('../../.config/config.json'); +// Options passed in from the git action +const rawOptions = PipelineCli.Util.parseArguments(); -const appName = config.module.app; -const name = config.module.api; -const dbName = config.module.db; +const options = processOptions(rawOptions); -const version = config.version; +// Get pull-request number from git action '--pr' arg +const changeId = options.pr; -const changeId = options.pr; // pull-request number or branch name +// Get branch name from the git action '--branch' arg +const branch = options.branch || null; -// A static deployment is when the deployment is updating dev, test, or prod (rather than a temporary PR) -// See `--type=static` in the `deployStatic.yml` git workflow -const isStaticDeployment = options.type === 'static'; - -const deployChangeId = (isStaticDeployment && 'deploy') || changeId; -const branch = (isStaticDeployment && options.branch) || null; -const tag = (branch && `build-${version}-${changeId}-${branch}`) || `build-${version}-${changeId}`; - -const staticUrlsAPI = config.staticUrlsAPI; -const staticUrls = config.staticUrls; - -const processOptions = (options) => { - const result = { ...options }; - - // Check git - if (!result.git.url.includes('.git')) { - result.git.url = `${result.git.url}.git`; - } - - if (!result.git.http_url.includes('.git')) { - result.git.http_url = `${result.git.http_url}.git`; - } - - // Fixing repo - if (result.git.repository.includes('/')) { - const last = result.git.repository.split('/').pop(); - const final = last.split('.')[0]; - result.git.repository = final; - } - - return result; -}; - -options = processOptions(options); +// Get pipeline config map from git action '--config' arg +const pipelineConfigMapString = options.config; +const pipelineConfigMap = JSON.parse(pipelineConfigMapString); +/** + * The pipeline settings for the API. + * + * The top-level keys are the pipeline environments (e.g. pr, dev, test, prod). + * - This is specified by setting the '--env' arg in the git action. + * + * The second-level keys are the pipeline phases (e.g. build, deploy). + * - This is specified by setting the '--phase' arg in the git action. + */ const phases = { - build: { - namespace: 'af2668-tools', - name: `${name}`, - dbName: `${dbName}`, - phase: 'build', - changeId: changeId, - suffix: `-build-${changeId}`, - instance: `${name}-build-${changeId}`, - version: `${version}-${changeId}`, - tag: tag, - tz: config.timezone.api, - branch: branch, - cpuRequest: '50m', - cpuLimit: '1000m', - memoryRequest: '100Mi', - memoryLimit: '3Gi' + pr: { + build: { + ...pipelineConfigMap.api.pr.build, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.api}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}`, + BRANCH: options.git.ref + }, + deploy: { + ...pipelineConfigMap.api.pr.deploy, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-dev-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.api}-pr-${changeId}`, + VERSION: `pr-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-${changeId}`, + API_HOST: `${pipelineConfigMap.module.api}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, + APP_HOST: `${pipelineConfigMap.module.app}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, + SSO: pipelineConfigMap.sso.pr, + S3_KEY_PREFIX: `${pipelineConfigMap.S3_KEY_PREFIX}/${changeId}` + } }, dev: { - namespace: 'af2668-dev', - name: `${name}`, - dbName: `${dbName}`, - phase: 'dev', - changeId: deployChangeId, - suffix: `-dev-${deployChangeId}`, - instance: `${name}-dev-${deployChangeId}`, - version: `${deployChangeId}-${changeId}`, - tag: `dev-${version}-${deployChangeId}`, - host: (isStaticDeployment && staticUrlsAPI.dev) || `${name}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, - appHost: (isStaticDeployment && staticUrls.dev) || `${appName}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, - backboneInternalApiHost: 'https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca', - backbonePublicApiHost: 'https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca', - backboneIntakePath: '/api/dwc/submission/queue', - backboneArtifactIntakePath: '/api/artifact/intake', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn', - backboneIntakeEnabled: false, - bctwApiHost: 'https://moe-bctw-api-dev.apps.silver.devops.gov.bc.ca', - critterbaseApiHost: 'https://moe-critterbase-api-dev.apps.silver.devops.gov.bc.ca/api', - nodeEnv: 'development', - s3KeyPrefix: (isStaticDeployment && 'sims') || `local/${deployChangeId}/sims`, - tz: config.timezone.api, - sso: config.sso.dev, - logLevel: 'info', - apiResponseValidationEnabled: true, - databaseResponseValidationEnabled: true, - nodeOptions: '--max_old_space_size=3000', // 75% of memoryLimit (bytes) - cpuRequest: '50m', - cpuLimit: '600m', - memoryRequest: '100Mi', - memoryLimit: '4Gi', - replicas: '1', - replicasMax: (isStaticDeployment && '2') || '1' + build: { + ...pipelineConfigMap.api.dev.build, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.api}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.api.dev.deploy, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: '-dev-deploy', + INSTANCE: `${pipelineConfigMap.module.api}-dev-deploy`, + VERSION: `deploy-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-deploy`, + API_HOST: pipelineConfigMap.api.dev.deploy.API_HOST, + APP_HOST: pipelineConfigMap.api.dev.deploy.APP_HOST, + SSO: pipelineConfigMap.sso.dev + } }, test: { - namespace: 'af2668-test', - name: `${name}`, - dbName: `${dbName}`, - phase: 'test', - changeId: deployChangeId, - suffix: `-test`, - instance: `${name}-test`, - version: `${version}`, - tag: `test-${version}`, - host: staticUrlsAPI.test, - appHost: staticUrls.test, - backboneInternalApiHost: 'https://api-test-biohub-platform.apps.silver.devops.gov.bc.ca', - backbonePublicApiHost: 'https://api-test-biohub-platform.apps.silver.devops.gov.bc.ca', - backboneIntakePath: '/api/dwc/submission/queue', - backboneArtifactIntakePath: '/api/artifact/intake', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn', - backboneIntakeEnabled: false, - bctwApiHost: 'https://moe-bctw-api-test.apps.silver.devops.gov.bc.ca', - critterbaseApiHost: 'https://moe-critterbase-api-test.apps.silver.devops.gov.bc.ca/api', - nodeEnv: 'production', - s3KeyPrefix: 'sims', - tz: config.timezone.api, - sso: config.sso.test, - logLevel: 'info', - apiResponseValidationEnabled: true, - databaseResponseValidationEnabled: true, - nodeOptions: '--max_old_space_size=3000', // 75% of memoryLimit (bytes) - cpuRequest: '50m', - cpuLimit: '1000m', - memoryRequest: '100Mi', - memoryLimit: '4Gi', - replicas: '2', - replicasMax: '2' + build: { + ...pipelineConfigMap.api.test.build, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.api}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.api.test.deploy, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: `-test`, + INSTANCE: `${pipelineConfigMap.module.api}-test`, + VERSION: `deploy-${changeId}`, + TAG: `test-${pipelineConfigMap.version}`, + API_HOST: pipelineConfigMap.api.test.deploy.API_HOST, + APP_HOST: pipelineConfigMap.api.test.deploy.APP_HOST, + SSO: pipelineConfigMap.sso.test + } }, prod: { - namespace: 'af2668-prod', - name: `${name}`, - dbName: `${dbName}`, - phase: 'prod', - changeId: deployChangeId, - suffix: `-prod`, - instance: `${name}-prod`, - version: `${version}`, - tag: `prod-${version}`, - host: staticUrlsAPI.prod, - appHost: staticUrls.prodVanityUrl, - backboneInternalApiHost: 'https://api-biohub-platform.apps.silver.devops.gov.bc.ca', - backbonePublicApiHost: 'https://api-biohub-platform.apps.silver.devops.gov.bc.ca', - backboneIntakePath: '/api/dwc/submission/queue', - backboneArtifactIntakePath: '/api/artifact/intake', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn', - backboneIntakeEnabled: false, - bctwApiHost: 'https://moe-bctw-api-prod.apps.silver.devops.gov.bc.ca', - critterbaseApiHost: 'https://moe-critterbase-api-prod.apps.silver.devops.gov.bc.ca/api', - nodeEnv: 'production', - s3KeyPrefix: 'sims', - tz: config.timezone.api, - sso: config.sso.prod, - logLevel: 'warn', - apiResponseValidationEnabled: false, - databaseResponseValidationEnabled: false, - nodeOptions: '--max_old_space_size=6000', // 75% of memoryLimit (bytes) - cpuRequest: '50m', - cpuLimit: '2000m', - memoryRequest: '100Mi', - memoryLimit: '8Gi', - replicas: '2', - replicasMax: '2' + build: { + ...pipelineConfigMap.api.prod.build, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.api}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.api.prod.deploy, + NAME: pipelineConfigMap.module.api, + DB_NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: `-prod`, + INSTANCE: `${pipelineConfigMap.module.api}-prod`, + VERSION: `deploy-${changeId}`, + TAG: `prod-${pipelineConfigMap.version}`, + API_HOST: pipelineConfigMap.api.prod.deploy.API_HOST, + APP_HOST: pipelineConfigMap.api.prod.deploy.APP_VANITY_URL, + SSO: pipelineConfigMap.sso.prod + } } }; diff --git a/api/.pipeline/lib/api.build.js b/api/.pipeline/lib/api.build.js index 301c0971d5..a66ec4b8e3 100644 --- a/api/.pipeline/lib/api.build.js +++ b/api/.pipeline/lib/api.build.js @@ -11,9 +11,10 @@ const path = require('path'); const apiBuild = (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); @@ -22,20 +23,26 @@ const apiBuild = (settings) => { objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/api.bc.yaml`, { param: { - NAME: phases[phase].name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, + NAME: phases[env][phase].NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, SOURCE_REPOSITORY_URL: oc.git.http_url, - SOURCE_REPOSITORY_REF: phases[phase].branch || oc.git.ref, - CPU_REQUEST: phases[phase].cpuRequest, - CPU_LIMIT: phases[phase].cpuLimit, - MEMORY_REQUEST: phases[phase].memoryRequest, - MEMORY_LIMIT: phases[phase].memoryLimit + SOURCE_REPOSITORY_REF: phases[env][phase].BRANCH, + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT } }) ); - oc.applyRecommendedLabels(objects, phases[phase].name, phase, phases[phase].changeId, phases[phase].instance); + oc.applyRecommendedLabels( + objects, + phases[env][phase].NAME, + env, + phases[env][phase].CHANGE_ID, + phases[env][phase].INSTANCE + ); oc.applyAndBuild(objects); }; diff --git a/api/.pipeline/lib/api.deploy.js b/api/.pipeline/lib/api.deploy.js index 6cdf34c7e5..c2fb0feef1 100644 --- a/api/.pipeline/lib/api.deploy.js +++ b/api/.pipeline/lib/api.deploy.js @@ -12,77 +12,92 @@ const path = require('path'); const apiDeploy = async (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.options.env; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - const changeId = phases[phase].changeId; + const DB_SERVICE_NAME = `${phases[env][phase].DB_NAME}-postgresql${phases[env][phase].SUFFIX}`; let objects = []; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/api.dc.yaml`, { param: { - NAME: phases[phase].name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, - HOST: phases[phase].host, - APP_HOST: phases[phase].appHost, - CHANGE_ID: phases.build.changeId || changeId, + NAME: phases[env][phase].NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, + API_HOST: phases[env][phase].API_HOST, + APP_HOST: phases[env][phase].APP_HOST, + CHANGE_ID: phases[env]['build'].CHANGE_ID, + MAX_REQ_BODY_SIZE: phases[env][phase].MAX_REQ_BODY_SIZE, // Node - NODE_ENV: phases[phase].nodeEnv, - NODE_OPTIONS: phases[phase].nodeOptions, + NODE_ENV: phases[env][phase].NODE_ENV, + NODE_OPTIONS: phases[env][phase].NODE_OPTIONS, + // Clamav + ENABLE_FILE_VIRUS_SCAN: phases[env][phase].ENABLE_FILE_VIRUS_SCAN, + CLAMAV_HOST: phases[env][phase].CLAMAV_HOST, + CLAMAV_PORT: phases[env][phase].CLAMAV_PORT, // BioHub Platform (aka: Backbone) - BACKBONE_INTERNAL_API_HOST: phases[phase].backboneInternalApiHost, - BACKBONE_INTAKE_PATH: phases[phase].backboneIntakePath, - BACKBONE_ARTIFACT_INTAKE_PATH: phases[phase].backboneArtifactIntakePath, - BACKBONE_INTAKE_ENABLED: phases[phase].backboneIntakeEnabled, - BIOHUB_TAXON_PATH: phases[phase].biohubTaxonPath, - BIOHUB_TAXON_TSN_PATH: phases[phase].biohubTaxonTsnPath, + BACKBONE_INTERNAL_API_HOST: phases[env][phase].BACKBONE_INTERNAL_API_HOST, + BACKBONE_INTAKE_PATH: phases[env][phase].BACKBONE_INTAKE_PATH, + BACKBONE_ARTIFACT_INTAKE_PATH: phases[env][phase].BACKBONE_ARTIFACT_INTAKE_PATH, + BIOHUB_TAXON_PATH: phases[env][phase].BIOHUB_TAXON_PATH, + BIOHUB_TAXON_TSN_PATH: phases[env][phase].BIOHUB_TAXON_TSN_PATH, + BACKBONE_INTAKE_ENABLED: phases[env][phase].BACKBONE_INTAKE_ENABLED, // BCTW / Critterbase - BCTW_API_HOST: phases[phase].bctwApiHost, - CB_API_HOST: phases[phase].critterbaseApiHost, - // S3 - S3_KEY_PREFIX: phases[phase].s3KeyPrefix, + BCTW_API_HOST: phases[env][phase].BCTW_API_HOST, + CB_API_HOST: phases[env][phase].CB_API_HOST, // Database - TZ: phases[phase].tz, - DB_SERVICE_NAME: `${phases[phase].dbName}-postgresql${phases[phase].suffix}`, + TZ: phases[env][phase].TZ, + DB_SERVICE_NAME: DB_SERVICE_NAME, // Keycloak - KEYCLOAK_HOST: phases[phase].sso.host, - KEYCLOAK_REALM: phases[phase].sso.realm, - KEYCLOAK_CLIENT_ID: phases[phase].sso.clientId, + KEYCLOAK_HOST: phases[env][phase].SSO.KEYCLOAK_HOST, + KEYCLOAK_REALM: phases[env][phase].SSO.KEYCLOAK_REALM, + KEYCLOAK_CLIENT_ID: phases[env][phase].SSO.KEYCLOAK_CLIENT_ID, // Keycloak secret - KEYCLOAK_SECRET: phases[phase].sso.keycloakSecret, + KEYCLOAK_SECRET: phases[env][phase].SSO.KEYCLOAK_SECRET, // Keycloak Service Client - KEYCLOAK_ADMIN_USERNAME: phases[phase].sso.serviceClient.serviceClientName, - KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY: phases[phase].sso.serviceClient.keycloakSecretServiceClientPasswordKey, + KEYCLOAK_ADMIN_USERNAME: phases[env][phase].SSO.serviceClient.KEYCLOAK_ADMIN_USERNAME, + KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY: phases[env][phase].SSO.serviceClient.KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY, // Keycloak CSS API - KEYCLOAK_API_TOKEN_URL: phases[phase].sso.cssApi.cssApiTokenUrl, - KEYCLOAK_API_CLIENT_ID: phases[phase].sso.cssApi.cssApiClientId, - KEYCLOAK_API_CLIENT_SECRET_KEY: phases[phase].sso.cssApi.keycloakSecretCssApiSecretKey, - KEYCLOAK_API_HOST: phases[phase].sso.cssApi.cssApiHost, - KEYCLOAK_API_ENVIRONMENT: phases[phase].sso.cssApi.cssApiEnvironment, + KEYCLOAK_API_TOKEN_URL: phases[env][phase].SSO.cssApi.KEYCLOAK_API_TOKEN_URL, + KEYCLOAK_API_CLIENT_ID: phases[env][phase].SSO.cssApi.KEYCLOAK_API_CLIENT_ID, + KEYCLOAK_API_CLIENT_SECRET_KEY: phases[env][phase].SSO.cssApi.KEYCLOAK_API_CLIENT_SECRET_KEY, + KEYCLOAK_API_HOST: phases[env][phase].SSO.cssApi.KEYCLOAK_API_HOST, + KEYCLOAK_API_ENVIRONMENT: phases[env][phase].SSO.cssApi.KEYCLOAK_API_ENVIRONMENT, + // Object Store + OBJECT_STORE_SECRET: phases[env][phase].OBJECT_STORE_SECRET, + MAX_UPLOAD_NUM_FILES: phases[env][phase].MAX_UPLOAD_NUM_FILES, + MAX_UPLOAD_FILE_SIZE: phases[env][phase].MAX_UPLOAD_FILE_SIZE, + S3_KEY_PREFIX: phases[env][phase].S3_KEY_PREFIX, // Log Level - LOG_LEVEL: phases[phase].logLevel, - API_RESPONSE_VALIDATION_ENABLED: phases[phase].apiResponseValidationEnabled, - DATABASE_RESPONSE_VALIDATION_ENABLED: phases[phase].databaseResponseValidationEnabled, + LOG_LEVEL: phases[env][phase].LOG_LEVEL, + API_RESPONSE_VALIDATION_ENABLED: phases[env][phase].API_RESPONSE_VALIDATION_ENABLED, + DATABASE_RESPONSE_VALIDATION_ENABLED: phases[env][phase].DATABASE_RESPONSE_VALIDATION_ENABLED, // Openshift Resources - CPU_REQUEST: phases[phase].cpuRequest, - CPU_LIMIT: phases[phase].cpuLimit, - MEMORY_REQUEST: phases[phase].memoryRequest, - MEMORY_LIMIT: phases[phase].memoryLimit, - REPLICAS: phases[phase].replicas, - REPLICAS_MAX: phases[phase].replicasMax + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT, + REPLICAS: phases[env][phase].REPLICAS, + REPLICAS_MAX: phases[env][phase].REPLICAS_MAX } }) ); - oc.applyRecommendedLabels(objects, phases[phase].name, phase, `${changeId}`, phases[phase].instance); - oc.importImageStreams(objects, phases[phase].tag, phases.build.namespace, phases.build.tag); + oc.applyRecommendedLabels( + objects, + phases[env][phase].NAME, + env, + phases[env][phase].CHANGE_ID, + phases[env][phase].INSTANCE + ); + oc.importImageStreams(objects, phases[env][phase].TAG, phases[env]['build'].NAMESPACE, phases[env]['build'].TAG); - await oc.applyAndDeploy(objects, phases[phase].instance); + await oc.applyAndDeploy(objects, phases[env][phase].INSTANCE); }; module.exports = { apiDeploy }; diff --git a/api/.pipeline/lib/clean.js b/api/.pipeline/lib/clean.js index f76bfe8129..7e42b13768 100644 --- a/api/.pipeline/lib/clean.js +++ b/api/.pipeline/lib/clean.js @@ -7,72 +7,71 @@ const { OpenShiftClientX } = require('pipeline-cli'); * * @param {*} settings */ -const clean = (settings) => { +const clean = async (settings) => { const phases = settings.phases; const options = settings.options; - const target_phase = options.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases.build.namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env]['build'].NAMESPACE }, options)); - for (let phaseKey in phases) { - if (!Object.prototype.hasOwnProperty.call(phases, phaseKey)) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases, env)) { + // is not a field of phases + return; + } - if (phaseKey !== target_phase) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases[env], phase)) { + // is not a field of phases[env] + return; + } - const phaseObj = phases[phaseKey]; + // Get build configs + let buildConfigs = oc.get('bc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); - // Get build configs - let buildConfigs = oc.get('bc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); + // Clean build configs + buildConfigs.forEach((buildConfig) => { + if (buildConfig.spec.output.to.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${buildConfig.spec.output.to.name}`], { + 'ignore-not-found': 'true', + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); + } + }); + + // get deployment configs + let deploymentConfigs = oc.get('dc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},env-name=${env},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); - // Clean build configs - buildConfigs.forEach((buildConfig) => { - if (buildConfig.spec.output.to.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${buildConfig.spec.output.to.name}`], { + // Clean deployment configs + deploymentConfigs.forEach((deploymentConfig) => { + deploymentConfig.spec.triggers.forEach((trigger) => { + if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { 'ignore-not-found': 'true', wait: 'true', - namespace: phaseObj.namespace + namespace: phases[env][phase].NAMESPACE }); } }); + }); - // get deployment configs - let deploymentConfigs = oc.get('dc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},env-name=${phaseKey},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); - - // Clean deployment configs - deploymentConfigs.forEach((deploymentConfig) => { - deploymentConfig.spec.triggers.forEach((trigger) => { - if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { - 'ignore-not-found': 'true', - wait: 'true', - namespace: phaseObj.namespace - }); - } - }); - }); + oc.raw('delete', ['all'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); - oc.raw('delete', ['all'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); - - oc.raw('delete', ['all,pvc,secrets,Secrets,secret,configmap,endpoints,Endpoints'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); - } + oc.raw('delete', ['all,pvc,secrets,Secrets,secret,configmap,endpoints,Endpoints'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); }; module.exports = { clean }; diff --git a/api/.pipeline/package-lock.json b/api/.pipeline/package-lock.json index 83751a9d58..299ead87cb 100644 --- a/api/.pipeline/package-lock.json +++ b/api/.pipeline/package-lock.json @@ -4,12 +4,1205 @@ "lockfileVersion": 1, "requires": true, "dependencies": { + "@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", + "dev": true + }, + "@babel/code-frame": { + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", + "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "dev": true + }, + "@babel/highlight": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", + "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.22.20", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + } + } + }, + "@eslint/eslintrc": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", + "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.1.1", + "espree": "^7.3.0", + "globals": "^13.9.0", + "ignore": "^4.0.6", + "import-fresh": "^3.2.1", + "js-yaml": "^3.13.1", + "minimatch": "^3.0.4", + "strip-json-comments": "^3.1.1" + } + }, + "@humanwhocodes/config-array": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", + "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.0", + "debug": "^4.1.1", + "minimatch": "^3.0.4" + } + }, + "@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "dev": true + }, + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + } + }, + "arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + } + }, + "astral-regex": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", + "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", + "dev": true + }, + "available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "requires": { + "possible-typed-array-names": "^1.0.0" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + } + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, "debug": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "requires": { - "ms": "2.1.2" + "ms": "2.1.2" + } + }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + } + }, + "define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "requires": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "enquirer": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.4.1.tgz", + "integrity": "sha512-rRqJg/6gd538VHvR3PSrdRBb/1Vy2YfzHqzvbhGIQpDRKIa4FgV/54b5Q1xYSxOOwKvjXweS26E0Q+nAMwp2pQ==", + "dev": true, + "requires": { + "ansi-colors": "^4.1.1", + "strip-ansi": "^6.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.22.5", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.5.tgz", + "integrity": "sha512-oW69R+4q2wG+Hc3KZePPZxOiisRIqfKBVo/HLx94QcJeWGU/8sZhCvc829rd1kS366vlJbzBfXf9yWwf0+Ko7w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.1", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.0", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.14" + } + }, + "es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4" + } + }, + "es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true + }, + "es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "requires": { + "es-errors": "^1.3.0" + } + }, + "es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "eslint": { + "version": "7.32.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", + "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", + "dev": true, + "requires": { + "@babel/code-frame": "7.12.11", + "@eslint/eslintrc": "^0.4.3", + "@humanwhocodes/config-array": "^0.5.0", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "enquirer": "^2.3.5", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^5.1.1", + "eslint-utils": "^2.1.0", + "eslint-visitor-keys": "^2.0.0", + "espree": "^7.3.1", + "esquery": "^1.4.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.1.2", + "globals": "^13.6.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.0.4", + "natural-compare": "^1.4.0", + "optionator": "^0.9.1", + "progress": "^2.0.0", + "regexpp": "^3.1.0", + "semver": "^7.2.1", + "strip-ansi": "^6.0.0", + "strip-json-comments": "^3.1.0", + "table": "^6.0.9", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + } + }, + "eslint-config-prettier": { + "version": "6.15.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.15.0.tgz", + "integrity": "sha512-a1+kOYLR8wMGustcgAjdydMsQ2A/2ipRPwRKUmfYaSxc9ZPcrku080Ctl6zrZzZNs/U82MjSv+qKREkoq3bJaw==", + "dev": true, + "requires": { + "get-stdin": "^6.0.0" + } + }, + "eslint-plugin-prettier": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", + "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", + "dev": true, + "requires": { + "prettier-linter-helpers": "^1.0.0" + } + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", + "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^1.1.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + }, + "espree": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", + "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", + "dev": true, + "requires": { + "acorn": "^7.4.0", + "acorn-jsx": "^5.3.1", + "eslint-visitor-keys": "^1.3.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "requires": { + "estraverse": "^5.1.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, + "flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "requires": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + } + }, + "flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "requires": { + "is-callable": "^1.1.3" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true + }, + "function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + } + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", + "dev": true + }, + "functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true + }, + "get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + } + }, + "get-stdin": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", + "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", + "dev": true + }, + "get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + } + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3" + } + }, + "gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.3" + } + }, + "graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true + }, + "has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0" + } + }, + "has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true + }, + "has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true + }, + "has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "requires": { + "has-symbols": "^1.0.3" + } + }, + "hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "requires": { + "function-bind": "^1.1.2" + } + }, + "hosted-git-info": { + "version": "2.8.9", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", + "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", + "dev": true + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + } + }, + "is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "requires": { + "has-bigints": "^1.0.1" + } + }, + "is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true + }, + "is-core-module": { + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", + "dev": true, + "requires": { + "hasown": "^2.0.0" + } + }, + "is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "requires": { + "is-typed-array": "^1.1.13" + } + }, + "is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true + }, + "is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "requires": { + "call-bind": "^1.0.7" + } + }, + "is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "requires": { + "has-symbols": "^1.0.2" + } + }, + "is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "requires": { + "which-typed-array": "^1.1.14" + } + }, + "is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + } + }, + "isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "requires": { + "json-buffer": "3.0.1" + } + }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" } }, "lodash.isempty": { @@ -32,11 +1225,269 @@ "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "lodash.truncate": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", + "integrity": "sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==", + "dev": true + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "memorystream": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", + "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", + "dev": true + }, + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, "ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + } + } + }, + "npm-run-all": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", + "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "chalk": "^2.4.1", + "cross-spawn": "^6.0.5", + "memorystream": "^0.3.1", + "minimatch": "^3.0.4", + "pidtree": "^0.3.0", + "read-pkg": "^3.0.0", + "shell-quote": "^1.6.1", + "string.prototype.padend": "^3.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", + "dev": true + }, + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "object-inspect": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", + "dev": true + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true + }, + "object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "optionator": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", + "dev": true, + "requires": { + "@aashutoshrathi/word-wrap": "^1.2.3", + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pidtree": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", + "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", + "dev": true + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "dev": true + }, "pipeline-cli": { "version": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git#61b44543041da3697d189beb2472539fe2e099c1", "from": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git", @@ -48,11 +1499,615 @@ "lodash.isstring": "^4.0.1" } }, + "possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true + }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, "prettier": { "version": "2.3.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.3.2.tgz", "integrity": "sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ==", "dev": true + }, + "prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "requires": { + "fast-diff": "^1.1.2" + } + }, + "prettier-plugin-organize-imports": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/prettier-plugin-organize-imports/-/prettier-plugin-organize-imports-2.3.4.tgz", + "integrity": "sha512-R8o23sf5iVL/U71h9SFUdhdOEPsi3nm42FD/oDYIZ2PQa4TNWWuWecxln6jlIQzpZTDMUeO1NicJP6lLn2TtRw==", + "dev": true + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true + }, + "punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "regexp.prototype.flags": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" + } + }, + "regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true + }, + "require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true + }, + "resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "requires": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + } + }, + "safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + } + }, + "semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + } + }, + "set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + } + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "shell-quote": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", + "dev": true + }, + "side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + } + }, + "slice-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", + "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "astral-regex": "^2.0.0", + "is-fullwidth-code-point": "^3.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + } + } + }, + "spdx-correct": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", + "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.17.tgz", + "integrity": "sha512-sh8PWc/ftMqAAdFiBu6Fy6JUOYjqDJBJvIhpfDMyHrr0Rbp5liZqd4TjtQ/RgfLjKFZb+LMx5hpml5qOWy0qvg==", + "dev": true + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "string.prototype.padend": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", + "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "dependencies": { + "es-abstract": { + "version": "1.23.2", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.2.tgz", + "integrity": "sha512-60s3Xv2T2p1ICykc7c+DNDPLDMm9t4QxCOUU0K9JxiLjM3C1zB9YVdN7tjxrFd4+AkZ8CdX1ovUga4P2+1e+/w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + } + } + } + }, + "string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + } + }, + "string.prototype.trimstart": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true + }, + "strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true + }, + "table": { + "version": "6.8.1", + "resolved": "https://registry.npmjs.org/table/-/table-6.8.1.tgz", + "integrity": "sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==", + "dev": true, + "requires": { + "ajv": "^8.0.1", + "lodash.truncate": "^4.4.2", + "slice-ansi": "^4.0.0", + "string-width": "^4.2.3", + "strip-ansi": "^6.0.1" + }, + "dependencies": { + "ajv": { + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.2.2" + } + }, + "json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true + } + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + }, + "typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-length": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.5.tgz", + "integrity": "sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + } + }, + "unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + } + }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "v8-compile-cache": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.4.0.tgz", + "integrity": "sha512-ocyWc3bAHBB/guyqJQVI5o4BZkPhznPYUG2ea80Gond/BgNWpap8TOmLSeeQG7bnh2KMISxskdADG59j7zruhw==", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "requires": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + } + }, + "which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true } } } diff --git a/api/.pipeline/package.json b/api/.pipeline/package.json index 1f13d26ce9..edff70d363 100644 --- a/api/.pipeline/package.json +++ b/api/.pipeline/package.json @@ -18,7 +18,8 @@ "lint": "eslint . --ignore-pattern 'node_modules' --ext .js,.ts", "lint-fix": "eslint . --fix --ignore-pattern 'node_modules' --ext .js,.ts", "format": "prettier --check \"./**/*.{js,jsx,ts,tsx,css,scss}\"", - "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"" + "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"", + "fix": "npm-run-all -l -s lint-fix format-fix" }, "dependencies": { "debug": "^4.2.0", @@ -29,6 +30,11 @@ "pipeline-cli": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git" }, "devDependencies": { - "prettier": "~2.3.2" + "eslint": "~7.32.0", + "eslint-config-prettier": "~6.15.0", + "eslint-plugin-prettier": "~3.3.1", + "npm-run-all": "~4.1.5", + "prettier": "^2.3.2", + "prettier-plugin-organize-imports": "~2.3.4" } } diff --git a/api/.pipeline/scripts/api.build.js b/api/.pipeline/scripts/api.build.js index 50ba782a41..aede09d36d 100644 --- a/api/.pipeline/scripts/api.build.js +++ b/api/.pipeline/scripts/api.build.js @@ -3,7 +3,10 @@ const { apiBuild } = require('../lib/api.build.js'); const config = require('../config.js'); -const settings = { ...config, phase: 'build' }; +if (['pr', 'dev'].includes(config.options.env)) { + console.debug(JSON.stringify(config.options)); + console.debug(JSON.stringify(config.phases)); +} // Builds the api image -apiBuild(settings); +apiBuild(config); diff --git a/api/.pipeline/scripts/api.deploy.js b/api/.pipeline/scripts/api.deploy.js index 47add18a0b..9c4b98f2ff 100644 --- a/api/.pipeline/scripts/api.deploy.js +++ b/api/.pipeline/scripts/api.deploy.js @@ -4,19 +4,17 @@ const process = require('process'); const { apiDeploy } = require('../lib/api.deploy.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - process.on('unhandledRejection', (reason, promise) => { - console.log('api deploy - unhandled rejection:', promise, 'reason:', reason); + console.debug('api deploy - unhandled rejection:', promise, 'reason:', reason); process.exit(1); }); process.on('exit', (code) => { - console.log('api deploy - exit:', 'code:', code); + console.debug('api deploy - exit:', 'code:', code); }); // Deploys the api image -apiDeploy(settings).catch((error) => { - console.log('api deploy - catch - error: ', error); +apiDeploy(config).catch((error) => { + console.debug('api deploy - catch - error: ', error); throw error; }); diff --git a/api/.pipeline/scripts/clean.js b/api/.pipeline/scripts/clean.js index 5e7fae7b4f..6d44c86eeb 100644 --- a/api/.pipeline/scripts/clean.js +++ b/api/.pipeline/scripts/clean.js @@ -3,7 +3,8 @@ const { clean } = require('../lib/clean.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - // Cleans all build and deployment artifacts (pods, etc) -clean(settings); +clean(config).catch((error) => { + console.debug('api clean - catch - error: ', error); + throw error; +}); diff --git a/api/.pipeline/templates/api.dc.yaml b/api/.pipeline/templates/api.dc.yaml index cc61045ce5..713fe4cc56 100644 --- a/api/.pipeline/templates/api.dc.yaml +++ b/api/.pipeline/templates/api.dc.yaml @@ -12,7 +12,7 @@ parameters: - name: VERSION description: Version of the application value: '1.0.0' - - name: HOST + - name: API_HOST description: Host name of the application required: true - name: APP_HOST @@ -27,11 +27,17 @@ parameters: required: true value: 'development' - name: NODE_OPTIONS + description: Optional node options. See https://nodejs.org/api/cli.html#node_optionsoptions + value: '' - name: API_PORT_DEFAULT value: '6100' - name: API_PORT_DEFAULT_NAME description: Api default port name value: '6100-tcp' + - name: MAX_REQ_BODY_SIZE + description: The maximum request body size in bytes + required: false + value: '52428800' # Clamav - name: ENABLE_FILE_VIRUS_SCAN value: 'true' @@ -85,14 +91,14 @@ parameters: required: true # Keycloak secret - name: KEYCLOAK_SECRET - description: The name of the keycloak secret + description: The name of the Openshift secret which contains the keycloak credentials. required: true # Keycloak Service Client - name: KEYCLOAK_ADMIN_USERNAME description: keycloak host admin username required: true - name: KEYCLOAK_SECRET_ADMIN_PASSWORD_KEY - description: The key of the admin password in the keycloak secret + description: The key of the admin password field in the Openshift keycloak secret required: true # Keycloak CSS API - name: KEYCLOAK_API_TOKEN_URL @@ -111,9 +117,17 @@ parameters: description: The css api environment to query (dev, test, prod) required: true # Object Store (S3) - - name: OBJECT_STORE_SECRETS - description: Secrets used to read and write to the S3 storage + - name: OBJECT_STORE_SECRET + description: The name of the Openshift secret which contains the object store credentials. value: 'biohubbc-object-store' + - name: MAX_UPLOAD_NUM_FILES + description: The maximum number of files that can be uploaded at once + required: false + value: '10' + - name: MAX_UPLOAD_FILE_SIZE + description: The maximum file size in bytes + required: false + value: '52428800' - name: S3_KEY_PREFIX description: S3 key optional prefix required: false @@ -211,7 +225,7 @@ objects: - name: api env: - name: API_HOST - value: ${HOST} + value: ${API_HOST} - name: API_PORT value: ${API_PORT_DEFAULT} - name: APP_HOST @@ -220,6 +234,9 @@ objects: value: ${VERSION} - name: CHANGE_VERSION value: ${CHANGE_ID} + - name: MAX_REQ_BODY_SIZE + value: ${MAX_REQ_BODY_SIZE} + # Node - name: NODE_ENV value: ${NODE_ENV} - name: NODE_OPTIONS @@ -305,22 +322,28 @@ objects: valueFrom: secretKeyRef: key: object_store_url - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} - name: OBJECT_STORE_ACCESS_KEY_ID valueFrom: secretKeyRef: key: object_store_access_key_id - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} - name: OBJECT_STORE_SECRET_KEY_ID valueFrom: secretKeyRef: key: object_store_secret_key_id - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} - name: OBJECT_STORE_BUCKET_NAME valueFrom: secretKeyRef: key: object_store_bucket_name - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} + - name: MAX_UPLOAD_NUM_FILES + value: ${MAX_UPLOAD_NUM_FILES} + - name: MAX_UPLOAD_FILE_SIZE + value: ${MAX_UPLOAD_FILE_SIZE} + - name: S3_KEY_PREFIX + value: ${S3_KEY_PREFIX} # Logging and Validation - name: LOG_LEVEL value: ${LOG_LEVEL} @@ -450,7 +473,7 @@ objects: labels: {} name: ${NAME}${SUFFIX} spec: - host: ${HOST} + host: ${API_HOST} tls: insecureEdgeTerminationPolicy: Redirect termination: edge diff --git a/api/.pipeline/templates/prereqs/biohubbc-db.yaml b/api/.pipeline/templates/prereqs/biohubbc-db.yaml index 1a8d9ef09f..cfa1f364e7 100644 --- a/api/.pipeline/templates/prereqs/biohubbc-db.yaml +++ b/api/.pipeline/templates/prereqs/biohubbc-db.yaml @@ -1,7 +1,7 @@ kind: Secret apiVersion: v1 metadata: - name: biohubbc-creds + name: sims-database data: database-admin: database-admin-password: diff --git a/api/.pipeline/utils/utils.js b/api/.pipeline/utils/utils.js new file mode 100644 index 0000000000..e199e6ebeb --- /dev/null +++ b/api/.pipeline/utils/utils.js @@ -0,0 +1,55 @@ +'use strict'; + +/** + * Parses the npm cli command options and the git action context. + * + * @param {*} options + * @return {{ + * git: { + * dir: '', + * branch: { + * name: '', + * remote: '', + * merge: '' + * }, + * url: 'https://github.com/bcgov/biohubbc.git', + * uri: 'https://github.com/bcgov/biohubbc', + * http_url: 'https://github.com/bcgov/biohubbc.git', + * owner: 'bcgov', + * repository: 'biohubbc', + * pull_request: '', + * ref: '', + * branch_ref: '' + * }, + * env: 'pr' | 'dev' | 'test' | 'prod', + * phase: 'build' | 'deploy', + * config: string, // sims pipeline config map (stringified JSON) + * pr?: number, // For PR based deployments + * branch?: string, // For static (dev, test, prod) deployments + * }} + */ +const processOptions = (options) => { + const result = { ...options }; + + // Check git + if (!result.git.url.includes('.git')) { + result.git.url = `${result.git.url}.git`; + } + + if (!result.git.http_url.includes('.git')) { + result.git.http_url = `${result.git.http_url}.git`; + } + + // Fixing repo + if (result.git.repository.includes('/')) { + const last = result.git.repository.split('/').pop(); + const final = last.split('.')[0]; + result.git.repository = final; + } + + return result; +}; + +module.exports = { + processOptions +}; diff --git a/app/.pipeline/config.js b/app/.pipeline/config.js index 4931167e4d..505456596c 100644 --- a/app/.pipeline/config.js +++ b/app/.pipeline/config.js @@ -1,152 +1,128 @@ 'use strict'; -let options = require('pipeline-cli').Util.parseArguments(); +const PipelineCli = require('pipeline-cli'); +const { processOptions } = require('./utils/utils'); -// The root config for common values -const config = require('../../.config/config.json'); +// Options passed in from the git action +const rawOptions = PipelineCli.Util.parseArguments(); -const name = config.module.app; -const apiName = config.module.api; +const options = processOptions(rawOptions); -const version = config.version; +// Get pull-request number from git action '--pr' arg +const changeId = options.pr; -const changeId = options.pr; // pull-request number or branch name +// Get branch name from the git action '--branch' arg +const branch = options.branch || null; -// A static deployment is when the deployment is updating dev, test, or prod (rather than a temporary PR) -// See `--type=static` in the `deployStatic.yml` git workflow -const isStaticDeployment = options.type === 'static'; - -const deployChangeId = (isStaticDeployment && 'deploy') || changeId; -const branch = (isStaticDeployment && options.branch) || null; -const tag = (branch && `build-${version}-${changeId}-${branch}`) || `build-${version}-${changeId}`; - -const staticUrls = config.staticUrls || {}; -const staticUrlsAPI = config.staticUrlsAPI || {}; - -const maxUploadNumFiles = 10; -const maxUploadFileSize = 52428800; // (bytes) - -const processOptions = (options) => { - const result = { ...options }; - - // Check git - if (!result.git.url.includes('.git')) { - result.git.url = `${result.git.url}.git`; - } - - if (!result.git.http_url.includes('.git')) { - result.git.http_url = `${result.git.http_url}.git`; - } - - // Fixing repo - if (result.git.repository.includes('/')) { - const last = result.git.repository.split('/').pop(); - const final = last.split('.')[0]; - result.git.repository = final; - } - - return result; -}; - -options = processOptions(options); +// Get pipeline config map from git action '--config' arg +const pipelineConfigMapString = options.config; +const pipelineConfigMap = JSON.parse(pipelineConfigMapString); +/** + * The pipeline settings for the APP. + * + * The top-level keys are the pipeline environments (e.g. pr, dev, test, prod). + * - This is specified by setting the '--env' arg in the git action. + * + * The second-level keys are the pipeline phases (e.g. build, deploy). + * - This is specified by setting the '--phase' arg in the git action. + */ const phases = { - build: { - namespace: 'af2668-tools', - name: `${name}`, - phase: 'build', - changeId: changeId, - suffix: `-build-${changeId}`, - instance: `${name}-build-${changeId}`, - version: `${version}-${changeId}`, - tag: tag, - branch: branch, - cpuRequest: '50m', - cpuLimit: '2000m', - memoryRequest: '100Mi', - memoryLimit: '6Gi' + pr: { + build: { + ...pipelineConfigMap.app.pr.build, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.app}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}`, + BRANCH: options.git.ref + }, + deploy: { + ...pipelineConfigMap.app.pr.deploy, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: changeId, + SUFFIX: `-dev-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.app}-pr-${changeId}`, + VERSION: `pr-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-${changeId}`, + APP_HOST: `${pipelineConfigMap.module.app}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, + API_HOST: `${pipelineConfigMap.module.api}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, + SSO: pipelineConfigMap.sso.pr + } }, dev: { - namespace: 'af2668-dev', - name: `${name}`, - phase: 'dev', - changeId: deployChangeId, - suffix: `-dev-${deployChangeId}`, - instance: `${name}-dev-${deployChangeId}`, - version: `${deployChangeId}-${changeId}`, - tag: `dev-${version}-${deployChangeId}`, - host: (isStaticDeployment && staticUrls.dev) || `${name}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, - apiHost: - (isStaticDeployment && staticUrlsAPI.dev) || `${apiName}-${changeId}-af2668-dev.apps.silver.devops.gov.bc.ca`, - siteminderLogoutURL: config.siteminderLogoutURL.dev, - maxUploadNumFiles, - maxUploadFileSize, - nodeEnv: 'development', - sso: config.sso.dev, - cpuRequest: '50m', - cpuLimit: '300m', - memoryRequest: '100Mi', - memoryLimit: '500Mi', - replicas: (isStaticDeployment && '1') || '1', - replicasMax: (isStaticDeployment && '2') || '1', - biohubFeatureFlag: 'true', - backbonePublicApiHost: 'https://api-dev-biohub-platform.apps.silver.devops.gov.bc.ca', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn' + build: { + ...pipelineConfigMap.app.dev.build, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.app}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.app.dev.deploy, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: 'deploy', + SUFFIX: '-dev-deploy', + INSTANCE: `${pipelineConfigMap.module.app}-dev-deploy`, + VERSION: `deploy-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-deploy`, + APP_HOST: pipelineConfigMap.app.dev.deploy.APP_HOST, + API_HOST: pipelineConfigMap.app.dev.deploy.API_HOST, + SSO: pipelineConfigMap.sso.dev + } }, test: { - namespace: 'af2668-test', - name: `${name}`, - phase: 'test', - changeId: deployChangeId, - suffix: `-test`, - instance: `${name}-test`, - version: `${version}`, - tag: `test-${version}`, - host: staticUrls.test, - apiHost: staticUrlsAPI.test, - siteminderLogoutURL: config.siteminderLogoutURL.test, - maxUploadNumFiles, - maxUploadFileSize, - nodeEnv: 'production', - sso: config.sso.test, - cpuRequest: '50m', - cpuLimit: '500m', - memoryRequest: '100Mi', - memoryLimit: '500Mi', - replicas: '2', - replicasMax: '2', - biohubFeatureFlag: 'false', - backbonePublicApiHost: 'https://api-test-biohub-platform.apps.silver.devops.gov.bc.ca', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn' + build: { + ...pipelineConfigMap.app.test.build, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.app}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.app.test.deploy, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: 'deploy', + SUFFIX: `-test`, + INSTANCE: `${pipelineConfigMap.module.app}-test`, + VERSION: `deploy-${changeId}`, + TAG: `test-${pipelineConfigMap.version}`, + APP_HOST: pipelineConfigMap.app.test.deploy.APP_HOST, + API_HOST: pipelineConfigMap.app.test.deploy.API_HOST, + SSO: pipelineConfigMap.sso.test + } }, prod: { - namespace: 'af2668-prod', - name: `${name}`, - phase: 'prod', - changeId: deployChangeId, - suffix: `-prod`, - instance: `${name}-prod`, - version: `${version}`, - tag: `prod-${version}`, - host: staticUrls.prod, - apiHost: staticUrlsAPI.prod, - siteminderLogoutURL: config.siteminderLogoutURL.prod, - maxUploadNumFiles, - maxUploadFileSize, - nodeEnv: 'production', - sso: config.sso.prod, - cpuRequest: '50m', - cpuLimit: '1000m', - memoryRequest: '100Mi', - memoryLimit: '1Gi', - replicas: '2', - replicasMax: '2', - biohubFeatureFlag: 'false', - backbonePublicApiHost: 'https://api-biohub-platform.apps.silver.devops.gov.bc.ca', - biohubTaxonPath: '/api/taxonomy/taxon', - biohubTaxonTsnPath: '/api/taxonomy/taxon/tsn' + build: { + ...pipelineConfigMap.app.prod.build, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.app}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.app.prod.deploy, + NAME: pipelineConfigMap.module.app, + CHANGE_ID: 'deploy', + SUFFIX: `-prod`, + INSTANCE: `${pipelineConfigMap.module.app}-prod`, + VERSION: `deploy-${changeId}`, + TAG: `prod-${pipelineConfigMap.version}`, + APP_HOST: pipelineConfigMap.app.prod.deploy.APP_HOST, + API_HOST: pipelineConfigMap.app.prod.deploy.API_HOST, + SSO: pipelineConfigMap.sso.prod + } } }; diff --git a/app/.pipeline/lib/app.build.js b/app/.pipeline/lib/app.build.js index 9f3aab0634..2cb0a8c2fa 100644 --- a/app/.pipeline/lib/app.build.js +++ b/app/.pipeline/lib/app.build.js @@ -11,31 +11,38 @@ const path = require('path'); const appBuild = (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - let objects = []; + const objects = []; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/app.bc.yaml`, { param: { - NAME: phases[phase].name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, + NAME: phases[env][phase].NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, SOURCE_REPOSITORY_URL: oc.git.http_url, - SOURCE_REPOSITORY_REF: phases[phase].branch || oc.git.ref, - CPU_REQUEST: phases[phase].cpuRequest, - CPU_LIMIT: phases[phase].cpuLimit, - MEMORY_REQUEST: phases[phase].memoryRequest, - MEMORY_LIMIT: phases[phase].memoryLimit + SOURCE_REPOSITORY_REF: phases[env][phase].BRANCH, + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT } }) ); - oc.applyRecommendedLabels(objects, phases[phase].name, phase, phases[phase].changeId, phases[phase].instance); + oc.applyRecommendedLabels( + objects, + phases[env][phase].NAME, + env, + phases[env][phase].CHANGE_ID, + phases[env][phase].INSTANCE + ); oc.applyAndBuild(objects); }; diff --git a/app/.pipeline/lib/app.deploy.js b/app/.pipeline/lib/app.deploy.js index 3a1d7f873a..dcc6724205 100644 --- a/app/.pipeline/lib/app.deploy.js +++ b/app/.pipeline/lib/app.deploy.js @@ -6,55 +6,62 @@ const path = require('path'); const appDeploy = async (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.options.env; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - const changeId = phases[phase].changeId; - const objects = []; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/app.dc.yaml`, { param: { - NAME: phases[phase].name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, - HOST: phases[phase].host, - CHANGE_ID: phases.build.changeId || changeId, - REACT_APP_API_HOST: phases[phase].apiHost, - REACT_APP_SITEMINDER_LOGOUT_URL: phases[phase].siteminderLogoutURL, - // File Upload Settings - REACT_APP_MAX_UPLOAD_NUM_FILES: phases[phase].maxUploadNumFiles, - REACT_APP_MAX_UPLOAD_FILE_SIZE: phases[phase].maxUploadFileSize, + NAME: phases[env][phase].NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, + APP_HOST: phases[env][phase].APP_HOST, + CHANGE_ID: phases[env]['build'].CHANGE_ID, + REACT_APP_API_HOST: phases[env][phase].API_HOST, + REACT_APP_SITEMINDER_LOGOUT_URL: phases[env][phase].SITEMINDER_LOGOUT_URL, + // Object Store + OBJECT_STORE_SECRET: phases[env][phase].OBJECT_STORE_SECRET, + REACT_APP_MAX_UPLOAD_NUM_FILES: phases[env][phase].MAX_UPLOAD_NUM_FILES, + REACT_APP_MAX_UPLOAD_FILE_SIZE: phases[env][phase].MAX_UPLOAD_FILE_SIZE, // Node - NODE_ENV: phases[phase].nodeEnv, - REACT_APP_NODE_ENV: phases[phase].nodeEnv, + NODE_ENV: phases[env][phase].NODE_ENV, + REACT_APP_NODE_ENV: phases[env][phase].NODE_ENV, // Keycloak - REACT_APP_KEYCLOAK_HOST: phases[phase].sso.host, - REACT_APP_KEYCLOAK_REALM: phases[phase].sso.realm, - REACT_APP_KEYCLOAK_CLIENT_ID: phases[phase].sso.clientId, + REACT_APP_KEYCLOAK_HOST: phases[env][phase].SSO.KEYCLOAK_HOST, + REACT_APP_KEYCLOAK_REALM: phases[env][phase].SSO.KEYCLOAK_REALM, + REACT_APP_KEYCLOAK_CLIENT_ID: phases[env][phase].SSO.KEYCLOAK_CLIENT_ID, + // BioHub Plastform (aka: Backbone) + REACT_APP_BACKBONE_PUBLIC_API_HOST: phases[env][phase].BACKBONE_PUBLIC_API_HOST, + REACT_APP_BIOHUB_TAXON_PATH: phases[env][phase].BIOHUB_TAXON_PATH, + REACT_APP_BIOHUB_TAXON_TSN_PATH: phases[env][phase].BIOHUB_TAXON_TSN_PATH, + REACT_APP_BIOHUB_FEATURE_FLAG: phases[env][phase].REACT_APP_BIOHUB_FEATURE_FLAG, // Openshift Resources - CPU_REQUEST: phases[phase].cpuRequest, - CPU_LIMIT: phases[phase].cpuLimit, - MEMORY_REQUEST: phases[phase].memoryRequest, - MEMORY_LIMIT: phases[phase].memoryLimit, - REPLICAS: phases[phase].replicas, - REPLICAS_MAX: phases[phase].replicasMax, - REACT_APP_BIOHUB_FEATURE_FLAG: phases[phase].biohubFeatureFlag, - REACT_APP_BACKBONE_PUBLIC_API_HOST: phases[phase].backbonePublicApiHost, - REACT_APP_BIOHUB_TAXON_PATH: phases[phase].biohubTaxonPath, - REACT_APP_BIOHUB_TAXON_TSN_PATH: phases[phase].biohubTaxonTsnPath + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT, + REPLICAS: phases[env][phase].REPLICAS, + REPLICAS_MAX: phases[env][phase].REPLICAS_MAX } }) ); - oc.applyRecommendedLabels(objects, phases[phase].name, phase, `${changeId}`, phases[phase].instance); - oc.importImageStreams(objects, phases[phase].tag, phases.build.namespace, phases.build.tag); + oc.applyRecommendedLabels( + objects, + phases[env][phase].NAME, + env, + phases[env][phase].CHANGE_ID, + phases[env][phase].INSTANCE + ); + oc.importImageStreams(objects, phases[env][phase].TAG, phases[env]['build'].NAMESPACE, phases[env]['build'].TAG); - await oc.applyAndDeploy(objects, phases[phase].instance); + await oc.applyAndDeploy(objects, phases[env][phase].INSTANCE); }; module.exports = { appDeploy }; diff --git a/app/.pipeline/lib/clean.js b/app/.pipeline/lib/clean.js index 9cd225d191..7e42b13768 100644 --- a/app/.pipeline/lib/clean.js +++ b/app/.pipeline/lib/clean.js @@ -7,72 +7,71 @@ const { OpenShiftClientX } = require('pipeline-cli'); * * @param {*} settings */ -const clean = (settings) => { +const clean = async (settings) => { const phases = settings.phases; const options = settings.options; - const target_phase = options.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases.build.namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env]['build'].NAMESPACE }, options)); - for (let phaseKey in phases) { - if (!Object.prototype.hasOwnProperty.call(phases, phaseKey)) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases, env)) { + // is not a field of phases + return; + } - if (phaseKey !== target_phase) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases[env], phase)) { + // is not a field of phases[env] + return; + } - const phaseObj = phases[phaseKey]; + // Get build configs + let buildConfigs = oc.get('bc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); - // Get build configs - let buildConfigs = oc.get('bc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); + // Clean build configs + buildConfigs.forEach((buildConfig) => { + if (buildConfig.spec.output.to.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${buildConfig.spec.output.to.name}`], { + 'ignore-not-found': 'true', + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); + } + }); + + // get deployment configs + let deploymentConfigs = oc.get('dc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},env-name=${env},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); - // Clean build configs - buildConfigs.forEach((buildConfig) => { - if (buildConfig.spec.output.to.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${buildConfig.spec.output.to.name}`], { + // Clean deployment configs + deploymentConfigs.forEach((deploymentConfig) => { + deploymentConfig.spec.triggers.forEach((trigger) => { + if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { 'ignore-not-found': 'true', wait: 'true', - namespace: phaseObj.namespace + namespace: phases[env][phase].NAMESPACE }); } }); + }); - // get deployment configs - let deploymentConfigs = oc.get('dc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},env-name=${phaseKey},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); - - // Clean deployment configs - deploymentConfigs.forEach((deploymentConfig) => { - deploymentConfig.spec.triggers.forEach((trigger) => { - if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { - 'ignore-not-found': 'true', - wait: 'true', - namespace: phaseObj.namespace - }); - } - }); - }); + oc.raw('delete', ['all'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); - oc.raw('delete', ['all'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); - - oc.raw('delete', ['pvc,Secret,secrets,secret,configmap,endpoints,Endpoints'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); - } + oc.raw('delete', ['all,pvc,secrets,Secrets,secret,configmap,endpoints,Endpoints'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); }; module.exports = { clean }; diff --git a/app/.pipeline/package-lock.json b/app/.pipeline/package-lock.json index 83751a9d58..299ead87cb 100644 --- a/app/.pipeline/package-lock.json +++ b/app/.pipeline/package-lock.json @@ -4,12 +4,1205 @@ "lockfileVersion": 1, "requires": true, "dependencies": { + "@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", + "dev": true + }, + "@babel/code-frame": { + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", + "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "dev": true + }, + "@babel/highlight": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", + "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.22.20", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + } + } + }, + "@eslint/eslintrc": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", + "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.1.1", + "espree": "^7.3.0", + "globals": "^13.9.0", + "ignore": "^4.0.6", + "import-fresh": "^3.2.1", + "js-yaml": "^3.13.1", + "minimatch": "^3.0.4", + "strip-json-comments": "^3.1.1" + } + }, + "@humanwhocodes/config-array": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", + "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.0", + "debug": "^4.1.1", + "minimatch": "^3.0.4" + } + }, + "@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "dev": true + }, + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + } + }, + "arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + } + }, + "astral-regex": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", + "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", + "dev": true + }, + "available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "requires": { + "possible-typed-array-names": "^1.0.0" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + } + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, "debug": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "requires": { - "ms": "2.1.2" + "ms": "2.1.2" + } + }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + } + }, + "define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "requires": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "enquirer": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.4.1.tgz", + "integrity": "sha512-rRqJg/6gd538VHvR3PSrdRBb/1Vy2YfzHqzvbhGIQpDRKIa4FgV/54b5Q1xYSxOOwKvjXweS26E0Q+nAMwp2pQ==", + "dev": true, + "requires": { + "ansi-colors": "^4.1.1", + "strip-ansi": "^6.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.22.5", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.5.tgz", + "integrity": "sha512-oW69R+4q2wG+Hc3KZePPZxOiisRIqfKBVo/HLx94QcJeWGU/8sZhCvc829rd1kS366vlJbzBfXf9yWwf0+Ko7w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.1", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.0", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.14" + } + }, + "es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4" + } + }, + "es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true + }, + "es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "requires": { + "es-errors": "^1.3.0" + } + }, + "es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "eslint": { + "version": "7.32.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", + "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", + "dev": true, + "requires": { + "@babel/code-frame": "7.12.11", + "@eslint/eslintrc": "^0.4.3", + "@humanwhocodes/config-array": "^0.5.0", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "enquirer": "^2.3.5", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^5.1.1", + "eslint-utils": "^2.1.0", + "eslint-visitor-keys": "^2.0.0", + "espree": "^7.3.1", + "esquery": "^1.4.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.1.2", + "globals": "^13.6.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.0.4", + "natural-compare": "^1.4.0", + "optionator": "^0.9.1", + "progress": "^2.0.0", + "regexpp": "^3.1.0", + "semver": "^7.2.1", + "strip-ansi": "^6.0.0", + "strip-json-comments": "^3.1.0", + "table": "^6.0.9", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + } + }, + "eslint-config-prettier": { + "version": "6.15.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.15.0.tgz", + "integrity": "sha512-a1+kOYLR8wMGustcgAjdydMsQ2A/2ipRPwRKUmfYaSxc9ZPcrku080Ctl6zrZzZNs/U82MjSv+qKREkoq3bJaw==", + "dev": true, + "requires": { + "get-stdin": "^6.0.0" + } + }, + "eslint-plugin-prettier": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", + "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", + "dev": true, + "requires": { + "prettier-linter-helpers": "^1.0.0" + } + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", + "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^1.1.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + }, + "espree": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", + "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", + "dev": true, + "requires": { + "acorn": "^7.4.0", + "acorn-jsx": "^5.3.1", + "eslint-visitor-keys": "^1.3.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "requires": { + "estraverse": "^5.1.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, + "flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "requires": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + } + }, + "flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "requires": { + "is-callable": "^1.1.3" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true + }, + "function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + } + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", + "dev": true + }, + "functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true + }, + "get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + } + }, + "get-stdin": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", + "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", + "dev": true + }, + "get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + } + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3" + } + }, + "gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.3" + } + }, + "graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true + }, + "has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0" + } + }, + "has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true + }, + "has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true + }, + "has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "requires": { + "has-symbols": "^1.0.3" + } + }, + "hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "requires": { + "function-bind": "^1.1.2" + } + }, + "hosted-git-info": { + "version": "2.8.9", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", + "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", + "dev": true + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + } + }, + "is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "requires": { + "has-bigints": "^1.0.1" + } + }, + "is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true + }, + "is-core-module": { + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", + "dev": true, + "requires": { + "hasown": "^2.0.0" + } + }, + "is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "requires": { + "is-typed-array": "^1.1.13" + } + }, + "is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true + }, + "is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "requires": { + "call-bind": "^1.0.7" + } + }, + "is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "requires": { + "has-symbols": "^1.0.2" + } + }, + "is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "requires": { + "which-typed-array": "^1.1.14" + } + }, + "is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + } + }, + "isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "requires": { + "json-buffer": "3.0.1" + } + }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" } }, "lodash.isempty": { @@ -32,11 +1225,269 @@ "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "lodash.truncate": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", + "integrity": "sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==", + "dev": true + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "memorystream": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", + "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", + "dev": true + }, + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, "ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + } + } + }, + "npm-run-all": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", + "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "chalk": "^2.4.1", + "cross-spawn": "^6.0.5", + "memorystream": "^0.3.1", + "minimatch": "^3.0.4", + "pidtree": "^0.3.0", + "read-pkg": "^3.0.0", + "shell-quote": "^1.6.1", + "string.prototype.padend": "^3.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", + "dev": true + }, + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "object-inspect": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", + "dev": true + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true + }, + "object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "optionator": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", + "dev": true, + "requires": { + "@aashutoshrathi/word-wrap": "^1.2.3", + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pidtree": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", + "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", + "dev": true + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "dev": true + }, "pipeline-cli": { "version": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git#61b44543041da3697d189beb2472539fe2e099c1", "from": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git", @@ -48,11 +1499,615 @@ "lodash.isstring": "^4.0.1" } }, + "possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true + }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, "prettier": { "version": "2.3.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.3.2.tgz", "integrity": "sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ==", "dev": true + }, + "prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "requires": { + "fast-diff": "^1.1.2" + } + }, + "prettier-plugin-organize-imports": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/prettier-plugin-organize-imports/-/prettier-plugin-organize-imports-2.3.4.tgz", + "integrity": "sha512-R8o23sf5iVL/U71h9SFUdhdOEPsi3nm42FD/oDYIZ2PQa4TNWWuWecxln6jlIQzpZTDMUeO1NicJP6lLn2TtRw==", + "dev": true + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true + }, + "punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "regexp.prototype.flags": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" + } + }, + "regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true + }, + "require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true + }, + "resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "requires": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + } + }, + "safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + } + }, + "semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + } + }, + "set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + } + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "shell-quote": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", + "dev": true + }, + "side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + } + }, + "slice-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", + "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "astral-regex": "^2.0.0", + "is-fullwidth-code-point": "^3.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + } + } + }, + "spdx-correct": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", + "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.17.tgz", + "integrity": "sha512-sh8PWc/ftMqAAdFiBu6Fy6JUOYjqDJBJvIhpfDMyHrr0Rbp5liZqd4TjtQ/RgfLjKFZb+LMx5hpml5qOWy0qvg==", + "dev": true + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "string.prototype.padend": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", + "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "dependencies": { + "es-abstract": { + "version": "1.23.2", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.2.tgz", + "integrity": "sha512-60s3Xv2T2p1ICykc7c+DNDPLDMm9t4QxCOUU0K9JxiLjM3C1zB9YVdN7tjxrFd4+AkZ8CdX1ovUga4P2+1e+/w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + } + } + } + }, + "string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + } + }, + "string.prototype.trimstart": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true + }, + "strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true + }, + "table": { + "version": "6.8.1", + "resolved": "https://registry.npmjs.org/table/-/table-6.8.1.tgz", + "integrity": "sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==", + "dev": true, + "requires": { + "ajv": "^8.0.1", + "lodash.truncate": "^4.4.2", + "slice-ansi": "^4.0.0", + "string-width": "^4.2.3", + "strip-ansi": "^6.0.1" + }, + "dependencies": { + "ajv": { + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.2.2" + } + }, + "json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true + } + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + }, + "typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-length": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.5.tgz", + "integrity": "sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + } + }, + "unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + } + }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "v8-compile-cache": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.4.0.tgz", + "integrity": "sha512-ocyWc3bAHBB/guyqJQVI5o4BZkPhznPYUG2ea80Gond/BgNWpap8TOmLSeeQG7bnh2KMISxskdADG59j7zruhw==", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "requires": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + } + }, + "which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true } } } diff --git a/app/.pipeline/package.json b/app/.pipeline/package.json index 3e805fbba6..841134fef5 100644 --- a/app/.pipeline/package.json +++ b/app/.pipeline/package.json @@ -18,7 +18,8 @@ "lint": "eslint . --ignore-pattern 'node_modules' --ext .js,.ts", "lint-fix": "eslint . --fix --ignore-pattern 'node_modules' --ext .js,.ts", "format": "prettier --check \"./**/*.{js,jsx,ts,tsx,css,scss}\"", - "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"" + "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"", + "fix": "npm-run-all -l -s lint-fix format-fix" }, "dependencies": { "debug": "^4.2.0", @@ -29,6 +30,11 @@ "pipeline-cli": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git" }, "devDependencies": { - "prettier": "~2.3.2" + "eslint": "~7.32.0", + "eslint-config-prettier": "~6.15.0", + "eslint-plugin-prettier": "~3.3.1", + "npm-run-all": "~4.1.5", + "prettier": "^2.3.2", + "prettier-plugin-organize-imports": "~2.3.4" } } diff --git a/app/.pipeline/scripts/app.build.js b/app/.pipeline/scripts/app.build.js index aeafd09c2a..508c55fd5f 100644 --- a/app/.pipeline/scripts/app.build.js +++ b/app/.pipeline/scripts/app.build.js @@ -1,8 +1,12 @@ 'use strict'; -const config = require('../config.js'); const { appBuild } = require('../lib/app.build.js'); +const config = require('../config.js'); -const settings = { ...config, phase: 'build' }; +if (['pr', 'dev'].includes(config.options.env)) { + console.debug(JSON.stringify(config.options)); + console.debug(JSON.stringify(config.phases)); +} -appBuild(settings); +// Builds the app image +appBuild(config); diff --git a/app/.pipeline/scripts/app.deploy.js b/app/.pipeline/scripts/app.deploy.js index 128a729257..34ad2496fe 100644 --- a/app/.pipeline/scripts/app.deploy.js +++ b/app/.pipeline/scripts/app.deploy.js @@ -4,19 +4,17 @@ const process = require('process'); const { appDeploy } = require('../lib/app.deploy.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - process.on('unhandledRejection', (reason, promise) => { - console.log('app deploy - unhandled rejection:', promise, 'reason:', reason); + console.debug('app deploy - unhandled rejection:', promise, 'reason:', reason); process.exit(1); }); process.on('exit', (code) => { - console.log('app deploy - exit:', 'code:', code); + console.debug('app deploy - exit:', 'code:', code); }); // Deploys the app image -appDeploy(settings).catch((error) => { - console.log('app deploy - catch - error: ', error); +appDeploy(config).catch((error) => { + console.debug('app deploy - catch - error: ', error); throw error; }); diff --git a/app/.pipeline/scripts/clean.js b/app/.pipeline/scripts/clean.js index 5e7fae7b4f..d37abfa54f 100644 --- a/app/.pipeline/scripts/clean.js +++ b/app/.pipeline/scripts/clean.js @@ -3,7 +3,8 @@ const { clean } = require('../lib/clean.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - // Cleans all build and deployment artifacts (pods, etc) -clean(settings); +clean(config).catch((error) => { + console.debug('app clean - catch - error: ', error); + throw error; +}); diff --git a/app/.pipeline/templates/app.dc.yaml b/app/.pipeline/templates/app.dc.yaml index 6bc31cf023..b417475d13 100644 --- a/app/.pipeline/templates/app.dc.yaml +++ b/app/.pipeline/templates/app.dc.yaml @@ -11,7 +11,7 @@ parameters: value: 'dev' - name: VERSION value: '1.0' - - name: HOST + - name: APP_HOST - name: CHANGE_ID value: '0' - name: REACT_APP_BIOHUB_FEATURE_FLAG @@ -35,8 +35,8 @@ parameters: - name: REACT_APP_NODE_ENV description: NODE_ENV specification variable for React app value: 'development' - - name: OBJECT_STORE_SECRETS - description: Secrets used to read and write to the S3 storage + - name: OBJECT_STORE_SECRET + description: The name of the Openshift secret which contains the object store credentials. value: 'biohubbc-object-store' - name: APP_PORT_DEFAULT description: Application default port @@ -137,12 +137,12 @@ objects: valueFrom: secretKeyRef: key: object_store_url - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} - name: OBJECT_STORE_BUCKET_NAME valueFrom: secretKeyRef: key: object_store_bucket_name - name: ${OBJECT_STORE_SECRETS} + name: ${OBJECT_STORE_SECRET} - name: NODE_ENV value: ${NODE_ENV} - name: REACT_APP_BIOHUB_FEATURE_FLAG @@ -250,7 +250,7 @@ objects: labels: {} name: ${NAME}${SUFFIX} spec: - host: ${HOST} + host: ${APP_HOST} tls: insecureEdgeTerminationPolicy: Redirect termination: edge diff --git a/app/.pipeline/utils/utils.js b/app/.pipeline/utils/utils.js new file mode 100644 index 0000000000..e199e6ebeb --- /dev/null +++ b/app/.pipeline/utils/utils.js @@ -0,0 +1,55 @@ +'use strict'; + +/** + * Parses the npm cli command options and the git action context. + * + * @param {*} options + * @return {{ + * git: { + * dir: '', + * branch: { + * name: '', + * remote: '', + * merge: '' + * }, + * url: 'https://github.com/bcgov/biohubbc.git', + * uri: 'https://github.com/bcgov/biohubbc', + * http_url: 'https://github.com/bcgov/biohubbc.git', + * owner: 'bcgov', + * repository: 'biohubbc', + * pull_request: '', + * ref: '', + * branch_ref: '' + * }, + * env: 'pr' | 'dev' | 'test' | 'prod', + * phase: 'build' | 'deploy', + * config: string, // sims pipeline config map (stringified JSON) + * pr?: number, // For PR based deployments + * branch?: string, // For static (dev, test, prod) deployments + * }} + */ +const processOptions = (options) => { + const result = { ...options }; + + // Check git + if (!result.git.url.includes('.git')) { + result.git.url = `${result.git.url}.git`; + } + + if (!result.git.http_url.includes('.git')) { + result.git.http_url = `${result.git.http_url}.git`; + } + + // Fixing repo + if (result.git.repository.includes('/')) { + const last = result.git.repository.split('/').pop(); + const final = last.split('.')[0]; + result.git.repository = final; + } + + return result; +}; + +module.exports = { + processOptions +}; diff --git a/containers/backup/templates/backup/backup-deploy.yaml b/containers/backup/templates/backup/backup-deploy.yaml index 2765663636..0ffb879b40 100644 --- a/containers/backup/templates/backup/backup-deploy.yaml +++ b/containers/backup/templates/backup/backup-deploy.yaml @@ -207,6 +207,10 @@ parameters: description: The path on which to mount the verification volume. This is used by the database server to contain the database configuration and data files. For Mongo, please use /var/lib/mongodb/data . For MSSQL, please use /var/opt/mssql/data. For MariaDB, please use /var/lib/mysql/data required: true value: /var/lib/pgsql/data + - name: OBJECT_STORE_SECRET + displayName: Object Store Secret + description: The name of the secret containing the object store credentials. + value: biohubbc-object-store - name: OBJECT_STORE_URL displayName: Object Store URL description: URL for the object store @@ -446,22 +450,22 @@ objects: - name: OBJECT_STORE_URL valueFrom: secretKeyRef: - name: biohubbc-object-store + name: ${OBJECT_STORE_SECRET} key: object_store_url - name: OBJECT_STORE_ACCESS_KEY_ID valueFrom: secretKeyRef: - name: biohubbc-object-store + name: ${OBJECT_STORE_SECRET} key: object_store_access_key_id - name: OBJECT_STORE_SECRET_KEY_ID valueFrom: secretKeyRef: - name: biohubbc-object-store + name: ${OBJECT_STORE_SECRET} key: object_store_secret_key_id - name: OBJECT_STORE_BUCKET_NAME valueFrom: secretKeyRef: - name: biohubbc-object-store + name: ${OBJECT_STORE_SECRET} key: object_store_bucket_name resources: requests: diff --git a/database/.pipeline/config.js b/database/.pipeline/config.js index e126db6e77..e914434787 100644 --- a/database/.pipeline/config.js +++ b/database/.pipeline/config.js @@ -1,120 +1,116 @@ 'use strict'; -let options = require('pipeline-cli').Util.parseArguments(); +const PipelineCli = require('pipeline-cli'); +const { processOptions } = require('./utils/utils'); -// The root config for common values -const config = require('../../.config/config.json'); +// Options passed in from the git action +const rawOptions = PipelineCli.Util.parseArguments(); -const name = config.module.db; +const options = processOptions(rawOptions); -const version = config.version; +// Get pull-request number from git action '--pr' arg +const changeId = options.pr; -const changeId = options.pr; // pull-request number or branch name +// Get branch name from the git action '--branch' arg +const branch = options.branch || null; -// A static deployment is when the deployment is updating dev, test, or prod (rather than a temporary PR) -// See `--type=static` in the `deployStatic.yml` git workflow -const isStaticDeployment = options.type === 'static'; - -const deployChangeId = (isStaticDeployment && 'deploy') || changeId; -const branch = (isStaticDeployment && options.branch) || null; -const tag = (branch && `build-${version}-${changeId}-${branch}`) || `build-${version}-${changeId}`; - -const dbSetupDockerfilePath = './.docker/db/Dockerfile.setup'; - -const processOptions = (options) => { - const result = { ...options }; - - // Check git - if (!result.git.url.includes('.git')) { - result.git.url = `${result.git.url}.git`; - } - - if (!result.git.http_url.includes('.git')) { - result.git.http_url = `${result.git.http_url}.git`; - } - - // Fixing repo - if (result.git.repository.includes('/')) { - const last = result.git.repository.split('/').pop(); - const final = last.split('.')[0]; - result.git.repository = final; - } - - return result; -}; - -options = processOptions(options); +// Get pipeline config map from git action '--config' arg +const pipelineConfigMapString = options.config; +const pipelineConfigMap = JSON.parse(pipelineConfigMapString); +/** + * The pipeline settings for the Database and Database Setup. + * + * The top-level keys are the pipeline environments (e.g. pr, dev, test, prod). + * - This is specified by setting the '--env' arg in the git action. + * + * The second-level keys are the pipeline phases (e.g. build, deploy). + * - This is specified by setting the '--phase' arg in the git action. + */ const phases = { - build: { - namespace: 'af2668-tools', - name: `${name}`, - phase: 'build', - changeId: changeId, - suffix: `-build-${changeId}`, - instance: `${name}-build-${changeId}`, - version: `${version}-${changeId}`, - tag: tag, - tz: config.timezone.db, - branch: branch, - dbSetupDockerfilePath: dbSetupDockerfilePath + pr: { + build: { + ...pipelineConfigMap.database.pr.build, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.db}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}`, + BRANCH: options.git.ref + }, + deploy: { + ...pipelineConfigMap.database.pr.deploy, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-dev-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.db}-pr-${changeId}`, + VERSION: `pr-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-${changeId}` + } }, dev: { - namespace: 'af2668-dev', - name: `${name}`, - phase: 'dev', - changeId: deployChangeId, - suffix: `-dev-${deployChangeId}`, - instance: `${name}-dev-${deployChangeId}`, - version: `${deployChangeId}-${changeId}`, - tag: `dev-${version}-${deployChangeId}`, - nodeEnv: 'development', - tz: config.timezone.db, - dbSetupDockerfilePath: dbSetupDockerfilePath, - volumeCapacity: (isStaticDeployment && '3Gi') || '500Mi', - cpuRequest: '50m', - cpuLimit: '600m', - memoryRequest: '100Mi', - memoryLimit: '4Gi', - replicas: '1' + build: { + ...pipelineConfigMap.database.dev.build, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.db}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.database.dev.deploy, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: `-dev-deploy`, + INSTANCE: `${pipelineConfigMap.module.db}-dev-deploy`, + VERSION: `deploy-${changeId}`, + TAG: `dev-${pipelineConfigMap.version}-deploy` + } }, test: { - namespace: 'af2668-test', - name: `${name}`, - phase: 'test', - changeId: deployChangeId, - suffix: `-test`, - instance: `${name}-test`, - version: `${version}`, - tag: `test-${version}`, - nodeEnv: 'production', - tz: config.timezone.db, - dbSetupDockerfilePath: dbSetupDockerfilePath, - volumeCapacity: '20Gi', - cpuRequest: '50m', - cpuLimit: '2000m', - memoryRequest: '100Mi', - memoryLimit: '5Gi', - replicas: '1' + build: { + ...pipelineConfigMap.database.test.build, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.db}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.database.test.deploy, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: `-test`, + INSTANCE: `${pipelineConfigMap.module.db}-test`, + VERSION: `deploy-${changeId}`, + TAG: `test-${pipelineConfigMap.version}` + } }, prod: { - namespace: 'af2668-prod', - name: `${name}`, - phase: 'prod', - changeId: deployChangeId, - suffix: `-prod`, - instance: `${name}-prod`, - version: `${version}`, - tag: `prod-${version}`, - nodeEnv: 'production', - tz: config.timezone.db, - dbSetupDockerfilePath: dbSetupDockerfilePath, - volumeCapacity: '20Gi', - cpuRequest: '50m', - cpuLimit: '4000m', - memoryRequest: '100Mi', - memoryLimit: '10Gi', - replicas: '1' + build: { + ...pipelineConfigMap.database.prod.build, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: changeId, + SUFFIX: `-build-${changeId}`, + INSTANCE: `${pipelineConfigMap.module.db}-build-${changeId}`, + VERSION: `${pipelineConfigMap.version}-${changeId}`, + TAG: `build-${pipelineConfigMap.version}-${changeId}-${branch}`, + BRANCH: branch + }, + deploy: { + ...pipelineConfigMap.database.prod.deploy, + NAME: pipelineConfigMap.module.db, + CHANGE_ID: 'deploy', + SUFFIX: `-prod`, + INSTANCE: `${pipelineConfigMap.module.db}-prod`, + VERSION: `deploy-${changeId}`, + TAG: `prod-${pipelineConfigMap.version}` + } } }; diff --git a/database/.pipeline/lib/clean.js b/database/.pipeline/lib/clean.js index 64e6d9b0de..69eb1768f5 100644 --- a/database/.pipeline/lib/clean.js +++ b/database/.pipeline/lib/clean.js @@ -3,81 +3,85 @@ const { OpenShiftClientX } = require('pipeline-cli'); const { checkAndClean } = require('../utils/utils'); +/** + * Run OC commands to clean all build and deployment artifacts (pods, imagestreams, builds/deployment configs, etc). + * + * @param {*} settings + */ const clean = async (settings) => { const phases = settings.phases; const options = settings.options; - const target_phase = options.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases.build.namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env]['build'].NAMESPACE }, options)); - for (let phaseKey in phases) { - if (!Object.prototype.hasOwnProperty.call(phases, phaseKey)) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases, env)) { + // is not a field of phases + return; + } - if (phaseKey !== target_phase) { - continue; - } + if (!Object.prototype.hasOwnProperty.call(phases[env], phase)) { + // is not a field of phases[env] + return; + } - const phaseObj = phases[phaseKey]; + // Get build configs + let buildConfigs = oc.get('bc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); - // Get build configs - let buildConfigs = oc.get('bc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); + // Clean build configs + buildConfigs.forEach((buildConfig) => { + if (buildConfig.spec.output.to.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${buildConfig.spec.output.to.name}`], { + 'ignore-not-found': 'true', + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); + } + }); - // Clean build configs - buildConfigs.forEach((bc) => { - if (bc.spec.output.to.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${bc.spec.output.to.name}`], { + // get deployment configs + let deploymentConfigs = oc.get('dc', { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},env-name=${env},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + namespace: phases[env][phase].NAMESPACE + }); + + // Clean deployment configs + deploymentConfigs.forEach((deploymentConfig) => { + deploymentConfig.spec.triggers.forEach((trigger) => { + if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { + oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { 'ignore-not-found': 'true', wait: 'true', - namespace: phaseObj.namespace + namespace: phases[env][phase].NAMESPACE }); } }); + }); - // get deployment configs - let deploymentConfigs = oc.get('dc', { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},env-name=${phaseKey},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - namespace: phaseObj.namespace - }); - - // Clean deployment configs - deploymentConfigs.forEach((dc) => { - dc.spec.triggers.forEach((trigger) => { - if (trigger.type == 'ImageChange' && trigger.imageChangeParams.from.kind == 'ImageStreamTag') { - oc.delete([`ImageStreamTag/${trigger.imageChangeParams.from.name}`], { - 'ignore-not-found': 'true', - wait: 'true', - namespace: phaseObj.namespace - }); - } - }); + // Cleaning other pods + if (phase !== 'build') { + const newOC = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); + const setupPod = `${phases[env][phase].NAME}-setup${phases[env][phase].SUFFIX}`; + await checkAndClean(`pod/${setupPod}`, 10, 5, 0, newOC).catch(() => { + // Ignore errors, nothing to clean }); + } - // Cleaning other pods - if (phaseKey !== 'build') { - const newOC = new OpenShiftClientX(Object.assign({ namespace: phases[phaseKey].namespace }, options)); - const setupPod = `${phases[phaseKey].name}-setup${phases[phaseKey].suffix}`; - await checkAndClean(`pod/${setupPod}`, 10, 5, 0, newOC).catch(() => { - // Ignore errors, nothing to clean - }); - } - - oc.raw('delete', ['all'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); + oc.raw('delete', ['all'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); - oc.raw('delete', ['all,pvc,secrets,Secrets,secret,configmap,endpoints,Endpoints'], { - selector: `app=${phaseObj.instance},env-id=${phaseObj.changeId},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, - wait: 'true', - namespace: phaseObj.namespace - }); - } + oc.raw('delete', ['all,pvc,secrets,Secrets,secret,configmap,endpoints,Endpoints'], { + selector: `app=${phases[env][phase].INSTANCE},env-id=${phases[env][phase].CHANGE_ID},!shared,github-repo=${oc.git.repository},github-owner=${oc.git.owner}`, + wait: 'true', + namespace: phases[env][phase].NAMESPACE + }); }; module.exports = { clean }; diff --git a/database/.pipeline/lib/db.build.js b/database/.pipeline/lib/db.build.js index 7fe7668f58..0b4373f9ef 100644 --- a/database/.pipeline/lib/db.build.js +++ b/database/.pipeline/lib/db.build.js @@ -11,9 +11,10 @@ const path = require('path'); const dbBuild = (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); @@ -22,14 +23,20 @@ const dbBuild = (settings) => { objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/db.bc.yaml`, { param: { - NAME: phases[phase].name, - SUFFIX: `${phases[phase].suffix}`, - TAG_NAME: `${phases[phase].tag}` + NAME: phases[env][phase].NAME, + SUFFIX: phases[env][phase].SUFFIX, + TAG_NAME: phases[env][phase].TAG } }) ); - oc.applyRecommendedLabels(objects, phases[phase].name, phase, phases[phase].changeId, phases[phase].instance); + oc.applyRecommendedLabels( + objects, + phases[env][phase].NAME, + env, + phases[env][phase].CHANGE_ID, + phases[env][phase].INSTANCE + ); oc.applyAndBuild(objects); }; diff --git a/database/.pipeline/lib/db.deploy.js b/database/.pipeline/lib/db.deploy.js index cbc1485827..98a174af7e 100644 --- a/database/.pipeline/lib/db.deploy.js +++ b/database/.pipeline/lib/db.deploy.js @@ -12,42 +12,44 @@ const path = require('path'); const dbDeploy = async (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.options.env; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - const name = `${phases[phase].name}`; - const instance = `${phases[phase].instance}`; - const changeId = `${phases[phase].changeId}`; + const NAME = `${phases[env][phase].NAME}`; + const INSTANCE = `${phases[env][phase].INSTANCE}`; + const CHANGE_ID = `${phases[env][phase].CHANGE_ID}`; const objects = []; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/db.dc.yaml`, { param: { - NAME: name, - DATABASE_SERVICE_NAME: `${name}-postgresql${phases[phase].suffix}`, - IMAGE_STREAM_NAME: name, - IMAGE_STREAM_VERSION: phases.build.tag, + NAME: NAME, + DATABASE_SERVICE_NAME: `${NAME}-postgresql${phases[env][phase].SUFFIX}`, + IMAGE_STREAM_NAME: NAME, + IMAGE_STREAM_VERSION: phases[env]['build'].TAG, POSTGRESQL_DATABASE: 'biohubbc', - TZ: phases[phase].tz, - IMAGE_STREAM_NAMESPACE: phases.build.namespace, - VOLUME_CAPACITY: phases[phase].volumeCapacity, - CPU_REQUEST: phases[phase].cpuRequest, - CPU_LIMIT: phases[phase].cpuLimit, - MEMORY_REQUEST: phases[phase].memoryRequest, - MEMORY_LIMIT: phases[phase].memoryLimit, - REPLICAS: phases[phase].replicas + TZ: phases[env][phase].TZ, + IMAGE_STREAM_NAMESPACE: phases[env]['build'].NAMESPACE, + VOLUME_CAPACITY: phases[env][phase].VOLUME_CAPACITY, + // Openshift Resources + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT, + REPLICAS: phases[env][phase].REPLICAS } }) ); - oc.applyRecommendedLabels(objects, name, phase, changeId, instance); - oc.importImageStreams(objects, phases[phase].tag, phases.build.namespace, phases.build.tag); - - await oc.applyAndDeploy(objects, instance); + oc.applyRecommendedLabels(objects, NAME, env, CHANGE_ID, INSTANCE); + oc.importImageStreams(objects, phases[env][phase].TAG, phases[env]['build'].NAMESPACE, phases[env]['build'].TAG); + + await oc.applyAndDeploy(objects, INSTANCE); }; module.exports = { dbDeploy }; diff --git a/database/.pipeline/lib/db.setup.build.js b/database/.pipeline/lib/db.setup.build.js index daf5d7b565..d287f5baa2 100644 --- a/database/.pipeline/lib/db.setup.build.js +++ b/database/.pipeline/lib/db.setup.build.js @@ -11,35 +11,36 @@ const path = require('path'); const dbSetupBuild = (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.phase; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - const name = `${phases[phase].name}-setup`; + const NAME = `${phases[env][phase].NAME}-setup`; const objects = []; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/db.setup.bc.yaml`, { param: { - NAME: name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, - SOURCE_CONTEXT_DIR: 'database', - DB_SETUP_DOCKERFILE_PATH: phases[phase].dbSetupDockerfilePath, + NAME: NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, + SOURCE_CONTEXT_DIR: phases[env][phase].SOURCE_CONTEXT_DIR, + DB_SETUP_DOCKERFILE_PATH: phases[env][phase].DB_SETUP_DOCKERFILE_PATH, SOURCE_REPOSITORY_URL: oc.git.http_url, - SOURCE_REPOSITORY_REF: phases[phase].branch || oc.git.ref, - CPU_REQUEST: '50m', - CPU_LIMIT: '1000m', - MEMORY_REQUEST: '100Mi', - MEMORY_LIMIT: '1.5Gi' + SOURCE_REPOSITORY_REF: phases[env][phase].BRANCH, + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT } }) ); - oc.applyRecommendedLabels(objects, name, phase, phases[phase].changeId, phases[phase].instance); + oc.applyRecommendedLabels(objects, NAME, env, phases[env][phase].CHANGE_ID, phases[env][phase].INSTANCE); oc.applyAndBuild(objects); }; diff --git a/database/.pipeline/lib/db.setup.deploy.js b/database/.pipeline/lib/db.setup.deploy.js index 08c9aeb14f..15e43b908e 100644 --- a/database/.pipeline/lib/db.setup.deploy.js +++ b/database/.pipeline/lib/db.setup.deploy.js @@ -14,24 +14,24 @@ const { const dbSetupDeploy = async (settings) => { const phases = settings.phases; const options = settings.options; - const phase = settings.options.env; + const env = settings.options.env; + const phase = settings.options.phase; - const oc = new OpenShiftClientX(Object.assign({ namespace: phases[phase].namespace }, options)); + const oc = new OpenShiftClientX(Object.assign({ namespace: phases[env][phase].NAMESPACE }, options)); const templatesLocalBaseUrl = oc.toFileUrl(path.resolve(__dirname, '../templates')); - const changeId = phases[phase].changeId; - const isName = `${phases[phase].name}-setup`; - const instance = `${isName}-${changeId}`; - const isVersion = `${phases[phase].tag}-setup`; - const imageStreamName = `${isName}:${isVersion}`; - const dbName = `${phases[phase].name}-postgresql${phases[phase].suffix}`; + const IMAGE_NAME = `${phases[env][phase].NAME}-setup`; + const INSTANCE = `${IMAGE_NAME}-${phases[env][phase].CHANGE_ID}`; + const IMAGE_VERSION = `${phases[env][phase].TAG}-setup`; + const IMAGESTREAM_NAME = `${IMAGE_NAME}:${IMAGE_VERSION}`; + const DB_SERVICE_NAME = `${phases[env][phase].NAME}-postgresql${phases[env][phase].SUFFIX}`; const objects = []; const imageStreamObjects = []; // Clean existing image - await checkAndClean(`istag/${imageStreamName}`, 10, 5, 0, oc).catch(() => { + await checkAndClean(`istag/${IMAGESTREAM_NAME}`, 10, 5, 0, oc).catch(() => { // Ignore errors, nothing to clean }); @@ -39,54 +39,61 @@ const dbSetupDeploy = async (settings) => { imageStreamObjects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/db.setup.is.yaml`, { param: { - NAME: `${isName}` + NAME: `${IMAGE_NAME}` } }) ); - oc.applyRecommendedLabels(imageStreamObjects, isName, phase, `${changeId}`, instance); - oc.importImageStreams(imageStreamObjects, isVersion, phases.build.namespace, phases.build.tag); + oc.applyRecommendedLabels(imageStreamObjects, IMAGE_NAME, env, phases[env][phase].CHANGE_ID, INSTANCE); + oc.importImageStreams(imageStreamObjects, IMAGE_VERSION, phases[env]['build'].NAMESPACE, phases[env]['build'].TAG); // Get database setup image stream - const fetchedImageStreams = oc.get(`istag/${imageStreamName}`) || []; + const fetchedImageStreams = oc.get(`istag/${IMAGESTREAM_NAME}`) || []; if (!fetchedImageStreams.length) { - console.log('Unable to fetch Database image reference for use in database setup deployment'); + console.debug('Unable to fetch Database image reference for use in database setup deployment'); process.exit(0); } const dbSetupImageStream = fetchedImageStreams[0]; - const name = `${isName}${phases[phase].suffix}`; + const NAME = `${IMAGE_NAME}${phases[env][phase].SUFFIX}`; objects.push( ...oc.processDeploymentTemplate(`${templatesLocalBaseUrl}/db.setup.dc.yaml`, { param: { - NAME: name, - SUFFIX: phases[phase].suffix, - VERSION: phases[phase].tag, - CHANGE_ID: changeId, - NODE_ENV: phases[phase].nodeEnv, - DB_SERVICE_NAME: dbName, - DB_SCHEMA: 'biohub', - DB_SCHEMA_DAPI_V1: 'biohub_dapi_v1', + NAME: NAME, + SUFFIX: phases[env][phase].SUFFIX, + VERSION: phases[env][phase].TAG, + CHANGE_ID: phases[env][phase].CHANGE_ID, + NODE_ENV: phases[env][phase].NODE_ENV, + DB_SERVICE_NAME: DB_SERVICE_NAME, + DB_SCHEMA: phases[env][phase].DB_SCHEMA, + DB_SCHEMA_DAPI_V1: phases[env][phase].DB_SCHEMA_DAPI_V1, IMAGE: dbSetupImageStream.image.dockerImageReference, - CPU_REQUEST: '50m', - CPU_LIMIT: '1000m', - MEMORY_REQUEST: '100Mi', - MEMORY_LIMIT: '1.5Gi' + // Development Seeding + SEED_PROJECT_USER_IDENTIFIER: phases[env][phase].SEED_PROJECT_USER_IDENTIFIER, + SEED_NUM_PROJECTS: phases[env][phase].SEED_NUM_PROJECTS, + SEED_NUM_SURVEYS_PER_PROJECT: phases[env][phase].SEED_NUM_SURVEYS_PER_PROJECT, + SEED_NUM_OBSERVATIONS_PER_SURVEY: phases[env][phase].SEED_NUM_OBSERVATIONS_PER_SURVEY, + SEED_NUM_SUBCOUNTS_PER_OBSERVATION: phases[env][phase].SEED_NUM_SUBCOUNTS_PER_OBSERVATION, + // Openshift Resources + CPU_REQUEST: phases[env][phase].CPU_REQUEST, + CPU_LIMIT: phases[env][phase].CPU_LIMIT, + MEMORY_REQUEST: phases[env][phase].MEMORY_REQUEST, + MEMORY_LIMIT: phases[env][phase].MEMORY_LIMIT } }) ); // Clean existing setup pod - await checkAndClean(`pod/${name}`, 10, 5, 0, oc).catch(() => { + await checkAndClean(`pod/${NAME}`, 10, 5, 0, oc).catch(() => { // Ignore errors, nothing to clean }); // Wait to confirm if the db pod deployed successfully await waitForResourceToMeetCondition( - () => getResourceByRaw(`name=${dbName}`, 'pod', settings, oc), + () => getResourceByRaw(`name=${DB_SERVICE_NAME}`, 'pod', settings, oc), isResourceRunning, 30, 5, @@ -94,11 +101,11 @@ const dbSetupDeploy = async (settings) => { ); // Deploy the db setup pod - oc.applyRecommendedLabels(objects, isName, phase, `${changeId}`, instance); - await oc.applyAndDeploy(objects, phases[phase].instance); + oc.applyRecommendedLabels(objects, IMAGE_NAME, env, phases[env][phase].CHANGE_ID, INSTANCE); + await oc.applyAndDeploy(objects, phases[env][phase].INSTANCE); // Wait to confirm if the db setup pod deployed successfully - await waitForResourceToMeetCondition(() => getResourceByName(`pod/${name}`, oc), isResourceComplete, 30, 5, 0); + await waitForResourceToMeetCondition(() => getResourceByName(`pod/${NAME}`, oc), isResourceComplete, 30, 5, 0); }; module.exports = { dbSetupDeploy }; diff --git a/database/.pipeline/package-lock.json b/database/.pipeline/package-lock.json index 83751a9d58..299ead87cb 100644 --- a/database/.pipeline/package-lock.json +++ b/database/.pipeline/package-lock.json @@ -4,12 +4,1205 @@ "lockfileVersion": 1, "requires": true, "dependencies": { + "@aashutoshrathi/word-wrap": { + "version": "1.2.6", + "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", + "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", + "dev": true + }, + "@babel/code-frame": { + "version": "7.12.11", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.12.11.tgz", + "integrity": "sha512-Zt1yodBx1UcyiePMSkWnU4hPqhwq7hGi2nFL1LeA3EUl+q2LQx16MISgJ0+z7dnmgvP9QtIleuETGOiOH1RcIw==", + "dev": true, + "requires": { + "@babel/highlight": "^7.10.4" + } + }, + "@babel/helper-validator-identifier": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "dev": true + }, + "@babel/highlight": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", + "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.22.20", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + } + } + }, + "@eslint/eslintrc": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz", + "integrity": "sha512-J6KFFz5QCYUJq3pf0mjEcCJVERbzv71PUIDczuh9JkwGEzced6CO5ADLHB1rbf/+oPBtoPfMYNOpGDzCANlbXw==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.1.1", + "espree": "^7.3.0", + "globals": "^13.9.0", + "ignore": "^4.0.6", + "import-fresh": "^3.2.1", + "js-yaml": "^3.13.1", + "minimatch": "^3.0.4", + "strip-json-comments": "^3.1.1" + } + }, + "@humanwhocodes/config-array": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.5.0.tgz", + "integrity": "sha512-FagtKFz74XrTl7y6HCzQpwDfXP0yhxe9lHLD1UZxjvZIcbyRz8zTFF/yYNfSfzU414eDwZ1SrO0Qvtyf+wFMQg==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.0", + "debug": "^4.1.1", + "minimatch": "^3.0.4" + } + }, + "@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, + "acorn": { + "version": "7.4.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", + "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "dev": true + }, + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dev": true, + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + } + }, + "arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + } + }, + "astral-regex": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", + "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", + "dev": true + }, + "available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "requires": { + "possible-typed-array-names": "^1.0.0" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + } + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, + "data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + } + }, "debug": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", "requires": { - "ms": "2.1.2" + "ms": "2.1.2" + } + }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + } + }, + "define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "requires": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "enquirer": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.4.1.tgz", + "integrity": "sha512-rRqJg/6gd538VHvR3PSrdRBb/1Vy2YfzHqzvbhGIQpDRKIa4FgV/54b5Q1xYSxOOwKvjXweS26E0Q+nAMwp2pQ==", + "dev": true, + "requires": { + "ansi-colors": "^4.1.1", + "strip-ansi": "^6.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.22.5", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.5.tgz", + "integrity": "sha512-oW69R+4q2wG+Hc3KZePPZxOiisRIqfKBVo/HLx94QcJeWGU/8sZhCvc829rd1kS366vlJbzBfXf9yWwf0+Ko7w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.1", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.0", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.14" + } + }, + "es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4" + } + }, + "es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true + }, + "es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "requires": { + "es-errors": "^1.3.0" + } + }, + "es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "requires": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "eslint": { + "version": "7.32.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-7.32.0.tgz", + "integrity": "sha512-VHZ8gX+EDfz+97jGcgyGCyRia/dPOd6Xh9yPv8Bl1+SoaIwD+a/vlrOmGRUyOYu7MwUhc7CxqeaDZU13S4+EpA==", + "dev": true, + "requires": { + "@babel/code-frame": "7.12.11", + "@eslint/eslintrc": "^0.4.3", + "@humanwhocodes/config-array": "^0.5.0", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "enquirer": "^2.3.5", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^5.1.1", + "eslint-utils": "^2.1.0", + "eslint-visitor-keys": "^2.0.0", + "espree": "^7.3.1", + "esquery": "^1.4.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.1.2", + "globals": "^13.6.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.0.4", + "natural-compare": "^1.4.0", + "optionator": "^0.9.1", + "progress": "^2.0.0", + "regexpp": "^3.1.0", + "semver": "^7.2.1", + "strip-ansi": "^6.0.0", + "strip-json-comments": "^3.1.0", + "table": "^6.0.9", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + } + }, + "eslint-config-prettier": { + "version": "6.15.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.15.0.tgz", + "integrity": "sha512-a1+kOYLR8wMGustcgAjdydMsQ2A/2ipRPwRKUmfYaSxc9ZPcrku080Ctl6zrZzZNs/U82MjSv+qKREkoq3bJaw==", + "dev": true, + "requires": { + "get-stdin": "^6.0.0" + } + }, + "eslint-plugin-prettier": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.3.1.tgz", + "integrity": "sha512-Rq3jkcFY8RYeQLgk2cCwuc0P7SEFwDravPhsJZOQ5N4YI4DSg50NyqJ/9gdZHzQlHf8MvafSesbNJCcP/FF6pQ==", + "dev": true, + "requires": { + "prettier-linter-helpers": "^1.0.0" + } + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-2.1.0.tgz", + "integrity": "sha512-w94dQYoauyvlDc43XnGB8lU3Zt713vNChgt4EWwhXAP2XkBvndfxF0AgIqKOOasjPIPzj9JqgwkwbCYD0/V3Zg==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^1.1.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + }, + "espree": { + "version": "7.3.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-7.3.1.tgz", + "integrity": "sha512-v3JCNCE64umkFpmkFGqzVKsOT0tN1Zr+ueqLZfpV1Ob8e+CEgPWa+OxCoGH3tnhimMKIaBm4m/vaRpJ/krRz2g==", + "dev": true, + "requires": { + "acorn": "^7.4.0", + "acorn-jsx": "^5.3.1", + "eslint-visitor-keys": "^1.3.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", + "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", + "dev": true + } + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true + }, + "esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "requires": { + "estraverse": "^5.1.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + }, + "dependencies": { + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + } + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "dev": true + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, + "flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "requires": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + } + }, + "flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "requires": { + "is-callable": "^1.1.3" + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true + }, + "function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + } + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", + "dev": true + }, + "functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true + }, + "get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + } + }, + "get-stdin": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", + "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", + "dev": true + }, + "get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + } + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3" + } + }, + "gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "requires": { + "get-intrinsic": "^1.1.3" + } + }, + "graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true + }, + "has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "requires": { + "es-define-property": "^1.0.0" + } + }, + "has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true + }, + "has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true + }, + "has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "requires": { + "has-symbols": "^1.0.3" + } + }, + "hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "requires": { + "function-bind": "^1.1.2" + } + }, + "hosted-git-info": { + "version": "2.8.9", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", + "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", + "dev": true + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "requires": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + } + }, + "is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + } + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "requires": { + "has-bigints": "^1.0.1" + } + }, + "is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true + }, + "is-core-module": { + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", + "dev": true, + "requires": { + "hasown": "^2.0.0" + } + }, + "is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "requires": { + "is-typed-array": "^1.1.13" + } + }, + "is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true + }, + "is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + } + }, + "is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "requires": { + "call-bind": "^1.0.7" + } + }, + "is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "requires": { + "has-tostringtag": "^1.0.0" + } + }, + "is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "requires": { + "has-symbols": "^1.0.2" + } + }, + "is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "requires": { + "which-typed-array": "^1.1.14" + } + }, + "is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.2" + } + }, + "isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dev": true, + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "requires": { + "json-buffer": "3.0.1" + } + }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==", + "dev": true, + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" } }, "lodash.isempty": { @@ -32,11 +1225,269 @@ "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "lodash.truncate": { + "version": "4.4.2", + "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", + "integrity": "sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==", + "dev": true + }, + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "memorystream": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", + "integrity": "sha512-S3UwM3yj5mtUSEfP41UZmt/0SCoVYUcU1rkXv+BQ5Ig8ndL4sPoJNBUJERafdPb5jjHJGuMgytgKvKIf58XNBw==", + "dev": true + }, + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, "ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "dev": true, + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + }, + "dependencies": { + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + } + } + }, + "npm-run-all": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", + "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "chalk": "^2.4.1", + "cross-spawn": "^6.0.5", + "memorystream": "^0.3.1", + "minimatch": "^3.0.4", + "pidtree": "^0.3.0", + "read-pkg": "^3.0.0", + "shell-quote": "^1.6.1", + "string.prototype.padend": "^3.0.0" + }, + "dependencies": { + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", + "dev": true + }, + "semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "object-inspect": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", + "dev": true + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true + }, + "object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + } + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "optionator": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", + "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", + "dev": true, + "requires": { + "@aashutoshrathi/word-wrap": "^1.2.3", + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", + "dev": true, + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "requires": { + "pify": "^3.0.0" + } + }, + "pidtree": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", + "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", + "dev": true + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "dev": true + }, "pipeline-cli": { "version": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git#61b44543041da3697d189beb2472539fe2e099c1", "from": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git", @@ -48,11 +1499,615 @@ "lodash.isstring": "^4.0.1" } }, + "possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true + }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, "prettier": { "version": "2.3.2", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.3.2.tgz", "integrity": "sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ==", "dev": true + }, + "prettier-linter-helpers": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", + "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", + "dev": true, + "requires": { + "fast-diff": "^1.1.2" + } + }, + "prettier-plugin-organize-imports": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/prettier-plugin-organize-imports/-/prettier-plugin-organize-imports-2.3.4.tgz", + "integrity": "sha512-R8o23sf5iVL/U71h9SFUdhdOEPsi3nm42FD/oDYIZ2PQa4TNWWuWecxln6jlIQzpZTDMUeO1NicJP6lLn2TtRw==", + "dev": true + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true + }, + "punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha512-BLq/cCO9two+lBgiTYNqD6GdtK8s4NpaWrl6/rCO9w0TUS8oJl7cmToOZfRYllKTISY6nt1U7jQ53brmKqY6BA==", + "dev": true, + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "regexp.prototype.flags": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" + } + }, + "regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true + }, + "require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "dev": true + }, + "resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "requires": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + } + }, + "safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "requires": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + } + }, + "semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + }, + "set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + } + }, + "set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "requires": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + } + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "shell-quote": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.8.1.tgz", + "integrity": "sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==", + "dev": true + }, + "side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + } + }, + "slice-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", + "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "astral-regex": "^2.0.0", + "is-fullwidth-code-point": "^3.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + } + } + }, + "spdx-correct": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", + "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==", + "dev": true, + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", + "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", + "dev": true + }, + "spdx-expression-parse": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", + "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", + "dev": true, + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.17.tgz", + "integrity": "sha512-sh8PWc/ftMqAAdFiBu6Fy6JUOYjqDJBJvIhpfDMyHrr0Rbp5liZqd4TjtQ/RgfLjKFZb+LMx5hpml5qOWy0qvg==", + "dev": true + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", + "dev": true + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + } + }, + "string.prototype.padend": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.5.tgz", + "integrity": "sha512-DOB27b/2UTTD+4myKUFh+/fXWcu/UDyASIXfg+7VzoCNNGOfWvoyU/x5pvVHr++ztyt/oSYI1BcWBBG/hmlNjA==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "dependencies": { + "es-abstract": { + "version": "1.23.2", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.2.tgz", + "integrity": "sha512-60s3Xv2T2p1ICykc7c+DNDPLDMm9t4QxCOUU0K9JxiLjM3C1zB9YVdN7tjxrFd4+AkZ8CdX1ovUga4P2+1e+/w==", + "dev": true, + "requires": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.5", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + } + } + } + }, + "string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + } + }, + "string.prototype.trimstart": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true + }, + "strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true + }, + "table": { + "version": "6.8.1", + "resolved": "https://registry.npmjs.org/table/-/table-6.8.1.tgz", + "integrity": "sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==", + "dev": true, + "requires": { + "ajv": "^8.0.1", + "lodash.truncate": "^4.4.2", + "slice-ansi": "^4.0.0", + "string-width": "^4.2.3", + "strip-ansi": "^6.0.1" + }, + "dependencies": { + "ajv": { + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz", + "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2", + "uri-js": "^4.2.2" + } + }, + "json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "dev": true + } + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + }, + "typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + } + }, + "typed-array-length": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.5.tgz", + "integrity": "sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==", + "dev": true, + "requires": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + } + }, + "unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "requires": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + } + }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "v8-compile-cache": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.4.0.tgz", + "integrity": "sha512-ocyWc3bAHBB/guyqJQVI5o4BZkPhznPYUG2ea80Gond/BgNWpap8TOmLSeeQG7bnh2KMISxskdADG59j7zruhw==", + "dev": true + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "dev": true, + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "requires": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + } + }, + "which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "requires": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true } } } diff --git a/database/.pipeline/package.json b/database/.pipeline/package.json index 2f88bbbd01..da182b9607 100644 --- a/database/.pipeline/package.json +++ b/database/.pipeline/package.json @@ -20,7 +20,8 @@ "lint": "eslint . --ignore-pattern 'node_modules' --ext .js,.ts", "lint-fix": "eslint . --fix --ignore-pattern 'node_modules' --ext .js,.ts", "format": "prettier --check \"./**/*.{js,jsx,ts,tsx,css,scss}\"", - "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"" + "format-fix": "prettier --write \"./**/*.{js,jsx,ts,tsx,json,css,scss}\"", + "fix": "npm-run-all -l -s lint-fix format-fix" }, "dependencies": { "debug": "^4.2.0", @@ -31,6 +32,11 @@ "pipeline-cli": "git+https://github.com/bcgov/biohubbc-pipeline-cli.git" }, "devDependencies": { - "prettier": "~2.3.2" + "eslint": "~7.32.0", + "eslint-config-prettier": "~6.15.0", + "eslint-plugin-prettier": "~3.3.1", + "npm-run-all": "~4.1.5", + "prettier": "^2.3.2", + "prettier-plugin-organize-imports": "~2.3.4" } } diff --git a/database/.pipeline/scripts/clean.js b/database/.pipeline/scripts/clean.js index 5e7fae7b4f..cbaabb14e6 100644 --- a/database/.pipeline/scripts/clean.js +++ b/database/.pipeline/scripts/clean.js @@ -3,7 +3,8 @@ const { clean } = require('../lib/clean.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - // Cleans all build and deployment artifacts (pods, etc) -clean(settings); +clean(config).catch((error) => { + console.debug('database clean - catch - error: ', error); + throw error; +}); diff --git a/database/.pipeline/scripts/db.build.js b/database/.pipeline/scripts/db.build.js index f7c622f3e0..8a281c2577 100644 --- a/database/.pipeline/scripts/db.build.js +++ b/database/.pipeline/scripts/db.build.js @@ -3,7 +3,10 @@ const { dbBuild } = require('../lib/db.build.js'); const config = require('../config.js'); -const settings = { ...config, phase: 'build' }; +if (['pr', 'dev'].includes(config.options.env)) { + console.debug(JSON.stringify(config.options)); + console.debug(JSON.stringify(config.phases)); +} // builds the database image -dbBuild(settings); +dbBuild(config); diff --git a/database/.pipeline/scripts/db.deploy.js b/database/.pipeline/scripts/db.deploy.js index 5589a45346..064d3c727e 100644 --- a/database/.pipeline/scripts/db.deploy.js +++ b/database/.pipeline/scripts/db.deploy.js @@ -4,19 +4,17 @@ const process = require('process'); const { dbDeploy } = require('../lib/db.deploy.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - process.on('unhandledRejection', (reason, promise) => { - console.log('database deploy - unhandled rejection:', promise, 'reason:', reason); + console.debug('database deploy - unhandled rejection:', promise, 'reason:', reason); process.exit(1); }); process.on('exit', (code) => { - console.log('database deploy - exit:', 'code:', code); + console.debug('database deploy - exit:', 'code:', code); }); // Deploys the database image -dbDeploy(settings).catch((error) => { - console.log('database deploy - catch - error: ', error); +dbDeploy(config).catch((error) => { + console.debug('database deploy - catch - error: ', error); throw error; }); diff --git a/database/.pipeline/scripts/db.setup.build.js b/database/.pipeline/scripts/db.setup.build.js index c8470ce9d2..49e6eeb583 100644 --- a/database/.pipeline/scripts/db.setup.build.js +++ b/database/.pipeline/scripts/db.setup.build.js @@ -3,7 +3,10 @@ const { dbSetupBuild } = require('../lib/db.setup.build.js'); const config = require('../config.js'); -const settings = { ...config, phase: 'build' }; +if (['pr', 'dev'].includes(config.options.env)) { + console.debug(JSON.stringify(config.options)); + console.debug(JSON.stringify(config.phases)); +} // build database Setup (migrations, seeding, etc) image -dbSetupBuild(settings); +dbSetupBuild(config); diff --git a/database/.pipeline/scripts/db.setup.deploy.js b/database/.pipeline/scripts/db.setup.deploy.js index ce708f5351..48b2193803 100644 --- a/database/.pipeline/scripts/db.setup.deploy.js +++ b/database/.pipeline/scripts/db.setup.deploy.js @@ -4,19 +4,17 @@ const process = require('process'); const { dbSetupDeploy } = require('../lib/db.setup.deploy.js'); const config = require('../config.js'); -const settings = { ...config, phase: config.options.phase }; - process.on('unhandledRejection', (reason, promise) => { - console.log('database setup deploy - unhandled rejection:', promise, 'reason:', reason); + console.debug('database setup deploy - unhandled rejection:', promise, 'reason:', reason); process.exit(1); }); process.on('exit', (code) => { - console.log('database setup deploy - exit:', 'code:', code); + console.debug('database setup deploy - exit:', 'code:', code); }); // deploy database setup (migrations, seeding, etc) -dbSetupDeploy(settings).catch((error) => { - console.log('database setup deploy - catch - error: ', error); +dbSetupDeploy(config).catch((error) => { + console.debug('database setup deploy - catch - error: ', error); throw error; }); diff --git a/database/.pipeline/templates/db.dc.yaml b/database/.pipeline/templates/db.dc.yaml index e4b567fed5..e955ef3c50 100644 --- a/database/.pipeline/templates/db.dc.yaml +++ b/database/.pipeline/templates/db.dc.yaml @@ -93,7 +93,7 @@ objects: template.openshift.io/expose-password: "{.data['database-user-password']}" template.openshift.io/expose-admin-password: "{.data['database-admin-password']}" template.openshift.io/expose-admin-username: "{.data['database-user']}" - as-copy-of: biohubbc-creds + as-copy-of: sims-database name: '${DATABASE_SERVICE_NAME}' stringData: database-name: '${POSTGRESQL_DATABASE}' diff --git a/database/.pipeline/templates/db.setup.dc.yaml b/database/.pipeline/templates/db.setup.dc.yaml index a384ae55a5..c7d80ad771 100644 --- a/database/.pipeline/templates/db.setup.dc.yaml +++ b/database/.pipeline/templates/db.setup.dc.yaml @@ -32,6 +32,18 @@ parameters: description: Application Environment type variable required: true value: 'development' + # Development Seeding + - name: SEED_PROJECT_USER_IDENTIFIER + value: '1' + - name: SEED_NUM_PROJECTS + value: '0' + - name: SEED_NUM_SURVEYS_PER_PROJECT + value: '0' + - name: SEED_NUM_OBSERVATIONS_PER_SURVEY + value: '0' + - name: SEED_NUM_SUBCOUNTS_PER_OBSERVATION + value: '0' + # Openshift Resources - name: CPU_REQUEST value: '50m' - name: CPU_LIMIT @@ -90,6 +102,16 @@ objects: value: ${DB_SCHEMA} - name: DB_SCHEMA_DAPI_V1 value: ${DB_SCHEMA_DAPI_V1} + - name: SEED_PROJECT_USER_IDENTIFIER + value: ${SEED_PROJECT_USER_IDENTIFIER} + - name: SEED_NUM_PROJECTS + value: ${SEED_NUM_PROJECTS} + - name: SEED_NUM_SURVEYS_PER_PROJECT + value: ${SEED_NUM_SURVEYS_PER_PROJECT} + - name: SEED_NUM_OBSERVATIONS_PER_SURVEY + value: ${SEED_NUM_OBSERVATIONS_PER_SURVEY} + - name: SEED_NUM_SUBCOUNTS_PER_OBSERVATION + value: ${SEED_NUM_SUBCOUNTS_PER_OBSERVATION} image: '${IMAGE}' imagePullPolicy: Always resources: diff --git a/database/.pipeline/utils/utils.js b/database/.pipeline/utils/utils.js index d354977eda..33ef2a2343 100644 --- a/database/.pipeline/utils/utils.js +++ b/database/.pipeline/utils/utils.js @@ -1,5 +1,55 @@ 'use strict'; +/** + * Parses the npm cli command options and the git action context. + * + * @param {*} options + * @return {{ + * git: { + * dir: '', + * branch: { + * name: '', + * remote: '', + * merge: '' + * }, + * url: 'https://github.com/bcgov/biohubbc.git', + * uri: 'https://github.com/bcgov/biohubbc', + * http_url: 'https://github.com/bcgov/biohubbc.git', + * owner: 'bcgov', + * repository: 'biohubbc', + * pull_request: '', + * ref: '', + * branch_ref: '' + * }, + * env: 'pr' | 'dev' | 'test' | 'prod', + * phase: 'build' | 'deploy', + * config: string, // sims pipeline config map (stringified JSON) + * pr?: number, // For PR based deployments + * branch?: string, // For static (dev, test, prod) deployments + * }} + */ +const processOptions = (options) => { + const result = { ...options }; + + // Check git + if (!result.git.url.includes('.git')) { + result.git.url = `${result.git.url}.git`; + } + + if (!result.git.http_url.includes('.git')) { + result.git.http_url = `${result.git.http_url}.git`; + } + + // Fixing repo + if (result.git.repository.includes('/')) { + const last = result.git.repository.split('/').pop(); + const final = last.split('.')[0]; + result.git.repository = final; + } + + return result; +}; + /** * Make an `oc get` command to fetch a resource by name. * @@ -9,7 +59,7 @@ * @throws an Error if the oc command fails */ const getResourceByName = (resourceName, oc) => { - console.log(`1 - getResourceByName - Fetching resource: ${resourceName}`); + console.debug(`1 - getResourceByName - Fetching resource: ${resourceName}`); const matches = oc.get(resourceName); if (!matches || !matches.length) { @@ -30,12 +80,13 @@ const getResourceByName = (resourceName, oc) => { */ const getResourceByRaw = (selector, type, settings, oc) => { const phases = settings.phases; - const phase = settings.options.env; + const env = settings.options.env; + const phase = settings.options.phase; const result = oc.raw('get', [type], { selector: selector, output: 'json', - namespace: phases[phase].namespace + namespace: phases[env][phase].NAMESPACE }); if (!result.stdout || !result.stdout.trim()) { @@ -59,7 +110,7 @@ const getResourceByRaw = (selector, type, settings, oc) => { * @return {*} */ const deleteResourceByName = (resourceName, oc) => { - console.log(`1 - deleteResourceByName - Deleting resource: ${resourceName}`); + console.debug(`1 - deleteResourceByName - Deleting resource: ${resourceName}`); return oc.delete([resourceName], { 'ignore-not-found': 'true', wait: 'true' }); }; @@ -74,29 +125,29 @@ const isResourceRunning = (resource) => { const status = resource.status || { conditions: [], containerStatuses: [] }; if (!status.conditions) { - console.log(`1 - isResourceRunning - Resource 'status.conditions' is null or undefined`); + console.debug(`1 - isResourceRunning - Resource 'status.conditions' is null or undefined`); return false; } if (status.conditions && !status.conditions.length) { - console.log(`2 - isResourceRunning - Resource 'status.conditions' is empty`); + console.debug(`2 - isResourceRunning - Resource 'status.conditions' is empty`); return false; } if (!status.containerStatuses) { - console.log(`3 - isResourceRunning - Resource 'status.containerStatuses' is null or undefined`); + console.debug(`3 - isResourceRunning - Resource 'status.containerStatuses' is null or undefined`); return false; } if (!status.containerStatuses.length) { - console.log(`4 - isResourceRunning - Resource 'status.containerStatuses' is empty`); + console.debug(`4 - isResourceRunning - Resource 'status.containerStatuses' is empty`); return false; } const containerStatus = status.containerStatuses[0] || {}; if (!containerStatus.state) { - console.log(`5 - isResourceRunning - Resource 'status.containerStatus[0].state' is null or undefined`); + console.debug(`5 - isResourceRunning - Resource 'status.containerStatus[0].state' is null or undefined`); return false; } @@ -104,21 +155,21 @@ const isResourceRunning = (resource) => { if (state.terminated) { if (state.terminated.reason.toLowerCase() === 'completed') { - console.log(`8 - isResourceRunning - Resource completed successfully`); + console.debug(`8 - isResourceRunning - Resource completed successfully`); throw new Error(`7 - isResourceRunning - Resource terminated without error`); } else { - console.log(`9 - isResourceRunning - Resource terminated with error`); - console.log(`9 - isResourceRunning - Error: resource status = ${JSON.stringify(resource.status, null, 2)}`); + console.debug(`9 - isResourceRunning - Resource terminated with error`); + console.debug(`9 - isResourceRunning - Error: resource status = ${JSON.stringify(resource.status, null, 2)}`); throw new Error(`9 - isResourceRunning - Resource terminated with error`); } } if (state.running) { - console.log(`6 - isResourceRunning - Resource is running`); + console.debug(`6 - isResourceRunning - Resource is running`); return true; // Happy path } - console.log(`7 - isResourceRunning - Resource is pending`); + console.debug(`7 - isResourceRunning - Resource is pending`); return false; }; @@ -134,29 +185,29 @@ const isResourceComplete = (resource) => { const status = resource.status || { conditions: [], containerStatuses: [] }; if (!status.conditions) { - console.log(`1 - isResourceComplete - Resource 'status.conditions' is null or undefined`); + console.debug(`1 - isResourceComplete - Resource 'status.conditions' is null or undefined`); return false; } if (status.conditions && !status.conditions.length) { - console.log(`2 - isResourceComplete - Resource 'status.conditions' is empty`); + console.debug(`2 - isResourceComplete - Resource 'status.conditions' is empty`); return false; } if (!status.containerStatuses) { - console.log(`3 - isResourceComplete - Resource 'status.containerStatuses' is null or undefined`); + console.debug(`3 - isResourceComplete - Resource 'status.containerStatuses' is null or undefined`); return false; } if (!status.containerStatuses.length) { - console.log(`4 - isResourceComplete - Resource 'status.containerStatuses' is empty`); + console.debug(`4 - isResourceComplete - Resource 'status.containerStatuses' is empty`); return false; } const containerStatus = status.containerStatuses[0] || {}; if (!containerStatus.state) { - console.log(`5 - isResourceComplete - Resource 'status.containerStatus[0].state' is null or undefined`); + console.debug(`5 - isResourceComplete - Resource 'status.containerStatus[0].state' is null or undefined`); return false; } @@ -164,16 +215,16 @@ const isResourceComplete = (resource) => { if (state.terminated) { if (state.terminated.reason.toLowerCase() === 'completed') { - console.log(`7 - isResourceComplete - Resource completed successfully`); + console.debug(`7 - isResourceComplete - Resource completed successfully`); return true; // Happy path } else { - console.log(`8 - isResourceComplete - Resource terminated with error`); - console.log(`8 - isResourceComplete - Error: resource status = ${JSON.stringify(resource.status, null, 2)}`); + console.debug(`8 - isResourceComplete - Resource terminated with error`); + console.debug(`8 - isResourceComplete - Error: resource status = ${JSON.stringify(resource.status, null, 2)}`); throw new Error(`8 - isResourceComplete - Resource terminated with error`); } } - console.log(`6 - isResourceComplete - Resource is pending`); + console.debug(`6 - isResourceComplete - Resource is pending`); return false; }; @@ -214,7 +265,7 @@ const waitForResourceToMeetCondition = async ( const retry = async () => { if (count > 0) { count = count - 1; - console.log(`4 - waitForResourceToMeetCondition - Waiting for resource: retry count = ${count}`); + console.debug(`4 - waitForResourceToMeetCondition - Waiting for resource: retry count = ${count}`); await sleep(timeout); return check(); } else { @@ -223,29 +274,29 @@ const waitForResourceToMeetCondition = async ( }; const check = async () => { - console.log(`1 - waitForResourceToMeetCondition - Waiting for resource begin`); + console.debug(`1 - waitForResourceToMeetCondition - Waiting for resource begin`); let resource; try { resource = getResourceFunction(); - } catch { - console.log(`2 - waitForResourceToMeetCondition - Resource was not found`); - return retry(); - } - - if (!resource) { - console.log(`3 - waitForResourceToMeetCondition - Resource was not found`); + } catch (_) { + console.debug(`2 - waitForResourceToMeetCondition - Resource was not found`); return retry(); } try { + if (!resource) { + console.debug(`3 - waitForResourceToMeetCondition - Resource was not found`); + return retry(); + } + const isConditionMet = resourceConditionFunction(resource); if (!isConditionMet) { return retry(); } - } catch { + } catch (_) { console.error(`6 - waitForResourceToMeetCondition - Error: waiting for resource failed`); throw new Error(`6 - waitForResourceToMeetCondition - Error: waiting for resource failed`); } @@ -274,7 +325,7 @@ const checkAndClean = async (resourceName, numberOfRetries, timeoutBetweenRetrie const retry = async () => { if (count > 0) { count = count - 1; - console.log(`5 - checkAndClean - Waiting for resource: retry count = ${count}`); + console.debug(`5 - checkAndClean - Waiting for resource: retry count = ${count}`); await sleep(timeout); return check(); } else { @@ -283,26 +334,26 @@ const checkAndClean = async (resourceName, numberOfRetries, timeoutBetweenRetrie }; const check = async () => { - console.log(`1 - checkAndClean - Waiting for resource begin`); + console.debug(`1 - checkAndClean - Waiting for resource begin`); - try { - let resource; + let resource; - try { - resource = getResourceByName(resourceName, oc); - } catch { - console.log(`2 - checkAndClean - Resource was not found`); - return retry(); - } + try { + resource = getResourceByName(resourceName, oc); + } catch (_) { + console.debug(`2 - checkAndClean - Resource was not found`); + return retry(); + } + try { if (!resource) { - console.log(`3 - checkAndClean - Resource was not found`); + console.debug(`3 - checkAndClean - Resource was not found`); return retry(); } - console.log(`4 - checkAndClean - Deleting resource: ${resourceName}`); + console.debug(`4 - checkAndClean - Deleting resource: ${resourceName}`); deleteResourceByName(resourceName, oc); - } catch { + } catch (_) { console.error(`7 - checkAndClean - Error: waiting for resource failed`); throw new Error(`7 - checkAndClean - Error: waiting for resource failed`); } @@ -314,6 +365,7 @@ const checkAndClean = async (resourceName, numberOfRetries, timeoutBetweenRetrie }; module.exports = { + processOptions, checkAndClean, deleteResourceByName, getResourceByName, diff --git a/database/src/seeds/03_basic_project_survey_setup.ts b/database/src/seeds/03_basic_project_survey_setup.ts index 9518473569..79bc8fdeac 100644 --- a/database/src/seeds/03_basic_project_survey_setup.ts +++ b/database/src/seeds/03_basic_project_survey_setup.ts @@ -3,13 +3,13 @@ import { Knex } from 'knex'; const DB_SCHEMA = process.env.DB_SCHEMA; const DB_SCHEMA_DAPI_V1 = process.env.DB_SCHEMA_DAPI_V1; -const PROJECT_SEEDER_USER_IDENTIFIER = process.env.PROJECT_SEEDER_USER_IDENTIFIER; +const SEED_PROJECT_USER_IDENTIFIER = process.env.SEED_PROJECT_USER_IDENTIFIER; -const NUM_SEED_PROJECTS = Number(process.env.NUM_SEED_PROJECTS ?? 2); -const NUM_SEED_SURVEYS_PER_PROJECT = Number(process.env.NUM_SEED_SURVEYS_PER_PROJECT ?? 2); +const SEED_NUM_PROJECTS = Number(process.env.SEED_NUM_PROJECTS ?? 2); +const SEED_NUM_SURVEYS_PER_PROJECT = Number(process.env.SEED_NUM_SURVEYS_PER_PROJECT ?? 2); -const NUM_SEED_OBSERVATIONS_PER_SURVEY = Number(process.env.NUM_SEED_OBSERVATIONS_PER_SURVEY ?? 3); -const NUM_SEED_SUBCOUNTS_PER_OBSERVATION = Number(process.env.NUM_SEED_SUBCOUNTS_PER_OBSERVATION ?? 1); +const SEED_NUM_OBSERVATIONS_PER_SURVEY = Number(process.env.SEED_NUM_OBSERVATIONS_PER_SURVEY ?? 3); +const SEED_NUM_SUBCOUNTS_PER_OBSERVATION = Number(process.env.SEED_NUM_SUBCOUNTS_PER_OBSERVATION ?? 1); const focalTaxonIdOptions = [ { itis_tsn: 180703, itis_scientific_name: 'Alces alces' }, // Moose @@ -52,7 +52,7 @@ export async function seed(knex: Knex): Promise { const checkProjectsResponse = await knex.raw(checkAnyProjectExists()); if (!checkProjectsResponse.rows.length) { - for (let i = 0; i < NUM_SEED_PROJECTS; i++) { + for (let i = 0; i < SEED_NUM_PROJECTS; i++) { // Insert project data const createProjectResponse = await knex.raw(insertProjectData(`Seed Project ${i + 1}`)); const projectId = createProjectResponse.rows[0].project_id; @@ -65,7 +65,7 @@ export async function seed(knex: Knex): Promise { `); // Insert survey data - for (let j = 0; j < NUM_SEED_SURVEYS_PER_PROJECT; j++) { + for (let j = 0; j < SEED_NUM_SURVEYS_PER_PROJECT; j++) { const createSurveyResponse = await knex.raw(insertSurveyData(projectId, `Seed Survey ${j + 1}`)); const surveyId = createSurveyResponse.rows[0].survey_id; @@ -88,17 +88,17 @@ export async function seed(knex: Knex): Promise { ${insertSurveySamplePeriodData(surveyId)} `); - for (let k = 0; k < NUM_SEED_OBSERVATIONS_PER_SURVEY; k++) { + for (let k = 0; k < SEED_NUM_OBSERVATIONS_PER_SURVEY; k++) { const createObservationResponse = await knex.raw( // set the number of observations to minimum 20 times the number of subcounts (which are set to a number // between 1 and 20) to ensure the sum of all subcounts is at least <= the observation count (to avoid // constraint violations) insertSurveyObservationData( surveyId, - NUM_SEED_SUBCOUNTS_PER_OBSERVATION * 20 + faker.number.int({ min: 1, max: 20 }) + SEED_NUM_SUBCOUNTS_PER_OBSERVATION * 20 + faker.number.int({ min: 1, max: 20 }) ) ); - for (let l = 0; l < NUM_SEED_SUBCOUNTS_PER_OBSERVATION; l++) { + for (let l = 0; l < SEED_NUM_SUBCOUNTS_PER_OBSERVATION; l++) { await knex.raw(insertObservationSubCount(createObservationResponse.rows[0].survey_observation_id)); } } @@ -162,7 +162,7 @@ const insertSurveyParticipationData = (surveyId: number) => ` FROM system_user su WHERE - su.user_identifier = '${PROJECT_SEEDER_USER_IDENTIFIER}' + su.user_identifier = '${SEED_PROJECT_USER_IDENTIFIER}' ), 1) ), 1 @@ -414,7 +414,7 @@ const insertProjectParticipationData = (projectId: number) => ` FROM system_user su WHERE - su.user_identifier = '${PROJECT_SEEDER_USER_IDENTIFIER}' + su.user_identifier = '${SEED_PROJECT_USER_IDENTIFIER}' ), 1) ), (SELECT project_role_id FROM project_role WHERE name = 'Coordinator' LIMIT 1) diff --git a/docker-compose.yml b/docker-compose.yml index bbcc8c466c..1a2b12b646 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -53,11 +53,11 @@ services: - DB_DATABASE=${DB_DATABASE} - DB_SCHEMA=${DB_SCHEMA} # Seed - - PROJECT_SEEDER_USER_IDENTIFIER=${PROJECT_SEEDER_USER_IDENTIFIER} - - NUM_SEED_PROJECTS=${NUM_SEED_PROJECTS} - - NUM_SEED_SURVEYS_PER_PROJECT=${NUM_SEED_SURVEYS_PER_PROJECT} - - NUM_SEED_OBSERVATIONS_PER_SURVEY=${NUM_SEED_OBSERVATIONS_PER_SURVEY} - - NUM_SEED_SUBCOUNTS_PER_OBSERVATION=${NUM_SEED_SUBCOUNTS_PER_OBSERVATION} + - SEED_PROJECT_USER_IDENTIFIER=${SEED_PROJECT_USER_IDENTIFIER} + - SEED_NUM_PROJECTS=${SEED_NUM_PROJECTS} + - SEED_NUM_SURVEYS_PER_PROJECT=${SEED_NUM_SURVEYS_PER_PROJECT} + - SEED_NUM_OBSERVATIONS_PER_SURVEY=${SEED_NUM_OBSERVATIONS_PER_SURVEY} + - SEED_NUM_SUBCOUNTS_PER_OBSERVATION=${SEED_NUM_SUBCOUNTS_PER_OBSERVATION} # Keycloak - KEYCLOAK_HOST=${KEYCLOAK_HOST} - KEYCLOAK_REALM=${KEYCLOAK_REALM} @@ -181,11 +181,12 @@ services: - DB_USER_API=${DB_USER_API} - DB_USER_API_PASS=${DB_USER_API_PASS} - DB_SCHEMA_DAPI_V1=${DB_SCHEMA_DAPI_V1} - - PROJECT_SEEDER_USER_IDENTIFIER=${PROJECT_SEEDER_USER_IDENTIFIER} - - NUM_SEED_PROJECTS=${NUM_SEED_PROJECTS} - - NUM_SEED_SURVEYS_PER_PROJECT=${NUM_SEED_SURVEYS_PER_PROJECT} - - NUM_SEED_OBSERVATIONS_PER_SURVEY=${NUM_SEED_OBSERVATIONS_PER_SURVEY} - - NUM_SEED_SUBCOUNTS_PER_OBSERVATION=${NUM_SEED_SUBCOUNTS_PER_OBSERVATION} + # Seed + - SEED_PROJECT_USER_IDENTIFIER=${SEED_PROJECT_USER_IDENTIFIER} + - SEED_NUM_PROJECTS=${SEED_NUM_PROJECTS} + - SEED_NUM_SURVEYS_PER_PROJECT=${SEED_NUM_SURVEYS_PER_PROJECT} + - SEED_NUM_OBSERVATIONS_PER_SURVEY=${SEED_NUM_OBSERVATIONS_PER_SURVEY} + - SEED_NUM_SUBCOUNTS_PER_OBSERVATION=${SEED_NUM_SUBCOUNTS_PER_OBSERVATION} volumes: - /opt/app-root/src/node_modules # prevents local node_modules overriding container node_modules networks: diff --git a/env_config/env.docker b/env_config/env.docker index 4e31d0fa73..5da4ed84bd 100644 --- a/env_config/env.docker +++ b/env_config/env.docker @@ -197,16 +197,16 @@ GCNOTIFY_SMS_URL=https://api.notification.canada.ca/v2/notifications/sms # Project Seeder User Identifier - Sets the project participant for the deafult # project to match the given user identifier. If left blank, defaults to the # user with system user ID 1. -PROJECT_SEEDER_USER_IDENTIFIER= +SEED_PROJECT_USER_IDENTIFIER= # Sets the number of desired seed projects to generate. Defaults to 2. -NUM_SEED_PROJECTS=2 +SEED_NUM_PROJECTS=2 # Sets the number of desired seed surveys to generate per project. Defaults to 2. -NUM_SEED_SURVEYS_PER_PROJECT=2 +SEED_NUM_SURVEYS_PER_PROJECT=2 # Sets the number of desired seed observations to generate per survey. defaults to 3. -NUM_SEED_OBSERVATIONS_PER_SURVEY=3 +SEED_NUM_OBSERVATIONS_PER_SURVEY=3 # Sets the number of desired seed subcounts to generate per observation. defaults to 1. -NUM_SEED_SUBCOUNTS_PER_OBSERVATION=1 \ No newline at end of file +SEED_NUM_SUBCOUNTS_PER_OBSERVATION=1 \ No newline at end of file