diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 100% rename from .eslintrc.js rename to .eslintrc.cjs diff --git a/.github/workflows/create-github-release.yml b/.github/workflows/create-github-release.yml new file mode 100644 index 0000000000..64b25c37c6 --- /dev/null +++ b/.github/workflows/create-github-release.yml @@ -0,0 +1,30 @@ +name: create-github-release + +on: + push: + branches: + - main + - prerelease/** + tags-ignore: + - '*' + workflow_dispatch: + inputs: + prerelease: + type: string + description: 'Name to use for the prerelease: beta, dev, etc. NOTE: If this is already set in the package.json, it does not need to be passed in here.' + +jobs: + release: + uses: salesforcecli/github-workflows/.github/workflows/create-github-release.yml@main + secrets: inherit + with: + prerelease: ${{ inputs.prerelease }} + # If this is a push event, we want to skip the release if there are no semantic commits + # However, if this is a manual release (workflow_dispatch), then we want to disable skip-on-empty + # This helps recover from forgetting to add semantic commits ('fix:', 'feat:', etc.) + skip-on-empty: ${{ github.event_name == 'push' }} + docs: + needs: release + if: github.ref_name == 'main' + uses: salesforcecli/github-workflows/.github/workflows/publishTypedoc.yml@main + secrets: inherit diff --git a/.github/workflows/failureNotifications.yml b/.github/workflows/failureNotifications.yml index 3f7c0d4441..2fe2fb8e13 100644 --- a/.github/workflows/failureNotifications.yml +++ b/.github/workflows/failureNotifications.yml @@ -1,13 +1,10 @@ name: failureNotifications - on: workflow_run: workflows: - - version, tag and github release - publish types: - completed - jobs: failure-notify: runs-on: ubuntu-latest @@ -15,7 +12,7 @@ jobs: steps: - name: Announce Failure id: slack - uses: slackapi/slack-github-action@v1.21.0 + uses: slackapi/slack-github-action@v1.24.0 env: # for non-CLI-team-owned plugins, you can send this anywhere you like SLACK_WEBHOOK_URL: ${{ secrets.CLI_ALERTS_SLACK_WEBHOOK }} diff --git a/.github/workflows/manualRelease.yml b/.github/workflows/manualRelease.yml deleted file mode 100644 index 8ceb52c3c5..0000000000 --- a/.github/workflows/manualRelease.yml +++ /dev/null @@ -1,36 +0,0 @@ -name: manual release - -on: - workflow_dispatch: - -jobs: - release: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - with: - token: ${{ secrets.SVC_CLI_BOT_GITHUB_TOKEN }} - - name: Conventional Changelog Action - id: changelog - uses: TriPSs/conventional-changelog-action@d360fad3a42feca6462f72c97c165d60a02d4bf2 - # overriding some of the basic behaviors to just get the changelog - with: - git-user-name: svc-cli-bot - git-user-email: svc_cli_bot@salesforce.com - github-token: ${{ secrets.SVC_CLI_BOT_GITHUB_TOKEN }} - output-file: false - # always do the release, even if there are no semantic commits - skip-on-empty: false - tag-prefix: '' - - uses: notiz-dev/github-action-json-property@2192e246737701f108a4571462b76c75e7376216 - id: packageVersion - with: - path: 'package.json' - prop_path: 'version' - - name: Create Github Release - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.SVC_CLI_BOT_GITHUB_TOKEN }} - with: - tag_name: ${{ steps.packageVersion.outputs.prop }} - release_name: ${{ steps.packageVersion.outputs.prop }} diff --git a/.github/workflows/onPushToMain.yml b/.github/workflows/onPushToMain.yml deleted file mode 100644 index 24b2a8ef70..0000000000 --- a/.github/workflows/onPushToMain.yml +++ /dev/null @@ -1,18 +0,0 @@ -# test -name: version, tag and github release - -on: - push: - branches: [main] - -jobs: - release: - uses: salesforcecli/github-workflows/.github/workflows/githubRelease.yml@main - secrets: inherit - - # most repos won't use this - # depends on previous job to avoid git collisions, not for any functionality reason - docs: - uses: salesforcecli/github-workflows/.github/workflows/publishTypedoc.yml@main - secrets: inherit - needs: release diff --git a/.github/workflows/onRelease.yml b/.github/workflows/onRelease.yml index f09fde0564..db03117ac4 100644 --- a/.github/workflows/onRelease.yml +++ b/.github/workflows/onRelease.yml @@ -2,7 +2,7 @@ name: publish on: release: - types: [released] + types: [published] # support manual release in case something goes wrong and needs to be repeated or tested workflow_dispatch: inputs: @@ -11,10 +11,22 @@ on: type: string required: true jobs: + # parses the package.json version and detects prerelease tag (ex: beta from 4.4.4-beta.0) + getDistTag: + outputs: + tag: ${{ steps.distTag.outputs.tag }} + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + with: + ref: ${{ github.event.release.tag_name || inputs.tag }} + - uses: salesforcecli/github-workflows/.github/actions/getPreReleaseTag@main + id: distTag + npm: uses: salesforcecli/github-workflows/.github/workflows/npmPublish.yml@main + needs: [getDistTag] with: - tag: latest - ctc: true + tag: ${{ needs.getDistTag.outputs.tag || 'latest' }} githubTag: ${{ github.event.release.tag_name || inputs.tag }} secrets: inherit diff --git a/.github/workflows/perf.yml b/.github/workflows/perf.yml new file mode 100644 index 0000000000..f6f6ddf7ff --- /dev/null +++ b/.github/workflows/perf.yml @@ -0,0 +1,42 @@ +# runs some very-large-repo tests (for windows filesystem limits) and commits perf results for comparison +name: perf-tests +on: + push: + branches-ignore: [main, gh-pages] + workflow_dispatch: + +# linux will finish ahead of windows, but prevent other branches/commits from hitting simultaneously +# since we're pushing git commits and there would be conflicts +concurrency: perf-test + +jobs: + perf-tests: + strategy: + matrix: + os: [ubuntu-latest, windows-latest] + fail-fast: false + runs-on: ${{ matrix.os }} + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-node@v4 + with: + cache: yarn + - uses: salesforcecli/github-workflows/.github/actions/yarnInstallWithRetries@main + - run: yarn build + - run: npm run test:perf | tee test/perf/output.txt + + # Run `github-action-benchmark` action + - name: Store benchmark result + uses: benchmark-action/github-action-benchmark@5bbce78ef18edf5b96cb2d23e8d240b485f9dc4a + with: + name: Logger Benchmarks - ${{ matrix.os }} + tool: 'benchmarkjs' + output-file-path: test/perf/output.txt + comment-on-alert: true + # Push and deploy GitHub pages branch automatically + # this has a bug where it creates duplicate commits when summary-always and aut-push are both true + # summary-always: true + comment-always: true + benchmark-data-dir-path: perf-${{ runner.os}} + auto-push: true + github-token: ${{ secrets.SVC_CLI_BOT_GITHUB_TOKEN }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 02ffdde057..e9d02ccab7 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -14,7 +14,7 @@ jobs: windows-unit-tests: needs: linux-unit-tests uses: salesforcecli/github-workflows/.github/workflows/unitTestsWindows.yml@main - nuts: + xNuts: needs: linux-unit-tests uses: salesforcecli/github-workflows/.github/workflows/externalNut.yml@main strategy: @@ -22,40 +22,56 @@ jobs: matrix: os: ['ubuntu-latest', 'windows-latest'] externalProjectGitUrl: - - https://github.com/salesforcecli/plugin-config - - https://github.com/salesforcecli/plugin-alias + - https://github.com/salesforcecli/plugin-apex - https://github.com/salesforcecli/plugin-auth + - https://github.com/salesforcecli/plugin-community + - https://github.com/salesforcecli/plugin-custom-metadata + - https://github.com/salesforcecli/plugin-data - https://github.com/salesforcecli/plugin-limits - - https://github.com/salesforcecli/plugin-schema - - https://github.com/salesforcecli/plugin-env - https://github.com/salesforcecli/plugin-org - - https://github.com/salesforcecli/plugin-login + - https://github.com/salesforcecli/plugin-schema + - https://github.com/salesforcecli/plugin-settings + - https://github.com/salesforcecli/plugin-signups + - https://github.com/salesforcecli/plugin-templates + - https://github.com/salesforcecli/plugin-user with: packageName: '@salesforce/core' externalProjectGitUrl: ${{ matrix.externalProjectGitUrl }} command: 'yarn test:nuts' os: ${{ matrix.os }} useCache: false - postBuildCommands: 'shx rm -rf node_modules/jsforce/typings' - preExternalBuildCommands: 'shx rm -rf node_modules/@salesforce/sf-plugins-core/node_modules/@salesforce/core' + preSwapCommands: 'yarn upgrade jsforce@beta; npx yarn-deduplicate; yarn install' + preExternalBuildCommands: 'shx rm -rf node_modules/@salesforce/core/node_modules/jsforce shx rm -rf node_modules/@salesforce/sf-plugins-core/node_modules/@salesforce/core node_modules/@salesforce/cli-plugins-testkit/node_modules/@salesforce/core node_modules/@salesforce/source-tracking/node_modules/@salesforce/core node_modules/@salesforce/source-deploy-retrieve/node_modules/@salesforce/core node_modules/@salesforce/apex-node/node_modules/@salesforce/core' secrets: inherit # hidden until we fix source-testkit to better handle jwt - # deployRetrieveNuts: - # needs: unit-tests - # uses: salesforcecli/github-workflows/.github/workflows/externalNut.yml@main - # strategy: - # fail-fast: false - # matrix: - # os: ['windows-latest-16x', 'ubuntu-latest-16x'] - # command: - # - yarn test:nuts:deploy:metadata:manifest - # - yarn test:nuts:deploy:metadata:metadata - # - yarn test:nuts:deploy:metadata:source-dir - # - yarn test:nuts:deploy:metadata:test-level - # - yarn test:nuts:static - # with: - # packageName: '@salesforce/core' - # externalProjectGitUrl: 'https://github.com/salesforcecli/plugin-deploy-retrieve' - # command: ${{ matrix.command }} - # os: ${{ matrix.os }} - # secrets: inherit + pdrNuts: + needs: linux-unit-tests + uses: salesforcecli/github-workflows/.github/workflows/externalNut.yml@main + strategy: + fail-fast: false + matrix: + os: ['ubuntu-latest', 'windows-latest'] + command: + - 'yarn test:nuts:convert' + - 'yarn test:nuts:deb' + - 'yarn test:nuts:delete' + - 'yarn test:nuts:deploy:metadata:manifest' + - 'yarn test:nuts:deploy:metadata:metadata' + - 'yarn test:nuts:deploy:metadata:metadata-dir' + - 'yarn test:nuts:deploy:metadata:source-dir' + - 'yarn test:nuts:deploy:metadata:test-level' + - 'yarn test:nuts:destructive' + - 'yarn test:nuts:manifest' + - 'yarn test:nuts:retrieve' + - 'yarn test:nuts:specialTypes' + - 'yarn test:nuts:static' + - 'yarn test:nuts:tracking' + with: + packageName: '@salesforce/core' + externalProjectGitUrl: 'https://github.com/salesforcecli/plugin-deploy-retrieve' + preSwapCommands: 'yarn upgrade jsforce@beta; npx yarn-deduplicate; yarn install' + command: ${{ matrix.command }} + os: ${{ matrix.os }} + preExternalBuildCommands: 'shx rm -rf node_modules/@salesforce/core/node_modules/jsforce shx rm -rf node_modules/@salesforce/sf-plugins-core/node_modules/@salesforce/core node_modules/@salesforce/cli-plugins-testkit/node_modules/@salesforce/core node_modules/@salesforce/source-tracking/node_modules/@salesforce/core node_modules/@salesforce/source-deploy-retrieve/node_modules/@salesforce/core' + secrets: + TESTKIT_AUTH_URL: ${{ secrets.TESTKIT_AUTH_URL }} diff --git a/.mocharc.json b/.mocharc.json index 90d4ee892d..8bb562fc13 100644 --- a/.mocharc.json +++ b/.mocharc.json @@ -4,5 +4,5 @@ "watch-files": ["src", "test"], "recursive": true, "reporter": "spec", - "timeout": 10000 + "timeout": 20000 } diff --git a/.sfdevrc.json b/.sfdevrc.json index ac25b4a163..e5ff37e5b5 100644 --- a/.sfdevrc.json +++ b/.sfdevrc.json @@ -4,7 +4,7 @@ }, "wireit": { "compile": { - "command": "ttsc -p . --pretty --incremental", + "command": "tspc -p . --pretty --incremental", "files": ["src/**/*.ts", "tsconfig.json", "messages", "messageTransformer"], "output": ["lib/**", "*.tsbuildinfo"], "clean": "if-file-deleted" diff --git a/CHANGELOG.md b/CHANGELOG.md index c5c494f1b9..605aed1a89 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6767 +1,5180 @@ -## [3.34.6](https://github.com/forcedotcom/sfdx-core/compare/3.34.5...3.34.6) (2023-03-26) - +## [6.5.1](https://github.com/forcedotcom/sfdx-core/compare/6.5.0...6.5.1) (2024-01-24) ### Bug Fixes -* **deps:** bump @salesforce/schemas from 1.5.0 to 1.5.1 ([d447260](https://github.com/forcedotcom/sfdx-core/commit/d447260323d6b4e8cc556b4f0c9ef084c11b579f)) - - - -## [3.34.5](https://github.com/forcedotcom/sfdx-core/compare/3.34.4...3.34.5) (2023-03-26) +- correct typings for configStore `get` ([4dad8c7](https://github.com/forcedotcom/sfdx-core/commit/4dad8c75e38252d2ecafe1a4349cc5b0d19d68ac)) +# [6.5.0](https://github.com/forcedotcom/sfdx-core/compare/6.4.8-dev.0...6.5.0) (2024-01-22) ### Bug Fixes -* **deps:** bump json5 from 1.0.1 to 1.0.2 ([0dbbcf6](https://github.com/forcedotcom/sfdx-core/commit/0dbbcf61576512d527799240a50b311f723ab200)) +- emit warning if config var is unset ([fc32218](https://github.com/forcedotcom/sfdx-core/commit/fc3221886ed47d83999de102e7d76e82a29c0c0c)) +- properly handle undefined ([94fe825](https://github.com/forcedotcom/sfdx-core/commit/94fe825c8e4772bce6ed97f3ab6842e5011f7dd2)) +## [6.4.8-dev.0](https://github.com/forcedotcom/sfdx-core/compare/6.4.7...6.4.8-dev.0) (2024-01-17) +### Features -## [3.34.4](https://github.com/forcedotcom/sfdx-core/compare/3.34.3...3.34.4) (2023-03-22) +- **scratch:** add `org-capitalize-record-types` ([725bf67](https://github.com/forcedotcom/sfdx-core/commit/725bf67bf0c7b4ba274644581005ed921862da09)) +## [6.4.7](https://github.com/forcedotcom/sfdx-core/compare/6.4.6...6.4.7) (2024-01-10) ### Bug Fixes -* check resumable state before emitting first progress event ([#793](https://github.com/forcedotcom/sfdx-core/issues/793)) ([6677d0f](https://github.com/forcedotcom/sfdx-core/commit/6677d0f02e155e7d245701b7f73ee19dc8aa03be)) - - - -## [3.34.3](https://github.com/forcedotcom/sfdx-core/compare/3.34.2...3.34.3) (2023-03-20) +- **deps:** bump pino from 8.16.2 to 8.17.2 ([c63976b](https://github.com/forcedotcom/sfdx-core/commit/c63976ba14a575f631ffad219d2022e7374755e3)) +## [6.4.6](https://github.com/forcedotcom/sfdx-core/compare/6.4.5...6.4.6) (2024-01-09) ### Bug Fixes -* **deps:** bump graceful-fs from 4.2.10 to 4.2.11 ([8384d3f](https://github.com/forcedotcom/sfdx-core/commit/8384d3fcef55fc0ef609590364311c146f171d46)) +- address review comments ([ea7ad36](https://github.com/forcedotcom/sfdx-core/commit/ea7ad36c65231b9a289c19f5dd185ca5bcf9c735)) +- better header check ([ae4757f](https://github.com/forcedotcom/sfdx-core/commit/ae4757f99746866b6bf0e73c4d8f5e9ac8e418c0)) +- handle html server response ([90d025d](https://github.com/forcedotcom/sfdx-core/commit/90d025d07e749499206c96f2eabe2055899f38cb)) +## [6.4.5](https://github.com/forcedotcom/sfdx-core/compare/6.4.4...6.4.5) (2024-01-09) +### Bug Fixes -## [3.34.2](https://github.com/forcedotcom/sfdx-core/compare/3.34.1...3.34.2) (2023-03-19) +- ignore requests for site icons ([aeab4a9](https://github.com/forcedotcom/sfdx-core/commit/aeab4a9eb0c11b987d9d20e217726688fbc3fd9b)) +## [6.4.4](https://github.com/forcedotcom/sfdx-core/compare/6.4.3...6.4.4) (2024-01-04) ### Bug Fixes -* **deps:** bump jsforce from 2.0.0-beta.19 to 2.0.0-beta.20 ([9026092](https://github.com/forcedotcom/sfdx-core/commit/90260926103273ae5ffac382db38d6aea9e2bcc3)) +- remove slash char from error message ([1bb300b](https://github.com/forcedotcom/sfdx-core/commit/1bb300b2bb9f4990c6e19b9b8c33453416c24c95)) +## [6.4.3](https://github.com/forcedotcom/sfdx-core/compare/6.4.2...6.4.3) (2023-12-31) +### Bug Fixes -## [3.34.1](https://github.com/forcedotcom/sfdx-core/compare/3.34.0...3.34.1) (2023-03-16) +- **deps:** bump pino-pretty from 10.3.0 to 10.3.1 ([e68014a](https://github.com/forcedotcom/sfdx-core/commit/e68014a992b8a6b7c7b5ff5f35bc5a2e238d834c)) +## [6.4.2](https://github.com/forcedotcom/sfdx-core/compare/6.4.1...6.4.2) (2023-12-17) ### Bug Fixes -* allow completed status to be resume ([484244d](https://github.com/forcedotcom/sfdx-core/commit/484244d2877b6eec610975bd643fea2a368b5f5e)) +- **deps:** bump pino-pretty from 10.2.3 to 10.3.0 ([f7da5be](https://github.com/forcedotcom/sfdx-core/commit/f7da5be9a1384e56a60363ff04906fd7bd15de61)) +## [6.4.1](https://github.com/forcedotcom/sfdx-core/compare/6.4.0...6.4.1) (2023-12-12) +### Bug Fixes -# [3.34.0](https://github.com/forcedotcom/sfdx-core/compare/3.33.9...3.34.0) (2023-03-14) +- update max query limit env var ([7b42e94](https://github.com/forcedotcom/sfdx-core/commit/7b42e949a88885c9eea236d667e07aa10a411b49)) +# [6.4.0](https://github.com/forcedotcom/sfdx-core/compare/6.3.0...6.4.0) (2023-12-08) ### Features -* deprecate messages.load and docs ([3229f74](https://github.com/forcedotcom/sfdx-core/commit/3229f742f6ee2d99729e55abb8021cf5f3639b9f)) - - +- import messages with 2 fewer imports ([#1003](https://github.com/forcedotcom/sfdx-core/issues/1003)) ([8080fc9](https://github.com/forcedotcom/sfdx-core/commit/8080fc98de2630603422369efd3e3aca101d0087)) -## [3.33.9](https://github.com/forcedotcom/sfdx-core/compare/3.33.8...3.33.9) (2023-03-14) +# [6.3.0](https://github.com/forcedotcom/sfdx-core/compare/6.2.3-qa.1...6.3.0) (2023-12-05) +## [6.2.3-qa.1](https://github.com/forcedotcom/sfdx-core/compare/6.2.3-qa.0...6.2.3-qa.1) (2023-12-04) ### Bug Fixes -* save expiration date for scratch org ([#775](https://github.com/forcedotcom/sfdx-core/issues/775)) ([a59323b](https://github.com/forcedotcom/sfdx-core/commit/a59323be438e6fc8e021855af8ce6d09700c2e60)) +- backward logic on scratch/sbox ([98762d5](https://github.com/forcedotcom/sfdx-core/commit/98762d510ad9fab37ede32a0670bf85a9fe9ab8f)) +## [6.2.3-qa.0](https://github.com/forcedotcom/sfdx-core/compare/6.2.2...6.2.3-qa.0) (2023-12-04) +### Features -## [3.33.8](https://github.com/forcedotcom/sfdx-core/compare/3.33.7...3.33.8) (2023-03-14) +- return a value, use that instead of mutating state ([b311cb1](https://github.com/forcedotcom/sfdx-core/commit/b311cb1a9340e9494c8deff127900d04f921aab8)) +## [6.2.2-qa.0](https://github.com/forcedotcom/sfdx-core/compare/6.2.1...6.2.2-qa.0) (2023-11-27) ### Bug Fixes -* **deps:** bump json5 from 1.0.1 to 1.0.2 ([7ccd063](https://github.com/forcedotcom/sfdx-core/commit/7ccd0637048531d4669252a65e7c371b2e8c5f98)) - +- jsdoc error ([985c2f6](https://github.com/forcedotcom/sfdx-core/commit/985c2f6b8fa90ee5302ecb84a07df8c4e2f214a4)) +- only hit server for undefined values, not false ([c0f3845](https://github.com/forcedotcom/sfdx-core/commit/c0f3845de26400381ee953782444abfdbaa530b9)) +### Features -## [3.33.7](https://github.com/forcedotcom/sfdx-core/compare/3.33.6...3.33.7) (2023-03-13) +- set some known props during scratch org creation ([447b070](https://github.com/forcedotcom/sfdx-core/commit/447b070d02badbe488f20c961b8db79ac6e9aef9)) +## [6.2.2](https://github.com/forcedotcom/sfdx-core/compare/6.2.2-qa.0...6.2.2) (2023-11-28) ### Bug Fixes -* conf file stubs for read and readSync ([a4ceedc](https://github.com/forcedotcom/sfdx-core/commit/a4ceedc086bd293f10a30d2ac78b2f832acc0120)) +- bump jsforce ([#1001](https://github.com/forcedotcom/sfdx-core/issues/1001)) ([bc5a6f0](https://github.com/forcedotcom/sfdx-core/commit/bc5a6f08c25087fb8f63a49882ade9e1a7a63bbc)) +## [6.2.2-qa.0](https://github.com/forcedotcom/sfdx-core/compare/6.2.1...6.2.2-qa.0) (2023-11-27) +### Bug Fixes -## [3.33.6](https://github.com/forcedotcom/sfdx-core/compare/3.33.5...3.33.6) (2023-03-02) +- jsdoc error ([985c2f6](https://github.com/forcedotcom/sfdx-core/commit/985c2f6b8fa90ee5302ecb84a07df8c4e2f214a4)) +- only hit server for undefined values, not false ([c0f3845](https://github.com/forcedotcom/sfdx-core/commit/c0f3845de26400381ee953782444abfdbaa530b9)) +### Features + +- set some known props during scratch org creation ([447b070](https://github.com/forcedotcom/sfdx-core/commit/447b070d02badbe488f20c961b8db79ac6e9aef9)) + +## [6.2.1](https://github.com/forcedotcom/sfdx-core/compare/6.2.0...6.2.1) (2023-11-26) ### Bug Fixes -* check for resumable state for sandbox resume ([157622f](https://github.com/forcedotcom/sfdx-core/commit/157622f10c1d16c531d1576feb44a17eb1b04952)) +- **deps:** bump @types/semver from 7.5.5 to 7.5.6 ([c12440d](https://github.com/forcedotcom/sfdx-core/commit/c12440de94c8479f4a885157082ee28065e43cff)) +# [6.2.0](https://github.com/forcedotcom/sfdx-core/compare/6.1.4...6.2.0) (2023-11-21) +### Features -## [3.33.5](https://github.com/forcedotcom/sfdx-core/compare/3.33.4...3.33.5) (2023-02-26) +- generic type for sfError.data ([49beee5](https://github.com/forcedotcom/sfdx-core/commit/49beee53824a843a53e44e6b78f38b628b4eb0f8)) +## [6.1.4](https://github.com/forcedotcom/sfdx-core/compare/6.1.3...6.1.4) (2023-11-19) ### Bug Fixes -* **deps:** bump @salesforce/schemas from 1.4.0 to 1.5.0 ([f63c2f8](https://github.com/forcedotcom/sfdx-core/commit/f63c2f8135c27f794c5fce65be3dd5ea9e14f57f)) +- **deps:** bump pino from 8.16.1 to 8.16.2 ([44678d4](https://github.com/forcedotcom/sfdx-core/commit/44678d4b8a7d1c5d89c67070807c324165c267fb)) +## [6.1.3](https://github.com/forcedotcom/sfdx-core/compare/6.1.2...6.1.3) (2023-11-15) +### Bug Fixes -## [3.33.4](https://github.com/forcedotcom/sfdx-core/compare/3.33.3...3.33.4) (2023-02-22) +- no retries on sync lock ([b7f5588](https://github.com/forcedotcom/sfdx-core/commit/b7f55882d10bb69c945ebd0cb89bcc6f1d48b9da)) +## [6.1.2](https://github.com/forcedotcom/sfdx-core/compare/6.1.1...6.1.2) (2023-11-15) ### Bug Fixes -* **deps:** bump @types/graceful-fs from 4.1.5 to 4.1.6 ([d7500b9](https://github.com/forcedotcom/sfdx-core/commit/d7500b96caf2b13f8b0824c29721e639b0274165)) +- **types:** additional props for packaging lib ([25b3cf1](https://github.com/forcedotcom/sfdx-core/commit/25b3cf1b28d58bdaeebfef13d4463c33ed8a4b8a)) +## [6.1.1](https://github.com/forcedotcom/sfdx-core/compare/6.1.0...6.1.1) (2023-11-15) +### Bug Fixes -## [3.33.3](https://github.com/forcedotcom/sfdx-core/compare/3.33.2...3.33.3) (2023-02-22) +- write safety and valid typing for sfProject ([ff8b066](https://github.com/forcedotcom/sfdx-core/commit/ff8b06696f7ef88ac74a35f60e281b90eb74471b)) +# [6.1.0](https://github.com/forcedotcom/sfdx-core/compare/5.3.20...6.1.0) (2023-11-14) ### Bug Fixes -* correct timeout for deploy during scratch org creation ([364985d](https://github.com/forcedotcom/sfdx-core/commit/364985d849d29dc07f4c27c5e3e67e2f3b344ff6)) - +- permissionSet type changes ([7412d10](https://github.com/forcedotcom/sfdx-core/commit/7412d103703cfe2df2211546fcf2e6d93a689bc0)) +### Features -## [3.33.2](https://github.com/forcedotcom/sfdx-core/compare/3.33.1...3.33.2) (2023-02-21) +- remove sfdxConfig class ([80f21a3](https://github.com/forcedotcom/sfdx-core/commit/80f21a3a44e25443bd59259a80e69c23f6917986)) +- reusable file locks outside of ConfigFile ([29c59e0](https://github.com/forcedotcom/sfdx-core/commit/29c59e013f0cf25407430bd0d4752e4df8686ab5)) +- ts5 and ts-patch ([4e66905](https://github.com/forcedotcom/sfdx-core/commit/4e66905b9c0bd8997c2b995f11d3f36648ec15cb)) +### Performance Improvements -### Bug Fixes +- parallelize clear writes ([25a525a](https://github.com/forcedotcom/sfdx-core/commit/25a525ac62f26c2616d062dd3ddc08acee9ef20b)) -* improve error contents for device login ([#774](https://github.com/forcedotcom/sfdx-core/issues/774)) ([3ad803a](https://github.com/forcedotcom/sfdx-core/commit/3ad803ad4d4b0ff473c04a8dd727c65546bfa86e)) +# [5.4.0-crdt.1](https://github.com/forcedotcom/sfdx-core/compare/6.0.1-crdt.0...5.4.0-crdt.1) (2023-10-13) +## [6.0.1-crdt.0](https://github.com/forcedotcom/sfdx-core/compare/5.3.9...6.0.1-crdt.0) (2023-10-13) +### Features -## [3.33.1](https://github.com/forcedotcom/sfdx-core/compare/3.33.0...3.33.1) (2023-01-23) +- configFile file locks and write-via-merge ([91316a7](https://github.com/forcedotcom/sfdx-core/commit/91316a7d8478810a07b8948e3de179e2e0abfb3f)) +- typing for what goes in the org-user file ([bde5005](https://github.com/forcedotcom/sfdx-core/commit/bde5005c9d688e179c55fa8a5a94de0611321571)) +- **wip:** crdt-configfile ([bad6dfb](https://github.com/forcedotcom/sfdx-core/commit/bad6dfbbb9bab8d0b3466f8f2d069e132fb871c9)) +## [5.3.20](https://github.com/forcedotcom/sfdx-core/compare/5.3.19...5.3.20) (2023-11-10) ### Bug Fixes -* remove source tracking files with Org.delete() ([a85c5bf](https://github.com/forcedotcom/sfdx-core/commit/a85c5bf4dc2312e6be689f70e3b2e74f61cfbfc4)) +- http 420 errors ([6deabcd](https://github.com/forcedotcom/sfdx-core/commit/6deabcd603055786311994cb25c8c9282ff9971d)) +## [5.3.19](https://github.com/forcedotcom/sfdx-core/compare/5.3.18...5.3.19) (2023-11-08) +### Bug Fixes -# [3.33.0](https://github.com/forcedotcom/sfdx-core/compare/3.32.14...3.33.0) (2023-01-19) +- use memory logger instance when disabled ([c2ef3a0](https://github.com/forcedotcom/sfdx-core/commit/c2ef3a0f8fea0518b5eec2f6f515064e9741b46e)) +## [5.3.18](https://github.com/forcedotcom/sfdx-core/compare/5.3.17...5.3.18) (2023-11-05) -### Features +### Bug Fixes -* backward compatible messages.createError ([ac564b9](https://github.com/forcedotcom/sfdx-core/commit/ac564b927bd0c85c874cda39641afb9d9206e268)) +- **deps:** bump @types/semver from 7.5.3 to 7.5.4 ([a3be392](https://github.com/forcedotcom/sfdx-core/commit/a3be3922f96f8420eb871c413858eac395a95ad3)) +## [5.3.17](https://github.com/forcedotcom/sfdx-core/compare/5.3.16...5.3.17) (2023-11-02) +### Bug Fixes -## [3.32.14](https://github.com/forcedotcom/sfdx-core/compare/3.32.13...3.32.14) (2023-01-18) +- **deps:** testSetup has non ts-sinon dependency ([9fcb206](https://github.com/forcedotcom/sfdx-core/commit/9fcb206220174af1c20fcc041e127409a41c3593)) +## [5.3.16](https://github.com/forcedotcom/sfdx-core/compare/5.3.15...5.3.16) (2023-10-29) ### Bug Fixes -* snapshot is optional ([e81684c](https://github.com/forcedotcom/sfdx-core/commit/e81684cbe78c22e63b5c191264d26cef70c6c2f8)) +- **deps:** bump @salesforce/kit from 3.0.14 to 3.0.15 ([6189030](https://github.com/forcedotcom/sfdx-core/commit/61890307e557962cc44e02d542c276c56a9329f7)) +## [5.3.15](https://github.com/forcedotcom/sfdx-core/compare/5.3.14...5.3.15) (2023-10-29) +### Bug Fixes -## [3.32.13](https://github.com/forcedotcom/sfdx-core/compare/3.32.12...3.32.13) (2023-01-12) +- **deps:** bump @salesforce/ts-types from 2.0.8 to 2.0.9 ([80dea3d](https://github.com/forcedotcom/sfdx-core/commit/80dea3dd60e36be37852177b11f4db18e9a8653a)) +## [5.3.14](https://github.com/forcedotcom/sfdx-core/compare/5.3.13...5.3.14) (2023-10-26) ### Bug Fixes -* **deps:** bump @salesforce/ts-types from 1.7.1 to 1.7.2 ([cadc91f](https://github.com/forcedotcom/sfdx-core/commit/cadc91fd5d0ced7cf15fed9ddeda1eea63f20f5b)) +- add scopeProfiles to project type ([b130982](https://github.com/forcedotcom/sfdx-core/commit/b1309829cbcc8511e60cb6c88a5721edb3c060dd)) +- update schemas dep ([3f70e8f](https://github.com/forcedotcom/sfdx-core/commit/3f70e8fcc64aff0a0a10a864f32aa6325a2ba144)) +## [5.3.13](https://github.com/forcedotcom/sfdx-core/compare/5.3.12...5.3.13) (2023-10-26) +### Bug Fixes -## [3.32.12](https://github.com/forcedotcom/sfdx-core/compare/3.32.11...3.32.12) (2022-12-23) +- handle alias file with no `orgs` prop ([c59c7c7](https://github.com/forcedotcom/sfdx-core/commit/c59c7c7387f159537b9d352057299842f864b864)) +## [5.3.12](https://github.com/forcedotcom/sfdx-core/compare/5.3.11...5.3.12) (2023-10-24) ### Bug Fixes -* **deps:** bump jsonwebtoken from 8.5.1 to 9.0.0 ([c40ea0a](https://github.com/forcedotcom/sfdx-core/commit/c40ea0aa3025045488c542bd35684ae7f296b5f5)) +- **deps:** bump pino from 8.15.6 to 8.16.0 ([7e05681](https://github.com/forcedotcom/sfdx-core/commit/7e0568183015151e649883ebcf581be298f792b3)) +## [5.3.11](https://github.com/forcedotcom/sfdx-core/compare/5.3.10...5.3.11) (2023-10-22) +### Bug Fixes -## [3.32.11](https://github.com/forcedotcom/sfdx-core/compare/3.32.10...3.32.11) (2022-12-16) +- **deps:** bump @salesforce/kit from 3.0.13 to 3.0.14 ([9e366de](https://github.com/forcedotcom/sfdx-core/commit/9e366de1c4d674ae9cc83f5f0cff6859edd18974)) +## [5.3.10](https://github.com/forcedotcom/sfdx-core/compare/5.4.0-crdt.1...5.3.10) (2023-10-20) ### Bug Fixes -* add password to mock org getConfig ([#729](https://github.com/forcedotcom/sfdx-core/issues/729)) ([00ee0fc](https://github.com/forcedotcom/sfdx-core/commit/00ee0fc940592cc04bc5b3ad6e609a3d5e6c2582)) +- bump jsforce ([#958](https://github.com/forcedotcom/sfdx-core/issues/958)) ([98a6fef](https://github.com/forcedotcom/sfdx-core/commit/98a6fef4b21320b57f2e0730f94918cdb590953c)) +# [5.4.0-crdt.1](https://github.com/forcedotcom/sfdx-core/compare/6.0.1-crdt.0...5.4.0-crdt.1) (2023-10-13) +## [6.0.1-crdt.0](https://github.com/forcedotcom/sfdx-core/compare/5.3.9...6.0.1-crdt.0) (2023-10-13) -## [3.32.10](https://github.com/forcedotcom/sfdx-core/compare/3.32.9...3.32.10) (2022-12-15) +### Features +- configFile file locks and write-via-merge ([91316a7](https://github.com/forcedotcom/sfdx-core/commit/91316a7d8478810a07b8948e3de179e2e0abfb3f)) +- typing for what goes in the org-user file ([bde5005](https://github.com/forcedotcom/sfdx-core/commit/bde5005c9d688e179c55fa8a5a94de0611321571)) +- **wip:** crdt-configfile ([bad6dfb](https://github.com/forcedotcom/sfdx-core/commit/bad6dfbbb9bab8d0b3466f8f2d069e132fb871c9)) + +## [5.3.9](https://github.com/forcedotcom/sfdx-core/compare/5.3.8...5.3.9) (2023-10-09) ### Bug Fixes -* provide way to stub user data ([#728](https://github.com/forcedotcom/sfdx-core/issues/728)) ([98b2503](https://github.com/forcedotcom/sfdx-core/commit/98b25035043676a745692181e4cf0f1c889ea9d0)) +- **deps:** bump @salesforce/kit from 3.0.12 to 3.0.13 ([08fb56b](https://github.com/forcedotcom/sfdx-core/commit/08fb56b1a14385168adba81bc44d67fc987040e6)) +## [5.3.8](https://github.com/forcedotcom/sfdx-core/compare/5.3.7...5.3.8) (2023-10-08) +### Bug Fixes -## [3.32.9](https://github.com/forcedotcom/sfdx-core/compare/3.32.8...3.32.9) (2022-12-08) +- **deps:** bump pino from 8.15.1 to 8.15.6 ([2a5a9cc](https://github.com/forcedotcom/sfdx-core/commit/2a5a9cc69e6616ed6b4338c3ce26e5c5dbd9abab)) +## [5.3.7](https://github.com/forcedotcom/sfdx-core/compare/5.3.6...5.3.7) (2023-10-08) ### Bug Fixes -* add password property to ([1995c01](https://github.com/forcedotcom/sfdx-core/commit/1995c010d13967a49cd4e460cf7acf27eb4327f7)) +- **deps:** bump @types/semver from 7.5.2 to 7.5.3 ([9e8a0a7](https://github.com/forcedotcom/sfdx-core/commit/9e8a0a7e53d8b5900baf00e01548ea81c1ecfd4e)) +## [5.3.6](https://github.com/forcedotcom/sfdx-core/compare/5.3.5...5.3.6) (2023-10-08) +### Bug Fixes -## [3.32.8](https://github.com/forcedotcom/sfdx-core/compare/3.32.7...3.32.8) (2022-12-04) +- **deps:** bump pino-pretty from 10.2.0 to 10.2.3 ([9e925c5](https://github.com/forcedotcom/sfdx-core/commit/9e925c599cbb7f5826ac6a0afe6043f6465e7dcf)) +## [5.3.5](https://github.com/forcedotcom/sfdx-core/compare/5.3.4...5.3.5) (2023-10-06) ### Bug Fixes -* **deps:** bump ajv from 8.11.0 to 8.11.2 ([78eb48d](https://github.com/forcedotcom/sfdx-core/commit/78eb48d394a63fb21655d8c84de64e2ea8efa987)) +- allow padding on id and secret ([b93ac50](https://github.com/forcedotcom/sfdx-core/commit/b93ac504d09145dad3d5b5beea4ce1d5a56985cd)) +## [5.3.4](https://github.com/forcedotcom/sfdx-core/compare/5.3.3...5.3.4) (2023-10-04) +### Bug Fixes -## [3.32.7](https://github.com/forcedotcom/sfdx-core/compare/3.32.6...3.32.7) (2022-12-04) +- handle multiple sandbox processes in resumable state ([#944](https://github.com/forcedotcom/sfdx-core/issues/944)) ([a49409d](https://github.com/forcedotcom/sfdx-core/commit/a49409d05ce7edbea861eaa0de91c2c9d8a70ddd)) +## [5.3.3](https://github.com/forcedotcom/sfdx-core/compare/5.3.2...5.3.3) (2023-10-01) ### Bug Fixes -* **deps:** bump decode-uri-component from 0.2.0 to 0.2.2 ([bb4c0d1](https://github.com/forcedotcom/sfdx-core/commit/bb4c0d1b6d0ca3dcc07532a728ef1a27b019d256)) +- **deps:** bump @salesforce/ts-types from 2.0.7 to 2.0.8 ([d3e22b9](https://github.com/forcedotcom/sfdx-core/commit/d3e22b9420beae576ca085fd4827c169f8b54535)) +## [5.3.2](https://github.com/forcedotcom/sfdx-core/compare/5.3.1...5.3.2) (2023-10-01) +### Bug Fixes -## [3.32.6](https://github.com/forcedotcom/sfdx-core/compare/3.32.5...3.32.6) (2022-12-01) +- **deps:** bump @salesforce/kit from 3.0.11 to 3.0.12 ([b738085](https://github.com/forcedotcom/sfdx-core/commit/b738085f2266801fbc94241824ebfe899ba80fd6)) +## [5.3.1](https://github.com/forcedotcom/sfdx-core/compare/5.3.0...5.3.1) (2023-09-28) ### Bug Fixes -* remove refs to legacy client id ([82689ea](https://github.com/forcedotcom/sfdx-core/commit/82689ea5257b95a94d91326200293c6eb464287f)) +- **deps:** bump get-func-name from 2.0.0 to 2.0.2 ([19aeb98](https://github.com/forcedotcom/sfdx-core/commit/19aeb98c16297da433f3227e413fe92833929108)) +# [5.3.0](https://github.com/forcedotcom/sfdx-core/compare/5.2.10...5.3.0) (2023-09-27) +### Features -## [3.32.5](https://github.com/forcedotcom/sfdx-core/compare/3.32.4...3.32.5) (2022-11-30) +- unique listener names for lifecycle events ([#941](https://github.com/forcedotcom/sfdx-core/issues/941)) ([c5d60ae](https://github.com/forcedotcom/sfdx-core/commit/c5d60ae62e4bbcacdd3a496d17fbd3ce0cfbafba)) +## [5.2.10](https://github.com/forcedotcom/sfdx-core/compare/5.2.9...5.2.10) (2023-09-17) ### Bug Fixes -* update a few tests ([6952b44](https://github.com/forcedotcom/sfdx-core/commit/6952b4429bf7adf4ed4c5c0c9681ab04986f7720)) -* use API version cache more often ([36b0e81](https://github.com/forcedotcom/sfdx-core/commit/36b0e81abecd75ef8d69543470a0b1ad36f14a03)) +- **deps:** bump @types/semver from 7.5.1 to 7.5.2 ([3994b3b](https://github.com/forcedotcom/sfdx-core/commit/3994b3b4d4234a7ed5d79e355a018d4d9249480c)) +## [5.2.9](https://github.com/forcedotcom/sfdx-core/compare/5.2.8...5.2.9) (2023-09-10) +### Bug Fixes -## [3.32.4](https://github.com/forcedotcom/sfdx-core/compare/3.32.3...3.32.4) (2022-11-27) +- **deps:** bump pino from 8.15.0 to 8.15.1 ([617c440](https://github.com/forcedotcom/sfdx-core/commit/617c44030a320575f87ed14c23de2a45544a8441)) +## [5.2.8](https://github.com/forcedotcom/sfdx-core/compare/5.2.7...5.2.8) (2023-09-10) ### Bug Fixes -* **deps:** bump @types/semver from 7.3.10 to 7.3.13 ([0584bf6](https://github.com/forcedotcom/sfdx-core/commit/0584bf642f1d01508594d16fd5391d7419f243f4)) +- **deps:** bump @types/semver from 7.5.0 to 7.5.1 ([90e2870](https://github.com/forcedotcom/sfdx-core/commit/90e2870fc911c495176a917007dacd9bbf64a91c)) +## [5.2.7](https://github.com/forcedotcom/sfdx-core/compare/5.2.6...5.2.7) (2023-09-04) +### Bug Fixes -## [3.32.3](https://github.com/forcedotcom/sfdx-core/compare/3.32.2...3.32.3) (2022-11-27) +- **deps:** bump ts-retry-promise from 0.7.0 to 0.7.1 ([d71420a](https://github.com/forcedotcom/sfdx-core/commit/d71420a7360e81c8c561e07becbb085ddaf5f6ce)) +## [5.2.6](https://github.com/forcedotcom/sfdx-core/compare/5.2.5...5.2.6) (2023-09-03) ### Bug Fixes -* **deps:** bump @salesforce/schemas from 1.1.3 to 1.4.0 ([9b0f2a9](https://github.com/forcedotcom/sfdx-core/commit/9b0f2a977868b40bc6c113ee2bff178c3ac3ceec)) +- **deps:** bump jsonwebtoken from 9.0.1 to 9.0.2 ([8323f3c](https://github.com/forcedotcom/sfdx-core/commit/8323f3cd253527210050b87b9936fb210ea74974)) +## [5.2.5](https://github.com/forcedotcom/sfdx-core/compare/5.2.4...5.2.5) (2023-09-01) +### Bug Fixes -## [3.32.2](https://github.com/forcedotcom/sfdx-core/compare/3.32.1...3.32.2) (2022-11-22) +- **deps:** bump pino from 8.14.2 to 8.15.0 ([e6770e6](https://github.com/forcedotcom/sfdx-core/commit/e6770e694024adee8b844bf47385f55a4d298efe)) +## [5.2.4](https://github.com/forcedotcom/sfdx-core/compare/5.2.3...5.2.4) (2023-08-31) ### Bug Fixes -* pass value to message correctly ([c21f088](https://github.com/forcedotcom/sfdx-core/commit/c21f0881a13f8d16ef5a02c5bdec1e9612d8acc8)) +- **perf:** perf tweaks, semver is a dep ([#918](https://github.com/forcedotcom/sfdx-core/issues/918)) ([5636083](https://github.com/forcedotcom/sfdx-core/commit/563608375fa23d1831673503bee501e487a8b1e4)) +## [5.2.3](https://github.com/forcedotcom/sfdx-core/compare/5.2.2...5.2.3) (2023-08-27) +### Bug Fixes -## [3.32.1](https://github.com/forcedotcom/sfdx-core/compare/3.32.0...3.32.1) (2022-11-17) +- **deps:** bump @salesforce/kit from 3.0.9 to 3.0.11 ([8bad544](https://github.com/forcedotcom/sfdx-core/commit/8bad544318f9999c4b73ac58ecfc976180c769b0)) +## [5.2.2](https://github.com/forcedotcom/sfdx-core/compare/5.2.1...5.2.2) (2023-08-27) ### Bug Fixes -* **deps:** bump @salesforce/kit from 1.7.0 to 1.8.0 ([8e065a7](https://github.com/forcedotcom/sfdx-core/commit/8e065a76bbfb6182d2851ed51b18630bdcc097dc)) +- **deps:** bump @salesforce/ts-types from 2.0.6 to 2.0.7 ([ee069f4](https://github.com/forcedotcom/sfdx-core/commit/ee069f4bfe8339779bc03f9c961d56cc45bc7a45)) +## [5.2.1](https://github.com/forcedotcom/sfdx-core/compare/5.2.0...5.2.1) (2023-08-13) +### Bug Fixes -# [3.32.0](https://github.com/forcedotcom/sfdx-core/compare/3.31.19...3.32.0) (2022-11-17) +- **deps:** bump @salesforce/kit from 3.0.6 to 3.0.9 ([a9d45eb](https://github.com/forcedotcom/sfdx-core/commit/a9d45eb7ac4f116464f2852cd4cce889d07e9228)) +# [5.2.0](https://github.com/forcedotcom/sfdx-core/compare/5.1.6...5.2.0) (2023-08-03) ### Features -* getConnection accepts an optional version ([c4299f8](https://github.com/forcedotcom/sfdx-core/commit/c4299f88acf2c45979c13ca8d093919308619c99)) -* log when unnecessarily setting api version ([9e4afd2](https://github.com/forcedotcom/sfdx-core/commit/9e4afd2c573219eea43e2e43d5f3ca5822d936b3)) - - - -## [3.31.19](https://github.com/forcedotcom/sfdx-core/compare/3.31.18...3.31.19) (2022-11-12) +- save namespacePrefix in auth file ([8d2dd7e](https://github.com/forcedotcom/sfdx-core/commit/8d2dd7ea9a5752a2ad9df3c2b5233476119db1b2)) +## [5.1.6](https://github.com/forcedotcom/sfdx-core/compare/5.1.5...5.1.6) (2023-08-03) ### Bug Fixes -* ajv allows union type schema, sfProject doesn't validate ([#698](https://github.com/forcedotcom/sfdx-core/issues/698)) ([ca726ae](https://github.com/forcedotcom/sfdx-core/commit/ca726ae1cb6313f7eaf179517552f15b769a5b74)) +- use debug levels that are numbers from the env ([f051963](https://github.com/forcedotcom/sfdx-core/commit/f051963272c91ace99e948ba36de8f7e29952796)) +## [5.1.5](https://github.com/forcedotcom/sfdx-core/compare/5.1.4...5.1.5) (2023-08-02) +### Bug Fixes -## [3.31.18](https://github.com/forcedotcom/sfdx-core/compare/3.31.17...3.31.18) (2022-11-07) +- better type for SandboxFields ([9bf4154](https://github.com/forcedotcom/sfdx-core/commit/9bf4154216dc0bd07438f8be34a3902fa0e64d8f)) +- check devhubs and non-scratch orgs and sandboxes ([57c0bae](https://github.com/forcedotcom/sfdx-core/commit/57c0bae9098f5d750a8ee4d90bc8bfa30a88f38b)) +- identify sandboxes during authentication ([a79117e](https://github.com/forcedotcom/sfdx-core/commit/a79117e2b83ef934addfd06ba74c06e32d66d056)) +- query devhubs, non-scratch orgs, and non-sandboxes to identify sandboxes ([26d923e](https://github.com/forcedotcom/sfdx-core/commit/26d923e5ec34efd9236675ef8c0290341da48c40)) +## [5.1.4](https://github.com/forcedotcom/sfdx-core/compare/5.1.3...5.1.4) (2023-07-31) ### Bug Fixes -* deduplicate headers case on Connect.request ([#697](https://github.com/forcedotcom/sfdx-core/issues/697)) ([fc592b2](https://github.com/forcedotcom/sfdx-core/commit/fc592b215bcc9184f3ca8003d382b6053447349b)) +- **deps:** bump pino-pretty from 10.0.0 to 10.2.0 ([0b66a21](https://github.com/forcedotcom/sfdx-core/commit/0b66a21da0fe3a0f7c76b39a96c3a525ab654659)) +## [5.1.3](https://github.com/forcedotcom/sfdx-core/compare/5.1.2...5.1.3) (2023-07-30) +### Bug Fixes -## [3.31.17](https://github.com/forcedotcom/sfdx-core/compare/3.31.16...3.31.17) (2022-10-24) +- **deps:** bump pino from 8.14.1 to 8.14.2 ([461f8e4](https://github.com/forcedotcom/sfdx-core/commit/461f8e45fb879e59becb69548a0539e7931764a9)) +## [5.1.2](https://github.com/forcedotcom/sfdx-core/compare/5.1.1...5.1.2) (2023-07-28) ### Bug Fixes -* improve `hubOrgIsNotDevHub` error msg ([#689](https://github.com/forcedotcom/sfdx-core/issues/689)) ([d3787fa](https://github.com/forcedotcom/sfdx-core/commit/d3787faf8c8aea75624b8a1b140384e1e567f1bc)) - +- **deps:** bump @salesforce/kit from 3.0.4 to 3.0.6 ([ecb5525](https://github.com/forcedotcom/sfdx-core/commit/ecb5525e5661571b36545d22d02e404a2deecda5)) +## [5.1.1](https://github.com/forcedotcom/sfdx-core/compare/5.1.0...5.1.1) (2023-07-28) -## [3.31.16](https://github.com/forcedotcom/sfdx-core/compare/3.31.15...3.31.16) (2022-10-19) +### Bug Fixes +- **deps:** bump @salesforce/ts-types from 2.0.4 to 2.0.5 ([0b13602](https://github.com/forcedotcom/sfdx-core/commit/0b136024d90e7a361c87f35039d4869255ca2e39)) +# [5.1.0](https://github.com/forcedotcom/sfdx-core/compare/5.0.1-v5-beta.1...5.1.0) (2023-07-27) -## [3.31.15](https://github.com/forcedotcom/sfdx-core/compare/3.31.13-0...3.31.15) (2022-10-19) +## [5.0.1-v5-beta.1](https://github.com/forcedotcom/sfdx-core/compare/5.0.1-v5-beta.0...5.0.1-v5-beta.1) (2023-07-24) +## [5.0.1-v5-beta.0](https://github.com/forcedotcom/sfdx-core/compare/4.3.11...5.0.1-v5-beta.0) (2023-07-20) ### Bug Fixes -* remove prerelease portion of version number ([6dffeac](https://github.com/forcedotcom/sfdx-core/commit/6dffeacd0f12c24b32b3e9de13011c8a1cd22c0b)) - +- bump jsforce ([1f52733](https://github.com/forcedotcom/sfdx-core/commit/1f527330f060ea47044c8245b62f5bdd08c65dae)) +### Features -## [3.31.13-0](https://github.com/forcedotcom/sfdx-core/compare/3.31.12...3.31.13-0) (2022-10-18) +- clean up week+ old log files ([2af0bb9](https://github.com/forcedotcom/sfdx-core/commit/2af0bb928c5bfc10e136ae694b11a9d54f2b2544)) +- parameterize log cleanup for test use ([b927164](https://github.com/forcedotcom/sfdx-core/commit/b92716483eae0a2b9494605d82cce083e8d762b5)) +- pino logger ([7b6565b](https://github.com/forcedotcom/sfdx-core/commit/7b6565b2f36322be85e6c9ff3dbb51844279c8f5)) +## [4.3.11](https://github.com/forcedotcom/sfdx-core/compare/4.3.10...4.3.11) (2023-07-16) ### Bug Fixes -* reset SFDX_INTEROPERABILITY on contextRestore ([#673](https://github.com/forcedotcom/sfdx-core/issues/673)) ([4c8ecae](https://github.com/forcedotcom/sfdx-core/commit/4c8ecae69f871309b00f69a68228e3833923eee9)) +- **deps:** bump jsonwebtoken from 9.0.0 to 9.0.1 ([ae66699](https://github.com/forcedotcom/sfdx-core/commit/ae66699c99012999db0edd85384237ba7405b7bf)) +## [4.3.10](https://github.com/forcedotcom/sfdx-core/compare/4.3.9...4.3.10) (2023-07-11) +### Bug Fixes -## [3.31.12](https://github.com/forcedotcom/sfdx-core/compare/3.31.11...3.31.12) (2022-10-18) +- **deps:** bump semver from 5.7.1 to 5.7.2 ([eef3f68](https://github.com/forcedotcom/sfdx-core/commit/eef3f68337ff0b087072e4e911f309eefe60efb4)) +## [4.3.9](https://github.com/forcedotcom/sfdx-core/compare/4.3.8...4.3.9) (2023-07-10) ### Bug Fixes -* incorrect url for scratch org error codes documentation ([#681](https://github.com/forcedotcom/sfdx-core/issues/681)) ([ab91644](https://github.com/forcedotcom/sfdx-core/commit/ab91644820e031a28f6fb262e0f7826e8419e5d7)) +- **deps:** bump @salesforce/schemas from 1.5.1 to 1.6.0 ([2be2263](https://github.com/forcedotcom/sfdx-core/commit/2be226386f14a3b3ffa1a4d6483d2db3d032c3f1)) +## [4.3.8](https://github.com/forcedotcom/sfdx-core/compare/4.3.7...4.3.8) (2023-07-09) +### Bug Fixes -## [3.31.11](https://github.com/forcedotcom/sfdx-core/compare/3.31.10...3.31.11) (2022-10-18) +- **deps:** bump @salesforce/kit from 3.0.3 to 3.0.4 ([a88baa7](https://github.com/forcedotcom/sfdx-core/commit/a88baa79116250d3e75aca3c9cd2958619cfe154)) +## [4.3.7](https://github.com/forcedotcom/sfdx-core/compare/4.3.6...4.3.7) (2023-07-08) ### Bug Fixes -* function addLogFileStreamSync to use recursive mkdir ([#683](https://github.com/forcedotcom/sfdx-core/issues/683)) ([c85c69c](https://github.com/forcedotcom/sfdx-core/commit/c85c69c4179b2b06e4b2e6cbe5727d2a98918304)) +- **deps:** bump tough-cookie from 4.0.0 to 4.1.3 ([230c975](https://github.com/forcedotcom/sfdx-core/commit/230c975c5b024ea64196400752c76750dae20669)) +## [4.3.6](https://github.com/forcedotcom/sfdx-core/compare/4.3.5...4.3.6) (2023-07-06) +### Bug Fixes -## [3.31.10](https://github.com/forcedotcom/sfdx-core/compare/3.31.9...3.31.10) (2022-10-14) +- query scratch orgs by provided Id ([cbfc47a](https://github.com/forcedotcom/sfdx-core/commit/cbfc47a66975a482cc51af2f1528142775aca3be)) +## [4.3.5](https://github.com/forcedotcom/sfdx-core/compare/4.3.4...4.3.5) (2023-06-29) ### Bug Fixes -* getPackageFromPath now handles nested package paths ([#678](https://github.com/forcedotcom/sfdx-core/issues/678)) ([d8c43c6](https://github.com/forcedotcom/sfdx-core/commit/d8c43c66ec4ea58e0398009083740fab0bac1439)) +- unset aliases and configs when org is deleted ([a06ce1f](https://github.com/forcedotcom/sfdx-core/commit/a06ce1f7c500313f1f317ec68bb5c98f5aef1728)) +## [4.3.4](https://github.com/forcedotcom/sfdx-core/compare/4.3.3...4.3.4) (2023-06-28) +### Bug Fixes -## [3.31.9](https://github.com/forcedotcom/sfdx-core/compare/3.31.8...3.31.9) (2022-10-13) +- **deps:** bump jsforce from 2.0.0-beta.24 to 2.0.0-beta.27 ([a0aa6c1](https://github.com/forcedotcom/sfdx-core/commit/a0aa6c1d74a8dcc4b3bc62927d1663132971d961)) +## [4.3.3](https://github.com/forcedotcom/sfdx-core/compare/4.3.2...4.3.3) (2023-06-26) ### Bug Fixes -* ensure the hubOrg passes is actually a DevHub, throw error if not ([#669](https://github.com/forcedotcom/sfdx-core/issues/669)) ([753292f](https://github.com/forcedotcom/sfdx-core/commit/753292fcf51d57a39aab36190a2053152caaacd8)) +- tolerate broken auth files (with warning) during readAll ([#869](https://github.com/forcedotcom/sfdx-core/issues/869)) ([4cea657](https://github.com/forcedotcom/sfdx-core/commit/4cea657213054b6c3f22bb70a00753105caf2337)) +## [4.3.2](https://github.com/forcedotcom/sfdx-core/compare/4.3.1...4.3.2) (2023-06-20) +### Bug Fixes -## [3.31.8](https://github.com/forcedotcom/sfdx-core/compare/3.30.14...3.31.8) (2022-10-13) +- better scratch org settings messages ([39d1124](https://github.com/forcedotcom/sfdx-core/commit/39d1124804ee845533888878c9a7aeb2c0ed8c25)) +## [4.3.1](https://github.com/forcedotcom/sfdx-core/compare/4.3.0...4.3.1) (2023-06-13) ### Bug Fixes -* force release ([da5ffa0](https://github.com/forcedotcom/sfdx-core/commit/da5ffa0e51855746decf1b63d6195d793929b846)) +- **messageTransformer:** remove export, require deep import from lib ([#861](https://github.com/forcedotcom/sfdx-core/issues/861)) ([49abe60](https://github.com/forcedotcom/sfdx-core/commit/49abe603e765a29bbcb5f29c664dd862c29493be)) +# [4.3.0](https://github.com/forcedotcom/sfdx-core/compare/4.2.2...4.3.0) (2023-06-13) ### Features -* deprecate testSetup and refactor TestContext ([#676](https://github.com/forcedotcom/sfdx-core/issues/676)) ([6e2f547](https://github.com/forcedotcom/sfdx-core/commit/6e2f547229199da2e2839e4ea70dabd13089c487)) - - - -## [3.30.14](https://github.com/forcedotcom/sfdx-core/compare/3.30.13...3.30.14) (2022-10-11) +- export msgTransformer for other libraries ([25a5b4f](https://github.com/forcedotcom/sfdx-core/commit/25a5b4f1f3e12864fb3ac735a44eebc3b0a19293)) +## [4.2.2](https://github.com/forcedotcom/sfdx-core/compare/4.2.1...4.2.2) (2023-06-11) ### Bug Fixes -* type on TokenAccessor.set ([#675](https://github.com/forcedotcom/sfdx-core/issues/675)) ([94fdf1e](https://github.com/forcedotcom/sfdx-core/commit/94fdf1ed9ded8f8fbe1a66d55affbd0ac27e79bb)) +- **deps:** bump @salesforce/kit from 3.0.2 to 3.0.3 ([19c1cf6](https://github.com/forcedotcom/sfdx-core/commit/19c1cf6310c61826ee8da296ab558f477b5817a0)) +## [4.2.1](https://github.com/forcedotcom/sfdx-core/compare/4.2.0...4.2.1) (2023-06-08) +### Bug Fixes -## [3.30.13](https://github.com/forcedotcom/sfdx-core/compare/3.30.12...3.30.13) (2022-10-10) +- typos ([58064b1](https://github.com/forcedotcom/sfdx-core/commit/58064b140adfb78895f3d09a72dd731a4d299dff)) +# [4.2.0](https://github.com/forcedotcom/sfdx-core/compare/4.1.3...4.2.0) (2023-06-06) ### Bug Fixes -* add tooling query support to autoFetchQuery ([#665](https://github.com/forcedotcom/sfdx-core/issues/665)) ([608b119](https://github.com/forcedotcom/sfdx-core/commit/608b11971d893f7417fcfe5f4eea710f38b8e7cf)) - +- improve test robustness ([1b29bd3](https://github.com/forcedotcom/sfdx-core/commit/1b29bd360a753a0d9c7606e45e096c6d7c7fa5e6)) +### Features -## [3.30.12](https://github.com/forcedotcom/sfdx-core/compare/3.30.11...3.30.12) (2022-10-08) +- replace archiver with jszip for ZipWriter ([c8d03d4](https://github.com/forcedotcom/sfdx-core/commit/c8d03d429cf14140fa025cdbf2499876b56a9b38)) +## [4.1.3](https://github.com/forcedotcom/sfdx-core/compare/4.1.2...4.1.3) (2023-06-06) ### Bug Fixes -* **deps:** bump ts-retry-promise from 0.6.2 to 0.7.0 ([5def87a](https://github.com/forcedotcom/sfdx-core/commit/5def87ae3be6eac81503abfaff96e29ba2c82bdf)) +- **deps:** bump @types/semver from 7.3.13 to 7.5.0 ([4a84e39](https://github.com/forcedotcom/sfdx-core/commit/4a84e39caaf5b66266de29a275bd46a1fde003fc)) +## [4.1.2](https://github.com/forcedotcom/sfdx-core/compare/4.1.1...4.1.2) (2023-06-05) +### Bug Fixes -## [3.30.11](https://github.com/forcedotcom/sfdx-core/compare/3.30.10...3.30.11) (2022-10-07) +- **deps:** bump @salesforce/kit from 3.0.0 to 3.0.2 ([c1e75d0](https://github.com/forcedotcom/sfdx-core/commit/c1e75d038a3fb6776bde246348935d6a2857f6dc)) +## [4.1.1](https://github.com/forcedotcom/sfdx-core/compare/4.1.0...4.1.1) (2023-06-05) ### Bug Fixes -* update kit, testSetup plus major refactor ([453b886](https://github.com/forcedotcom/sfdx-core/commit/453b8860c16991796252f05a3c933dee1e9d7e3b)) +- trigger gha ([efbd179](https://github.com/forcedotcom/sfdx-core/commit/efbd1798fb5600545b4507ca894819d03375e0c5)) +- trigger gha ([a6cb99a](https://github.com/forcedotcom/sfdx-core/commit/a6cb99adbd28e8c1abd6bd38550c3b45d9f33c74)) +- use SF prefixed env vars, add UTs ([e266340](https://github.com/forcedotcom/sfdx-core/commit/e266340f57c6512acaf71eb3cf8a9d292f37ca01)) +# [4.1.0](https://github.com/forcedotcom/sfdx-core/compare/4.0.1...4.1.0) (2023-06-01) +### Bug Fixes -## [3.30.10](https://github.com/forcedotcom/sfdx-core/compare/3.30.9...3.30.10) (2022-10-04) +- everything but ut/testsetup ([616488a](https://github.com/forcedotcom/sfdx-core/commit/616488af548498c32cf1fde45b79fd52490db6f3)) +### Features +- file locking for aliases ([d351ebb](https://github.com/forcedotcom/sfdx-core/commit/d351ebb1136cd97d1c2d70f14d29622b4b40e711)) -## [3.30.9](https://github.com/forcedotcom/sfdx-core/compare/3.30.8...3.30.9) (2022-09-28) +## [4.0.1](https://github.com/forcedotcom/sfdx-core/compare/3.36.2...4.0.1) (2023-05-30) +## [3.36.2](https://github.com/forcedotcom/sfdx-core/compare/3.36.1...3.36.2) (2023-05-22) ### Bug Fixes -* fix package dir functions ([#660](https://github.com/forcedotcom/sfdx-core/issues/660)) ([7df117c](https://github.com/forcedotcom/sfdx-core/commit/7df117c6b5aecf500af82adb52efe5e931fb8718)) +- bump jsforce to latest beta ([32c46c1](https://github.com/forcedotcom/sfdx-core/commit/32c46c187738cbb6b686e9901a03183e0a02cf34)) + +## [3.36.1](https://github.com/forcedotcom/sfdx-core/compare/3.36.0...3.36.1) (2023-05-11) +### Bug Fixes +- handle unknown config keys that moved to plugins ([5077340](https://github.com/forcedotcom/sfdx-core/commit/5077340d04b8225bf3089112502de106af911841)) -## [3.30.8](https://github.com/forcedotcom/sfdx-core/compare/3.30.7...3.30.8) (2022-09-23) +# [3.36.0](https://github.com/forcedotcom/sfdx-core/compare/3.35.0...3.36.0) (2023-04-28) +# [3.35.0-qa.3](https://github.com/forcedotcom/sfdx-core/compare/3.35.0-qa.2...3.35.0-qa.3) (2023-04-24) ### Bug Fixes -* **scratch:** respect `apiVersion` config value ([#656](https://github.com/forcedotcom/sfdx-core/issues/656)) ([1a29482](https://github.com/forcedotcom/sfdx-core/commit/1a294821c07f334494f2e56295dcd1a23570fa4b)) +- load config for deprecated stuff, too ([ef1c71b](https://github.com/forcedotcom/sfdx-core/commit/ef1c71b2f9989f7afeb99e662f5b441ef077515f)) +# [3.35.0-qa.2](https://github.com/forcedotcom/sfdx-core/compare/3.34.8...3.35.0-qa.2) (2023-04-24) +### Features -## [3.30.7](https://github.com/forcedotcom/sfdx-core/compare/3.30.4...3.30.7) (2022-09-23) +- sf rest_deploy via env ([46ae051](https://github.com/forcedotcom/sfdx-core/commit/46ae051bd36a52be0244b55274dc4aa438286286)) +# [3.35.0-qa.1](https://github.com/forcedotcom/sfdx-core/compare/3.34.7...3.35.0-qa.1) (2023-04-21) ### Bug Fixes -* force build ([cb0b831](https://github.com/forcedotcom/sfdx-core/commit/cb0b8310ca2b2fc9e537229c0034deb1063c3a34)) -* revert 3.30.4 ([#658](https://github.com/forcedotcom/sfdx-core/issues/658)) ([3ed9565](https://github.com/forcedotcom/sfdx-core/commit/3ed95653fd03f80483d0bbd137697cb7df87ddd8)), closes [#657](https://github.com/forcedotcom/sfdx-core/issues/657) [#655](https://github.com/forcedotcom/sfdx-core/issues/655) - - - -## [3.30.4](https://github.com/forcedotcom/sfdx-core/compare/3.30.3...3.30.4) (2022-09-23) +- prerelease branch for testing ([cdeaa51](https://github.com/forcedotcom/sfdx-core/commit/cdeaa514497456d7cae198e04079eb2d12630d7a)) +# [3.35.0](https://github.com/forcedotcom/sfdx-core/compare/3.34.9...3.35.0) (2023-04-28) ### Bug Fixes -* retire use of pkgdir.name field ([#655](https://github.com/forcedotcom/sfdx-core/issues/655)) ([227f9a8](https://github.com/forcedotcom/sfdx-core/commit/227f9a8663401813b3e8626344fa59464510a732)) - +- bad error message for in progress scratch orgs ([b18d112](https://github.com/forcedotcom/sfdx-core/commit/b18d1121b56c96f7bb9cddfcacc0bae58f977628)) +### Features -## [3.30.3](https://github.com/forcedotcom/sfdx-core/compare/v3.30.2...3.30.3) (2022-09-20) +- backward compatible configs/envs with warnings ([51ed461](https://github.com/forcedotcom/sfdx-core/commit/51ed461ba06fd62bbada398dcc86656eb9b34fac)) +- sfdxConfigAggregator = configAggregator ([a98cd97](https://github.com/forcedotcom/sfdx-core/commit/a98cd975e17e4bc75f76c3f6034050816d0f9e1e)) +- warnings from config ([a84993e](https://github.com/forcedotcom/sfdx-core/commit/a84993edeee942175f80c5e96683164579a4fa70)) +## [3.34.9](https://github.com/forcedotcom/sfdx-core/compare/3.35.0-qa.3...3.34.9) (2023-04-27) ### Bug Fixes -* add helper functions to project for pkging ([1ed5563](https://github.com/forcedotcom/sfdx-core/commit/1ed556348cd0cc2f8c9dae7125a12bf177206c5c)) +- redirect to oauth success url ([#811](https://github.com/forcedotcom/sfdx-core/issues/811)) ([e505351](https://github.com/forcedotcom/sfdx-core/commit/e505351e2d91cc8481b2e3908914d2406ea5a217)) +## [3.34.8](https://github.com/forcedotcom/sfdx-core/compare/3.35.0-qa.1...3.34.8) (2023-04-21) +### Bug Fixes -## [3.30.2](https://github.com/forcedotcom/sfdx-core/compare/v3.30.1...v3.30.2) (2022-09-16) +- prevent logging loop ([55bcbc3](https://github.com/forcedotcom/sfdx-core/commit/55bcbc357e9ac04b6d064e3d42a07e2975213d96)) +# [3.35.0-qa.3](https://github.com/forcedotcom/sfdx-core/compare/3.35.0-qa.2...3.35.0-qa.3) (2023-04-24) ### Bug Fixes -* **logger:** support `SF_*` env vars ([#637](https://github.com/forcedotcom/sfdx-core/issues/637)) ([53c4296](https://github.com/forcedotcom/sfdx-core/commit/53c4296d0ab0728a798e39626a29168371e1a062)) +- load config for deprecated stuff, too ([ef1c71b](https://github.com/forcedotcom/sfdx-core/commit/ef1c71b2f9989f7afeb99e662f5b441ef077515f)) +# [3.35.0-qa.2](https://github.com/forcedotcom/sfdx-core/compare/3.34.8...3.35.0-qa.2) (2023-04-24) +### Features -## [3.30.1](https://github.com/forcedotcom/sfdx-core/compare/v3.30.0...v3.30.1) (2022-09-15) +- sf rest_deploy via env ([46ae051](https://github.com/forcedotcom/sfdx-core/commit/46ae051bd36a52be0244b55274dc4aa438286286)) +# [3.35.0-qa.1](https://github.com/forcedotcom/sfdx-core/compare/3.34.7...3.35.0-qa.1) (2023-04-21) ### Bug Fixes -* await postOrgCreate hook ([#636](https://github.com/forcedotcom/sfdx-core/issues/636)) ([b9934d2](https://github.com/forcedotcom/sfdx-core/commit/b9934d2df6f5ea49b4f8bae44779aa5cab0e897f)) +- bad error message for in progress scratch orgs ([b18d112](https://github.com/forcedotcom/sfdx-core/commit/b18d1121b56c96f7bb9cddfcacc0bae58f977628)) +- prerelease branch for testing ([cdeaa51](https://github.com/forcedotcom/sfdx-core/commit/cdeaa514497456d7cae198e04079eb2d12630d7a)) +### Features +- backward compatible configs/envs with warnings ([51ed461](https://github.com/forcedotcom/sfdx-core/commit/51ed461ba06fd62bbada398dcc86656eb9b34fac)) +- sfdxConfigAggregator = configAggregator ([a98cd97](https://github.com/forcedotcom/sfdx-core/commit/a98cd975e17e4bc75f76c3f6034050816d0f9e1e)) +- warnings from config ([a84993e](https://github.com/forcedotcom/sfdx-core/commit/a84993edeee942175f80c5e96683164579a4fa70)) -# [3.30.0](https://github.com/forcedotcom/sfdx-core/compare/v3.26.3...v3.30.0) (2022-09-12) +## [3.34.8](https://github.com/forcedotcom/sfdx-core/compare/3.35.0-qa.1...3.34.8) (2023-04-21) +### Bug Fixes +- prevent logging loop ([55bcbc3](https://github.com/forcedotcom/sfdx-core/commit/55bcbc357e9ac04b6d064e3d42a07e2975213d96)) -## [3.26.3](https://github.com/forcedotcom/sfdx-core/compare/v3.26.2...v3.26.3) (2022-09-06) +# [3.35.0-qa.1](https://github.com/forcedotcom/sfdx-core/compare/3.34.7...3.35.0-qa.1) (2023-04-21) +### Bug Fixes +- bad error message for in progress scratch orgs ([b18d112](https://github.com/forcedotcom/sfdx-core/commit/b18d1121b56c96f7bb9cddfcacc0bae58f977628)) +- prerelease branch for testing ([cdeaa51](https://github.com/forcedotcom/sfdx-core/commit/cdeaa514497456d7cae198e04079eb2d12630d7a)) -## [3.26.2](https://github.com/forcedotcom/sfdx-core/compare/v3.26.1...v3.26.2) (2022-08-16) +### Features +- backward compatible configs/envs with warnings ([51ed461](https://github.com/forcedotcom/sfdx-core/commit/51ed461ba06fd62bbada398dcc86656eb9b34fac)) +- sfdxConfigAggregator = configAggregator ([a98cd97](https://github.com/forcedotcom/sfdx-core/commit/a98cd975e17e4bc75f76c3f6034050816d0f9e1e)) +- warnings from config ([a84993e](https://github.com/forcedotcom/sfdx-core/commit/a84993edeee942175f80c5e96683164579a4fa70)) +## [3.34.7](https://github.com/forcedotcom/sfdx-core/compare/3.34.6...3.34.7) (2023-04-16) -## [3.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.26.0...v3.26.1) (2022-08-08) +### Bug Fixes +- **deps:** bump jsforce from 2.0.0-beta.20 to 2.0.0-beta.21 ([4a5ee12](https://github.com/forcedotcom/sfdx-core/commit/4a5ee126aaf10bd6d35f0f6b9bd76bed0e74e5f6)) + +## [3.34.6](https://github.com/forcedotcom/sfdx-core/compare/3.34.5...3.34.6) (2023-03-26) ### Bug Fixes -* update jsforce ([0353330](https://github.com/forcedotcom/sfdx-core/commit/03533307f0ea1f8877027a5619c970e1ae2443ec)) +- **deps:** bump @salesforce/schemas from 1.5.0 to 1.5.1 ([d447260](https://github.com/forcedotcom/sfdx-core/commit/d447260323d6b4e8cc556b4f0c9ef084c11b579f)) +## [3.34.5](https://github.com/forcedotcom/sfdx-core/compare/3.34.4...3.34.5) (2023-03-26) +### Bug Fixes -# [3.26.0](https://github.com/forcedotcom/sfdx-core/compare/v3.25.1...v3.26.0) (2022-08-04) +- **deps:** bump json5 from 1.0.1 to 1.0.2 ([0dbbcf6](https://github.com/forcedotcom/sfdx-core/commit/0dbbcf61576512d527799240a50b311f723ab200)) +## [3.34.4](https://github.com/forcedotcom/sfdx-core/compare/3.34.3...3.34.4) (2023-03-22) -### Features +### Bug Fixes -* remove GlobalInfo ([57bd0fa](https://github.com/forcedotcom/sfdx-core/commit/57bd0fa50c5fe3cc859ca107fd0a18dc1b871c1f)) +- check resumable state before emitting first progress event ([#793](https://github.com/forcedotcom/sfdx-core/issues/793)) ([6677d0f](https://github.com/forcedotcom/sfdx-core/commit/6677d0f02e155e7d245701b7f73ee19dc8aa03be)) +## [3.34.3](https://github.com/forcedotcom/sfdx-core/compare/3.34.2...3.34.3) (2023-03-20) +### Bug Fixes -## [3.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.25.0...v3.25.1) (2022-08-03) +- **deps:** bump graceful-fs from 4.2.10 to 4.2.11 ([8384d3f](https://github.com/forcedotcom/sfdx-core/commit/8384d3fcef55fc0ef609590364311c146f171d46)) +## [3.34.2](https://github.com/forcedotcom/sfdx-core/compare/3.34.1...3.34.2) (2023-03-19) ### Bug Fixes -* add interop between templates config/env var ([eea3d05](https://github.com/forcedotcom/sfdx-core/commit/eea3d055b75ceb61639e06bc53e309a01f70a8e2)) +- **deps:** bump jsforce from 2.0.0-beta.19 to 2.0.0-beta.20 ([9026092](https://github.com/forcedotcom/sfdx-core/commit/90260926103273ae5ffac382db38d6aea9e2bcc3)) +## [3.34.1](https://github.com/forcedotcom/sfdx-core/compare/3.34.0...3.34.1) (2023-03-16) +### Bug Fixes -# [3.25.0](https://github.com/forcedotcom/sfdx-core/compare/v3.24.5...v3.25.0) (2022-07-29) +- allow completed status to be resume ([484244d](https://github.com/forcedotcom/sfdx-core/commit/484244d2877b6eec610975bd643fea2a368b5f5e)) +# [3.34.0](https://github.com/forcedotcom/sfdx-core/compare/3.33.9...3.34.0) (2023-03-14) ### Features -* orgAccessor.get has throwOnNotFound option ([a2ee821](https://github.com/forcedotcom/sfdx-core/commit/a2ee8219adf692de7de17ba254e05f501ef5814c)) +- deprecate messages.load and docs ([3229f74](https://github.com/forcedotcom/sfdx-core/commit/3229f742f6ee2d99729e55abb8021cf5f3639b9f)) +## [3.33.9](https://github.com/forcedotcom/sfdx-core/compare/3.33.8...3.33.9) (2023-03-14) +### Bug Fixes -## [3.24.5](https://github.com/forcedotcom/sfdx-core/compare/v3.24.4...v3.24.5) (2022-07-28) +- save expiration date for scratch org ([#775](https://github.com/forcedotcom/sfdx-core/issues/775)) ([a59323b](https://github.com/forcedotcom/sfdx-core/commit/a59323be438e6fc8e021855af8ce6d09700c2e60)) +## [3.33.8](https://github.com/forcedotcom/sfdx-core/compare/3.33.7...3.33.8) (2023-03-14) ### Bug Fixes -* set correct file mode for log file ([30aa3fc](https://github.com/forcedotcom/sfdx-core/commit/30aa3fc09ba2bf0db600ee6528fde5b0ff97b217)) +- **deps:** bump json5 from 1.0.1 to 1.0.2 ([7ccd063](https://github.com/forcedotcom/sfdx-core/commit/7ccd0637048531d4669252a65e7c371b2e8c5f98)) +## [3.33.7](https://github.com/forcedotcom/sfdx-core/compare/3.33.6...3.33.7) (2023-03-13) +### Bug Fixes -## [3.24.4](https://github.com/forcedotcom/sfdx-core/compare/v3.24.3...v3.24.4) (2022-07-28) +- conf file stubs for read and readSync ([a4ceedc](https://github.com/forcedotcom/sfdx-core/commit/a4ceedc086bd293f10a30d2ac78b2f832acc0120)) +## [3.33.6](https://github.com/forcedotcom/sfdx-core/compare/3.33.5...3.33.6) (2023-03-02) +### Bug Fixes -## [3.24.3](https://github.com/forcedotcom/sfdx-core/compare/v3.24.2...v3.24.3) (2022-07-28) +- check for resumable state for sandbox resume ([157622f](https://github.com/forcedotcom/sfdx-core/commit/157622f10c1d16c531d1576feb44a17eb1b04952)) +## [3.33.5](https://github.com/forcedotcom/sfdx-core/compare/3.33.4...3.33.5) (2023-02-26) ### Bug Fixes -* handle ancestor keywords when creating scratch org ([72af55a](https://github.com/forcedotcom/sfdx-core/commit/72af55a53b87f1d81d22dc4e53891b3b0ab2966f)) +- **deps:** bump @salesforce/schemas from 1.4.0 to 1.5.0 ([f63c2f8](https://github.com/forcedotcom/sfdx-core/commit/f63c2f8135c27f794c5fce65be3dd5ea9e14f57f)) +## [3.33.4](https://github.com/forcedotcom/sfdx-core/compare/3.33.3...3.33.4) (2023-02-22) +### Bug Fixes -## [3.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.24.1...v3.24.2) (2022-07-26) +- **deps:** bump @types/graceful-fs from 4.1.5 to 4.1.6 ([d7500b9](https://github.com/forcedotcom/sfdx-core/commit/d7500b96caf2b13f8b0824c29721e639b0274165)) +## [3.33.3](https://github.com/forcedotcom/sfdx-core/compare/3.33.2...3.33.3) (2023-02-22) ### Bug Fixes -* use correct field for clone requests ([#623](https://github.com/forcedotcom/sfdx-core/issues/623)) ([2372f03](https://github.com/forcedotcom/sfdx-core/commit/2372f0364b87a7ac498c8d7ef637a9b5fdc725ea)) +- correct timeout for deploy during scratch org creation ([364985d](https://github.com/forcedotcom/sfdx-core/commit/364985d849d29dc07f4c27c5e3e67e2f3b344ff6)) +## [3.33.2](https://github.com/forcedotcom/sfdx-core/compare/3.33.1...3.33.2) (2023-02-21) +### Bug Fixes -## [3.24.1](https://github.com/forcedotcom/sfdx-core/compare/v3.24.0...v3.24.1) (2022-07-21) +- improve error contents for device login ([#774](https://github.com/forcedotcom/sfdx-core/issues/774)) ([3ad803a](https://github.com/forcedotcom/sfdx-core/commit/3ad803ad4d4b0ff473c04a8dd727c65546bfa86e)) +## [3.33.1](https://github.com/forcedotcom/sfdx-core/compare/3.33.0...3.33.1) (2023-01-23) ### Bug Fixes -* bump jsforce ([#622](https://github.com/forcedotcom/sfdx-core/issues/622)) ([c7b53b7](https://github.com/forcedotcom/sfdx-core/commit/c7b53b73977012f81e029a15f39c3fb35bc1041d)) +- remove source tracking files with Org.delete() ([a85c5bf](https://github.com/forcedotcom/sfdx-core/commit/a85c5bf4dc2312e6be689f70e3b2e74f61cfbfc4)) +# [3.33.0](https://github.com/forcedotcom/sfdx-core/compare/3.32.14...3.33.0) (2023-01-19) +### Features -# [3.24.0](https://github.com/forcedotcom/sfdx-core/compare/v3.23.9...v3.24.0) (2022-07-14) +- backward compatible messages.createError ([ac564b9](https://github.com/forcedotcom/sfdx-core/commit/ac564b927bd0c85c874cda39641afb9d9206e268)) +## [3.32.14](https://github.com/forcedotcom/sfdx-core/compare/3.32.13...3.32.14) (2023-01-18) ### Bug Fixes -* align messages/files ([5a5f04d](https://github.com/forcedotcom/sfdx-core/commit/5a5f04d3ea8ffb30fdbbfe2c83824ec56a56ec34)) -* load messages by name ([7c3a2d9](https://github.com/forcedotcom/sfdx-core/commit/7c3a2d9d84f9553bb9cf1bc369b49ca46100484e)) -* use named messages always ([2bb25a9](https://github.com/forcedotcom/sfdx-core/commit/2bb25a9c24fcb7146e363783ea81bc3708060a18)) +- snapshot is optional ([e81684c](https://github.com/forcedotcom/sfdx-core/commit/e81684cbe78c22e63b5c191264d26cef70c6c2f8)) +## [3.32.13](https://github.com/forcedotcom/sfdx-core/compare/3.32.12...3.32.13) (2023-01-12) -### Features +### Bug Fixes -* org.scratchOrgCreate uses all options except hub ([045a7aa](https://github.com/forcedotcom/sfdx-core/commit/045a7aa56c97323aa8b3191c4879cd1b43f0cfb1)) +- **deps:** bump @salesforce/ts-types from 1.7.1 to 1.7.2 ([cadc91f](https://github.com/forcedotcom/sfdx-core/commit/cadc91fd5d0ced7cf15fed9ddeda1eea63f20f5b)) +## [3.32.12](https://github.com/forcedotcom/sfdx-core/compare/3.32.11...3.32.12) (2022-12-23) +### Bug Fixes -## [3.23.9](https://github.com/forcedotcom/sfdx-core/compare/v3.23.8...v3.23.9) (2022-07-14) +- **deps:** bump jsonwebtoken from 8.5.1 to 9.0.0 ([c40ea0a](https://github.com/forcedotcom/sfdx-core/commit/c40ea0aa3025045488c542bd35684ae7f296b5f5)) +## [3.32.11](https://github.com/forcedotcom/sfdx-core/compare/3.32.10...3.32.11) (2022-12-16) +### Bug Fixes -## [3.23.8](https://github.com/forcedotcom/sfdx-core/compare/v3.23.7...v3.23.8) (2022-07-13) +- add password to mock org getConfig ([#729](https://github.com/forcedotcom/sfdx-core/issues/729)) ([00ee0fc](https://github.com/forcedotcom/sfdx-core/commit/00ee0fc940592cc04bc5b3ad6e609a3d5e6c2582)) +## [3.32.10](https://github.com/forcedotcom/sfdx-core/compare/3.32.9...3.32.10) (2022-12-15) ### Bug Fixes -* remove greedy matching for AuthInfo encryptedKeys ([12c6dcc](https://github.com/forcedotcom/sfdx-core/commit/12c6dcc5137a48d59e0da4a20426d8fa2cf747d9)) +- provide way to stub user data ([#728](https://github.com/forcedotcom/sfdx-core/issues/728)) ([98b2503](https://github.com/forcedotcom/sfdx-core/commit/98b25035043676a745692181e4cf0f1c889ea9d0)) +## [3.32.9](https://github.com/forcedotcom/sfdx-core/compare/3.32.8...3.32.9) (2022-12-08) +### Bug Fixes -## [3.23.7](https://github.com/forcedotcom/sfdx-core/compare/v3.23.6...v3.23.7) (2022-07-08) +- add password property to ([1995c01](https://github.com/forcedotcom/sfdx-core/commit/1995c010d13967a49cd4e460cf7acf27eb4327f7)) +## [3.32.8](https://github.com/forcedotcom/sfdx-core/compare/3.32.7...3.32.8) (2022-12-04) ### Bug Fixes -* add structure writer interface and refactor ([daef19c](https://github.com/forcedotcom/sfdx-core/commit/daef19cb3a4d145ebb22c4f721a1bd47ffddce40)) +- **deps:** bump ajv from 8.11.0 to 8.11.2 ([78eb48d](https://github.com/forcedotcom/sfdx-core/commit/78eb48d394a63fb21655d8c84de64e2ea8efa987)) +## [3.32.7](https://github.com/forcedotcom/sfdx-core/compare/3.32.6...3.32.7) (2022-12-04) +### Bug Fixes -## [3.23.6](https://github.com/forcedotcom/sfdx-core/compare/v3.23.5...v3.23.6) (2022-07-06) +- **deps:** bump decode-uri-component from 0.2.0 to 0.2.2 ([bb4c0d1](https://github.com/forcedotcom/sfdx-core/commit/bb4c0d1b6d0ca3dcc07532a728ef1a27b019d256)) +## [3.32.6](https://github.com/forcedotcom/sfdx-core/compare/3.32.5...3.32.6) (2022-12-01) ### Bug Fixes -* workaround for jsforce update bug ([1776f50](https://github.com/forcedotcom/sfdx-core/commit/1776f505671a5a764c4e966736c2981df2b178a4)) +- remove refs to legacy client id ([82689ea](https://github.com/forcedotcom/sfdx-core/commit/82689ea5257b95a94d91326200293c6eb464287f)) +## [3.32.5](https://github.com/forcedotcom/sfdx-core/compare/3.32.4...3.32.5) (2022-11-30) +### Bug Fixes -## [3.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.23.4...v3.23.5) (2022-07-06) +- update a few tests ([6952b44](https://github.com/forcedotcom/sfdx-core/commit/6952b4429bf7adf4ed4c5c0c9681ab04986f7720)) +- use API version cache more often ([36b0e81](https://github.com/forcedotcom/sfdx-core/commit/36b0e81abecd75ef8d69543470a0b1ad36f14a03)) +## [3.32.4](https://github.com/forcedotcom/sfdx-core/compare/3.32.3...3.32.4) (2022-11-27) ### Bug Fixes -* add resolveAlias ([#605](https://github.com/forcedotcom/sfdx-core/issues/605)) ([ffa9ed6](https://github.com/forcedotcom/sfdx-core/commit/ffa9ed63ea583baa327071db4030ea5346d1128f)) +- **deps:** bump @types/semver from 7.3.10 to 7.3.13 ([0584bf6](https://github.com/forcedotcom/sfdx-core/commit/0584bf642f1d01508594d16fd5391d7419f243f4)) +## [3.32.3](https://github.com/forcedotcom/sfdx-core/compare/3.32.2...3.32.3) (2022-11-27) +### Bug Fixes -## [3.23.4](https://github.com/forcedotcom/sfdx-core/compare/v3.23.3...v3.23.4) (2022-07-05) +- **deps:** bump @salesforce/schemas from 1.1.3 to 1.4.0 ([9b0f2a9](https://github.com/forcedotcom/sfdx-core/commit/9b0f2a977868b40bc6c113ee2bff178c3ac3ceec)) +## [3.32.2](https://github.com/forcedotcom/sfdx-core/compare/3.32.1...3.32.2) (2022-11-22) ### Bug Fixes -* force publish ([3eb660d](https://github.com/forcedotcom/sfdx-core/commit/3eb660dd23ee959e085a9ac3dbd65de92e511d74)) +- pass value to message correctly ([c21f088](https://github.com/forcedotcom/sfdx-core/commit/c21f0881a13f8d16ef5a02c5bdec1e9612d8acc8)) +## [3.32.1](https://github.com/forcedotcom/sfdx-core/compare/3.32.0...3.32.1) (2022-11-17) +### Bug Fixes -## [3.23.3](https://github.com/forcedotcom/sfdx-core/compare/v3.23.2...v3.23.3) (2022-06-30) +- **deps:** bump @salesforce/kit from 1.7.0 to 1.8.0 ([8e065a7](https://github.com/forcedotcom/sfdx-core/commit/8e065a76bbfb6182d2851ed51b18630bdcc097dc)) +# [3.32.0](https://github.com/forcedotcom/sfdx-core/compare/3.31.19...3.32.0) (2022-11-17) -### Bug Fixes +### Features -* force publish ([b767232](https://github.com/forcedotcom/sfdx-core/commit/b767232f2f76a4a00387e37128428ad18221a594)) +- getConnection accepts an optional version ([c4299f8](https://github.com/forcedotcom/sfdx-core/commit/c4299f88acf2c45979c13ca8d093919308619c99)) +- log when unnecessarily setting api version ([9e4afd2](https://github.com/forcedotcom/sfdx-core/commit/9e4afd2c573219eea43e2e43d5f3ca5822d936b3)) +## [3.31.19](https://github.com/forcedotcom/sfdx-core/compare/3.31.18...3.31.19) (2022-11-12) +### Bug Fixes -## [3.23.2](https://github.com/forcedotcom/sfdx-core/compare/v3.23.1...v3.23.2) (2022-06-30) +- ajv allows union type schema, sfProject doesn't validate ([#698](https://github.com/forcedotcom/sfdx-core/issues/698)) ([ca726ae](https://github.com/forcedotcom/sfdx-core/commit/ca726ae1cb6313f7eaf179517552f15b769a5b74)) +## [3.31.18](https://github.com/forcedotcom/sfdx-core/compare/3.31.17...3.31.18) (2022-11-07) ### Bug Fixes -* add getter for shape dir name ([#614](https://github.com/forcedotcom/sfdx-core/issues/614)) ([06282d8](https://github.com/forcedotcom/sfdx-core/commit/06282d868b508b2d8417fcd4de404a7863c74b14)) +- deduplicate headers case on Connect.request ([#697](https://github.com/forcedotcom/sfdx-core/issues/697)) ([fc592b2](https://github.com/forcedotcom/sfdx-core/commit/fc592b215bcc9184f3ca8003d382b6053447349b)) + +## [3.31.17](https://github.com/forcedotcom/sfdx-core/compare/3.31.16...3.31.17) (2022-10-24) +### Bug Fixes +- improve `hubOrgIsNotDevHub` error msg ([#689](https://github.com/forcedotcom/sfdx-core/issues/689)) ([d3787fa](https://github.com/forcedotcom/sfdx-core/commit/d3787faf8c8aea75624b8a1b140384e1e567f1bc)) -## [3.23.1](https://github.com/forcedotcom/sfdx-core/compare/v3.23.0...v3.23.1) (2022-06-30) +## [3.31.16](https://github.com/forcedotcom/sfdx-core/compare/3.31.15...3.31.16) (2022-10-19) +## [3.31.15](https://github.com/forcedotcom/sfdx-core/compare/3.31.13-0...3.31.15) (2022-10-19) ### Bug Fixes -* isScratch should be boolean ([ebda782](https://github.com/forcedotcom/sfdx-core/commit/ebda782bfd4f3927bc12ce4e6402673361ac47d6)) -* update AuthFields type ([766efec](https://github.com/forcedotcom/sfdx-core/commit/766efec26f404cc1f0e4d380d82f4f05aa455e95)) +- remove prerelease portion of version number ([6dffeac](https://github.com/forcedotcom/sfdx-core/commit/6dffeacd0f12c24b32b3e9de13011c8a1cd22c0b)) +## [3.31.13-0](https://github.com/forcedotcom/sfdx-core/compare/3.31.12...3.31.13-0) (2022-10-18) +### Bug Fixes -# [3.23.0](https://github.com/forcedotcom/sfdx-core/compare/v3.22.1...v3.23.0) (2022-06-30) +- reset SFDX_INTEROPERABILITY on contextRestore ([#673](https://github.com/forcedotcom/sfdx-core/issues/673)) ([4c8ecae](https://github.com/forcedotcom/sfdx-core/commit/4c8ecae69f871309b00f69a68228e3833923eee9)) +## [3.31.12](https://github.com/forcedotcom/sfdx-core/compare/3.31.11...3.31.12) (2022-10-18) -### Features +### Bug Fixes -* support more enhanced domains, wider test cases ([f1bac94](https://github.com/forcedotcom/sfdx-core/commit/f1bac945d9b135a9a8165260b95f7de5568ccca6)) +- incorrect url for scratch org error codes documentation ([#681](https://github.com/forcedotcom/sfdx-core/issues/681)) ([ab91644](https://github.com/forcedotcom/sfdx-core/commit/ab91644820e031a28f6fb262e0f7826e8419e5d7)) +## [3.31.11](https://github.com/forcedotcom/sfdx-core/compare/3.31.10...3.31.11) (2022-10-18) +### Bug Fixes -## [3.22.1](https://github.com/forcedotcom/sfdx-core/compare/v3.22.0...v3.22.1) (2022-06-28) +- function addLogFileStreamSync to use recursive mkdir ([#683](https://github.com/forcedotcom/sfdx-core/issues/683)) ([c85c69c](https://github.com/forcedotcom/sfdx-core/commit/c85c69c4179b2b06e4b2e6cbe5727d2a98918304)) +## [3.31.10](https://github.com/forcedotcom/sfdx-core/compare/3.31.9...3.31.10) (2022-10-14) ### Bug Fixes -* encrypted key regex tests will no longer be stateful ([06b7fa2](https://github.com/forcedotcom/sfdx-core/commit/06b7fa2f41401155b472c84f13cbf5608150a43e)) -* update dev-scripts so yarn build won't change line endings for LICENSE.txt on Windows ([ec5e48e](https://github.com/forcedotcom/sfdx-core/commit/ec5e48ee1dab2b3999f630aa56c53d353baa717e)) - +- getPackageFromPath now handles nested package paths ([#678](https://github.com/forcedotcom/sfdx-core/issues/678)) ([d8c43c6](https://github.com/forcedotcom/sfdx-core/commit/d8c43c66ec4ea58e0398009083740fab0bac1439)) +## [3.31.9](https://github.com/forcedotcom/sfdx-core/compare/3.31.8...3.31.9) (2022-10-13) -# [3.22.0](https://github.com/forcedotcom/sfdx-core/compare/v3.21.6...v3.22.0) (2022-06-23) +### Bug Fixes +- ensure the hubOrg passes is actually a DevHub, throw error if not ([#669](https://github.com/forcedotcom/sfdx-core/issues/669)) ([753292f](https://github.com/forcedotcom/sfdx-core/commit/753292fcf51d57a39aab36190a2053152caaacd8)) -### Features +## [3.31.8](https://github.com/forcedotcom/sfdx-core/compare/3.30.14...3.31.8) (2022-10-13) -* modify uniqid to accept length and template ([#604](https://github.com/forcedotcom/sfdx-core/issues/604)) ([1fd1b5c](https://github.com/forcedotcom/sfdx-core/commit/1fd1b5c40ab7f9b4d66eada94f3ecfa149b263b7)) +### Bug Fixes +- force release ([da5ffa0](https://github.com/forcedotcom/sfdx-core/commit/da5ffa0e51855746decf1b63d6195d793929b846)) +### Features -## [3.21.6](https://github.com/forcedotcom/sfdx-core/compare/v3.21.5...v3.21.6) (2022-06-23) +- deprecate testSetup and refactor TestContext ([#676](https://github.com/forcedotcom/sfdx-core/issues/676)) ([6e2f547](https://github.com/forcedotcom/sfdx-core/commit/6e2f547229199da2e2839e4ea70dabd13089c487)) +## [3.30.14](https://github.com/forcedotcom/sfdx-core/compare/3.30.13...3.30.14) (2022-10-11) +### Bug Fixes -## [3.21.5](https://github.com/forcedotcom/sfdx-core/compare/v3.21.4...v3.21.5) (2022-06-23) +- type on TokenAccessor.set ([#675](https://github.com/forcedotcom/sfdx-core/issues/675)) ([94fdf1e](https://github.com/forcedotcom/sfdx-core/commit/94fdf1ed9ded8f8fbe1a66d55affbd0ac27e79bb)) +## [3.30.13](https://github.com/forcedotcom/sfdx-core/compare/3.30.12...3.30.13) (2022-10-10) ### Bug Fixes -* bump jsforce ([b1e8604](https://github.com/forcedotcom/sfdx-core/commit/b1e8604203b09df7b252fd6520fb73405e287aa4)) +- add tooling query support to autoFetchQuery ([#665](https://github.com/forcedotcom/sfdx-core/issues/665)) ([608b119](https://github.com/forcedotcom/sfdx-core/commit/608b11971d893f7417fcfe5f4eea710f38b8e7cf)) +## [3.30.12](https://github.com/forcedotcom/sfdx-core/compare/3.30.11...3.30.12) (2022-10-08) +### Bug Fixes -## [3.21.4](https://github.com/forcedotcom/sfdx-core/compare/v3.21.3...v3.21.4) (2022-06-22) +- **deps:** bump ts-retry-promise from 0.6.2 to 0.7.0 ([5def87a](https://github.com/forcedotcom/sfdx-core/commit/5def87ae3be6eac81503abfaff96e29ba2c82bdf)) +## [3.30.11](https://github.com/forcedotcom/sfdx-core/compare/3.30.10...3.30.11) (2022-10-07) ### Bug Fixes -* cause release for jsforce again ([0700356](https://github.com/forcedotcom/sfdx-core/commit/0700356759506fce59b426e84fefbe85ae2f247e)) +- update kit, testSetup plus major refactor ([453b886](https://github.com/forcedotcom/sfdx-core/commit/453b8860c16991796252f05a3c933dee1e9d7e3b)) +## [3.30.10](https://github.com/forcedotcom/sfdx-core/compare/3.30.9...3.30.10) (2022-10-04) +## [3.30.9](https://github.com/forcedotcom/sfdx-core/compare/3.30.8...3.30.9) (2022-09-28) -## [3.21.3](https://github.com/forcedotcom/sfdx-core/compare/v3.21.2...v3.21.3) (2022-06-22) +### Bug Fixes +- fix package dir functions ([#660](https://github.com/forcedotcom/sfdx-core/issues/660)) ([7df117c](https://github.com/forcedotcom/sfdx-core/commit/7df117c6b5aecf500af82adb52efe5e931fb8718)) -### Bug Fixes - -* jsforce autofech fix 2 ([3865af9](https://github.com/forcedotcom/sfdx-core/commit/3865af9c607a8739ce6b04a166b746d7057f064c)) - +## [3.30.8](https://github.com/forcedotcom/sfdx-core/compare/3.30.7...3.30.8) (2022-09-23) +### Bug Fixes -## [3.21.2](https://github.com/forcedotcom/sfdx-core/compare/v3.21.1...v3.21.2) (2022-06-21) +- **scratch:** respect `apiVersion` config value ([#656](https://github.com/forcedotcom/sfdx-core/issues/656)) ([1a29482](https://github.com/forcedotcom/sfdx-core/commit/1a294821c07f334494f2e56295dcd1a23570fa4b)) +## [3.30.7](https://github.com/forcedotcom/sfdx-core/compare/3.30.4...3.30.7) (2022-09-23) ### Bug Fixes -* bump jsforce to latest v2 ([8a05add](https://github.com/forcedotcom/sfdx-core/commit/8a05add08c78f2bc3b6e6c30d4f1763e9fda24b0)) +- force build ([cb0b831](https://github.com/forcedotcom/sfdx-core/commit/cb0b8310ca2b2fc9e537229c0034deb1063c3a34)) +- revert 3.30.4 ([#658](https://github.com/forcedotcom/sfdx-core/issues/658)) ([3ed9565](https://github.com/forcedotcom/sfdx-core/commit/3ed95653fd03f80483d0bbd137697cb7df87ddd8)), closes [#657](https://github.com/forcedotcom/sfdx-core/issues/657) [#655](https://github.com/forcedotcom/sfdx-core/issues/655) +## [3.30.4](https://github.com/forcedotcom/sfdx-core/compare/3.30.3...3.30.4) (2022-09-23) +### Bug Fixes -## [3.21.1](https://github.com/forcedotcom/sfdx-core/compare/v3.21.0...v3.21.1) (2022-06-15) +- retire use of pkgdir.name field ([#655](https://github.com/forcedotcom/sfdx-core/issues/655)) ([227f9a8](https://github.com/forcedotcom/sfdx-core/commit/227f9a8663401813b3e8626344fa59464510a732)) +## [3.30.3](https://github.com/forcedotcom/sfdx-core/compare/v3.30.2...3.30.3) (2022-09-20) ### Bug Fixes -* deprecate maxQueryLimit config var ([48105be](https://github.com/forcedotcom/sfdx-core/commit/48105bedf01d69b38a7fa527ad74c78053f7d4ef)) +- add helper functions to project for pkging ([1ed5563](https://github.com/forcedotcom/sfdx-core/commit/1ed556348cd0cc2f8c9dae7125a12bf177206c5c)) +## [3.30.2](https://github.com/forcedotcom/sfdx-core/compare/v3.30.1...v3.30.2) (2022-09-16) +### Bug Fixes -# [3.21.0](https://github.com/forcedotcom/sfdx-core/compare/v3.20.3...v3.21.0) (2022-06-15) +- **logger:** support `SF_*` env vars ([#637](https://github.com/forcedotcom/sfdx-core/issues/637)) ([53c4296](https://github.com/forcedotcom/sfdx-core/commit/53c4296d0ab0728a798e39626a29168371e1a062)) +## [3.30.1](https://github.com/forcedotcom/sfdx-core/compare/v3.30.0...v3.30.1) (2022-09-15) -### Features +### Bug Fixes -* add getConnection method to MockTestOrgData ([#600](https://github.com/forcedotcom/sfdx-core/issues/600)) ([a642f28](https://github.com/forcedotcom/sfdx-core/commit/a642f28dc1179552ba5c646c96d2d55f5b6f3f61)) +- await postOrgCreate hook ([#636](https://github.com/forcedotcom/sfdx-core/issues/636)) ([b9934d2](https://github.com/forcedotcom/sfdx-core/commit/b9934d2df6f5ea49b4f8bae44779aa5cab0e897f)) +# [3.30.0](https://github.com/forcedotcom/sfdx-core/compare/v3.26.3...v3.30.0) (2022-09-12) +## [3.26.3](https://github.com/forcedotcom/sfdx-core/compare/v3.26.2...v3.26.3) (2022-09-06) -## [3.20.3](https://github.com/forcedotcom/sfdx-core/compare/v3.20.2...v3.20.3) (2022-06-15) +## [3.26.2](https://github.com/forcedotcom/sfdx-core/compare/v3.26.1...v3.26.2) (2022-08-16) +## [3.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.26.0...v3.26.1) (2022-08-08) ### Bug Fixes -* **url:** support sandboxes with enhanced domains enabled ([7c958d1](https://github.com/forcedotcom/sfdx-core/commit/7c958d1f59efc6ef55a7b4c60126603616b21794)) +- update jsforce ([0353330](https://github.com/forcedotcom/sfdx-core/commit/03533307f0ea1f8877027a5619c970e1ae2443ec)) +# [3.26.0](https://github.com/forcedotcom/sfdx-core/compare/v3.25.1...v3.26.0) (2022-08-04) +### Features -## [3.20.2](https://github.com/forcedotcom/sfdx-core/compare/v3.20.1...v3.20.2) (2022-06-13) +- remove GlobalInfo ([57bd0fa](https://github.com/forcedotcom/sfdx-core/commit/57bd0fa50c5fe3cc859ca107fd0a18dc1b871c1f)) +## [3.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.25.0...v3.25.1) (2022-08-03) ### Bug Fixes -* instanceUrl config now using org-instance-url ([54cb450](https://github.com/forcedotcom/sfdx-core/commit/54cb450c53f3db5352d9f0fdb83d33dce1da728e)) - - - -## [3.20.1](https://github.com/forcedotcom/sfdx-core/compare/v3.19.5...v3.20.1) (2022-06-08) +- add interop between templates config/env var ([eea3d05](https://github.com/forcedotcom/sfdx-core/commit/eea3d055b75ceb61639e06bc53e309a01f70a8e2)) +# [3.25.0](https://github.com/forcedotcom/sfdx-core/compare/v3.24.5...v3.25.0) (2022-07-29) ### Features -* cause a publish from previous skip ([069c366](https://github.com/forcedotcom/sfdx-core/commit/069c36646f5dc10a4172868ef7b5f9cd82ef7503)) -* safer caching for nuts ([fa0af41](https://github.com/forcedotcom/sfdx-core/commit/fa0af41451a4363c84e9713685c8ece439acf3bc)) +- orgAccessor.get has throwOnNotFound option ([a2ee821](https://github.com/forcedotcom/sfdx-core/commit/a2ee8219adf692de7de17ba254e05f501ef5814c)) + +## [3.24.5](https://github.com/forcedotcom/sfdx-core/compare/v3.24.4...v3.24.5) (2022-07-28) +### Bug Fixes +- set correct file mode for log file ([30aa3fc](https://github.com/forcedotcom/sfdx-core/commit/30aa3fc09ba2bf0db600ee6528fde5b0ff97b217)) -## [3.19.5](https://github.com/forcedotcom/sfdx-core/compare/v3.19.4...v3.19.5) (2022-06-06) +## [3.24.4](https://github.com/forcedotcom/sfdx-core/compare/v3.24.3...v3.24.4) (2022-07-28) +## [3.24.3](https://github.com/forcedotcom/sfdx-core/compare/v3.24.2...v3.24.3) (2022-07-28) ### Bug Fixes -* update `NamedOrgNotFound` err name ([6a6a627](https://github.com/forcedotcom/sfdx-core/commit/6a6a62782046858c062ecb24a1d28631ea1f3bbe)) +- handle ancestor keywords when creating scratch org ([72af55a](https://github.com/forcedotcom/sfdx-core/commit/72af55a53b87f1d81d22dc4e53891b3b0ab2966f)) +## [3.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.24.1...v3.24.2) (2022-07-26) +### Bug Fixes -## [3.19.4](https://github.com/forcedotcom/sfdx-core/compare/v3.19.3...v3.19.4) (2022-06-06) +- use correct field for clone requests ([#623](https://github.com/forcedotcom/sfdx-core/issues/623)) ([2372f03](https://github.com/forcedotcom/sfdx-core/commit/2372f0364b87a7ac498c8d7ef637a9b5fdc725ea)) +## [3.24.1](https://github.com/forcedotcom/sfdx-core/compare/v3.24.0...v3.24.1) (2022-07-21) ### Bug Fixes -* add stat method to OrgAccessor ([f4e297c](https://github.com/forcedotcom/sfdx-core/commit/f4e297c576647b32be62621377d6e3fc5c8dc5f1)) +- bump jsforce ([#622](https://github.com/forcedotcom/sfdx-core/issues/622)) ([c7b53b7](https://github.com/forcedotcom/sfdx-core/commit/c7b53b73977012f81e029a15f39c3fb35bc1041d)) +# [3.24.0](https://github.com/forcedotcom/sfdx-core/compare/v3.23.9...v3.24.0) (2022-07-14) +### Bug Fixes -## [3.19.3](https://github.com/forcedotcom/sfdx-core/compare/v3.19.2...v3.19.3) (2022-06-06) +- align messages/files ([5a5f04d](https://github.com/forcedotcom/sfdx-core/commit/5a5f04d3ea8ffb30fdbbfe2c83824ec56a56ec34)) +- load messages by name ([7c3a2d9](https://github.com/forcedotcom/sfdx-core/commit/7c3a2d9d84f9553bb9cf1bc369b49ca46100484e)) +- use named messages always ([2bb25a9](https://github.com/forcedotcom/sfdx-core/commit/2bb25a9c24fcb7146e363783ea81bc3708060a18)) +### Features +- org.scratchOrgCreate uses all options except hub ([045a7aa](https://github.com/forcedotcom/sfdx-core/commit/045a7aa56c97323aa8b3191c4879cd1b43f0cfb1)) -## [3.19.2](https://github.com/forcedotcom/sfdx-core/compare/v3.19.1...v3.19.2) (2022-06-02) +## [3.23.9](https://github.com/forcedotcom/sfdx-core/compare/v3.23.8...v3.23.9) (2022-07-14) +## [3.23.8](https://github.com/forcedotcom/sfdx-core/compare/v3.23.7...v3.23.8) (2022-07-13) ### Bug Fixes -* loosen audience url determination ([#588](https://github.com/forcedotcom/sfdx-core/issues/588)) ([a58ab89](https://github.com/forcedotcom/sfdx-core/commit/a58ab89e2ada34fbdb6d8c72d88966a5281db60b)) +- remove greedy matching for AuthInfo encryptedKeys ([12c6dcc](https://github.com/forcedotcom/sfdx-core/commit/12c6dcc5137a48d59e0da4a20426d8fa2cf747d9)) +## [3.23.7](https://github.com/forcedotcom/sfdx-core/compare/v3.23.6...v3.23.7) (2022-07-08) +### Bug Fixes -## [3.19.1](https://github.com/forcedotcom/sfdx-core/compare/v3.19.0...v3.19.1) (2022-05-27) +- add structure writer interface and refactor ([daef19c](https://github.com/forcedotcom/sfdx-core/commit/daef19cb3a4d145ebb22c4f721a1bd47ffddce40)) +## [3.23.6](https://github.com/forcedotcom/sfdx-core/compare/v3.23.5...v3.23.6) (2022-07-06) ### Bug Fixes -* env var resolution in ConfigAggregator ([#590](https://github.com/forcedotcom/sfdx-core/issues/590)) ([a65cfbd](https://github.com/forcedotcom/sfdx-core/commit/a65cfbdd0e2a6c3806aa4da3270b237f68b37133)) +- workaround for jsforce update bug ([1776f50](https://github.com/forcedotcom/sfdx-core/commit/1776f505671a5a764c4e966736c2981df2b178a4)) +## [3.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.23.4...v3.23.5) (2022-07-06) +### Bug Fixes -# [3.19.0](https://github.com/forcedotcom/sfdx-core/compare/v3.18.3...v3.19.0) (2022-05-20) +- add resolveAlias ([#605](https://github.com/forcedotcom/sfdx-core/issues/605)) ([ffa9ed6](https://github.com/forcedotcom/sfdx-core/commit/ffa9ed63ea583baa327071db4030ea5346d1128f)) +## [3.23.4](https://github.com/forcedotcom/sfdx-core/compare/v3.23.3...v3.23.4) (2022-07-05) -### Features +### Bug Fixes -* missing prop and logic correction ([debe97e](https://github.com/forcedotcom/sfdx-core/commit/debe97e08f54bbd55edd2cb5b18e9d14abd3652f)) -* property on org with inteligent defaults and handling of undefined ([e7295d3](https://github.com/forcedotcom/sfdx-core/commit/e7295d38f2b8defdb54a77e61b4ef8862e5398f9)) -* tracking property on AuthFields ([2243d34](https://github.com/forcedotcom/sfdx-core/commit/2243d345c5cc81bd637c889adbe1db6eae6c93fc)) -* tracksSource in TestSetup mock ([7544c60](https://github.com/forcedotcom/sfdx-core/commit/7544c604bd4a32d21d105e8472f41b2d37fbf601)) +- force publish ([3eb660d](https://github.com/forcedotcom/sfdx-core/commit/3eb660dd23ee959e085a9ac3dbd65de92e511d74)) +## [3.23.3](https://github.com/forcedotcom/sfdx-core/compare/v3.23.2...v3.23.3) (2022-06-30) +### Bug Fixes -## [3.18.3](https://github.com/forcedotcom/sfdx-core/compare/v3.18.2...v3.18.3) (2022-05-20) +- force publish ([b767232](https://github.com/forcedotcom/sfdx-core/commit/b767232f2f76a4a00387e37128428ad18221a594)) +## [3.23.2](https://github.com/forcedotcom/sfdx-core/compare/v3.23.1...v3.23.2) (2022-06-30) +### Bug Fixes -## [3.18.2](https://github.com/forcedotcom/sfdx-core/compare/v3.18.1...v3.18.2) (2022-05-17) +- add getter for shape dir name ([#614](https://github.com/forcedotcom/sfdx-core/issues/614)) ([06282d8](https://github.com/forcedotcom/sfdx-core/commit/06282d868b508b2d8417fcd4de404a7863c74b14)) +## [3.23.1](https://github.com/forcedotcom/sfdx-core/compare/v3.23.0...v3.23.1) (2022-06-30) ### Bug Fixes -* remove unreachable code ([#585](https://github.com/forcedotcom/sfdx-core/issues/585)) ([2a6d611](https://github.com/forcedotcom/sfdx-core/commit/2a6d611a9ded7d4a0718864ca4023a0f7f259e8a)) +- isScratch should be boolean ([ebda782](https://github.com/forcedotcom/sfdx-core/commit/ebda782bfd4f3927bc12ce4e6402673361ac47d6)) +- update AuthFields type ([766efec](https://github.com/forcedotcom/sfdx-core/commit/766efec26f404cc1f0e4d380d82f4f05aa455e95)) +# [3.23.0](https://github.com/forcedotcom/sfdx-core/compare/v3.22.1...v3.23.0) (2022-06-30) +### Features -## [3.18.1](https://github.com/forcedotcom/sfdx-core/compare/v3.18.0...v3.18.1) (2022-05-16) +- support more enhanced domains, wider test cases ([f1bac94](https://github.com/forcedotcom/sfdx-core/commit/f1bac945d9b135a9a8165260b95f7de5568ccca6)) +## [3.22.1](https://github.com/forcedotcom/sfdx-core/compare/v3.22.0...v3.22.1) (2022-06-28) +### Bug Fixes -# [3.18.0](https://github.com/forcedotcom/sfdx-core/compare/v3.17.0...v3.18.0) (2022-05-12) +- encrypted key regex tests will no longer be stateful ([06b7fa2](https://github.com/forcedotcom/sfdx-core/commit/06b7fa2f41401155b472c84f13cbf5608150a43e)) +- update dev-scripts so yarn build won't change line endings for LICENSE.txt on Windows ([ec5e48e](https://github.com/forcedotcom/sfdx-core/commit/ec5e48ee1dab2b3999f630aa56c53d353baa717e)) +# [3.22.0](https://github.com/forcedotcom/sfdx-core/compare/v3.21.6...v3.22.0) (2022-06-23) ### Features -* bump jsforce for metadata rest api ([#583](https://github.com/forcedotcom/sfdx-core/issues/583)) ([6addcfd](https://github.com/forcedotcom/sfdx-core/commit/6addcfd9b2bd480974f6c965b4d04c610a38f2db)) +- modify uniqid to accept length and template ([#604](https://github.com/forcedotcom/sfdx-core/issues/604)) ([1fd1b5c](https://github.com/forcedotcom/sfdx-core/commit/1fd1b5c40ab7f9b4d66eada94f3ecfa149b263b7)) +## [3.21.6](https://github.com/forcedotcom/sfdx-core/compare/v3.21.5...v3.21.6) (2022-06-23) +## [3.21.5](https://github.com/forcedotcom/sfdx-core/compare/v3.21.4...v3.21.5) (2022-06-23) -# [3.17.0](https://github.com/forcedotcom/sfdx-core/compare/v3.16.2...v3.17.0) (2022-05-12) +### Bug Fixes +- bump jsforce ([b1e8604](https://github.com/forcedotcom/sfdx-core/commit/b1e8604203b09df7b252fd6520fb73405e287aa4)) -### Features +## [3.21.4](https://github.com/forcedotcom/sfdx-core/compare/v3.21.3...v3.21.4) (2022-06-22) + +### Bug Fixes -* sandboxStatus for v3 ([#571](https://github.com/forcedotcom/sfdx-core/issues/571)) ([60a004b](https://github.com/forcedotcom/sfdx-core/commit/60a004b663d918ec8b37d6ded7ddf12ce112b7f8)) +- cause release for jsforce again ([0700356](https://github.com/forcedotcom/sfdx-core/commit/0700356759506fce59b426e84fefbe85ae2f247e)) +## [3.21.3](https://github.com/forcedotcom/sfdx-core/compare/v3.21.2...v3.21.3) (2022-06-22) +### Bug Fixes -## [3.16.2](https://github.com/forcedotcom/sfdx-core/compare/v3.16.1...v3.16.2) (2022-05-11) +- jsforce autofech fix 2 ([3865af9](https://github.com/forcedotcom/sfdx-core/commit/3865af9c607a8739ce6b04a166b746d7057f064c)) +## [3.21.2](https://github.com/forcedotcom/sfdx-core/compare/v3.21.1...v3.21.2) (2022-06-21) +### Bug Fixes -## [3.16.1](https://github.com/forcedotcom/sfdx-core/compare/v3.16.0...v3.16.1) (2022-05-11) +- bump jsforce to latest v2 ([8a05add](https://github.com/forcedotcom/sfdx-core/commit/8a05add08c78f2bc3b6e6c30d4f1763e9fda24b0)) +## [3.21.1](https://github.com/forcedotcom/sfdx-core/compare/v3.21.0...v3.21.1) (2022-06-15) ### Bug Fixes -* homedir can change after Core loads ([bb1e4f5](https://github.com/forcedotcom/sfdx-core/commit/bb1e4f5b1f59269f6d48a5389b1d76eeee252db0)) +- deprecate maxQueryLimit config var ([48105be](https://github.com/forcedotcom/sfdx-core/commit/48105bedf01d69b38a7fa527ad74c78053f7d4ef)) + +# [3.21.0](https://github.com/forcedotcom/sfdx-core/compare/v3.20.3...v3.21.0) (2022-06-15) +### Features +- add getConnection method to MockTestOrgData ([#600](https://github.com/forcedotcom/sfdx-core/issues/600)) ([a642f28](https://github.com/forcedotcom/sfdx-core/commit/a642f28dc1179552ba5c646c96d2d55f5b6f3f61)) -# [3.16.0](https://github.com/forcedotcom/sfdx-core/compare/v3.15.5...v3.16.0) (2022-05-04) +## [3.20.3](https://github.com/forcedotcom/sfdx-core/compare/v3.20.2...v3.20.3) (2022-06-15) +### Bug Fixes + +- **url:** support sandboxes with enhanced domains enabled ([7c958d1](https://github.com/forcedotcom/sfdx-core/commit/7c958d1f59efc6ef55a7b4c60126603616b21794)) + +## [3.20.2](https://github.com/forcedotcom/sfdx-core/compare/v3.20.1...v3.20.2) (2022-06-13) ### Bug Fixes -* disable schemaValidation ([#578](https://github.com/forcedotcom/sfdx-core/issues/578)) ([9b60cb4](https://github.com/forcedotcom/sfdx-core/commit/9b60cb4dd3181f0bfbafadb72bcd0904e851084f)) +- instanceUrl config now using org-instance-url ([54cb450](https://github.com/forcedotcom/sfdx-core/commit/54cb450c53f3db5352d9f0fdb83d33dce1da728e)) +## [3.20.1](https://github.com/forcedotcom/sfdx-core/compare/v3.19.5...v3.20.1) (2022-06-08) ### Features -* force v3 release ([05620c8](https://github.com/forcedotcom/sfdx-core/commit/05620c80256052a1b814b631e9afd951d63bea9e)) +- cause a publish from previous skip ([069c366](https://github.com/forcedotcom/sfdx-core/commit/069c36646f5dc10a4172868ef7b5f9cd82ef7503)) +- safer caching for nuts ([fa0af41](https://github.com/forcedotcom/sfdx-core/commit/fa0af41451a4363c84e9713685c8ece439acf3bc)) +## [3.19.5](https://github.com/forcedotcom/sfdx-core/compare/v3.19.4...v3.19.5) (2022-06-06) +### Bug Fixes -## [3.15.5](https://github.com/forcedotcom/sfdx-core/compare/v3.15.4...v3.15.5) (2022-05-03) +- update `NamedOrgNotFound` err name ([6a6a627](https://github.com/forcedotcom/sfdx-core/commit/6a6a62782046858c062ecb24a1d28631ea1f3bbe)) +## [3.19.4](https://github.com/forcedotcom/sfdx-core/compare/v3.19.3...v3.19.4) (2022-06-06) ### Bug Fixes -* SfdxConfigAggregator ([238ad07](https://github.com/forcedotcom/sfdx-core/commit/238ad0757cc332ecc1897bd7230140a31a559332)) +- add stat method to OrgAccessor ([f4e297c](https://github.com/forcedotcom/sfdx-core/commit/f4e297c576647b32be62621377d6e3fc5c8dc5f1)) +## [3.19.3](https://github.com/forcedotcom/sfdx-core/compare/v3.19.2...v3.19.3) (2022-06-06) +## [3.19.2](https://github.com/forcedotcom/sfdx-core/compare/v3.19.1...v3.19.2) (2022-06-02) -## [3.15.4](https://github.com/forcedotcom/sfdx-core/compare/v3.15.3...v3.15.4) (2022-05-03) +### Bug Fixes + +- loosen audience url determination ([#588](https://github.com/forcedotcom/sfdx-core/issues/588)) ([a58ab89](https://github.com/forcedotcom/sfdx-core/commit/a58ab89e2ada34fbdb6d8c72d88966a5281db60b)) +## [3.19.1](https://github.com/forcedotcom/sfdx-core/compare/v3.19.0...v3.19.1) (2022-05-27) ### Bug Fixes -* SfdxConfigAggregator ([#576](https://github.com/forcedotcom/sfdx-core/issues/576)) ([9a25928](https://github.com/forcedotcom/sfdx-core/commit/9a259282efd3d2d97da42a54fd76c45d7f73df27)) +- env var resolution in ConfigAggregator ([#590](https://github.com/forcedotcom/sfdx-core/issues/590)) ([a65cfbd](https://github.com/forcedotcom/sfdx-core/commit/a65cfbdd0e2a6c3806aa4da3270b237f68b37133)) +# [3.19.0](https://github.com/forcedotcom/sfdx-core/compare/v3.18.3...v3.19.0) (2022-05-20) +### Features -## [3.15.3](https://github.com/forcedotcom/sfdx-core/compare/v3.15.2...v3.15.3) (2022-05-02) +- missing prop and logic correction ([debe97e](https://github.com/forcedotcom/sfdx-core/commit/debe97e08f54bbd55edd2cb5b18e9d14abd3652f)) +- property on org with inteligent defaults and handling of undefined ([e7295d3](https://github.com/forcedotcom/sfdx-core/commit/e7295d38f2b8defdb54a77e61b4ef8862e5398f9)) +- tracking property on AuthFields ([2243d34](https://github.com/forcedotcom/sfdx-core/commit/2243d345c5cc81bd637c889adbe1db6eae6c93fc)) +- tracksSource in TestSetup mock ([7544c60](https://github.com/forcedotcom/sfdx-core/commit/7544c604bd4a32d21d105e8472f41b2d37fbf601)) +## [3.18.3](https://github.com/forcedotcom/sfdx-core/compare/v3.18.2...v3.18.3) (2022-05-20) -### Bug Fixes +## [3.18.2](https://github.com/forcedotcom/sfdx-core/compare/v3.18.1...v3.18.2) (2022-05-17) -* SfdxConfigAggregator ([6ee1437](https://github.com/forcedotcom/sfdx-core/commit/6ee14378f10df123ac38325853bc3b83d4d953bd)) +### Bug Fixes +- remove unreachable code ([#585](https://github.com/forcedotcom/sfdx-core/issues/585)) ([2a6d611](https://github.com/forcedotcom/sfdx-core/commit/2a6d611a9ded7d4a0718864ca4023a0f7f259e8a)) +## [3.18.1](https://github.com/forcedotcom/sfdx-core/compare/v3.18.0...v3.18.1) (2022-05-16) -## [3.15.2](https://github.com/forcedotcom/sfdx-core/compare/v3.15.1...v3.15.2) (2022-05-02) +# [3.18.0](https://github.com/forcedotcom/sfdx-core/compare/v3.17.0...v3.18.0) (2022-05-12) +### Features -### Bug Fixes +- bump jsforce for metadata rest api ([#583](https://github.com/forcedotcom/sfdx-core/issues/583)) ([6addcfd](https://github.com/forcedotcom/sfdx-core/commit/6addcfd9b2bd480974f6c965b4d04c610a38f2db)) -* allow ConfigAggregator to accept custom config vars ([#575](https://github.com/forcedotcom/sfdx-core/issues/575)) ([2642128](https://github.com/forcedotcom/sfdx-core/commit/264212898cf14d8f34638926841ace89abf7efb0)) +# [3.17.0](https://github.com/forcedotcom/sfdx-core/compare/v3.16.2...v3.17.0) (2022-05-12) +### Features +- sandboxStatus for v3 ([#571](https://github.com/forcedotcom/sfdx-core/issues/571)) ([60a004b](https://github.com/forcedotcom/sfdx-core/commit/60a004b663d918ec8b37d6ded7ddf12ce112b7f8)) -## [3.15.1](https://github.com/forcedotcom/sfdx-core/compare/v3.15.0...v3.15.1) (2022-04-28) +## [3.16.2](https://github.com/forcedotcom/sfdx-core/compare/v3.16.1...v3.16.2) (2022-05-11) +## [3.16.1](https://github.com/forcedotcom/sfdx-core/compare/v3.16.0...v3.16.1) (2022-05-11) ### Bug Fixes -* replace jsen ([664da58](https://github.com/forcedotcom/sfdx-core/commit/664da58cbe06019465ccf70ed17dfafb2425e06b)) - +- homedir can change after Core loads ([bb1e4f5](https://github.com/forcedotcom/sfdx-core/commit/bb1e4f5b1f59269f6d48a5389b1d76eeee252db0)) +# [3.16.0](https://github.com/forcedotcom/sfdx-core/compare/v3.15.5...v3.16.0) (2022-05-04) -# [3.15.0](https://github.com/forcedotcom/sfdx-core/compare/v3.14.0...v3.15.0) (2022-04-26) +### Bug Fixes +- disable schemaValidation ([#578](https://github.com/forcedotcom/sfdx-core/issues/578)) ([9b60cb4](https://github.com/forcedotcom/sfdx-core/commit/9b60cb4dd3181f0bfbafadb72bcd0904e851084f)) ### Features -* core changes to support create scratch and sandboxes ([#570](https://github.com/forcedotcom/sfdx-core/issues/570)) ([916eeb1](https://github.com/forcedotcom/sfdx-core/commit/916eeb1f96bebd5dce255f13c838ac0b10bf5b96)) +- force v3 release ([05620c8](https://github.com/forcedotcom/sfdx-core/commit/05620c80256052a1b814b631e9afd951d63bea9e)) +## [3.15.5](https://github.com/forcedotcom/sfdx-core/compare/v3.15.4...v3.15.5) (2022-05-03) +### Bug Fixes -# [3.14.0](https://github.com/forcedotcom/sfdx-core/compare/v3.13.1...v3.14.0) (2022-04-25) +- SfdxConfigAggregator ([238ad07](https://github.com/forcedotcom/sfdx-core/commit/238ad0757cc332ecc1897bd7230140a31a559332)) +## [3.15.4](https://github.com/forcedotcom/sfdx-core/compare/v3.15.3...v3.15.4) (2022-05-03) -### Features +### Bug Fixes -* add SfdxConfigAggregator ([#563](https://github.com/forcedotcom/sfdx-core/issues/563)) ([cd4debd](https://github.com/forcedotcom/sfdx-core/commit/cd4debdc99046580090b5d21bbd9da9030822d4a)) +- SfdxConfigAggregator ([#576](https://github.com/forcedotcom/sfdx-core/issues/576)) ([9a25928](https://github.com/forcedotcom/sfdx-core/commit/9a259282efd3d2d97da42a54fd76c45d7f73df27)) +## [3.15.3](https://github.com/forcedotcom/sfdx-core/compare/v3.15.2...v3.15.3) (2022-05-02) +### Bug Fixes -## [3.13.1](https://github.com/forcedotcom/sfdx-core/compare/v3.13.0...v3.13.1) (2022-04-21) +- SfdxConfigAggregator ([6ee1437](https://github.com/forcedotcom/sfdx-core/commit/6ee14378f10df123ac38325853bc3b83d4d953bd)) +## [3.15.2](https://github.com/forcedotcom/sfdx-core/compare/v3.15.1...v3.15.2) (2022-05-02) ### Bug Fixes -* log rotation errors ([#564](https://github.com/forcedotcom/sfdx-core/issues/564)) ([8a4c9de](https://github.com/forcedotcom/sfdx-core/commit/8a4c9de85840ae0efa0ee8a27494d63a61545da5)) +- allow ConfigAggregator to accept custom config vars ([#575](https://github.com/forcedotcom/sfdx-core/issues/575)) ([2642128](https://github.com/forcedotcom/sfdx-core/commit/264212898cf14d8f34638926841ace89abf7efb0)) +## [3.15.1](https://github.com/forcedotcom/sfdx-core/compare/v3.15.0...v3.15.1) (2022-04-28) +### Bug Fixes -# [3.13.0](https://github.com/forcedotcom/sfdx-core/compare/v3.12.2...v3.13.0) (2022-04-20) +- replace jsen ([664da58](https://github.com/forcedotcom/sfdx-core/commit/664da58cbe06019465ccf70ed17dfafb2425e06b)) +# [3.15.0](https://github.com/forcedotcom/sfdx-core/compare/v3.14.0...v3.15.0) (2022-04-26) ### Features -* detect if org is a devhub at auth time ([#560](https://github.com/forcedotcom/sfdx-core/issues/560)) ([958e2e7](https://github.com/forcedotcom/sfdx-core/commit/958e2e7317e670b738b3e7c82260ef741e1416d2)) +- core changes to support create scratch and sandboxes ([#570](https://github.com/forcedotcom/sfdx-core/issues/570)) ([916eeb1](https://github.com/forcedotcom/sfdx-core/commit/916eeb1f96bebd5dce255f13c838ac0b10bf5b96)) +# [3.14.0](https://github.com/forcedotcom/sfdx-core/compare/v3.13.1...v3.14.0) (2022-04-25) +### Features -## [3.12.2](https://github.com/forcedotcom/sfdx-core/compare/v3.12.1...v3.12.2) (2022-04-14) +- add SfdxConfigAggregator ([#563](https://github.com/forcedotcom/sfdx-core/issues/563)) ([cd4debd](https://github.com/forcedotcom/sfdx-core/commit/cd4debdc99046580090b5d21bbd9da9030822d4a)) +## [3.13.1](https://github.com/forcedotcom/sfdx-core/compare/v3.13.0...v3.13.1) (2022-04-21) ### Bug Fixes -* sandbox cname recognition ([#556](https://github.com/forcedotcom/sfdx-core/issues/556)) ([2f85709](https://github.com/forcedotcom/sfdx-core/commit/2f8570912cae38fb0ddeaa37836395444c47611a)) +- log rotation errors ([#564](https://github.com/forcedotcom/sfdx-core/issues/564)) ([8a4c9de](https://github.com/forcedotcom/sfdx-core/commit/8a4c9de85840ae0efa0ee8a27494d63a61545da5)) +# [3.13.0](https://github.com/forcedotcom/sfdx-core/compare/v3.12.2...v3.13.0) (2022-04-20) +### Features -## [3.12.1](https://github.com/forcedotcom/sfdx-core/compare/v3.12.0...v3.12.1) (2022-04-05) +- detect if org is a devhub at auth time ([#560](https://github.com/forcedotcom/sfdx-core/issues/560)) ([958e2e7](https://github.com/forcedotcom/sfdx-core/commit/958e2e7317e670b738b3e7c82260ef741e1416d2)) +## [3.12.2](https://github.com/forcedotcom/sfdx-core/compare/v3.12.1...v3.12.2) (2022-04-14) ### Bug Fixes -* more FormData with buffers and headers ([5ebf78f](https://github.com/forcedotcom/sfdx-core/commit/5ebf78fe2b037df395c87197b90ee06a0d34d5d0)) +- sandbox cname recognition ([#556](https://github.com/forcedotcom/sfdx-core/issues/556)) ([2f85709](https://github.com/forcedotcom/sfdx-core/commit/2f8570912cae38fb0ddeaa37836395444c47611a)) + +## [3.12.1](https://github.com/forcedotcom/sfdx-core/compare/v3.12.0...v3.12.1) (2022-04-05) +### Bug Fixes +- more FormData with buffers and headers ([5ebf78f](https://github.com/forcedotcom/sfdx-core/commit/5ebf78fe2b037df395c87197b90ee06a0d34d5d0)) # [3.12.0](https://github.com/forcedotcom/sfdx-core/compare/v3.11.1...v3.12.0) (2022-04-04) - ### Features -* move common authinfo utils to core ([01b8cf3](https://github.com/forcedotcom/sfdx-core/commit/01b8cf3fa38162380da5ce15f6dee1d2a5d2d72d)) - - +- move common authinfo utils to core ([01b8cf3](https://github.com/forcedotcom/sfdx-core/commit/01b8cf3fa38162380da5ce15f6dee1d2a5d2d72d)) ## [3.11.1](https://github.com/forcedotcom/sfdx-core/compare/v3.11.0...v3.11.1) (2022-04-01) - - # [3.11.0](https://github.com/forcedotcom/sfdx-core/compare/v3.10.1...v3.11.0) (2022-03-30) - ### Features -* normalize config vars for sf ([#543](https://github.com/forcedotcom/sfdx-core/issues/543)) ([93f3cbe](https://github.com/forcedotcom/sfdx-core/commit/93f3cbe90103fa159f21f532ffc173931037651c)) - - +- normalize config vars for sf ([#543](https://github.com/forcedotcom/sfdx-core/issues/543)) ([93f3cbe](https://github.com/forcedotcom/sfdx-core/commit/93f3cbe90103fa159f21f532ffc173931037651c)) ## [3.10.1](https://github.com/forcedotcom/sfdx-core/compare/v3.10.0...v3.10.1) (2022-03-24) - ### Bug Fixes -* rotating file logs ([ef5df25](https://github.com/forcedotcom/sfdx-core/commit/ef5df25c17a67541d12d5c228c18b75775251d98)) - - +- rotating file logs ([ef5df25](https://github.com/forcedotcom/sfdx-core/commit/ef5df25c17a67541d12d5c228c18b75775251d98)) # [3.10.0](https://github.com/forcedotcom/sfdx-core/compare/v3.9.0...v3.10.0) (2022-03-23) - ### Bug Fixes -* casing typo for import ([066a2bb](https://github.com/forcedotcom/sfdx-core/commit/066a2bbb37b07f62415f021ef511344976315128)) -* warnings about tracking aren't a throw (org will still auth, default) ([38114a3](https://github.com/forcedotcom/sfdx-core/commit/38114a3526267a615fa8f5d3470b79c9b36a8fa8)) - +- casing typo for import ([066a2bb](https://github.com/forcedotcom/sfdx-core/commit/066a2bbb37b07f62415f021ef511344976315128)) +- warnings about tracking aren't a throw (org will still auth, default) ([38114a3](https://github.com/forcedotcom/sfdx-core/commit/38114a3526267a615fa8f5d3470b79c9b36a8fa8)) ### Features -* lifecycle events for scratch org create ([cba673b](https://github.com/forcedotcom/sfdx-core/commit/cba673b515df311165f3c392b155fcf5fbf9e2c6)) -* scratch org lifecycle events ([541349d](https://github.com/forcedotcom/sfdx-core/commit/541349d84b4784356d8bc504d1e331450487b6ec)) - - +- lifecycle events for scratch org create ([cba673b](https://github.com/forcedotcom/sfdx-core/commit/cba673b515df311165f3c392b155fcf5fbf9e2c6)) +- scratch org lifecycle events ([541349d](https://github.com/forcedotcom/sfdx-core/commit/541349d84b4784356d8bc504d1e331450487b6ec)) # [3.9.0](https://github.com/forcedotcom/sfdx-core/compare/v3.8.1...v3.9.0) (2022-03-21) - ### Features -* add TTLConfig ([#538](https://github.com/forcedotcom/sfdx-core/issues/538)) ([e623241](https://github.com/forcedotcom/sfdx-core/commit/e623241c7e513778c8f179dde4dc16e603a3778c)) - - +- add TTLConfig ([#538](https://github.com/forcedotcom/sfdx-core/issues/538)) ([e623241](https://github.com/forcedotcom/sfdx-core/commit/e623241c7e513778c8f179dde4dc16e603a3778c)) ## [3.8.1](https://github.com/forcedotcom/sfdx-core/compare/v3.8.0...v3.8.1) (2022-03-18) - ### Bug Fixes -* adjust mock org test data to conform to v3 ([38faf50](https://github.com/forcedotcom/sfdx-core/commit/38faf5063931955066312c24b4188b12c40098a5)) -* side effects function should not save when no changes ([#541](https://github.com/forcedotcom/sfdx-core/issues/541)) ([6bfb841](https://github.com/forcedotcom/sfdx-core/commit/6bfb84172fdf74882102b9ffc6e6fbfe58e6ffbc)) - - +- adjust mock org test data to conform to v3 ([38faf50](https://github.com/forcedotcom/sfdx-core/commit/38faf5063931955066312c24b4188b12c40098a5)) +- side effects function should not save when no changes ([#541](https://github.com/forcedotcom/sfdx-core/issues/541)) ([6bfb841](https://github.com/forcedotcom/sfdx-core/commit/6bfb84172fdf74882102b9ffc6e6fbfe58e6ffbc)) # [3.8.0](https://github.com/forcedotcom/sfdx-core/compare/v3.7.9...v3.8.0) (2022-03-09) - ### Features -* add handle side effect function to authinfo ([64c78e7](https://github.com/forcedotcom/sfdx-core/commit/64c78e74bc5e1cfb748fd2d64e4b1e8fc1062bf6)) - - +- add handle side effect function to authinfo ([64c78e7](https://github.com/forcedotcom/sfdx-core/commit/64c78e74bc5e1cfb748fd2d64e4b1e8fc1062bf6)) ## [3.7.9](https://github.com/forcedotcom/sfdx-core/compare/v3.7.8...v3.7.9) (2022-03-04) - ### Bug Fixes -* error literal to match the error thrown ([#533](https://github.com/forcedotcom/sfdx-core/issues/533)) ([b91ce5c](https://github.com/forcedotcom/sfdx-core/commit/b91ce5c329c9b2b88fb4b0ad028aee5f6d5b6e77)) - - +- error literal to match the error thrown ([#533](https://github.com/forcedotcom/sfdx-core/issues/533)) ([b91ce5c](https://github.com/forcedotcom/sfdx-core/commit/b91ce5c329c9b2b88fb4b0ad028aee5f6d5b6e77)) ## [3.7.8](https://github.com/forcedotcom/sfdx-core/compare/v3.7.7...v3.7.8) (2022-03-03) - ### Bug Fixes -* add create warning and info convenience functions ([#526](https://github.com/forcedotcom/sfdx-core/issues/526)) ([e3428b3](https://github.com/forcedotcom/sfdx-core/commit/e3428b35e00b9cee3c90153ed6ce08b352535ff7)) - - +- add create warning and info convenience functions ([#526](https://github.com/forcedotcom/sfdx-core/issues/526)) ([e3428b3](https://github.com/forcedotcom/sfdx-core/commit/e3428b35e00b9cee3c90153ed6ce08b352535ff7)) ## [3.7.7](https://github.com/forcedotcom/sfdx-core/compare/v3.7.6...v3.7.7) (2022-03-01) - - ## [3.7.6](https://github.com/forcedotcom/sfdx-core/compare/v4.0.0...v3.7.6) (2022-02-28) - - # [4.0.0](https://github.com/forcedotcom/sfdx-core/compare/v2.35.2...v4.0.0) (2022-02-28) - - ## [3.7.5](https://github.com/forcedotcom/sfdx-core/compare/v2.35.1...v3.7.5) (2022-02-14) - ### Bug Fixes -* add env vars from sfdx-cli init to envvars ([#520](https://github.com/forcedotcom/sfdx-core/issues/520)) ([8ef2785](https://github.com/forcedotcom/sfdx-core/commit/8ef27859d95bfffc5999b14f4792874d04f0504c)) - - +- add env vars from sfdx-cli init to envvars ([#520](https://github.com/forcedotcom/sfdx-core/issues/520)) ([8ef2785](https://github.com/forcedotcom/sfdx-core/commit/8ef27859d95bfffc5999b14f4792874d04f0504c)) ## [3.7.4](https://github.com/forcedotcom/sfdx-core/compare/v2.35.0...v3.7.4) (2022-02-07) - ### Bug Fixes -* pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) - - +- pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) ## [3.7.3](https://github.com/forcedotcom/sfdx-core/compare/v2.33.1...v3.7.3) (2021-12-16) - - ## [3.7.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.1...v3.7.2) (2021-10-28) - ### Bug Fixes -* make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) - - +- make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) ## [3.7.1](https://github.com/forcedotcom/sfdx-core/compare/v2.28.2...v3.7.1) (2021-10-28) - - # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) ## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - - ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.35.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.5...v2.35.2) (2022-02-16) - ### Bug Fixes -* network error tolerance ([#517](https://github.com/forcedotcom/sfdx-core/issues/517)) ([676ebfe](https://github.com/forcedotcom/sfdx-core/commit/676ebfe58b13826b53f461b2fef321c21f583004)) - - +- network error tolerance ([#517](https://github.com/forcedotcom/sfdx-core/issues/517)) ([676ebfe](https://github.com/forcedotcom/sfdx-core/commit/676ebfe58b13826b53f461b2fef321c21f583004)) ## [2.35.1](https://github.com/forcedotcom/sfdx-core/compare/v3.7.4...v2.35.1) (2022-02-10) - ### Bug Fixes -* add error message on failed settings deploy ([e218b1e](https://github.com/forcedotcom/sfdx-core/commit/e218b1e40414ea9e4fec256b74224626d96eff4a)) -* prefer instanceUrl for loginUrl on user:create ([#518](https://github.com/forcedotcom/sfdx-core/issues/518)) ([c070a87](https://github.com/forcedotcom/sfdx-core/commit/c070a871861409dea722e85845eeb91f262ab66f)) - - +- add error message on failed settings deploy ([e218b1e](https://github.com/forcedotcom/sfdx-core/commit/e218b1e40414ea9e4fec256b74224626d96eff4a)) +- prefer instanceUrl for loginUrl on user:create ([#518](https://github.com/forcedotcom/sfdx-core/issues/518)) ([c070a87](https://github.com/forcedotcom/sfdx-core/commit/c070a871861409dea722e85845eeb91f262ab66f)) # [2.35.0](https://github.com/forcedotcom/sfdx-core/compare/v2.34.2...v2.35.0) (2022-01-25) - ### Bug Fixes -* jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) - - +- jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) ## [2.34.2](https://github.com/forcedotcom/sfdx-core/compare/v2.33.2...v2.34.2) (2022-01-25) - - ## [2.33.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.3...v2.33.2) (2022-01-25) - ### Bug Fixes -* correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) -* exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) -* refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) -* remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) -* save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) - - +- correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) +- exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) +- refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) +- remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) +- save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) ## [2.33.1](https://github.com/forcedotcom/sfdx-core/compare/v2.33.0...v2.33.1) (2021-12-15) - ### Bug Fixes -* faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) - - +- faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) # [2.33.0](https://github.com/forcedotcom/sfdx-core/compare/v2.32.0...v2.33.0) (2021-12-14) - ### Features -* sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) - - +- sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) # [2.32.0](https://github.com/forcedotcom/sfdx-core/compare/v2.31.1...v2.32.0) (2021-12-14) - ### Bug Fixes -* no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) -* remove redundant warnings about no listerners on warnings ([7a5bd23](https://github.com/forcedotcom/sfdx-core/commit/7a5bd2390713da929e886f41d9dcbc811104f99a)) - +- no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) +- remove redundant warnings about no listerners on warnings ([7a5bd23](https://github.com/forcedotcom/sfdx-core/commit/7a5bd2390713da929e886f41d9dcbc811104f99a)) ### Features -* switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) - +- switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) ### Reverts -* Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) - - +- Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) ## [2.31.1](https://github.com/forcedotcom/sfdx-core/compare/v2.31.0...v2.31.1) (2021-12-06) - - # [2.31.0](https://github.com/forcedotcom/sfdx-core/compare/v2.30.1...v2.31.0) (2021-11-30) - ### Features -* bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) - - +- bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) ## [2.30.1](https://github.com/forcedotcom/sfdx-core/compare/v2.30.0...v2.30.1) (2021-11-30) - ### Bug Fixes -* better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) - - +- better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) # [2.30.0](https://github.com/forcedotcom/sfdx-core/compare/v2.29.0...v2.30.0) (2021-11-25) - ### Features -* delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) - - +- delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) # [2.29.0](https://github.com/forcedotcom/sfdx-core/compare/v2.28.4...v2.29.0) (2021-11-17) - ### Bug Fixes -* use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) - - +- use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) ## [2.28.4](https://github.com/forcedotcom/sfdx-core/compare/v2.28.3...v2.28.4) (2021-11-10) - ### Bug Fixes -* bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) -* transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) - +- bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) +- transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) ### Features -* cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) -* use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) -* warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) -* warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) - - +- cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) +- use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) +- warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) +- warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) ## [2.28.3](https://github.com/forcedotcom/sfdx-core/compare/v3.7.2...v2.28.3) (2021-11-08) - ### Bug Fixes -* fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) -* force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) - - +- fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) +- force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) ## [2.28.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.0...v2.28.2) (2021-10-13) - ### Bug Fixes -* support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) - - +- support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) -* improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) +- improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.7.5](https://github.com/forcedotcom/sfdx-core/compare/v2.35.1...v3.7.5) (2022-02-14) - ### Bug Fixes -* add env vars from sfdx-cli init to envvars ([#520](https://github.com/forcedotcom/sfdx-core/issues/520)) ([8ef2785](https://github.com/forcedotcom/sfdx-core/commit/8ef27859d95bfffc5999b14f4792874d04f0504c)) - - +- add env vars from sfdx-cli init to envvars ([#520](https://github.com/forcedotcom/sfdx-core/issues/520)) ([8ef2785](https://github.com/forcedotcom/sfdx-core/commit/8ef27859d95bfffc5999b14f4792874d04f0504c)) ## [3.7.4](https://github.com/forcedotcom/sfdx-core/compare/v2.35.0...v3.7.4) (2022-02-07) - ### Bug Fixes -* pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) - - +- pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) ## [3.7.3](https://github.com/forcedotcom/sfdx-core/compare/v2.33.1...v3.7.3) (2021-12-16) - - ## [3.7.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.1...v3.7.2) (2021-10-28) - ### Bug Fixes -* make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) - - +- make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) ## [3.7.1](https://github.com/forcedotcom/sfdx-core/compare/v2.28.2...v3.7.1) (2021-10-28) - - # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) ## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - - ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.35.1](https://github.com/forcedotcom/sfdx-core/compare/v3.7.4...v2.35.1) (2022-02-10) - ### Bug Fixes -* add error message on failed settings deploy ([e218b1e](https://github.com/forcedotcom/sfdx-core/commit/e218b1e40414ea9e4fec256b74224626d96eff4a)) -* prefer instanceUrl for loginUrl on user:create ([#518](https://github.com/forcedotcom/sfdx-core/issues/518)) ([c070a87](https://github.com/forcedotcom/sfdx-core/commit/c070a871861409dea722e85845eeb91f262ab66f)) - - +- add error message on failed settings deploy ([e218b1e](https://github.com/forcedotcom/sfdx-core/commit/e218b1e40414ea9e4fec256b74224626d96eff4a)) +- prefer instanceUrl for loginUrl on user:create ([#518](https://github.com/forcedotcom/sfdx-core/issues/518)) ([c070a87](https://github.com/forcedotcom/sfdx-core/commit/c070a871861409dea722e85845eeb91f262ab66f)) # [2.35.0](https://github.com/forcedotcom/sfdx-core/compare/v2.34.2...v2.35.0) (2022-01-25) - ### Bug Fixes -* jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) - - +- jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) ## [2.34.2](https://github.com/forcedotcom/sfdx-core/compare/v2.33.2...v2.34.2) (2022-01-25) - - ## [2.33.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.3...v2.33.2) (2022-01-25) - ### Bug Fixes -* correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) -* exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) -* refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) -* remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) -* save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) - - +- correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) +- exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) +- refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) +- remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) +- save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) ## [2.33.1](https://github.com/forcedotcom/sfdx-core/compare/v2.33.0...v2.33.1) (2021-12-15) - ### Bug Fixes -* faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) - - +- faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) # [2.33.0](https://github.com/forcedotcom/sfdx-core/compare/v2.32.0...v2.33.0) (2021-12-14) - ### Features -* sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) - - +- sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) # [2.32.0](https://github.com/forcedotcom/sfdx-core/compare/v2.31.1...v2.32.0) (2021-12-14) - ### Bug Fixes -* no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) - +- no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) ### Features -* switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) - +- switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) ### Reverts -* Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) - - +- Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) ## [2.31.1](https://github.com/forcedotcom/sfdx-core/compare/v2.31.0...v2.31.1) (2021-12-06) - - # [2.31.0](https://github.com/forcedotcom/sfdx-core/compare/v2.30.1...v2.31.0) (2021-11-30) - ### Features -* bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) - - +- bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) ## [2.30.1](https://github.com/forcedotcom/sfdx-core/compare/v2.30.0...v2.30.1) (2021-11-30) - ### Bug Fixes -* better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) - - +- better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) # [2.30.0](https://github.com/forcedotcom/sfdx-core/compare/v2.29.0...v2.30.0) (2021-11-25) - ### Features -* delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) - - +- delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) # [2.29.0](https://github.com/forcedotcom/sfdx-core/compare/v2.28.4...v2.29.0) (2021-11-17) - ### Bug Fixes -* use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) - - +- use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) ## [2.28.4](https://github.com/forcedotcom/sfdx-core/compare/v2.28.3...v2.28.4) (2021-11-10) - ### Bug Fixes -* bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) -* transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) - +- bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) +- transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) ### Features -* cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) -* use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) -* warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) -* warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) - - +- cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) +- use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) +- warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) +- warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) ## [2.28.3](https://github.com/forcedotcom/sfdx-core/compare/v3.7.2...v2.28.3) (2021-11-08) - ### Bug Fixes -* fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) -* force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) - - +- fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) +- force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) ## [2.28.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.0...v2.28.2) (2021-10-13) - ### Bug Fixes -* support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) - - +- support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) -* improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) +- improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.7.4](https://github.com/forcedotcom/sfdx-core/compare/v2.35.0...v3.7.4) (2022-02-07) - ### Bug Fixes -* pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) - - +- pin ts to 4.4.4 and bump other deps ([#509](https://github.com/forcedotcom/sfdx-core/issues/509)) ([1c0e15c](https://github.com/forcedotcom/sfdx-core/commit/1c0e15cd9a96f03e24476c13d73b62577a535fa3)) ## [3.7.3](https://github.com/forcedotcom/sfdx-core/compare/v2.33.1...v3.7.3) (2021-12-16) - - ## [3.7.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.1...v3.7.2) (2021-10-28) - ### Bug Fixes -* make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) - - +- make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) ## [3.7.1](https://github.com/forcedotcom/sfdx-core/compare/v2.28.2...v3.7.1) (2021-10-28) - - # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) ## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - - ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) # [2.35.0](https://github.com/forcedotcom/sfdx-core/compare/v2.34.2...v2.35.0) (2022-01-25) - ### Bug Fixes -* jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) -* refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) - - +- jsforce dep and pjson version realign ([#516](https://github.com/forcedotcom/sfdx-core/issues/516)) ([9f35f2f](https://github.com/forcedotcom/sfdx-core/commit/9f35f2f0ce30e996a0b4c88461c2babb536c33f7)) +- refresh auth on a connection, too ([ff32a70](https://github.com/forcedotcom/sfdx-core/commit/ff32a705d87d6e410d06597eefa407b54eeb215d)) ## [2.34.2](https://github.com/forcedotcom/sfdx-core/compare/v2.33.2...v2.34.2) (2022-01-25) - - ## [2.33.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.3...v2.33.2) (2022-01-25) - ### Bug Fixes -* correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) -* exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) -* remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) -* save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) - - +- correct import declaration ([4c69d2d](https://github.com/forcedotcom/sfdx-core/commit/4c69d2dc3370c5f920becfe260ccb178279e4d92)) +- exit deploy loop with error on status SucceededPartial ([492e891](https://github.com/forcedotcom/sfdx-core/commit/492e89184e4c865cc7fcf7df41b9c6af6a6f2237)) +- remove unwanted dep ([12ccc3a](https://github.com/forcedotcom/sfdx-core/commit/12ccc3adc0efbe687059187ab4d849b1741c823d)) +- save auth info ([226bbd2](https://github.com/forcedotcom/sfdx-core/commit/226bbd2dc09a7a8df5887c0ae7548c83ae19b748)) ## [2.33.1](https://github.com/forcedotcom/sfdx-core/compare/v2.33.0...v2.33.1) (2021-12-15) - ### Bug Fixes -* faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) - - +- faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) # [2.33.0](https://github.com/forcedotcom/sfdx-core/compare/v2.32.0...v2.33.0) (2021-12-14) - ### Features -* sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) - - +- sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) # [2.32.0](https://github.com/forcedotcom/sfdx-core/compare/v2.31.1...v2.32.0) (2021-12-14) - ### Bug Fixes -* no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) - +- no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) ### Features -* switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) - +- switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) ### Reverts -* Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) - - +- Revert "test: added basic tests for settings" ([28e656c](https://github.com/forcedotcom/sfdx-core/commit/28e656ce6f8b8461dbc866474137829941a7bde0)) ## [2.31.1](https://github.com/forcedotcom/sfdx-core/compare/v2.31.0...v2.31.1) (2021-12-06) - - # [2.31.0](https://github.com/forcedotcom/sfdx-core/compare/v2.30.1...v2.31.0) (2021-11-30) - ### Features -* bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) - - +- bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) ## [2.30.1](https://github.com/forcedotcom/sfdx-core/compare/v2.30.0...v2.30.1) (2021-11-30) - ### Bug Fixes -* better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) - - +- better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) # [2.30.0](https://github.com/forcedotcom/sfdx-core/compare/v2.29.0...v2.30.0) (2021-11-25) - ### Features -* delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) - - +- delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) # [2.29.0](https://github.com/forcedotcom/sfdx-core/compare/v2.28.4...v2.29.0) (2021-11-17) - ### Bug Fixes -* use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) - - +- use correct dir structure ([e947fec](https://github.com/forcedotcom/sfdx-core/commit/e947fecf33a1c19ff80b33f7515e39d4e524f77f)) ## [2.28.4](https://github.com/forcedotcom/sfdx-core/compare/v2.28.3...v2.28.4) (2021-11-10) - ### Bug Fixes -* bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) -* transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) - +- bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) +- transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) ### Features -* cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) -* use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) -* warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) -* warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) - - +- cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) +- use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) +- warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) +- warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) ## [2.28.3](https://github.com/forcedotcom/sfdx-core/compare/v3.7.2...v2.28.3) (2021-11-08) - ### Bug Fixes -* fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) -* force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) - - +- fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) +- force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) ## [2.28.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.0...v2.28.2) (2021-10-13) - ### Bug Fixes -* support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) - - +- support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- cant use require on json as module use readFileSync instead ([3085029](https://github.com/forcedotcom/sfdx-core/commit/3085029e70d7f88e2535bf0b80240855f13abf37)) +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) -* improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) +- improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.7.3](https://github.com/forcedotcom/sfdx-core/compare/v2.33.1...v3.7.3) (2021-12-16) - - ## [3.7.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.1...v3.7.2) (2021-10-28) - ### Bug Fixes -* make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) - - +- make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) ## [3.7.1](https://github.com/forcedotcom/sfdx-core/compare/v2.28.2...v3.7.1) (2021-10-28) - - # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - - -## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) +## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.33.1](https://github.com/forcedotcom/sfdx-core/compare/v2.33.0...v2.33.1) (2021-12-15) - ### Bug Fixes -* faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) - - +- faye doesn't use custom stuff passed it ([b1cefc7](https://github.com/forcedotcom/sfdx-core/commit/b1cefc76afde7f0dd56ed72b5539a47c118eef63)) # [2.33.0](https://github.com/forcedotcom/sfdx-core/compare/v2.32.0...v2.33.0) (2021-12-14) - ### Features -* sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) - - +- sandbox creation ([314dcf1](https://github.com/forcedotcom/sfdx-core/commit/314dcf164d93bd0e3a5f4763a4dfcdde7d0cb14a)) # [2.32.0](https://github.com/forcedotcom/sfdx-core/compare/v2.31.1...v2.32.0) (2021-12-14) - ### Bug Fixes -* no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) - +- no maxquery warning when records.length is 0 ([758f912](https://github.com/forcedotcom/sfdx-core/commit/758f912a23bd3e9f8d4f854f3e07682dd4d4c4aa)) ### Features -* switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) - - +- switch sfdx-faye with faye ([a0545e5](https://github.com/forcedotcom/sfdx-core/commit/a0545e57d5041c97e499f284afbd7fcb16cf2247)) ## [2.31.1](https://github.com/forcedotcom/sfdx-core/compare/v2.31.0...v2.31.1) (2021-12-06) - - # [2.31.0](https://github.com/forcedotcom/sfdx-core/compare/v2.30.1...v2.31.0) (2021-11-30) - ### Features -* bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) - - +- bump version of jsforce ([7d89024](https://github.com/forcedotcom/sfdx-core/commit/7d89024f593968c031af22ac817efc26d00fcd54)) ## [2.30.1](https://github.com/forcedotcom/sfdx-core/compare/v2.30.0...v2.30.1) (2021-11-30) - ### Bug Fixes -* better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) - - +- better output for authUrl errors ([f3ec729](https://github.com/forcedotcom/sfdx-core/commit/f3ec7298bdbd3194d3d14bfea09f47f413669376)) # [2.30.0](https://github.com/forcedotcom/sfdx-core/compare/v2.29.0...v2.30.0) (2021-11-25) - ### Features -* delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) - - +- delete scratch orgs and sandboxes ([#491](https://github.com/forcedotcom/sfdx-core/issues/491)) ([468c348](https://github.com/forcedotcom/sfdx-core/commit/468c348f0ecc69ddeea02927bf7a26ca660a86ca)) # [2.29.0](https://github.com/forcedotcom/sfdx-core/compare/v2.28.4...v2.29.0) (2021-11-17) - ### Bug Fixes -* transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) - +- transfer listeners when upgrading the global instance to newer version ([0a40831](https://github.com/forcedotcom/sfdx-core/commit/0a408317c132548771ced0fe196178d2e9c76232)) ### Features -* cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) -* use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) -* warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) -* warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) - - +- cleans up old listeners from upgraded instance ([e3f2d69](https://github.com/forcedotcom/sfdx-core/commit/e3f2d69ccd5c096d37addb1b982e19354175f11a)) +- use warnings instead of process in sfdx-core ([c1f7e98](https://github.com/forcedotcom/sfdx-core/commit/c1f7e98f6b19d57da1a2ee0cdf58e449079f0ee7)) +- warning and telemetry events ([80a8039](https://github.com/forcedotcom/sfdx-core/commit/80a8039e2f686d973ddbc24c9a2980fb93928d13)) +- warning and telemetry events ([a04b293](https://github.com/forcedotcom/sfdx-core/commit/a04b29355c8ca6c7e37e071ccc159aff5e5e9ca0)) ## [2.28.4](https://github.com/forcedotcom/sfdx-core/compare/v2.28.3...v2.28.4) (2021-11-10) - ### Bug Fixes -* bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) - - +- bump jsforce types and run unit tests on Windows ([#485](https://github.com/forcedotcom/sfdx-core/issues/485)) ([3952c8f](https://github.com/forcedotcom/sfdx-core/commit/3952c8fe248531a0597477ed12240f611048caba)) ## [2.28.3](https://github.com/forcedotcom/sfdx-core/compare/v3.7.2...v2.28.3) (2021-11-08) - ### Bug Fixes -* fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) -* force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) - - +- fix unit test ([d903c04](https://github.com/forcedotcom/sfdx-core/commit/d903c04e5f3e4f01fccb3f00b91560c443013ddf)) +- force new release ([124bb74](https://github.com/forcedotcom/sfdx-core/commit/124bb744c5ecc28cb8babf285c6d8c3032eb7ef6)) ## [2.28.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.0...v2.28.2) (2021-10-13) - ### Bug Fixes -* support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) - - +- support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) -* improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) +- improve error message when providing an invalid username ([2ab4bbd](https://github.com/forcedotcom/sfdx-core/commit/2ab4bbdefd962283d88ccb735de88c88fe189d39)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.7.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.1...v3.7.2) (2021-10-28) - ### Bug Fixes -* make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) - - +- make @types/sfdx-faye a dependendcy ([683680b](https://github.com/forcedotcom/sfdx-core/commit/683680b8133048f71d25ef4df7aa24d9700dc5e8)) ## [3.7.1](https://github.com/forcedotcom/sfdx-core/compare/v2.28.2...v3.7.1) (2021-10-28) - - # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) ## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - - ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.28.2](https://github.com/forcedotcom/sfdx-core/compare/v3.7.0...v2.28.2) (2021-10-13) - ### Bug Fixes -* support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) - - +- support for .mil sandboxes ([9ef35c7](https://github.com/forcedotcom/sfdx-core/commit/9ef35c7b1ef0fe974c3bd3b89b862a436e00f7d9)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) # [3.7.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.6...v3.7.0) (2021-10-12) - ### Features -* use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) - - +- use jsforce v2 ([#457](https://github.com/forcedotcom/sfdx-core/issues/457)) ([4a9094e](https://github.com/forcedotcom/sfdx-core/commit/4a9094e958288cdcc6c69f5d87b10a70a437d8e9)) ## [3.6.6](https://github.com/forcedotcom/sfdx-core/compare/v2.28.1...v3.6.6) (2021-10-08) - - ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.28.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.5...v2.28.1) (2021-10-06) - ### Bug Fixes -* crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) - - +- crmforce.mil ([e263d5d](https://github.com/forcedotcom/sfdx-core/commit/e263d5d74be9c0651e5c2676d6eec1c31fca05e4)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.6.5](https://github.com/forcedotcom/sfdx-core/compare/v3.6.4...v3.6.5) (2021-09-29) - ### Bug Fixes -* add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) - - +- add getValue to AliasAccessor ([c4b69f5](https://github.com/forcedotcom/sfdx-core/commit/c4b69f5ff38547fad640c64833291fe0c6e06a79)) ## [3.6.4](https://github.com/forcedotcom/sfdx-core/compare/v3.6.3...v3.6.4) (2021-09-23) - ### Bug Fixes -* edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) - - +- edit the env var blurbs ([#482](https://github.com/forcedotcom/sfdx-core/issues/482)) ([bbbdb6d](https://github.com/forcedotcom/sfdx-core/commit/bbbdb6d0800015e94ce0f0c551eec8ed73dd87c6)) ## [3.6.3](https://github.com/forcedotcom/sfdx-core/compare/v3.6.2...v3.6.3) (2021-09-23) - ### Bug Fixes -* edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) - - +- edit the config var blurbs ([#480](https://github.com/forcedotcom/sfdx-core/issues/480)) ([f845512](https://github.com/forcedotcom/sfdx-core/commit/f8455121bfd96f27495bc124dc06570632dfce70)) ## [3.6.2](https://github.com/forcedotcom/sfdx-core/compare/v2.28.0...v3.6.2) (2021-09-17) - ### Bug Fixes -* improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) - - +- improve time to build auths for many orgs @W-9914839@ ([#478](https://github.com/forcedotcom/sfdx-core/issues/478)) ([c788541](https://github.com/forcedotcom/sfdx-core/commit/c7885415d59994b28552227f0b84dcee5d3ec7cf)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) # [2.28.0](https://github.com/forcedotcom/sfdx-core/compare/v3.6.1...v2.28.0) (2021-09-16) - ### Features -* add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) -* add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) -* update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) - - +- add custom templates config ([3cf8a8c](https://github.com/forcedotcom/sfdx-core/commit/3cf8a8cee1e7196efced989dcca9b545e1283386)) +- add validator for custom templates config ([dd2bcfe](https://github.com/forcedotcom/sfdx-core/commit/dd2bcfe8e7fee5c5c1c6321189ec04288103d5b6)) +- update config name ([72e84bf](https://github.com/forcedotcom/sfdx-core/commit/72e84bfacef48a1c2d00a61ebbae3f632601abbd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.6.1](https://github.com/forcedotcom/sfdx-core/compare/v3.6.0...v3.6.1) (2021-09-13) - ### Bug Fixes -* remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) - - +- remove tokens associated with org ([#477](https://github.com/forcedotcom/sfdx-core/issues/477)) ([5034fa2](https://github.com/forcedotcom/sfdx-core/commit/5034fa2d4c52d347c00499e137a71366e4feba7f)) # [3.6.0](https://github.com/forcedotcom/sfdx-core/compare/v3.5.0...v3.6.0) (2021-09-10) - ### Features -* add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) - - +- add help section helper ([#474](https://github.com/forcedotcom/sfdx-core/issues/474)) ([b34c2d7](https://github.com/forcedotcom/sfdx-core/commit/b34c2d7a442aed2cf091fd394a7c3656287d1dbf)) # [3.5.0](https://github.com/forcedotcom/sfdx-core/compare/v3.4.5...v3.5.0) (2021-09-09) - ### Features -* expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) - - +- expose well known env vars as part of core ([#473](https://github.com/forcedotcom/sfdx-core/issues/473)) ([11c3f53](https://github.com/forcedotcom/sfdx-core/commit/11c3f53f964459072826274e6ebb33d4a9ecb990)) ## [3.4.5](https://github.com/forcedotcom/sfdx-core/compare/v3.4.4...v3.4.5) (2021-09-03) - ### Bug Fixes -* provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) - - +- provide the correct options to SfdxConfig ([fa2117e](https://github.com/forcedotcom/sfdx-core/commit/fa2117e12d7a903f26067bdcf35d7ec9c142101e)) ## [3.4.4](https://github.com/forcedotcom/sfdx-core/compare/v3.4.3...v3.4.4) (2021-09-03) - - ## [3.4.3](https://github.com/forcedotcom/sfdx-core/compare/v3.4.2...v3.4.3) (2021-08-26) - - ## [3.4.2](https://github.com/forcedotcom/sfdx-core/compare/v3.4.1...v3.4.2) (2021-08-17) - ### Bug Fixes -* improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) - - +- improve interoperability when unsetting ([#467](https://github.com/forcedotcom/sfdx-core/issues/467)) ([ad781d5](https://github.com/forcedotcom/sfdx-core/commit/ad781d5378652dfd64ccb476c11f418e940b8669)) ## [3.4.1](https://github.com/forcedotcom/sfdx-core/compare/v3.4.0...v3.4.1) (2021-08-11) - ### Bug Fixes -* optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) - - +- optionally throw error when reading deprecated config key ([#466](https://github.com/forcedotcom/sfdx-core/issues/466)) ([3118ad8](https://github.com/forcedotcom/sfdx-core/commit/3118ad836db384ac27c2b1db88c4753e6121e4db)) # [3.4.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.12...v3.4.0) (2021-08-11) - ### Features -* config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) - - +- config interoperability ([#461](https://github.com/forcedotcom/sfdx-core/issues/461)) ([11b60ad](https://github.com/forcedotcom/sfdx-core/commit/11b60adbe54acc8e16a90327c77abbe2613fbaab)) ## [3.3.12](https://github.com/forcedotcom/sfdx-core/compare/v2.27.2...v3.3.12) (2021-08-10) - ### Bug Fixes -* add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) - - +- add predicate function to list all auths ([ccdb02c](https://github.com/forcedotcom/sfdx-core/commit/ccdb02c268fae7532b23e0c791bcdd831f77cf98)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.27.2](https://github.com/forcedotcom/sfdx-core/compare/v2.27.1...v2.27.2) (2021-08-05) - ### Bug Fixes -* improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) - - +- improve error handling while removing config props ([eecf7b0](https://github.com/forcedotcom/sfdx-core/commit/eecf7b0d0cf14e1371dc4c5ef03a413f864b0a8b)) ## [2.27.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.11...v2.27.1) (2021-08-05) - ### Bug Fixes -* dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) - - +- dont fail when trying to unset sf config keys ([#456](https://github.com/forcedotcom/sfdx-core/issues/456)) ([8aff9fd](https://github.com/forcedotcom/sfdx-core/commit/8aff9fd4bdb73ec20e58f5a16a8192a8eecba912)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.3.11](https://github.com/forcedotcom/sfdx-core/compare/v3.3.10...v3.3.11) (2021-08-04) - ### Bug Fixes -* allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) - - +- allows for message keys of error and errors ([#455](https://github.com/forcedotcom/sfdx-core/issues/455)) ([3bfac58](https://github.com/forcedotcom/sfdx-core/commit/3bfac587c6cf1734af6f2b517439d278591ddd50)) ## [3.3.10](https://github.com/forcedotcom/sfdx-core/compare/v3.3.9...v3.3.10) (2021-08-04) - - ## [3.3.9](https://github.com/forcedotcom/sfdx-core/compare/v3.3.8...v3.3.9) (2021-08-04) - ### Bug Fixes -* merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) - - +- merge main(v2) into v3 ([#452](https://github.com/forcedotcom/sfdx-core/issues/452)) ([3a003b9](https://github.com/forcedotcom/sfdx-core/commit/3a003b9c17962f77344e4a23314bb608e1ae50db)) ## [3.3.8](https://github.com/forcedotcom/sfdx-core/compare/v3.3.7...v3.3.8) (2021-08-02) - ### Bug Fixes -* return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) - - +- return all info from AuthInfo.listAllAuthorizations ([#449](https://github.com/forcedotcom/sfdx-core/issues/449)) ([17e60ea](https://github.com/forcedotcom/sfdx-core/commit/17e60eabe87c73a83c26344967076f365ddea81c)) ## [3.3.7](https://github.com/forcedotcom/sfdx-core/compare/v2.27.0...v3.3.7) (2021-07-30) - - ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) # [2.27.0](https://github.com/forcedotcom/sfdx-core/compare/v3.3.6...v2.27.0) (2021-07-29) - ### Features -* Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) - - +- Core URL class SfdcUrl ([#420](https://github.com/forcedotcom/sfdx-core/issues/420)) ([66881ea](https://github.com/forcedotcom/sfdx-core/commit/66881eae2f30215c862ea398bfc1630d9a5898fe)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.3.6](https://github.com/forcedotcom/sfdx-core/compare/v3.3.5...v3.3.6) (2021-07-28) - ### Bug Fixes -* use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) - - +- use correct method to get username ([#446](https://github.com/forcedotcom/sfdx-core/issues/446)) ([79a6b2f](https://github.com/forcedotcom/sfdx-core/commit/79a6b2f069f95b0c50a6c03ecbac07cf0d1832b1)) ## [3.3.5](https://github.com/forcedotcom/sfdx-core/compare/v3.3.4...v3.3.5) (2021-07-28) - - ## [3.3.4](https://github.com/forcedotcom/sfdx-core/compare/v3.3.3...v3.3.4) (2021-07-26) - ### Bug Fixes -* remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) - - +- remove bad validator function ([1b97dc6](https://github.com/forcedotcom/sfdx-core/commit/1b97dc6f4d657a5b86489d33c4843ebfd54b3715)) ## [3.3.3](https://github.com/forcedotcom/sfdx-core/compare/v3.3.2...v3.3.3) (2021-07-22) - ### Bug Fixes -* write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) - - +- write sf.json contents on init ([c47f649](https://github.com/forcedotcom/sfdx-core/commit/c47f64954118d0d2f7f4a8e992d3450516239084)) ## [3.3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.26.1...v3.3.2) (2021-07-21) - ### Bug Fixes -* correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) - - +- correct jsdoc ([a362e94](https://github.com/forcedotcom/sfdx-core/commit/a362e94c4ae7538cbbcd7dae8fcd3244629d845c)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - - -## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) +## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.26.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.1...v2.26.1) (2021-07-19) - ### Bug Fixes -* force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) - - +- force:org:open force:org:open --urlonly display bug ([#439](https://github.com/forcedotcom/sfdx-core/issues/439)) ([2ea0e74](https://github.com/forcedotcom/sfdx-core/commit/2ea0e74b8bf1bff6de8af70372025cac10fc8c18)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.3.1](https://github.com/forcedotcom/sfdx-core/compare/v3.3.0...v3.3.1) (2021-07-15) - ### Bug Fixes -* temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) - - +- temporarily point Alias back to .sfdx ([#438](https://github.com/forcedotcom/sfdx-core/issues/438)) ([4bffcd8](https://github.com/forcedotcom/sfdx-core/commit/4bffcd84362d5b3049ef428e90dc1b538a435f81)) # [3.3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.2.0-v3.0...v3.3.0) (2021-07-14) - ### Features -* V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) - - +- V3 merge ([#436](https://github.com/forcedotcom/sfdx-core/issues/436)) ([1193449](https://github.com/forcedotcom/sfdx-core/commit/119344969147679088e30bae4c4fc5e941661078)), closes [#413](https://github.com/forcedotcom/sfdx-core/issues/413) [#415](https://github.com/forcedotcom/sfdx-core/issues/415) [#428](https://github.com/forcedotcom/sfdx-core/issues/428) [#429](https://github.com/forcedotcom/sfdx-core/issues/429) [#427](https://github.com/forcedotcom/sfdx-core/issues/427) [#432](https://github.com/forcedotcom/sfdx-core/issues/432) # [3.2.0-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.26.0...v3.2.0-v3.0) (2021-07-14) - ### Features -* use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) - - +- use .sf/config.json @W-9546117@ ([#433](https://github.com/forcedotcom/sfdx-core/issues/433)) ([6c41653](https://github.com/forcedotcom/sfdx-core/commit/6c416531a9bae10e855ded3efc289a99196bc26b)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) # [2.26.0](https://github.com/forcedotcom/sfdx-core/compare/v2.25.1...v2.26.0) (2021-07-13) - ### Features -* update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) - - +- update generate password functionality ([#432](https://github.com/forcedotcom/sfdx-core/issues/432)) ([ed65e83](https://github.com/forcedotcom/sfdx-core/commit/ed65e83da3afe0d101743ee89cc7b2a7a38d5254)) ## [2.25.1](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.2...v2.25.1) (2021-06-30) - ### Bug Fixes -* set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) - - +- set retries to INFINITELY for polling client ([31539b4](https://github.com/forcedotcom/sfdx-core/commit/31539b4f0edd0cc1c049f70331ed5e40b8af55ea)) ## [3.1.1-3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.25.0...v3.1.1-3.2) (2021-06-30) - ### Features -* @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) - - +- @W-9517449@ Allow signupTargetLoginUrl to be overridden via env var ([#429](https://github.com/forcedotcom/sfdx-core/issues/429)) ([e2b8b36](https://github.com/forcedotcom/sfdx-core/commit/e2b8b36b2836b5277c83ffe22922978dc32e7b11)), closes [#427](https://github.com/forcedotcom/sfdx-core/issues/427) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - - ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.1.1-v3.2](https://github.com/forcedotcom/sfdx-core/compare/v2.24.2...v3.1.1-v3.2) (2021-06-29) - ### Bug Fixes -* do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) - - +- do not use function prop ([#426](https://github.com/forcedotcom/sfdx-core/issues/426)) ([39efe0c](https://github.com/forcedotcom/sfdx-core/commit/39efe0ccc84b05bc891e54b24bfcddc62790ae0e)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.24.2](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.1...v2.24.2) (2021-06-23) - ### Bug Fixes -* puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) - - +- puts some types back in dependencies ([94bea31](https://github.com/forcedotcom/sfdx-core/commit/94bea31037a41d4377faecb22bce8a2d12e95f4f)) ## [3.1.1-3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.1...v3.1.1-3.1) (2021-06-23) - ### Bug Fixes -* rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) - - +- rewrite polling client ([8d363d1](https://github.com/forcedotcom/sfdx-core/commit/8d363d13616f5efa944d4bb717a010add3c996b5)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.1.1-v3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.24.0...v3.1.1-v3.1) (2021-06-14) - ### Bug Fixes -* keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) - - +- keep track of auth changes ([210be6c](https://github.com/forcedotcom/sfdx-core/commit/210be6cb408bd9ecc861989570df0e14f6a3a566)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) # [2.24.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.5...v2.24.0) (2021-06-08) - ### Features -* exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) - - +- exported function checkLightningDomain() ([#415](https://github.com/forcedotcom/sfdx-core/issues/415)) ([8e75231](https://github.com/forcedotcom/sfdx-core/commit/8e752313abf4a383a6ef18250ffac78b398987dd)) ## [2.23.5](https://github.com/forcedotcom/sfdx-core/compare/v3.1.1-3.0...v2.23.5) (2021-06-07) - ### Bug Fixes -* w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) - - +- w-9299422 (login url from config) and fs-parallelization ([043bb17](https://github.com/forcedotcom/sfdx-core/commit/043bb179dbf64f9c4522a4c0f0720ae09794227c)) ## [3.1.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.4...v3.1.1-3.0) (2021-06-03) - ### Bug Fixes -* works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) - - +- works with TS4+ and jsforce types ([#413](https://github.com/forcedotcom/sfdx-core/issues/413)) ([b77cdad](https://github.com/forcedotcom/sfdx-core/commit/b77cdad56b114290b8e5fd23d968e23e7d4eedf4)) ## [3.1.1-v3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.23.3...v3.1.1-v3.0) (2021-06-03) - ### Bug Fixes -* compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) -* unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) -* unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) - +- compilation errors ([33a9876](https://github.com/forcedotcom/sfdx-core/commit/33a9876575eff7944bb287d428f52413831725d9)) +- unit test failures ([4507575](https://github.com/forcedotcom/sfdx-core/commit/45075754175d411b6cb71eb809096e6eb3e23d95)) +- unsetAuthorization ([#399](https://github.com/forcedotcom/sfdx-core/issues/399)) ([dd57438](https://github.com/forcedotcom/sfdx-core/commit/dd57438a95b49515f560d3b915cdf916a4b8643b)) ### Features -* add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) -* add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) -* move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) - - +- add GlobalInfo config file ([#397](https://github.com/forcedotcom/sfdx-core/issues/397)) ([889425c](https://github.com/forcedotcom/sfdx-core/commit/889425c06e8ed6a364d9a2bc3dd5ef0a38a66046)) +- add message support for markdown files ([0f235a2](https://github.com/forcedotcom/sfdx-core/commit/0f235a23d5dddbd7b3f07544d8c7e380875c6c55)) +- move crypto to config file @W-9225317@ ([#406](https://github.com/forcedotcom/sfdx-core/issues/406)) ([bac83c3](https://github.com/forcedotcom/sfdx-core/commit/bac83c3a52b15c9b462dfb68be9d080e710493cd)) ## [2.23.3](https://github.com/forcedotcom/sfdx-core/compare/v2.23.2...v2.23.3) (2021-06-03) - - ## [2.23.2](https://github.com/forcedotcom/sfdx-core/compare/v2.23.1...v2.23.2) (2021-06-02) - ### Bug Fixes -* authinfo returning only lowercase usernames. ([#411](https://github.com/forcedotcom/sfdx-core/issues/411)) ([243668e](https://github.com/forcedotcom/sfdx-core/commit/243668e61cd8418b6acb2f0d4806da50ccf37b29)), closes [#405](https://github.com/forcedotcom/sfdx-core/issues/405) - - +- authinfo returning only lowercase usernames. ([#411](https://github.com/forcedotcom/sfdx-core/issues/411)) ([243668e](https://github.com/forcedotcom/sfdx-core/commit/243668e61cd8418b6acb2f0d4806da50ccf37b29)), closes [#405](https://github.com/forcedotcom/sfdx-core/issues/405) ## [2.23.1](https://github.com/forcedotcom/sfdx-core/compare/v2.23.0...v2.23.1) (2021-05-27) - - # [2.23.0](https://github.com/forcedotcom/sfdx-core/compare/v2.22.0...v2.23.0) (2021-05-26) - ### Bug Fixes -* export library method ([d0016f9](https://github.com/forcedotcom/sfdx-core/commit/d0016f96da1246535049884c1043399239a33c00)) - +- export library method ([d0016f9](https://github.com/forcedotcom/sfdx-core/commit/d0016f96da1246535049884c1043399239a33c00)) ### Features -* export getJwtAudienceUrl ([e7d26d2](https://github.com/forcedotcom/sfdx-core/commit/e7d26d20106d6abb6b424936bdf26c0a9f8cd175)) - - +- export getJwtAudienceUrl ([e7d26d2](https://github.com/forcedotcom/sfdx-core/commit/e7d26d20106d6abb6b424936bdf26c0a9f8cd175)) # [2.22.0](https://github.com/forcedotcom/sfdx-core/compare/v2.21.0...v2.22.0) (2021-05-24) - ### Features -* export getJwtAudienceUrl ([#407](https://github.com/forcedotcom/sfdx-core/issues/407)) ([585bb07](https://github.com/forcedotcom/sfdx-core/commit/585bb073434d73473a855ee52b7ddc6f0228aae1)) - - +- export getJwtAudienceUrl ([#407](https://github.com/forcedotcom/sfdx-core/issues/407)) ([585bb07](https://github.com/forcedotcom/sfdx-core/commit/585bb073434d73473a855ee52b7ddc6f0228aae1)) # [2.21.0](https://github.com/forcedotcom/sfdx-core/compare/v2.20.11...v2.21.0) (2021-05-24) - ### Features -* modify authInfo to return username for access token auth ([160b7d2](https://github.com/forcedotcom/sfdx-core/commit/160b7d20e32b80d7a54c8cf679154fcbaa9e8cda)) - - +- modify authInfo to return username for access token auth ([160b7d2](https://github.com/forcedotcom/sfdx-core/commit/160b7d20e32b80d7a54c8cf679154fcbaa9e8cda)) ## [2.20.11](https://github.com/forcedotcom/sfdx-core/compare/v3.1.0-3.0...v2.20.11) (2021-05-12) - ### Bug Fixes -* force release ([f0b837a](https://github.com/forcedotcom/sfdx-core/commit/f0b837ab7b4d0361c2fa3ba15fe56cd2f7cc1fd0)) - - +- force release ([f0b837a](https://github.com/forcedotcom/sfdx-core/commit/f0b837ab7b4d0361c2fa3ba15fe56cd2f7cc1fd0)) # [3.1.0-3.0](https://github.com/forcedotcom/sfdx-core/compare/v3.0.1-3.0...v3.1.0-3.0) (2021-05-12) - - ## [3.0.1-3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.20.10...v3.0.1-3.0) (2021-05-05) - - ## [2.20.10](https://github.com/forcedotcom/sfdx-core/compare/v2.20.9...v2.20.10) (2021-04-14) - ### Bug Fixes -* add another internal test env domain ([6ea538f](https://github.com/forcedotcom/sfdx-core/commit/6ea538f2ce62daba7262a247472ce821c6e2616f)) - - +- add another internal test env domain ([6ea538f](https://github.com/forcedotcom/sfdx-core/commit/6ea538f2ce62daba7262a247472ce821c6e2616f)) ## [2.20.9](https://github.com/forcedotcom/sfdx-core/compare/v2.20.8...v2.20.9) (2021-04-05) - ### Bug Fixes -* allow = in authUrl tokens ([2337fcd](https://github.com/forcedotcom/sfdx-core/commit/2337fcddfb1907a7092cd52f5b3ad73ae963d59e)) - - +- allow = in authUrl tokens ([2337fcd](https://github.com/forcedotcom/sfdx-core/commit/2337fcddfb1907a7092cd52f5b3ad73ae963d59e)) ## [2.20.8](https://github.com/forcedotcom/sfdx-core/compare/v2.20.7...v2.20.8) (2021-04-03) - ### Bug Fixes -* debugEnabled should be public ([dbd0124](https://github.com/forcedotcom/sfdx-core/commit/dbd01243003f555b8b4db45c83e81cc08b8cb9a1)) - - +- debugEnabled should be public ([dbd0124](https://github.com/forcedotcom/sfdx-core/commit/dbd01243003f555b8b4db45c83e81cc08b8cb9a1)) ## [2.20.7](https://github.com/forcedotcom/sfdx-core/compare/v2.20.6...v2.20.7) (2021-04-02) - ### Bug Fixes -* add deployRecentValidation ([62d367b](https://github.com/forcedotcom/sfdx-core/commit/62d367b217e6b552573bd7176b064e28252348c5)) -* add deployRecentValidation ([a39c329](https://github.com/forcedotcom/sfdx-core/commit/a39c329b3fab603b537ae5ed8cce4773bdf24eb6)) -* add test, clarify comments ([8d5679e](https://github.com/forcedotcom/sfdx-core/commit/8d5679ecbd482af84842f5c1c8908a059d97ef3f)) - - +- add deployRecentValidation ([62d367b](https://github.com/forcedotcom/sfdx-core/commit/62d367b217e6b552573bd7176b064e28252348c5)) +- add deployRecentValidation ([a39c329](https://github.com/forcedotcom/sfdx-core/commit/a39c329b3fab603b537ae5ed8cce4773bdf24eb6)) +- add test, clarify comments ([8d5679e](https://github.com/forcedotcom/sfdx-core/commit/8d5679ecbd482af84842f5c1c8908a059d97ef3f)) ## [2.20.6](https://github.com/forcedotcom/sfdx-core/compare/v2.20.5...v2.20.6) (2021-04-02) - ### Bug Fixes -* add REST deploy and test ([a1204f8](https://github.com/forcedotcom/sfdx-core/commit/a1204f857654ef979913708a8404d3b1e5328352)) -* deploy with REST working :) ([ec36851](https://github.com/forcedotcom/sfdx-core/commit/ec368515cd2d5d947f947573abbdaa83d3a853a2)) -* remove requrie ts-node/register from package ([5377fe4](https://github.com/forcedotcom/sfdx-core/commit/5377fe46c3ed5707d31e45794f9fd397aabbcf63)) -* rest deploy without fs :D ([9a4202d](https://github.com/forcedotcom/sfdx-core/commit/9a4202d157131fbf6aebb007a0334d3d1ce1d4e8)) -* working on adding REST deploy ([0b3947b](https://github.com/forcedotcom/sfdx-core/commit/0b3947b4e39b1ecd790cd6c03077e4388faf2b04)) - - +- add REST deploy and test ([a1204f8](https://github.com/forcedotcom/sfdx-core/commit/a1204f857654ef979913708a8404d3b1e5328352)) +- deploy with REST working :) ([ec36851](https://github.com/forcedotcom/sfdx-core/commit/ec368515cd2d5d947f947573abbdaa83d3a853a2)) +- remove requrie ts-node/register from package ([5377fe4](https://github.com/forcedotcom/sfdx-core/commit/5377fe46c3ed5707d31e45794f9fd397aabbcf63)) +- rest deploy without fs :D ([9a4202d](https://github.com/forcedotcom/sfdx-core/commit/9a4202d157131fbf6aebb007a0334d3d1ce1d4e8)) +- working on adding REST deploy ([0b3947b](https://github.com/forcedotcom/sfdx-core/commit/0b3947b4e39b1ecd790cd6c03077e4388faf2b04)) ## [2.20.5](https://github.com/forcedotcom/sfdx-core/compare/v2.20.4...v2.20.5) (2021-03-08) - ### Bug Fixes -* qualify a sandbox url via cname lookup ([#385](https://github.com/forcedotcom/sfdx-core/issues/385)) ([3e27623](https://github.com/forcedotcom/sfdx-core/commit/3e276237278fabb609b890e3271c4d8a28c0f573)) - - +- qualify a sandbox url via cname lookup ([#385](https://github.com/forcedotcom/sfdx-core/issues/385)) ([3e27623](https://github.com/forcedotcom/sfdx-core/commit/3e276237278fabb609b890e3271c4d8a28c0f573)) ## [2.20.4](https://github.com/forcedotcom/sfdx-core/compare/v2.20.3...v2.20.4) (2021-03-03) - - ## [2.20.3](https://github.com/forcedotcom/sfdx-core/compare/v2.20.2...v2.20.3) (2021-02-25) - ### Bug Fixes -* await the call to authInfo.save ([299499e](https://github.com/forcedotcom/sfdx-core/commit/299499ee29e9243b7d60fb9bdef22165a34b4611)) -* web:login fails when org cannot access REST ([31b139a](https://github.com/forcedotcom/sfdx-core/commit/31b139a56ce37e0d8a15946163dbf96c872c565b)) - +- await the call to authInfo.save ([299499e](https://github.com/forcedotcom/sfdx-core/commit/299499ee29e9243b7d60fb9bdef22165a34b4611)) +- web:login fails when org cannot access REST ([31b139a](https://github.com/forcedotcom/sfdx-core/commit/31b139a56ce37e0d8a15946163dbf96c872c565b)) ### Performance Improvements -* small queries to identify a devHub ([7bc75c1](https://github.com/forcedotcom/sfdx-core/commit/7bc75c16c7d03a81031e4e645e24aa9d23205028)) - - +- small queries to identify a devHub ([7bc75c1](https://github.com/forcedotcom/sfdx-core/commit/7bc75c16c7d03a81031e4e645e24aa9d23205028)) ## [2.20.2](https://github.com/forcedotcom/sfdx-core/compare/v2.20.1...v2.20.2) (2021-02-25) - ### Performance Improvements -* small queries to identify a devHub ([2bae295](https://github.com/forcedotcom/sfdx-core/commit/2bae295a63cb28ee7e7ea31f8d4b8f165ccd6173)) - - +- small queries to identify a devHub ([2bae295](https://github.com/forcedotcom/sfdx-core/commit/2bae295a63cb28ee7e7ea31f8d4b8f165ccd6173)) ## [2.20.1](https://github.com/forcedotcom/sfdx-core/compare/v2.20.0...v2.20.1) (2021-02-24) - ### Bug Fixes -* await the call to authInfo.save ([b26ea70](https://github.com/forcedotcom/sfdx-core/commit/b26ea700793eb2a985f28ce7fc349164d5edaf89)) - - +- await the call to authInfo.save ([b26ea70](https://github.com/forcedotcom/sfdx-core/commit/b26ea700793eb2a985f28ce7fc349164d5edaf89)) # [2.20.0](https://github.com/forcedotcom/sfdx-core/compare/v2.19.1...v2.20.0) (2021-02-22) - ### Bug Fixes -* do not save access token files ([46d88b9](https://github.com/forcedotcom/sfdx-core/commit/46d88b90c11c7de392412ef64ded201a2145de9d)) - +- do not save access token files ([46d88b9](https://github.com/forcedotcom/sfdx-core/commit/46d88b90c11c7de392412ef64ded201a2145de9d)) ### Features -* cache api version on auth info ([cb21cf0](https://github.com/forcedotcom/sfdx-core/commit/cb21cf099a4ab6911e49b26488b51eb6988b2be7)) - - +- cache api version on auth info ([cb21cf0](https://github.com/forcedotcom/sfdx-core/commit/cb21cf099a4ab6911e49b26488b51eb6988b2be7)) ## [2.19.1](https://github.com/forcedotcom/sfdx-core/compare/v2.19.0...v2.19.1) (2021-02-19) - ### Bug Fixes -* meet more password requirements ([53025f0](https://github.com/forcedotcom/sfdx-core/commit/53025f00a5a52cb32ed8ac20178c409df5014b76)) - - +- meet more password requirements ([53025f0](https://github.com/forcedotcom/sfdx-core/commit/53025f00a5a52cb32ed8ac20178c409df5014b76)) # [2.19.0](https://github.com/forcedotcom/sfdx-core/compare/v2.18.6...v2.19.0) (2021-02-17) - ### Bug Fixes -* move env vars to myDomainResolver ([fcf1a4a](https://github.com/forcedotcom/sfdx-core/commit/fcf1a4a4e333e6ac9e8d6e91204d030031de3d1c)) -* revert dns polling timeout to 30 and frequency to 10 ([4ba7a63](https://github.com/forcedotcom/sfdx-core/commit/4ba7a63ad5019c33123773789af6c7c58e4c6eb3)) - +- move env vars to myDomainResolver ([fcf1a4a](https://github.com/forcedotcom/sfdx-core/commit/fcf1a4a4e333e6ac9e8d6e91204d030031de3d1c)) +- revert dns polling timeout to 30 and frequency to 10 ([4ba7a63](https://github.com/forcedotcom/sfdx-core/commit/4ba7a63ad5019c33123773789af6c7c58e4c6eb3)) ### Features -* add SFDX_DISABLE_DNS_CHECK ([2e2cb84](https://github.com/forcedotcom/sfdx-core/commit/2e2cb84f557ecb057358efa107c616d79dbc160b)) - - +- add SFDX_DISABLE_DNS_CHECK ([2e2cb84](https://github.com/forcedotcom/sfdx-core/commit/2e2cb84f557ecb057358efa107c616d79dbc160b)) ## [2.18.6](https://github.com/forcedotcom/sfdx-core/compare/v2.18.5...v2.18.6) (2021-02-17) - ### Bug Fixes -* pass decrypted client secret for oauth ([#374](https://github.com/forcedotcom/sfdx-core/issues/374)) ([63bf84e](https://github.com/forcedotcom/sfdx-core/commit/63bf84eaa962c151dc6a5ffcec3edcdf4bf91b05)) - - +- pass decrypted client secret for oauth ([#374](https://github.com/forcedotcom/sfdx-core/issues/374)) ([63bf84e](https://github.com/forcedotcom/sfdx-core/commit/63bf84eaa962c151dc6a5ffcec3edcdf4bf91b05)) ## [2.18.5](https://github.com/forcedotcom/sfdx-core/compare/v2.18.4...v2.18.5) (2021-02-11) - ### Bug Fixes -* filter allowedProperties on getConfigInfo ([cbb91e1](https://github.com/forcedotcom/sfdx-core/commit/cbb91e1604f7c7c8b192b8d6ca2c64bdd4fb05b2)) -* no throw on unknown config value ([49618db](https://github.com/forcedotcom/sfdx-core/commit/49618db01cd180fd1267092d36754d83a6514182)) - - +- filter allowedProperties on getConfigInfo ([cbb91e1](https://github.com/forcedotcom/sfdx-core/commit/cbb91e1604f7c7c8b192b8d6ca2c64bdd4fb05b2)) +- no throw on unknown config value ([49618db](https://github.com/forcedotcom/sfdx-core/commit/49618db01cd180fd1267092d36754d83a6514182)) ## [2.18.4](https://github.com/forcedotcom/sfdx-core/compare/v2.18.3...v2.18.4) (2021-02-10) - ### Bug Fixes -* isresolvable mock ([6a7e8b1](https://github.com/forcedotcom/sfdx-core/commit/6a7e8b153a42135792a3df58b809981706492e83)) - - +- isresolvable mock ([6a7e8b1](https://github.com/forcedotcom/sfdx-core/commit/6a7e8b153a42135792a3df58b809981706492e83)) ## [2.18.3](https://github.com/forcedotcom/sfdx-core/compare/v2.18.2...v2.18.3) (2021-02-05) - ### Bug Fixes -* update password jsdoc for v51 + return type ([390ed8d](https://github.com/forcedotcom/sfdx-core/commit/390ed8d0f15ee3915e35ccea5505890b10f16c81)) - - +- update password jsdoc for v51 + return type ([390ed8d](https://github.com/forcedotcom/sfdx-core/commit/390ed8d0f15ee3915e35ccea5505890b10f16c81)) ## [2.18.2](https://github.com/forcedotcom/sfdx-core/compare/v2.18.1...v2.18.2) (2021-02-04) - ### Bug Fixes -* fixed maxQueryLimit validation ([6431065](https://github.com/forcedotcom/sfdx-core/commit/6431065a0da6a615ef19594f69c069a19885f3e5)) -* fixed test descriptions ([1455204](https://github.com/forcedotcom/sfdx-core/commit/145520456c48c59003b1397ef7bcdf7a047ac083)) -* improved validation, error message, add test ([63e6c4d](https://github.com/forcedotcom/sfdx-core/commit/63e6c4d5814aa324d41b87a7ec275c16a085ef78)) -* maxQueryLimit must be > 0 ([a3d9156](https://github.com/forcedotcom/sfdx-core/commit/a3d91561f7510901dc02e42e80bb943bf3008a62)) - - +- fixed maxQueryLimit validation ([6431065](https://github.com/forcedotcom/sfdx-core/commit/6431065a0da6a615ef19594f69c069a19885f3e5)) +- fixed test descriptions ([1455204](https://github.com/forcedotcom/sfdx-core/commit/145520456c48c59003b1397ef7bcdf7a047ac083)) +- improved validation, error message, add test ([63e6c4d](https://github.com/forcedotcom/sfdx-core/commit/63e6c4d5814aa324d41b87a7ec275c16a085ef78)) +- maxQueryLimit must be > 0 ([a3d9156](https://github.com/forcedotcom/sfdx-core/commit/a3d91561f7510901dc02e42e80bb943bf3008a62)) ## [2.18.1](https://github.com/forcedotcom/sfdx-core/compare/v2.18.0...v2.18.1) (2021-02-04) - ### Bug Fixes -* add space option to write json ([51d01aa](https://github.com/forcedotcom/sfdx-core/commit/51d01aae7f7b2fc7fe0cf10ec9cffd170e0574ca)) - - +- add space option to write json ([51d01aa](https://github.com/forcedotcom/sfdx-core/commit/51d01aae7f7b2fc7fe0cf10ec9cffd170e0574ca)) # [2.18.0](https://github.com/forcedotcom/sfdx-core/compare/v2.17.0...v2.18.0) (2021-02-01) - ### Bug Fixes -* audience for loginUrls without my in the domain ([2bca84c](https://github.com/forcedotcom/sfdx-core/commit/2bca84c0b66d59b536ffa61f051e43b43c4c23dd)) -* audiences handle uppercased CS instances ([0d6d3ea](https://github.com/forcedotcom/sfdx-core/commit/0d6d3ea14601c1008f16e7d23af2802ef8e3ff65)) -* audiences use instanceURL ([64590cc](https://github.com/forcedotcom/sfdx-core/commit/64590cc4f9f30a37dbf4d17a6cf8db53ba0bdd09)) -* support enhanced domains ([a89ce21](https://github.com/forcedotcom/sfdx-core/commit/a89ce21c24ddbdd4cfad0772490f16768e5a0e3c)) - +- audience for loginUrls without my in the domain ([2bca84c](https://github.com/forcedotcom/sfdx-core/commit/2bca84c0b66d59b536ffa61f051e43b43c4c23dd)) +- audiences handle uppercased CS instances ([0d6d3ea](https://github.com/forcedotcom/sfdx-core/commit/0d6d3ea14601c1008f16e7d23af2802ef8e3ff65)) +- audiences use instanceURL ([64590cc](https://github.com/forcedotcom/sfdx-core/commit/64590cc4f9f30a37dbf4d17a6cf8db53ba0bdd09)) +- support enhanced domains ([a89ce21](https://github.com/forcedotcom/sfdx-core/commit/a89ce21c24ddbdd4cfad0772490f16768e5a0e3c)) ### Features -* falcon usa support w/o createdOrgInstance ([ec15d37](https://github.com/forcedotcom/sfdx-core/commit/ec15d37cb2500e41e787c432579e87ec7ed126d4)) -* more falcon domain support, url case insensitivity ([f72b85d](https://github.com/forcedotcom/sfdx-core/commit/f72b85d3e8a875306654bc7eb5b692218f242518)) -* more jwt audience domains ([03751ea](https://github.com/forcedotcom/sfdx-core/commit/03751ea884eacb59eecaadd139a8a09035cd08d0)) - - +- falcon usa support w/o createdOrgInstance ([ec15d37](https://github.com/forcedotcom/sfdx-core/commit/ec15d37cb2500e41e787c432579e87ec7ed126d4)) +- more falcon domain support, url case insensitivity ([f72b85d](https://github.com/forcedotcom/sfdx-core/commit/f72b85d3e8a875306654bc7eb5b692218f242518)) +- more jwt audience domains ([03751ea](https://github.com/forcedotcom/sfdx-core/commit/03751ea884eacb59eecaadd139a8a09035cd08d0)) # [2.17.0](https://github.com/forcedotcom/sfdx-core/compare/v2.16.6...v2.17.0) (2021-01-29) - ### Bug Fixes -* at least 3 ([109da8a](https://github.com/forcedotcom/sfdx-core/commit/109da8a5b335678c4967bd2aef92069e1f1bd955)) - +- at least 3 ([109da8a](https://github.com/forcedotcom/sfdx-core/commit/109da8a5b335678c4967bd2aef92069e1f1bd955)) ### Features -* adjustable DNS timeout ([9db7b66](https://github.com/forcedotcom/sfdx-core/commit/9db7b66bf8f3fb284ab98c0fbd0906c6195eabc6)) - - +- adjustable DNS timeout ([9db7b66](https://github.com/forcedotcom/sfdx-core/commit/9db7b66bf8f3fb284ab98c0fbd0906c6195eabc6)) ## [2.16.6](https://github.com/forcedotcom/sfdx-core/compare/v2.16.5...v2.16.6) (2021-01-29) - ### Bug Fixes -* add internal mil environment ([27e33ae](https://github.com/forcedotcom/sfdx-core/commit/27e33ae0a99ebc2c63364a67348174ab56468290)) -* additional "internal" host ([af15447](https://github.com/forcedotcom/sfdx-core/commit/af15447166e85124326134a4f8d51b9fd05381ea)) -* internal, local, and new stm.force domains ([b93f26d](https://github.com/forcedotcom/sfdx-core/commit/b93f26d2a2e255a0ef3089cde1d20445aa12e802)) -* myDomainResolver shouldn't check localhost ([c07984e](https://github.com/forcedotcom/sfdx-core/commit/c07984e507d98be59ca15da97621b92bd2e73497)) - - +- add internal mil environment ([27e33ae](https://github.com/forcedotcom/sfdx-core/commit/27e33ae0a99ebc2c63364a67348174ab56468290)) +- additional "internal" host ([af15447](https://github.com/forcedotcom/sfdx-core/commit/af15447166e85124326134a4f8d51b9fd05381ea)) +- internal, local, and new stm.force domains ([b93f26d](https://github.com/forcedotcom/sfdx-core/commit/b93f26d2a2e255a0ef3089cde1d20445aa12e802)) +- myDomainResolver shouldn't check localhost ([c07984e](https://github.com/forcedotcom/sfdx-core/commit/c07984e507d98be59ca15da97621b92bd2e73497)) ## [2.16.5](https://github.com/forcedotcom/sfdx-core/compare/v2.16.4...v2.16.5) (2021-01-29) - ### Bug Fixes -* send oauth error to browser ([5fd027a](https://github.com/forcedotcom/sfdx-core/commit/5fd027a2ee8c12b21621f7478763175f499a1517)) - - +- send oauth error to browser ([5fd027a](https://github.com/forcedotcom/sfdx-core/commit/5fd027a2ee8c12b21621f7478763175f499a1517)) ## [2.16.4](https://github.com/forcedotcom/sfdx-core/compare/v2.16.3...v2.16.4) (2021-01-27) - ### Bug Fixes -* remove mobile domains ([ae413db](https://github.com/forcedotcom/sfdx-core/commit/ae413db35916ecd480524d1994664729c0685f2f)) - - +- remove mobile domains ([ae413db](https://github.com/forcedotcom/sfdx-core/commit/ae413db35916ecd480524d1994664729c0685f2f)) ## [2.16.3](https://github.com/forcedotcom/sfdx-core/compare/v2.16.2...v2.16.3) (2021-01-21) - - ## [2.16.2](https://github.com/forcedotcom/sfdx-core/compare/v2.16.1...v2.16.2) (2021-01-21) - ### Bug Fixes -* better error messaging and Steve feedback ([20c8977](https://github.com/forcedotcom/sfdx-core/commit/20c897739d077a15945701843fac9c2c3457dff4)) -* better error name ([43cac98](https://github.com/forcedotcom/sfdx-core/commit/43cac980bba0bf276a28cd7d90b4bc3656cacd3b)) -* error name as a constant ([92ced7e](https://github.com/forcedotcom/sfdx-core/commit/92ced7e7de418c4dc36af6d12be930adcf801706)) -* export name for testing ([fda9ce0](https://github.com/forcedotcom/sfdx-core/commit/fda9ce0a802917cbcf496dc03450182f3ec5f79a)) -* line spacing ([89e4dc7](https://github.com/forcedotcom/sfdx-core/commit/89e4dc7d46e7b3b553329c7eb125caa75015dce1)) -* log versions as string ([d82fe3e](https://github.com/forcedotcom/sfdx-core/commit/d82fe3e8a41c177bd905ee3278332db375dc9761)) -* prevent DNS ENOTFOUND from hitting stdout ([1bc473f](https://github.com/forcedotcom/sfdx-core/commit/1bc473fc36ff70edbb1145b1c2f3ae6e0a4331ee)) - - +- better error messaging and Steve feedback ([20c8977](https://github.com/forcedotcom/sfdx-core/commit/20c897739d077a15945701843fac9c2c3457dff4)) +- better error name ([43cac98](https://github.com/forcedotcom/sfdx-core/commit/43cac980bba0bf276a28cd7d90b4bc3656cacd3b)) +- error name as a constant ([92ced7e](https://github.com/forcedotcom/sfdx-core/commit/92ced7e7de418c4dc36af6d12be930adcf801706)) +- export name for testing ([fda9ce0](https://github.com/forcedotcom/sfdx-core/commit/fda9ce0a802917cbcf496dc03450182f3ec5f79a)) +- line spacing ([89e4dc7](https://github.com/forcedotcom/sfdx-core/commit/89e4dc7d46e7b3b553329c7eb125caa75015dce1)) +- log versions as string ([d82fe3e](https://github.com/forcedotcom/sfdx-core/commit/d82fe3e8a41c177bd905ee3278332db375dc9761)) +- prevent DNS ENOTFOUND from hitting stdout ([1bc473f](https://github.com/forcedotcom/sfdx-core/commit/1bc473fc36ff70edbb1145b1c2f3ae6e0a4331ee)) ## [2.16.1](https://github.com/forcedotcom/sfdx-core/compare/v2.16.0...v2.16.1) (2021-01-20) - - # [2.16.0](https://github.com/forcedotcom/sfdx-core/compare/v2.15.5...v2.16.0) (2021-01-12) - ### Bug Fixes -* bumped npm release to v4 ([1ad0a98](https://github.com/forcedotcom/sfdx-core/commit/1ad0a984fd75e5e0cba20a907f542014b919095f)) -* dry-run fixed orb ([b3eb476](https://github.com/forcedotcom/sfdx-core/commit/b3eb4764b63869907d653d63e47f4e092df75481)) -* per peter feedback ([e0c366a](https://github.com/forcedotcom/sfdx-core/commit/e0c366ad6d7b7affb746aa8ba4869685f8563b5d)) -* remove another redundant condition ([021ff2d](https://github.com/forcedotcom/sfdx-core/commit/021ff2d08292148e50cf1ba8eccc54c92ed12328)) -* revert dry-run fix ([b415aca](https://github.com/forcedotcom/sfdx-core/commit/b415aca58e005093760cd8873e67d69ce70e1935)) -* updated yarn.lock ([7caaed5](https://github.com/forcedotcom/sfdx-core/commit/7caaed58d4f18bb6be675b690b1b9fc17c16d207)) - +- bumped npm release to v4 ([1ad0a98](https://github.com/forcedotcom/sfdx-core/commit/1ad0a984fd75e5e0cba20a907f542014b919095f)) +- dry-run fixed orb ([b3eb476](https://github.com/forcedotcom/sfdx-core/commit/b3eb4764b63869907d653d63e47f4e092df75481)) +- per peter feedback ([e0c366a](https://github.com/forcedotcom/sfdx-core/commit/e0c366ad6d7b7affb746aa8ba4869685f8563b5d)) +- remove another redundant condition ([021ff2d](https://github.com/forcedotcom/sfdx-core/commit/021ff2d08292148e50cf1ba8eccc54c92ed12328)) +- revert dry-run fix ([b415aca](https://github.com/forcedotcom/sfdx-core/commit/b415aca58e005093760cd8873e67d69ce70e1935)) +- updated yarn.lock ([7caaed5](https://github.com/forcedotcom/sfdx-core/commit/7caaed58d4f18bb6be675b690b1b9fc17c16d207)) ### Features -* singleRecordQuery ([ea72d9f](https://github.com/forcedotcom/sfdx-core/commit/ea72d9f3e31aff8dbcf1f15fd7539f75cafc4ffc)) - - +- singleRecordQuery ([ea72d9f](https://github.com/forcedotcom/sfdx-core/commit/ea72d9f3e31aff8dbcf1f15fd7539f75cafc4ffc)) ## [2.15.5](https://github.com/forcedotcom/sfdx-core/compare/v2.15.4...v2.15.5) (2021-01-07) - ### Bug Fixes -* accessToken works as username ([6f0ec24](https://github.com/forcedotcom/sfdx-core/commit/6f0ec24d0b220f4ba6f3460392c2ae6fc3b4d998)) -* get username from accessToken ([18dd97d](https://github.com/forcedotcom/sfdx-core/commit/18dd97dad14639d66a19cfde0b33497864fa3594)) -* test > match ([56815e8](https://github.com/forcedotcom/sfdx-core/commit/56815e85cbaf6fd0b7253c83af08d62ba6b1f685)) - - +- accessToken works as username ([6f0ec24](https://github.com/forcedotcom/sfdx-core/commit/6f0ec24d0b220f4ba6f3460392c2ae6fc3b4d998)) +- get username from accessToken ([18dd97d](https://github.com/forcedotcom/sfdx-core/commit/18dd97dad14639d66a19cfde0b33497864fa3594)) +- test > match ([56815e8](https://github.com/forcedotcom/sfdx-core/commit/56815e85cbaf6fd0b7253c83af08d62ba6b1f685)) ## [2.15.4](https://github.com/forcedotcom/sfdx-core/compare/v2.15.3...v2.15.4) (2020-12-09) - ### Bug Fixes -* **windows:** throw error when file is not accessible ([3c5e5f8](https://github.com/forcedotcom/sfdx-core/commit/3c5e5f83ead8fe5f8e9cfc9623a3d4296e42458f)) - - +- **windows:** throw error when file is not accessible ([3c5e5f8](https://github.com/forcedotcom/sfdx-core/commit/3c5e5f83ead8fe5f8e9cfc9623a3d4296e42458f)) ## [2.15.3](https://github.com/forcedotcom/sfdx-core/compare/v2.15.2...v2.15.3) (2020-12-02) - ### Bug Fixes -* added docs around MyDomainResolver constructor method ([68d8e52](https://github.com/forcedotcom/sfdx-core/commit/68d8e520353dae10cda4b04153ec7cc753cbc02a)) -* single package entry is defaulted to default package ([badff89](https://github.com/forcedotcom/sfdx-core/commit/badff89be92c492d990dc91ce79ff94eb88a7117)) - - +- added docs around MyDomainResolver constructor method ([68d8e52](https://github.com/forcedotcom/sfdx-core/commit/68d8e520353dae10cda4b04153ec7cc753cbc02a)) +- single package entry is defaulted to default package ([badff89](https://github.com/forcedotcom/sfdx-core/commit/badff89be92c492d990dc91ce79ff94eb88a7117)) ## [2.15.2](https://github.com/forcedotcom/sfdx-core/compare/v2.15.1...v2.15.2) (2020-11-11) - ### Bug Fixes -* config aggregator show changes to local and global config ([e3b3a55](https://github.com/forcedotcom/sfdx-core/commit/e3b3a55b7ea5e3a728ea021c8eb6a24555b63dc4)) -* localConfig typings now correctly show it might not exist ([3cb7716](https://github.com/forcedotcom/sfdx-core/commit/3cb7716fff790aac2357cd28dd28e11e81513e4f)) -* updated various logic and QOL on User and PermissionSetAssignment ([1bab28f](https://github.com/forcedotcom/sfdx-core/commit/1bab28fc799cba944aa01aa5d330e5524e267b63)) - - +- config aggregator show changes to local and global config ([e3b3a55](https://github.com/forcedotcom/sfdx-core/commit/e3b3a55b7ea5e3a728ea021c8eb6a24555b63dc4)) +- localConfig typings now correctly show it might not exist ([3cb7716](https://github.com/forcedotcom/sfdx-core/commit/3cb7716fff790aac2357cd28dd28e11e81513e4f)) +- updated various logic and QOL on User and PermissionSetAssignment ([1bab28f](https://github.com/forcedotcom/sfdx-core/commit/1bab28fc799cba944aa01aa5d330e5524e267b63)) ## [2.15.1](https://github.com/forcedotcom/sfdx-core/compare/v2.15.0...v2.15.1) (2020-11-02) - ### Bug Fixes -* move @types/mkdirp to dependencies ([e8e5cf7](https://github.com/forcedotcom/sfdx-core/commit/e8e5cf753c9d3ca56ae9f55e90b41d6168b49d0b)) - - +- move @types/mkdirp to dependencies ([e8e5cf7](https://github.com/forcedotcom/sfdx-core/commit/e8e5cf753c9d3ca56ae9f55e90b41d6168b49d0b)) # [2.15.0](https://github.com/forcedotcom/sfdx-core/compare/v2.14.0...v2.15.0) (2020-10-30) - ### Features -* allow adding property metas to allowedProperties on config ([2a264d3](https://github.com/forcedotcom/sfdx-core/commit/2a264d3ca3002c4c90c771beaa2036a06d331697)) - - +- allow adding property metas to allowedProperties on config ([2a264d3](https://github.com/forcedotcom/sfdx-core/commit/2a264d3ca3002c4c90c771beaa2036a06d331697)) # [2.14.0](https://github.com/forcedotcom/sfdx-core/compare/v2.13.0...v2.14.0) (2020-10-22) - ### Features -* add decrypt option to getFields ([ccd32e2](https://github.com/forcedotcom/sfdx-core/commit/ccd32e20aa613554153c75bab59373225cea2382)) - - +- add decrypt option to getFields ([ccd32e2](https://github.com/forcedotcom/sfdx-core/commit/ccd32e20aa613554153c75bab59373225cea2382)) # [2.13.0](https://github.com/forcedotcom/sfdx-core/compare/v2.12.3...v2.13.0) (2020-10-13) - ### Bug Fixes -* add falcon sandboxes ([558dd72](https://github.com/forcedotcom/sfdx-core/commit/558dd720d1988ad2d80fa9227b277e56c284e09a)) -* mock package json instead of fs ([8cba4d1](https://github.com/forcedotcom/sfdx-core/commit/8cba4d1e04a7c8fbe98e9cc646f663f404330394)) -* resolve sfdx project path before checking cache ([265e523](https://github.com/forcedotcom/sfdx-core/commit/265e52350a69028f6a81aafb2e9779f455a29c31)) - +- add falcon sandboxes ([558dd72](https://github.com/forcedotcom/sfdx-core/commit/558dd720d1988ad2d80fa9227b277e56c284e09a)) +- mock package json instead of fs ([8cba4d1](https://github.com/forcedotcom/sfdx-core/commit/8cba4d1e04a7c8fbe98e9cc646f663f404330394)) +- resolve sfdx project path before checking cache ([265e523](https://github.com/forcedotcom/sfdx-core/commit/265e52350a69028f6a81aafb2e9779f455a29c31)) ### Features -* add DeviceOauthService ([3e72962](https://github.com/forcedotcom/sfdx-core/commit/3e72962fd3a192b7dc6ff2ce7123ef7312185694)) -* add WebOauthServer for web based auth flow ([25cea05](https://github.com/forcedotcom/sfdx-core/commit/25cea057200fcb5861d6862f877832a1ad93fd79)) - - +- add DeviceOauthService ([3e72962](https://github.com/forcedotcom/sfdx-core/commit/3e72962fd3a192b7dc6ff2ce7123ef7312185694)) +- add WebOauthServer for web based auth flow ([25cea05](https://github.com/forcedotcom/sfdx-core/commit/25cea057200fcb5861d6862f877832a1ad93fd79)) ## [2.12.3](https://github.com/forcedotcom/sfdx-core/compare/v2.12.2...v2.12.3) (2020-10-01) - ### Bug Fixes -* lifecycle should be a singleton across core versions ([66a450b](https://github.com/forcedotcom/sfdx-core/commit/66a450b0a0030d85c61645eb8c782289e4938e4a)) -* stub should call resolver at runtime ([9002cbf](https://github.com/forcedotcom/sfdx-core/commit/9002cbf8f02da9422dd547a3ea989d174749726b)) - - +- lifecycle should be a singleton across core versions ([66a450b](https://github.com/forcedotcom/sfdx-core/commit/66a450b0a0030d85c61645eb8c782289e4938e4a)) +- stub should call resolver at runtime ([9002cbf](https://github.com/forcedotcom/sfdx-core/commit/9002cbf8f02da9422dd547a3ea989d174749726b)) ## [2.12.2](https://github.com/forcedotcom/sfdx-core/compare/v2.12.1...v2.12.2) (2020-09-28) - ### Bug Fixes -* fixed mocking error ([f5cfe52](https://github.com/forcedotcom/sfdx-core/commit/f5cfe52605e54ab8250e155e17077bc03b0cd6ec)) - - +- fixed mocking error ([f5cfe52](https://github.com/forcedotcom/sfdx-core/commit/f5cfe52605e54ab8250e155e17077bc03b0cd6ec)) ## [2.12.1](https://github.com/forcedotcom/sfdx-core/compare/v2.12.0...v2.12.1) (2020-09-18) - ### Bug Fixes -* missed line in merge ([9f73ba5](https://github.com/forcedotcom/sfdx-core/commit/9f73ba52c6cf3330b3a3f4560920e35296151bd5)) - - +- missed line in merge ([9f73ba5](https://github.com/forcedotcom/sfdx-core/commit/9f73ba52c6cf3330b3a3f4560920e35296151bd5)) # [2.12.0](https://github.com/forcedotcom/sfdx-core/compare/v2.11.0...v2.12.0) (2020-09-14) - ### Bug Fixes -* convert core from tslint -> eslint ([d4791c8](https://github.com/forcedotcom/sfdx-core/commit/d4791c8db200a18973d2164971395998693b3d03)) -* query for username during refresh token flow ([f640070](https://github.com/forcedotcom/sfdx-core/commit/f640070feef25c0589cbcad8868152a564be028c)) -* some changes regressed toolbelt ([#299](https://github.com/forcedotcom/sfdx-core/issues/299)) ([2c571a7](https://github.com/forcedotcom/sfdx-core/commit/2c571a729c4d62fc2da4427aa28ebfc769c92b97)) - +- convert core from tslint -> eslint ([d4791c8](https://github.com/forcedotcom/sfdx-core/commit/d4791c8db200a18973d2164971395998693b3d03)) +- query for username during refresh token flow ([f640070](https://github.com/forcedotcom/sfdx-core/commit/f640070feef25c0589cbcad8868152a564be028c)) +- some changes regressed toolbelt ([#299](https://github.com/forcedotcom/sfdx-core/issues/299)) ([2c571a7](https://github.com/forcedotcom/sfdx-core/commit/2c571a729c4d62fc2da4427aa28ebfc769c92b97)) ### Features -* add a lot of sync method, add package directory information to the project ([#284](https://github.com/forcedotcom/sfdx-core/issues/284)) ([b973901](https://github.com/forcedotcom/sfdx-core/commit/b973901d69855debecc553452a6664dc482cc3c5)) -* add scope options ([#289](https://github.com/forcedotcom/sfdx-core/issues/289)) ([6bc23ec](https://github.com/forcedotcom/sfdx-core/commit/6bc23ecbb0f744e8575ac21b90a59bf540a79156)) -* support plugin-auth ([a1f6eca](https://github.com/forcedotcom/sfdx-core/commit/a1f6eca37d26cb869014e1cd7eafcc3eb5b5e830)) - - +- add a lot of sync method, add package directory information to the project ([#284](https://github.com/forcedotcom/sfdx-core/issues/284)) ([b973901](https://github.com/forcedotcom/sfdx-core/commit/b973901d69855debecc553452a6664dc482cc3c5)) +- add scope options ([#289](https://github.com/forcedotcom/sfdx-core/issues/289)) ([6bc23ec](https://github.com/forcedotcom/sfdx-core/commit/6bc23ecbb0f744e8575ac21b90a59bf540a79156)) +- support plugin-auth ([a1f6eca](https://github.com/forcedotcom/sfdx-core/commit/a1f6eca37d26cb869014e1cd7eafcc3eb5b5e830)) # [2.11.0](https://github.com/forcedotcom/sfdx-core/compare/v2.10.0...v2.11.0) (2020-08-27) - ### Bug Fixes -* examples/package.json & examples/yarn.lock to reduce vulnerabilities ([d062ccc](https://github.com/forcedotcom/sfdx-core/commit/d062cccdd96d16f45dafd41425827299a26ed766)) -* wrap logfmt message with double quotes ([#280](https://github.com/forcedotcom/sfdx-core/issues/280)) ([3ef407b](https://github.com/forcedotcom/sfdx-core/commit/3ef407b667cdd65dc2bbd8259924e0b8b7ecb284)) - +- examples/package.json & examples/yarn.lock to reduce vulnerabilities ([d062ccc](https://github.com/forcedotcom/sfdx-core/commit/d062cccdd96d16f45dafd41425827299a26ed766)) +- wrap logfmt message with double quotes ([#280](https://github.com/forcedotcom/sfdx-core/issues/280)) ([3ef407b](https://github.com/forcedotcom/sfdx-core/commit/3ef407b667cdd65dc2bbd8259924e0b8b7ecb284)) ### Features -* support array of messages when using getMessage ([ac7407a](https://github.com/forcedotcom/sfdx-core/commit/ac7407ad899fba3825082ba23f53b66101b699de)) -* support logfmt style formatting ([#273](https://github.com/forcedotcom/sfdx-core/issues/273)) ([2767cbf](https://github.com/forcedotcom/sfdx-core/commit/2767cbfe4ec356915140260dfb780ec3b39ccb84)) - - +- support array of messages when using getMessage ([ac7407a](https://github.com/forcedotcom/sfdx-core/commit/ac7407ad899fba3825082ba23f53b66101b699de)) +- support logfmt style formatting ([#273](https://github.com/forcedotcom/sfdx-core/issues/273)) ([2767cbf](https://github.com/forcedotcom/sfdx-core/commit/2767cbfe4ec356915140260dfb780ec3b39ccb84)) # [2.10.0](https://github.com/forcedotcom/sfdx-core/compare/v2.9.4...v2.10.0) (2020-08-10) - ### Features -* support logfmt style formatting ([#273](https://github.com/forcedotcom/sfdx-core/issues/273)) ([#274](https://github.com/forcedotcom/sfdx-core/issues/274)) ([93b156c](https://github.com/forcedotcom/sfdx-core/commit/93b156c6e82ee8029bd4c8ec714b75c89e0f531f)) - - +- support logfmt style formatting ([#273](https://github.com/forcedotcom/sfdx-core/issues/273)) ([#274](https://github.com/forcedotcom/sfdx-core/issues/274)) ([93b156c](https://github.com/forcedotcom/sfdx-core/commit/93b156c6e82ee8029bd4c8ec714b75c89e0f531f)) ## [2.9.4](https://github.com/forcedotcom/sfdx-core/compare/v2.9.3...v2.9.4) (2020-08-07) - ### Bug Fixes -* updated messaging ([7f9ab06](https://github.com/forcedotcom/sfdx-core/commit/7f9ab06ecbde1ac082f027f35f07002efb8dc7cf)) -* fix edge case, updated messaging ([a8f9a54](https://github.com/forcedotcom/sfdx-core/commit/a8f9a547893918b2a3f6a23e9bcfa99e13b28974)) - - +- updated messaging ([7f9ab06](https://github.com/forcedotcom/sfdx-core/commit/7f9ab06ecbde1ac082f027f35f07002efb8dc7cf)) +- fix edge case, updated messaging ([a8f9a54](https://github.com/forcedotcom/sfdx-core/commit/a8f9a547893918b2a3f6a23e9bcfa99e13b28974)) ## [2.9.3](https://github.com/forcedotcom/sfdx-core/compare/v2.9.2...v2.9.3) (2020-08-06) - ### Bug Fixes -* changed to be greater than, not greater than or equal to ([7f1a12d](https://github.com/forcedotcom/sfdx-core/commit/7f1a12d7a7d7aa460de5bb32a368f52c11219a4e)) - - +- changed to be greater than, not greater than or equal to ([7f1a12d](https://github.com/forcedotcom/sfdx-core/commit/7f1a12d7a7d7aa460de5bb32a368f52c11219a4e)) ## [2.9.2](https://github.com/forcedotcom/sfdx-core/compare/v2.9.1...v2.9.2) (2020-08-06) - ### Bug Fixes -* maxQueryLimit config, return full jsforce result, fix build issue ([6c11196](https://github.com/forcedotcom/sfdx-core/commit/6c11196a48e19bca8d43fd994fa864bf3cb72cfa)) -* removed promise.reject ([d28d649](https://github.com/forcedotcom/sfdx-core/commit/d28d649f60ca1362380b4e5e408376561d6a64ed)) -* updated autoFetchQuery method ([4d018f6](https://github.com/forcedotcom/sfdx-core/commit/4d018f6d2c8e4d6b19179563f11db2ff1f9b5f3d)) - - +- maxQueryLimit config, return full jsforce result, fix build issue ([6c11196](https://github.com/forcedotcom/sfdx-core/commit/6c11196a48e19bca8d43fd994fa864bf3cb72cfa)) +- removed promise.reject ([d28d649](https://github.com/forcedotcom/sfdx-core/commit/d28d649f60ca1362380b4e5e408376561d6a64ed)) +- updated autoFetchQuery method ([4d018f6](https://github.com/forcedotcom/sfdx-core/commit/4d018f6d2c8e4d6b19179563f11db2ff1f9b5f3d)) ## [2.9.1](https://github.com/forcedotcom/sfdx-core/compare/v2.9.0...v2.9.1) (2020-08-04) - ### Bug Fixes -* remove encrypted from ISV_URL ([d2c89fe](https://github.com/forcedotcom/sfdx-core/commit/d2c89fed3602f0f9e06a3cefa605268914d69d6e)), closes [#262](https://github.com/forcedotcom/sfdx-core/issues/262) - - +- remove encrypted from ISV_URL ([d2c89fe](https://github.com/forcedotcom/sfdx-core/commit/d2c89fed3602f0f9e06a3cefa605268914d69d6e)), closes [#262](https://github.com/forcedotcom/sfdx-core/issues/262) # [2.9.0](https://github.com/forcedotcom/sfdx-core/compare/v2.8.0...v2.9.0) (2020-07-29) - ### Features -* overwriting configStore unset ([6095dd6](https://github.com/forcedotcom/sfdx-core/commit/6095dd69ab4ed5e4324e5a46d8ec5bed74bb538a)) - - +- overwriting configStore unset ([6095dd6](https://github.com/forcedotcom/sfdx-core/commit/6095dd69ab4ed5e4324e5a46d8ec5bed74bb538a)) # [2.8.0](https://github.com/forcedotcom/sfdx-core/compare/v2.7.0...v2.8.0) (2020-07-27) - ### Features -* changed data to be more flexible type ([50414f9](https://github.com/forcedotcom/sfdx-core/commit/50414f936569993b5bdf96c90bf251bbd6083b10)) - - +- changed data to be more flexible type ([50414f9](https://github.com/forcedotcom/sfdx-core/commit/50414f936569993b5bdf96c90bf251bbd6083b10)) # [2.7.0](https://github.com/forcedotcom/sfdx-core/compare/v2.6.0...v2.7.0) (2020-07-01) - ### Features -* adds areFilesEqual / actOn / getContentHash from toolbelt to core ([807dc72](https://github.com/forcedotcom/sfdx-core/commit/807dc729f414cda335fcba737580b53fc6ceddc1)) - - +- adds areFilesEqual / actOn / getContentHash from toolbelt to core ([807dc72](https://github.com/forcedotcom/sfdx-core/commit/807dc729f414cda335fcba737580b53fc6ceddc1)) # [2.6.0](https://github.com/forcedotcom/sfdx-core/compare/v2.5.1...v2.6.0) (2020-06-23) - ### Bug Fixes -* added line breaks for readability ([0f8b857](https://github.com/forcedotcom/sfdx-core/commit/0f8b8576d6401ed88b424e60e2f9302003d9ea90)) -* fixed a capitalization that caused CircleCI to fail ([db803a7](https://github.com/forcedotcom/sfdx-core/commit/db803a7fc83ead6fccf84e1791ba668cd25d013e)) -* updated comments and async for loop ([fa3b580](https://github.com/forcedotcom/sfdx-core/commit/fa3b580d82b3bb389a4d1b7edf9340080d392f50)) - +- added line breaks for readability ([0f8b857](https://github.com/forcedotcom/sfdx-core/commit/0f8b8576d6401ed88b424e60e2f9302003d9ea90)) +- fixed a capitalization that caused CircleCI to fail ([db803a7](https://github.com/forcedotcom/sfdx-core/commit/db803a7fc83ead6fccf84e1791ba668cd25d013e)) +- updated comments and async for loop ([fa3b580](https://github.com/forcedotcom/sfdx-core/commit/fa3b580d82b3bb389a4d1b7edf9340080d392f50)) ### Features -* added lifecycleEvents.ts from toolbelt: an event listener/emitter ([099478c](https://github.com/forcedotcom/sfdx-core/commit/099478cf087c024d965bba16bb6341df64ce7edb)) - - +- added lifecycleEvents.ts from toolbelt: an event listener/emitter ([099478c](https://github.com/forcedotcom/sfdx-core/commit/099478cf087c024d965bba16bb6341df64ce7edb)) ## [2.5.1](https://github.com/forcedotcom/sfdx-core/compare/v2.5.0...v2.5.1) (2020-06-11) - ### Bug Fixes -* fix child logger unit test ([93da343](https://github.com/forcedotcom/sfdx-core/commit/93da3432e83e4db0f2642b54f618521ea53bc414)) -* log uncaught exception in root logger only ([7a80662](https://github.com/forcedotcom/sfdx-core/commit/7a806622e1007d363f317f90a392328f6b6d40e7)) -* mock audience url for unit test ([963b696](https://github.com/forcedotcom/sfdx-core/commit/963b6960e971adaafd43c31581ffc07686fc8378)) - - +- fix child logger unit test ([93da343](https://github.com/forcedotcom/sfdx-core/commit/93da3432e83e4db0f2642b54f618521ea53bc414)) +- log uncaught exception in root logger only ([7a80662](https://github.com/forcedotcom/sfdx-core/commit/7a806622e1007d363f317f90a392328f6b6d40e7)) +- mock audience url for unit test ([963b696](https://github.com/forcedotcom/sfdx-core/commit/963b6960e971adaafd43c31581ffc07686fc8378)) # [2.5.0](https://github.com/forcedotcom/sfdx-core/compare/v2.4.1...v2.5.0) (2020-06-08) - ### Bug Fixes -* update mkdirp for updated dep ([e2b471b](https://github.com/forcedotcom/sfdx-core/commit/e2b471b120edd1b55bca50d71a2fe8d995ef8bbd)) - +- update mkdirp for updated dep ([e2b471b](https://github.com/forcedotcom/sfdx-core/commit/e2b471b120edd1b55bca50d71a2fe8d995ef8bbd)) ### Features -* add fs.fileExists ([0c5d0a7](https://github.com/forcedotcom/sfdx-core/commit/0c5d0a75867094f5b05d9d356f23c94c38d6213e)) - - +- add fs.fileExists ([0c5d0a7](https://github.com/forcedotcom/sfdx-core/commit/0c5d0a75867094f5b05d9d356f23c94c38d6213e)) ## [2.4.1](https://github.com/forcedotcom/sfdx-core/compare/v2.4.0...v2.4.1) (2020-05-05) - ### Bug Fixes -* don't ship with ts-sinon ([b4005fb](https://github.com/forcedotcom/sfdx-core/commit/b4005fb27b3f85be1297b9cfec0bc7e0de91979d)) -* fixed test spy ([c1f4ba4](https://github.com/forcedotcom/sfdx-core/commit/c1f4ba42ba94a03c5e3e77e793558cfea947f78e)) -* path.resolve jwt key file path ([86e6957](https://github.com/forcedotcom/sfdx-core/commit/86e695757a68dca1ea659e801ead59e57e6632b9)) - - +- don't ship with ts-sinon ([b4005fb](https://github.com/forcedotcom/sfdx-core/commit/b4005fb27b3f85be1297b9cfec0bc7e0de91979d)) +- fixed test spy ([c1f4ba4](https://github.com/forcedotcom/sfdx-core/commit/c1f4ba42ba94a03c5e3e77e793558cfea947f78e)) +- path.resolve jwt key file path ([86e6957](https://github.com/forcedotcom/sfdx-core/commit/86e695757a68dca1ea659e801ead59e57e6632b9)) # [2.4.0](https://github.com/forcedotcom/sfdx-core/compare/v2.3.1...v2.4.0) (2020-04-23) - ### Features -* create auth info with sfdx auth url ([68dbfad](https://github.com/forcedotcom/sfdx-core/commit/68dbfad817202813555b5438c498b24bfdb5aa0f)) - - +- create auth info with sfdx auth url ([68dbfad](https://github.com/forcedotcom/sfdx-core/commit/68dbfad817202813555b5438c498b24bfdb5aa0f)) ## [2.3.1](https://github.com/forcedotcom/sfdx-core/compare/v2.3.0...v2.3.1) (2020-04-13) - ### Bug Fixes -* use new @salesfore/bunyan library, run tests in node 10 & 12 ([#211](https://github.com/forcedotcom/sfdx-core/issues/211)) ([249850d](https://github.com/forcedotcom/sfdx-core/commit/249850dfbf5da4199709e9573944a4da72d0581d)) - - +- use new @salesfore/bunyan library, run tests in node 10 & 12 ([#211](https://github.com/forcedotcom/sfdx-core/issues/211)) ([249850d](https://github.com/forcedotcom/sfdx-core/commit/249850dfbf5da4199709e9573944a4da72d0581d)) # [2.3.0](https://github.com/forcedotcom/sfdx-core/compare/v2.2.0...v2.3.0) (2020-03-20) - ### Features -* allow stubbing on single tests ([37cef1b](https://github.com/forcedotcom/sfdx-core/commit/37cef1bbf8f4d1c4909f13c1fac7757f1430e40b)) - - +- allow stubbing on single tests ([37cef1b](https://github.com/forcedotcom/sfdx-core/commit/37cef1bbf8f4d1c4909f13c1fac7757f1430e40b)) # [2.2.0](https://github.com/forcedotcom/sfdx-core/compare/v2.1.6...v2.2.0) (2020-02-11) - ### Features -* create authinfo with a parent authinfo ([9b21226](https://github.com/forcedotcom/sfdx-core/commit/9b212264bafe458c95ae22fce11298c706d23393)), closes [#202](https://github.com/forcedotcom/sfdx-core/issues/202) - - +- create authinfo with a parent authinfo ([9b21226](https://github.com/forcedotcom/sfdx-core/commit/9b212264bafe458c95ae22fce11298c706d23393)), closes [#202](https://github.com/forcedotcom/sfdx-core/issues/202) ## [2.1.6](https://github.com/forcedotcom/sfdx-core/compare/v2.1.5...v2.1.6) (2020-01-13) - ### Bug Fixes -* add config var for telemetry opt out ([f79ace3](https://github.com/forcedotcom/sfdx-core/commit/f79ace34462f586feb296b94ee369e1f7922341d)) - - +- add config var for telemetry opt out ([f79ace3](https://github.com/forcedotcom/sfdx-core/commit/f79ace34462f586feb296b94ee369e1f7922341d)) ## [2.1.5](https://github.com/forcedotcom/sfdx-core/compare/v2.1.4...v2.1.5) (2019-11-15) - ### Bug Fixes -* rogue import causing compile issue ([d0b5e5c](https://github.com/forcedotcom/sfdx-core/commit/d0b5e5c13dc497ef0ba98d460e91514ea0400d7a)) - - +- rogue import causing compile issue ([d0b5e5c](https://github.com/forcedotcom/sfdx-core/commit/d0b5e5c13dc497ef0ba98d460e91514ea0400d7a)) ## [2.1.4](https://github.com/forcedotcom/sfdx-core/compare/v2.1.3...v2.1.4) (2019-11-04) - ### Bug Fixes -* contrib ([7e91751](https://github.com/forcedotcom/sfdx-core/commit/7e91751e1dcb1d3ca18d083262ae675503a7614b)) - - +- contrib ([7e91751](https://github.com/forcedotcom/sfdx-core/commit/7e91751e1dcb1d3ca18d083262ae675503a7614b)) ## [2.1.3](https://github.com/forcedotcom/sfdx-core/compare/v2.1.2...v2.1.3) (2019-10-09) - ### Bug Fixes -* make sure when stream processor throws an error we disconnect the streaming client ([6dc8de9](https://github.com/forcedotcom/sfdx-core/commit/6dc8de9cfbf7aebfadf50233d914c05cba6eda9a)) - - +- make sure when stream processor throws an error we disconnect the streaming client ([6dc8de9](https://github.com/forcedotcom/sfdx-core/commit/6dc8de9cfbf7aebfadf50233d914c05cba6eda9a)) ## [2.1.2](https://github.com/forcedotcom/sfdx-core/compare/v2.1.1...v2.1.2) (2019-08-29) - ### Bug Fixes -* add debug logger that accepts a function ([117dee4](https://github.com/forcedotcom/sfdx-core/commit/117dee474600ea8202f460afefb2b54d272516a7)) -* deleting and org auth file never worked ([a6a77c6](https://github.com/forcedotcom/sfdx-core/commit/a6a77c674b4c6111d0a213f537eebdd2f4099808)) -* review feedback ([7c1f630](https://github.com/forcedotcom/sfdx-core/commit/7c1f630cc936b6f49b261fa8304b07dbd8a0527b)) - - +- add debug logger that accepts a function ([117dee4](https://github.com/forcedotcom/sfdx-core/commit/117dee474600ea8202f460afefb2b54d272516a7)) +- deleting and org auth file never worked ([a6a77c6](https://github.com/forcedotcom/sfdx-core/commit/a6a77c674b4c6111d0a213f537eebdd2f4099808)) +- review feedback ([7c1f630](https://github.com/forcedotcom/sfdx-core/commit/7c1f630cc936b6f49b261fa8304b07dbd8a0527b)) ## [2.1.1](https://github.com/forcedotcom/sfdx-core/compare/v2.1.0...v2.1.1) (2019-07-17) - ### Bug Fixes -* yarn.lock ([70e75a2](https://github.com/forcedotcom/sfdx-core/commit/70e75a219aff454a4aefb26482e450e684fd527a)) - - +- yarn.lock ([70e75a2](https://github.com/forcedotcom/sfdx-core/commit/70e75a219aff454a4aefb26482e450e684fd527a)) # [2.1.0](https://github.com/forcedotcom/sfdx-core/compare/v2.0.1...v2.1.0) (2019-07-16) - ### Bug Fixes -* update secureBuffer cipherName ([b55fcde](https://github.com/forcedotcom/sfdx-core/commit/b55fcde0baac74e2450b0eec8121d397d5760628)) -* update secureBuffer cipherName ([8e66a0c](https://github.com/forcedotcom/sfdx-core/commit/8e66a0c86daa5debd080a6de82a24c38645bd409)) -* use empty string for client secret when client secret is undefined ([9513551](https://github.com/forcedotcom/sfdx-core/commit/951355110b2a4aa0c97e93b764f59052be2b5356)) - +- update secureBuffer cipherName ([b55fcde](https://github.com/forcedotcom/sfdx-core/commit/b55fcde0baac74e2450b0eec8121d397d5760628)) +- update secureBuffer cipherName ([8e66a0c](https://github.com/forcedotcom/sfdx-core/commit/8e66a0c86daa5debd080a6de82a24c38645bd409)) +- use empty string for client secret when client secret is undefined ([9513551](https://github.com/forcedotcom/sfdx-core/commit/951355110b2a4aa0c97e93b764f59052be2b5356)) ### Features -* add config file for sandbox ([db2026e](https://github.com/forcedotcom/sfdx-core/commit/db2026e4530971877a702938843cb9e338cca84b)) -* do not throw error on org.remove if sandbox config doesn't exist ([3912993](https://github.com/forcedotcom/sfdx-core/commit/391299358c4789cf5c2c24048617d3de8df7ee6d)) - - +- add config file for sandbox ([db2026e](https://github.com/forcedotcom/sfdx-core/commit/db2026e4530971877a702938843cb9e338cca84b)) +- do not throw error on org.remove if sandbox config doesn't exist ([3912993](https://github.com/forcedotcom/sfdx-core/commit/391299358c4789cf5c2c24048617d3de8df7ee6d)) ## [2.0.1](https://github.com/forcedotcom/sfdx-core/compare/v2.0.0...v2.0.1) (2019-07-02) - ### Bug Fixes -* update secureBuffer cipherName ([1e8037b](https://github.com/forcedotcom/sfdx-core/commit/1e8037b3ed51141d67510e68ddcefb41ea288168)) -* update secureBuffer cipherName ([874d5b6](https://github.com/forcedotcom/sfdx-core/commit/874d5b69ccec6f720cddfea90d3a6d3b1a62a454)) -* use empty string for client secret when client secret is undefined ([0d22a56](https://github.com/forcedotcom/sfdx-core/commit/0d22a56f3a3060712065cc0a5d6be14f43955f48)) - - +- update secureBuffer cipherName ([1e8037b](https://github.com/forcedotcom/sfdx-core/commit/1e8037b3ed51141d67510e68ddcefb41ea288168)) +- update secureBuffer cipherName ([874d5b6](https://github.com/forcedotcom/sfdx-core/commit/874d5b69ccec6f720cddfea90d3a6d3b1a62a454)) +- use empty string for client secret when client secret is undefined ([0d22a56](https://github.com/forcedotcom/sfdx-core/commit/0d22a56f3a3060712065cc0a5d6be14f43955f48)) # [2.0.0](https://github.com/forcedotcom/sfdx-core/compare/v1.3.3...v2.0.0) (2019-06-17) - ### Bug Fixes -* 🐛 prevent auth files from being accidentally overwritten ([06d96fc](https://github.com/forcedotcom/sfdx-core/commit/06d96fcd6fc052960b4d991e88b0da8751e48209)), closes [PR#114](https://github.com/PR/issues/114) -* add clientId to jwt fields ([8a7c040](https://github.com/forcedotcom/sfdx-core/commit/8a7c04049038b76c2b40a86619d848624ce74c74)) -* force version bump to test ci-docs on release ([ecb6a66](https://github.com/forcedotcom/sfdx-core/commit/ecb6a663c266539c5de5b15c54ca603c0c57cea2)) - +- 🐛 prevent auth files from being accidentally overwritten ([06d96fc](https://github.com/forcedotcom/sfdx-core/commit/06d96fcd6fc052960b4d991e88b0da8751e48209)), closes [PR#114](https://github.com/PR/issues/114) +- add clientId to jwt fields ([8a7c040](https://github.com/forcedotcom/sfdx-core/commit/8a7c04049038b76c2b40a86619d848624ce74c74)) +- force version bump to test ci-docs on release ([ecb6a66](https://github.com/forcedotcom/sfdx-core/commit/ecb6a663c266539c5de5b15c54ca603c0c57cea2)) ### BREAKING CHANGES -* 🧨 some commands that call getCoreConnection with auth options and a -username will now throw an error. - - +- 🧨 some commands that call getCoreConnection with auth options and a + username will now throw an error. ## [1.3.3](https://github.com/forcedotcom/sfdx-core/compare/v1.3.2...v1.3.3) (2019-04-04) - ### Bug Fixes -* allow aliases with dots ([e8b17af](https://github.com/forcedotcom/sfdx-core/commit/e8b17af8b06a8137844f834c62d18d773638be36)) -* allow packageAliases in sfdx-project.json ([8d7b1fe](https://github.com/forcedotcom/sfdx-core/commit/8d7b1fe4cb8e61beb726f19241543c3887e062af)) -* hide sensitive values from being logged ([8505f04](https://github.com/forcedotcom/sfdx-core/commit/8505f04e80a561a94be52a99ba5fa75b1131b190)) -* move generating the secretfile path to the catch block ([2b9e57d](https://github.com/forcedotcom/sfdx-core/commit/2b9e57d36722a1e5d629639527cf5c1a54b1c720)) -* potential missing key.json file on windows ([f94f127](https://github.com/forcedotcom/sfdx-core/commit/f94f12762b423a1cb23aaa7920ae910cebb29669)) -* properly invoke callbacks ([f03838c](https://github.com/forcedotcom/sfdx-core/commit/f03838ce54cf2987762f7ed9ef31734d50e68e95)) - - +- allow aliases with dots ([e8b17af](https://github.com/forcedotcom/sfdx-core/commit/e8b17af8b06a8137844f834c62d18d773638be36)) +- allow packageAliases in sfdx-project.json ([8d7b1fe](https://github.com/forcedotcom/sfdx-core/commit/8d7b1fe4cb8e61beb726f19241543c3887e062af)) +- hide sensitive values from being logged ([8505f04](https://github.com/forcedotcom/sfdx-core/commit/8505f04e80a561a94be52a99ba5fa75b1131b190)) +- move generating the secretfile path to the catch block ([2b9e57d](https://github.com/forcedotcom/sfdx-core/commit/2b9e57d36722a1e5d629639527cf5c1a54b1c720)) +- potential missing key.json file on windows ([f94f127](https://github.com/forcedotcom/sfdx-core/commit/f94f12762b423a1cb23aaa7920ae910cebb29669)) +- properly invoke callbacks ([f03838c](https://github.com/forcedotcom/sfdx-core/commit/f03838ce54cf2987762f7ed9ef31734d50e68e95)) ## [1.3.2](https://github.com/forcedotcom/sfdx-core/compare/v1.3.1...v1.3.2) (2019-03-25) - ### Bug Fixes -* revert of throwing auth error ([f6ebe12](https://github.com/forcedotcom/sfdx-core/commit/f6ebe12907e04337169ef6473ae0f8a29ace231c)) - - +- revert of throwing auth error ([f6ebe12](https://github.com/forcedotcom/sfdx-core/commit/f6ebe12907e04337169ef6473ae0f8a29ace231c)) ## [1.3.1](https://github.com/forcedotcom/sfdx-core/compare/v1.3.0...v1.3.1) (2019-03-25) - ### Bug Fixes -* prevent auth files from being inadvertently overwritten ([45195c1](https://github.com/forcedotcom/sfdx-core/commit/45195c1b8232c243746ee2582e67a811c74a9e2e)) -* update test and don't throw when auth file not found ([75af396](https://github.com/forcedotcom/sfdx-core/commit/75af396c253b80c668f1c76a29462677b6b9d950)) - - +- prevent auth files from being inadvertently overwritten ([45195c1](https://github.com/forcedotcom/sfdx-core/commit/45195c1b8232c243746ee2582e67a811c74a9e2e)) +- update test and don't throw when auth file not found ([75af396](https://github.com/forcedotcom/sfdx-core/commit/75af396c253b80c668f1c76a29462677b6b9d950)) # [1.3.0](https://github.com/forcedotcom/sfdx-core/compare/v1.2.3...v1.3.0) (2019-03-19) - ### Features -* support wrapping a string ([2445003](https://github.com/forcedotcom/sfdx-core/commit/24450037619c39c361647af4415665499dc518a2)) - - +- support wrapping a string ([2445003](https://github.com/forcedotcom/sfdx-core/commit/24450037619c39c361647af4415665499dc518a2)) ## [1.2.3](https://github.com/forcedotcom/sfdx-core/compare/v1.2.2...v1.2.3) (2019-03-18) - ### Bug Fixes -* @W-5907580@ respect code if it exist ([5263fe2](https://github.com/forcedotcom/sfdx-core/commit/5263fe2ee8045e1162492d00ac90de6cb62283e5)) -* do not let name and code get out-of-date is name is set ([3e5914e](https://github.com/forcedotcom/sfdx-core/commit/3e5914ef7e11d3309df1520abba037e649be88f2)) -* security update and patch to allow colons in filepaths for windows ([a385b40](https://github.com/forcedotcom/sfdx-core/commit/a385b403e11508006fa18abed51ba250e7aa0520)) -* use name by default for code ([c5283d3](https://github.com/forcedotcom/sfdx-core/commit/c5283d374b67c667d3deab5f7f941c8f5d789f62)) - - +- @W-5907580@ respect code if it exist ([5263fe2](https://github.com/forcedotcom/sfdx-core/commit/5263fe2ee8045e1162492d00ac90de6cb62283e5)) +- do not let name and code get out-of-date is name is set ([3e5914e](https://github.com/forcedotcom/sfdx-core/commit/3e5914ef7e11d3309df1520abba037e649be88f2)) +- security update and patch to allow colons in filepaths for windows ([a385b40](https://github.com/forcedotcom/sfdx-core/commit/a385b403e11508006fa18abed51ba250e7aa0520)) +- use name by default for code ([c5283d3](https://github.com/forcedotcom/sfdx-core/commit/c5283d374b67c667d3deab5f7f941c8f5d789f62)) ## [1.2.2](https://github.com/forcedotcom/sfdx-core/compare/v1.2.1...v1.2.2) (2019-02-11) - ### Bug Fixes -* use default options off the constructor ([368a5f1](https://github.com/forcedotcom/sfdx-core/commit/368a5f160206559529eafae2d71d47aad6186549)) - - +- use default options off the constructor ([368a5f1](https://github.com/forcedotcom/sfdx-core/commit/368a5f160206559529eafae2d71d47aad6186549)) ## [1.2.1](https://github.com/forcedotcom/sfdx-core/compare/v1.2.0...v1.2.1) (2019-01-31) - ### Bug Fixes -* update docs ([789816e](https://github.com/forcedotcom/sfdx-core/commit/789816e7b734864471c943ca503ea6c1bd9d668f)) - - +- update docs ([789816e](https://github.com/forcedotcom/sfdx-core/commit/789816e7b734864471c943ca503ea6c1bd9d668f)) # [1.2.0](https://github.com/forcedotcom/sfdx-core/compare/v1.1.2...v1.2.0) (2019-01-30) - ### Bug Fixes -* do not query server if cached ([d7ccf99](https://github.com/forcedotcom/sfdx-core/commit/d7ccf99aaf84c432da96046d63bd387945a10c21)) -* update to allow stored connected app info ([66ea057](https://github.com/forcedotcom/sfdx-core/commit/66ea05727ca4f6e4a979ee3045fdd96a9c9f8a1e)) - +- do not query server if cached ([d7ccf99](https://github.com/forcedotcom/sfdx-core/commit/d7ccf99aaf84c432da96046d63bd387945a10c21)) +- update to allow stored connected app info ([66ea057](https://github.com/forcedotcom/sfdx-core/commit/66ea05727ca4f6e4a979ee3045fdd96a9c9f8a1e)) ### Features -* determine if a org is a dev hub ([586d7ba](https://github.com/forcedotcom/sfdx-core/commit/586d7bac67636b40c040a7944e8ccaaae9f85621)) - - +- determine if a org is a dev hub ([586d7ba](https://github.com/forcedotcom/sfdx-core/commit/586d7bac67636b40c040a7944e8ccaaae9f85621)) ## [1.1.2](https://github.com/forcedotcom/sfdx-core/compare/v1.1.1...v1.1.2) (2018-12-21) - ### Bug Fixes -* update contrib doc to trigger build ([28c6945](https://github.com/forcedotcom/sfdx-core/commit/28c694506f813f2e38f8cb3789d618833e042f6e)) - - +- update contrib doc to trigger build ([28c6945](https://github.com/forcedotcom/sfdx-core/commit/28c694506f813f2e38f8cb3789d618833e042f6e)) ## [1.1.1](https://github.com/forcedotcom/sfdx-core/compare/v1.1.0...v1.1.1) (2018-12-19) - ### Bug Fixes -* bump kit, ts-types, and ts-sinon versions ([1f088b4](https://github.com/forcedotcom/sfdx-core/commit/1f088b4332ee7e00d1481fcf152a9177b5c20f29)) -* downgrade jsforce to match sfdx toolbelt ([5fba254](https://github.com/forcedotcom/sfdx-core/commit/5fba254c75f0412b2407a5a14f6d66e592159169)) -* fix jsforce types reference ([407e3df](https://github.com/forcedotcom/sfdx-core/commit/407e3dfff4356eba17da3f7a1ffee1f39b0e7776)) -* migrate from /docs to gh-pages branch ([7d36139](https://github.com/forcedotcom/sfdx-core/commit/7d36139542ef731d460f1dcf39495e951c4b794b)) - - +- bump kit, ts-types, and ts-sinon versions ([1f088b4](https://github.com/forcedotcom/sfdx-core/commit/1f088b4332ee7e00d1481fcf152a9177b5c20f29)) +- downgrade jsforce to match sfdx toolbelt ([5fba254](https://github.com/forcedotcom/sfdx-core/commit/5fba254c75f0412b2407a5a14f6d66e592159169)) +- fix jsforce types reference ([407e3df](https://github.com/forcedotcom/sfdx-core/commit/407e3dfff4356eba17da3f7a1ffee1f39b0e7776)) +- migrate from /docs to gh-pages branch ([7d36139](https://github.com/forcedotcom/sfdx-core/commit/7d36139542ef731d460f1dcf39495e951c4b794b)) # [1.1.0](https://github.com/forcedotcom/sfdx-core/compare/v1.0.3...v1.1.0) (2018-12-14) - ### Bug Fixes -* add retreive to keychain config ([#29](https://github.com/forcedotcom/sfdx-core/issues/29)) ([219b1ce](https://github.com/forcedotcom/sfdx-core/commit/219b1cec58fb3233ae9b55ceeef66c4a596b978e)) -* conflict merge ([8686cf8](https://github.com/forcedotcom/sfdx-core/commit/8686cf84570058dfa4282b37d2b0d48e16c07ef4)) -* doc update ([7ad690e](https://github.com/forcedotcom/sfdx-core/commit/7ad690e38e39a8d57f70ee58e7d86f3550cef004)) -* doc updates ([3c34908](https://github.com/forcedotcom/sfdx-core/commit/3c34908f0932fe0ccb48ac90e0332be1cf9832e7)) -* docs updates ([cecd438](https://github.com/forcedotcom/sfdx-core/commit/cecd438df2bf499e7e76c9598d4a84ca6c15138d)) -* docs updates ([2a01945](https://github.com/forcedotcom/sfdx-core/commit/2a019450c54b15eb57c00e3a9df531f799801a7f)) -* ensure AuthInfoConfig can throw when config file not found ([f11b84a](https://github.com/forcedotcom/sfdx-core/commit/f11b84a498e73dbd72fca5c48439cf4785962cda)) -* lower code coverage ([73eabad](https://github.com/forcedotcom/sfdx-core/commit/73eabad4e0c04197be7c927bf1f4ff2aa3e49ea1)) -* make user use async creatable ([895da90](https://github.com/forcedotcom/sfdx-core/commit/895da903f57f0babff7ca93eabffe9bd66117fab)) -* move call to super.init after dependency ([f52341e](https://github.com/forcedotcom/sfdx-core/commit/f52341e9018422d511abb34aab5b889606f2ba4e)) -* move throwOnNotFound option to ConfigFile ([924352a](https://github.com/forcedotcom/sfdx-core/commit/924352af134e16a2dc242d48eb00c99f6ca6898a)) -* move ts-sinon to reg dep ([47a6e6a](https://github.com/forcedotcom/sfdx-core/commit/47a6e6a3c069d4539e65226823860890936e874c)) -* remove reference to yarnpkg ([5ba0887](https://github.com/forcedotcom/sfdx-core/commit/5ba08872b6a52830e8aee38d6a761374eb3ad7d6)) -* resolve alias before creating AuthInfo ([4234197](https://github.com/forcedotcom/sfdx-core/commit/4234197065cd936d86f756e5256ea76d4c3dfb4a)) -* typedoc updates ([2552fec](https://github.com/forcedotcom/sfdx-core/commit/2552feca49fdc12689adf7471c6a4f95e281425d)) -* update docs for config ([3fcdc52](https://github.com/forcedotcom/sfdx-core/commit/3fcdc52cb41d644b1eec043bed3f3eee9f68c42b)) -* update package.json ([69ee399](https://github.com/forcedotcom/sfdx-core/commit/69ee39925d72f1e7181eda6227104ea168a823e3)) -* update package.json ([650021d](https://github.com/forcedotcom/sfdx-core/commit/650021d99ef005fab6b64c824a652d95638f44b2)) -* update package.json ([83bce69](https://github.com/forcedotcom/sfdx-core/commit/83bce694ddd60be629916c9808f63deaaeaa3460)) -* update package.json ([9cc515a](https://github.com/forcedotcom/sfdx-core/commit/9cc515a7d8b203eccf1c91d9830a389b6446c739)) -* update package.json version ([871f211](https://github.com/forcedotcom/sfdx-core/commit/871f211253ce8d25046f1392610cdb054d332ccd)) -* update to latest docs ([e250e2f](https://github.com/forcedotcom/sfdx-core/commit/e250e2f440b6f4751278a76f8c3fcc38ad651967)) - - -### Features - -* consistent enum naming ([#26](https://github.com/forcedotcom/sfdx-core/issues/26)) ([ab3bc7e](https://github.com/forcedotcom/sfdx-core/commit/ab3bc7e3c37da4bf86f23b6824c8715ba780a0a6)) -* replace time with kit's duration ([#24](https://github.com/forcedotcom/sfdx-core/issues/24)) ([a3b519f](https://github.com/forcedotcom/sfdx-core/commit/a3b519f83b190d61475353525483b14c54d09020)) -* update jsforce typings ([374b8fc](https://github.com/forcedotcom/sfdx-core/commit/374b8fcf7d5f24465843f3d98e448a0663a8a89f)) - - +- add retreive to keychain config ([#29](https://github.com/forcedotcom/sfdx-core/issues/29)) ([219b1ce](https://github.com/forcedotcom/sfdx-core/commit/219b1cec58fb3233ae9b55ceeef66c4a596b978e)) +- conflict merge ([8686cf8](https://github.com/forcedotcom/sfdx-core/commit/8686cf84570058dfa4282b37d2b0d48e16c07ef4)) +- doc update ([7ad690e](https://github.com/forcedotcom/sfdx-core/commit/7ad690e38e39a8d57f70ee58e7d86f3550cef004)) +- doc updates ([3c34908](https://github.com/forcedotcom/sfdx-core/commit/3c34908f0932fe0ccb48ac90e0332be1cf9832e7)) +- docs updates ([cecd438](https://github.com/forcedotcom/sfdx-core/commit/cecd438df2bf499e7e76c9598d4a84ca6c15138d)) +- docs updates ([2a01945](https://github.com/forcedotcom/sfdx-core/commit/2a019450c54b15eb57c00e3a9df531f799801a7f)) +- ensure AuthInfoConfig can throw when config file not found ([f11b84a](https://github.com/forcedotcom/sfdx-core/commit/f11b84a498e73dbd72fca5c48439cf4785962cda)) +- lower code coverage ([73eabad](https://github.com/forcedotcom/sfdx-core/commit/73eabad4e0c04197be7c927bf1f4ff2aa3e49ea1)) +- make user use async creatable ([895da90](https://github.com/forcedotcom/sfdx-core/commit/895da903f57f0babff7ca93eabffe9bd66117fab)) +- move call to super.init after dependency ([f52341e](https://github.com/forcedotcom/sfdx-core/commit/f52341e9018422d511abb34aab5b889606f2ba4e)) +- move throwOnNotFound option to ConfigFile ([924352a](https://github.com/forcedotcom/sfdx-core/commit/924352af134e16a2dc242d48eb00c99f6ca6898a)) +- move ts-sinon to reg dep ([47a6e6a](https://github.com/forcedotcom/sfdx-core/commit/47a6e6a3c069d4539e65226823860890936e874c)) +- remove reference to yarnpkg ([5ba0887](https://github.com/forcedotcom/sfdx-core/commit/5ba08872b6a52830e8aee38d6a761374eb3ad7d6)) +- resolve alias before creating AuthInfo ([4234197](https://github.com/forcedotcom/sfdx-core/commit/4234197065cd936d86f756e5256ea76d4c3dfb4a)) +- typedoc updates ([2552fec](https://github.com/forcedotcom/sfdx-core/commit/2552feca49fdc12689adf7471c6a4f95e281425d)) +- update docs for config ([3fcdc52](https://github.com/forcedotcom/sfdx-core/commit/3fcdc52cb41d644b1eec043bed3f3eee9f68c42b)) +- update package.json ([69ee399](https://github.com/forcedotcom/sfdx-core/commit/69ee39925d72f1e7181eda6227104ea168a823e3)) +- update package.json ([650021d](https://github.com/forcedotcom/sfdx-core/commit/650021d99ef005fab6b64c824a652d95638f44b2)) +- update package.json ([83bce69](https://github.com/forcedotcom/sfdx-core/commit/83bce694ddd60be629916c9808f63deaaeaa3460)) +- update package.json ([9cc515a](https://github.com/forcedotcom/sfdx-core/commit/9cc515a7d8b203eccf1c91d9830a389b6446c739)) +- update package.json version ([871f211](https://github.com/forcedotcom/sfdx-core/commit/871f211253ce8d25046f1392610cdb054d332ccd)) +- update to latest docs ([e250e2f](https://github.com/forcedotcom/sfdx-core/commit/e250e2f440b6f4751278a76f8c3fcc38ad651967)) + +### Features + +- consistent enum naming ([#26](https://github.com/forcedotcom/sfdx-core/issues/26)) ([ab3bc7e](https://github.com/forcedotcom/sfdx-core/commit/ab3bc7e3c37da4bf86f23b6824c8715ba780a0a6)) +- replace time with kit's duration ([#24](https://github.com/forcedotcom/sfdx-core/issues/24)) ([a3b519f](https://github.com/forcedotcom/sfdx-core/commit/a3b519f83b190d61475353525483b14c54d09020)) +- update jsforce typings ([374b8fc](https://github.com/forcedotcom/sfdx-core/commit/374b8fcf7d5f24465843f3d98e448a0663a8a89f)) ## [0.24.3](https://github.com/forcedotcom/sfdx-core/compare/v0.25.0...v0.24.3) (2018-11-15) - ### Bug Fixes -* remove npm install from core ([832eaeb](https://github.com/forcedotcom/sfdx-core/commit/832eaeb73855dc65eb0acf91d13869e042d53166)) - - +- remove npm install from core ([832eaeb](https://github.com/forcedotcom/sfdx-core/commit/832eaeb73855dc65eb0acf91d13869e042d53166)) # [0.25.0](https://github.com/forcedotcom/sfdx-core/compare/v0.24.2...v0.25.0) (2018-11-15) - ### Features -* build ([c03e0bc](https://github.com/forcedotcom/sfdx-core/commit/c03e0bc866e255ed8a1bb37dd28557cd2e5487d1)) - - +- build ([c03e0bc](https://github.com/forcedotcom/sfdx-core/commit/c03e0bc866e255ed8a1bb37dd28557cd2e5487d1)) ## [0.24.2](https://github.com/forcedotcom/sfdx-core/compare/v0.24.1...v0.24.2) (2018-11-15) - ### Features -* update build ([4e6426e](https://github.com/forcedotcom/sfdx-core/commit/4e6426e74dd221503b0b8b63629149397568a8fd)) - - +- update build ([4e6426e](https://github.com/forcedotcom/sfdx-core/commit/4e6426e74dd221503b0b8b63629149397568a8fd)) ## [0.24.1](https://github.com/forcedotcom/sfdx-core/compare/v0.21.4...v0.24.1) (2018-11-15) - ### Bug Fixes -* adopt ts-types fix of AnyJson values ([#20](https://github.com/forcedotcom/sfdx-core/issues/20)) ([c7d1433](https://github.com/forcedotcom/sfdx-core/commit/c7d14336020995c7f195b813a2d0822b5cb2f444)) -* support sfdx-faye ([#21](https://github.com/forcedotcom/sfdx-core/issues/21)) ([115683c](https://github.com/forcedotcom/sfdx-core/commit/115683ca1457929b0b94520c0e1b3b372c02bf75)) - +- adopt ts-types fix of AnyJson values ([#20](https://github.com/forcedotcom/sfdx-core/issues/20)) ([c7d1433](https://github.com/forcedotcom/sfdx-core/commit/c7d14336020995c7f195b813a2d0822b5cb2f444)) +- support sfdx-faye ([#21](https://github.com/forcedotcom/sfdx-core/issues/21)) ([115683c](https://github.com/forcedotcom/sfdx-core/commit/115683ca1457929b0b94520c0e1b3b372c02bf75)) ### Features -* new build ([8cf0c39](https://github.com/forcedotcom/sfdx-core/commit/8cf0c39a486f00229ff9a7878e98415f4d8e85ca)) - +- new build ([8cf0c39](https://github.com/forcedotcom/sfdx-core/commit/8cf0c39a486f00229ff9a7878e98415f4d8e85ca)) ### Reverts -* Revert "Revert "build: try oclif semantic/release"" ([a514b9a](https://github.com/forcedotcom/sfdx-core/commit/a514b9ab7e66d2aaaf767d01d02470b35bc5d60b)) -* Revert "build: try oclif semantic/release" ([840da22](https://github.com/forcedotcom/sfdx-core/commit/840da22c64a57cf2ca8f729c65c4a9aab34127cd)) - - +- Revert "Revert "build: try oclif semantic/release"" ([a514b9a](https://github.com/forcedotcom/sfdx-core/commit/a514b9ab7e66d2aaaf767d01d02470b35bc5d60b)) +- Revert "build: try oclif semantic/release" ([840da22](https://github.com/forcedotcom/sfdx-core/commit/840da22c64a57cf2ca8f729c65c4a9aab34127cd)) ## [0.21.4](https://github.com/forcedotcom/sfdx-core/compare/v0.21.3...v0.21.4) (2018-11-08) - ### Bug Fixes -* make public ([ac497a3](https://github.com/forcedotcom/sfdx-core/commit/ac497a3a50a7f7dea93d4182d29c2b4508888642)) - - +- make public ([ac497a3](https://github.com/forcedotcom/sfdx-core/commit/ac497a3a50a7f7dea93d4182d29c2b4508888642)) ## [0.21.3](https://github.com/forcedotcom/sfdx-core/compare/v0.21.2...v0.21.3) (2018-11-08) - ### Bug Fixes -* actual ts-types and kit versions ([ca03b33](https://github.com/forcedotcom/sfdx-core/commit/ca03b3321702362a061b8d46b59c30fec8818bd1)) -* typing correction in kit ([2191040](https://github.com/forcedotcom/sfdx-core/commit/2191040a11b749efa6d732accc6988fa691b52f7)) -* update has impl ([429c4e9](https://github.com/forcedotcom/sfdx-core/commit/429c4e934bd3f6942b5791259d31e48f6bb7ead2)) -* updates for ts-types and kit api changes ([c7c599d](https://github.com/forcedotcom/sfdx-core/commit/c7c599d8af5aa2d1dfee55b58778ddfd1dc0174f)) -* use latest versions of ts-types and kit ([0d73ad6](https://github.com/forcedotcom/sfdx-core/commit/0d73ad62247f9051e640f6d5cd06b61a63330029)) - - +- actual ts-types and kit versions ([ca03b33](https://github.com/forcedotcom/sfdx-core/commit/ca03b3321702362a061b8d46b59c30fec8818bd1)) +- typing correction in kit ([2191040](https://github.com/forcedotcom/sfdx-core/commit/2191040a11b749efa6d732accc6988fa691b52f7)) +- update has impl ([429c4e9](https://github.com/forcedotcom/sfdx-core/commit/429c4e934bd3f6942b5791259d31e48f6bb7ead2)) +- updates for ts-types and kit api changes ([c7c599d](https://github.com/forcedotcom/sfdx-core/commit/c7c599d8af5aa2d1dfee55b58778ddfd1dc0174f)) +- use latest versions of ts-types and kit ([0d73ad6](https://github.com/forcedotcom/sfdx-core/commit/0d73ad62247f9051e640f6d5cd06b61a63330029)) ## [0.21.2](https://github.com/forcedotcom/sfdx-core/compare/v0.23.1...v0.21.2) (2018-10-24) - ### Bug Fixes -* disable semantic release until approved ([e443d17](https://github.com/forcedotcom/sfdx-core/commit/e443d17a04451b81ed83d0bdbb2ed3cae956c803)) -* fix build config ([b286261](https://github.com/forcedotcom/sfdx-core/commit/b28626110273ab387d1c570b0500d1a7232533e6)) - - +- disable semantic release until approved ([e443d17](https://github.com/forcedotcom/sfdx-core/commit/e443d17a04451b81ed83d0bdbb2ed3cae956c803)) +- fix build config ([b286261](https://github.com/forcedotcom/sfdx-core/commit/b28626110273ab387d1c570b0500d1a7232533e6)) ## [0.23.1](https://github.com/forcedotcom/sfdx-core/compare/v0.22.0...v0.23.1) (2018-10-05) - - # [0.22.0](https://github.com/forcedotcom/sfdx-core/compare/v0.21.1...v0.22.0) (2018-09-25) - - ## [0.21.1](https://github.com/forcedotcom/sfdx-core/compare/v0.21.0...v0.21.1) (2018-09-18) - - # [0.21.0](https://github.com/forcedotcom/sfdx-core/compare/v0.20.0...v0.21.0) (2018-09-14) - - # [0.20.0](https://github.com/forcedotcom/sfdx-core/compare/v0.19.0...v0.20.0) (2018-08-30) - - # [0.19.0](https://github.com/forcedotcom/sfdx-core/compare/v0.18.2...v0.19.0) (2018-08-21) - - ## [0.18.2](https://github.com/forcedotcom/sfdx-core/compare/v0.18.1...v0.18.2) (2018-07-16) - - ## [0.18.1](https://github.com/forcedotcom/sfdx-core/compare/v0.17.6...v0.18.1) (2018-07-12) - - ## [0.17.6](https://github.com/forcedotcom/sfdx-core/compare/v0.17.5...v0.17.6) (2018-07-11) - - ## [0.17.5](https://github.com/forcedotcom/sfdx-core/compare/v0.17.4...v0.17.5) (2018-07-06) - - ## [0.17.4](https://github.com/forcedotcom/sfdx-core/compare/v0.17.3...v0.17.4) (2018-06-29) - - ## [0.17.3](https://github.com/forcedotcom/sfdx-core/compare/v0.17.2...v0.17.3) (2018-06-29) - - ## [0.17.2](https://github.com/forcedotcom/sfdx-core/compare/v0.17.1...v0.17.2) (2018-06-16) - - ## [0.17.1](https://github.com/forcedotcom/sfdx-core/compare/v0.16.17...v0.17.1) (2018-06-16) - - ## [0.16.17](https://github.com/forcedotcom/sfdx-core/compare/v0.16.16...v0.16.17) (2018-06-13) - - ## [0.16.16](https://github.com/forcedotcom/sfdx-core/compare/v0.16.15...v0.16.16) (2018-06-04) - - ## [0.16.15](https://github.com/forcedotcom/sfdx-core/compare/v0.16.14...v0.16.15) (2018-05-29) - - ## [0.16.14](https://github.com/forcedotcom/sfdx-core/compare/v0.16.13...v0.16.14) (2018-05-22) - - ## [0.16.13](https://github.com/forcedotcom/sfdx-core/compare/v0.16.12...v0.16.13) (2018-04-20) - - ## [0.16.12](https://github.com/forcedotcom/sfdx-core/compare/v0.16.11...v0.16.12) (2018-04-06) - - ## [0.16.11](https://github.com/forcedotcom/sfdx-core/compare/v0.16.10...v0.16.11) (2018-04-06) - - ## [0.16.10](https://github.com/forcedotcom/sfdx-core/compare/v0.16.9...v0.16.10) (2018-03-22) - - ## [0.16.9](https://github.com/forcedotcom/sfdx-core/compare/v0.16.8...v0.16.9) (2018-03-21) - - ## [0.16.8](https://github.com/forcedotcom/sfdx-core/compare/v0.16.7...v0.16.8) (2018-03-20) - - ## [0.16.7](https://github.com/forcedotcom/sfdx-core/compare/v0.16.6...v0.16.7) (2018-03-20) - - ## [0.16.6](https://github.com/forcedotcom/sfdx-core/compare/v0.16.5...v0.16.6) (2018-03-16) - - ## [0.16.5](https://github.com/forcedotcom/sfdx-core/compare/v0.16.4...v0.16.5) (2018-03-15) - - ## [0.16.4](https://github.com/forcedotcom/sfdx-core/compare/v0.16.3...v0.16.4) (2018-03-14) - - ## [0.16.3](https://github.com/forcedotcom/sfdx-core/compare/v0.16.2...v0.16.3) (2018-03-14) - - ## [0.16.2](https://github.com/forcedotcom/sfdx-core/compare/v0.16.1...v0.16.2) (2018-03-10) - - ## [0.16.1](https://github.com/forcedotcom/sfdx-core/compare/v0.16.0...v0.16.1) (2018-03-06) - - # [0.16.0](https://github.com/forcedotcom/sfdx-core/compare/v0.15.0...v0.16.0) (2018-03-06) - - # [0.15.0](https://github.com/forcedotcom/sfdx-core/compare/v0.14.0...v0.15.0) (2018-03-06) - - # [0.14.0](https://github.com/forcedotcom/sfdx-core/compare/v0.13.0...v0.14.0) (2018-03-06) - - # [0.13.0](https://github.com/forcedotcom/sfdx-core/compare/v0.12.0...v0.13.0) (2018-03-06) - - # [0.12.0](https://github.com/forcedotcom/sfdx-core/compare/v0.11.0...v0.12.0) (2018-03-05) - - # [0.11.0](https://github.com/forcedotcom/sfdx-core/compare/v0.10.0...v0.11.0) (2018-03-05) - - # [0.10.0](https://github.com/forcedotcom/sfdx-core/compare/v0.9.0...v0.10.0) (2018-03-01) - - # [0.9.0](https://github.com/forcedotcom/sfdx-core/compare/v0.8.0...v0.9.0) (2018-02-27) - - # [0.8.0](https://github.com/forcedotcom/sfdx-core/compare/v0.7.0...v0.8.0) (2018-02-27) - - ## [0.5.3](https://github.com/forcedotcom/sfdx-core/compare/v0.5.2...v0.5.3) (2018-02-26) - - ## [0.5.2](https://github.com/forcedotcom/sfdx-core/compare/v0.6.0...v0.5.2) (2018-02-26) - - ## [0.5.1](https://github.com/forcedotcom/sfdx-core/compare/v0.5.0...v0.5.1) (2018-02-26) - - # [0.7.0](https://github.com/forcedotcom/sfdx-core/compare/v0.5.3...v0.7.0) (2018-02-27) - - # [0.6.0](https://github.com/forcedotcom/sfdx-core/compare/v0.5.1...v0.6.0) (2018-02-26) - - ## [0.5.3](https://github.com/forcedotcom/sfdx-core/compare/v0.5.2...v0.5.3) (2018-02-26) - - ## [0.5.2](https://github.com/forcedotcom/sfdx-core/compare/v0.6.0...v0.5.2) (2018-02-26) - - ## [0.5.1](https://github.com/forcedotcom/sfdx-core/compare/v0.5.0...v0.5.1) (2018-02-26) - - # [0.6.0](https://github.com/forcedotcom/sfdx-core/compare/v0.5.1...v0.6.0) (2018-02-26) - - ## [0.5.1](https://github.com/forcedotcom/sfdx-core/compare/v0.5.0...v0.5.1) (2018-02-26) - - # [0.5.0](https://github.com/forcedotcom/sfdx-core/compare/v0.4.0...v0.5.0) (2018-02-23) - - # [0.4.0](https://github.com/forcedotcom/sfdx-core/compare/v0.3.0...v0.4.0) (2018-02-22) - - # [0.3.0](https://github.com/forcedotcom/sfdx-core/compare/v0.2.0...v0.3.0) (2018-02-22) - - # [0.2.0](https://github.com/forcedotcom/sfdx-core/compare/v0.1.0...v0.2.0) (2018-02-20) - - # [0.1.0](https://github.com/forcedotcom/sfdx-core/compare/v0.0.4...v0.1.0) (2018-02-13) - - ## [0.0.4](https://github.com/forcedotcom/sfdx-core/compare/v0.0.3...v0.0.4) (2017-12-05) - - ## [0.0.3](https://github.com/forcedotcom/sfdx-core/compare/v0.0.2...v0.0.3) (2017-12-05) - - ## [0.0.2](https://github.com/forcedotcom/sfdx-core/compare/v0.0.1...v0.0.2) (2017-12-05) - - ## 0.0.1 (2017-12-05) - - - diff --git a/CODEOWNERS b/CODEOWNERS index 522fa4a0f7..4d71d6d782 100644 --- a/CODEOWNERS +++ b/CODEOWNERS @@ -1,2 +1,5 @@ -# Comment line immediately above ownership line is reserved for related gus information. Please be careful while editing. -#ECCN:Open Source +# Techical writers will be added as reviewers on markdown changes. +*.md @forcedotcom/cli-docs + +# Comment line immediately above ownership line is reserved for related other information. Please be careful while editing. +#ECCN:Open Source 5D002 diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 326c116636..41f825a591 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,7 +1,7 @@ ## Contributing 1. The [DEVELOPING](DEVELOPING.md) doc has details on how to set up your environment. -1. Familiarize yourself with the codebase by reading the [docs](docs), which you can generate locally by running `yarn docs`. +1. Familiarize yourself with the codebase by reading the [docs](https://forcedotcom.github.io/sfdx-core), which you can generate locally by running `yarn docs`. 1. Create a new issue before starting your project so that we can keep track of what you are trying to add/fix. That way, we can also offer suggestions or let you know if there is already an effort in progress. diff --git a/DEVELOPING.md b/DEVELOPING.md index a50e16227a..9add3998b8 100644 --- a/DEVELOPING.md +++ b/DEVELOPING.md @@ -37,7 +37,7 @@ This tests the typescript using ts-node. ### `yarn docs` -This generates documentation into [docs](docs). +This generates documentation into [docs](https://forcedotcom.github.io/sfdx-core/). ### `yarn lint` diff --git a/LICENSE.txt b/LICENSE.txt index f2cee7bb61..6cfd873423 100644 --- a/LICENSE.txt +++ b/LICENSE.txt @@ -1,4 +1,4 @@ -Copyright (c) 2023, Salesforce.com, Inc. +Copyright (c) 2024, Salesforce.com, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: diff --git a/MIGRATING_V2-V3.md b/MIGRATING_V2-V3.md index 36636a7901..0ce6810267 100644 --- a/MIGRATING_V2-V3.md +++ b/MIGRATING_V2-V3.md @@ -84,7 +84,7 @@ await stateAggregator.aliases.write(); | `SfdxPropertyKeys.MAX_QUERY_LIMIT` | `OrgConfigProperties.ORG_MAX_QUERY_LIMIT` | | `SfdxPropertyKeys.REST_DEPLOY` | REMOVED | -- `ConifgAggregator` will not work with any of the deprecated keys. **We strongly suggest that you move to the new keys as part of the migration process.** +- `ConfigAggregator` will not work with any of the deprecated keys. **We strongly suggest that you move to the new keys as part of the migration process.** - If you absolutely cannot migrate to the new config keys, then you can use `SfdxConfigAggregator` in the meantime. ### Why diff --git a/MIGRATING_V3-V4.md b/MIGRATING_V3-V4.md new file mode 100644 index 0000000000..2980615bb8 --- /dev/null +++ b/MIGRATING_V3-V4.md @@ -0,0 +1,41 @@ +# Migrating `@salesforce/core` from v3 to v4 + +v4 remove node14 support and removes many previously deprecated features + +## Messages + +Use `Messages.loadMessages` instead of `Messages.load`. You don't have to specify the messages individually, and the [eslint rules](https://github.com/salesforcecli/eslint-plugin-sf-plugin) check your messages more effectively. + +`Messages.createErrorButPreserveName` is removed. + +## SfdxConfigAggregator + +Recent versions of v3 has `SfdxConfigAggregator` exactly matching `ConfigAggregator`. Use `ConfigAggregator`. + +## SfdxError + +Was a copy of `SfError`, now removed. Use `SfError`. + +## SfdxProject and SfdxProjectJson + +Both of these were empty wrappers around `SfProject` and `SfProjectJson`. Use those instead. + +## Connection.deployRecentValidation + +Since this was moved to jsforce2, the sfdx-core implementation was an empty wrapper. Use jsforce's ConnectionDeployRecentValidation instead. + +## StateAggregator.aliases (aliasAccessor) + +There are some deprecated methods (set, unset). They still exist, but you should use the newer async equivalent. They not only set/unset the value in memory, but immediately write to the filesystem. + +`write` on aliases is now deprecated and a no-op. + +AliasAccessor no longer inherits from the entire configFile family of classes, so those methods are no longer available. + +This new version introduces file locks so parallel operations that write to Aliases should not cross-save each other. + +## sfdc + +These were independent functions on an object. Import the individual functions you need instead. + +Ex: `sfdc.trimTo15()` should be `trimTo15()` diff --git a/MIGRATING_V4-V5.md b/MIGRATING_V4-V5.md new file mode 100644 index 0000000000..ab00d48131 --- /dev/null +++ b/MIGRATING_V4-V5.md @@ -0,0 +1,64 @@ +# Migrating `@salesforce/core` from v4 to v5 + +v5 contains breaking changes to the Logger class + +Prior to v5, the Logger class wrapped a fork of Bunyan. v5 uses [Pino](https://getpino.io/) + +You could create the Logger and then make modifications to it (adding streams, changing it to in-memory). + +The v5 implementation is much simpler. Once you've created it, you cannot modify the logging destination. + +This commit contains the breaking changes: https://github.com/forcedotcom/sfdx-core/commit/c52a29bd4162bc14ebaf690876db6589d21929fe + +Most of the methods for manipulating streams, filter or changing the settings of an existing Logger are gone. The only change you can make to an existing Logger is to change the level or to add an additional field to all the outputs. + +## MemoryLogging + +instead of creating a Logger and then calling `useMemoryLogging` you can now pass the option `useMemoryLogger` when creating the Logger + +## Output format + +JSON is your only option. LogFmt no longer exists + +## Debug + +`enableDEBUG` is gone. The logger will use DEBUG and prettified output when `DEBUG=*` etc are in the environment. + +## Log file destinations + +Previously, logger went to sf.log and then rotated to sf.log.0, sf.log.1, etc. + +The new Logger will write to dated files like `sf-2023-06-29.log` so that no rotation is necessary. + +## Log file cleanup + +When a new logger is instantiated, there's a chance that it kicks off a cleanup process on existing logs. By default, they'll be around 7 days. If you don't use the CLI much, it might take extra time before the log files are cleaned up (but they'd be much smaller in that case) + +## Notes + +the new `getRawLogger` is similar to the previous `getBunyanLogger. It'll return the underlying Pino instance. + +This is an improvement in that it has TypeScript types for the pino methods. Example usage + +```ts +// Logger (class) which contains the root pino logger. Will be created if one doesn't exist +// child (class) which contains a pino child logger +// return the pino logger from child class +const childLogger = Logger.childFromRoot('myRootChild', { tag: 'whatever' }).getRawLogger(); +// same result, but async +const childLogger = await Logger.child('myRootChild', { tag: 'whatever' }).getRawLogger(); + +childLogger.debug('foo'); +``` + +This skips all that Class instantiation and hierarchy (get the pino instance from the root Logger class and create a child logger off of that) + +```ts +// Logger (class) which contains the root pino logger. Will be created if one doesn't exist +// pino child logger created from the root Logger (class) pino instance +const childLogger = Logger.getRoot().getRawLogger().child({ tag: 'whatever', name: `myRootChild` }); +// same result, but async +const childLogger = (await Logger.root()).getRawLogger().child({ tag: 'whatever', name: `myRootChild` }); + +childLogger.debug('foo'); +``` diff --git a/MIGRATING_V5-V6.md b/MIGRATING_V5-V6.md new file mode 100644 index 0000000000..afcec25d78 --- /dev/null +++ b/MIGRATING_V5-V6.md @@ -0,0 +1,30 @@ +# Migrating `@salesforce/core` from v5 to v6 + +v5 contains breaking changes to the classes that extend from ConfigStore/ConfigFile. We'll call these the "config stack" as a shorthand + +We've had a series of bugs where files controlled by the config stack could lose data or become corrupted when multiple processes try to write them concurrently. + +V6 introducing a file locking mechanism previously only available on the `alias` file and a process of resolving conflicts based on timestamps. + +But that comes with breaking changes to reduce the risk of "getting around" the safeties. + +## Breaking changes related to the Config Stack + +- AuthInfo.getFields now returns a read-only object. Use AuthInfo.update to change values in the fields. +- `setContents` method is no longer available in the ConfigFile stack. Use `update` to merge in multiple props, or `set/unset` on a single prop. +- `write` and `writeSync` method no longer accepts a param. Use other methods (`set`, `unset`, `update) to make modifications, then call write()/writeSync() to do the write. +- the use of lodash-style `get`/`set`/`unset`/`unsetAll` (ex: `set('foo.bar.baz[0]', 3)`) no longer works. +- `awaitEach` is removed +- You can no longer override the `setMethod` and `getMethod` when extending classes built on ConfigFile. Technically you could override get/set, but DON'T! +- Everything related to tokens/tokenConfig is gone + +## Unrelated changes that we did because it's a major version + +- node18+ only, compiles to es2022 +- move `uniqid`` to a shared function, outside of testSetup + +## Previously deprecated items that are now removed + +- removed sfdc.isInternalUrl. Use new SfdcUrl(url).isInternalUrl() +- removed sfdc.findUppercaseKeys. There is no replacement. +- removed SchemaPrinter. There is no replacement. diff --git a/README.md b/README.md index 633b904a17..4989db6d02 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,10 @@ [![NPM](https://img.shields.io/npm/v/@salesforce/core.svg)](https://www.npmjs.com/package/@salesforce/core) -[![CircleCI](https://circleci.com/gh/forcedotcom/sfdx-core.svg?style=svg&circle-token=2377ca31221869e9d13448313620486da80e595f)](https://circleci.com/gh/forcedotcom/sfdx-core) - [Description](#description) - [Usage](#usage) - [Contributing](#contributing) - [Using TestSetup](#using-testsetup) - - [Mocking Authorizations](#mocking-authorizations) - - [Mocking Config Files](#mocking-config-files) - - [Using the Built-in Sinon Sandboxes](#using-the-built-in-sinon-sandboxes) - - [Testing Expected Failures](#testing-expected-failures) - - [Testing Log Lines](#testing-log-lines) +- [Message Transformer](#message-transformer) # Description @@ -21,202 +16,66 @@ See the [API documentation](https://forcedotcom.github.io/sfdx-core/). ## Contributing -If you are interested in contributing, please take a look at the [CONTRIBUTING](CONTRIBUTING.md) guide. +If you're interested in contributing, take a look at the [CONTRIBUTING](CONTRIBUTING.md) guide. -# Using TestSetup - -The Salesforce DX Core Library provides a unit testing utility to help with mocking and sand-boxing core components. This feature allows unit tests to execute without needing to make API calls to salesforce.com. - -## Mocking Authorizations +## Issues -Here you can mock authorization for a Salesforce scratch org. - -```typescript -import { strictEqual } from 'assert'; -import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; -import { AuthInfo } from '@salesforce/core'; - -describe('Mocking Auth data', () => { - const $$ = new TestContext(); - it('example', async () => { - const testData = new MockTestOrgData(); - await $$.stubAuths(testData); - const auth = await AuthInfo.create({ username: testData.username }); - strictEqual(auth.getUsername(), testData.username); - }); -}); -``` +Report all issues to the [issues only repository](https://github.com/forcedotcom/cli/issues). -After having a valid AuthInfo object you can then create fake connections to a Salesforce.com scratch org. This allows for writing tests that can validate result responses for SOQL queries and REST endpoints. - -```typescript -import { AuthInfo, Connection, SfError } from '@salesforce/core'; -import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; -import { AnyJson, ensureJsonMap, JsonMap } from '@salesforce/ts-types'; -import { ensureString } from '@salesforce/ts-types'; -import { deepStrictEqual } from 'assert'; -import { QueryResult } from 'jsforce'; - -describe('Mocking a force server call', () => { - const $$ = new TestContext(); - it('example', async () => { - const records: AnyJson = { records: ['123456', '234567'] }; - const testData = new MockTestOrgData(); - await $$.stubAuths(testData); - $$.fakeConnectionRequest = (request: AnyJson): Promise => { - const _request = ensureJsonMap(request); - if (request && ensureString(_request.url).includes('Account')) { - return Promise.resolve(records); - } else { - return Promise.reject(new SfError(`Unexpected request: ${_request.url}`)); - } - }; - const connection = await Connection.create({ - authInfo: await AuthInfo.create({ username: testData.username }), - }); - const result = await connection.query('select Id From Account'); - deepStrictEqual(result, records); - }); -}); -``` +# Using TestSetup -## Mocking Config Files - -You can mock the contents of various config files - -```typescript -import { strictEqual } from 'assert'; -import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; -import { StateAggregator, OrgConfigProperties } from '@salesforce/core'; - -describe('Mocking Aliases', () => { - const $$ = new TestContext(); - it('example', async () => { - const testData = new MockTestOrgData(); - await $$.stubAliases({ myAlias: testData.username }); - const alias = (await StateAggregator.getInstance()).aliases.get(testData.username); - strictEqual(alias, 'myAlais'); - }); -}); - -describe('Mocking Config', () => { - it('example', async () => { - const testData = new MockTestOrgData(); - await $$.stubConfig({ [OrgConfigProperties.TARGET_ORG]: testData.username }); - const { value } = (await ConfigAggregator.create()).getInfo(OrgConfigProperties.TARGET_ORG); - strictEqual(value, testData.username); - }); -}); - -describe('Mocking Arbitrary Config Files', () => { - it('example', async () => { - // MyConfigFile must extend the ConfigFile class in order for this to work properly. - $$.setConfigStubContents('MyConfigFile', { contents: { foo: 'bar' } }); - }); -}); -``` +The Salesforce DX Core Library provides a unit testing utility to help with mocking and sand-boxing core components. This feature allows unit tests to execute without needing to make API calls to salesforce.com. -## Using the Built-in Sinon Sandboxes +See the [Test Setup documentation](TEST_SETUP.md). -sfdx-core uses Sinon as its underlying mocking system. If you're unfamiliar with Sinon and its sandboxing concept you can find more information here: -https://sinonjs.org/ -Sinon `stub`s and `spy`s must be cleaned up after test invocations. To ease the use of Sinon with sfdx core we've exposed our sandbox in TestSetup. After adding your own `stub`s and/or `spy`s they will automatically be cleaned up after each test using mocha's afterEach method. +## Message Transformer -```typescript -import { strictEqual } from 'assert'; +The Messages class, by default, loads message text during run time. It's optimized to do this only per file. -import { TestContext } from '@salesforce/core/lib/testSetup'; -import * as os from 'os'; +If you're using @salesforce/core or other code that uses its Messages class in a bundler (webpack, esbuild, etc) it may struggle with these runtime references. -describe('Using the built in Sinon sandbox.', () => { - const $$ = new TestContext(); - it('example', async () => { - const unsupportedOS = 'LEO'; - $$.SANDBOX.stub(os, 'platform').returns(unsupportedOS); - strictEqual(os.platform(), unsupportedOS); - }); -}); -``` +src/messageTransformer will "inline" the messages into the js files during TS compile using `https://github.com/nonara/ts-patch`. -## Testing Expected Failures +In your plugin or library, -It's important to have negative tests that ensure proper error handling. With `shouldThrow` it's easy to test for expected async rejections. +`yarn add --dev ts-patch` -```typescript -import { SfError } from '@salesforce/core'; -import { shouldThrow } from '@salesforce/core/lib/testSetup'; -import { strictEqual } from 'assert'; +> tsconfig.json -class TestObject { - public static async method() { - throw new SfError('Error', 'ExpectedError'); - } +```json +{ + ... + "plugins": [{ "transform": "@salesforce/core/lib/messageTransformer", "import": "messageTransformer" }] } - -describe('Testing for expected errors', () => { - it('example', async () => { - try { - await shouldThrow(TestObject.method()); - } catch (e) { - strictEqual(e.name, 'ExpectedError'); - } - }); -}); ``` -You can also use `shouldThrowSync` for syncrhonous functions you expect to fail - -```typescript -import { SfError } from '@salesforce/core'; -import { shouldThrowSync } from '@salesforce/core/lib/testSetup'; -import { strictEqual } from 'assert'; - -class TestObject { - public static method() { - throw new SfError('Error', 'ExpectedError'); +> .sfdevrc.json, which gets merged into package.json + +```json +"wireit": { + "compile": { + "command": "tspc -p . --pretty --incremental", + "files": [ + "src/**/*.ts", + "tsconfig.json", + "messages" + ], + "output": [ + "lib/**", + "*.tsbuildinfo" + ], + "clean": "if-file-deleted" + } } -} -describe('Testing for expected errors', () => { - it('example', async () => { - try { - shouldThrowSync(() => TestObject.method()); - } catch (e) { - strictEqual(e.name, 'ExpectedError'); - } - }); -}); ``` -## Testing Log Lines - -It's also useful to check expected values and content from log lines. TestSetup configures the sfdx-core logger to use an in memory LogLine storage structure. These can be easily accessed from tests. +## Performance Testing -```typescript -import { Logger, LogLine } from '@salesforce/core'; -import { TestContext } from '@salesforce/core/lib/testSetup'; -import { strictEqual } from 'assert'; +There are some benchmark.js checks to get a baseline for Logger performance. +https://forcedotcom.github.io/sfdx-core/perf-Linux +https://forcedotcom.github.io/sfdx-core/perf-Windows -const TEST_STRING = 'foo was here'; +You can add more test cases in test/perf/logger/main.js -class TestObject { - constructor(private logger: Logger) { - this.logger = logger.child('TestObject'); - } - - public method() { - this.logger.error(TEST_STRING); - } -} - -describe('Testing log lines', () => { - const $$ = new TestContext(); - it('example', async () => { - const obj = new TestObject($$.TEST_LOGGER); - obj.method(); - const records = $$.TEST_LOGGER.getBufferedRecords(); - strictEqual(records.length, 1); - strictEqual(records[0].msg, TEST_STRING); - }); -}); -``` +If you add tests for new parts of sfdx-core outside of Logger, add new test Suites and create new jobs in the GHA `perf.yml` diff --git a/TEST_SETUP.md b/TEST_SETUP.md new file mode 100644 index 0000000000..ae516234b4 --- /dev/null +++ b/TEST_SETUP.md @@ -0,0 +1,223 @@ +# Using TestSetup + +> **Note** +> Explore test examples in the [examples directory](./examples) + +The Salesforce DX Core Library provides a unit testing utility to help with mocking and sand-boxing core components. This feature allows unit tests to execute without needing to make API calls to salesforce.com. + +- [Mocking Authorizations](#mocking-authorizations) +- [Mocking Config Files](#mocking-config-files) +- [Using the Built-in Sinon Sandboxes](#using-the-built-in-sinon-sandboxes) +- [Testing Expected Failures](#testing-expected-failures) +- [Testing Log Lines](#testing-log-lines) + +## Mocking Authorizations + +This code shows how to mock authorization for a Salesforce scratch org. + +```typescript +import { strictEqual } from 'assert'; +import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; +import { AuthInfo } from '@salesforce/core'; + +describe('Mocking Auth data', () => { + const $$ = new TestContext(); + it('example', async () => { + const testData = new MockTestOrgData(); + await $$.stubAuths(testData); + const auth = await AuthInfo.create({ username: testData.username }); + strictEqual(auth.getUsername(), testData.username); + }); +}); +``` + +After having a valid AuthInfo object, you can then create fake connections to a Salesforce.com scratch org. You can then write tests that can validate result responses for SOQL queries and REST endpoints. + +```typescript +import { AuthInfo, Connection, SfError } from '@salesforce/core'; +import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; +import { AnyJson, ensureJsonMap, JsonMap } from '@salesforce/ts-types'; +import { ensureString } from '@salesforce/ts-types'; +import { deepStrictEqual } from 'assert'; +import { QueryResult } from 'jsforce'; + +describe('Mocking a force server call', () => { + const $$ = new TestContext(); + it('example', async () => { + const records: AnyJson = { records: ['123456', '234567'] }; + const testData = new MockTestOrgData(); + await $$.stubAuths(testData); + $$.fakeConnectionRequest = (request: AnyJson): Promise => { + const _request = ensureJsonMap(request); + if (request && ensureString(_request.url).includes('Account')) { + return Promise.resolve(records); + } else { + return Promise.reject(new SfError(`Unexpected request: ${_request.url}`)); + } + }; + const connection = await Connection.create({ + authInfo: await AuthInfo.create({ username: testData.username }), + }); + const result = await connection.query('select Id From Account'); + deepStrictEqual(result, records); + }); +}); +``` + +## Mocking Config Files + +You can mock the contents of various config files. + +```typescript +import { strictEqual } from 'assert'; +import { MockTestOrgData, TestContext } from '@salesforce/core/lib/testSetup'; +import { StateAggregator, OrgConfigProperties } from '@salesforce/core'; + +describe('Mocking Aliases', () => { + const $$ = new TestContext(); + it('example', async () => { + const testData = new MockTestOrgData(); + await $$.stubAliases({ myAlias: testData.username }); + const alias = (await StateAggregator.getInstance()).aliases.get(testData.username); + strictEqual(alias, 'myAlias'); + }); +}); + +describe('Mocking Config', () => { + it('example', async () => { + const testData = new MockTestOrgData(); + await $$.stubConfig({ [OrgConfigProperties.TARGET_ORG]: testData.username }); + const { value } = (await ConfigAggregator.create()).getInfo(OrgConfigProperties.TARGET_ORG); + strictEqual(value, testData.username); + }); +}); + +describe('Mocking a project config file', () => { + it('stubs the project config file', async () => { + $$.setConfigStubContents('SfProjectJson', { + contents: { + packageDirectories: [ + { + path: 'force-app', + default: true, + }, + ], + sourceApiVersion: '57.0', + }, + }); + }); +}); + +describe('Mocking Arbitrary Config Files', () => { + it('example', async () => { + // MyConfigFile must extend the ConfigFile class in order for this to work properly. + // Examples include: DeployCache, DeployPipelineCache, ScratchOrgCache + $$.setConfigStubContents('MyConfigFile', { contents: { foo: 'bar' } }); + }); +}); +``` + +## Using the Built-in Sinon Sandboxes + +sfdx-core uses Sinon as its underlying mocking system. Find more information about Sinon and its sandboxing concept [here](https://sinonjs.org/). + +Sinon `stub`s and `spy`s must be cleaned up after test invocations. To ease the use of Sinon with sfdx-core, we've exposed our sandbox in `TestSetup`. After adding your own `stub`s or `spy`s, they'll automatically be cleaned up after each test using mocha's `afterEach` method. + +```typescript +import { strictEqual } from 'assert'; + +import { TestContext } from '@salesforce/core/lib/testSetup'; +import * as os from 'os'; + +describe('Using the built in Sinon sandbox.', () => { + const $$ = new TestContext(); + it('example', async () => { + const unsupportedOS = 'LEO'; + $$.SANDBOX.stub(os, 'platform').returns(unsupportedOS); + strictEqual(os.platform(), unsupportedOS); + }); +}); +``` + +## Testing Expected Failures + +It's important to have negative tests that ensure proper error handling. With `shouldThrow` it's easy to test for expected async rejections. + +```typescript +import { SfError } from '@salesforce/core'; +import { shouldThrow } from '@salesforce/core/lib/testSetup'; +import { strictEqual } from 'assert'; + +class TestObject { + public static async method() { + throw new SfError('Error', 'ExpectedError'); + } +} + +describe('Testing for expected errors', () => { + it('example', async () => { + try { + await shouldThrow(TestObject.method()); + } catch (e) { + strictEqual(e.name, 'ExpectedError'); + } + }); +}); +``` + +You can also use `shouldThrowSync` for syncrhonous functions you expect to fail. + +```typescript +import { SfError } from '@salesforce/core'; +import { shouldThrowSync } from '@salesforce/core/lib/testSetup'; +import { strictEqual } from 'assert'; + +class TestObject { + public static method() { + throw new SfError('Error', 'ExpectedError'); + } +} + +describe('Testing for expected errors', () => { + it('example', async () => { + try { + shouldThrowSync(() => TestObject.method()); + } catch (e) { + strictEqual(e.name, 'ExpectedError'); + } + }); +}); +``` + +## Testing Log Lines + +It's also useful to check expected values and content from log lines. TestSetup configures the sfdx-core logger to use an in memory LogLine storage structure. These can be easily accessed from tests. + +```typescript +import { Logger, LogLine } from '@salesforce/core'; +import { TestContext } from '@salesforce/core/lib/testSetup'; +import { strictEqual } from 'assert'; + +const TEST_STRING = 'foo was here'; + +class TestObject { + constructor(private logger: Logger) { + this.logger = logger.child('TestObject'); + } + + public method() { + this.logger.error(TEST_STRING); + } +} + +describe('Testing log lines', () => { + const $$ = new TestContext(); + it('example', async () => { + const obj = new TestObject($$.TEST_LOGGER); + obj.method(); + const records = $$.TEST_LOGGER.getBufferedRecords(); + strictEqual(records.length, 1); + strictEqual(records[0].msg, TEST_STRING); + }); +}); +``` diff --git a/examples/yarn.lock b/examples/yarn.lock index 6f6f4449e5..960efb407e 100644 --- a/examples/yarn.lock +++ b/examples/yarn.lock @@ -890,9 +890,9 @@ get-caller-file@^2.0.5: integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== get-func-name@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" - integrity sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig== + version "2.0.2" + resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.2.tgz#0d7cf20cd13fda808669ffa88f4ffc7a3943fc41" + integrity sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ== glob-parent@~5.1.2: version "5.1.2" @@ -1627,6 +1627,11 @@ punycode@^2.1.0, punycode@^2.1.1: resolved "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== +querystringify@^2.1.1: + version "2.2.0" + resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" + integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== + randombytes@^2.1.0: version "2.1.0" resolved "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" @@ -1692,6 +1697,11 @@ require-from-string@^2.0.2: resolved "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" + integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== + resolve@^1.1.6: version "1.22.0" resolved "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz#5e0b8c67c15df57a89bdbabe603a002f21731198" @@ -1766,9 +1776,9 @@ sax@>=0.6.0: integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== semver@^5.6.0: - version "5.7.1" - resolved "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" - integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== + version "5.7.2" + resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.2.tgz#48d55db737c3287cd4835e17fa13feace1c41ef8" + integrity sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g== sentence-case@^3.0.4: version "3.0.4" @@ -1938,13 +1948,14 @@ to-regex-range@^5.0.1: is-number "^7.0.0" tough-cookie@*: - version "4.0.0" - resolved "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" - integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg== + version "4.1.3" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.1.3.tgz#97b9adb0728b42280aa3d814b6b999b2ff0318bf" + integrity sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw== dependencies: psl "^1.1.33" punycode "^2.1.1" - universalify "^0.1.2" + universalify "^0.2.0" + url-parse "^1.5.3" tr46@~0.0.3: version "0.0.3" @@ -2007,11 +2018,16 @@ typescript@^4: resolved "https://registry.npmjs.org/typescript/-/typescript-4.7.3.tgz#8364b502d5257b540f9de4c40be84c98e23a129d" integrity sha512-WOkT3XYvrpXx4vMMqlD+8R8R37fZkjyLGlxavMc4iB8lrl8L0DeTcHbYgw/v0N/z9wAFsgBhcsF0ruoySS22mA== -universalify@^0.1.0, universalify@^0.1.2: +universalify@^0.1.0: version "0.1.2" resolved "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== +universalify@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.2.0.tgz#6451760566fa857534745ab1dde952d1b1761be0" + integrity sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg== + upper-case-first@^2.0.2: version "2.0.2" resolved "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.2.tgz#992c3273f882abd19d1e02894cc147117f844324" @@ -2033,6 +2049,14 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" +url-parse@^1.5.3: + version "1.5.10" + resolved "https://registry.yarnpkg.com/url-parse/-/url-parse-1.5.10.tgz#9d3c2f736c1d75dd3bd2be507dcc111f1e2ea9c1" + integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== + dependencies: + querystringify "^2.1.1" + requires-port "^1.0.0" + util-deprecate@^1.0.1, util-deprecate@~1.0.1: version "1.0.2" resolved "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" diff --git a/messageTransformer/messageTransformer.ts b/messageTransformer/messageTransformer.ts deleted file mode 100644 index e99fdeb654..0000000000 --- a/messageTransformer/messageTransformer.ts +++ /dev/null @@ -1,93 +0,0 @@ -/* - * Copyright (c) 2023, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ -/* eslint-disable no-console */ -/* eslint-disable complexity */ - -import * as ts from 'typescript'; -import { Messages, StoredMessageMap } from '../src/messages'; - -/** - * - * @experimental - * transforms `messages` references from dynamic run-time to static compile-time values - */ -const transformer = (program: ts.Program, pluginOptions: {}) => { - Messages.importMessagesDirectory(process.cwd()); - const transformerFactory: ts.TransformerFactory = (context) => { - return (sourceFile) => { - // if there are no messages, no transformation is needed - if ( - !sourceFile.statements.some((i) => ts.isImportDeclaration(i) && i.importClause?.getText().includes('Messages')) - ) { - return sourceFile; - } - - const visitor = (node: ts.Node): ts.VisitResult => { - if (ts.isExpressionStatement(node) && node.getText().includes('importMessagesDirectory')) { - // importMessagesDirectory now happens at compile, not in runtime - // returning undefined removes the node - return undefined; - } - if ( - // transform a runtime load call into hardcoded messages values - // const foo = Messages.load|loadMessages('pluginName', 'messagesFile' ...) => - // const foo = new Messages('pluginName', 'messagesFile', new Map([['key', 'value']])) - ts.isCallExpression(node) && - ts.isPropertyAccessExpression(node.expression) && - node.expression.expression.getText() === 'Messages' && - node.expression.name.getText().includes('load') - ) { - // we always want the first two arguments, which are the plugin name and the messages file name - const arrayMembers = node.arguments.slice(0, 2); - const arrayMembersText = arrayMembers.map(getTextWithoutQuotes); - - // Messages doesn't care whether you call messages.load or loadMessages, it loads the whole file - const messagesInstance = Messages.loadMessages(arrayMembersText[0], arrayMembersText[1]); - return context.factory.createNewExpression(node.expression.expression, undefined, [ - arrayMembers[0], - arrayMembers[1], - context.factory.createNewExpression(context.factory.createIdentifier('Map'), undefined, [ - messageMapToHardcodedMap(messagesInstance.messages), - ]), - ]); - } - // it might be a node that contains one of the things we're interested in, so keep digging - return ts.visitEachChild(node, visitor, context); - }; - return ts.visitNode(sourceFile, visitor); - }; - }; - return transformerFactory; -}; - -export default transformer; - -const getTextWithoutQuotes = (node: ts.Node): string => node.getText().replace(/'/g, ''); - -/** turn a loaded message map into */ -const messageMapToHardcodedMap = (messages: StoredMessageMap): ts.ArrayLiteralExpression => { - return ts.factory.createArrayLiteralExpression( - Array.from(messages).map(([key, value]) => { - // case 1: string - if (typeof value === 'string') { - return ts.factory.createArrayLiteralExpression([ - ts.factory.createStringLiteral(key), - ts.factory.createStringLiteral(value), - ]); - } else if (Array.isArray(value)) { - // case 2: string[] - return ts.factory.createArrayLiteralExpression([ - ts.factory.createStringLiteral(key), - ts.factory.createArrayLiteralExpression(value.map((v) => ts.factory.createStringLiteral(v))), - ]); - } else { - // turn the object into a map and recurse! - return messageMapToHardcodedMap(new Map(Object.entries(value))); - } - }) - ); -}; diff --git a/messages/auth.md b/messages/auth.md index 6076e125aa..6e866202b8 100644 --- a/messages/auth.md +++ b/messages/auth.md @@ -24,14 +24,26 @@ Invalid request method: %s Invalid request uri: %s +# error.HttpApi + +HTTP response contains html content. Check that the org exists and can be reached. + # pollingTimeout The device authorization request timed out. After executing force:auth:device:login, you must approve access to the device within 10 minutes. This can happen if the URL wasn’t copied into the browser, login was not attempted, or the 2FA process was not completed within 10 minutes. Request authorization again. # serverErrorHTMLResponse -

%s


This is most likely not an error with the Salesforce CLI. Please ensure all information is accurate and try again. +
%s

This is most likely not an error with the Salesforce CLI. Please ensure all information is accurate and try again.
# missingAuthCode No authentication code found on login response. + +# serverSuccessHTMLResponse + +
You've successfully logged in. You can now close this browser tab or window.
+ +# serverSfdcImage + +PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDIxLjEuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAyNjIgMTg0IiBzdHlsZT0iZW5hYmxlLWJhY2tncm91bmQ6bmV3IDAgMCAyNjIgMTg0OyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+CjxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+Cgkuc3Qwe2ZpbGw6IzAwQTFFMDt9Cgkuc3Qxe2ZpbGw6I0ZGRkZGRjt9Cjwvc3R5bGU+Cjx0aXRsZT5sb2dvLXNhbGVzZm9yY2U8L3RpdGxlPgo8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4KPGcgaWQ9IlRlc3QtQiI+Cgk8ZyBpZD0iTW9iaWxlLU5hdi0tLVRlc3QtQi1feDI4XzBfeDI5XyI+CgkJPGcgaWQ9Ikdyb3VwIj4KCQkJPGcgaWQ9ImxvZ28tc2FsZXNmb3JjZSI+CgkJCQk8cGF0aCBpZD0iRmlsbC0xIiBjbGFzcz0ic3QwIiBkPSJNMTA5LjIsMjAuOWM4LjQtOC43LDIwLjEtMTQuMiwzMy0xNC4yYzE3LjIsMCwzMi4xLDkuNiw0MC4xLDIzLjhjNi45LTMuMSwxNC42LTQuOCwyMi43LTQuOAoJCQkJCWMzMSwwLDU2LDI1LjMsNTYsNTYuNXMtMjUuMSw1Ni41LTU2LDU2LjVjLTMuOCwwLTcuNS0wLjQtMTEtMS4xYy03LDEyLjUtMjAuNCwyMS0zNS44LDIxYy02LjQsMC0xMi41LTEuNS0xNy45LTQuMQoJCQkJCWMtNy4xLDE2LjctMjMuNywyOC41LTQzLDI4LjVjLTIwLjEsMC0zNy4zLTEyLjctNDMuOS0zMC42Yy0yLjksMC42LTUuOSwwLjktOC45LDAuOWMtMjQsMC00My40LTE5LjYtNDMuNC00My45CgkJCQkJYzAtMTYuMiw4LjctMzAuNCwyMS43LTM4Yy0yLjctNi4xLTQuMi0xMi45LTQuMi0yMC4xQzE4LjUsMjMuNiw0MS4yLDEsNjksMUM4NS40LDEsMTAwLDguOCwxMDkuMiwyMC45Ii8+CgkJCQk8cGF0aCBpZD0iQ29tYmluZWQtU2hhcGUiIGNsYXNzPSJzdDEiIGQ9Ik0zOC43LDk1LjRsMS4xLTIuOWMwLjItMC41LDAuNS0wLjMsMC43LTAuMmMwLjMsMC4yLDAuNSwwLjMsMC45LDAuNmMzLjEsMiw2LDIsNi45LDIKCQkJCQljMi4zLDAsMy44LTEuMiwzLjgtMi45di0wLjFjMC0xLjgtMi4yLTIuNS00LjgtMy4zbC0wLjYtMC4yYy0zLjUtMS03LjMtMi41LTcuMy02Ljl2LTAuMWMwLTQuMiwzLjQtNy4yLDguMy03LjJsMC41LDAKCQkJCQljMi45LDAsNS42LDAuOCw3LjYsMi4xYzAuMiwwLjEsMC40LDAuMywwLjMsMC42Yy0wLjEsMC4zLTEsMi42LTEuMSwyLjljLTAuMiwwLjUtMC43LDAuMi0wLjcsMC4yYy0xLjgtMS00LjUtMS43LTYuOC0xLjcKCQkJCQljLTIuMSwwLTMuNCwxLjEtMy40LDIuNnYwLjFjMCwxLjcsMi4zLDIuNSw0LjksMy4zbDAuNSwwLjFjMy41LDEuMSw3LjIsMi42LDcuMiw2Ljl2MC4xYzAsNC42LTMuMyw3LjQtOC42LDcuNAoJCQkJCWMtMi42LDAtNS4xLTAuNC03LjgtMS44Yy0wLjUtMC4zLTEtMC41LTEuNS0wLjlDMzguNyw5NS45LDM4LjUsOTUuOCwzOC43LDk1LjR6IE0xMTYuNyw5NS40bDEuMS0yLjljMC4yLTAuNSwwLjYtMC4zLDAuNy0wLjIKCQkJCQljMC4zLDAuMiwwLjUsMC4zLDAuOSwwLjZjMy4xLDIsNiwyLDYuOSwyYzIuMywwLDMuOC0xLjIsMy44LTIuOXYtMC4xYzAtMS44LTIuMi0yLjUtNC44LTMuM2wtMC42LTAuMmMtMy41LTEtNy4zLTIuNS03LjMtNi45CgkJCQkJdi0wLjFjMC00LjIsMy40LTcuMiw4LjMtNy4ybDAuNSwwYzIuOSwwLDUuNiwwLjgsNy42LDIuMWMwLjIsMC4xLDAuNCwwLjMsMC4zLDAuNmMtMC4xLDAuMy0xLDIuNi0xLjEsMi45CgkJCQkJYy0wLjIsMC41LTAuNywwLjItMC43LDAuMmMtMS44LTEtNC41LTEuNy02LjgtMS43Yy0yLjEsMC0zLjQsMS4xLTMuNCwyLjZ2MC4xYzAsMS43LDIuMywyLjUsNC45LDMuM2wwLjUsMC4xCgkJCQkJYzMuNSwxLjEsNy4yLDIuNiw3LjIsNi45djAuMWMwLDQuNi0zLjMsNy40LTguNiw3LjRjLTIuNiwwLTUuMS0wLjQtNy44LTEuOGMtMC41LTAuMy0xLTAuNS0xLjUtMC45CgkJCQkJQzExNi44LDk1LjksMTE2LjYsOTUuOCwxMTYuNyw5NS40eiBNMTc0LjUsODEuN2MwLjQsMS41LDAuNywzLjEsMC43LDQuOHMtMC4yLDMuMy0wLjcsNC44Yy0wLjQsMS41LTEuMSwyLjgtMiwzLjkKCQkJCQljLTAuOSwxLjEtMi4xLDItMy40LDIuNmMtMS40LDAuNi0zLDAuOS00LjgsMC45Yy0xLjgsMC0zLjQtMC4zLTQuOC0wLjljLTEuNC0wLjYtMi41LTEuNS0zLjQtMi42Yy0wLjktMS4xLTEuNi0yLjQtMi0zLjkKCQkJCQljLTAuNC0xLjUtMC43LTMuMS0wLjctNC44YzAtMS43LDAuMi0zLjMsMC43LTQuOGMwLjQtMS41LDEuMS0yLjgsMi0zLjljMC45LTEuMSwyLjEtMiwzLjQtMi42YzEuNC0wLjYsMy0xLDQuOC0xCgkJCQkJYzEuOCwwLDMuNCwwLjMsNC44LDFjMS40LDAuNiwyLjUsMS41LDMuNCwyLjZDMTczLjQsNzguOSwxNzQuMSw4MC4yLDE3NC41LDgxLjd6IE0xNzAsODYuNGMwLTIuNi0wLjUtNC42LTEuNC02CgkJCQkJYy0wLjktMS40LTIuNC0yLjEtNC4zLTIuMWMtMiwwLTMuNCwwLjctNC4zLDIuMWMtMC45LDEuNC0xLjQsMy40LTEuNCw2YzAsMi42LDAuNSw0LjYsMS40LDYuMWMwLjksMS40LDIuMywyLjEsNC4zLDIuMQoJCQkJCWMyLDAsMy40LTAuNyw0LjMtMi4xQzE2OS42LDkxLjEsMTcwLDg5LDE3MCw4Ni40eiBNMjExLjEsOTMuOWwxLjEsM2MwLjEsMC40LTAuMiwwLjUtMC4yLDAuNWMtMS43LDAuNy00LDEuMS02LjMsMS4xCgkJCQkJYy0zLjksMC02LjgtMS4xLTguOC0zLjNjLTItMi4yLTMtNS4yLTMtOC45YzAtMS43LDAuMi0zLjMsMC43LTQuOGMwLjUtMS41LDEuMi0yLjgsMi4yLTMuOWMxLTEuMSwyLjItMiwzLjYtMi42CgkJCQkJYzEuNC0wLjYsMy4xLTEsNS0xYzEuMywwLDIuNCwwLjEsMy4zLDAuMmMxLDAuMiwyLjQsMC41LDMsMC44YzAuMSwwLDAuNCwwLjIsMC4zLDAuNWMtMC40LDEuMi0wLjcsMi0xLjEsMwoJCQkJCWMtMC4yLDAuNS0wLjUsMC4zLTAuNSwwLjNjLTEuNS0wLjUtMi45LTAuNy00LjctMC43Yy0yLjIsMC0zLjksMC43LTQuOSwyLjJjLTEuMSwxLjQtMS43LDMuMy0xLjcsNS45YzAsMi44LDAuNyw0LjgsMS45LDYuMQoJCQkJCWMxLjIsMS4zLDIuOSwxLjksNS4xLDEuOWMwLjksMCwxLjctMC4xLDIuNC0wLjJjMC43LTAuMSwxLjQtMC4zLDIuMS0wLjZDMjEwLjUsOTMuNiwyMTAuOSw5My41LDIxMS4xLDkzLjl6IE0yMzMuOCw4MC44CgkJCQkJYzEsMy40LDAuNSw2LjMsMC40LDYuNWMwLDAuNC0wLjQsMC40LTAuNCwwLjRsLTE1LjEsMGMwLjEsMi4zLDAuNiwzLjksMS44LDVjMS4xLDEuMSwyLjgsMS44LDUuMiwxLjhjMy42LDAsNS4xLTAuNyw2LjItMS4xCgkJCQkJYzAsMCwwLjQtMC4xLDAuNiwwLjNsMSwyLjhjMC4yLDAuNSwwLDAuNi0wLjEsMC43Yy0wLjksMC41LTMuMiwxLjUtNy42LDEuNWMtMi4xLDAtNC0wLjMtNS41LTAuOWMtMS41LTAuNi0yLjgtMS40LTMuOC0yLjUKCQkJCQljLTEtMS4xLTEuNy0yLjQtMi4yLTMuOGMtMC41LTEuNS0wLjctMy4xLTAuNy00LjhjMC0xLjcsMC4yLTMuMywwLjctNC44YzAuNC0xLjUsMS4xLTIuOCwyLTMuOWMwLjktMS4xLDIuMS0yLDMuNS0yLjYKCQkJCQljMS40LTAuNywzLjEtMSw1LTFjMS42LDAsMy4xLDAuMyw0LjMsMC45YzAuOSwwLjQsMS45LDEuMSwyLjksMi4yQzIzMi41LDc3LjksMjMzLjQsNzkuNCwyMzMuOCw4MC44eiBNMjE4LjgsODRoMTAuNwoJCQkJCWMtMC4xLTEuNC0wLjQtMi42LTEtMy42Yy0wLjktMS40LTIuMi0yLjItNC4yLTIuMmMtMiwwLTMuNCwwLjgtNC4zLDIuMkMyMTkuNCw4MS4zLDIxOS4xLDgyLjUsMjE4LjgsODR6IE0xMTMuMSw4MC44CgkJCQkJYzEsMy40LDAuNSw2LjMsMC41LDYuNWMwLDAuNC0wLjQsMC40LTAuNCwwLjRsLTE1LjEsMGMwLjEsMi4zLDAuNiwzLjksMS44LDVjMS4xLDEuMSwyLjgsMS44LDUuMiwxLjhjMy42LDAsNS4xLTAuNyw2LjItMS4xCgkJCQkJYzAsMCwwLjQtMC4xLDAuNiwwLjNsMSwyLjhjMC4yLDAuNSwwLDAuNi0wLjEsMC43Yy0wLjksMC41LTMuMiwxLjUtNy42LDEuNWMtMi4xLDAtNC0wLjMtNS41LTAuOWMtMS41LTAuNi0yLjgtMS40LTMuOC0yLjUKCQkJCQljLTEtMS4xLTEuNy0yLjQtMi4yLTMuOGMtMC41LTEuNS0wLjctMy4xLTAuNy00LjhjMC0xLjcsMC4yLTMuMywwLjctNC44YzAuNC0xLjUsMS4xLTIuOCwyLTMuOWMwLjktMS4xLDIuMS0yLDMuNS0yLjYKCQkJCQljMS40LTAuNywzLjEtMSw1LTFjMS42LDAsMy4xLDAuMyw0LjMsMC45YzAuOSwwLjQsMS45LDEuMSwyLjksMi4yQzExMS44LDc3LjksMTEyLjgsNzkuNCwxMTMuMSw4MC44eiBNOTguMSw4NGgxMC44CgkJCQkJYy0wLjEtMS40LTAuNC0yLjYtMS0zLjZjLTAuOS0xLjQtMi4yLTIuMi00LjItMi4yYy0yLDAtMy40LDAuOC00LjMsMi4yQzk4LjcsODEuMyw5OC40LDgyLjUsOTguMSw4NHogTTcxLjYsODMuMgoJCQkJCWMwLDAsMS4yLDAuMSwyLjUsMC4zdi0wLjZjMC0yLTAuNC0zLTEuMi0zLjZjLTAuOC0wLjYtMi4xLTEtMy43LTFjMCwwLTMuNywwLTYuNiwxLjVjLTAuMSwwLjEtMC4yLDAuMS0wLjIsMC4xCgkJCQkJcy0wLjQsMC4xLTAuNS0wLjJsLTEuMS0yLjljLTAuMi0wLjQsMC4xLTAuNiwwLjEtMC42YzEuNC0xLjEsNC42LTEuNyw0LjYtMS43YzEuMS0wLjIsMi45LTAuNCw0LTAuNGMzLDAsNS4zLDAuNyw2LjksMi4xCgkJCQkJYzEuNiwxLjQsMi40LDMuNiwyLjQsNi43bDAsMTMuOGMwLDAsMCwwLjQtMC4zLDAuNWMwLDAtMC42LDAuMi0xLjEsMC4zYy0wLjUsMC4xLTIuMywwLjUtMy44LDAuN2MtMS41LDAuMy0zLDAuNC00LjYsMC40CgkJCQkJYy0xLjUsMC0yLjgtMC4xLTQtMC40Yy0xLjItMC4zLTIuMi0wLjctMy4xLTEuM2MtMC44LTAuNi0xLjUtMS40LTItMi40Yy0wLjUtMC45LTAuNy0yLjEtMC43LTMuNGMwLTEuMywwLjMtMi41LDAuOC0zLjUKCQkJCQljMC41LTEsMS4zLTEuOCwyLjItMi41YzAuOS0wLjcsMi0xLjEsMy4xLTEuNWMxLjItMC4zLDIuNC0wLjUsMy43LTAuNUM3MC4yLDgzLjIsNzEsODMuMiw3MS42LDgzLjJ6IE02NS42LDkzLjgKCQkJCQljMCwwLDEuNCwxLjEsNC40LDAuOWMyLjItMC4xLDQuMS0wLjUsNC4xLTAuNXYtNi45YzAsMC0xLjktMC4zLTQuMS0wLjNjLTMuMSwwLTQuNCwxLjEtNC40LDEuMWMtMC45LDAuNi0xLjMsMS42LTEuMywyLjkKCQkJCQljMCwwLjgsMC4yLDEuNSwwLjUsMkM2NC45LDkzLjIsNjUsOTMuNCw2NS42LDkzLjh6IE0xOTMuMSw3NS41Yy0wLjEsMC40LTAuOSwyLjUtMS4xLDMuMmMtMC4xLDAuMy0wLjMsMC40LTAuNiwwLjQKCQkJCQljMCwwLTAuOS0wLjItMS43LTAuMmMtMC41LDAtMS4zLDAuMS0yLDAuM2MtMC43LDAuMi0xLjMsMC42LTEuOSwxLjFjLTAuNiwwLjUtMSwxLjMtMS4zLDIuMmMtMC4zLDAuOS0wLjUsMi40LTAuNSw0djExLjIKCQkJCQljMCwwLjMtMC4yLDAuNS0wLjUsMC41aC00Yy0wLjMsMC0wLjUtMC4yLTAuNS0wLjVWNzUuMmMwLTAuMywwLjItMC41LDAuNC0wLjVoMy45YzAuMywwLDAuNCwwLjIsMC40LDAuNVY3NwoJCQkJCWMwLjYtMC44LDEuNi0xLjUsMi41LTEuOWMwLjktMC40LDItMC43LDMuOS0wLjZjMSwwLjEsMi4zLDAuMywyLjUsMC40QzE5Myw3NSwxOTMuMiw3NS4xLDE5My4xLDc1LjV6IE0xNTYsNjUuMQoJCQkJCWMwLjEsMCwwLjQsMC4yLDAuMywwLjVsLTEuMiwzLjJjLTAuMSwwLjItMC4yLDAuNC0wLjcsMC4yYy0wLjEsMC0wLjMtMC4xLTAuOC0wLjJjLTAuMy0wLjEtMC44LTAuMS0xLjItMC4xCgkJCQkJYy0wLjYsMC0xLjEsMC4xLTEuNiwwLjJjLTAuNSwwLjEtMC45LDAuNC0xLjMsMC44Yy0wLjQsMC40LTAuOCwwLjktMS4xLDEuNmMtMC42LDEuNi0wLjgsMy4zLTAuOCwzLjRoNC44CgkJCQkJYzAuNCwwLDAuNSwwLjIsMC41LDAuNWwtMC42LDMuMWMtMC4xLDAuNS0wLjUsMC40LTAuNSwwLjRoLTVMMTQzLjYsOThjLTAuNCwyLTAuOCwzLjctMS4zLDUuMWMtMC41LDEuNC0xLjEsMi40LTIsMy40CgkJCQkJYy0wLjgsMC45LTEuNywxLjYtMi44LDEuOWMtMSwwLjQtMi4zLDAuNi0zLjcsMC42Yy0wLjcsMC0xLjQsMC0yLjItMC4yYy0wLjYtMC4xLTAuOS0wLjItMS40LTAuNGMtMC4yLTAuMS0wLjMtMC4zLTAuMi0wLjYKCQkJCQljMC4xLTAuMywxLTIuNywxLjEtMy4xYzAuMi0wLjQsMC41LTAuMiwwLjUtMC4yYzAuMywwLjEsMC41LDAuMiwwLjgsMC4zYzAuNCwwLjEsMC44LDAuMSwxLjIsMC4xYzAuNywwLDEuMy0wLjEsMS44LTAuMwoJCQkJCWMwLjYtMC4yLDEtMC42LDEuNC0xLjFjMC40LTAuNSwwLjctMS4yLDEuMS0yLjFjMC4zLTAuOSwwLjYtMi4yLDAuOS0zLjdsMy40LTE4LjloLTMuM2MtMC40LDAtMC41LTAuMi0wLjUtMC41bDAuNi0zLjEKCQkJCQljMC4xLTAuNSwwLjUtMC40LDAuNS0wLjRoMy40bDAuMi0xYzAuNS0zLDEuNS01LjMsMy02LjhjMS41LTEuNSwzLjctMi4zLDYuNC0yLjNjMC44LDAsMS41LDAuMSwyLjEsMC4yCgkJCQkJQzE1NSw2NC44LDE1NS41LDY0LjksMTU2LDY1LjF6IE04OC42LDk3LjZjMCwwLjMtMC4yLDAuNS0wLjQsMC41aC00Yy0wLjMsMC0wLjQtMC4yLTAuNC0wLjVWNjUuNWMwLTAuMiwwLjItMC41LDAuNC0wLjVoNAoJCQkJCWMwLjMsMCwwLjQsMC4yLDAuNCwwLjVWOTcuNnoiLz4KCQkJPC9nPgoJCTwvZz4KCTwvZz4KPC9nPgo8L3N2Zz4K diff --git a/messages/config.md b/messages/config.md index 1fe9b6a29f..7039fea6f8 100644 --- a/messages/config.md +++ b/messages/config.md @@ -151,6 +151,10 @@ A valid repository URL or directory for the custom org metadata templates. A valid repository URL or directory for the custom org metadata templates. +# org-capitalize-record-types + +Whether record types are capitalized on scratch org creation. + # invalidId The given id %s is not a valid 15 or 18 character Salesforce ID. diff --git a/messages/connection.md b/messages/connection.md index d926ec0f3a..8b5c0fe7b8 100644 --- a/messages/connection.md +++ b/messages/connection.md @@ -8,10 +8,10 @@ The org cannot be found # domainNotFoundError.actions -- Verify that the org still exists', -- If your org is newly created, wait a minute and run your command again', -- If you deployed or updated the org's My Domain, logout from the CLI and authenticate again", -- If you are running in a CI environment with a DNS that blocks external IPs, try setting SFDX_DISABLE_DNS_CHECK=true' +- Verify that the org still exists, +- If your org is newly created, wait a minute and run your command again, +- If you deployed or updated the org's My Domain, logout from the CLI and authenticate again, +- If you are running in a CI environment with a DNS that blocks external IPs, try setting SFDX_DISABLE_DNS_CHECK=true # noInstanceUrlError diff --git a/messages/envVars.md b/messages/envVars.md index 8ecd92a5d6..f46ea1c39a 100644 --- a/messages/envVars.md +++ b/messages/envVars.md @@ -301,3 +301,17 @@ Boolean indicating that the installer is running # sfEnv Describes if sf is in "demo" mode + +# deprecatedEnv + +Deprecated environment variable: %s. Please use %s instead. + +# deprecatedEnvDisagreement + +Deprecated environment variable: %s. Please use %s instead. + +Your environment has both variables populated, and with different values. The value from %s will be used. + +# sfCapitalizeRecordTypes + +Whether record types are capitalized on scratch org creation. diff --git a/messages/scratchOrgErrorCodes.md b/messages/scratchOrgErrorCodes.md index d620916392..39e01810cb 100644 --- a/messages/scratchOrgErrorCodes.md +++ b/messages/scratchOrgErrorCodes.md @@ -20,7 +20,7 @@ The scratch org is not ready yet (Status = %s). # action.StillInProgress -Wait for a few minutes, and then try the <%= config.bin %> <%= command.id %> command again +Wait for a few minutes, and then try the command again # NoScratchOrgInfoError diff --git a/messages/scratchOrgSettingsGenerator.md b/messages/scratchOrgSettingsGenerator.md new file mode 100644 index 0000000000..3b2eb5da79 --- /dev/null +++ b/messages/scratchOrgSettingsGenerator.md @@ -0,0 +1,4 @@ +# noCapitalizeRecordTypeConfigVar + +Record types defined in the scratch org definition file will stop being capitalized by default in a future release. +Set the `org-capitalize-record-types` config var to `true` to enforce capitalization. diff --git a/package.json b/package.json index 9bf3e84383..28829abcad 100644 --- a/package.json +++ b/package.json @@ -1,13 +1,15 @@ { "name": "@salesforce/core", - "version": "3.34.6", + "version": "6.5.1", "description": "Core libraries to interact with SFDX projects, orgs, and APIs.", "main": "lib/exported", "types": "lib/exported.d.ts", "license": "BSD-3-Clause", + "engines": { + "node": ">=18.0.0" + }, "scripts": { "build": "wireit", - "ci-docs": "yarn sf-ci-docs", "clean": "sf-clean", "clean-all": "sf-clean all", "compile": "wireit", @@ -19,8 +21,8 @@ "prepack": "sf-prepack", "prepare": "sf-install", "test": "wireit", - "test:compile": "wireit", - "test:only": "wireit" + "test:only": "wireit", + "test:perf": "ts-node test/perf/logger/main.test.ts" }, "keywords": [ "force", @@ -36,61 +38,37 @@ "messageTransformer/messageTransformer.ts" ], "dependencies": { - "@salesforce/bunyan": "^2.0.0", - "@salesforce/kit": "^1.9.2", - "@salesforce/schemas": "^1.5.1", - "@salesforce/ts-types": "^1.7.2", - "@types/graceful-fs": "^4.1.6", - "@types/semver": "^7.3.13", + "@salesforce/kit": "^3.0.15", + "@salesforce/schemas": "^1.6.1", + "@salesforce/ts-types": "^2.0.9", + "@types/semver": "^7.5.6", "ajv": "^8.12.0", - "archiver": "^5.3.0", "change-case": "^4.1.2", - "debug": "^3.2.7", "faye": "^1.4.0", "form-data": "^4.0.0", - "graceful-fs": "^4.2.11", "js2xmlparser": "^4.0.1", - "jsforce": "^2.0.0-beta.20", - "jsonwebtoken": "9.0.0", - "ts-retry-promise": "^0.7.0" + "jsforce": "^2.0.0-beta.29", + "jsonwebtoken": "9.0.2", + "jszip": "3.10.1", + "pino": "^8.17.2", + "pino-abstract-transport": "^1.1.0", + "pino-pretty": "^10.3.1", + "proper-lockfile": "^4.1.2", + "semver": "^7.5.4", + "ts-retry-promise": "^0.7.1" }, "devDependencies": { - "@salesforce/dev-config": "^3.0.1", - "@salesforce/dev-scripts": "^4.0.0-beta.7", - "@salesforce/prettier-config": "^0.0.2", - "@salesforce/ts-sinon": "^1.4.6", - "@types/archiver": "^5.3.2", - "@types/chai-string": "^1.4.2", - "@types/debug": "0.0.31", - "@types/jsen": "0.0.21", - "@types/jsonwebtoken": "9.0.1", - "@types/lodash": "^4.14.192", - "@types/shelljs": "0.8.11", - "@typescript-eslint/eslint-plugin": "^5.57.0", - "@typescript-eslint/parser": "^5.57.0", - "chai": "^4.3.7", + "@salesforce/dev-scripts": "^7.1.1", + "@salesforce/ts-sinon": "^1.4.19", + "@types/benchmark": "^2.1.5", + "@types/chai-string": "^1.4.5", + "@types/jsonwebtoken": "9.0.5", + "@types/proper-lockfile": "^4.1.4", + "benchmark": "^2.1.4", "chai-string": "^1.5.0", - "commitizen": "^3.1.2", - "eslint": "^8.37.0", - "eslint-config-prettier": "^8.8.0", - "eslint-config-salesforce": "^1.1.1", - "eslint-config-salesforce-license": "^0.2.0", - "eslint-config-salesforce-typescript": "^1.1.1", - "eslint-plugin-header": "^3.1.1", - "eslint-plugin-import": "^2.27.5", - "eslint-plugin-jsdoc": "^39.9.1", - "husky": "^7.0.4", - "lodash": "^4.17.21", - "mocha": "^9.1.3", - "nyc": "^15.1.0", - "prettier": "^2.8.7", - "pretty-quick": "^3.1.3", - "shelljs": "0.8.5", - "sinon": "^14.0.2", - "ts-node": "^10.4.0", - "ttypescript": "^1.5.15", - "typescript": "^4.9.5", - "wireit": "^0.9.5" + "ts-node": "^10.9.2", + "ts-patch": "^3.1.1", + "typescript": "^5.3.3" }, "repository": { "type": "git", @@ -107,7 +85,7 @@ ] }, "compile": { - "command": "ttsc -p . --pretty --incremental", + "command": "tspc -p . --pretty --incremental", "files": [ "src/**/*.ts", "tsconfig.json", @@ -121,15 +99,24 @@ "clean": "if-file-deleted" }, "format": { - "command": "prettier --write \"+(src|test|schemas)/**/*.+(ts|js|json)|command-snapshot.json\"" + "command": "prettier --write \"+(src|test|schemas)/**/*.+(ts|js|json)|command-snapshot.json\"", + "files": [ + "src/**/*.ts", + "test/**/*.ts", + "schemas/**/*.json", + "command-snapshot.json", + ".prettier*" + ], + "output": [] }, "lint": { - "command": "eslint --color --cache --cache-location .eslintcache", + "command": "eslint src test --color --cache --cache-location .eslintcache", "files": [ "src/**/*.ts", "test/**/*.ts", - ".eslintignore", - ".eslintrc.js" + "messages/**", + "**/.eslint*", + "**/tsconfig.json" ], "output": [] }, @@ -137,18 +124,22 @@ "command": "tsc -p \"./test\" --pretty", "files": [ "test/**/*.ts", - "tsconfig.json", - "test/tsconfig.json" + "**/tsconfig.json" ], "output": [] }, "test:only": { "command": "nyc mocha \"test/**/*Test.ts\"", + "env": { + "FORCE_COLOR": "2" + }, "files": [ "test/**/*.ts", "src/**/*.ts", - "tsconfig.json", - "test/tsconfig.json" + "**/tsconfig.json", + ".mocha*", + "!*.nut.ts", + ".nycrc" ], "output": [] }, @@ -159,4 +150,4 @@ ] } } -} \ No newline at end of file +} diff --git a/src/config/aliasesConfig.ts b/src/config/aliasesConfig.ts deleted file mode 100644 index ad655fc64c..0000000000 --- a/src/config/aliasesConfig.ts +++ /dev/null @@ -1,27 +0,0 @@ -/* - * Copyright (c) 2022, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -import { ConfigGroup } from './configGroup'; -import { ConfigContents, ConfigValue } from './configStore'; - -/** - * Different groups of aliases. Currently only support orgs. - */ -export enum AliasGroup { - ORGS = 'orgs', -} - -export class AliasesConfig extends ConfigGroup { - public static getDefaultOptions(): ConfigGroup.Options { - return { ...ConfigGroup.getOptions(AliasGroup.ORGS, 'alias.json'), isGlobal: true, isState: true }; - } - - // eslint-disable-next-line class-methods-use-this - protected setMethod(contents: ConfigContents, key: string, value?: ConfigValue): void { - contents[key] = value; - } -} diff --git a/src/config/authInfoConfig.ts b/src/config/authInfoConfig.ts index 9ce5abcde4..f901f6e32c 100644 --- a/src/config/authInfoConfig.ts +++ b/src/config/authInfoConfig.ts @@ -5,7 +5,7 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { AuthFields } from '../org'; +import { AuthFields } from '../org/authInfo'; import { ConfigFile } from './configFile'; /** diff --git a/src/config/config.ts b/src/config/config.ts index f4f8cf1387..7af17722d5 100644 --- a/src/config/config.ts +++ b/src/config/config.ts @@ -5,18 +5,20 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { dirname as pathDirname, join as pathJoin } from 'path'; -import * as fs from 'fs'; -import { keyBy, parseJsonMap, set } from '@salesforce/kit'; -import { Dictionary, ensure, isString, JsonPrimitive, Nullable } from '@salesforce/ts-types'; +import { dirname as pathDirname, join as pathJoin } from 'node:path'; +import * as fs from 'node:fs'; +import { keyBy, parseJsonMap } from '@salesforce/kit'; +import { Dictionary, ensure, isString, Nullable } from '@salesforce/ts-types'; import { Global } from '../global'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { validateApiVersion } from '../util/sfdc'; import { SfdcUrl } from '../util/sfdcUrl'; import { ORG_CONFIG_ALLOWED_PROPERTIES, OrgConfigProperties } from '../org/orgConfigProperties'; +import { Lifecycle } from '../lifecycleEvents'; import { ConfigFile } from './configFile'; -import { ConfigContents, ConfigValue } from './configStore'; +import { ConfigContents, ConfigValue, Key } from './configStackTypes'; +import { LWWState, stateFromContents } from './lwwMap'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'config'); @@ -94,7 +96,7 @@ export const SF_ALLOWED_PROPERTIES = [ key: SfConfigProperties.DISABLE_TELEMETRY, description: messages.getMessage(SfConfigProperties.DISABLE_TELEMETRY), input: { - validator: (value: ConfigValue): boolean => value == null || ['true', 'false'].includes(value.toString()), + validator: (value: ConfigValue): boolean => value == null || isBooleanOrBooleanString(value), failedMessage: messages.getMessage('invalidBooleanConfigValue'), }, }, @@ -246,7 +248,7 @@ export const SFDX_ALLOWED_PROPERTIES = [ deprecated: true, description: messages.getMessage(SfdxPropertyKeys.DISABLE_TELEMETRY), input: { - validator: (value: ConfigValue): boolean => value == null || ['true', 'false'].includes(value.toString()), + validator: (value: ConfigValue): boolean => value == null || isBooleanOrBooleanString(value), failedMessage: messages.getMessage('invalidBooleanConfigValue'), }, }, @@ -263,7 +265,7 @@ export const SFDX_ALLOWED_PROPERTIES = [ newKey: 'org-metadata-rest-deploy', deprecated: true, input: { - validator: (value: ConfigValue): boolean => value != null && ['true', 'false'].includes(value.toString()), + validator: (value: ConfigValue): boolean => value != null && isBooleanOrBooleanString(value), failedMessage: messages.getMessage('invalidBooleanConfigValue'), }, }, @@ -286,7 +288,10 @@ export const SFDX_ALLOWED_PROPERTIES = [ // Generic global config properties. Specific properties can be loaded like orgConfigProperties.ts. export const SfProperty: { [index: string]: ConfigPropertyMeta } = {}; -export type ConfigProperties = { [index: string]: JsonPrimitive }; +/* A very loose type to account for the possibility of plugins adding properties via configMeta. + * The class itself is doing runtime validation to check property keys and values. + */ +export type ConfigProperties = ConfigContents; /** * The files where sfdx config values are stored for projects and the global space. @@ -308,28 +313,24 @@ export class Config extends ConfigFile { ...ORG_CONFIG_ALLOWED_PROPERTIES, ]; - private sfdxConfig: SfdxConfig; + private sfdxPath?: string; public constructor(options?: ConfigFile.Options) { - super( - Object.assign( - { - isGlobal: false, - }, - options ?? {}, - { - // Don't let consumers of config override this. If they really really want to, - // they can extend this class. - isState: true, - filename: Config.getFileName(), - stateFolder: Global.SF_STATE_FOLDER, - } - ) - ); + super({ + ...{ isGlobal: false }, + ...(options ?? {}), + // Don't let consumers of config override this. If they really really want to, + // they can extend this class. + isState: true, + filename: Config.getFileName(), + stateFolder: Global.SF_STATE_FOLDER, + }); // Resolve the config path on creation. this.getPath(); - this.sfdxConfig = new SfdxConfig(this.options, this); + if (Global.SFDX_INTEROPERABILITY) { + this.sfdxPath = buildSfdxPath(this.options); + } } /** @@ -377,31 +378,33 @@ export class Config extends ConfigFile { * @param propertyName The name of the property to set. * @param value The property value. */ - public static async update(isGlobal: boolean, propertyName: string, value?: ConfigValue): Promise { + public static async update>( + isGlobal: boolean, + propertyName: K, + value?: ConfigProperties[K] + ): Promise { const config = await Config.create({ isGlobal }); - const content = await config.read(); + await config.read(); if (value == null) { - delete content[propertyName]; + config.unset(propertyName); } else { - set(content, propertyName, value); + config.set(propertyName, value); } - - return config.write(content); + return config.write(); } /** * Clear all the configured properties both local and global. */ public static async clear(): Promise { - const globalConfig = await Config.create({ isGlobal: true }); - globalConfig.clear(); - await globalConfig.write(); + const [globalConfig, localConfig] = await Promise.all([Config.create({ isGlobal: true }), Config.create()]); - const localConfig = await Config.create(); + globalConfig.clear(); localConfig.clear(); - await localConfig.write(); + + await Promise.all([globalConfig.write(), localConfig.write()]); } public static getPropertyConfigMeta(propertyName: string): Nullable { @@ -422,10 +425,12 @@ export class Config extends ConfigFile { */ public async read(force = true): Promise { try { - const config = await super.read(false, force); - // Merge .sfdx/sfdx-config.json and .sf/config.json - const merged = this.sfdxConfig.merge(config); - this.setContents(merged); + await super.read(false, force); + if (Global.SFDX_INTEROPERABILITY) { + // will exist if Global.SFDX_INTEROPERABILITY is enabled + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + this.contents.merge(stateFromSfdxFileSync(this.sfdxPath!, this)); + } await this.cryptProperties(false); return this.getContents(); } finally { @@ -434,10 +439,13 @@ export class Config extends ConfigFile { } public readSync(force = true): ConfigProperties { - const config = super.readSync(false, force); - // Merge .sfdx/sfdx-config.json and .sf/config.json - const merged = this.sfdxConfig.merge(config); - this.setContents(merged); + super.readSync(false, force); + if (Global.SFDX_INTEROPERABILITY) { + // will exist if Global.SFDX_INTEROPERABILITY is enabled + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + this.contents.merge(stateFromSfdxFileSync(this.sfdxPath!, this)); + } + return this.getContents(); } @@ -446,16 +454,17 @@ export class Config extends ConfigFile { * * @param newContents The new Config value to persist. */ - public async write(newContents?: ConfigProperties): Promise { - if (newContents != null) { - this.setContents(newContents); - } - + public async write(): Promise { await this.cryptProperties(true); + // super.write will merge the contents if the target file had newer properties await super.write(); - if (Global.SFDX_INTEROPERABILITY) await this.sfdxConfig.write(); + if (Global.SFDX_INTEROPERABILITY) { + // will exist if Global.SFDX_INTEROPERABILITY is enabled + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + await writeToSfdx(this.sfdxPath!, this.getContents()); + } await this.cryptProperties(false); return this.getContents(); @@ -483,17 +492,19 @@ export class Config extends ConfigFile { * @param key The property to set. * @param value The value of the property. */ - public set(key: string, value: JsonPrimitive): ConfigProperties { + public set>(key: K, value: ConfigProperties[K]): ConfigProperties { const property = Config.allowedProperties.find((allowedProp) => allowedProp.key === key); if (!property) { throw messages.createError('unknownConfigKey', [key]); } if (property.deprecated && property.newKey) { - throw messages.createError('deprecatedConfigKey', [key, property.newKey]); + // you're trying to set a deprecated key, but we'll set the new key instead + void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, property.newKey])); + return this.set(property.newKey, value); } - if (property.input) { + if (value !== undefined && property.input) { if (property.input?.validator(value)) { super.set(property.key, value); } else { @@ -526,7 +537,10 @@ export class Config extends ConfigFile { } if (property.deprecated && property.newKey) { - throw messages.createError('deprecatedConfigKey', [key, property.newKey]); + // you're trying to set a deprecated key, so we'll ALSO unset the new key + void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, property.newKey])); + super.unset(property.key); + return this.unset(property.newKey); } return super.unset(property.key); @@ -544,6 +558,10 @@ export class Config extends ConfigFile { const prop = Config.propertyConfigMap()[propertyName]; if (!prop) { + const newEquivalent = Config.allowedProperties.find((p) => p.newKey); + if (newEquivalent) { + return this.getPropertyConfig(newEquivalent.key); + } throw messages.createError('unknownConfigKey', [propertyName]); } return prop; @@ -579,97 +597,71 @@ export class Config extends ConfigFile { } } -export class SfdxConfig { - private sfdxPath: string; - public constructor(private options: ConfigFile.Options = {}, private config: Config) { - this.sfdxPath = this.getSfdxPath(); - } - - /** - * If Global.SFDX_INTEROPERABILITY is enabled, merge the sfdx config into the sf config - */ - public merge(config: ConfigProperties): ConfigProperties | undefined { - if (!Global.SFDX_INTEROPERABILITY) return config; - const sfdxConfig = this.readSync(); - - const sfdxPropKeys = Object.values(SfdxPropertyKeys) as string[]; - - // Get a list of config keys that are NOT provided by SfdxPropertyKeys - const nonSfdxPropKeys = Config.getAllowedProperties() - .filter((p) => !sfdxPropKeys.includes(p.key)) - .map((p) => p.key); - - // Remove any config from .sf that isn't also in .sfdx - // This handles the scenario where a config has been deleted - // from .sfdx and we want to mirror that change in .sf - for (const key of nonSfdxPropKeys) { - if (!sfdxConfig[key]) delete config[key]; - } - - return Object.assign(config, sfdxConfig); - } +/** + * convert from "new" to "old" config names + * - For example, `target-org` will be renamed to `defaultusername`. + */ +const translateToSfdx = (sfContents: ConfigProperties): ConfigProperties => + Object.fromEntries( + Object.entries(sfContents).map(([key, value]) => { + const propConfig = Config.getAllowedProperties().find((c) => c.newKey === key) ?? ({} as ConfigPropertyMeta); + return propConfig.deprecated && propConfig.newKey ? [propConfig.key, value] : [key, value]; + }) + ); - public async write(config = this.config.toObject()): Promise { - try { - const translated = this.translate(config as ConfigProperties, 'toOld'); - const sfdxPath = this.getSfdxPath(); - await fs.promises.mkdir(pathDirname(sfdxPath), { recursive: true }); - await fs.promises.writeFile(sfdxPath, JSON.stringify(translated, null, 2)); - } catch (error) { - /* Do nothing */ - } - } +/** + * convert from "old" to "new" config names + * - For example, `defaultusername` will be renamed to `target-org` + */ +const translateToSf = (sfdxContents: ConfigProperties, SfConfig: Config): ConfigProperties => + Object.fromEntries( + Object.entries(sfdxContents).map(([key, value]) => { + const propConfig = SfConfig.getPropertyConfig(key); + return propConfig.deprecated && propConfig.newKey ? [propConfig.newKey, value] : [key, value]; + }) + ); + +/** given the ConfigFile options, calculate the full path where the config file goes */ +const buildSfdxPath = (options: ConfigFile.Options): string => { + // Don't let users store config files in homedir without being in the state folder. + const configRootFolder = options.rootFolder ?? ConfigFile.resolveRootFolderSync(!!options.isGlobal); + const rootWithState = + options.isGlobal === true || options.isState === true + ? pathJoin(configRootFolder, Global.SFDX_STATE_FOLDER) + : configRootFolder; + + return pathJoin(rootWithState, SFDX_CONFIG_FILE_NAME); +}; - private readSync(): ConfigProperties { - try { - const contents = parseJsonMap(fs.readFileSync(this.getSfdxPath(), 'utf8')); - return this.translate(contents, 'toNew'); - } catch (error) { - /* Do nothing */ - return {}; - } +/** + * writes (in an unsafe way) the configuration file to the sfdx file location. + * Make sure you call ConfigFile.write and getContents so that the contents passed here are not cross-saving something + */ +const writeToSfdx = async (path: string, contents: ConfigProperties): Promise => { + try { + const translated = translateToSfdx(contents); + await fs.promises.mkdir(pathDirname(path), { recursive: true }); + await fs.promises.writeFile(path, JSON.stringify(translated, null, 2)); + } catch (e) { + const logger = Logger.childFromRoot('core:config:writeToSfdx'); + logger.debug(`Error writing to sfdx config file at ${path}: ${e instanceof Error ? e.message : ''}`); } - - private getSfdxPath(): string { - if (!this.sfdxPath) { - const stateFolder = Global.SFDX_STATE_FOLDER; - const fileName = SFDX_CONFIG_FILE_NAME; - - // Don't let users store config files in homedir without being in the state folder. - let configRootFolder = this.options.rootFolder - ? this.options.rootFolder - : ConfigFile.resolveRootFolderSync(!!this.options.isGlobal); - - if (this.options.isGlobal === true || this.options.isState === true) { - configRootFolder = pathJoin(configRootFolder, stateFolder); - } - - this.sfdxPath = pathJoin(configRootFolder, fileName); - } - return this.sfdxPath; +}; + +/** turn the sfdx config file into a LWWState based on its contents and its timestamp */ +const stateFromSfdxFileSync = (path: string, config: Config): LWWState => { + try { + const fileContents = fs.readFileSync(path, 'utf8'); + const mtimeNs = fs.statSync(path, { bigint: true }).mtimeNs; + const translatedContents = translateToSf(parseJsonMap(fileContents, path), config); + // get the file timestamp + return stateFromContents(translatedContents, mtimeNs); + } catch (e) { + const logger = Logger.childFromRoot('core:config:stateFromSfdxFileSync'); + logger.debug(`Error reading state from sfdx config file at ${path}: ${e instanceof Error ? e.message : ''}`); + return {}; } +}; - /** - * If toNew is specified: migrate all deprecated configs with a newKey to the newKey. - * - For example, defaultusername will be renamed to target-org. - * - * If toOld is specified: migrate all deprecated configs back to their original key. - * - For example, target-org will be renamed to defaultusername. - */ - private translate(contents: ConfigProperties, direction: 'toNew' | 'toOld'): ConfigProperties { - const translated = {} as ConfigProperties; - for (const [key, value] of Object.entries(contents)) { - const propConfig = - direction === 'toNew' - ? this.config.getPropertyConfig(key) - : Config.getAllowedProperties().find((c) => c.newKey === key) ?? ({} as ConfigPropertyMeta); - if (propConfig.deprecated && propConfig.newKey) { - const normalizedKey = direction === 'toNew' ? propConfig.newKey : propConfig.key; - translated[normalizedKey] = value; - } else { - translated[key] = value; - } - } - return translated; - } -} +const isBooleanOrBooleanString = (value: unknown): boolean => + (typeof value === 'string' && ['true', 'false'].includes(value)) || typeof value === 'boolean'; diff --git a/src/config/configAggregator.ts b/src/config/configAggregator.ts index 3fdffdf8d2..03c75cb2ff 100644 --- a/src/config/configAggregator.ts +++ b/src/config/configAggregator.ts @@ -8,8 +8,9 @@ import { AsyncOptionalCreatable, merge, sortBy } from '@salesforce/kit'; import { AnyJson, Dictionary, isArray, isJsonMap, JsonMap, Optional } from '@salesforce/ts-types'; import { Messages } from '../messages'; +import { Lifecycle } from '../lifecycleEvents'; import { EnvVars } from './envVars'; -import { Config, ConfigPropertyMeta, SfdxPropertyKeys, SFDX_ALLOWED_PROPERTIES } from './config'; +import { Config, ConfigPropertyMeta } from './config'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'config'); @@ -79,8 +80,8 @@ export class ConfigAggregator extends AsyncOptionalCreatable = {}; /** @@ -165,13 +166,22 @@ export class ConfigAggregator extends AsyncOptionalCreatable(key: string): Optional { - if (this.getAllowedProperties().some((element) => key === element.key)) { + const match = this.getAllowedProperties().find((element) => key === element.key); + if (match?.deprecated && match.newKey) { + void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, match.newKey])); + const newKeyMatch = this.getAllowedProperties().find((element) => match.newKey === element.key); + if (newKeyMatch) { + return (this.getConfig()[newKeyMatch.key] as T) ?? (this.getConfig()[match.key] as T); + } + } + if (this.getAllowedProperties().some((element) => key === element.key || key === element.newKey)) { return this.getConfig()[key] as T; } else { throw messages.createError('unknownConfigKey', [key]); @@ -180,6 +190,7 @@ export class ConfigAggregator extends AsyncOptionalCreatable key === element.key); if (match) { + if (match.deprecated && match.newKey) { + void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedConfigKey', [key, match.newKey])); + const newKeyMatch = this.getAllowedProperties().find((element) => key === element.newKey); + if (newKeyMatch) { + return newKeyMatch ?? match; + } + } return match; - } else { - throw messages.createError('unknownConfigKey', [key]); } + const matchFromNewKey = this.getAllowedProperties().find((element) => key === element.newKey); + if (matchFromNewKey) { + return matchFromNewKey; + } + throw messages.createError('unknownConfigKey', [key]); } /** * Get a resolved config property. + * If a property is deprecated, it will try to use the the new key, if there is a config there. * * @param key The key of the property. * @param throwOnDeprecation True, if you want an error throw when reading a deprecated config @@ -203,15 +225,18 @@ export class ConfigAggregator extends AsyncOptionalCreatable location === ConfigAggregator.Location.LOCAL, isGlobal: () => location === ConfigAggregator.Location.GLOBAL, isEnvVar: () => location === ConfigAggregator.Location.ENVIRONMENT, @@ -230,6 +255,7 @@ export class ConfigAggregator extends AsyncOptionalCreatable { + // envs populate old and new automatically if (this.envVars[key] != null) { return ConfigAggregator.Location.ENVIRONMENT; } @@ -256,6 +282,7 @@ export class ConfigAggregator extends AsyncOptionalCreatable { + // TODO: make EnvVars always prefer the "new" regardless of CLI if (this.envVars[key] != null) { return `$${EnvVars.propertyToEnvName(key)}`; } @@ -280,7 +307,7 @@ export class ConfigAggregator extends AsyncOptionalCreatable this.getAllowedProperties().some((element) => key === element.key)) + .filter((key) => this.getAllowedProperties().some((element) => key === element.key || key === element.newKey)) .map((key) => this.getInfo(key)) .filter((info): info is ConfigInfo => !!info); return sortBy(infos, 'key'); @@ -307,6 +334,19 @@ export class ConfigAggregator extends AsyncOptionalCreatable { + const hasLocalWrites = this.localConfig + ?.getKeysByValue(key) + .map((k) => this.localConfig?.unset(k)) + .some(Boolean); + if (hasLocalWrites) await this.localConfig?.write(); + const hasGlobalWrites = this.globalConfig + ?.getKeysByValue(key) + .map((k) => this.globalConfig?.unset(k)) + .some(Boolean); + if (hasGlobalWrites) await this.globalConfig?.write(); + } + /** * Get the config properties that are environment variables. */ @@ -385,8 +425,7 @@ export class ConfigAggregator extends AsyncOptionalCreatable merge(acc, el), json); - return reduced; + return configs.filter(isJsonMap).reduce((acc: JsonMap, el: AnyJson) => merge(acc, el), json); } } @@ -415,84 +454,3 @@ export namespace ConfigAggregator { customConfigMeta?: ConfigPropertyMeta[]; }; } - -/** - * A ConfigAggregator that will work with deprecated config vars (e.g. defaultusername, apiVersion). - * We do NOT recommend using this class unless you absolutely have to. - * - * @deprecated - */ -export class SfdxConfigAggregator extends ConfigAggregator { - protected static instance: AsyncOptionalCreatable; - protected static encrypted = true; - - public static async create>( - this: new (options?: ConfigAggregator.Options) => T, - options: ConfigAggregator.Options = {} - ): Promise { - const customConfigMeta = options.customConfigMeta ?? []; - // org-metadata-rest-deploy has been moved to plugin-deploy-retrieve but we need to have a placeholder - // for it here since sfdx needs to know how to set the deprecated restDeploy config var. - const restDeploy = SFDX_ALLOWED_PROPERTIES.find((p) => p.key === SfdxPropertyKeys.REST_DEPLOY); - const orgRestDeploy = Object.assign({}, restDeploy, { key: 'org-metadata-rest-deploy', deprecated: false }); - options.customConfigMeta = [...customConfigMeta, orgRestDeploy]; - - let config = SfdxConfigAggregator.instance as SfdxConfigAggregator; - if (!config) { - config = SfdxConfigAggregator.instance = new this(options) as unknown as SfdxConfigAggregator; - await config.init(); - } - if (SfdxConfigAggregator.encrypted) { - await config.loadProperties(); - } - - if (options?.customConfigMeta) { - Config.addAllowedProperties(options.customConfigMeta); - } - return SfdxConfigAggregator.instance as T; - } - - public getPropertyMeta(key: string): ConfigPropertyMeta { - const match = this.getAllowedProperties().find((element) => key === element.key); - if (match?.deprecated && match?.newKey) { - return this.getPropertyMeta(match.newKey); - } else if (match) { - return match; - } else { - throw messages.createError('unknownConfigKey', [key]); - } - } - - public getPropertyValue(key: string): Optional { - return super.getPropertyValue(this.translate(key)); - } - - public getInfo(key: string): ConfigInfo { - const info = super.getInfo(this.translate(key)); - info.key = this.translate(info.key, 'toOld'); - return info; - } - - public getLocation(key: string): Optional { - return super.getLocation(this.translate(key)); - } - - public getPath(key: string): Optional { - return super.getPath(this.translate(key)); - } - - public getConfigInfo(): ConfigInfo[] { - return super.getConfigInfo().map((c) => { - c.key = this.translate(c.key, 'toOld'); - return c; - }); - } - - private translate(key: string, direction: 'toNew' | 'toOld' = 'toNew'): string { - const propConfig = - direction === 'toNew' - ? this.getPropertyMeta(key) - : Config.getAllowedProperties().find((c) => c.newKey === key) ?? ({} as ConfigPropertyMeta); - return propConfig.key || key; - } -} diff --git a/src/config/configFile.ts b/src/config/configFile.ts index 52d588a7fb..97b21b707d 100644 --- a/src/config/configFile.ts +++ b/src/config/configFile.ts @@ -5,17 +5,19 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as fs from 'fs'; -import { constants as fsConstants, Stats as fsStats } from 'fs'; -import { homedir as osHomedir } from 'os'; -import { dirname as pathDirname, join as pathJoin } from 'path'; -import { isPlainObject } from '@salesforce/ts-types'; +import * as fs from 'node:fs'; +import { constants as fsConstants, Stats as fsStats } from 'node:fs'; +import { homedir as osHomedir } from 'node:os'; +import { join as pathJoin } from 'node:path'; import { parseJsonMap } from '@salesforce/kit'; import { Global } from '../global'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { resolveProjectPath, resolveProjectPathSync } from '../util/internal'; -import { BaseConfigStore, ConfigContents } from './configStore'; +import { lockInit, lockInitSync } from '../util/fileLocking'; +import { BaseConfigStore } from './configStore'; +import { ConfigContents } from './configStackTypes'; +import { stateFromContents } from './lwwMap'; /** * Represents a json config file used to manage settings and state. Global config @@ -160,23 +162,30 @@ export class ConfigFile< // Only need to read config files once. They are kept up to date // internally and updated persistently via write(). if (!this.hasRead || force) { - this.logger.info(`Reading config file: ${this.getPath()}`); - const obj = parseJsonMap(await fs.promises.readFile(this.getPath(), 'utf8')); - this.setContentsFromObject(obj); + this.logger.debug( + `Reading config file: ${this.getPath()} because ${ + !this.hasRead ? 'hasRead is false' : 'force parameter is true' + }` + ); + + const obj = parseJsonMap

(await fs.promises.readFile(this.getPath(), 'utf8'), this.getPath()); + this.setContentsFromFileContents(obj, (await fs.promises.stat(this.getPath(), { bigint: true })).mtimeNs); } + // Necessarily set this even when an error happens to avoid infinite re-reading. + // To attempt another read, pass `force=true`. + this.hasRead = true; return this.getContents(); } catch (err) { + this.hasRead = true; if ((err as SfError).code === 'ENOENT') { if (!throwOnNotFound) { - this.setContents(); + this.setContentsFromFileContents({} as P); return this.getContents(); } } - throw err; - } finally { // Necessarily set this even when an error happens to avoid infinite re-reading. // To attempt another read, pass `force=true`. - this.hasRead = true; + throw err; } } @@ -194,15 +203,19 @@ export class ConfigFile< // Only need to read config files once. They are kept up to date // internally and updated persistently via write(). if (!this.hasRead || force) { - this.logger.info(`Reading config file: ${this.getPath()}`); - const obj = parseJsonMap(fs.readFileSync(this.getPath(), 'utf8')); - this.setContentsFromObject(obj); + this.logger.debug(`Reading config file: ${this.getPath()}`); + const obj = parseJsonMap

(fs.readFileSync(this.getPath(), 'utf8')); + this.setContentsFromFileContents(obj, fs.statSync(this.getPath(), { bigint: true }).mtimeNs); } + // Necessarily set this even when an error happens to avoid infinite re-reading. + // To attempt another read, pass `force=true`. + this.hasRead = true; return this.getContents(); } catch (err) { + this.hasRead = true; if ((err as SfError).code === 'ENOENT') { if (!throwOnNotFound) { - this.setContents(); + this.setContentsFromFileContents({} as P); return this.getContents(); } } @@ -220,19 +233,19 @@ export class ConfigFile< * * @param newContents The new contents of the file. */ - public async write(newContents?: P): Promise

{ - if (newContents) { - this.setContents(newContents); - } + public async write(): Promise

{ + const lockResponse = await lockInit(this.getPath()); + // lock the file. Returns an unlock function to call when done. try { - await fs.promises.mkdir(pathDirname(this.getPath()), { recursive: true }); + const fileTimestamp = (await fs.promises.stat(this.getPath(), { bigint: true })).mtimeNs; + const fileContents = parseJsonMap

(await fs.promises.readFile(this.getPath(), 'utf8'), this.getPath()); + this.logAndMergeContents(fileTimestamp, fileContents); } catch (err) { - throw SfError.wrap(err as Error); + this.handleWriteError(err); } - - this.logger.info(`Writing to config file: ${this.getPath()}`); - await fs.promises.writeFile(this.getPath(), JSON.stringify(this.toObject(), null, 2)); + // write the merged LWWMap to file + await lockResponse.writeAndUnlock(JSON.stringify(this.getContents(), null, 2)); return this.getContents(); } @@ -243,19 +256,19 @@ export class ConfigFile< * * @param newContents The new contents of the file. */ - public writeSync(newContents?: P): P { - if (isPlainObject(newContents)) { - this.setContents(newContents); - } - + public writeSync(): P { + const lockResponse = lockInitSync(this.getPath()); try { - fs.mkdirSync(pathDirname(this.getPath()), { recursive: true }); + // get the file modstamp. Do this after the lock acquisition in case the file is being written to. + const fileTimestamp = fs.statSync(this.getPath(), { bigint: true }).mtimeNs; + const fileContents = parseJsonMap

(fs.readFileSync(this.getPath(), 'utf8'), this.getPath()); + this.logAndMergeContents(fileTimestamp, fileContents); } catch (err) { - throw SfError.wrap(err as Error); + this.handleWriteError(err); } - this.logger.info(`Writing to config file: ${this.getPath()}`); - fs.writeFileSync(this.getPath(), JSON.stringify(this.toObject(), null, 2)); + // write the merged LWWMap to file + lockResponse.writeAndUnlock(JSON.stringify(this.getContents(), null, 2)); return this.getContents(); } @@ -366,6 +379,27 @@ export class ConfigFile< // Read the file, which also sets the path and throws any errors around project paths. await this.read(this.options.throwOnNotFound); } + + // method exists to share code between write() and writeSync() + private logAndMergeContents(fileTimestamp: bigint, fileContents: P): void { + this.logger.debug(`Existing file contents on filesystem (timestamp: ${fileTimestamp.toString()}`, fileContents); + this.logger.debug('Contents in configFile in-memory', this.getContents()); + + // read the file contents into a LWWMap using the modstamp + const stateFromFile = stateFromContents

(fileContents, fileTimestamp); + // merge the new contents into the in-memory LWWMap + this.contents.merge(stateFromFile); + this.logger.debug('Result from merge', this.getContents()); + } + + // shared error handling for both write() and writeSync() + private handleWriteError(err: unknown): void { + if (err instanceof Error && err.message.includes('ENOENT')) { + this.logger.debug(`No file found at ${this.getPath()}. Write will create it.`); + } else { + throw err; + } + } } export namespace ConfigFile { diff --git a/src/config/configGroup.ts b/src/config/configGroup.ts deleted file mode 100644 index 6f153eb6a3..0000000000 --- a/src/config/configGroup.ts +++ /dev/null @@ -1,252 +0,0 @@ -/* - * Copyright (c) 2020, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -import { definiteEntriesOf, definiteValuesOf, Dictionary, getJsonMap, JsonMap, Optional } from '@salesforce/ts-types'; -import { SfError } from '../sfError'; -import { ConfigFile } from './configFile'; -import { ConfigContents, ConfigEntry, ConfigValue } from './configStore'; - -/** - * A config file that stores config values in groups. e.g. to store different config - * values for different commands, without having manually manipulate the config. - * - * **Note:** All config methods are overwritten to use the {@link ConfigGroup.setDefaultGroup}. - * - * ``` - * class MyPluginConfig extends ConfigGroup { - * public static getFileName(): string { - * return 'myPluginConfigFilename.json'; - * } - * } - * const myConfig = await MyPluginConfig.create(ConfigGroup.getOptions('all')); - * myConfig.setDefaultGroup('myCommand'); // Can be set in your command's init. - * myConfig.set('mykey', 'myvalue'); // Sets 'myKey' for the 'myCommand' group. - * myConfig.setInGroup('myKey', 'myvalue', 'all'); // Manually set in another group. - * await myConfig.write(); - * ``` - */ -export class ConfigGroup extends ConfigFile { - protected defaultGroup = 'default'; - /** - * Get ConfigGroup specific options, such as the default group. - * - * @param defaultGroup The default group to use when creating the config. - * @param filename The filename of the config file. Uses the static {@link getFileName} by default. - */ - public static getOptions(defaultGroup: string, filename?: string): ConfigGroup.Options { - const options: ConfigFile.Options = ConfigFile.getDefaultOptions(true, filename); - const configGroupOptions: ConfigGroup.Options = { defaultGroup }; - Object.assign(configGroupOptions, options); - return configGroupOptions; - } - - /** - * Sets the default group for all {@link BaseConfigStore} methods to use. - * **Throws** *{@link SfError}{ name: 'MissingGroupName' }* The group parameter is null or undefined. - * - * @param group The group. - */ - public setDefaultGroup(group: string): void { - if (!group) { - throw new SfError('null or undefined group', 'MissingGroupName'); - } - - this.defaultGroup = group; - } - - /** - * Set a group of entries in a bulk save. Returns The new properties that were saved. - * - * @param newEntries An object representing the aliases to set. - * @param group The group the property belongs to. - */ - public async updateValues(newEntries: Dictionary, group?: string): Promise> { - // Make sure the contents are loaded - await this.read(); - Object.entries(newEntries).forEach(([key, val]) => this.setInGroup(key, val, group ?? this.defaultGroup)); - await this.write(); - return newEntries; - } - - /** - * Set a value on a group. Returns the promise resolved when the value is set. - * - * @param key The key. - * @param value The value. - * @param group The group. - */ - public async updateValue(key: string, value: ConfigValue, group?: string): Promise { - // Make sure the content is loaded - await this.read(); - this.setInGroup(key, value, group ?? this.defaultGroup); - // Then save it - await this.write(); - } - - /** - * Gets an array of key value pairs. - */ - public entries(): ConfigEntry[] { - const group = this.getGroup(); - if (group) { - return definiteEntriesOf(group); - } - return []; - } - - /** - * Returns a specified element from ConfigGroup. Returns the associated value. - * - * @param key The key. - */ - public get(key: string): Optional { - return this.getInGroup(key); - } - - /** - * Returns a boolean if an element with the specified key exists in the default group. - * - * @param {string} key The key. - */ - public has(key: string): boolean { - const group = this.getGroup(); - return !!group && super.has(this.defaultGroup) && !!group[key]; - } - - /** - * Returns an array of the keys from the default group. - */ - public keys(): string[] { - return Object.keys(this.getGroup(this.defaultGroup) ?? {}); - } - - /** - * Returns an array of the values from the default group. - */ - public values(): ConfigValue[] { - return definiteValuesOf(this.getGroup(this.defaultGroup) ?? {}); - } - - /** - * Add or updates an element with the specified key in the default group. - * - * @param key The key. - * @param value The value. - */ - public set(key: string, value: ConfigValue): ConfigContents { - return this.setInGroup(key, value, this.defaultGroup); - } - - /** - * Removes an element with the specified key from the default group. Returns `true` if the item was deleted. - * - * @param key The key. - */ - public unset(key: string): boolean { - const groupContents = this.getGroup(this.defaultGroup); - if (groupContents) { - delete groupContents[key]; - return true; - } - return false; - } - - /** - * Remove all key value pairs from the default group. - */ - public clear(): void { - delete this.getContents()[this.defaultGroup]; - } - - /** - * Get all config contents for a group. - * - * @param {string} [group = 'default'] The group. - */ - public getGroup(group = this.defaultGroup): Optional { - return getJsonMap(this.getContents(), group) ?? undefined; - } - - /** - * Returns the value associated to the key and group, or undefined if there is none. - * - * @param key The key. - * @param group The group. Defaults to the default group. - */ - public getInGroup(key: string, group?: string): Optional { - const groupContents = this.getGroup(group); - if (groupContents) { - return groupContents[key]; - } - } - - /** - * Convert the config object to a json object. - */ - public toObject(): JsonMap { - return this.getContents(); - } - - /** - * Convert an object to a {@link ConfigContents} and set it as the config contents. - * - * @param {object} obj The object. - */ - // eslint-disable-next-line @typescript-eslint/ban-types - public setContentsFromObject(obj: U): void { - const contents = new Map(Object.entries(obj)); - Array.from(contents.entries()).forEach(([groupKey, groupContents]) => { - if (groupContents) { - Object.entries(groupContents).forEach(([contentKey, contentValue]) => { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - this.setInGroup(contentKey, contentValue, groupKey); - }); - } - }); - } - - /** - * Sets the value for the key and group in the config object. - * - * @param key The key. - * @param value The value. - * @param group The group. Uses the default group if not specified. - */ - public setInGroup(key: string, value?: ConfigValue, group?: string): ConfigContents { - group = group ?? this.defaultGroup; - - if (!super.has(group)) { - super.set(group, {}); - } - const content = this.getGroup(group) ?? {}; - this.setMethod(content, key, value); - - return content; - } - - /** - * Initialize the asynchronous dependencies. - */ - public async init(): Promise { - await super.init(); - if (this.options.defaultGroup) { - this.setDefaultGroup(this.options.defaultGroup); - } - } -} - -export namespace ConfigGroup { - /** - * Options when creating the config file. - */ - export interface Options extends ConfigFile.Options { - /** - * The default group for properties to go into. - */ - defaultGroup?: string; - } -} diff --git a/src/config/configStackTypes.ts b/src/config/configStackTypes.ts new file mode 100644 index 0000000000..420c76f29d --- /dev/null +++ b/src/config/configStackTypes.ts @@ -0,0 +1,24 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { Dictionary, AnyJson } from '@salesforce/ts-types'; + +export type Key

= Extract; +/** + * The allowed types stored in a config store. + */ + +export type ConfigValue = AnyJson; +/** + * The type of entries in a config store defined by the key and value type of {@link ConfigContents}. + */ + +export type ConfigEntry = [string, ConfigValue]; +/** + * The type of content a config stores. + */ + +export type ConfigContents = Dictionary; diff --git a/src/config/configStore.ts b/src/config/configStore.ts index 52b4eb348a..70a9913f93 100644 --- a/src/config/configStore.ts +++ b/src/config/configStore.ts @@ -5,38 +5,14 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { AsyncOptionalCreatable, cloneJson, set } from '@salesforce/kit'; -import { isPlainObject } from '@salesforce/ts-types'; -import { - AnyJson, - definiteEntriesOf, - definiteValuesOf, - Dictionary, - get, - isJsonMap, - isString, - JsonMap, - Optional, -} from '@salesforce/ts-types'; +import { AsyncOptionalCreatable } from '@salesforce/kit'; +import { entriesOf, isPlainObject } from '@salesforce/ts-types'; +import { definiteEntriesOf, definiteValuesOf, isJsonMap, isString, JsonMap, Optional } from '@salesforce/ts-types'; import { Crypto } from '../crypto/crypto'; import { SfError } from '../sfError'; - -/** - * The allowed types stored in a config store. - */ -export type ConfigValue = AnyJson; - -/** - * The type of entries in a config store defined by the key and value type of {@link ConfigContents}. - */ -export type ConfigEntry = [string, ConfigValue]; - -/** - * The type of content a config stores. - */ -export type ConfigContents = Dictionary; - -export type Key

= Extract; +import { nowBigInt } from '../util/time'; +import { LWWMap, stateFromContents } from './lwwMap'; +import { ConfigContents, ConfigEntry, ConfigValue, Key } from './configStackTypes'; /** * An interface for a config object with a persistent store. @@ -44,7 +20,9 @@ export type Key

= Extract; export interface ConfigStore

{ // Map manipulation methods entries(): ConfigEntry[]; + // NEXT_RELEASE: update types to specify return can be P[K] | undefined get>(key: K, decrypt: boolean): P[K]; + // NEXT_RELEASE: update types to specify return can be T | undefined get(key: string, decrypt: boolean): T; getKeysByValue(value: ConfigValue): Array>; has(key: string): boolean; @@ -59,11 +37,9 @@ export interface ConfigStore

{ values(): ConfigValue[]; forEach(actionFn: (key: string, value: ConfigValue) => void): void; - awaitEach(actionFn: (key: string, value: ConfigValue) => Promise): Promise; // Content methods getContents(): P; - setContents(contents?: P): void; } /** @@ -85,7 +61,7 @@ export abstract class BaseConfigStore< protected crypto?: Crypto; // Initialized in setContents - private contents!: P; + protected contents = new LWWMap

(); private statics = this.constructor as typeof BaseConfigStore; /** @@ -104,30 +80,34 @@ export abstract class BaseConfigStore< * Returns an array of {@link ConfigEntry} for each element in the config. */ public entries(): ConfigEntry[] { - return definiteEntriesOf(this.contents); + return definiteEntriesOf(this.contents.value ?? {}); } /** * Returns the value associated to the key, or undefined if there is none. * - * @param key The key. Supports query key like `a.b[0]`. + * @param key The key (object property) * @param decrypt If it is an encrypted key, decrypt the value. * If the value is an object, a clone will be returned. */ + // NEXT_RELEASE: update types to specify return can be | undefined public get>(key: K, decrypt?: boolean): P[K]; + // NEXT_RELEASE: update types to specify return can be | undefined + // NEXT_RELEASE: consider getting rid of ConfigValue and letting it just use the Key<> approach public get(key: string, decrypt?: boolean): V; + // NEXT_RELEASE: update types to specify return can be | undefined public get>(key: K | string, decrypt = false): P[K] | ConfigValue { - const k = key as string; - let value = this.getMethod(this.contents, k); + const rawValue = this.contents.get(key as K); if (this.hasEncryption() && decrypt) { - if (isJsonMap(value)) { - value = this.recursiveDecrypt(cloneJson(value), k); - } else if (this.isCryptoKey(k)) { - value = this.decrypt(value); + if (isJsonMap(rawValue)) { + return this.recursiveDecrypt(structuredClone(rawValue), key); + } else if (this.isCryptoKey(key)) { + return this.decrypt(rawValue) as P[K] | ConfigValue; } } - return value as P[K]; + // NEXT_RELEASE: update types to specify return can be | undefined + return rawValue as P[K] | ConfigValue; } /** @@ -144,29 +124,26 @@ export abstract class BaseConfigStore< /** * Returns a boolean asserting whether a value has been associated to the key in the config object or not. * - * @param key The key. Supports query key like `a.b[0]`. */ public has(key: string): boolean { - return !!this.getMethod(this.contents, key); + return this.contents.has(key) ?? false; } /** * Returns an array that contains the keys for each element in the config object. */ public keys(): Array> { - return Object.keys(this.contents) as Array>; + return Object.keys(this.contents.value ?? {}) as Array>; } /** * Sets the value for the key in the config object. This will override the existing value. * To do a partial update, use {@link BaseConfigStore.update}. * - * @param key The key. Supports query key like `a.b[0]`. + * @param key The key. * @param value The value. */ - public set>(key: K, value: P[K]): void; - public set(key: string, value: V): void; - public set>(key: K | string, value: P[K] | ConfigValue): void { + public set>(key: K, value: P[K]): void { if (this.hasEncryption()) { if (isJsonMap(value)) { value = this.recursiveEncrypt(value, key as string) as P[K]; @@ -174,40 +151,40 @@ export abstract class BaseConfigStore< value = this.encrypt(value) as P[K]; } } - this.setMethod(this.contents, key as string, value); + // set(key, undefined) means unset + if (value === undefined) { + this.unset(key); + } else { + this.contents.set(key, value); + } } /** * Updates the value for the key in the config object. If the value is an object, it * will be merged with the existing object. * - * @param key The key. Supports query key like `a.b[0]`. + * @param key The key. * @param value The value. */ - public update>(key: K, value: Partial): void; - public update(key: string, value: Partial): void; - public update>(key: K | string, value: Partial | Partial): void { + public update>(key: K, value: Partial): void { const existingValue = this.get(key, true); if (isPlainObject(existingValue) && isPlainObject(value)) { - value = Object.assign({}, existingValue, value); + const mergedValue = Object.assign({}, existingValue, value); + this.set(key, mergedValue as P[K]); + } else { + this.set(key, value as P[K]); } - this.set(key, value); } /** * Returns `true` if an element in the config object existed and has been removed, or `false` if the element does not * exist. {@link BaseConfigStore.has} will return false afterwards. * - * @param key The key. Supports query key like `a.b[0]`. + * @param key The key */ - public unset(key: string): boolean { + public unset>(key: K): boolean { if (this.has(key)) { - if (this.contents[key]) { - delete this.contents[key]; - } else { - // It is a query key, so just set it to undefined - this.setMethod(this.contents, key, undefined); - } + this.contents.delete(key); return true; } return false; @@ -217,24 +194,24 @@ export abstract class BaseConfigStore< * Returns `true` if all elements in the config object existed and have been removed, or `false` if all the elements * do not exist (some may have been removed). {@link BaseConfigStore.has(key)} will return false afterwards. * - * @param keys The keys. Supports query keys like `a.b[0]`. + * @param keys The keys */ - public unsetAll(keys: string[]): boolean { - return keys.reduce((val: boolean, key) => val && this.unset(key), true); + public unsetAll(keys: Array>): boolean { + return keys.map((key) => this.unset(key)).every(Boolean); } /** * Removes all key/value pairs from the config object. */ public clear(): void { - this.contents = {} as P; + this.keys().map((key) => this.unset(key)); } /** * Returns an array that contains the values for each element in the config object. */ public values(): ConfigValue[] { - return definiteValuesOf(this.contents); + return definiteValuesOf(this.contents.value ?? {}); } /** @@ -247,26 +224,11 @@ export abstract class BaseConfigStore< * @param decrypt: decrypt all data in the config. A clone of the data will be returned. * */ - public getContents(decrypt = false): P { - if (!this.contents) { - this.setContents(); - } + public getContents(decrypt = false): Readonly

{ if (this.hasEncryption() && decrypt) { - return this.recursiveDecrypt(cloneJson(this.contents)) as P; + return this.recursiveDecrypt(structuredClone(this.contents?.value ?? {})) as P; } - return this.contents; - } - - /** - * Sets the entire config contents. - * - * @param contents The contents. - */ - public setContents(contents: P = {} as P): void { - if (this.hasEncryption()) { - contents = this.recursiveEncrypt(contents); - } - this.contents = contents; + return this.contents?.value ?? ({} as P); } /** @@ -275,26 +237,7 @@ export abstract class BaseConfigStore< * @param {function} actionFn The function `(key: string, value: ConfigValue) => void` to be called for each element. */ public forEach(actionFn: (key: string, value: ConfigValue) => void): void { - const entries = this.entries(); - for (const entry of entries) { - actionFn(entry[0], entry[1]); - } - } - - /** - * Asynchronously invokes `actionFn` once for each key-value pair present in the config object. - * - * @param {function} actionFn The function `(key: string, value: ConfigValue) => Promise` to be called for - * each element. - * @returns {Promise} - */ - public async awaitEach(actionFn: (key: string, value: ConfigValue) => Promise): Promise { - const entries = this.entries(); - for (const entry of entries) { - // prevent ConfigFile collision bug - // eslint-disable-next-line no-await-in-loop - await actionFn(entry[0], entry[1]); - } + this.entries().map((entry) => actionFn(entry[0], entry[1])); } /** @@ -302,7 +245,7 @@ export abstract class BaseConfigStore< * Same as calling {@link ConfigStore.getContents} */ public toObject(): JsonMap { - return this.contents; + return this.contents.value ?? {}; } /** @@ -310,15 +253,39 @@ export abstract class BaseConfigStore< * * @param obj The object. */ - public setContentsFromObject(obj: U): void { - this.contents = (this.hasEncryption() ? this.recursiveEncrypt(obj) : {}) as P; - Object.entries(obj).forEach(([key, value]) => { - this.setMethod(this.contents, key, value); + public setContentsFromObject(obj: P): void { + const objForWrite = this.hasEncryption() ? this.recursiveEncrypt(obj) : obj; + entriesOf(objForWrite).map(([key, value]) => { + this.set(key, value); + }); + } + + /** + * Keep ConfigFile concurrency-friendly. + * Avoid using this unless you're reading the file for the first time + * and guaranteed to no be cross-saving existing contents + * */ + protected setContentsFromFileContents(contents: P, timestamp?: bigint): void { + const state = stateFromContents(contents, timestamp ?? nowBigInt()); + this.contents = new LWWMap

(state); + } + + /** + * Sets the entire config contents. + * + * @param contents The contents. + */ + protected setContents(contents: P = {} as P): void { + if (this.hasEncryption()) { + contents = this.recursiveEncrypt(contents); + } + entriesOf(contents).map(([key, value]) => { + this.contents.set(key, value); }); } protected getEncryptedKeys(): Array { - return [...(this.options?.encryptedKeys ?? []), ...(this.statics?.encryptedKeys || [])]; + return [...(this.options?.encryptedKeys ?? []), ...(this.statics?.encryptedKeys ?? [])]; } /** @@ -330,21 +297,6 @@ export abstract class BaseConfigStore< return this.getEncryptedKeys().length > 0; } - // Allows extended classes the ability to override the set method. i.e. maybe they want - // nested object set from kit. - // eslint-disable-next-line class-methods-use-this - protected setMethod(contents: ConfigContents, key: string, value?: ConfigValue): void { - set(contents, key, value); - } - - // Allows extended classes the ability to override the get method. i.e. maybe they want - // nested object get from ts-types. - // NOTE: Key must stay string to be reliably overwritten. - // eslint-disable-next-line class-methods-use-this - protected getMethod(contents: ConfigContents, key: string): Optional { - return get(contents, key) as ConfigValue; - } - // eslint-disable-next-line class-methods-use-this protected initialContents(): P { return {} as P; @@ -411,18 +363,18 @@ export abstract class BaseConfigStore< if (!this.crypto) throw new SfError('crypto is not initialized', 'CryptoNotInitializedError'); if (!isString(value)) throw new SfError( - `can only encrypt strings but found: ${typeof value} : ${value.toString()}`, + `can only encrypt strings but found: ${typeof value} : ${JSON.stringify(value)}`, 'InvalidCryptoValueError' ); return this.crypto.isEncrypted(value) ? value : this.crypto.encrypt(value); } - protected decrypt(value: unknown): Optional { + protected decrypt(value: unknown): string | undefined { if (!value) return; if (!this.crypto) throw new SfError('crypto is not initialized', 'CryptoNotInitializedError'); if (!isString(value)) throw new SfError( - `can only encrypt strings but found: ${typeof value} : ${value.toString()}`, + `can only encrypt strings but found: ${typeof value} : ${JSON.stringify(value)}`, 'InvalidCryptoValueError' ); return this.crypto.isEncrypted(value) ? this.crypto.decrypt(value) : value; diff --git a/src/config/envVars.ts b/src/config/envVars.ts index ca5b5dd3b7..a6a2a5bdec 100644 --- a/src/config/envVars.ts +++ b/src/config/envVars.ts @@ -4,15 +4,16 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { join as pathJoin } from 'path'; +import { join as pathJoin } from 'node:path'; import { Dictionary, Nullable } from '@salesforce/ts-types'; import { camelCase, snakeCase } from 'change-case'; import { Env } from '@salesforce/kit'; import { Messages } from '../messages'; -import { Global } from '../global'; +import { Lifecycle } from '../lifecycleEvents'; Messages.importMessagesDirectory(pathJoin(__dirname)); const messages = Messages.loadMessages('@salesforce/core', 'envVars'); + export enum EnvironmentVariable { 'FORCE_OPEN_URL' = 'FORCE_OPEN_URL', 'FORCE_SHOW_SPINNER' = 'FORCE_SHOW_SPINNER', @@ -90,9 +91,11 @@ export enum EnvironmentVariable { 'SF_UPDATE_INSTRUCTIONS' = 'SF_UPDATE_INSTRUCTIONS', 'SF_INSTALLER' = 'SF_INSTALLER', 'SF_ENV' = 'SF_ENV', + 'SF_CAPITALIZE_RECORD_TYPES' = 'SF_CAPITALIZE_RECORD_TYPES', } type EnvMetaData = { description: string; + /** the env has been renamed. synonymOf points to the new env */ synonymOf: Nullable; }; @@ -241,7 +244,8 @@ export const SUPPORTED_ENV_VARS: EnvType = { }, [EnvironmentVariable.SFDX_REST_DEPLOY]: { description: getMessage(EnvironmentVariable.SFDX_REST_DEPLOY), - synonymOf: null, + // this is not an "official" env var, but it supports the env=>config naming convention for the config that lives in plugin-deploy-retrieve + synonymOf: 'SF_ORG_METADATA_REST_DEPLOY', }, [EnvironmentVariable.SFDX_SOURCE_MEMBER_POLLING_TIMEOUT]: { description: getMessage(EnvironmentVariable.SFDX_SOURCE_MEMBER_POLLING_TIMEOUT), @@ -277,11 +281,11 @@ export const SUPPORTED_ENV_VARS: EnvType = { }, [EnvironmentVariable.SF_TARGET_ORG]: { description: getMessage(EnvironmentVariable.SF_TARGET_ORG), - synonymOf: EnvironmentVariable.SFDX_DEFAULTUSERNAME, + synonymOf: null, }, [EnvironmentVariable.SF_TARGET_DEV_HUB]: { description: getMessage(EnvironmentVariable.SF_TARGET_DEV_HUB), - synonymOf: EnvironmentVariable.SFDX_DEFAULTDEVHUBUSERNAME, + synonymOf: null, }, // sf vars [EnvironmentVariable.SF_ACCESS_TOKEN]: { @@ -290,7 +294,7 @@ export const SUPPORTED_ENV_VARS: EnvType = { }, [EnvironmentVariable.SF_ORG_API_VERSION]: { description: getMessage(EnvironmentVariable.SF_ORG_API_VERSION), - synonymOf: EnvironmentVariable.SFDX_API_VERSION, + synonymOf: null, }, [EnvironmentVariable.SF_AUDIENCE_URL]: { description: getMessage(EnvironmentVariable.SF_AUDIENCE_URL), @@ -342,7 +346,7 @@ export const SUPPORTED_ENV_VARS: EnvType = { }, [EnvironmentVariable.SF_DISABLE_LOG_FILE]: { description: getMessage(EnvironmentVariable.SF_DISABLE_LOG_FILE), - synonymOf: EnvironmentVariable.SFDX_DISABLE_LOG_FILE, + synonymOf: null, }, [EnvironmentVariable.SF_LOG_LEVEL]: { description: getMessage(EnvironmentVariable.SF_LOG_LEVEL), @@ -358,7 +362,7 @@ export const SUPPORTED_ENV_VARS: EnvType = { }, [EnvironmentVariable.SF_ORG_MAX_QUERY_LIMIT]: { description: getMessage(EnvironmentVariable.SF_ORG_MAX_QUERY_LIMIT), - synonymOf: EnvironmentVariable.SFDX_MAX_QUERY_LIMIT, + synonymOf: null, }, [EnvironmentVariable.SF_MDAPI_TEMP_DIR]: { description: getMessage(EnvironmentVariable.SF_MDAPI_TEMP_DIR), @@ -414,6 +418,10 @@ export const SUPPORTED_ENV_VARS: EnvType = { description: getMessage(EnvironmentVariable.SF_ENV), synonymOf: null, }, + [EnvironmentVariable.SF_CAPITALIZE_RECORD_TYPES]: { + description: getMessage(EnvironmentVariable.SF_CAPITALIZE_RECORD_TYPES), + synonymOf: null, + }, }; export class EnvVars extends Env { @@ -427,48 +435,52 @@ export class EnvVars extends Env { } private static defaultPrefix(): string { - if (process.argv[0].startsWith('sfdx')) return 'SFDX_'; - if (process.argv[0].startsWith('sf')) return 'SF_'; - return 'SFDX_'; + return 'SF_'; } public getPropertyFromEnv(property: string, prefix = EnvVars.defaultPrefix()): Nullable { const envName = EnvVars.propertyToEnvName(property, prefix); - const synonym = SUPPORTED_ENV_VARS[envName as EnvironmentVariable]?.synonymOf; - return this.get(envName) ?? this.get(synonym as string); + return this.get(envName); } public asDictionary(): Dictionary { - return this.entries().reduce>((accumulator, [key, value]) => { - accumulator[key] = value; - return accumulator; - }, {}); + return Object.fromEntries(this.entries()); } - public asMap(): Map { - return this.entries().reduce((accumulator, [key, value]) => { - accumulator.set(key, value); - return accumulator; - }, new Map()); + public asMap(): Map { + return new Map(this.entries()); } private resolve(): void { + // iterate everything in the real environment + const corrections = new Map(); + this.entries().forEach(([key, value]) => { - if (SUPPORTED_ENV_VARS[key as EnvironmentVariable]) { - // cross populate value to synonym if synonym exists - if (SUPPORTED_ENV_VARS[key as EnvironmentVariable].synonymOf) { - const synonym = SUPPORTED_ENV_VARS[key as EnvironmentVariable].synonymOf; - // set synonym only if it is in the map and running in interoperability mode - if (synonym && Global.SFDX_INTEROPERABILITY) { - this.setString(synonym, value); + if (SUPPORTED_ENV_VARS[key as EnvironmentVariable]?.synonymOf) { + // we are looking at an "old" key that has a new name + // if the new key has a value set, use that for the old key, too + const newEnvName = SUPPORTED_ENV_VARS[key as EnvironmentVariable].synonymOf; + if (newEnvName) { + const valueOfNewName = this.getString(newEnvName); + if (!valueOfNewName) { + void Lifecycle.getInstance().emitWarning(messages.getMessage('deprecatedEnv', [key, newEnvName])); + corrections.set(newEnvName, value); + } else if (valueOfNewName !== value) { + void Lifecycle.getInstance().emitWarning( + messages.getMessage('deprecatedEnvDisagreement', [key, newEnvName, newEnvName]) + ); + corrections.set(key, valueOfNewName ?? value); } } } }); + corrections.forEach((v, k) => { + this.setString(k, v); + }); } private get(envName: string): T { - return this.asDictionary()[envName] as T; + return this.asMap().get(envName) as T; } } diff --git a/src/config/lwwMap.ts b/src/config/lwwMap.ts new file mode 100644 index 0000000000..953ad9ba87 --- /dev/null +++ b/src/config/lwwMap.ts @@ -0,0 +1,107 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +import { entriesOf } from '@salesforce/ts-types'; +import { nowBigInt } from '../util/time'; +import { LWWRegister } from './lwwRegister'; +import { ConfigContents, Key } from './configStackTypes'; + +export const SYMBOL_FOR_DELETED = 'UNIQUE_IDENTIFIER_FOR_DELETED' as const; + +export type LWWState

= { + [Property in keyof P]: LWWRegister['state']; +}; + +/** + * @param contents object aligning with ConfigContents + * @param timestamp a bigInt that sets the timestamp. Defaults to the current time + * construct a LWWState from an object + * @param keysToCheckForDeletion if a key is in this array, AND not in the contents, it will be marked as deleted + * */ +export const stateFromContents =

(contents: P, timestamp?: bigint): LWWState

=> + Object.fromEntries( + entriesOf(contents).map( + ([key, value]): [keyof P, LWWRegister['state']] => [ + key, + new LWWRegister({ timestamp: timestamp ?? nowBigInt(), value }), + ] + ) + // I'd love to get rid of this ASsertion but don't know how. + ) as LWWState

; + +export class LWWMap

{ + /** map of key to LWWRegister. Used for managing conflicts */ + #data = new Map>(); + + public constructor(state?: LWWState

) { + // create a new register for each key in the initial state + for (const [key, register] of entriesOf(state ?? {})) { + this.#data.set(key, new LWWRegister(register)); + } + } + + public get value(): P { + return Object.fromEntries( + Array.from(this.#data.entries()) + .filter(([, register]) => register.value !== SYMBOL_FOR_DELETED) + .map(([key, register]) => [key, register.value]) + ) as P; + } + + public get state(): LWWState

{ + return Object.fromEntries( + Array.from(this.#data.entries()).map(([key, register]) => [key, register.state]) + ) as LWWState

; + } + + // Merge top-level properties of the incoming state with the current state. + // The value with the latest timestamp wins. + public merge(state: LWWState

): LWWState

{ + // properties that are in the incoming state but not the current state might have been deleted. + // recursively merge each key's register with the incoming state for that key + for (const [key, remote] of entriesOf(state)) { + const local = this.#data.get(key); + // if the register already exists, merge it with the incoming state + if (local) local.merge(remote); + // otherwise, instantiate a new `LWWRegister` with the incoming state + else this.#data.set(key, new LWWRegister(remote)); + } + return this.state; + } + + public set>(key: K, value: P[K]): void { + // get the register at the given key + const register = this.#data.get(key); + + // if the register already exists, set the value + if (register) register.set(value); + // otherwise, instantiate a new `LWWRegister` with the value + else this.#data.set(key, new LWWRegister({ timestamp: nowBigInt(), value })); + } + + public get>(key: K): P[K] | undefined { + // map loses the typing + const value = this.#data.get(key)?.value; + if (value === SYMBOL_FOR_DELETED) return undefined; + return value as P[K]; + } + + public delete>(key: K): void { + this.#data.set( + key, + new LWWRegister({ + timestamp: nowBigInt(), + value: SYMBOL_FOR_DELETED, + }) + ); + } + + public has(key: string): boolean { + // if a register doesn't exist or its value is null, the map doesn't contain the key + return this.#data.has(key) && this.#data.get(key)?.value !== SYMBOL_FOR_DELETED; + } +} diff --git a/src/config/lwwRegister.ts b/src/config/lwwRegister.ts new file mode 100644 index 0000000000..9e63ee97c9 --- /dev/null +++ b/src/config/lwwRegister.ts @@ -0,0 +1,39 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +import { nowBigInt } from '../util/time'; + +type LWWRegisterState = { timestamp: bigint; value: T }; + +/** a CRDT implementation. Uses timestamps to resolve conflicts when updating the value (last write wins) + * mostly based on https://jakelazaroff.com/words/an-interactive-intro-to-crdts/ + * + * @param T the type of the value stored in the register + */ +export class LWWRegister { + public constructor(public state: LWWRegisterState) {} + + public get value(): T { + return this.state.value; + } + + public get timestamp(): bigint { + return this.state.timestamp; + } + + public set(value: T): void { + this.state = { timestamp: nowBigInt(), value }; + } + + public merge(incoming: LWWRegisterState): LWWRegisterState { + // only update if the incoming timestamp is greater than the local timestamp + if (incoming.timestamp > this.state.timestamp) { + this.state = incoming; + } + return this.state; + } +} diff --git a/src/config/orgUsersConfig.ts b/src/config/orgUsersConfig.ts index 089688af65..b14e1f500e 100644 --- a/src/config/orgUsersConfig.ts +++ b/src/config/orgUsersConfig.ts @@ -8,10 +8,13 @@ import { Global } from '../global'; import { ConfigFile } from './configFile'; +type UserConfig = { + usernames: string[]; +}; /** * A config file that stores usernames for an org. */ -export class OrgUsersConfig extends ConfigFile { +export class OrgUsersConfig extends ConfigFile { /** * Constructor. * **Do not directly construct instances of this class -- use {@link OrgUsersConfig.create} instead.** diff --git a/src/config/sandboxProcessCache.ts b/src/config/sandboxProcessCache.ts index 9a36d28ffa..56dac4e790 100644 --- a/src/config/sandboxProcessCache.ts +++ b/src/config/sandboxProcessCache.ts @@ -5,7 +5,7 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ import { Duration } from '@salesforce/kit'; -import { SandboxProcessObject, SandboxRequest } from '../org'; +import { SandboxProcessObject, SandboxRequest } from '../org/org'; import { Global } from '../global'; import { TTLConfig } from './ttlConfig'; diff --git a/src/config/tokensConfig.ts b/src/config/tokensConfig.ts deleted file mode 100644 index 05ea646732..0000000000 --- a/src/config/tokensConfig.ts +++ /dev/null @@ -1,31 +0,0 @@ -/* - * Copyright (c) 2022, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ -/* eslint-disable class-methods-use-this */ - -import { Optional } from '@salesforce/ts-types'; -import { SfTokens } from '../stateAggregator'; -import { ConfigFile } from './configFile'; -import { ConfigContents, ConfigValue } from './configStore'; - -export class TokensConfig extends ConfigFile { - protected static encryptedKeys = [/token/i, /password/i, /secret/i]; - public static getDefaultOptions(): ConfigFile.Options { - return { - isGlobal: true, - isState: true, - filename: 'tokens.json', - }; - } - - protected getMethod(contents: ConfigContents, key: string): Optional { - return contents[key]; - } - - protected setMethod(contents: ConfigContents, key: string, value?: ConfigValue): void { - contents[key] = value; - } -} diff --git a/src/config/ttlConfig.ts b/src/config/ttlConfig.ts index afc2874b96..ebe1e31e0c 100644 --- a/src/config/ttlConfig.ts +++ b/src/config/ttlConfig.ts @@ -46,7 +46,11 @@ export class TTLConfig extends C protected async init(): Promise { const contents = await this.read(this.options.throwOnNotFound); const date = new Date().getTime(); - this.setContents(Object.fromEntries(Object.entries(contents).filter(([, value]) => !this.isExpired(date, value)))); + + // delete all the expired entries + Object.entries(contents) + .filter(([, value]) => this.isExpired(date, value)) + .map(([key]) => this.unset(key)); } // eslint-disable-next-line class-methods-use-this diff --git a/src/crypto/crypto.ts b/src/crypto/crypto.ts index 7fea403a04..7161fd79e5 100644 --- a/src/crypto/crypto.ts +++ b/src/crypto/crypto.ts @@ -6,16 +6,16 @@ */ /* eslint-disable @typescript-eslint/ban-types */ -import * as crypto from 'crypto'; -import * as os from 'os'; -import { join as pathJoin } from 'path'; +import * as crypto from 'node:crypto'; +import * as os from 'node:os'; +import { join as pathJoin } from 'node:path'; import { ensure, isString, Nullable, Optional } from '@salesforce/ts-types'; import { AsyncOptionalCreatable, env } from '@salesforce/kit'; -import { Logger } from '../logger'; -import { SfError } from '../sfError'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { Cache } from '../util/cache'; import { Global } from '../global'; +import { SfError } from '../sfError'; import { retrieveKeychain } from './keyChain'; import { KeyChain } from './keyChainImpl'; import { SecureBuffer } from './secureBuffer'; @@ -109,7 +109,7 @@ export class Crypto extends AsyncOptionalCreatable { private noResetOnClose!: boolean; // true when the key is 32 hex chars - private legacy_key_mode = false; + private legacyKeyMode = false; /** * Constructor @@ -183,24 +183,24 @@ export class Crypto extends AsyncOptionalCreatable { dec += decipher.final('utf8'); } catch (_err: unknown) { const err = (isString(_err) ? SfError.wrap(_err) : _err) as Error; - const handleDecryptError = (decryptErr: Error) => { + const handleDecryptError = (decryptErr: Error): void => { const error = messages.createError('authDecryptError', [decryptErr.message], [], decryptErr); const useGenericUnixKeychain = - env.getBoolean('SFDX_USE_GENERIC_UNIX_KEYCHAIN') || env.getBoolean('USE_GENERIC_UNIX_KEYCHAIN'); + env.getBoolean('SF_USE_GENERIC_UNIX_KEYCHAIN') || env.getBoolean('USE_GENERIC_UNIX_KEYCHAIN'); if (os.platform() === 'darwin' && !useGenericUnixKeychain) { error.actions = [messages.getMessage('macKeychainOutOfSync')]; } throw error; }; - if (this.legacy_key_mode && err?.message === 'Unsupported state or unable to authenticate data') { + if (this.legacyKeyMode && err?.message === 'Unsupported state or unable to authenticate data') { try { - const iv_legacy = tokens[0].substring(0, BYTE_COUNT_FOR_IV); - const secret_legacy = tokens[0].substring(BYTE_COUNT_FOR_IV, tokens[0].length); + const ivLegacy = tokens[0].substring(0, BYTE_COUNT_FOR_IV); + const secretLegacy = tokens[0].substring(BYTE_COUNT_FOR_IV, tokens[0].length); // legacy encryption used a utf8 encoded string from the buffer - decipher = crypto.createDecipheriv(ALGO, buffer.toString('utf8'), iv_legacy); + decipher = crypto.createDecipheriv(ALGO, buffer.toString('utf8'), ivLegacy); decipher.setAuthTag(Buffer.from(tag, 'hex')); - dec = decipher.update(secret_legacy, 'hex', 'utf8'); + dec = decipher.update(secretLegacy, 'hex', 'utf8'); dec += decipher.final('utf8'); } catch (_err2: unknown) { const err2 = (isString(_err2) ? SfError.wrap(_err2) : _err2) as Error; @@ -277,7 +277,7 @@ export class Crypto extends AsyncOptionalCreatable { } else { encoding = 'utf8'; logger.debug('Detected legacy key size'); - this.legacy_key_mode = true; + this.legacyKeyMode = true; } this.key.consume(Buffer.from(pwdHex, encoding)); } catch (err) { diff --git a/src/crypto/keyChain.ts b/src/crypto/keyChain.ts index 88945a131e..ffe8806c3d 100644 --- a/src/crypto/keyChain.ts +++ b/src/crypto/keyChain.ts @@ -6,7 +6,7 @@ */ import { env } from '@salesforce/kit'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { KeyChain, keyChainImpl } from './keyChainImpl'; @@ -23,7 +23,7 @@ export const retrieveKeychain = async (platform: string): Promise => { const logger: Logger = await Logger.child('keyChain'); logger.debug(`platform: ${platform}`); - const useGenericUnixKeychainVar = env.getBoolean('SFDX_USE_GENERIC_UNIX_KEYCHAIN'); + const useGenericUnixKeychainVar = env.getBoolean('SF_USE_GENERIC_UNIX_KEYCHAIN'); const shouldUseGenericUnixKeychain = useGenericUnixKeychainVar && useGenericUnixKeychainVar; if (platform.startsWith('win')) { diff --git a/src/crypto/keyChainImpl.ts b/src/crypto/keyChainImpl.ts index ddcfe18315..01e6e7f1cf 100644 --- a/src/crypto/keyChainImpl.ts +++ b/src/crypto/keyChainImpl.ts @@ -5,12 +5,12 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as childProcess from 'child_process'; -import * as nodeFs from 'fs'; -import * as fs from 'fs'; -import * as os from 'os'; -import { homedir } from 'os'; -import * as path from 'path'; +import * as childProcess from 'node:child_process'; +import * as nodeFs from 'node:fs'; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import { homedir } from 'node:os'; +import * as path from 'node:path'; import { asString, ensureString, Nullable } from '@salesforce/ts-types'; import { parseJsonMap } from '@salesforce/kit'; import { Global } from '../global'; @@ -46,7 +46,7 @@ const isExe = (mode: number, gid: number, uid: number): boolean => { return Boolean( mode & parseInt('0001', 8) || - (mode & parseInt('0010', 8) && process.getgid && gid === process.getgid()) || + Boolean(mode & parseInt('0010', 8) && process.getgid && gid === process.getgid()) || (mode & parseInt('0100', 8) && process.getuid && uid === process.getuid()) ); }; diff --git a/src/crypto/secureBuffer.ts b/src/crypto/secureBuffer.ts index ec9cf0bd8f..6ef4a92ae5 100644 --- a/src/crypto/secureBuffer.ts +++ b/src/crypto/secureBuffer.ts @@ -5,7 +5,7 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as crypto from 'crypto'; +import * as crypto from 'node:crypto'; import { ensure, Optional } from '@salesforce/ts-types'; const cipherName = 'aes-256-cbc'; diff --git a/src/deviceOauthService.ts b/src/deviceOauthService.ts index 815523a426..6683ff6e39 100644 --- a/src/deviceOauthService.ts +++ b/src/deviceOauthService.ts @@ -8,12 +8,13 @@ /* eslint-disable @typescript-eslint/ban-types */ import Transport from 'jsforce/lib/transport'; -import { AsyncCreatable, Duration, parseJsonMap } from '@salesforce/kit'; +import { AsyncCreatable, Duration, parseJsonMap, sleep } from '@salesforce/kit'; import { HttpRequest, OAuth2Config } from 'jsforce'; -import { ensureString, JsonMap, Nullable } from '@salesforce/ts-types'; +import { ensureString, isString, JsonMap, Nullable } from '@salesforce/ts-types'; import * as FormData from 'form-data'; -import { Logger } from './logger'; -import { AuthInfo, DEFAULT_CONNECTED_APP_INFO, SFDX_HTTP_HEADERS } from './org'; +import { Logger } from './logger/logger'; +import { AuthInfo, DEFAULT_CONNECTED_APP_INFO } from './org/authInfo'; +import { SFDX_HTTP_HEADERS } from './org/connection'; import { SfError } from './sfError'; import { Messages } from './messages'; @@ -38,15 +39,23 @@ export interface DeviceCodePollingResponse extends JsonMap { issued_at: string; } -async function wait(ms = 1000): Promise { - return new Promise((resolve) => { - setTimeout(resolve, ms); - }); +interface DeviceCodeAuthError extends SfError { + error: string; + error_description: string; + status: number; } async function makeRequest(options: HttpRequest): Promise { const rawResponse = await new Transport().httpRequest(options); + + if (rawResponse?.headers?.['content-type'] === 'text/html') { + const htmlResponseError = messages.createError('error.HttpApi'); + htmlResponseError.setData(rawResponse.body); + throw htmlResponseError; + } + const response = parseJsonMap(rawResponse.body); + if (response.error) { const errorDescription = typeof response.error_description === 'string' ? response.error_description : ''; const error = typeof response.error === 'string' ? response.error : 'Unknown'; @@ -174,21 +183,25 @@ export class DeviceOauthService extends AsyncCreatable { ); try { return await makeRequest(httpRequest); - } catch (e) { - /* eslint-disable @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/restrict-template-expressions */ - const err: any = (e as SfError).data; - if (err.error && err.status === 400 && err.error === 'authorization_pending') { + } catch (e: unknown) { + if (e instanceof SfError && e.name === 'HttpApiError') { + throw e; + } + + const err = (e instanceof SfError ? e.data : SfError.wrap(isString(e) ? e : 'unknown').data) as + | DeviceCodeAuthError + | undefined; + if (err?.error && err?.status === 400 && err?.error === 'authorization_pending') { // do nothing because we're still waiting } else { - if (err.error && err.error_description) { + if (err?.error && err?.error_description) { this.logger.error(`Polling error: ${err.error}: ${err.error_description}`); } else { this.logger.error('Unknown Polling Error:'); - this.logger.error(err); + this.logger.error(err ?? e); } - throw err; + throw err ?? e; } - /* eslint-enable @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/restrict-template-expressions */ } } @@ -211,7 +224,7 @@ export class DeviceOauthService extends AsyncCreatable { } else { this.logger.debug(`waiting ${interval} ms...`); // eslint-disable-next-line no-await-in-loop - await wait(interval); + await sleep(interval); this.pollingCount += 1; } } diff --git a/src/exported.ts b/src/exported.ts index c4ec4580e0..c067a98232 100644 --- a/src/exported.ts +++ b/src/exported.ts @@ -6,19 +6,19 @@ */ import { Messages } from './messages'; + Messages.importMessagesDirectory(__dirname); export { OAuth2Config } from 'jsforce'; - export { ConfigFile } from './config/configFile'; export { TTLConfig } from './config/ttlConfig'; export { envVars, EnvironmentVariable, SUPPORTED_ENV_VARS, EnvVars } from './config/envVars'; -export { ConfigContents, ConfigEntry, ConfigStore, ConfigValue } from './config/configStore'; - -export { SfTokens, StateAggregator } from './stateAggregator'; +export { ConfigStore } from './config/configStore'; +export { ConfigEntry, ConfigContents, ConfigValue } from './config/configStackTypes'; +export { StateAggregator } from './stateAggregator/stateAggregator'; export { DeviceOauthService, DeviceCodeResponse, DeviceCodePollingResponse } from './deviceOauthService'; @@ -36,7 +36,7 @@ export { export { SandboxRequestCacheEntry, SandboxRequestCache } from './config/sandboxProcessCache'; -export { ConfigInfo, ConfigAggregator, SfdxConfigAggregator } from './config/configAggregator'; +export { ConfigInfo, ConfigAggregator } from './config/configAggregator'; export { AuthFields, AuthInfo, AuthSideEffects, OrgAuthorization } from './org/authInfo'; @@ -54,16 +54,7 @@ export { SfdcUrl } from './util/sfdcUrl'; export { getJwtAudienceUrl } from './util/getJwtAudienceUrl'; -export { - Fields, - FieldValue, - LoggerLevel, - LoggerLevelValue, - LogLine, - LoggerOptions, - LoggerStream, - Logger, -} from './logger'; +export { Fields, FieldValue, LoggerLevel, LoggerLevelValue, LogLine, LoggerOptions, Logger } from './logger/logger'; export { Messages, StructuredMessage } from './messages'; @@ -79,25 +70,15 @@ export { OrgTypes, ResultEvent, ScratchOrgRequest, -} from './org'; +} from './org/org'; export { OrgConfigProperties, ORG_CONFIG_ALLOWED_PROPERTIES } from './org/orgConfigProperties'; -export { - PackageDir, - NamedPackageDir, - PackageDirDependency, - SfProject, - SfProjectJson, - SfdxProject, - SfdxProjectJson, -} from './sfProject'; - -export { SchemaPrinter } from './schema/printer'; +export { PackageDir, NamedPackageDir, PackageDirDependency, SfProject, SfProjectJson } from './sfProject'; export { SchemaValidator } from './schema/validator'; -export { SfError, SfdxError } from './sfError'; +export { SfError } from './sfError'; export { PollingClient } from './status/pollingClient'; @@ -108,7 +89,7 @@ export { MyDomainResolver } from './status/myDomainResolver'; export { DefaultUserFields, REQUIRED_FIELDS, User, UserFields } from './org/user'; export { PermissionSetAssignment, PermissionSetAssignmentFields } from './org/permissionSetAssignment'; - +export { lockInit } from './util/fileLocking'; export { ScratchOrgCreateOptions, ScratchOrgCreateResult, @@ -123,6 +104,6 @@ export { scratchOrgLifecycleStages, } from './org/scratchOrgLifecycleEvents'; export { ScratchOrgCache } from './org/scratchOrgCache'; + // Utility sub-modules export * from './util/sfdc'; -export * from './util/sfdcUrl'; diff --git a/src/global.ts b/src/global.ts index efb04c61c0..ba2e23f9cc 100644 --- a/src/global.ts +++ b/src/global.ts @@ -5,9 +5,9 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as fs from 'fs'; -import * as os from 'os'; -import * as path from 'path'; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import * as path from 'node:path'; import { env } from '@salesforce/kit'; import { SfError } from './sfError'; @@ -75,13 +75,6 @@ export class Global { return path.join(os.homedir(), Global.SFDX_STATE_FOLDER); } - /** - * The full system path to the global log file. - */ - // member ordering conflicts with the TS use-before-declaration error - // eslint-disable-next-line @typescript-eslint/member-ordering - public static readonly LOG_FILE_PATH: string = path.join(Global.SF_DIR, 'sf.log'); - /** * Gets the current mode environment variable as a {@link Mode} instance. * @@ -90,7 +83,10 @@ export class Global { * ``` */ public static getEnvironmentMode(): Mode { - return Mode[env.getKeyOf('SFDX_ENV', Mode, Mode.PRODUCTION, (value) => value.toUpperCase())]; + const envValue = env.getString('SF_ENV') ?? env.getString('SFDX_ENV', Mode.PRODUCTION); + return envValue in Mode || envValue.toUpperCase() in Mode + ? Mode[envValue.toUpperCase() as keyof typeof Mode] + : Mode.PRODUCTION; } /** diff --git a/src/lifecycleEvents.ts b/src/lifecycleEvents.ts index 9ccf33f48c..64f5a82176 100644 --- a/src/lifecycleEvents.ts +++ b/src/lifecycleEvents.ts @@ -6,12 +6,12 @@ */ import { AnyJson, Dictionary } from '@salesforce/ts-types'; -import * as Debug from 'debug'; import { compare } from 'semver'; // needed for TS to not put everything inside /lib/src // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore import * as pjson from '../package.json'; +import { Logger } from './logger/logger'; // Data of any type can be passed to the callback. Can be cast to any type that is given in emit(). // eslint-disable-next-line @typescript-eslint/no-explicit-any @@ -45,9 +45,12 @@ declare const global: { export class Lifecycle { public static readonly telemetryEventName = 'telemetry'; public static readonly warningEventName = 'warning'; - private debug = Debug(`sfdx:${this.constructor.name}`); + private logger?: Logger; - private constructor(private readonly listeners: Dictionary = {}) {} + private constructor( + private readonly listeners: Dictionary = {}, + private readonly uniqueListeners: Map> = new Map>() + ) {} /** * return the package.json version of the sfdx-core library. @@ -87,7 +90,7 @@ export class Lifecycle { const oldInstance = global.salesforceCoreLifecycle; // use the newer version and transfer any listeners from the old version // object spread keeps them from being references - global.salesforceCoreLifecycle = new Lifecycle({ ...oldInstance.listeners }); + global.salesforceCoreLifecycle = new Lifecycle({ ...oldInstance.listeners }, oldInstance.uniqueListeners); // clean up any listeners on the old version Object.keys(oldInstance.listeners).map((eventName) => { oldInstance.removeAllListeners(eventName); @@ -111,6 +114,7 @@ export class Lifecycle { */ public removeAllListeners(eventName: string): void { this.listeners[eventName] = []; + this.uniqueListeners.delete(eventName); } /** @@ -119,7 +123,9 @@ export class Lifecycle { * @param eventName The name of the event to get listeners of */ public getListeners(eventName: string): callback[] { - const listeners = this.listeners[eventName]; + const listeners = this.listeners[eventName]?.concat( + Array.from((this.uniqueListeners.get(eventName) ?? []).values()) ?? [] + ); if (listeners) { return listeners; } else { @@ -150,11 +156,15 @@ export class Lifecycle { * * @param eventName The name of the event that is being listened for * @param cb The callback function to run when the event is emitted + * @param uniqueListenerIdentifier A unique identifier for the listener. If a listener with the same identifier is already registered, a new one will not be added */ - public on(eventName: string, cb: (data: T) => Promise): void { + public on(eventName: string, cb: (data: T) => Promise, uniqueListenerIdentifier?: string): void { const listeners = this.getListeners(eventName); if (listeners.length !== 0) { - this.debug( + if (!this.logger) { + this.logger = Logger.childFromRoot('Lifecycle'); + } + this.logger.debug( `${ listeners.length + 1 } lifecycle events with the name ${eventName} have now been registered. When this event is emitted all ${ @@ -162,8 +172,19 @@ export class Lifecycle { } listeners will fire.` ); } - listeners.push(cb); - this.listeners[eventName] = listeners; + + if (uniqueListenerIdentifier) { + if (!this.uniqueListeners.has(eventName)) { + // nobody is listening to the event yet + this.uniqueListeners.set(eventName, new Map([[uniqueListenerIdentifier, cb]])); + } else if (!this.uniqueListeners.get(eventName)?.has(uniqueListenerIdentifier)) { + // the unique listener identifier is not already registered + this.uniqueListeners.get(eventName)?.set(uniqueListenerIdentifier, cb); + } + } else { + listeners.push(cb); + this.listeners[eventName] = listeners; + } } /** @@ -196,7 +217,10 @@ export class Lifecycle { public async emit(eventName: string, data: T): Promise { const listeners = this.getListeners(eventName); if (listeners.length === 0 && eventName !== Lifecycle.warningEventName) { - this.debug( + if (!this.logger) { + this.logger = Logger.childFromRoot('Lifecycle'); + } + this.logger.debug( `A lifecycle event with the name ${eventName} does not exist. An event must be registered before it can be emitted.` ); } else { diff --git a/src/logger.ts b/src/logger.ts deleted file mode 100644 index 74ca2b2e16..0000000000 --- a/src/logger.ts +++ /dev/null @@ -1,943 +0,0 @@ -/* - * Copyright (c) 2020, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ -import { EventEmitter } from 'events'; -import * as os from 'os'; -import * as path from 'path'; -import { Writable } from 'stream'; -import * as fs from 'fs'; -// eslint-disable-next-line @typescript-eslint/ban-ts-comment -// @ts-ignore -import * as Bunyan from '@salesforce/bunyan'; -import { Env, parseJson, parseJsonMap } from '@salesforce/kit'; -import { - Dictionary, - ensure, - ensureNumber, - isArray, - isFunction, - isKeyOf, - isObject, - isPlainObject, - isString, - Many, - Optional, -} from '@salesforce/ts-types'; -import * as Debug from 'debug'; -import { Global, Mode } from './global'; -import { SfError } from './sfError'; - -/* eslint-disable @typescript-eslint/no-unsafe-return */ -/* eslint-disable @typescript-eslint/no-unsafe-member-access */ -/* eslint-disable @typescript-eslint/no-unsafe-assignment */ -/* eslint-disable @typescript-eslint/no-unsafe-call */ -/* eslint-disable @typescript-eslint/explicit-function-return-type */ -/* eslint-disable @typescript-eslint/restrict-template-expressions */ - -/** - * A Bunyan `Serializer` function. - * - * @param input The input to be serialized. - * **See** {@link https://github.com/forcedotcom/node-bunyan#serializers|Bunyan Serializers API} - */ -export type Serializer = (input: unknown) => unknown; - -/** - * A collection of named `Serializer`s. - * - * **See** {@link https://github.com/forcedotcom/node-bunyan#serializers|Bunyan Serializers API} - */ -export interface Serializers { - [key: string]: Serializer; -} - -/** - * The common set of `Logger` options. - */ -export interface LoggerOptions { - /** - * The logger name. - */ - name: string; - - /** - * The logger format type. Current options include LogFmt or JSON (default). - */ - format?: LoggerFormat; - - /** - * The logger's serializers. - */ - serializers?: Serializers; - /** - * Whether or not to log source file, line, and function information. - */ - src?: boolean; - /** - * The desired log level. - */ - level?: LoggerLevelValue; - /** - * A stream to write to. - */ - stream?: Writable; - /** - * An array of streams to write to. - */ - streams?: LoggerStream[]; -} - -/** - * Standard `Logger` levels. - * - * **See** {@link https://github.com/forcedotcom/node-bunyan#levels|Bunyan Levels} - */ -export enum LoggerLevel { - TRACE = 10, - DEBUG = 20, - INFO = 30, - WARN = 40, - ERROR = 50, - FATAL = 60, -} - -/** - * `Logger` format types. - */ -export enum LoggerFormat { - JSON, - LOGFMT, -} - -/** - * A Bunyan stream configuration. - * - * @see {@link https://github.com/forcedotcom/node-bunyan#streams|Bunyan Streams} - */ -export interface LoggerStream { - // eslint-disable-next-line @typescript-eslint/no-explicit-any - [key: string]: any; - /** - * The type of stream -- may be inferred from other properties. - */ - type?: string; - /** - * The desired log level for the stream. - */ - level?: LoggerLevelValue; - /** - * The stream to write to. Mutually exclusive with `path`. - */ - stream?: Writable; - /** - * The name of the stream. - */ - name?: string; - /** - * A log file path to write to. Mutually exclusive with `stream`. - */ - path?: string; -} - -/** - * Any numeric `Logger` level. - */ -export type LoggerLevelValue = LoggerLevel | number; - -/** - * A collection of named `FieldValue`s. - * - * **See** {@link https://github.com/forcedotcom/node-bunyan#log-record-fields|Bunyan Log Record Fields} - */ -export interface Fields { - [key: string]: FieldValue; -} - -/** - * All possible field value types. - */ -export type FieldValue = string | number | boolean; - -/** - * Log line interface - */ -export interface LogLine { - name: string; - hostname: string; - pid: string; - log: string; - level: number; - msg: string; - time: string; - v: number; -} - -/** - * A logging abstraction powered by {@link https://github.com/forcedotcom/node-bunyan|Bunyan} that provides both a default - * logger configuration that will log to `sfdx.log`, and a way to create custom loggers based on the same foundation. - * - * ``` - * // Gets the root sfdx logger - * const logger = await Logger.root(); - * - * // Creates a child logger of the root sfdx logger with custom fields applied - * const childLogger = await Logger.child('myRootChild', {tag: 'value'}); - * - * // Creates a custom logger unaffiliated with the root logger - * const myCustomLogger = new Logger('myCustomLogger'); - * - * // Creates a child of a custom logger unaffiliated with the root logger with custom fields applied - * const myCustomChildLogger = myCustomLogger.child('myCustomChild', {tag: 'value'}); - * ``` - * **See** https://github.com/forcedotcom/node-bunyan - * - * **See** https://developer.salesforce.com/docs/atlas.en-us.sfdx_setup.meta/sfdx_setup/sfdx_dev_cli_log_messages.htm - */ -export class Logger { - /** - * The name of the root sfdx `Logger`. - */ - public static readonly ROOT_NAME = 'sf'; - - /** - * The default `LoggerLevel` when constructing new `Logger` instances. - */ - public static readonly DEFAULT_LEVEL = LoggerLevel.WARN; - - /** - * A list of all lower case `LoggerLevel` names. - * - * **See** {@link LoggerLevel} - */ - public static readonly LEVEL_NAMES = Object.values(LoggerLevel) - .filter(isString) - .map((v: string) => v.toLowerCase()); - // Rollup all instance-specific process event listeners together to prevent global `MaxListenersExceededWarning`s. - private static readonly lifecycle = ((): EventEmitter => { - const events = new EventEmitter(); - events.setMaxListeners(0); // never warn on listener counts - process.on('uncaughtException', (err) => events.emit('uncaughtException', err)); - process.on('exit', () => events.emit('exit')); - return events; - })(); - - // The sfdx root logger singleton - private static rootLogger?: Logger; - - /** - * The default rotation period for logs. Example '1d' will rotate logs daily (at midnight). - * See 'period' docs here: https://github.com/forcedotcom/node-bunyan#stream-type-rotating-file - */ - - public readonly logRotationPeriod = new Env().getString('SF_LOG_ROTATION_PERIOD') ?? '1d'; - - /** - * The number of backup rotated log files to keep. - * Example: '3' will have the base sf.log file, and the past 3 (period) log files. - * See 'count' docs here: https://github.com/forcedotcom/node-bunyan#stream-type-rotating-file - */ - - public readonly logRotationCount = new Env().getNumber('SF_LOG_ROTATION_COUNT') ?? 2; - - /** - * Whether debug is enabled for this Logger. - */ - public debugEnabled = false; - - // The actual Bunyan logger - private bunyan: Bunyan; - - private readonly format: LoggerFormat; - - /** - * Constructs a new `Logger`. - * - * @param optionsOrName A set of `LoggerOptions` or name to use with the default options. - * - * **Throws** *{@link SfError}{ name: 'RedundantRootLoggerError' }* More than one attempt is made to construct the root - * `Logger`. - */ - public constructor(optionsOrName: LoggerOptions | string) { - let options: LoggerOptions; - if (typeof optionsOrName === 'string') { - options = { - name: optionsOrName, - level: Logger.DEFAULT_LEVEL, - serializers: Bunyan.stdSerializers, - }; - } else { - options = optionsOrName; - } - - if (Logger.rootLogger && options.name === Logger.ROOT_NAME) { - throw new SfError('Can not create another root logger.', 'RedundantRootLoggerError'); - } - - // Inspect format to know what logging format to use then delete from options to - // ensure it doesn't conflict with Bunyan. - this.format = options.format ?? LoggerFormat.JSON; - delete options.format; - - // If the log format is LOGFMT, we need to convert any stream(s) into a LOGFMT type stream. - if (this.format === LoggerFormat.LOGFMT && options.stream) { - const ls: LoggerStream = this.createLogFmtFormatterStream({ stream: options.stream }); - options.stream = ls.stream; - } - if (this.format === LoggerFormat.LOGFMT && options.streams) { - const logFmtConvertedStreams: LoggerStream[] = []; - options.streams.forEach((ls: LoggerStream) => { - logFmtConvertedStreams.push(this.createLogFmtFormatterStream(ls)); - }); - options.streams = logFmtConvertedStreams; - } - - this.bunyan = new Bunyan(options); - this.bunyan.name = options.name; - this.bunyan.filters = []; - - if (!options.streams && !options.stream) { - this.bunyan.streams = []; - } - - // all SFDX loggers must filter sensitive data - this.addFilter((...args) => filterSecrets(...args)); - - if (Global.getEnvironmentMode() !== Mode.TEST) { - Logger.lifecycle.on('uncaughtException', this.uncaughtExceptionHandler); - Logger.lifecycle.on('exit', this.exitHandler); - } - - this.trace(`Created '${this.getName()}' logger instance`); - } - - /** - * Gets the root logger with the default level, file stream, and DEBUG enabled. - */ - public static async root(): Promise { - if (this.rootLogger) { - return this.rootLogger; - } - const rootLogger = (this.rootLogger = new Logger(Logger.ROOT_NAME).setLevel()); - - // disable log file writing, if applicable - const disableLogFile = new Env().getString('SF_DISABLE_LOG_FILE'); - if (disableLogFile !== 'true' && Global.getEnvironmentMode() !== Mode.TEST) { - await rootLogger.addLogFileStream(Global.LOG_FILE_PATH); - } - - rootLogger.enableDEBUG(); - return rootLogger; - } - - /** - * Gets the root logger with the default level, file stream, and DEBUG enabled. - */ - public static getRoot(): Logger { - if (this.rootLogger) { - return this.rootLogger; - } - const rootLogger = (this.rootLogger = new Logger(Logger.ROOT_NAME).setLevel()); - - // disable log file writing, if applicable - if (process.env.SFDX_DISABLE_LOG_FILE !== 'true' && Global.getEnvironmentMode() !== Mode.TEST) { - rootLogger.addLogFileStreamSync(Global.LOG_FILE_PATH); - } - - rootLogger.enableDEBUG(); - return rootLogger; - } - - /** - * Destroys the root `Logger`. - * - * @ignore - */ - public static destroyRoot(): void { - if (this.rootLogger) { - this.rootLogger.close(); - this.rootLogger = undefined; - } - } - - /** - * Create a child of the root logger, inheriting this instance's configuration such as `level`, `streams`, etc. - * - * @param name The name of the child logger. - * @param fields Additional fields included in all log lines. - */ - public static async child(name: string, fields?: Fields): Promise { - return (await Logger.root()).child(name, fields); - } - - /** - * Create a child of the root logger, inheriting this instance's configuration such as `level`, `streams`, etc. - * - * @param name The name of the child logger. - * @param fields Additional fields included in all log lines. - */ - public static childFromRoot(name: string, fields?: Fields): Logger { - return Logger.getRoot().child(name, fields); - } - - /** - * Gets a numeric `LoggerLevel` value by string name. - * - * @param {string} levelName The level name to convert to a `LoggerLevel` enum value. - * - * **Throws** *{@link SfError}{ name: 'UnrecognizedLoggerLevelNameError' }* The level name was not case-insensitively recognized as a valid `LoggerLevel` value. - * @see {@Link LoggerLevel} - */ - public static getLevelByName(levelName: string): LoggerLevelValue { - levelName = levelName.toUpperCase(); - if (!isKeyOf(LoggerLevel, levelName)) { - throw new SfError(`Invalid log level "${levelName}".`, 'UnrecognizedLoggerLevelNameError'); - } - return LoggerLevel[levelName]; - } - - /** - * Adds a stream. - * - * @param stream The stream configuration to add. - * @param defaultLevel The default level of the stream. - */ - public addStream(stream: LoggerStream, defaultLevel?: LoggerLevelValue): void { - if (this.format === LoggerFormat.LOGFMT) { - stream = this.createLogFmtFormatterStream(stream); - } - this.bunyan.addStream(stream, defaultLevel); - } - - /** - * Adds a file stream to this logger. Resolved or rejected upon completion of the addition. - * - * @param logFile The path to the log file. If it doesn't exist it will be created. - */ - public async addLogFileStream(logFile: string): Promise { - try { - // Check if we have write access to the log file (i.e., we created it already) - await fs.promises.access(logFile, fs.constants.W_OK); - } catch (err1) { - try { - if (process.platform === 'win32') { - await fs.promises.mkdir(path.dirname(logFile), { recursive: true }); - } else { - await fs.promises.mkdir(path.dirname(logFile), { recursive: true, mode: 0o700 }); - } - } catch (err2) { - throw SfError.wrap(err2 as string | Error); - } - try { - await fs.promises.writeFile(logFile, '', { mode: '600' }); - } catch (err3) { - throw SfError.wrap(err3 as string | Error); - } - } - - // avoid multiple streams to same log file - if ( - !this.bunyan.streams.find( - // No bunyan typings - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (stream: any) => stream.type === 'rotating-file' && stream.path === logFile - ) - ) { - this.addStream({ - type: 'rotating-file', - path: logFile, - period: this.logRotationPeriod, - count: this.logRotationCount, - level: this.bunyan.level(), - }); - } - } - - /** - * Adds a file stream to this logger. Resolved or rejected upon completion of the addition. - * - * @param logFile The path to the log file. If it doesn't exist it will be created. - */ - public addLogFileStreamSync(logFile: string): void { - try { - // Check if we have write access to the log file (i.e., we created it already) - fs.accessSync(logFile, fs.constants.W_OK); - } catch (err1) { - try { - if (process.platform === 'win32') { - fs.mkdirSync(path.dirname(logFile), { recursive: true }); - } else { - fs.mkdirSync(path.dirname(logFile), { recursive: true, mode: 0o700 }); - } - } catch (err2) { - throw SfError.wrap(err2 as Error); - } - try { - fs.writeFileSync(logFile, '', { mode: '600' }); - } catch (err3) { - throw SfError.wrap(err3 as string | Error); - } - } - - // avoid multiple streams to same log file - if ( - !this.bunyan.streams.find( - // No bunyan typings - // eslint-disable-next-line @typescript-eslint/no-explicit-any - (stream: any) => stream.type === 'rotating-file' && stream.path === logFile - ) - ) { - this.addStream({ - type: 'rotating-file', - path: logFile, - period: this.logRotationPeriod, - count: this.logRotationCount, - level: this.bunyan.level(), - }); - } - } - - /** - * Gets the name of this logger. - */ - public getName(): string { - return this.bunyan.name; - } - - /** - * Gets the current level of this logger. - */ - public getLevel(): LoggerLevelValue { - return this.bunyan.level(); - } - - /** - * Set the logging level of all streams for this logger. If a specific `level` is not provided, this method will - * attempt to read it from the environment variable `SFDX_LOG_LEVEL`, and if not found, - * {@link Logger.DEFAULT_LOG_LEVEL} will be used instead. For convenience `this` object is returned. - * - * @param {LoggerLevelValue} [level] The logger level. - * - * **Throws** *{@link SfError}{ name: 'UnrecognizedLoggerLevelNameError' }* A value of `level` read from `SFDX_LOG_LEVEL` - * was invalid. - * - * ``` - * // Sets the level from the environment or default value - * logger.setLevel() - * - * // Set the level from the INFO enum - * logger.setLevel(LoggerLevel.INFO) - * - * // Sets the level case-insensitively from a string value - * logger.setLevel(Logger.getLevelByName('info')) - * ``` - */ - public setLevel(level?: LoggerLevelValue): Logger { - if (level == null) { - const logLevelFromEnvVar = new Env().getString('SF_LOG_LEVEL'); - level = logLevelFromEnvVar ? Logger.getLevelByName(logLevelFromEnvVar) : Logger.DEFAULT_LEVEL; - } - this.bunyan.level(level); - return this; - } - - /** - * Gets the underlying Bunyan logger. - */ - // leave this typed as any to keep if from trying to export the type from the untyped bunyan module - // this prevents consumers from getting node_modules/@salesforce/core/lib/logger.d.ts:281:24 - error TS2304: Cannot find name 'Bunyan'. - // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any - public getBunyanLogger(): any { - return this.bunyan; - } - - /** - * Compares the requested log level with the current log level. Returns true if - * the requested log level is greater than or equal to the current log level. - * - * @param level The requested log level to compare against the currently set log level. - */ - public shouldLog(level: LoggerLevelValue): boolean { - if (typeof level === 'string') { - level = Bunyan.levelFromName(level) as number; - } - return level >= this.getLevel(); - } - - /** - * Use in-memory logging for this logger instance instead of any parent streams. Useful for testing. - * For convenience this object is returned. - * - * **WARNING: This cannot be undone for this logger instance.** - */ - public useMemoryLogging(): Logger { - this.bunyan.streams = []; - this.bunyan.ringBuffer = new Bunyan.RingBuffer({ limit: 5000 }); - this.addStream({ - type: 'raw', - stream: this.bunyan.ringBuffer, - level: this.bunyan.level(), - }); - return this; - } - - /** - * Gets an array of log line objects. Each element is an object that corresponds to a log line. - */ - public getBufferedRecords(): LogLine[] { - if (this.bunyan.ringBuffer) { - return this.bunyan.ringBuffer.records; - } - return []; - } - - /** - * Reads a text blob of all the log lines contained in memory or the log file. - */ - public readLogContentsAsText(): string { - if (this.bunyan.ringBuffer) { - return this.getBufferedRecords().reduce((accum, line) => { - accum += JSON.stringify(line) + os.EOL; - return accum; - }, ''); - } else { - let content = ''; - // No bunyan typings - // eslint-disable-next-line @typescript-eslint/no-explicit-any - this.bunyan.streams.forEach(async (stream: any) => { - if (stream.type === 'file') { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - content += await fs.promises.readFile(stream.path, 'utf8'); - } - }); - return content; - } - } - - /** - * Adds a filter to be applied to all logged messages. - * - * @param filter A function with signature `(...args: any[]) => any[]` that transforms log message arguments. - */ - public addFilter(filter: (...args: unknown[]) => unknown): void { - if (!this.bunyan.filters) { - this.bunyan.filters = []; - } - this.bunyan.filters.push(filter); - } - - /** - * Close the logger, including any streams, and remove all listeners. - * - * @param fn A function with signature `(stream: LoggerStream) => void` to call for each stream with the stream as an arg. - */ - public close(fn?: (stream: LoggerStream) => void): void { - if (this.bunyan.streams) { - try { - this.bunyan.streams.forEach((entry: LoggerStream) => { - if (fn) { - fn(entry); - } - // close file streams, flush buffer to disk - // eslint-disable-next-line @typescript-eslint/unbound-method - if (entry.type === 'file' && entry.stream && isFunction(entry.stream.end)) { - entry.stream.end(); - } - }); - } finally { - Logger.lifecycle.removeListener('uncaughtException', this.uncaughtExceptionHandler); - Logger.lifecycle.removeListener('exit', this.exitHandler); - } - } - } - - /** - * Create a child logger, typically to add a few log record fields. For convenience this object is returned. - * - * @param name The name of the child logger that is emitted w/ log line as `log:`. - * @param fields Additional fields included in all log lines for the child logger. - */ - public child(name: string, fields: Fields = {}): Logger { - if (!name) { - throw new SfError('LoggerNameRequired'); - } - fields.log = name; - - const child = new Logger(name); - // only support including additional fields on log line (no config) - child.bunyan = this.bunyan.child(fields, true); - child.bunyan.name = name; - child.bunyan.filters = this.bunyan.filters; - - this.trace(`Setup child '${name}' logger instance`); - - return child; - } - - /** - * Add a field to all log lines for this logger. For convenience `this` object is returned. - * - * @param name The name of the field to add. - * @param value The value of the field to be logged. - */ - public addField(name: string, value: FieldValue): Logger { - this.bunyan.fields[name] = value; - return this; - } - - /** - * Logs at `trace` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - // eslint-disable-next-line @typescript-eslint/no-explicit-any - public trace(...args: any[]): Logger { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - this.bunyan.trace(this.applyFilters(LoggerLevel.TRACE, ...args)); - return this; - } - - /** - * Logs at `debug` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - public debug(...args: unknown[]): Logger { - this.bunyan.debug(this.applyFilters(LoggerLevel.DEBUG, ...args)); - return this; - } - - /** - * Logs at `debug` level with filtering applied. - * - * @param cb A callback that returns on array objects to be logged. - */ - public debugCallback(cb: () => unknown[] | string): void { - if (this.getLevel() === LoggerLevel.DEBUG || process.env.DEBUG) { - const result = cb(); - if (isArray(result)) { - this.bunyan.debug(this.applyFilters(LoggerLevel.DEBUG, ...result)); - } else { - this.bunyan.debug(this.applyFilters(LoggerLevel.DEBUG, ...[result])); - } - } - } - - /** - * Logs at `info` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - public info(...args: unknown[]): Logger { - this.bunyan.info(this.applyFilters(LoggerLevel.INFO, ...args)); - return this; - } - - /** - * Logs at `warn` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - public warn(...args: unknown[]): Logger { - this.bunyan.warn(this.applyFilters(LoggerLevel.WARN, ...args)); - return this; - } - - /** - * Logs at `error` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - public error(...args: unknown[]): Logger { - this.bunyan.error(this.applyFilters(LoggerLevel.ERROR, ...args)); - return this; - } - - /** - * Logs at `fatal` level with filtering applied. For convenience `this` object is returned. - * - * @param args Any number of arguments to be logged. - */ - public fatal(...args: unknown[]): Logger { - // always show fatal to stderr - // eslint-disable-next-line no-console - console.error(...args); - this.bunyan.fatal(this.applyFilters(LoggerLevel.FATAL, ...args)); - return this; - } - - /** - * Enables logging to stdout when the DEBUG environment variable is used. It uses the logger - * name as the debug name, so you can do DEBUG= to filter the results to your logger. - */ - public enableDEBUG(): void { - // The debug library does this for you, but no point setting up the stream if it isn't there - if (process.env.DEBUG && !this.debugEnabled) { - const debuggers: Dictionary = {}; - - debuggers.core = Debug(`${this.getName()}:core`); - - this.addStream({ - name: 'debug', - stream: new Writable({ - write: (chunk, encoding, next) => { - try { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const json = parseJsonMap(chunk.toString()); - const logLevel = ensureNumber(json.level); - if (this.getLevel() <= logLevel) { - let debuggerName = 'core'; - if (isString(json.log)) { - debuggerName = json.log; - if (!debuggers[debuggerName]) { - debuggers[debuggerName] = Debug(`${this.getName()}:${debuggerName}`); - } - } - const level = LoggerLevel[logLevel]; - ensure(debuggers[debuggerName])(`${level} ${json.msg}`); - } - } catch (err) { - // do nothing - } - next(); - }, - }), - // Consume all levels - level: 0, - }); - this.debugEnabled = true; - } - } - - private applyFilters(logLevel: LoggerLevel, ...args: unknown[]): Optional> { - if (this.shouldLog(logLevel)) { - // No bunyan typings - // eslint-disable-next-line @typescript-eslint/no-explicit-any - this.bunyan.filters.forEach((filter: any) => (args = filter(...args))); - } - return args && args.length === 1 ? args[0] : args; - } - - private uncaughtExceptionHandler = (err: Error) => { - // W-7558552 - // Only log uncaught exceptions in root logger - if (this === Logger.rootLogger) { - // log the exception - // FIXME: good chance this won't be logged because - // process.exit was called before this is logged - // https://github.com/trentm/node-bunyan/issues/95 - this.fatal(err); - } - }; - - private exitHandler = () => { - this.close(); - }; - - // eslint-disable-next-line class-methods-use-this - private createLogFmtFormatterStream(loggerStream: LoggerStream): LoggerStream { - const logFmtWriteableStream = new Writable({ - write: (chunk, enc, cb) => { - try { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const parsedJSON = JSON.parse(chunk.toString()); - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const keys = Object.keys(parsedJSON); - - let logEntry = ''; - keys.forEach((key) => { - let logMsg = `${parsedJSON[key]}`; - if (logMsg.trim().includes(' ')) { - logMsg = `"${logMsg}"`; - } - logEntry += `${key}=${logMsg} `; - }); - if (loggerStream.stream) { - loggerStream.stream.write(logEntry.trimRight() + '\n'); - } - } catch (error) { - if (loggerStream.stream) { - loggerStream.stream.write(chunk.toString()); - } - } - cb(null); - }, - }); - - return Object.assign({}, loggerStream, { stream: logFmtWriteableStream }); - } -} - -type FilteredKey = string | { name: string; regex: string }; - -// Ok to log clientid -const FILTERED_KEYS: FilteredKey[] = [ - 'sid', - 'Authorization', - // Any json attribute that contains the words "access" and "token" will have the attribute/value hidden - { name: 'access_token', regex: 'access[^\'"]*token' }, - // Any json attribute that contains the words "refresh" and "token" will have the attribute/value hidden - { name: 'refresh_token', regex: 'refresh[^\'"]*token' }, - 'clientsecret', - // Any json attribute that contains the words "sfdx", "auth", and "url" will have the attribute/value hidden - { name: 'sfdxauthurl', regex: 'sfdx[^\'"]*auth[^\'"]*url' }, -]; - -// SFDX code and plugins should never show tokens or connect app information in the logs -const filterSecrets = (...args: unknown[]): unknown => - args.map((arg) => { - if (isArray(arg)) { - return filterSecrets(...arg); - } - - if (arg) { - let mutableArg: string; - - // Normalize all objects into a string. This includes errors. - if (arg instanceof Buffer) { - mutableArg = ''; - } else if (isObject(arg)) { - mutableArg = JSON.stringify(arg); - } else if (isString(arg)) { - mutableArg = arg; - } else { - mutableArg = ''; - } - - const HIDDEN = 'HIDDEN'; - - FILTERED_KEYS.forEach((key: FilteredKey) => { - let expElement = key; - let expName = key; - - // Filtered keys can be strings or objects containing regular expression components. - if (isPlainObject(key)) { - expElement = key.regex; - expName = key.name; - } - - const hiddenAttrMessage = `"<${expName} - ${HIDDEN}>"`; - - // Match all json attribute values case insensitive: ex. {" Access*^&(*()^* Token " : " 45143075913458901348905 \n\t" ...} - const regexTokens = new RegExp(`(['"][^'"]*${expElement}[^'"]*['"]\\s*:\\s*)['"][^'"]*['"]`, 'gi'); - - mutableArg = mutableArg.replace(regexTokens, `$1${hiddenAttrMessage}`); - - // Match all key value attribute case insensitive: ex. {" key\t" : ' access_token ' , " value " : " dsafgasr431 " ....} - const keyRegex = new RegExp( - `(['"]\\s*key\\s*['"]\\s*:)\\s*['"]\\s*${expElement}\\s*['"]\\s*.\\s*['"]\\s*value\\s*['"]\\s*:\\s*['"]\\s*[^'"]*['"]`, - 'gi' - ); - mutableArg = mutableArg.replace(keyRegex, `$1${hiddenAttrMessage}`); - }); - - mutableArg = mutableArg.replace(/(00D\w{12,15})![.\w]*/, `<${HIDDEN}>`); - - // return an object if an object was logged; otherwise return the filtered string. - return isObject(arg) ? parseJson(mutableArg) : mutableArg; - } else { - return arg; - } - }); diff --git a/src/logger/cleanup.ts b/src/logger/cleanup.ts new file mode 100644 index 0000000000..b9d0c2f395 --- /dev/null +++ b/src/logger/cleanup.ts @@ -0,0 +1,58 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import * as fs from 'node:fs'; +import { join } from 'node:path'; +import { Global } from '../global'; +import { Logger } from './logger'; + +/** + * the odds of running are 1 in CLEAN_ODDS + * ex: CLEAN_ODDS=100 implies 1 in 100 + * ex: CLEAN_ODDS=1 implies 1 in 1 (run every time) + * */ +const CLEAN_ODDS = 100; +const MAX_FILE_AGE_DAYS = 7; +const MAX_FILE_AGE_MS = 1000 * 60 * 60 * 24 * MAX_FILE_AGE_DAYS; + +const shouldClean = Math.random() * CLEAN_ODDS > CLEAN_ODDS - 1; + +/** + * New logger (Summer 2023) changes how file rotation works. Each day, the logger writes to a new file + * To get old files cleaned up, this can be called when a new root logger is instantiated + * based on CLEAN_ODDS, it could exit OR delete some old log files + * + * to start this without waiting, use void cleanup() + * + * accepts params to override the default behavior (used to cleanup huge log file during perf tests) + */ +export const cleanup = async (maxMs = MAX_FILE_AGE_MS, force = false): Promise => { + if (shouldClean || force) { + try { + const filesToConsider = await fs.promises // get the files in that dir + .readdir(Global.SF_DIR); + + const filesToDelete = getOldLogFiles(filesToConsider, maxMs); + await Promise.all(filesToDelete.map((f) => fs.promises.unlink(join(Global.SF_DIR, f)))); + } catch (e) { + // we never, ever, ever throw since we're not awaiting this promise, so just log a warning + (await Logger.child('cleanup')).warn('Failed to cleanup old log files', e); + } + } +}; + +export const getOldLogFiles = (files: string[], maxMs = MAX_FILE_AGE_MS): string[] => + files + .filter((f) => f.endsWith('.log')) + // map of filename and the date sf-YYYY-MM-DD.log => YYYY-MM-DD + .map((f) => ({ file: f, date: f.match(/sf-(\d{4}-\d{2}-\d{2}).*\.log/)?.[1] })) + .filter(hasDate) + .map((f) => ({ file: f.file, date: new Date(f.date) })) + .filter((f) => f.date < new Date(Date.now() - maxMs)) + .map((f) => f.file); + +const hasDate = (f: unknown): f is { file: string; date: string } => + typeof f === 'object' && f !== null && 'date' in f && typeof f.date === 'string'; diff --git a/src/logger/filters.ts b/src/logger/filters.ts new file mode 100644 index 0000000000..1bace000b9 --- /dev/null +++ b/src/logger/filters.ts @@ -0,0 +1,91 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { isArray, isObject, isString } from '@salesforce/ts-types'; +import { accessTokenRegex, sfdxAuthUrlRegex } from '../util/sfdc'; +export const HIDDEN = 'HIDDEN'; + +type FilteredKeyDefinition = { name: string; regex?: string }; +type FilteredKeyForProcessing = FilteredKeyDefinition & { + hiddenAttrMessage: string; + regexTokens: RegExp; + keyRegex: RegExp; +}; + +type Replacer = (input: T) => T; + +// Match all json attribute values case insensitive: ex. {" Access*^&(*()^* Token " : " 45143075913458901348905 \n\t" ...} +const buildTokens = (expElement: string): RegExp => + new RegExp(`(['"][^'"]*${expElement}[^'"]*['"]\\s*:\\s*)['"][^'"]*['"]`, 'gi'); + +// Match all key value attribute case insensitive: ex. {" key\t" : ' access_token ' , " value " : " dsafgasr431 " ....} +const buildKeyRegex = (expElement: string): RegExp => + RegExp( + `(['"]\\s*key\\s*['"]\\s*:)\\s*['"]\\s*${expElement}\\s*['"]\\s*.\\s*['"]\\s*value\\s*['"]\\s*:\\s*['"]\\s*[^'"]*['"]`, + 'gi' + ); + +// This will redact values when the keys match certain patterns +const FILTERED_KEYS: FilteredKeyDefinition[] = [ + { name: 'sid' }, + { name: 'Authorization' }, + // Any json attribute that contains the words "refresh" and "token" will have the attribute/value hidden + { name: 'refresh_token', regex: 'refresh[^\'"]*token' }, + { name: 'clientsecret' }, +]; + +const FILTERED_KEYS_FOR_PROCESSING: FilteredKeyForProcessing[] = FILTERED_KEYS.map((key) => ({ + ...key, + regexTokens: buildTokens(key.regex ?? key.name), + hiddenAttrMessage: `"<${key.name} - ${HIDDEN}>"`, + keyRegex: buildKeyRegex(key.regex ?? key.name), +})); + +const compose = (...fns: Array>): Replacer => + fns.reduce((prevFn, nextFn) => (value: T) => prevFn(nextFn(value))); + +const replacementFunctions = FILTERED_KEYS_FOR_PROCESSING.flatMap( + (key): Array> => [ + // two functions to run across each key + (input: string): string => input.replace(key.regexTokens, `$1${key.hiddenAttrMessage}`), + (input: string): string => input.replace(key.keyRegex, `$1${key.hiddenAttrMessage}`), + ] +).concat([ + // plus any "generalized" functions that are matching contents regardless of keys + // use these for secrets with known patterns + (input: string): string => + input + .replace(new RegExp(accessTokenRegex, 'g'), '') + .replace(new RegExp(sfdxAuthUrlRegex, 'g'), ''), +]); + +const fullReplacementChain = compose(...replacementFunctions); +/** + * + * @param args you *probably are passing this an object, but it can handle any type + * @returns + */ +export const filterSecrets = (...args: unknown[]): unknown => + args.map((arg) => { + if (!arg) { + return arg; + } + if (isArray(arg)) { + return filterSecrets(...arg); + } + + // Normalize all objects into a string. This includes errors. + if (arg instanceof Buffer) { + return ''; + } + if (isObject(arg)) { + return JSON.parse(fullReplacementChain(JSON.stringify(arg))) as Record; + } + if (isString(arg)) { + return fullReplacementChain(arg); + } + return ''; + }); diff --git a/src/logger/logger.ts b/src/logger/logger.ts new file mode 100644 index 0000000000..74cbd62372 --- /dev/null +++ b/src/logger/logger.ts @@ -0,0 +1,513 @@ +/* + * Copyright (c) 2020, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import * as os from 'node:os'; +import * as path from 'node:path'; + +import { Logger as PinoLogger, pino } from 'pino'; +import { Env } from '@salesforce/kit'; +import { isKeyOf, isString } from '@salesforce/ts-types'; +import { Global, Mode } from '../global'; +import { SfError } from '../sfError'; +import { unwrapArray } from '../util/unwrapArray'; +import { MemoryLogger } from './memoryLogger'; +import { cleanup } from './cleanup'; + +/** + * The common set of `Logger` options. + */ +export interface LoggerOptions { + /** + * The logger name. + */ + name: string; + + /** + * The desired log level. + */ + level?: LoggerLevelValue; + + /** + * Create a logger with the fields set + */ + fields?: Fields; + + /** log to memory instead of to a file. Intended for Unit Testing */ + useMemoryLogger?: boolean; +} + +/** + * Standard `Logger` levels. + * + * **See** {@link https://getpino.io/#/docs/api?id=logger-level |Logger Levels} + */ +export enum LoggerLevel { + TRACE = 10, + DEBUG = 20, + INFO = 30, + WARN = 40, + ERROR = 50, + FATAL = 60, +} + +/** + * Any numeric `Logger` level. + */ +export type LoggerLevelValue = LoggerLevel | number; + +/** + * An object + */ +export type Fields = Record; + +/** + * All possible field value types. + */ +export type FieldValue = string | number | boolean | Fields; + +/** + * Log line interface + */ +export interface LogLine { + name: string; + hostname: string; + pid: string; + log: string; + level: number; + msg: string; + time: string; + v: number; +} + +/** + * A logging abstraction powered by {@link https://github.com/pinojs/pino | Pino} that provides both a default + * logger configuration that will log to the default path, and a way to create custom loggers based on the same foundation. + * + * ``` + * // Gets the root sfdx logger + * const logger = await Logger.root(); + * + * // Creates a child logger of the root sfdx logger with custom fields applied + * const childLogger = await Logger.child('myRootChild', {tag: 'value'}); + * + * // Creates a custom logger unaffiliated with the root logger + * const myCustomLogger = new Logger('myCustomLogger'); + * + * // Creates a child of a custom logger unaffiliated with the root logger with custom fields applied + * const myCustomChildLogger = myCustomLogger.child('myCustomChild', {tag: 'value'}); + * + * // get a raw pino logger from the root instance of Logger + * // you can use these to avoid constructing another Logger wrapper class and to get better type support + * const logger = Logger.getRawRootLogger().child({name: 'foo', otherProp: 'bar'}); + * logger.info({some: 'stuff'}, 'a message'); + * + * + * // get a raw pino logger from the current instance + * const childLogger = await Logger.child('myRootChild', {tag: 'value'}); + * const logger = childLogger.getRawLogger(); + * ``` + * + * **See** https://developer.salesforce.com/docs/atlas.en-us.sfdx_setup.meta/sfdx_setup/sfdx_dev_cli_log_messages.htm + */ +export class Logger { + /** + * The name of the root sfdx `Logger`. + */ + public static readonly ROOT_NAME = 'sf'; + + /** + * The default `LoggerLevel` when constructing new `Logger` instances. + */ + public static readonly DEFAULT_LEVEL = LoggerLevel.WARN; + + /** + * A list of all lower case `LoggerLevel` names. + * + * **See** {@link LoggerLevel} + */ + public static readonly LEVEL_NAMES = Object.values(LoggerLevel) + .filter(isString) + .map((v: string) => v.toLowerCase()); + + // The sfdx root logger singleton + private static rootLogger?: Logger; + + private pinoLogger: PinoLogger; + + private memoryLogger?: MemoryLogger; + /** + * Constructs a new `Logger`. + * + * @param optionsOrName A set of `LoggerOptions` or name to use with the default options. + * + * **Throws** *{@link SfError}{ name: 'RedundantRootLoggerError' }* More than one attempt is made to construct the root + * `Logger`. + */ + public constructor(optionsOrName: LoggerOptions | string) { + const enabled = process.env.SFDX_DISABLE_LOG_FILE !== 'true' && process.env.SF_DISABLE_LOG_FILE !== 'true'; + + const options: LoggerOptions = + typeof optionsOrName === 'string' + ? { name: optionsOrName, level: Logger.DEFAULT_LEVEL, fields: {} } + : optionsOrName; + + if (Logger.rootLogger && options.name === Logger.ROOT_NAME) { + throw new SfError('Can not create another root logger.', 'RedundantRootLoggerError'); + } + + // if there is a rootLogger, use its Pino instance + if (Logger.rootLogger) { + this.pinoLogger = Logger.rootLogger.pinoLogger.child({ ...options.fields, name: options.name }); + this.memoryLogger = Logger.rootLogger.memoryLogger; // if the root was constructed with memory logging, keep that + this.pinoLogger.trace(`Created '${options.name}' child logger instance`); + } else { + const level = computeLevel(options.level); + const commonOptions = { + name: options.name ?? Logger.ROOT_NAME, + base: options.fields ?? {}, + level, + enabled, + }; + if (Boolean(options.useMemoryLogger) || Global.getEnvironmentMode() === Mode.TEST || !enabled) { + this.memoryLogger = new MemoryLogger(); + this.pinoLogger = pino(commonOptions, this.memoryLogger); + } else { + this.pinoLogger = pino({ + ...commonOptions, + transport: { + pipeline: [ + { + target: path.join('..', '..', 'lib', 'logger', 'transformStream'), + }, + getWriteStream(level), + ], + }, + }); + // when a new file logger root is instantiated, we check for old log files. + // but we don't want to wait for it + // and it's async and we can't wait from a ctor anyway + void cleanup(); + } + + Logger.rootLogger = this; + } + } + + /** + * + * Gets the root logger. It's a singleton + * See also getRawLogger if you don't need the root logger + */ + public static async root(): Promise { + return Promise.resolve(this.getRoot()); + } + + /** + * Gets the root logger. It's a singleton + */ + public static getRoot(): Logger { + if (this.rootLogger) { + return this.rootLogger; + } + const rootLogger = (this.rootLogger = new Logger(Logger.ROOT_NAME)); + return rootLogger; + } + + /** + * Destroys the root `Logger`. + * + * @ignore + */ + public static destroyRoot(): void { + if (this.rootLogger) { + this.rootLogger = undefined; + } + } + + /** + * Create a child of the root logger, inheriting this instance's configuration such as `level`, transports, etc. + * + * @param name The name of the child logger. + * @param fields Additional fields included in all log lines. + */ + public static async child(name: string, fields?: Fields): Promise { + return (await Logger.root()).child(name, fields); + } + + /** + * Create a child of the root logger, inheriting this instance's configuration such as `level`, transports, etc. + * + * @param name The name of the child logger. + * @param fields Additional fields included in all log lines. + */ + public static childFromRoot(name: string, fields?: Fields): Logger { + return Logger.getRoot().child(name, fields); + } + + /** + * Gets a numeric `LoggerLevel` value by string name. + * + * @param {string} levelName The level name to convert to a `LoggerLevel` enum value. + * + * **Throws** *{@link SfError}{ name: 'UnrecognizedLoggerLevelNameError' }* The level name was not case-insensitively recognized as a valid `LoggerLevel` value. + * @see {@Link LoggerLevel} + */ + public static getLevelByName(levelName: string): LoggerLevelValue { + levelName = levelName.toUpperCase(); + if (!isKeyOf(LoggerLevel, levelName)) { + throw new SfError(`Invalid log level "${levelName}".`, 'UnrecognizedLoggerLevelNameError'); + } + return LoggerLevel[levelName]; + } + + /** get the bare (pino) logger instead of using the class hierarchy */ + public static getRawRootLogger(): PinoLogger { + return Logger.getRoot().pinoLogger; + } + + /** get the bare (pino) logger instead of using the class hierarchy */ + public getRawLogger(): PinoLogger { + return this.pinoLogger; + } + + /** + * Gets the name of this logger. + */ + public getName(): string { + return (this.pinoLogger.bindings().name as string) ?? ''; + } + + /** + * Gets the current level of this logger. + */ + public getLevel(): LoggerLevelValue { + return this.pinoLogger.levelVal; + } + + /** + * Set the logging level of all streams for this logger. If a specific `level` is not provided, this method will + * attempt to read it from the environment variable `SFDX_LOG_LEVEL`, and if not found, + * {@link Logger.DEFAULT_LOG_LEVEL} will be used instead. For convenience `this` object is returned. + * + * @param {LoggerLevelValue} [level] The logger level. + * + * **Throws** *{@link SfError}{ name: 'UnrecognizedLoggerLevelNameError' }* A value of `level` read from `SFDX_LOG_LEVEL` + * was invalid. + * + * ``` + * // Sets the level from the environment or default value + * logger.setLevel() + * + * // Set the level from the INFO enum + * logger.setLevel(LoggerLevel.INFO) + * + * // Sets the level case-insensitively from a string value + * logger.setLevel(Logger.getLevelByName('info')) + * ``` + */ + public setLevel(level?: LoggerLevelValue): Logger { + if (level == null) { + const logLevelFromEnvVar = new Env().getString('SF_LOG_LEVEL'); + level = logLevelFromEnvVar ? Logger.getLevelByName(logLevelFromEnvVar) : Logger.DEFAULT_LEVEL; + } + this.pinoLogger.level = this.pinoLogger.levels.labels[level] ?? this.pinoLogger.levels.labels[Logger.DEFAULT_LEVEL]; + return this; + } + + /** + * Compares the requested log level with the current log level. Returns true if + * the requested log level is greater than or equal to the current log level. + * + * @param level The requested log level to compare against the currently set log level. + */ + public shouldLog(level: LoggerLevelValue): boolean { + return (typeof level === 'string' ? this.pinoLogger.levelVal : level) >= this.getLevel(); + } + + /** + * Gets an array of log line objects. Each element is an object that corresponds to a log line. + */ + public getBufferedRecords(): LogLine[] { + if (!this.memoryLogger) { + throw new Error('getBufferedRecords is only supported when useMemoryLogging is true'); + } + return (this.memoryLogger?.loggedData as unknown as LogLine[]) ?? []; + } + + /** + * Reads a text blob of all the log lines contained in memory or the log file. + */ + public readLogContentsAsText(): string { + if (this.memoryLogger) { + return this.memoryLogger.loggedData.reduce((accum, line) => { + accum += JSON.stringify(line) + os.EOL; + return accum; + }, ''); + } else { + this.pinoLogger.warn( + 'readLogContentsAsText is not supported for file streams, only used when useMemoryLogging is true' + ); + const content = ''; + return content; + } + } + + /** + * Create a child logger, typically to add a few log record fields. For convenience this object is returned. + * + * @param name The name of the child logger that is emitted w/ log line. Will be prefixed with the parent logger name and `:` + * @param fields Additional fields included in all log lines for the child logger. + */ + public child(name: string, fields: Fields = {}): Logger { + const fullName = `${this.getName()}:${name}`; + const child = new Logger({ name: fullName, fields }); + this.pinoLogger.trace(`Setup child '${fullName}' logger instance`); + + return child; + } + + /** + * Add a field to all log lines for this logger. For convenience `this` object is returned. + * + * @param name The name of the field to add. + * @param value The value of the field to be logged. + */ + public addField(name: string, value: FieldValue): Logger { + this.pinoLogger.setBindings({ ...this.pinoLogger.bindings(), [name]: value }); + return this; + } + + /** + * Logs at `trace` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + // eslint-disable-next-line @typescript-eslint/no-explicit-any + public trace(...args: any[]): Logger { + this.pinoLogger.trace(unwrapArray(args)); + return this; + } + + /** + * Logs at `debug` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + public debug(...args: unknown[]): Logger { + this.pinoLogger.debug(unwrapArray(args)); + return this; + } + + /** + * Logs at `debug` level with filtering applied. + * + * @param cb A callback that returns on array objects to be logged. + */ + // eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function + public debugCallback(cb: () => unknown[] | string): void {} + + /** + * Logs at `info` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + public info(...args: unknown[]): Logger { + this.pinoLogger.info(unwrapArray(args)); + return this; + } + + /** + * Logs at `warn` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + public warn(...args: unknown[]): Logger { + this.pinoLogger.warn(unwrapArray(args)); + return this; + } + + /** + * Logs at `error` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + public error(...args: unknown[]): Logger { + this.pinoLogger.error(unwrapArray(args)); + return this; + } + + /** + * Logs at `fatal` level with filtering applied. For convenience `this` object is returned. + * + * @param args Any number of arguments to be logged. + */ + public fatal(...args: unknown[]): Logger { + // always show fatal to stderr + // IMPORTANT: + // Do not use console.error() here, if fatal() is called from the uncaughtException handler, it + // will be re-thrown and caught again by the uncaughtException handler, causing an infinite loop. + console.log(...args); // eslint-disable-line no-console + this.pinoLogger.fatal(unwrapArray(args)); + return this; + } +} + +/** return various streams that the logger could send data to, depending on the options and env */ +const getWriteStream = (level = 'warn'): pino.TransportSingleOptions => { + // used when debug mode, writes to stdout (colorized) + if (process.env.DEBUG) { + return { + target: 'pino-pretty', + options: { colorize: true }, + }; + } + + // default: we're writing to a rotating file + const rotator = new Map([ + ['1m', new Date().toISOString().split(':').slice(0, 2).join('-')], + ['1h', new Date().toISOString().split(':').slice(0, 1).join('-')], + ['1d', new Date().toISOString().split('T')[0]], + ]); + const logRotationPeriod = new Env().getString('SF_LOG_ROTATION_PERIOD') ?? '1d'; + + return { + // write to a rotating file + target: 'pino/file', + options: { + destination: path.join(Global.SF_DIR, `sf-${rotator.get(logRotationPeriod) ?? rotator.get('1d')}.log`), + mkdir: true, + level, + }, + }; +}; + +export const computeLevel = (optionsLevel?: number | string): string => { + const env = new Env(); + const envValue = isNaN(env.getNumber('SF_LOG_LEVEL') ?? NaN) + ? env.getString('SF_LOG_LEVEL') + : env.getNumber('SF_LOG_LEVEL'); + + if (typeof envValue !== 'undefined') { + return typeof envValue === 'string' ? envValue : numberToLevel(envValue); + } + return levelFromOption(optionsLevel); +}; + +const levelFromOption = (value?: string | number): string => { + switch (typeof value) { + case 'number': + return numberToLevel(value); + case 'string': + return value; + default: + return pino.levels.labels[Logger.DEFAULT_LEVEL]; + } +}; +// /** match a number to a pino level, or if a match isn't found, the next highest level */ +const numberToLevel = (level: number): string => + pino.levels.labels[level] ?? + Object.entries(pino.levels.labels).find(([value]) => Number(value) > level)?.[1] ?? + 'warn'; diff --git a/src/logger/memoryLogger.ts b/src/logger/memoryLogger.ts new file mode 100644 index 0000000000..a88be2c61a --- /dev/null +++ b/src/logger/memoryLogger.ts @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { Writable } from 'node:stream'; +import { unwrapArray } from '../util/unwrapArray'; +import { filterSecrets } from './filters'; + +/** + * Used by test setup to keep UT from writing to disk. + */ +export class MemoryLogger extends Writable { + public loggedData: Array> = []; + + public constructor() { + super({ objectMode: true }); + } + + public _write(chunk: Record, encoding: string, callback: (err?: Error) => void): void { + const filteredChunk = unwrapArray(filterSecrets([chunk])); + this.loggedData.push( + typeof filteredChunk === 'string' + ? (JSON.parse(filteredChunk) as Record) + : (filteredChunk as Record) + ); + callback(); + } +} diff --git a/src/logger/transformStream.ts b/src/logger/transformStream.ts new file mode 100644 index 0000000000..e813204be4 --- /dev/null +++ b/src/logger/transformStream.ts @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { pipeline, Transform } from 'node:stream'; +import { unwrapArray } from '../util/unwrapArray'; +import { filterSecrets } from './filters'; + +// eslint-disable-next-line @typescript-eslint/no-var-requires, @typescript-eslint/no-unsafe-assignment +const build = require('pino-abstract-transport'); + +export default function (): Transform { + // eslint-disable-next-line @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-call + return build( + // eslint-disable-next-line @typescript-eslint/no-explicit-any + (source: any): Transform => { + const myTransportStream = new Transform({ + objectMode: true, + transform(chunk: Record, enc, cb): void { + if (debugAllows(chunk)) { + // uses the original logger's filters. + const filteredChunk = unwrapArray(filterSecrets([chunk])); + const stringified = JSON.stringify(filteredChunk); + this.push(stringified.concat('\n')); + } + cb(); + }, + }); + // eslint-disable-next-line @typescript-eslint/no-empty-function + pipeline(source, myTransportStream, () => {}); + return myTransportStream; + }, + { + // This is needed to be able to pipeline transports. + enablePipelining: true, + } + ); +} + +/** if the DEBUG= is set, see if that matches the logger name. If not, we don't want to keep going */ +const debugAllows = (chunk: Record): boolean => { + if (!process.env.DEBUG || process.env.DEBUG === '*') return true; + if (typeof chunk.name !== 'string') return true; + // turn wildcard patterns into regexes + const regexFromDebug = new RegExp(process.env.DEBUG.replace(/\*/g, '.*')); + if (!regexFromDebug.test(chunk.name)) { + // console.log(`no match : ${chunk.name} for ${process.env.DEBUG}`); + return false; + } else { + // console.log(`match : ${chunk.name} for ${process.env.DEBUG}`); + return true; + } +}; diff --git a/src/messageTransformer.ts b/src/messageTransformer.ts new file mode 100644 index 0000000000..789f8dd12d --- /dev/null +++ b/src/messageTransformer.ts @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +import * as ts from 'typescript'; +import { Messages, StoredMessageMap } from './messages'; + +/** + * + * @experimental + * transforms `messages` references from dynamic run-time to static compile-time values + */ +export const messageTransformer = (): ts.TransformerFactory => { + Messages.importMessagesDirectory(process.cwd()); + const transformerFactory: ts.TransformerFactory = (context) => (sourceFile) => { + if ( + // if there are no messages, no transformation is needed + !sourceFile.statements.some((i) => ts.isImportDeclaration(i) && i.importClause?.getText().includes('Messages')) || + // don't transform the transformer itself + sourceFile.fileName.includes('messageTransformer.ts') + ) { + return sourceFile; + } + + const visitor = (node: ts.Node): ts.VisitResult => { + if (ts.isExpressionStatement(node) && node.getText().includes('importMessagesDirectory')) { + // importMessagesDirectory now happens at compile, not in runtime + // returning undefined removes the node + return ts.factory.createEmptyStatement(); + } + if ( + // transform a runtime load call into hardcoded messages values + // const foo = Messages.load|loadMessages('pluginName', 'messagesFile' ...) => + // const foo = new Messages('pluginName', 'messagesFile', new Map([['key', 'value']])) + ts.isCallExpression(node) && + ts.isPropertyAccessExpression(node.expression) && + node.expression.expression.getText() === 'Messages' && + node.expression.name.getText().includes('load') + ) { + // we always want the first two arguments, which are the plugin name and the messages file name + const arrayMembers = node.arguments.slice(0, 2); + const arrayMembersText = arrayMembers.map(getTextWithoutQuotes); + + // Messages doesn't care whether you call messages.load or loadMessages, it loads the whole file + const messagesInstance = Messages.loadMessages(arrayMembersText[0], arrayMembersText[1]); + return context.factory.createNewExpression(node.expression.expression, undefined, [ + arrayMembers[0], + arrayMembers[1], + context.factory.createNewExpression(context.factory.createIdentifier('Map'), undefined, [ + messageMapToHardcodedMap(messagesInstance.messages), + ]), + ]); + } + // it might be a node that contains one of the things we're interested in, so keep digging + return ts.visitEachChild(node, visitor, context); + }; + return ts.visitNode(sourceFile, visitor, ts.isSourceFile); + }; + return transformerFactory; +}; + +export default messageTransformer; + +const getTextWithoutQuotes = (node: ts.Node): string => node.getText().replace(/'/g, ''); + +/** turn a loaded message map into */ +const messageMapToHardcodedMap = (messages: StoredMessageMap): ts.ArrayLiteralExpression => + ts.factory.createArrayLiteralExpression( + Array.from(messages).map(([key, value]) => { + // case 1: string + if (typeof value === 'string') { + return ts.factory.createArrayLiteralExpression([ + ts.factory.createStringLiteral(key), + ts.factory.createStringLiteral(value), + ]); + } else if (Array.isArray(value)) { + // case 2: string[] + return ts.factory.createArrayLiteralExpression([ + ts.factory.createStringLiteral(key), + ts.factory.createArrayLiteralExpression(value.map((v) => ts.factory.createStringLiteral(v))), + ]); + } else { + // turn the object into a map and recurse! + return messageMapToHardcodedMap(new Map(Object.entries(value))); + } + }) + ); diff --git a/src/messages.ts b/src/messages.ts index bfb35628a3..280eebde7b 100644 --- a/src/messages.ts +++ b/src/messages.ts @@ -5,10 +5,11 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as fs from 'fs'; -import * as os from 'os'; -import * as path from 'path'; -import * as util from 'util'; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import * as path from 'node:path'; +import * as util from 'node:util'; +import { fileURLToPath } from 'node:url'; import { AnyJson, asString, ensureJsonMap, ensureString, isJsonMap, isObject } from '@salesforce/ts-types'; import { ensureArray, NamedError, upperFirst } from '@salesforce/kit'; import { SfError } from './sfError'; @@ -172,6 +173,9 @@ const jsAndJsonLoader: FileParser = (filePath: string, fileContents: string): St * // Create loader functions for all files in the messages directory * Messages.importMessagesDirectory(__dirname); * + * // or, for ESM code + * Messages.importMessagesDirectoryFromMetaUrl(import.meta.url) + * * // Now you can use the messages from anywhere in your code or file. * // If using importMessageDirectory, the bundle name is the file name. * const messages: Messages = Messages.loadMessages(packageName, bundleName); @@ -300,6 +304,22 @@ export class Messages { } } + /** + * Support ESM plugins who can't use __dirname + * + * @param metaUrl pass in `import.meta.url` + * @param truncateToProjectPath Will look for the messages directory in the project root (where the package.json file is located). + * i.e., the module is typescript and the messages folder is in the top level of the module directory. + * @param packageName The npm package name. Figured out from the root directory's package.json. + */ + public static importMessagesDirectoryFromMetaUrl( + metaUrl: string, + truncateToProjectPath = true, + packageName?: string + ): void { + return Messages.importMessagesDirectory(path.dirname(fileURLToPath(metaUrl)), truncateToProjectPath, packageName); + } + /** * Import all json and js files in a messages directory. Use the file name as the bundle key when * {@link Messages.loadMessages} is called. By default, we're assuming the moduleDirectoryPart is a @@ -406,49 +426,6 @@ export class Messages { throw new NamedError('MissingBundleError', `Missing bundle ${key} for locale ${Messages.getLocale()}.`); } - /** - * - * @deprecated Use {@link Messages.loadMessages} instead. - * @param packageName The name of the npm package. - * @param bundleName The name of the bundle to load. - * @param keys The message keys that will be used. - */ - public static load(packageName: string, bundleName: string, keys: [T, ...T[]]): Messages { - const key = getKey(packageName, bundleName); - let messages: Messages | undefined; - - if (this.isCached(packageName, bundleName)) { - messages = this.bundles.get(key); - } else if (this.loaders.has(key)) { - const loader = this.loaders.get(key); - if (loader) { - messages = loader(Messages.getLocale()); - this.bundles.set(key, messages); - messages = this.bundles.get(key); - } - } - - if (messages) { - // Type guard on key length, but do a runtime check. - if (!keys || keys.length === 0) { - throw new NamedError( - 'MissingKeysError', - 'Can not load messages without providing the message keys that will be used.' - ); - } - - // Get all messages to validate they are actually present - for (const messageKey of keys) { - messages.getMessage(messageKey); - } - - return messages; - } - - // Don't use messages inside messages - throw new NamedError('MissingBundleError', `Missing bundle ${key} for locale ${Messages.getLocale()}.`); - } - /** * Check if a bundle already been loaded. * @@ -527,36 +504,6 @@ export class Messages { return new SfError(message, name, actions, exitCodeOrCause, cause); } - /** - * SfError wants error names to end with the suffix Error. Use this to create errors while preserving their existing name (for compatibility reasons). - * - * @deprecated Use `createError` instead unless you need to preserver the error name to avoid breaking changes. - * `error.name` will be the upper-cased key, remove prefixed `error.`. - * `error.actions` will be loaded using `${key}.actions` if available. - * - * @param key The key of the error message. - * @param tokens The error message tokens. - * @param actionTokens The action messages tokens. - * @param exitCodeOrCause The exit code which will be used by SfdxCommand or the underlying error that caused this error to be raised. - * @param cause The underlying error that caused this error to be raised. - */ - public createErrorButPreserveName( - key: T, - tokens: Tokens = [], - actionTokens: Tokens = [], - exitCodeOrCause?: number | Error, - cause?: Error - ): SfError { - const { message, name, actions } = this.formatMessageContents({ - type: 'error', - key, - tokens, - actionTokens, - preserveName: true, - }); - return new SfError(message, name, actions, exitCodeOrCause, cause); - } - /** * Convenience method to create warning using message labels. * @@ -617,7 +564,7 @@ export class Messages { // 'myMessage' -> `MyMessageWarning` // 'myMessageError' -> `MyMessageError` // 'warning.myMessage' -> `MyMessageWarning` - const name = `${upperFirst(key.replace(searchValue, ''))}${labelRegExp.exec(key) || preserveName ? '' : label}`; + const name = `${upperFirst(key.replace(searchValue, ''))}${labelRegExp.exec(key) ?? preserveName ? '' : label}`; const message = this.getMessage(key, tokens); let actions; try { diff --git a/src/org/authInfo.ts b/src/org/authInfo.ts index 8894ec2fab..d0a1fc6e17 100644 --- a/src/org/authInfo.ts +++ b/src/org/authInfo.ts @@ -6,11 +6,12 @@ */ /* eslint-disable class-methods-use-this */ -import { randomBytes } from 'crypto'; -import { resolve as pathResolve } from 'path'; -import * as os from 'os'; -import * as fs from 'fs'; -import { AsyncOptionalCreatable, cloneJson, env, isEmpty, parseJson, parseJsonMap } from '@salesforce/kit'; +import { randomBytes } from 'node:crypto'; +import { resolve as pathResolve } from 'node:path'; +import * as os from 'node:os'; +import * as fs from 'node:fs'; +import { Record as RecordType } from 'jsforce'; +import { AsyncOptionalCreatable, env, isEmpty, parseJson, parseJsonMap } from '@salesforce/kit'; import { AnyJson, asString, @@ -25,20 +26,20 @@ import { Nullable, Optional, } from '@salesforce/ts-types'; -import { JwtOAuth2, JwtOAuth2Config, OAuth2, TokenResponse } from 'jsforce'; +import { OAuth2Config, OAuth2, TokenResponse } from 'jsforce'; import Transport from 'jsforce/lib/transport'; import * as jwt from 'jsonwebtoken'; import { Config } from '../config/config'; import { ConfigAggregator } from '../config/configAggregator'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { matchesAccessToken, trimTo15 } from '../util/sfdc'; -import { StateAggregator } from '../stateAggregator'; +import { StateAggregator } from '../stateAggregator/stateAggregator'; import { Messages } from '../messages'; import { getLoginAudienceCombos, SfdcUrl } from '../util/sfdcUrl'; import { Connection, SFDX_HTTP_HEADERS } from './connection'; import { OrgConfigProperties } from './orgConfigProperties'; -import { Org } from './org'; +import { Org, SandboxFields } from './org'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'core'); @@ -111,6 +112,14 @@ export type AuthSideEffects = { setTracksSource?: boolean; }; +export type JwtOAuth2Config = OAuth2Config & { + privateKey?: string; + privateKeyFile?: string; + authCode?: string; + refreshToken?: string; + username?: string; +}; + type UserInfo = AnyJson & { username: string; organizationId: string; @@ -234,7 +243,7 @@ export class AuthInfo extends AsyncOptionalCreatable { * @returns {string} */ public static getDefaultInstanceUrl(): string { - const configuredInstanceUrl = ConfigAggregator.getValue(OrgConfigProperties.ORG_INSTANCE_URL).value as string; + const configuredInstanceUrl = ConfigAggregator.getValue(OrgConfigProperties.ORG_INSTANCE_URL)?.value as string; return configuredInstanceUrl ?? SfdcUrl.PRODUCTION; } @@ -353,7 +362,7 @@ export class AuthInfo extends AsyncOptionalCreatable { sfdxAuthUrl: string ): Pick { const match = sfdxAuthUrl.match( - /^force:\/\/([a-zA-Z0-9._-]+):([a-zA-Z0-9._-]*):([a-zA-Z0-9._-]+={0,2})@([a-zA-Z0-9._-]+)/ + /^force:\/\/([a-zA-Z0-9._-]+={0,2}):([a-zA-Z0-9._-]*={0,2}):([a-zA-Z0-9._-]+={0,2})@([a-zA-Z0-9._-]+)/ ); if (!match) { @@ -373,7 +382,7 @@ export class AuthInfo extends AsyncOptionalCreatable { /** * Given a set of decrypted fields and an authInfo, determine if the org belongs to an available - * dev hub. + * dev hub, or if the org is a sandbox of another CLI authed production org. * * @param fields * @param orgAuthInfo @@ -384,21 +393,29 @@ export class AuthInfo extends AsyncOptionalCreatable { // authInfo before it is necessary. const logger = await Logger.child('Common', { tag: 'identifyPossibleScratchOrgs' }); - // return if we already know the hub org we know it is a devhub or prod-like or no orgId present - if (fields.isDevHub || fields.devHubUsername || !fields.orgId) return; + // return if we already know the hub org, we know it is a devhub or prod-like, or no orgId present + if (Boolean(fields.isDevHub) || Boolean(fields.devHubUsername) || !fields.orgId) return; - logger.debug('getting devHubs'); + logger.debug('getting devHubs and prod orgs to identify scratch orgs and sandboxes'); // TODO: return if url is not sandbox-like to avoid constantly asking about production orgs // TODO: someday we make this easier by asking the org if it is a scratch org const hubAuthInfos = await AuthInfo.getDevHubAuthInfos(); + // Get a list of org auths that are known not to be scratch orgs or sandboxes. + const possibleProdOrgs = await AuthInfo.listAllAuthorizations( + (orgAuth) => orgAuth && !orgAuth.isScratchOrg && !orgAuth.isSandbox + ); + logger.debug(`found ${hubAuthInfos.length} DevHubs`); - if (hubAuthInfos.length === 0) return; + logger.debug(`found ${possibleProdOrgs.length} possible prod orgs`); + if (hubAuthInfos.length === 0 && possibleProdOrgs.length === 0) { + return; + } // ask all those orgs if they know this orgId - await Promise.all( - hubAuthInfos.map(async (hubAuthInfo) => { + await Promise.all([ + ...hubAuthInfos.map(async (hubAuthInfo) => { try { const soi = await AuthInfo.queryScratchOrg(hubAuthInfo.username, fields.orgId as string); // if any return a result @@ -419,10 +436,17 @@ export class AuthInfo extends AsyncOptionalCreatable { logger.debug(`error updating auth file for ${orgAuthInfo.getUsername()}`, error); } } catch (error) { - logger.error(`Error connecting to devhub ${hubAuthInfo.username}`, error); + if (error instanceof Error && error.name === 'NoActiveScratchOrgFound') { + logger.error(`devhub ${hubAuthInfo.username} has no scratch orgs`, error); + } else { + logger.error(`Error connecting to devhub ${hubAuthInfo.username}`, error); + } } - }) - ); + }), + ...possibleProdOrgs.map(async (pOrgAuthInfo) => { + await AuthInfo.identifyPossibleSandbox(pOrgAuthInfo, fields, orgAuthInfo, logger); + }), + ]); } /** @@ -432,16 +456,83 @@ export class AuthInfo extends AsyncOptionalCreatable { return AuthInfo.listAllAuthorizations((possibleHub) => possibleHub?.isDevHub ?? false); } + private static async identifyPossibleSandbox( + possibleProdOrg: OrgAuthorization, + fields: AuthFields, + orgAuthInfo: AuthInfo, + logger: Logger + ): Promise { + if (!fields.orgId) { + return; + } + + try { + const prodOrg = await Org.create({ aliasOrUsername: possibleProdOrg.username }); + const sbxProcess = await prodOrg.querySandboxProcessByOrgId(fields.orgId); + if (!sbxProcess?.SandboxInfoId) { + return; + } + logger.debug(`${fields.orgId} is a sandbox of ${possibleProdOrg.username}`); + + try { + await orgAuthInfo.save({ + ...fields, + isScratch: false, + isSandbox: true, + }); + } catch (err) { + logger.debug(`error updating auth file for: ${orgAuthInfo.getUsername()}`, err); + throw err; // rethrow; don't want a sandbox config file with an invalid auth file + } + + try { + // set the sandbox config value + const sfSandbox: SandboxFields = { + sandboxUsername: fields.username, + sandboxOrgId: fields.orgId, + prodOrgUsername: possibleProdOrg.username, + sandboxName: sbxProcess.SandboxName, + sandboxProcessId: sbxProcess.Id, + sandboxInfoId: sbxProcess.SandboxInfoId, + timestamp: new Date().toISOString(), + }; + + const stateAggregator = await StateAggregator.getInstance(); + stateAggregator.sandboxes.set(fields.orgId, sfSandbox); + logger.debug(`writing sandbox auth file for: ${orgAuthInfo.getUsername()} with ID: ${fields.orgId}`); + await stateAggregator.sandboxes.write(fields.orgId); + } catch (e) { + logger.debug(`error writing sandbox auth file for: ${orgAuthInfo.getUsername()}`, e); + } + } catch (err) { + logger.debug(`${fields.orgId} is not a sandbox of ${possibleProdOrg.username}`); + } + } + + /** + * Checks active scratch orgs to match by the ScratchOrg field (the 15-char org id) + * if you pass an 18-char scratchOrgId, it will be trimmed to 15-char for query purposes + * Throws is no matching scratch org is found + */ private static async queryScratchOrg( devHubUsername: string | undefined, scratchOrgId: string ): Promise<{ Id: string; ExpirationDate: string }> { const devHubOrg = await Org.create({ aliasOrUsername: devHubUsername }); + const trimmedId = trimTo15(scratchOrgId); const conn = devHubOrg.getConnection(); - const data = await conn.singleRecordQuery<{ Id: string; ExpirationDate: string }>( - `select Id, ExpirationDate from ScratchOrgInfo where ScratchOrg = '${trimTo15(scratchOrgId)}'` + const data = await conn.query<{ Id: string; ExpirationDate: string; ScratchOrg: string }>( + `select Id, ExpirationDate, ScratchOrg from ScratchOrgInfo where ScratchOrg = '${trimmedId}' and Status = 'Active'` + ); + // where ScratchOrg='00DDE00000485Lg' will return a record for both 00DDE00000485Lg and 00DDE00000485LG. + // this is our way of enforcing case sensitivity on a 15-char Id (which is unfortunately how ScratchOrgInfo stores it) + const result = data.records.filter((r) => r.ScratchOrg === trimmedId)[0]; + if (result) return result; + + throw new SfError( + `DevHub ${devHubUsername} has no active scratch orgs that match ${trimmedId}`, + 'NoActiveScratchOrgFound' ); - return data; } /** @@ -573,8 +664,10 @@ export class AuthInfo extends AsyncOptionalCreatable { * Get the authorization fields. * * @param decrypt Decrypt the fields. + * + * Returns a ReadOnly object of the fields. If you need to modify the fields, use AuthInfo.update() */ - public getFields(decrypt?: boolean): AuthFields { + public getFields(decrypt?: boolean): Readonly { return this.stateAggregator.orgs.get(this.username, decrypt) ?? {}; } @@ -622,7 +715,7 @@ export class AuthInfo extends AsyncOptionalCreatable { */ public async handleAliasAndDefaultSettings(sideEffects: AuthSideEffects): Promise { if ( - sideEffects.alias || + Boolean(sideEffects.alias) || sideEffects.setDefault || sideEffects.setDefaultDevHub || typeof sideEffects.setTracksSource === 'boolean' @@ -754,7 +847,7 @@ export class AuthInfo extends AsyncOptionalCreatable { let authConfig: AuthFields; if (options) { - options = cloneJson(options); + options = structuredClone(options); if (this.isTokenOptions(options)) { authConfig = options; @@ -804,6 +897,15 @@ export class AuthInfo extends AsyncOptionalCreatable { ensureString(authConfig.accessToken) ); + const namespacePrefix = await this.getNamespacePrefix( + ensureString(authConfig.instanceUrl), + ensureString(authConfig.accessToken) + ); + + if (namespacePrefix) { + authConfig.namespacePrefix = namespacePrefix; + } + if (authConfig.username) await this.stateAggregator.orgs.read(authConfig.username, false, false); // Update the auth fields WITH encryption @@ -938,10 +1040,14 @@ export class AuthInfo extends AsyncOptionalCreatable { } ); - const oauth2 = new JwtOAuth2({ loginUrl }); - // jsforce has it types as any - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - return ensureJsonMap(await oauth2.jwtAuthorize(jwtToken)); + const oauth2 = new OAuth2({ loginUrl }); + return ensureJsonMap( + await oauth2.requestToken({ + // eslint-disable-next-line camelcase + grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer', + assertion: jwtToken, + }) + ); } // Build OAuth config for a refresh token auth flow @@ -1050,7 +1156,7 @@ export class AuthInfo extends AsyncOptionalCreatable { this.throwUserGetException(response); } else { const userInfoJson = parseJsonMap(response.body) as UserInfoResult; - const url = `${baseUrl.toString()}/services/data/${apiVersion}/sobjects/User/${userInfoJson.user_id}`; + const url = `${baseUrl.toString()}services/data/${apiVersion}/sobjects/User/${userInfoJson.user_id}`; this.logger.info(`Sending request for User SObject after successful auth code exchange to URL: ${url}`); response = await new Transport().httpRequest({ url, method: 'GET', headers }); if (response.statusCode >= 400) { @@ -1088,6 +1194,32 @@ export class AuthInfo extends AsyncOptionalCreatable { throw new SfError(errorMsg); } + private async getNamespacePrefix(instanceUrl: string, accessToken: string): Promise { + // Make a REST call for the Organization obj directly. Normally this is done via a connection + // but we don't want to create circular dependencies or lots of snowflakes + // within this file to support it. + const apiVersion = 'v51.0'; // hardcoding to v51.0 just for this call is okay. + const instance = ensure(instanceUrl); + const baseUrl = new SfdcUrl(instance); + const namespacePrefixOrgUrl = `${baseUrl.toString()}/services/data/${apiVersion}/query?q=Select%20Namespaceprefix%20FROM%20Organization`; + const headers = Object.assign({ Authorization: `Bearer ${accessToken}` }, SFDX_HTTP_HEADERS); + + try { + const res = await new Transport().httpRequest({ url: namespacePrefixOrgUrl, method: 'GET', headers }); + if (res.statusCode >= 400) { + return; + } + + const namespacePrefix = JSON.parse(res.body) as { + records: RecordType[]; + }; + + return ensureString(namespacePrefix.records[0]?.NamespacePrefix); + } catch (err) { + /* Doesn't have a namespace */ + return; + } + } /** * Returns `true` if the org is a Dev Hub. * diff --git a/src/org/authRemover.ts b/src/org/authRemover.ts index f0f6440237..1b2a3e211a 100644 --- a/src/org/authRemover.ts +++ b/src/org/authRemover.ts @@ -8,11 +8,11 @@ import { AsyncOptionalCreatable } from '@salesforce/kit'; import { JsonMap } from '@salesforce/ts-types'; import { ConfigAggregator } from '../config/configAggregator'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; -import { StateAggregator } from '../stateAggregator'; +import { StateAggregator } from '../stateAggregator/stateAggregator'; import { OrgConfigProperties } from './orgConfigProperties'; -import { AuthFields } from '.'; +import { AuthFields } from './authInfo'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'auth'); @@ -55,7 +55,6 @@ export class AuthRemover extends AsyncOptionalCreatable { this.logger.debug(`Removing authorization for user ${username}`); await this.unsetConfigValues(username); await this.unsetAliases(username); - await this.unsetTokens(username); await this.stateAggregator.orgs.remove(username); } @@ -186,15 +185,4 @@ export class AuthRemover extends AsyncOptionalCreatable { existingAliases.forEach((alias) => this.stateAggregator.aliases.unset(alias)); await this.stateAggregator.aliases.write(); } - - private async unsetTokens(username: string): Promise { - this.logger.debug(`Clearing tokens for username: ${username}`); - const tokens = this.stateAggregator.tokens.getAll(); - for (const [key, token] of Object.entries(tokens)) { - if (token.user === username) { - this.stateAggregator.tokens.unset(key); - } - } - await this.stateAggregator.tokens.write(); - } } diff --git a/src/org/connection.ts b/src/org/connection.ts index e365ccd930..df781e73e1 100644 --- a/src/org/connection.ts +++ b/src/org/connection.ts @@ -7,10 +7,10 @@ /* eslint-disable @typescript-eslint/ban-ts-comment */ -import { URL } from 'url'; +import { URL } from 'node:url'; import { AsyncResult, DeployOptions, DeployResultLocator } from 'jsforce/api/metadata'; import { Duration, env, maxBy } from '@salesforce/kit'; -import { asString, ensure, isString, JsonCollection, JsonMap, Optional } from '@salesforce/ts-types'; +import { asString, ensure, isString, JsonMap, Optional } from '@salesforce/ts-types'; import { Connection as JSForceConnection, ConnectionConfig, @@ -25,7 +25,7 @@ import { Tooling as JSForceTooling } from 'jsforce/lib/api/tooling'; import { StreamPromise } from 'jsforce/lib/util/promise'; import { MyDomainResolver } from '../status/myDomainResolver'; import { ConfigAggregator } from '../config/configAggregator'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { validateApiVersion } from '../util/sfdc'; import { Messages } from '../messages'; @@ -43,7 +43,6 @@ export const SFDX_HTTP_HEADERS = { }; export const DNS_ERROR_NAME = 'DomainNotFoundError'; -type recentValidationOptions = { id: string; rest?: boolean }; export type DeployOptionsWithRest = Partial & { rest?: boolean }; export interface Tooling extends JSForceTooling { @@ -203,7 +202,7 @@ export class Connection extends JSForceConnection ...SFDX_HTTP_HEADERS, ...lowercasedHeaders, }; - this.logger.debug(`request: ${JSON.stringify(httpRequest)}`); + this.logger.getRawLogger().debug(httpRequest, 'request'); return super.request(httpRequest, options); } @@ -216,19 +215,6 @@ export class Connection extends JSForceConnection return super._baseUrl(); } - /** - * Will deploy a recently validated deploy request - directly calling jsforce now that this is supported. - * WARNING: will always return a string from jsforce, the type is JsonCollection to support backwards compatibility - * - * @param options.id = the deploy ID that's been validated already from a previous checkOnly deploy request - * @param options.rest = a boolean whether or not to use the REST API - * @deprecated use {@link Connection.metadata#deployRecentValidation} instead - the jsforce implementation, instead of this wrapper - */ - public async deployRecentValidation(options: recentValidationOptions): Promise { - // REST returns an object with an id property, SOAP returns the id as a string directly. That is now handled - // in jsforce, so we have to cast a string as unknown as JsonCollection to support backwards compatibility. - return (await this.metadata.deployRecentValidation(options)) as unknown as JsonCollection; - } /** * Retrieves the highest api version that is supported by the target server instance. */ @@ -396,7 +382,7 @@ export class Connection extends JSForceConnection void Lifecycle.getInstance().emitWarning( `The query result is missing ${ query.totalSize - query.records.length - } records due to a ${maxFetch} record limit. Increase the number of records returned by setting the config value "maxQueryLimit" or the environment variable "SFDX_MAX_QUERY_LIMIT" to ${ + } records due to a ${maxFetch} record limit. Increase the number of records returned by setting the config value "maxQueryLimit" or the environment variable "SF_ORG_MAX_QUERY_LIMIT" to ${ query.totalSize } or greater than ${maxFetch}.` ); diff --git a/src/org/index.ts b/src/org/index.ts deleted file mode 100644 index 684f6b8d31..0000000000 --- a/src/org/index.ts +++ /dev/null @@ -1,13 +0,0 @@ -/* - * Copyright (c) 2020, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -export * from './authInfo'; -export * from './authRemover'; -export * from './connection'; -export * from './org'; -export * from './permissionSetAssignment'; -export * from './user'; diff --git a/src/org/org.ts b/src/org/org.ts index 55ed85c82d..78fa75a00c 100644 --- a/src/org/org.ts +++ b/src/org/org.ts @@ -6,8 +6,8 @@ */ /* eslint-disable class-methods-use-this */ -import { join as pathJoin } from 'path'; -import * as fs from 'fs'; +import { join as pathJoin } from 'node:path'; +import * as fs from 'node:fs'; import { AsyncOptionalCreatable, Duration } from '@salesforce/kit'; import { AnyFunction, @@ -15,27 +15,25 @@ import { ensure, ensureJsonArray, ensureString, - isArray, isBoolean, isString, JsonArray, JsonMap, Nullable, - Optional, } from '@salesforce/ts-types'; import { HttpRequest, SaveResult } from 'jsforce'; import { Config } from '../config/config'; import { ConfigAggregator } from '../config/configAggregator'; -import { ConfigContents } from '../config/configStore'; +import { ConfigContents } from '../config/configStackTypes'; import { OrgUsersConfig } from '../config/orgUsersConfig'; import { Global } from '../global'; import { Lifecycle } from '../lifecycleEvents'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { trimTo15 } from '../util/sfdc'; import { WebOAuthServer } from '../webOAuthServer'; import { Messages } from '../messages'; -import { StateAggregator } from '../stateAggregator'; +import { StateAggregator } from '../stateAggregator/stateAggregator'; import { PollingClient } from '../status/pollingClient'; import { StatusResult } from '../status/types'; import { Connection, SingleRecordQueryErrors } from './connection'; @@ -83,6 +81,7 @@ export enum SandboxEvents { EVENT_RESULT = 'result', EVENT_AUTH = 'auth', EVENT_RESUME = 'resume', + EVENT_MULTIPLE_SBX_PROCESSES = 'multipleMatchingSbxProcesses', } export interface SandboxUserAuthResponse { @@ -134,6 +133,7 @@ export type SandboxFields = { sandboxUsername?: string; sandboxProcessId?: string; sandboxInfoId?: string; + timestamp?: string; }; /** @@ -167,7 +167,7 @@ export class Org extends AsyncOptionalCreatable { private configAggregator!: ConfigAggregator; // Initialized in create - private logger!: Logger; + private logger!: ReturnType; private connection!: Connection; private options: Org.Options; @@ -197,18 +197,16 @@ export class Org extends AsyncOptionalCreatable { interval: Duration.seconds(30), } ): Promise { - this.logger.debug(`CreateSandbox called with SandboxRequest: ${JSON.stringify(sandboxReq, undefined, 2)}`); + this.logger.debug(sandboxReq, 'CreateSandbox called with SandboxRequest'); const createResult = await this.connection.tooling.create('SandboxInfo', sandboxReq); - this.logger.debug(`Return from calling tooling.create: ${JSON.stringify(createResult, undefined, 2)}`); + this.logger.debug(createResult, 'Return from calling tooling.create'); if (Array.isArray(createResult) || !createResult.success) { throw messages.createError('sandboxInfoCreateFailed', [JSON.stringify(createResult)]); } const sandboxCreationProgress = await this.querySandboxProcessBySandboxInfoId(createResult.id); - this.logger.debug( - `Return from calling singleRecordQuery with tooling: ${JSON.stringify(sandboxCreationProgress, undefined, 2)}` - ); + this.logger.debug(sandboxCreationProgress, 'Return from calling singleRecordQuery with tooling'); const isAsync = !!options.async; @@ -219,11 +217,8 @@ export class Org extends AsyncOptionalCreatable { } const [wait, pollInterval] = this.validateWaitOptions(options); this.logger.debug( - `create - pollStatusAndAuth sandboxProcessObj ${JSON.stringify( - sandboxCreationProgress, - undefined, - 2 - )}, max wait time of ${wait.minutes} minutes` + sandboxCreationProgress, + `create - pollStatusAndAuth sandboxProcessObj, max wait time of ${wait.minutes} minutes` ); return this.pollStatusAndAuth({ sandboxProcessObj: sandboxCreationProgress, @@ -245,16 +240,16 @@ export class Org extends AsyncOptionalCreatable { options: { wait?: Duration; interval?: Duration } ): Promise { sandboxReq.SourceId = (await this.querySandboxProcessBySandboxName(sourceSandboxName)).SandboxInfoId; - this.logger.debug('Clone sandbox sourceId %s', sandboxReq.SourceId); + this.logger.debug(`Clone sandbox sourceId ${sandboxReq.SourceId}`); return this.createSandbox(sandboxReq, options); } /** - * resume a sandbox creation from a production org - * 'this' needs to be a production org with sandbox licenses available + * Resume a sandbox creation from a production org. + * `this` needs to be a production org with sandbox licenses available. * * @param resumeSandboxRequest SandboxRequest options to create the sandbox with - * @param options Wait: The amount of time to wait (default: 30 minutes) before timing out, + * @param options Wait: The amount of time to wait (default: 0 minutes) before timing out, * Interval: The time interval (default: 30 seconds) between polling */ public async resumeSandbox( @@ -265,23 +260,32 @@ export class Org extends AsyncOptionalCreatable { interval: Duration.seconds(30), } ): Promise { - this.logger.debug( - `ResumeSandbox called with ResumeSandboxRequest: ${JSON.stringify(resumeSandboxRequest, undefined, 2)}` - ); + this.logger.debug(resumeSandboxRequest, 'ResumeSandbox called with ResumeSandboxRequest'); let sandboxCreationProgress: SandboxProcessObject; // seed the sandboxCreationProgress via the resumeSandboxRequest options - if (resumeSandboxRequest.SandboxName) { - sandboxCreationProgress = await this.querySandboxProcessBySandboxName(resumeSandboxRequest.SandboxName); - } else if (resumeSandboxRequest.SandboxProcessObjId) { + if (resumeSandboxRequest.SandboxProcessObjId) { sandboxCreationProgress = await this.querySandboxProcessById(resumeSandboxRequest.SandboxProcessObjId); + } else if (resumeSandboxRequest.SandboxName) { + try { + // There can be multiple sandbox processes returned when querying by name. Use the most recent + // process and fire a warning event with all processes. + sandboxCreationProgress = await this.querySandboxProcessBySandboxName(resumeSandboxRequest.SandboxName); + } catch (err) { + if (err instanceof SfError && err.name === 'SingleRecordQuery_MultipleRecords' && err.data) { + const sbxProcesses = err.data as SandboxProcessObject[]; + // 0 index will always be the most recently created process since the query sorts on created date desc. + sandboxCreationProgress = sbxProcesses[0]; + await Lifecycle.getInstance().emit(SandboxEvents.EVENT_MULTIPLE_SBX_PROCESSES, sbxProcesses); + } else { + throw err; + } + } } else { throw messages.createError('sandboxNotFound', [ resumeSandboxRequest.SandboxName ?? resumeSandboxRequest.SandboxProcessObjId, ]); } - this.logger.debug( - `Return from calling singleRecordQuery with tooling: ${JSON.stringify(sandboxCreationProgress, undefined, 2)}` - ); + this.logger.debug(sandboxCreationProgress, 'Return from calling singleRecordQuery with tooling'); if (!sandboxIsResumable(sandboxCreationProgress.Status)) { throw messages.createError('sandboxNotResumable', [ @@ -301,7 +305,7 @@ export class Org extends AsyncOptionalCreatable { if (sandboxInfo) { await Lifecycle.getInstance().emit(SandboxEvents.EVENT_AUTH, sandboxInfo); try { - this.logger.debug(`sandbox signup complete with ${JSON.stringify(sandboxInfo, undefined, 2)}`); + this.logger.debug(sandboxInfo, 'sandbox signup complete'); await this.writeSandboxAuthFile(sandboxCreationProgress, sandboxInfo); return sandboxCreationProgress; } catch (err) { @@ -314,11 +318,8 @@ export class Org extends AsyncOptionalCreatable { } this.logger.debug( - `resume - pollStatusAndAuth sandboxProcessObj ${JSON.stringify( - sandboxCreationProgress, - undefined, - 2 - )}, max wait time of ${wait.minutes} minutes` + sandboxCreationProgress, + `resume - pollStatusAndAuth sandboxProcessObj, max wait time of ${wait.minutes} minutes` ); return this.pollStatusAndAuth({ sandboxProcessObj: sandboxCreationProgress, @@ -455,7 +456,7 @@ export class Org extends AsyncOptionalCreatable { /** * Returns the Org object or null if this org is not affiliated with a Dev Hub (according to the local config). */ - public async getDevHubOrg(): Promise> { + public async getDevHubOrg(): Promise { if (this.isDevHubOrg()) { return this; } else if (this.getField(Org.Fields.DEV_HUB_USERNAME)) { @@ -507,6 +508,16 @@ export class Org extends AsyncOptionalCreatable { * Will delete 'this' instance remotely and any files locally */ public async delete(): Promise { + const username = ensureString(this.getUsername()); + + // unset any aliases referencing this org + const stateAgg = await StateAggregator.getInstance(); + const existingAliases = stateAgg.aliases.getAll(username); + await stateAgg.aliases.unsetValuesAndSave(existingAliases); + + // unset any configs referencing this org + [...existingAliases, username].flatMap((name) => this.configAggregator.unsetByValue(name)); + if (await this.isSandbox()) { await this.deleteSandbox(); } else { @@ -615,13 +626,12 @@ export class Org extends AsyncOptionalCreatable { * using {@link Org.retrieveOrganizationInformation}. */ public async determineIfScratch(): Promise { - let cache = this.getField(Org.Fields.IS_SCRATCH); - - if (!cache) { - await this.updateLocalInformation(); - cache = this.getField(Org.Fields.IS_SCRATCH); + const cache = this.getField(Org.Fields.IS_SCRATCH); + if (cache !== undefined) { + return cache; } - return cache as boolean; + const updated = await this.updateLocalInformation(); + return updated?.isScratch === true; } /** @@ -632,13 +642,12 @@ export class Org extends AsyncOptionalCreatable { * using {@link Org.retrieveOrganizationInformation}. */ public async determineIfSandbox(): Promise { - let cache = this.getField(Org.Fields.IS_SANDBOX); - - if (!cache) { - await this.updateLocalInformation(); - cache = this.getField(Org.Fields.IS_SANDBOX); + const cache = this.getField(Org.Fields.IS_SANDBOX); + if (cache !== undefined) { + return cache; } - return cache as boolean; + const updated = await this.updateLocalInformation(); + return updated?.isSandbox === true; } /** @@ -657,22 +666,35 @@ export class Org extends AsyncOptionalCreatable { * Some organization information is locally cached, such as if the org name or if it is a scratch org. * This method populates/updates the filesystem from information retrieved from the org. */ - public async updateLocalInformation(): Promise { + public async updateLocalInformation(): Promise< + | Pick< + AuthFields, + | Org.Fields.NAME + | Org.Fields.INSTANCE_NAME + | Org.Fields.NAMESPACE_PREFIX + | Org.Fields.IS_SANDBOX + | Org.Fields.IS_SCRATCH + | Org.Fields.TRIAL_EXPIRATION_DATE + > + | undefined + > { const username = this.getUsername(); if (username) { - const organization = await this.retrieveOrganizationInformation(); - const isScratch = organization.IsSandbox && Boolean(organization.TrialExpirationDate); - const isSandbox = organization.IsSandbox && !organization.TrialExpirationDate; - const stateAggregator = await StateAggregator.getInstance(); - stateAggregator.orgs.update(username, { + const [stateAggregator, organization] = await Promise.all([ + StateAggregator.getInstance(), + this.retrieveOrganizationInformation(), + ]); + const updateFields = { [Org.Fields.NAME]: organization.Name, [Org.Fields.INSTANCE_NAME]: organization.InstanceName, [Org.Fields.NAMESPACE_PREFIX]: organization.NamespacePrefix, - [Org.Fields.IS_SANDBOX]: isSandbox, - [Org.Fields.IS_SCRATCH]: isScratch, + [Org.Fields.IS_SANDBOX]: organization.IsSandbox && !organization.TrialExpirationDate, + [Org.Fields.IS_SCRATCH]: organization.IsSandbox && Boolean(organization.TrialExpirationDate), [Org.Fields.TRIAL_EXPIRATION_DATE]: organization.TrialExpirationDate, - }); + }; + stateAggregator.orgs.update(username, updateFields); await stateAggregator.orgs.write(username); + return updateFields; } } @@ -685,8 +707,8 @@ export class Org extends AsyncOptionalCreatable { url: this.getConnection().baseUrl(), method: 'GET', }; - const conn = this.getConnection(); - await conn.request(requestInfo); + + await this.getConnection().request(requestInfo); } /** @@ -698,15 +720,11 @@ export class Org extends AsyncOptionalCreatable { const thisUsername = ensure(this.getUsername()); const usernames: JsonArray = ensureJsonArray(contents.usernames ?? [thisUsername]); return Promise.all( - usernames.map((username) => { - if (username === thisUsername) { - return AuthInfo.create({ - username: this.getConnection().getUsername(), - }); - } else { - return AuthInfo.create({ username: ensureString(username) }); - } - }) + usernames.map((username) => + AuthInfo.create({ + username: username === thisUsername ? this.getConnection().getUsername() : ensureString(username), + }) + ) ); } @@ -742,7 +760,7 @@ export class Org extends AsyncOptionalCreatable { // needs config refactoring to improve const usernames = contents.usernames ?? []; - if (!isArray(usernames)) { + if (!Array.isArray(usernames)) { throw new SfError('Usernames is not an array', 'UnexpectedDataFormat'); } @@ -785,13 +803,13 @@ export class Org extends AsyncOptionalCreatable { this.logger.debug(`removing username ${authInfo.getFields().username}`); const orgConfig: OrgUsersConfig = await this.retrieveOrgUsersConfig(); - - const contents: ConfigContents = await orgConfig.read(); + const contents = await orgConfig.read(); const targetUser = authInfo.getFields().username; - const usernames = (contents.usernames ?? []) as string[]; - contents.usernames = usernames.filter((username) => username !== targetUser); + const usernames = (contents.usernames ?? []).filter((username) => username !== targetUser); + + orgConfig.set('usernames', usernames); await orgConfig.write(); return this; } @@ -828,7 +846,7 @@ export class Org extends AsyncOptionalCreatable { /** * Returns the admin username used to create the org. */ - public getUsername(): Optional { + public getUsername(): string | undefined { return this.getConnection().getUsername(); } @@ -863,11 +881,7 @@ export class Org extends AsyncOptionalCreatable { * Returns a map of requested fields. */ public getFields(keys: Org.Fields[]): JsonMap { - const json: JsonMap = {}; - return keys.reduce((map, key) => { - map[key] = this.getField(key); - return map; - }, json); + return Object.fromEntries(keys.map((key) => [key, this.getField(key)])); } /** @@ -908,7 +922,6 @@ export class Org extends AsyncOptionalCreatable { * query SandboxProcess via sandbox name * * @param name SandboxName to query for - * @private */ public async querySandboxProcessBySandboxName(name: string): Promise { return this.querySandboxProcess(`SandboxName='${name}'`); @@ -918,7 +931,6 @@ export class Org extends AsyncOptionalCreatable { * query SandboxProcess via SandboxInfoId * * @param id SandboxInfoId to query for - * @private */ public async querySandboxProcessBySandboxInfoId(id: string): Promise { return this.querySandboxProcess(`SandboxInfoId='${id}'`); @@ -928,18 +940,27 @@ export class Org extends AsyncOptionalCreatable { * query SandboxProcess via Id * * @param id SandboxProcessId to query for - * @private */ public async querySandboxProcessById(id: string): Promise { return this.querySandboxProcess(`Id='${id}'`); } + /** + * query SandboxProcess via SandboxOrganization (sandbox Org ID) + * + * @param sandboxOrgId SandboxOrganization ID to query for + */ + public async querySandboxProcessByOrgId(sandboxOrgId: string): Promise { + // Must query with a 15 character Org ID + return this.querySandboxProcess(`SandboxOrganization='${trimTo15(sandboxOrgId)}'`); + } + /** * Initialize async components. */ protected async init(): Promise { const stateAggregator = await StateAggregator.getInstance(); - this.logger = await Logger.child('Org'); + this.logger = (await Logger.child('Org')).getRawLogger(); this.configAggregator = this.options.aggregator ? this.options.aggregator : await ConfigAggregator.create(); @@ -1008,11 +1029,7 @@ export class Org extends AsyncOptionalCreatable { } ): Promise { const [wait, pollInterval] = this.validateWaitOptions(options); - this.logger.debug( - `AuthWithRetries sandboxProcessObj ${JSON.stringify(sandboxProcessObj, undefined, 2)}, max wait time of ${ - wait.minutes - } minutes` - ); + this.logger.debug(sandboxProcessObj, `AuthWithRetries sandboxProcessObj, max wait time of ${wait.minutes} minutes`); return this.pollStatusAndAuth({ sandboxProcessObj, wait, @@ -1028,11 +1045,11 @@ export class Org extends AsyncOptionalCreatable { */ private async queryLatestSandboxProcessBySandboxName(sandboxNameIn: string): Promise { const { tooling } = this.getConnection(); - this.logger.debug('QueryLatestSandboxProcessBySandboxName called with SandboxName: %s ', sandboxNameIn); + this.logger.debug(`QueryLatestSandboxProcessBySandboxName called with SandboxName: ${sandboxNameIn}`); const queryStr = `SELECT Id, Status, SandboxName, SandboxInfoId, LicenseType, CreatedDate, CopyProgress, SandboxOrganization, SourceId, Description, EndDate FROM SandboxProcess WHERE SandboxName='${sandboxNameIn}' AND Status != 'D' ORDER BY CreatedDate DESC LIMIT 1`; const queryResult = await tooling.query(queryStr); - this.logger.debug('Return from calling queryToolingApi: %s ', queryResult); + this.logger.debug(queryResult, 'Return from calling queryToolingApi'); if (queryResult?.records?.length === 1) { return queryResult.records[0] as SandboxProcessObject; } else if (queryResult.records && queryResult.records.length > 1) { @@ -1106,7 +1123,7 @@ export class Org extends AsyncOptionalCreatable { if (sandboxInfoId) { const deleteResult = await this.destroySandbox(prodOrg, sandboxInfoId); - this.logger.debug('Return from calling tooling.delete: ', deleteResult); + this.logger.debug(deleteResult, 'Return from calling tooling.delete'); } // cleanup remaining artifacts await this.remove(); @@ -1132,6 +1149,7 @@ export class Org extends AsyncOptionalCreatable { try { const devHubConn = devHub.getConnection(); const username = this.getUsername(); + const activeScratchOrgRecordId = ( await devHubConn.singleRecordQuery<{ Id: string }>( `SELECT Id FROM ActiveScratchOrg WHERE SignupUsername='${username}'` @@ -1211,36 +1229,33 @@ export class Org extends AsyncOptionalCreatable { this.logger.debug(`Removing users associate with org: ${this.getOrgId()}`); const config = await this.retrieveOrgUsersConfig(); this.logger.debug(`using path for org users: ${config.getPath()}`); - const authInfos: AuthInfo[] = await this.readUserAuthFiles(); + + const usernames = (await this.readUserAuthFiles()).map((auth) => auth.getFields().username).filter(isString); await Promise.all( - authInfos - .map((auth) => auth.getFields().username) - .map(async (username) => { - const aliasKeys = (username && stateAggregator.aliases.getAll(username)) ?? []; - stateAggregator.aliases.unsetAll(username as string); - - const orgForUser = - username === this.getUsername() - ? this - : await Org.create({ - connection: await Connection.create({ authInfo: await AuthInfo.create({ username }) }), - }); - - const orgType = this.isDevHubOrg() ? OrgConfigProperties.TARGET_DEV_HUB : OrgConfigProperties.TARGET_ORG; - const configInfo = orgForUser.configAggregator.getInfo(orgType); - const needsConfigUpdate = - (configInfo.isGlobal() || configInfo.isLocal()) && - (configInfo.value === username || aliasKeys.includes(configInfo.value as string)); - - return [ - orgForUser.removeAuth(), - needsConfigUpdate ? Config.update(configInfo.isGlobal(), orgType, undefined) : undefined, - ].filter(Boolean); - }) + usernames.map(async (username) => { + const orgForUser = + username === this.getUsername() + ? this + : await Org.create({ + connection: await Connection.create({ authInfo: await AuthInfo.create({ username }) }), + }); + + const orgType = this.isDevHubOrg() ? OrgConfigProperties.TARGET_DEV_HUB : OrgConfigProperties.TARGET_ORG; + const configInfo = orgForUser.configAggregator.getInfo(orgType); + const needsConfigUpdate = + (configInfo.isGlobal() || configInfo.isLocal()) && + (configInfo.value === username || stateAggregator.aliases.get(configInfo.value as string) === username); + + return [ + orgForUser.removeAuth(), + needsConfigUpdate ? Config.update(configInfo.isGlobal(), orgType, undefined) : undefined, + ].filter(Boolean); + }) ); - await stateAggregator.aliases.write(); + // now that we're done with all the aliases, we can unset those + await stateAggregator.aliases.unsetValuesAndSave(usernames); } private async removeSandboxConfig(): Promise { @@ -1252,14 +1267,11 @@ export class Org extends AsyncOptionalCreatable { sandboxProcessObj: SandboxProcessObject, sandboxRes: SandboxUserAuthResponse ): Promise { - this.logger.debug( - `writeSandboxAuthFile sandboxProcessObj: ${JSON.stringify(sandboxProcessObj)}, sandboxRes: ${JSON.stringify( - sandboxRes - )}` - ); + this.logger.debug(sandboxProcessObj, 'writeSandboxAuthFile sandboxProcessObj'); + this.logger.debug(sandboxRes, 'writeSandboxAuthFile sandboxRes'); if (sandboxRes.authUserName) { const productionAuthFields = this.connection.getAuthInfoFields(); - this.logger.debug('Result from getAuthInfoFields: AuthFields', productionAuthFields); + this.logger.debug(productionAuthFields, 'Result from getAuthInfoFields: AuthFields'); // let's do headless auth via jwt (if we have privateKey) or web auth const oauth2Options: AuthFields & { @@ -1286,29 +1298,31 @@ export class Org extends AsyncOptionalCreatable { }); this.logger.debug( - 'Creating AuthInfo for sandbox', - sandboxRes.authUserName, - productionAuthFields.username, - oauth2Options + { + sandboxResAuthUsername: sandboxRes.authUserName, + productionAuthFieldsUsername: productionAuthFields.username, + ...oauth2Options, + }, + 'Creating AuthInfo for sandbox' ); // save auth info for new sandbox await authInfo.save(); - const sandboxOrgId = authInfo.getFields().orgId as string; + const sandboxOrgId = authInfo.getFields().orgId; if (!sandboxOrgId) { throw messages.createError('AuthInfoOrgIdUndefined'); } // set the sandbox config value - const sfSandbox = { + const sfSandbox: SandboxFields = { sandboxUsername: sandboxRes.authUserName, sandboxOrgId, - prodOrgUsername: this.getUsername(), + prodOrgUsername: this.getUsername() as string, sandboxName: sandboxProcessObj.SandboxName, sandboxProcessId: sandboxProcessObj.Id, sandboxInfoId: sandboxProcessObj.SandboxInfoId, timestamp: new Date().toISOString(), - } as SandboxFields; + }; await this.setSandboxConfig(sandboxOrgId, sfSandbox); await (await StateAggregator.getInstance()).sandboxes.write(sandboxOrgId); @@ -1328,25 +1342,18 @@ export class Org extends AsyncOptionalCreatable { wait: Duration; pollInterval: Duration; }): Promise { - this.logger.debug( - 'PollStatusAndAuth called with SandboxProcessObject', - options.sandboxProcessObj, - options.wait.minutes, - options.pollInterval.seconds - ); + this.logger.debug(options, 'PollStatusAndAuth called with SandboxProcessObject'); let remainingWait = options.wait; let waitingOnAuth = false; const pollingClient = await PollingClient.create({ poll: async (): Promise => { - const sandboxProcessObj = await this.querySandboxProcessBySandboxInfoId( - options.sandboxProcessObj.SandboxInfoId - ); + const sandboxProcessObj = await this.querySandboxProcessById(options.sandboxProcessObj.Id); // check to see if sandbox can authenticate via sandboxAuth endpoint const sandboxInfo = await this.sandboxSignupComplete(sandboxProcessObj); if (sandboxInfo) { await Lifecycle.getInstance().emit(SandboxEvents.EVENT_AUTH, sandboxInfo); try { - this.logger.debug('sandbox signup complete with', sandboxInfo); + this.logger.debug(sandboxInfo, 'sandbox signup complete with'); await this.writeSandboxAuthFile(sandboxProcessObj, sandboxInfo); return { completed: true, payload: sandboxProcessObj }; } catch (err) { @@ -1383,10 +1390,19 @@ export class Org extends AsyncOptionalCreatable { * @private */ private async querySandboxProcess(where: string): Promise { - const queryStr = `SELECT Id, Status, SandboxName, SandboxInfoId, LicenseType, CreatedDate, CopyProgress, SandboxOrganization, SourceId, Description, EndDate FROM SandboxProcess WHERE ${where} AND Status != 'D'`; - return this.connection.singleRecordQuery(queryStr, { - tooling: true, - }); + const soql = `SELECT Id, Status, SandboxName, SandboxInfoId, LicenseType, CreatedDate, CopyProgress, SandboxOrganization, SourceId, Description, EndDate FROM SandboxProcess WHERE ${where} ORDER BY CreatedDate DESC`; + const result = (await this.connection.tooling.query(soql)).records.filter( + (item) => !item.Status.startsWith('Del') + ); + if (result.length === 0) { + throw new SfError(`No record found for ${soql}`, SingleRecordQueryErrors.NoRecords); + } + if (result.length > 1) { + const err = new SfError('The query returned more than 1 record', SingleRecordQueryErrors.MultipleRecords); + err.data = result; + throw err; + } + return result[0]; } /** * determines if the sandbox has successfully been created @@ -1414,7 +1430,7 @@ export class Org extends AsyncOptionalCreatable { callbackUrl, }; - this.logger.debug('Calling sandboxAuth with SandboxUserAuthRequest', sandboxReq); + this.logger.debug(sandboxReq, 'Calling sandboxAuth with SandboxUserAuthRequest'); // eslint-disable-next-line no-underscore-dangle const url = `${this.connection.tooling._baseUrl()}/sandboxAuth`; @@ -1427,7 +1443,7 @@ export class Org extends AsyncOptionalCreatable { const result: SandboxUserAuthResponse = await this.connection.tooling.request(params); - this.logger.debug('Result of calling sandboxAuth', result); + this.logger.debug(result, 'Result of calling sandboxAuth'); return result; } catch (err) { const error = err as Error; @@ -1548,7 +1564,7 @@ export namespace Org { */ IS_SCRATCH = 'isScratch', /** - * Is the current org a dev hub org. e.g. Organization has IsSandbox == true and TrialExpirationDate == null. + * Is the current org a sandbox (not a scratch org on a non-prod instance), but an actual Sandbox org). e.g. Organization has IsSandbox == true and TrialExpirationDate == null. */ IS_SANDBOX = 'isSandbox', /** diff --git a/src/org/orgConfigProperties.ts b/src/org/orgConfigProperties.ts index 2d1eea7056..2c2a50f672 100644 --- a/src/org/orgConfigProperties.ts +++ b/src/org/orgConfigProperties.ts @@ -5,9 +5,9 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { join as pathJoin } from 'path'; +import { join as pathJoin } from 'node:path'; import { isString } from '@salesforce/ts-types'; -import { ConfigValue } from '../config/configStore'; +import { ConfigValue } from '../config/configStackTypes'; import { Messages } from '../messages'; import { SfdcUrl } from '../util/sfdcUrl'; import { validateApiVersion } from '../util/sfdc'; @@ -48,9 +48,17 @@ export enum OrgConfigProperties { * The url for the debugger configuration. */ ORG_ISV_DEBUGGER_URL = 'org-isv-debugger-url', + /** + * Capitalize record types when deploying scratch org settings + */ + ORG_CAPITALIZE_RECORD_TYPES = 'org-capitalize-record-types', } export const ORG_CONFIG_ALLOWED_PROPERTIES = [ + { + key: OrgConfigProperties.ORG_CAPITALIZE_RECORD_TYPES, + description: messages.getMessage(OrgConfigProperties.ORG_CAPITALIZE_RECORD_TYPES), + }, { key: OrgConfigProperties.ORG_CUSTOM_METADATA_TEMPLATES, description: messages.getMessage(OrgConfigProperties.ORG_CUSTOM_METADATA_TEMPLATES), diff --git a/src/org/permissionSetAssignment.ts b/src/org/permissionSetAssignment.ts index 1247a61cf9..663b5cdf29 100644 --- a/src/org/permissionSetAssignment.ts +++ b/src/org/permissionSetAssignment.ts @@ -5,11 +5,11 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { EOL } from 'os'; +import { EOL } from 'node:os'; import { mapKeys, upperFirst } from '@salesforce/kit'; -import { hasArray, Optional } from '@salesforce/ts-types'; -import { QueryResult, Record } from 'jsforce'; -import { Logger } from '../logger'; +import type { Optional } from '@salesforce/ts-types'; +import type { QueryResult, Record } from 'jsforce'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { SfError } from '../sfError'; import { Org } from './org'; @@ -94,19 +94,22 @@ export class PermissionSetAssignment { .sobject('PermissionSetAssignment') .create(mapKeys(assignment, (value: unknown, key: string) => upperFirst(key))); - if (hasArray(createResponse, 'errors') && createResponse.errors.length > 0) { - let message = messages.getMessage('errorsEncounteredCreatingAssignment'); - - const errors = createResponse.errors; - if (errors && errors.length > 0) { - message = `${message}:${EOL}`; - errors.forEach((_message) => { - message = `${message}${_message as string}${EOL}`; - }); - throw new SfError(message, 'errorsEncounteredCreatingAssignment'); - } else { + if (createResponse.success === false) { + if (!createResponse.errors?.length) { throw messages.createError('notSuccessfulButNoErrorsReported'); } + const message = [messages.getMessage('errorsEncounteredCreatingAssignment')] + .concat( + (createResponse.errors ?? []).map((error) => { + // note: the types for jsforce SaveError don't have "string[]" error, + // but there was a UT for that at https://github.com/forcedotcom/sfdx-core/blob/7412d103703cfe2df2211546fcf2e6d93a689bc0/test/unit/org/permissionSetAssignmentTest.ts#L146 + // which could either be hallucination or a real response we've seen, so I'm preserving that behavior. + if (typeof error === 'string') return error; + return error.fields ? `${error.message} on fields ${error.fields.join(',')}` : error.message; + }) + ) + .join(EOL); + throw new SfError(message, 'errorsEncounteredCreatingAssignment'); } else { return assignment; } diff --git a/src/org/scratchOrgCreate.ts b/src/org/scratchOrgCreate.ts index f2bae0b714..4a09a6e283 100644 --- a/src/org/scratchOrgCreate.ts +++ b/src/org/scratchOrgCreate.ts @@ -4,14 +4,14 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { Duration } from '@salesforce/kit'; +import { Duration, toBoolean } from '@salesforce/kit'; import { ensureString } from '@salesforce/ts-types'; import { Messages } from '../messages'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { ConfigAggregator } from '../config/configAggregator'; import { OrgConfigProperties } from '../org/orgConfigProperties'; import { SfProject } from '../sfProject'; -import { StateAggregator } from '../stateAggregator'; +import { StateAggregator } from '../stateAggregator/stateAggregator'; import { Org } from './org'; import { authorizeScratchOrg, @@ -110,9 +110,12 @@ export const scratchOrgResume = async (jobId: string): Promise => { // a project isn't required for org:create } }; + +async function getCapitalizeRecordTypesConfig(): Promise { + const configAgg = await ConfigAggregator.create(); + const value = configAgg.getInfo('org-capitalize-record-types').value as string | undefined; + + if (value !== undefined) return toBoolean(value); + + // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion + return value as undefined; +} diff --git a/src/org/scratchOrgErrorCodes.ts b/src/org/scratchOrgErrorCodes.ts index 9406ca3ae1..35ff3f7c5b 100644 --- a/src/org/scratchOrgErrorCodes.ts +++ b/src/org/scratchOrgErrorCodes.ts @@ -8,7 +8,7 @@ import { Optional } from '@salesforce/ts-types'; import { Messages } from '../messages'; import { SfError } from '../sfError'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { ScratchOrgInfo } from './scratchOrgTypes'; import { ScratchOrgCache } from './scratchOrgCache'; import { emit } from './scratchOrgLifecycleEvents'; diff --git a/src/org/scratchOrgInfoApi.ts b/src/org/scratchOrgInfoApi.ts index 47ebb5fec5..57b46d7855 100644 --- a/src/org/scratchOrgInfoApi.ts +++ b/src/org/scratchOrgInfoApi.ts @@ -7,9 +7,10 @@ import { env, Duration, upperFirst } from '@salesforce/kit'; import { AnyJson } from '@salesforce/ts-types'; -import { OAuth2Config, JwtOAuth2Config, SaveResult } from 'jsforce'; +import { OAuth2Config, SaveResult } from 'jsforce'; import { retryDecorator, RetryError } from 'ts-retry-promise'; -import { Logger } from '../logger'; +import { JwtOAuth2Config } from '../org/authInfo'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { SfError } from '../sfError'; import { SfdcUrl } from '../util/sfdcUrl'; @@ -231,7 +232,11 @@ export const authorizeScratchOrg = async (options: { clientId: scratchOrgInfoComplete.ConnectedAppConsumerKey, createdOrgInstance: scratchOrgInfoComplete.SignupInstance, isDevHub: false, - snapshot: scratchOrgInfoComplete.Snapshot, + isScratch: true, + isSandbox: false, + // omit optional fields unless they are present + ...(scratchOrgInfoComplete.Namespace ? { namespacePrefix: scratchOrgInfoComplete.Namespace } : {}), + ...(scratchOrgInfoComplete.Snapshot ? { snapshot: scratchOrgInfoComplete.Snapshot } : {}), }); return authInfo; diff --git a/src/org/scratchOrgInfoGenerator.ts b/src/org/scratchOrgInfoGenerator.ts index 0b03001fad..de0302d988 100644 --- a/src/org/scratchOrgInfoGenerator.ts +++ b/src/org/scratchOrgInfoGenerator.ts @@ -4,7 +4,7 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { promises as fs } from 'fs'; +import { promises as fs } from 'node:fs'; import { parseJson } from '@salesforce/kit'; import { ensureString } from '@salesforce/ts-types'; import { SfProjectJson } from '../sfProject'; diff --git a/src/org/scratchOrgLifecycleEvents.ts b/src/org/scratchOrgLifecycleEvents.ts index 32cbc6a29a..bab73415f1 100644 --- a/src/org/scratchOrgLifecycleEvents.ts +++ b/src/org/scratchOrgLifecycleEvents.ts @@ -8,8 +8,6 @@ import { Lifecycle } from '../lifecycleEvents'; import { AuthFields } from './authInfo'; import { ScratchOrgInfo } from './scratchOrgTypes'; -const emitter = Lifecycle.getInstance(); - export const scratchOrgLifecycleEventName = 'scratchOrgLifecycleEvent'; export const scratchOrgLifecycleStages = [ 'prepare request', @@ -21,12 +19,12 @@ export const scratchOrgLifecycleStages = [ 'done', ] as const; export interface ScratchOrgLifecycleEvent { - stage: typeof scratchOrgLifecycleStages[number]; + stage: (typeof scratchOrgLifecycleStages)[number]; scratchOrgInfo?: ScratchOrgInfo; } export const emit = async (event: ScratchOrgLifecycleEvent): Promise => - emitter.emit(scratchOrgLifecycleEventName, event); + Lifecycle.getInstance().emit(scratchOrgLifecycleEventName, event); const postOrgCreateHookFields = [ 'accessToken', @@ -41,13 +39,13 @@ const postOrgCreateHookFields = [ 'username', ] as const; -type PostOrgCreateHook = Pick; +type PostOrgCreateHook = Pick; -const isHookField = (key: string): key is typeof postOrgCreateHookFields[number] => - postOrgCreateHookFields.includes(key as typeof postOrgCreateHookFields[number]); +const isHookField = (key: string): key is (typeof postOrgCreateHookFields)[number] => + postOrgCreateHookFields.includes(key as (typeof postOrgCreateHookFields)[number]); export const emitPostOrgCreate = async (authFields: AuthFields): Promise => { - await emitter.emit( + await Lifecycle.getInstance().emit( 'postorgcreate', Object.fromEntries(Object.entries(authFields).filter(([key]) => isHookField(key))) as PostOrgCreateHook ); diff --git a/src/org/scratchOrgSettingsGenerator.ts b/src/org/scratchOrgSettingsGenerator.ts index 593ff02587..1d9d62d192 100644 --- a/src/org/scratchOrgSettingsGenerator.ts +++ b/src/org/scratchOrgSettingsGenerator.ts @@ -5,20 +5,24 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as path from 'path'; +import * as path from 'node:path'; import { isEmpty, env, upperFirst, Duration } from '@salesforce/kit'; import { ensureObject, JsonMap } from '@salesforce/ts-types'; import * as js2xmlparser from 'js2xmlparser'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { StructuredWriter } from '../util/structuredWriter'; import { StatusResult } from '../status/types'; import { PollingClient } from '../status/pollingClient'; import { ZipWriter } from '../util/zipWriter'; import { DirectoryWriter } from '../util/directoryWriter'; +import { Lifecycle } from '../lifecycleEvents'; +import { Messages } from '../messages'; import { ScratchOrgInfo, ObjectSetting } from './scratchOrgTypes'; import { Org } from './org'; +Messages.importMessagesDirectory(__dirname); + export enum RequestStatus { Pending = 'Pending', InProgress = 'InProgress', @@ -82,13 +86,19 @@ export const createObjectFileContent = ({ return { ...output, ...{ version: apiVersion } }; }; -const calculateBusinessProcess = (objectName: string, defaultRecordType: string): Array => { +const calculateBusinessProcess = ( + objectName: string, + defaultRecordType: string, + capitalizeBusinessProcess: boolean +): Array => { let businessProcessName = null; let businessProcessPicklistVal = null; // These four objects require any record type to specify a "business process"-- // a restricted set of items from a standard picklist on the object. if (['Case', 'Lead', 'Opportunity', 'Solution'].includes(objectName)) { - businessProcessName = upperFirst(defaultRecordType) + 'Process'; + businessProcessName = capitalizeBusinessProcess + ? `${upperFirst(defaultRecordType)}Process` + : `${defaultRecordType}Process`; switch (objectName) { case 'Case': businessProcessPicklistVal = 'New'; @@ -110,7 +120,8 @@ export const createRecordTypeAndBusinessProcessFileContent = ( objectName: string, json: Record, allRecordTypes: string[], - allBusinessProcesses: string[] + allBusinessProcesses: string[], + capitalizeRecordTypes: boolean ): JsonMap => { let output = { '@': { @@ -126,15 +137,23 @@ export const createRecordTypeAndBusinessProcessFileContent = ( }; } - const defaultRecordType = json.defaultRecordType; + const defaultRecordType = capitalizeRecordTypes + ? upperFirst(json.defaultRecordType as string) + : json.defaultRecordType; + if (typeof defaultRecordType === 'string') { // We need to keep track of these globally for when we generate the package XML. - allRecordTypes.push(`${name}.${upperFirst(defaultRecordType)}`); - const [businessProcessName, businessProcessPicklistVal] = calculateBusinessProcess(name, defaultRecordType); + allRecordTypes.push(`${name}.${defaultRecordType}`); + const [businessProcessName, businessProcessPicklistVal] = calculateBusinessProcess( + name, + defaultRecordType, + capitalizeRecordTypes + ); + // Create the record type const recordTypes = { - fullName: upperFirst(defaultRecordType), - label: upperFirst(defaultRecordType), + fullName: defaultRecordType, + label: defaultRecordType, active: true, }; @@ -186,9 +205,22 @@ export default class SettingsGenerator { private allBusinessProcesses: string[] = []; private readonly shapeDirName: string; private readonly packageFilePath: string; - - public constructor(options?: { mdApiTmpDir?: string; shapeDirName?: string; asDirectory?: boolean }) { + private readonly capitalizeRecordTypes: boolean; + + public constructor(options?: { + mdApiTmpDir?: string; + shapeDirName?: string; + asDirectory?: boolean; + capitalizeRecordTypes?: boolean; + }) { this.logger = Logger.childFromRoot('SettingsGenerator'); + if (options?.capitalizeRecordTypes === undefined) { + const messages = Messages.loadMessages('@salesforce/core', 'scratchOrgSettingsGenerator'); + void Lifecycle.getInstance().emitWarning(messages.getMessage('noCapitalizeRecordTypeConfigVar')); + this.capitalizeRecordTypes = true; + } else { + this.capitalizeRecordTypes = options.capitalizeRecordTypes; + } // If SFDX_MDAPI_TEMP_DIR is set, copy settings to that dir for people to inspect. const mdApiTmpDir = options?.mdApiTmpDir ?? env.getString('SFDX_MDAPI_TEMP_DIR'); this.shapeDirName = options?.shapeDirName ?? `shape_${Date.now()}`; @@ -286,12 +318,17 @@ export default class SettingsGenerator { const client = await PollingClient.create(pollingOptions); const status = await client.subscribe(); - if (status !== RequestStatus.Succeeded) { + type FailureMessage = { + problemType: string; + fullName: string; + problem: string; + }; + if (status !== RequestStatus.Succeeded.toString()) { const componentFailures = ensureObject<{ - componentFailures: Record | Array>; + componentFailures: FailureMessage | FailureMessage[]; }>(result.details).componentFailures; const failures = (Array.isArray(componentFailures) ? componentFailures : [componentFailures]) - .map((failure) => failure.problem) + .map((failure) => `[${failure.problemType}] ${failure.fullName} : ${failure.problem} `) .join('\n'); const error = new SfError( `A scratch org was created with username ${username}, but the settings failed to deploy due to: \n${failures}`, @@ -339,7 +376,8 @@ export default class SettingsGenerator { item, value, allRecordTypes, - allbusinessProcesses + allbusinessProcesses, + this.capitalizeRecordTypes ); const xml = js2xmlparser.parse('CustomObject', fileContent); return this.writer.addToStore(xml, path.join(objectsDir, upperFirst(item) + '.object')); diff --git a/src/org/user.ts b/src/org/user.ts index d3d0ea8e11..e0edb73d7a 100644 --- a/src/org/user.ts +++ b/src/org/user.ts @@ -5,12 +5,12 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { EOL } from 'os'; +import { EOL } from 'node:os'; import { AsyncCreatable, lowerFirst, mapKeys, omit, parseJsonMap, upperFirst } from '@salesforce/kit'; import { asJsonArray, asNumber, ensureJsonMap, ensureString, isJsonMap, Many } from '@salesforce/ts-types'; import type { HttpRequest, HttpResponse, QueryResult, Schema, SObjectUpdateRecord } from 'jsforce'; import { HttpApi } from 'jsforce/lib/http-api'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Messages } from '../messages'; import { SecureBuffer } from '../crypto/secureBuffer'; import { SfError } from '../sfError'; @@ -389,8 +389,7 @@ export class User extends AsyncCreatable { }); // Update the auth info object with created user id. - const newUserAuthFields: AuthFields = newUserAuthInfo.getFields(); - newUserAuthFields.userId = refreshTokenSecret.userId; + newUserAuthInfo.update({ userId: refreshTokenSecret.userId }); // Make sure we can connect and if so save the auth info. await this.describeUserAndSave(newUserAuthInfo); diff --git a/src/schema/printer.ts b/src/schema/printer.ts deleted file mode 100644 index 52a5445a4f..0000000000 --- a/src/schema/printer.ts +++ /dev/null @@ -1,307 +0,0 @@ -/* - * Copyright (c) 2020, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ -/* eslint-disable class-methods-use-this */ - -import { - asJsonArray, - asJsonMap, - asNumber, - asString, - isJsonMap, - JsonArray, - JsonMap, - Optional, -} from '@salesforce/ts-types'; -import { Logger } from '../logger'; -import { SfError } from '../sfError'; - -/** - * Renders schema properties. By default, this is simply an identity transform. Subclasses may provide more - * interesting decorations of each values, such as ANSI coloring. - * - * @deprecated - */ -export class SchemaPropertyRenderer { - /** - * Renders a name. - * - * @param name The name value to render. - */ - public renderName(name: string): string { - return name; - } - - /** - * Renders a title. - * - * @param title The title value to render. - */ - public renderTitle(title: string): string { - return title; - } - - /** - * Renders a description. - * - * @param description The description value to render. - */ - public renderDescription(description: string): string { - return description; - } - - /** - * Renders a type. - * - * @param propertyType The type value to render. - */ - public renderType(propertyType: string): string { - return propertyType; - } -} - -/** - * Prints a JSON schema in a human-friendly format. - * - * @deprecated - * - * ``` - * import chalk from 'chalk'; - * class MyPropertyRenderer extends SchemaPropertyRenderer { - * renderName(name) { return chalk.bold.blue(name); } - * } - * - * const printer = new SchemaPrinter(logger, schema, new MyPropertyRenderer()); - * printer.getLines().forEach(console.log); - * ``` - */ -export class SchemaPrinter { - private logger: Logger; - private lines: string[] = []; - - /** - * Constructs a new `SchemaPrinter`. - * - * @param logger The logger to use when emitting the printed schema. - * @param schema The schema to print. - * @param propertyRenderer The property renderer. - */ - public constructor( - logger: Logger, - private schema: JsonMap, - private propertyRenderer: SchemaPropertyRenderer = new SchemaPropertyRenderer() - ) { - this.logger = logger.child('SchemaPrinter'); - - if (!this.schema.properties && !this.schema.items) { - // No need to add to messages, since this should never happen. In fact, - // this will cause a test failure if there is a command that uses a schema - // with no properties defined. - throw new SfError('There is no purpose to print a schema with no properties or items'); - } - - const startLevel = 0; - const add = this.addFn(startLevel); - - // For object schemas, print out the "header" and first level properties differently - if (this.schema.properties) { - if (typeof this.schema.description === 'string') { - // Output the overall schema description before printing the properties - add(this.schema.description); - add(''); - } - - Object.keys(this.schema.properties).forEach((key) => { - const properties = asJsonMap(this.schema.properties); - if (!properties) { - return; - } - this.parseProperty(key, asJsonMap(properties[key]), startLevel); - add(''); - }); - } else { - this.parseProperty('schema', this.schema, startLevel); - } - } - - /** - * Gets a read-only array of ready-to-display lines. - */ - public getLines(): readonly string[] { - return this.lines; - } - - /** - * Gets a ready-to-display line by index. - * - * @param index The line index to get. - */ - public getLine(index: number): string { - return this.lines[index]; - } - - /** - * Prints the accumulated set of schema lines as info log lines to the logger. - */ - public print(): void { - this.lines.forEach((line) => this.logger.info(line)); - } - - private addFn(level: number): (line: string) => void { - const indent = ' '.repeat(level * 4); - return (line: string) => { - this.lines.push(`${indent}${line}`); - }; - } - - private parseProperty(name: string, rawProperty?: JsonMap, level = 0): void { - if (!rawProperty) { - return; - } - - const add = this.addFn(level); - const property = new SchemaProperty(this.logger, this.schema, name, rawProperty, this.propertyRenderer); - - add(property.renderHeader()); - - if (property.type === 'object' && property.properties) { - Object.keys(property.properties).forEach((key) => { - this.parseProperty(key, property.getProperty(key), level + 1); - }); - } - if (property.type === 'array') { - add(` ${property.renderArrayHeader()}`); - if (property.items && property.items.type === 'object' && property.items.properties) { - Object.keys(property.items.properties).forEach((key) => { - const items = asJsonMap(property.items); - if (!items) { - return; - } - const properties = asJsonMap(items.properties); - if (!properties) { - return; - } - this.parseProperty(key, asJsonMap(properties[key]), level + 2); - }); - } - } - if (property.required) { - add(`Required: ${property.required.join(', ')}`); - } - } -} - -class SchemaProperty { - public constructor( - private readonly logger: Logger, - private readonly schema: JsonMap, - private readonly name: string, - private rawProperty: JsonMap, - private propertyRenderer: SchemaPropertyRenderer - ) { - this.name = name; - - // Capture the referenced definition, if specified - if (typeof this.rawProperty.$ref === 'string') { - // Copy the referenced property while adding the original property's properties on top of that -- - // if they are defined here, they take precedence over referenced definition properties. - this.rawProperty = Object.assign({}, resolveRef(this.schema, this.rawProperty), rawProperty); - } - - const oneOfs = asJsonArray(this.rawProperty.oneOf); - if (oneOfs && !this.rawProperty.type) { - this.rawProperty.type = oneOfs.map((value) => (isJsonMap(value) ? value.type ?? value.$ref : value)).join('|'); - } - - // Handle items references - if (isJsonMap(this.items) && this.items && this.items.$ref) { - Object.assign(this.items, resolveRef(this.schema, this.items)); - } - } - - public get title(): Optional { - return asString(this.rawProperty.title); - } - - public get description(): Optional { - return asString(this.rawProperty.description); - } - - public get type(): Optional { - return asString(this.rawProperty.type); - } - - public get required(): Optional { - return asJsonArray(this.rawProperty.required); - } - - public get properties(): Optional { - return asJsonMap(this.rawProperty.properties); - } - - public get items(): Optional { - return asJsonMap(this.rawProperty.items); - } - - public get minItems(): Optional { - return asNumber(this.rawProperty.minItems); - } - - public getProperty(key: string): Optional { - const properties = this.getProperties(); - return asJsonMap(properties?.[key]); - } - - public getProperties(): Optional { - return asJsonMap(this.rawProperty.properties); - } - - public renderName(): string { - return this.propertyRenderer.renderName(this.name); - } - - public renderTitle(): string { - return this.propertyRenderer.renderTitle(this.title ?? ''); - } - - public renderDescription(): string { - return this.propertyRenderer.renderDescription(this.description ?? ''); - } - - public renderType(): string { - return this.propertyRenderer.renderType(this.type ?? ''); - } - - public renderHeader(): string { - return `${this.renderName()}(${this.renderType()}) - ${this.renderTitle()}: ${this.renderDescription()}`; - } - - public renderArrayHeader(): string { - if (!this.items) { - return ''; - } - const minItems = this.minItems ? ` - min ${this.minItems}` : ''; - const prop = new SchemaProperty(this.logger, this.schema, 'items', this.items, this.propertyRenderer); - return `items(${prop.renderType()}${minItems}) - ${prop.renderTitle()}: ${prop.renderDescription()}`; - } -} - -/** - * Get the referenced definition by following the reference path on the current schema. - * - * @param schema The source schema containing the property containing a `$ref` field. - * @param property The property that contains the `$ref` field. - */ -function resolveRef(schema: JsonMap, property: JsonMap): JsonMap | null { - const ref = property.$ref; - if (!ref || typeof ref !== 'string') { - return null; - } - return ref.split('/').reduce((prev, key) => { - const next = prev[key]; - return key === '#' ? schema : isJsonMap(next) ? next : {}; - }, property); -} diff --git a/src/schema/validator.ts b/src/schema/validator.ts index 114332d2a5..b249006c2c 100644 --- a/src/schema/validator.ts +++ b/src/schema/validator.ts @@ -5,12 +5,12 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as path from 'path'; -import * as fs from 'fs'; +import * as path from 'node:path'; +import * as fs from 'node:fs'; import Ajv, { DefinedError } from 'ajv'; import { AnyJson, JsonMap } from '@salesforce/ts-types'; import { getJsonValuesByName, parseJsonMap } from '@salesforce/kit'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; /** @@ -110,7 +110,7 @@ export class SchemaValidator { // AJV will modify the original json object. We need to make a clone of the // json to keep this backwards compatible with JSEN functionality - const jsonClone: T = JSON.parse(JSON.stringify(json)) as T; + const jsonClone = structuredClone(json); const valid = validate(jsonClone); diff --git a/src/sfError.ts b/src/sfError.ts index f870dbaad2..390a550285 100644 --- a/src/sfError.ts +++ b/src/sfError.ts @@ -6,7 +6,7 @@ */ import { NamedError } from '@salesforce/kit'; -import { hasString, isString, JsonMap } from '@salesforce/ts-types'; +import { AnyJson, hasString, isString, JsonMap } from '@salesforce/ts-types'; /** * A generalized sfdx error which also contains an action. The action is used in the @@ -24,7 +24,7 @@ import { hasString, isString, JsonMap } from '@salesforce/ts-types'; * throw new SfError(message.getMessage('myError'), 'MyErrorName'); * ``` */ -export class SfError extends NamedError { +export class SfError extends NamedError { /** * Action messages. Hints to the users regarding what can be done to fix related issues. */ @@ -41,7 +41,7 @@ export class SfError extends NamedError { public context?: string; // Additional data helpful for consumers of this error. E.g., API call result - public data?: unknown; + public data?: T; /** * Some errors support `error.code` instead of `error.name`. This keeps backwards compatability. @@ -75,7 +75,7 @@ export class SfError extends NamedError { } // eslint-disable-next-line @typescript-eslint/no-explicit-any - public get code(): string | undefined | any { + public get code(): any { return this.#code ?? this.name; } @@ -121,7 +121,7 @@ export class SfError extends NamedError { * * @param data The payload data. */ - public setData(data: unknown): SfError { + public setData(data: T): SfError { this.data = data; return this; } @@ -132,7 +132,7 @@ export class SfError extends NamedError { public toObject(): JsonMap { const obj: JsonMap = { name: this.name, - message: this.message || this.name, + message: this.message ?? this.name, exitCode: this.exitCode, actions: this.actions, }; @@ -142,15 +142,12 @@ export class SfError extends NamedError { } if (this.data) { - // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-assignment - obj.data = this.data as any; + // DANGER: data was previously typed as `unknown` and this assertion was here on the toObject. + // TODO in next major release: put proper type constraint on SfError.data to something that can serialize + // while we're making breaking changes, provide a more definite type for toObject + obj.data = this.data as AnyJson; } return obj; } } - -/** - * @deprecated use SfError instead - */ -export class SfdxError extends SfError {} diff --git a/src/sfProject.ts b/src/sfProject.ts index 4a992aedc1..427154f7df 100644 --- a/src/sfProject.ts +++ b/src/sfProject.ts @@ -4,21 +4,21 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { basename, dirname, isAbsolute, normalize, resolve, sep } from 'path'; -import * as fs from 'fs'; +import { basename, dirname, isAbsolute, normalize, resolve, sep } from 'node:path'; +import * as fs from 'node:fs'; import { defaults, env } from '@salesforce/kit'; import { Dictionary, ensure, JsonMap, Nullable, Optional } from '@salesforce/ts-types'; import { SfdcUrl } from './util/sfdcUrl'; import { ConfigAggregator } from './config/configAggregator'; import { ConfigFile } from './config/configFile'; -import { ConfigContents } from './config/configStore'; +import { ConfigContents } from './config/configStackTypes'; import { SchemaValidator } from './schema/validator'; import { resolveProjectPath, resolveProjectPathSync, SFDX_PROJECT_JSON } from './util/internal'; import { SfError } from './sfError'; -import { findUpperCaseKeys } from './util/sfdc'; import { Messages } from './messages'; +import { findUpperCaseKeys } from './util/findUppercaseKeys'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'config'); @@ -43,10 +43,13 @@ export type PackageDir = { postInstallScript?: string; postInstallUrl?: string; releaseNotesUrl?: string; + scopeProfiles?: boolean; uninstallScript?: string; versionDescription?: string; versionName?: string; versionNumber?: string; + unpackagedMetadata?: { path: string }; + seedMetadata?: { path: string }; }; export type NamedPackageDir = PackageDir & { @@ -88,7 +91,7 @@ export type ProjectJson = ConfigContents & { * * **See** [force:project:create](https://developer.salesforce.com/docs/atlas.en-us.sfdx_dev.meta/sfdx_dev/sfdx_dev_ws_create_new.htm) */ -export class SfProjectJson extends ConfigFile { +export class SfProjectJson extends ConfigFile { public static BLOCKLIST = ['packageAliases']; public static getFileName(): string { @@ -101,46 +104,31 @@ export class SfProjectJson extends ConfigFile { return options; } - public async read(): Promise { + public async read(): Promise { const contents = await super.read(); this.validateKeys(); return contents; } - public readSync(): ConfigContents { + public readSync(): ProjectJson { const contents = super.readSync(); this.validateKeys(); return contents; } - public async write(newContents?: ConfigContents): Promise { - if (newContents) { - this.setContents(newContents); - } + public async write(): Promise { this.validateKeys(); return super.write(); } - public writeSync(newContents?: ConfigContents): ConfigContents { - if (newContents) { - this.setContents(newContents); - } + public writeSync(): ProjectJson { this.validateKeys(); return super.writeSync(); } - public getContents(): ProjectJson { - return super.getContents() as ProjectJson; - } - // eslint-disable-next-line class-methods-use-this public getDefaultOptions(options?: ConfigFile.Options): ConfigFile.Options { - const defaultOptions: ConfigFile.Options = { - isState: false, - }; - - Object.assign(defaultOptions, options ?? {}); - return defaultOptions; + return { ...{ isState: false }, ...(options ?? {}) }; } /** @@ -334,13 +322,8 @@ export class SfProjectJson extends ConfigFile { if (!/^.{15,18}$/.test(id)) { throw messages.createError('invalidId', [id]); } - - const contents = this.getContents(); - if (!contents.packageAliases) { - contents.packageAliases = {}; - } - contents.packageAliases[alias] = id; - this.setContents(contents); + const newAliases = { ...(this.getContents().packageAliases ?? {}), [alias]: id }; + this.contents.set('packageAliases', newAliases); } /** @@ -369,12 +352,15 @@ export class SfProjectJson extends ConfigFile { dirIndex > -1 ? this.getContents().packageDirectories[dirIndex] : packageDir, packageDir ); - // update package dir entries - if (dirIndex > -1) { - this.getContents().packageDirectories[dirIndex] = packageDirEntry; - } else { - this.getContents().packageDirectories.push(packageDirEntry); - } + + const modifiedPackagesDirs = + dirIndex > -1 + ? // replace the matching entry with the new entry + this.getContents().packageDirectories.map((pd, i) => (i === dirIndex ? packageDir : pd)) + : // add the new entry to the end of the list + [...(this.getContents()?.packageDirectories ?? []), packageDirEntry]; + + this.set('packageDirectories', modifiedPackagesDirs); } // eslint-disable-next-line class-methods-use-this @@ -769,13 +755,3 @@ export class SfProject { .map(([key]) => key); } } - -/** - * @deprecated use SfProject instead - */ -export class SfdxProject extends SfProject {} - -/** - * @deprecated use SfProjectJson instead - */ -export class SfdxProjectJson extends SfProjectJson {} diff --git a/src/stateAggregator/accessors/aliasAccessor.ts b/src/stateAggregator/accessors/aliasAccessor.ts index dacff1e2c9..0d06462929 100644 --- a/src/stateAggregator/accessors/aliasAccessor.ts +++ b/src/stateAggregator/accessors/aliasAccessor.ts @@ -5,17 +5,30 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { AsyncOptionalCreatable } from '@salesforce/kit'; +import { join, dirname } from 'node:path'; +import { homedir } from 'node:os'; +import { readFile, writeFile, mkdir } from 'node:fs/promises'; +import { writeFileSync, readFileSync } from 'node:fs'; +import { lock, unlock, lockSync, unlockSync } from 'proper-lockfile'; + +import { AsyncOptionalCreatable, ensureArray } from '@salesforce/kit'; + import { Nullable } from '@salesforce/ts-types'; -import { AliasesConfig } from '../../config/aliasesConfig'; -import { AuthFields, ConfigContents } from '../../exported'; +import { Global } from '../../global'; +import { AuthFields } from '../../org/authInfo'; +import { ConfigContents } from '../../config/configStackTypes'; import { SfError } from '../../sfError'; -import { SfToken } from './tokenAccessor'; +import { lockRetryOptions, lockOptions } from '../../util/lockRetryOptions'; -export type Aliasable = string | (Partial & Partial); +export type Aliasable = string | Partial; +export const DEFAULT_GROUP = 'orgs'; +export const FILENAME = 'alias.json'; export class AliasAccessor extends AsyncOptionalCreatable { - private config!: AliasesConfig; + // set in init method + private fileLocation!: string; + /** orgs is the default group */ + private aliasStore!: Map; /** * Returns all the aliases for all the values @@ -30,14 +43,14 @@ export class AliasAccessor extends AsyncOptionalCreatable { public getAll(entity?: Aliasable): string[] | ConfigContents { // This will only return aliases under "orgs". This will need to be modified // if/when we want to support more aliases groups. - const all = (this.config.getGroup() ?? {}) as ConfigContents; + if (entity) { - const value = this.getNameOf(entity); - return Object.entries(all) - .filter((entry) => entry[1] === value) - .map((entry) => entry[0]); + const nameFromEntity = getNameOf(entity); + return Array.from(this.aliasStore.entries()) + .filter(([, value]) => nameFromEntity === value) + .map(([alias]) => alias); } else { - return all; + return Object.fromEntries(this.aliasStore.entries()); } } @@ -47,7 +60,7 @@ export class AliasAccessor extends AsyncOptionalCreatable { * @param entity the aliasable entity that you want to get the alias of */ public get(entity: Aliasable): Nullable { - return this.getAll(entity).find((alias) => alias) ?? null; + return this.getAll(entity)[0] ?? null; } /** @@ -56,7 +69,7 @@ export class AliasAccessor extends AsyncOptionalCreatable { * @param alias the alias that corresponds to a value */ public getValue(alias: string): Nullable { - return this.getAll()[alias] ?? null; + return this.aliasStore.get(alias) ?? null; } /** @@ -65,21 +78,7 @@ export class AliasAccessor extends AsyncOptionalCreatable { * @param alias the alias that corresponds to a username */ public getUsername(alias: string): Nullable { - return this.getAll()[alias] ?? null; - } - - /** - * If the provided string is an alias, it returns the corresponding value. - * If the provided string is not an alias, we assume that the provided string - * is the value and return it. - * - * This method is helpful when you don't know if the string you have is a value - * or an alias. - * - * @param valueOrAlias a string that might be a value or might be an alias - */ - public resolveValue(valueOrAlias: string): string { - return this.getValue(valueOrAlias) ?? valueOrAlias; + return this.aliasStore.get(alias) ?? null; } /** @@ -105,41 +104,92 @@ export class AliasAccessor extends AsyncOptionalCreatable { * * @param usernameOrAlias a string that might be a username or might be an alias */ - public resolveAlias(usernameOrAlias: string): Nullable { - if (this.has(usernameOrAlias)) return usernameOrAlias; - return Object.entries(this.getAll()).find(([, username]) => username === usernameOrAlias)?.[0]; + public resolveAlias(usernameOrAlias: string): string | undefined { + if (this.aliasStore.has(usernameOrAlias)) return usernameOrAlias; + return Array.from(this.aliasStore.entries()).find(([, value]) => value === usernameOrAlias)?.[0]; } /** - * Set an alias for the given aliasable entity + * Set an alias for the given aliasable entity. Writes to the file * + * @deprecated use setAndSave * @param alias the alias you want to set * @param entity the aliasable entity that's being aliased */ public set(alias: string, entity: Aliasable): void { - this.config.set(alias, this.getNameOf(entity)); + // get a very fresh copy to merge with to avoid conflicts + this.readFileToAliasStoreSync(); + this.aliasStore.set(alias, getNameOf(entity)); + this.saveAliasStoreToFileSync(); } /** - * Unset the given alias. + * Set an alias for the given aliasable entity. Writes to the file + * + * @param alias the alias you want to set + * @param entity the aliasable entity that's being aliased + */ + public async setAndSave(alias: string, entity: Aliasable): Promise { + // get a very fresh copy to merge with to avoid conflicts, then lock + await this.readFileToAliasStore(true); + this.aliasStore.set(alias, getNameOf(entity)); + return this.saveAliasStoreToFile(); + } + + /** + * Unset the given alias. Writes to the file + * + * @deprecated use unsetAndSave * */ public unset(alias: string): void { - this.config.unset(alias); + this.readFileToAliasStoreSync(); + this.aliasStore.delete(alias); + this.saveAliasStoreToFileSync(); + } + + /** + * Unset the given alias(es). Writes to the file + * + */ + public async unsetAndSave(alias: string): Promise { + await this.readFileToAliasStore(true); + this.aliasStore.delete(alias); + return this.saveAliasStoreToFile(); } /** * Unsets all the aliases for the given entity. * + * @deprecated use unsetValuesAndSave + * * @param entity the aliasable entity for which you want to unset all aliases */ public unsetAll(entity: Aliasable): void { + this.readFileToAliasStoreSync(); const aliases = this.getAll(entity); - aliases.forEach((alias) => this.unset(alias)); + aliases.forEach((a) => this.aliasStore.delete(a)); + this.saveAliasStoreToFileSync(); } - public async write(): Promise { - return this.config.write(); + /** + * Unset all the aliases for the given array of entity. + * + * @param entity the aliasable entity for which you want to unset all aliases + */ + public async unsetValuesAndSave(aliasees: Aliasable[]): Promise { + await this.readFileToAliasStore(true); + ensureArray(aliasees) + .flatMap((a) => this.getAll(a)) + .map((a) => this.aliasStore.delete(a)); + return this.saveAliasStoreToFile(); + } + + /** + * @deprecated the set/unset methods now write to the file when called. Use (un)setAndSave instead of calling (un)set and then calling write() + */ + public async write(): Promise> { + return Promise.resolve(this.getAll()); } /** @@ -148,23 +198,102 @@ export class AliasAccessor extends AsyncOptionalCreatable { * @param alias the alias you want to check */ public has(alias: string): boolean { - return this.config.has(alias); + return this.aliasStore.has(alias); } protected async init(): Promise { - this.config = await AliasesConfig.create(AliasesConfig.getDefaultOptions()); + this.fileLocation = getFileLocation(); + await this.readFileToAliasStore(); } /** - * Returns the username of given aliasable entity + * go to the fileSystem and read the file, storing a copy in the class's store + * if the file doesn't exist, create it empty */ - // eslint-disable-next-line class-methods-use-this - private getNameOf(entity: Aliasable): string { - if (typeof entity === 'string') return entity; - const aliaseeName = entity.username ?? entity.user; - if (!aliaseeName) { - throw new SfError(`Invalid aliasee, it must contain a user or username property: ${JSON.stringify(entity)}`); + private async readFileToAliasStore(useLock = false): Promise { + if (useLock) { + await lock(this.fileLocation, lockRetryOptions); + } + try { + this.aliasStore = fileContentsRawToAliasStore(await readFile(this.fileLocation, 'utf-8')); + } catch (e) { + if (e instanceof Error && 'code' in e && e.code === 'ENOENT') { + this.aliasStore = new Map(); + await mkdir(dirname(this.fileLocation), { recursive: true }); + await this.saveAliasStoreToFile(); + return; + } + if (useLock) return unlockIfLocked(this.fileLocation); + throw e; + } + } + + private async saveAliasStoreToFile(): Promise { + await writeFile(this.fileLocation, aliasStoreToRawFileContents(this.aliasStore)); + return unlockIfLocked(this.fileLocation); + } + + /** + * @deprecated use the async version of this method instead + * provided for the legacy sync set/unset methods. */ + private readFileToAliasStoreSync(): void { + // the file is guaranteed to exist because this init method ensures it + // put a lock in place. This method is only used by legacy set/unset methods. + lockSync(this.fileLocation, lockOptions); + this.aliasStore = fileContentsRawToAliasStore(readFileSync(this.fileLocation, 'utf-8')); + } + + /** + * @deprecated use the async version of this method instead + * provided for the legacy sync set/unset methods */ + private saveAliasStoreToFileSync(): void { + writeFileSync(this.fileLocation, aliasStoreToRawFileContents(this.aliasStore)); + try { + unlockSync(this.fileLocation); + } catch (e) { + // ignore the error. If it wasn't locked, that's what we wanted + if (errorIsNotAcquired(e)) return; + throw e; } - return aliaseeName; } } + +/** + * Returns the username of given aliasable entity + */ +const getNameOf = (entity: Aliasable): string => { + if (typeof entity === 'string') return entity; + const aliaseeName = entity.username; + if (!aliaseeName) { + throw new SfError(`Invalid aliasee, it must contain a user or username property: ${JSON.stringify(entity)}`); + } + return aliaseeName; +}; + +const fileContentsRawToAliasStore = (contents: string): Map => { + const fileContents = JSON.parse(contents) as { + [group: string]: { [alias: string]: string }; + [DEFAULT_GROUP]: { [alias: string]: string }; + }; + + // handle when alias file exists but is missing the org property + return new Map(Object.entries(fileContents[DEFAULT_GROUP] ?? {})); +}; + +const aliasStoreToRawFileContents = (aliasStore: Map): string => + JSON.stringify({ [DEFAULT_GROUP]: Object.fromEntries(Array.from(aliasStore.entries())) }); + +// exported for testSetup mocking +export const getFileLocation = (): string => join(homedir(), Global.SFDX_STATE_FOLDER, FILENAME); + +const unlockIfLocked = async (fileLocation: string): Promise => { + try { + await unlock(fileLocation); + } catch (e) { + // ignore the error. If it wasn't locked, that's what we wanted + if (errorIsNotAcquired(e)) return; + throw e; + } +}; + +const errorIsNotAcquired = (e: unknown): boolean => e instanceof Error && 'code' in e && e.code === 'ENOTACQUIRED'; diff --git a/src/stateAggregator/accessors/orgAccessor.ts b/src/stateAggregator/accessors/orgAccessor.ts index c1ae2d3cd7..3a44bc8e89 100644 --- a/src/stateAggregator/accessors/orgAccessor.ts +++ b/src/stateAggregator/accessors/orgAccessor.ts @@ -5,17 +5,18 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as fs from 'fs'; -import * as path from 'path'; -import { Nullable } from '@salesforce/ts-types'; +import * as fs from 'node:fs'; +import * as path from 'node:path'; +import { Nullable, entriesOf } from '@salesforce/ts-types'; import { AsyncOptionalCreatable, isEmpty } from '@salesforce/kit'; import { AuthInfoConfig } from '../../config/authInfoConfig'; import { Global } from '../../global'; -import { AuthFields } from '../../org'; +import { AuthFields } from '../../org/authInfo'; import { ConfigFile } from '../../config/configFile'; -import { ConfigContents } from '../../config/configStore'; -import { Logger } from '../../logger'; +import { ConfigContents } from '../../config/configStackTypes'; +import { Logger } from '../../logger/logger'; import { Messages } from '../../messages'; +import { Lifecycle } from '../../lifecycleEvents'; function chunk(array: T[], chunkSize: number): T[][] { const final = []; @@ -25,6 +26,7 @@ function chunk(array: T[], chunkSize: number): T[][] { export abstract class BaseOrgAccessor extends AsyncOptionalCreatable { private configs: Map> = new Map(); + /** map of Org files by username */ private contents: Map = new Map(); private logger!: Logger; @@ -41,6 +43,9 @@ export abstract class BaseOrgAccessor { const username = this.parseUsername(f); - const config = await this.initAuthFile(username); - this.configs.set(username, config); + try { + const config = await this.initAuthFile(username); + this.configs.set(username, config); + } catch (e) { + await Lifecycle.getInstance().emitWarning(`The auth file for ${username} is invalid.`); + } }); // eslint-disable-next-line no-await-in-loop await Promise.all(promises); @@ -159,10 +168,10 @@ export abstract class BaseOrgAccessor config.set(key, value)); + if (!config.has('username')) { + config.set('username', username); + } } else { // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore diff --git a/src/stateAggregator/accessors/sandboxAccessor.ts b/src/stateAggregator/accessors/sandboxAccessor.ts index 69f756433d..ecdd4c744c 100644 --- a/src/stateAggregator/accessors/sandboxAccessor.ts +++ b/src/stateAggregator/accessors/sandboxAccessor.ts @@ -7,7 +7,7 @@ /* eslint-disable class-methods-use-this */ import { SandboxOrgConfig } from '../../config/sandboxOrgConfig'; -import { SandboxFields } from '../../org'; +import { SandboxFields } from '../../org/org'; import { BaseOrgAccessor } from './orgAccessor'; export class SandboxAccessor extends BaseOrgAccessor { diff --git a/src/stateAggregator/accessors/tokenAccessor.ts b/src/stateAggregator/accessors/tokenAccessor.ts deleted file mode 100644 index 67068ed91d..0000000000 --- a/src/stateAggregator/accessors/tokenAccessor.ts +++ /dev/null @@ -1,98 +0,0 @@ -/* - * Copyright (c) 2021, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -import { AsyncOptionalCreatable } from '@salesforce/kit'; -import { JsonMap, Optional } from '@salesforce/ts-types'; -import { TokensConfig } from '../../config/tokensConfig'; - -export type SfToken = { - token: string; - url: string; - user?: string; - timestamp: string; -} & JsonMap; - -export type SfTokens = { - [key: string]: SfToken; -}; - -export class TokenAccessor extends AsyncOptionalCreatable { - private config!: TokensConfig; - - /** - * Return all tokens. - * - * @param decrypt - * @returns {SfTokens} - */ - public getAll(decrypt = false): SfTokens { - return this.config.getContents(decrypt) || {}; - } - - /** - * Return a token for the provided name. - * - * @param name - * @param decrypt - * @returns {Optional} - */ - public get(name: string, decrypt = false): Optional { - return this.config.get(name, decrypt); - } - - /** - * Return true if a given name has a token associated with it. - * - * @param name - * @returns {boolean} - */ - public has(name: string): boolean { - return !!this.getAll()[name]; - } - - /** - * Set the token for the provided name. - * - * @param name - * @param token - */ - public set(name: string, token: Partial): void { - this.config.set(name, token); - } - - /** - * Update the token for the provided name. - * - * @param name - * @param token - */ - public update(name: string, token: Partial): void { - this.config.update(name, token); - } - - /** - * Unet the token for the provided name. - * - * @param name - */ - public unset(name: string): void { - this.config.unset(name); - } - - /** - * Write the contents to the token file. - * - * @returns {Promise} - */ - public async write(): Promise { - return this.config.write(); - } - - protected async init(): Promise { - this.config = await TokensConfig.create(); - } -} diff --git a/src/stateAggregator/index.ts b/src/stateAggregator/index.ts deleted file mode 100644 index 381b749a7b..0000000000 --- a/src/stateAggregator/index.ts +++ /dev/null @@ -1,11 +0,0 @@ -/* - * Copyright (c) 2021, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -export * from './accessors/orgAccessor'; -export * from './accessors/aliasAccessor'; -export * from './accessors/tokenAccessor'; -export * from './stateAggregator'; diff --git a/src/stateAggregator/stateAggregator.ts b/src/stateAggregator/stateAggregator.ts index 395bb08a57..3259b1f91b 100644 --- a/src/stateAggregator/stateAggregator.ts +++ b/src/stateAggregator/stateAggregator.ts @@ -10,13 +10,11 @@ import { Global } from '../global'; import { AliasAccessor } from './accessors/aliasAccessor'; import { OrgAccessor } from './accessors/orgAccessor'; import { SandboxAccessor } from './accessors/sandboxAccessor'; -import { TokenAccessor } from './accessors/tokenAccessor'; export class StateAggregator extends AsyncOptionalCreatable { private static instanceMap: Map = new Map(); public aliases!: AliasAccessor; public orgs!: OrgAccessor; public sandboxes!: SandboxAccessor; - public tokens!: TokenAccessor; /** * Reuse a StateAggregator if one was already created for the current global state directory @@ -44,6 +42,5 @@ export class StateAggregator extends AsyncOptionalCreatable { this.orgs = await OrgAccessor.create(); this.sandboxes = await SandboxAccessor.create(); this.aliases = await AliasAccessor.create(); - this.tokens = await TokenAccessor.create(); } } diff --git a/src/status/myDomainResolver.ts b/src/status/myDomainResolver.ts index 1f86e69074..b93574c568 100644 --- a/src/status/myDomainResolver.ts +++ b/src/status/myDomainResolver.ts @@ -5,14 +5,14 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { lookup, resolveCname } from 'dns'; -import { URL } from 'url'; -import { promisify } from 'util'; +import { lookup, resolveCname } from 'node:dns'; +import { URL } from 'node:url'; +import { promisify } from 'node:util'; import { ensureString } from '@salesforce/ts-types'; import { AsyncOptionalCreatable, Duration, Env } from '@salesforce/kit'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfdcUrl } from '../util/sfdcUrl'; import { StatusResult } from './types'; import { PollingClient } from './pollingClient'; @@ -73,8 +73,9 @@ export class MyDomainResolver extends AsyncOptionalCreatable { - if (new Env().getBoolean('SFDX_DISABLE_DNS_CHECK', false)) { - this.logger.debug('SFDX_DISABLE_DNS_CHECK set to true. Skipping DNS check...'); + const env = new Env(); + if (env.getBoolean('SF_DISABLE_DNS_CHECK', env.getBoolean('SFDX_DISABLE_DNS_CHECK', false))) { + this.logger.debug('SF_DISABLE_DNS_CHECK set to true. Skipping DNS check...'); return this.options.url.host; } diff --git a/src/status/pollingClient.ts b/src/status/pollingClient.ts index f00d110bd4..97cd6667a0 100644 --- a/src/status/pollingClient.ts +++ b/src/status/pollingClient.ts @@ -7,7 +7,7 @@ import { AsyncOptionalCreatable, Duration } from '@salesforce/kit'; import { AnyJson, ensure } from '@salesforce/ts-types'; import { retryDecorator, NotRetryableError } from 'ts-retry-promise'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { SfError } from '../sfError'; import { Lifecycle } from '../lifecycleEvents'; import { StatusResult } from './types'; diff --git a/src/status/streamingClient.ts b/src/status/streamingClient.ts index ca5b2e7eb9..248b6d8719 100644 --- a/src/status/streamingClient.ts +++ b/src/status/streamingClient.ts @@ -7,11 +7,11 @@ /* eslint-disable @typescript-eslint/ban-ts-comment */ -import { resolve as resolveUrl } from 'url'; +import { resolve as resolveUrl } from 'node:url'; import { AsyncOptionalCreatable, Duration, Env, env, set } from '@salesforce/kit/lib'; import { AnyFunction, AnyJson, ensure, ensureString, JsonMap } from '@salesforce/ts-types/lib'; import * as Faye from 'faye'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Org } from '../org/org'; import { SfError } from '../sfError'; import { Messages } from '../messages'; @@ -215,7 +215,7 @@ export class StreamingClient extends AsyncOptionalCreatable { - let timeout: NodeJS.Timer; + let timeout: NodeJS.Timeout; return new Promise((resolve, reject) => { timeout = setTimeout(() => { @@ -243,7 +243,7 @@ export class StreamingClient extends AsyncOptionalCreatable Promise): Promise { - let timeout: NodeJS.Timer; + let timeout: NodeJS.Timeout; // This outer promise is to hold the streaming promise chain open until the streaming processor // says it's complete. @@ -323,7 +323,7 @@ export class StreamingClient extends AsyncOptionalCreatable Promise; - /** - * A function to conditionally set based on the config instance. The `this` value will be the config instance. - */ - updateContents?: () => Promise; } /** @@ -122,11 +120,9 @@ export class TestContext { */ public configStubs: { [configName: string]: Optional; - AliasesConfig?: ConfigStub; AuthInfoConfig?: ConfigStub; Config?: ConfigStub; SfProjectJson?: ConfigStub; - TokensConfig?: ConfigStub; OrgUsersConfig?: ConfigStub; } = {}; /** @@ -151,7 +147,7 @@ export class TestContext { ORGS: sinon.createSandbox(), }; - this.TEST_LOGGER = new Logger({ name: 'SFDX_Core_Test_Logger' }).useMemoryLogging(); + this.TEST_LOGGER = new Logger({ name: 'SFDX_Core_Test_Logger', useMemoryLogger: true }); if (opts.setup) { this.setup(); @@ -293,9 +289,12 @@ export class TestContext { ); const orgMap = new Map(entries); - stubMethod(this.SANDBOX, OrgAccessor.prototype, 'getAllFiles').resolves([...orgMap.keys()].map((o) => `${o}.json`)); + // @ts-expect-error because private method + this.SANDBOX.stub(OrgAccessor.prototype, 'getAllFiles').resolves([...orgMap.keys()].map((o) => `${o}.json`)); - stubMethod(this.SANDBOX, OrgAccessor.prototype, 'hasFile').callsFake((username: string) => orgMap.has(username)); + this.SANDBOX.stub(OrgAccessor.prototype, 'hasFile').callsFake((username: string) => + Promise.resolve(orgMap.has(username)) + ); const retrieveContents = async function (this: { path: string }): Promise { const username = basename(this.path.replace('.json', '')); @@ -340,9 +339,11 @@ export class TestContext { }) ); - stubMethod(this.SANDBOX, User.prototype, 'retrieve').callsFake( - (username): Promise => Promise.resolve(mockUsers.find((org) => org.username === username)) - ); + this.SANDBOX.stub(User.prototype, 'retrieve').callsFake((username): Promise => { + const user = mockUsers.find((org) => org.username === username); + if (!user) throw new SfError('User not found', 'UserNotFoundError'); + return Promise.resolve(user); + }); const retrieveContents = async function (this: { path: string }): Promise<{ usernames?: string[] }> { const orgId = basename(this.path.replace('.json', '')); @@ -361,7 +362,8 @@ export class TestContext { )) as Array<[string, SandboxFields]>; const sandboxMap = new Map(entries); - stubMethod(this.SANDBOX, SandboxAccessor.prototype, 'getAllFiles').resolves( + // @ts-expect-error because private method + this.SANDBOX.stub(SandboxAccessor.prototype, 'getAllFiles').resolves( [...sandboxMap.keys()].map((o) => `${o}.sandbox.json`) ); @@ -376,8 +378,11 @@ export class TestContext { /** * Stub the aliases in the global aliases config file. */ - public stubAliases(aliases: Record, group = AliasGroup.ORGS): void { - this.configStubs.AliasesConfig = { contents: { [group]: aliases } }; + public stubAliases(aliases: Record, group = aliasAccessorEntireFile.DEFAULT_GROUP): void { + // we don't really "stub" these since they don't use configFile. + // write the fileContents to location + fs.mkdirSync(dirname(getAliasFileLocation()), { recursive: true }); + fs.writeFileSync(getAliasFileLocation(), JSON.stringify({ [group]: aliases })); } /** @@ -390,13 +395,6 @@ export class TestContext { await ConfigAggregator.create(); } - /** - * Stub the tokens in the global token config file. - */ - public stubTokens(tokens: Record): void { - this.configStubs.TokensConfig = { contents: tokens }; - } - public restore(): void { restoreContext(this); } @@ -433,28 +431,6 @@ export class TestContext { } } -/** - * A function to generate a unique id and return it in the context of a template, if supplied. - * - * A template is a string that can contain `${%s}` to be replaced with a unique id. - * If the template contains the "%s" placeholder, it will be replaced with the unique id otherwise the id will be appended to the template. - * - * @param options an object with the following properties: - * - template: a template string. - * - length: the length of the unique id as presented in hexadecimal. - */ -export function uniqid(options?: { template?: string; length?: number }): string { - const uniqueString = randomBytes(Math.ceil((options?.length ?? 32) / 2.0)) - .toString('hex') - .slice(0, options?.length ?? 32); - if (!options?.template) { - return uniqueString; - } - return options.template.includes('%s') - ? util.format(options.template, uniqueString) - : `${options.template}${uniqueString}`; -} - function getTestLocalPath(uid: string): string { return pathJoin(osTmpdir(), uid, 'sfdx_core', 'local'); } @@ -527,12 +503,11 @@ export const stubContext = (testContext: TestContext): Record // Turn off the interoperability feature so that we don't have to mock // the old .sfdx config files Global.SFDX_INTEROPERABILITY = false; - const stubs: Record = {}; // Most core files create a child logger so stub this to return our test logger. - stubMethod(testContext.SANDBOX, Logger, 'child').resolves(testContext.TEST_LOGGER); - stubMethod(testContext.SANDBOX, Logger, 'childFromRoot').returns(testContext.TEST_LOGGER); + testContext.SANDBOX.stub(Logger, 'child').resolves(testContext.TEST_LOGGER); + testContext.SANDBOX.stub(Logger, 'childFromRoot').returns(testContext.TEST_LOGGER); testContext.inProject(true); testContext.SANDBOXES.CONFIG.stub(ConfigFile, 'resolveRootFolder').callsFake((isGlobal: boolean) => testContext.rootPathRetriever(isGlobal, testContext.id) @@ -541,9 +516,11 @@ export const stubContext = (testContext: TestContext): Record testContext.rootPathRetrieverSync(isGlobal, testContext.id) ); - stubMethod(testContext.SANDBOXES.PROJECT, SfProjectJson.prototype, 'doesPackageExist').callsFake(() => true); + // @ts-expect-error using private method + testContext.SANDBOXES.PROJECT.stub(SfProjectJson.prototype, 'doesPackageExist').callsFake(() => true); const initStubForRead = (configFile: ConfigFile): ConfigStub => { + testContext.configStubs[configFile.constructor.name] ??= {}; const stub: ConfigStub = testContext.configStubs[configFile.constructor.name] ?? {}; // init calls read calls getPath which sets the path on the config file the first time. // Since read is now stubbed, make sure to call getPath to initialize it. @@ -556,7 +533,7 @@ export const stubContext = (testContext: TestContext): Record const readSync = function (this: ConfigFile, newContents?: JsonMap): JsonMap { const stub = initStubForRead(this); - this.setContentsFromObject(newContents ?? stub.contents ?? {}); + this.setContentsFromFileContents(newContents ?? stub.contents ?? {}); return this.getContents(); }; @@ -579,42 +556,31 @@ export const stubContext = (testContext: TestContext): Record // @ts-expect-error: muting exact type match for stub readSync stubs.configReadSync = testContext.SANDBOXES.CONFIG.stub(ConfigFile.prototype, 'readSync').callsFake(readSync); - const writeSync = function (this: ConfigFile, newContents?: ConfigContents): void { - if (!testContext.configStubs[this.constructor.name]) { - testContext.configStubs[this.constructor.name] = {}; - } - const stub = testContext.configStubs[this.constructor.name]; - if (!stub) return; + const writeSync = function (this: ConfigFile): void { + testContext.configStubs[this.constructor.name] ??= {}; + const stub = testContext.configStubs[this.constructor.name] ?? {}; - this.setContents(newContents ?? this.getContents()); stub.contents = this.toObject(); }; - const write = async function (this: ConfigFile, newContents?: ConfigContents): Promise { - if (!testContext.configStubs[this.constructor.name]) { - testContext.configStubs[this.constructor.name] = {}; - } - const stub = testContext.configStubs[this.constructor.name]; - if (!stub) return; + const write = async function (this: ConfigFile): Promise { + testContext.configStubs[this.constructor.name] ??= {}; + const stub = testContext.configStubs[this.constructor.name] ?? {}; if (stub.writeFn) { - return stub.writeFn.call(this, newContents); + return stub.writeFn.call(this); } - if (stub.updateContents) { - writeSync.call(this, await stub.updateContents.call(this)); - } else { - writeSync.call(this); - } + writeSync.call(this); }; - stubs.configWriteSync = stubMethod(testContext.SANDBOXES.CONFIG, ConfigFile.prototype, 'writeSync').callsFake( - writeSync - ); + stubs.configWriteSync = testContext.SANDBOXES.CONFIG.stub(ConfigFile.prototype, 'writeSync').callsFake(writeSync); - stubs.configWrite = stubMethod(testContext.SANDBOXES.CONFIG, ConfigFile.prototype, 'write').callsFake(write); + stubs.configWrite = testContext.SANDBOXES.CONFIG.stub(ConfigFile.prototype, 'write').callsFake(write); - stubMethod(testContext.SANDBOXES.CRYPTO, Crypto.prototype, 'getKeyChain').callsFake(() => + // @ts-expect-error: getKeyChain is private + testContext.SANDBOXES.CRYPTO.stub(Crypto.prototype, 'getKeyChain').callsFake(() => + // @ts-expect-error: not the full type Promise.resolve({ setPassword: () => Promise.resolve(), getPassword: (data: Record, cb: AnyFunction) => @@ -622,9 +588,10 @@ export const stubContext = (testContext: TestContext): Record }) ); - stubMethod(testContext.SANDBOXES.CONNECTION, Connection.prototype, 'isResolvable').resolves(true); + testContext.SANDBOXES.CONNECTION.stub(Connection.prototype, 'isResolvable').resolves(true); - stubMethod(testContext.SANDBOXES.CONNECTION, Connection.prototype, 'request').callsFake(function ( + // @ts-expect-error: just enough of an httpResponse for testing + testContext.SANDBOXES.CONNECTION.stub(Connection.prototype, 'request').callsFake(function ( this: Connection, request: string, options?: Dictionary @@ -635,21 +602,25 @@ export const stubContext = (testContext: TestContext): Record return testContext.fakeConnectionRequest.call(this, request, options as AnyJson); }); - stubs.configExists = stubMethod(testContext.SANDBOXES.ORGS, OrgAccessor.prototype, 'exists').callsFake( - async function (this: OrgAccessor, username: string): Promise { - // @ts-expect-error because private member - if ([...this.contents.keys()].includes(username)) return Promise.resolve(true); - else return Promise.resolve(false); - } - ); + testContext.SANDBOX.stub(aliasAccessorEntireFile, 'getFileLocation').returns(getAliasFileLocation()); - stubs.configRemove = stubMethod(testContext.SANDBOXES.ORGS, OrgAccessor.prototype, 'remove').callsFake( - async function (this: OrgAccessor, username: string): Promise { - // @ts-expect-error because private member - if ([...this.contents.keys()].includes(username)) return Promise.resolve(true); - else return Promise.resolve(false); - } - ); + stubs.configExists = testContext.SANDBOXES.ORGS.stub(OrgAccessor.prototype, 'exists').callsFake(async function ( + this: OrgAccessor, + username: string + ): Promise { + // @ts-expect-error because private member + if ([...this.contents.keys()].includes(username)) return Promise.resolve(true); + else return Promise.resolve(false); + }); + + stubs.configRemove = testContext.SANDBOXES.ORGS.stub(OrgAccessor.prototype, 'remove').callsFake(async function ( + this: OrgAccessor, + username: string + ): Promise { + // @ts-expect-error because private member + if ([...this.contents.keys()].includes(username)) return Promise.resolve(); + else return Promise.resolve(); + }); // Always start with the default and tests beforeEach or it methods can override it. testContext.fakeConnectionRequest = defaultFakeConnectionRequest; @@ -659,6 +630,8 @@ export const stubContext = (testContext: TestContext): Record return stubs; }; +const getAliasFileLocation = (): string => + pathJoin(osTmpdir(), Global.SFDX_STATE_FOLDER, aliasAccessorEntireFile.FILENAME); /** * Restore a @salesforce/core test context. This is automatically stubbed in the global beforeEach created by * `const $$ = testSetup()` but is useful if you don't want to have a global stub of @salesforce/core and you @@ -692,71 +665,6 @@ export const restoreContext = (testContext: TestContext): void => { delete ConfigAggregator.instance; }; -// eslint-disable-next-line no-underscore-dangle -const _testSetup = (sinon?: SinonStatic): TestContext => { - const testContext = instantiateContext(sinon); - - beforeEach(() => { - // Allow each test to have their own config aggregator - // @ts-ignore clear for testing. - delete ConfigAggregator.instance; - testContext.stubs = stubContext(testContext); - }); - - afterEach(() => { - restoreContext(testContext); - }); - - return testContext; -}; - -/** - * @deprecated Use TestContext instead. - * Using testSetup will create globals stubs that could lead to erratic test behavior. - * - * This example shows you how to use TestContext: - * @example - * ``` - * const $$ = new TestContext(); - * - * beforeEach(() => { - * $$.init(); - * }); - * - * afterEach(() => { - * $$.restore(); - * }); - * ``` - * - * Use to mock out different pieces of sfdx-core to make testing easier. This will mock out - * logging to a file, config file reading and writing, local and global path resolution, and - * *http request using connection (soon)*. - * - * **Note:** The testSetup should be outside of the describe. If you need to stub per test, use - * `TestContext`. - * ``` - * // In a mocha tests - * import testSetup from '@salesforce/core/lib/testSetup'; - * - * const $$ = testSetup(); - * - * describe(() => { - * it('test', () => { - * // Stub out your own method - * $$.SANDBOX.stub(MyClass.prototype, 'myMethod').returnsFake(() => {}); - * - * // Set the contents that is used when aliases are read. Same for all config files. - * $$.stubAliases({ 'myTestAlias': 'user@company.com' }); - * - * // Will use the contents set above. - * const username = (await StateAggregator.getInstance()).aliases.resolveUsername("myTestAlias"); - * expect(username).to.equal("user@company.com"); - * }); - * }); - * ``` - */ -export const testSetup = once(_testSetup); - /** * A pre-canned error for try/catch testing. * @@ -1024,6 +932,7 @@ export class MockTestOrgData { public isScratchOrg?: boolean; public isExpired?: boolean | 'unknown'; public password?: string; + public namespacePrefix?: string; public constructor(id: string = uniqid(), options?: { username: string }) { this.testId = id; @@ -1038,6 +947,7 @@ export class MockTestOrgData { this.accessToken = `${this.testId}/accessToken`; this.refreshToken = `${this.testId}/refreshToken`; this.redirectUri = 'http://localhost:1717/OauthRedirect'; + this.namespacePrefix = `acme_${this.testId}`; } /** @@ -1132,7 +1042,8 @@ export class MockTestOrgData { config.password = crypto.encrypt(this.password); } - return config as AuthFields; + // remove "undefined" properties that don't exist in actual files + return Object.fromEntries(Object.entries(config).filter(([, v]) => v !== undefined)) as AuthFields; } /** diff --git a/src/util/checkLightningDomain.ts b/src/util/checkLightningDomain.ts index d1116d5340..6ee6f183c7 100644 --- a/src/util/checkLightningDomain.ts +++ b/src/util/checkLightningDomain.ts @@ -4,17 +4,17 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { URL } from 'url'; +import { URL } from 'node:url'; import { Env, Duration } from '@salesforce/kit'; import { MyDomainResolver } from '../status/myDomainResolver'; -import { isInternalUrl } from './sfdc'; +import { SfdcUrl } from './sfdcUrl'; export default async function checkLightningDomain(url: string): Promise { const domain = `https://${/https?:\/\/([^.]*)/.exec(url)?.slice(1, 2).pop()}.lightning.force.com`; const quantity = new Env().getNumber('SFDX_DOMAIN_RETRY', 240) ?? 0; const timeout = new Duration(quantity, Duration.Unit.SECONDS); - if (isInternalUrl(url) || timeout.seconds === 0) { + if (new SfdcUrl(url).isInternalUrl() || timeout.seconds === 0) { return true; } diff --git a/src/util/directoryWriter.ts b/src/util/directoryWriter.ts index d9b0c68139..96ebed22bf 100644 --- a/src/util/directoryWriter.ts +++ b/src/util/directoryWriter.ts @@ -5,11 +5,11 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { Readable, pipeline as cbPipeline } from 'stream'; -import * as fs from 'fs'; -import * as os from 'os'; -import * as path from 'path'; -import { promisify } from 'util'; +import { Readable, pipeline as cbPipeline } from 'node:stream'; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import * as path from 'node:path'; +import { promisify } from 'node:util'; import { StructuredWriter } from './structuredWriter'; const pipeline = promisify(cbPipeline); diff --git a/src/util/fileLocking.ts b/src/util/fileLocking.ts new file mode 100644 index 0000000000..db955221b0 --- /dev/null +++ b/src/util/fileLocking.ts @@ -0,0 +1,97 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import * as fs from 'node:fs'; +import { dirname } from 'node:path'; +import { lock, lockSync } from 'proper-lockfile'; +import { SfError } from '../sfError'; +import { Logger } from '../logger/logger'; +import { lockOptions, lockRetryOptions } from './lockRetryOptions'; + +type LockInitResponse = { writeAndUnlock: (data: string) => Promise; unlock: () => Promise }; +type LockInitSyncResponse = { writeAndUnlock: (data: string) => void; unlock: () => void }; + +/** + * + *This method exists as a separate function so it can be used by ConfigFile OR outside of ConfigFile. + * + * @param filePath where to save the file + * @returns 2 functions: + * - writeAndUnlock: a function that takes the data to write and writes it to the file, then unlocks the file whether write succeeded or not + * - unlock: a function that unlocks the file (in case you don't end up calling writeAndUnlock) + */ +export const lockInit = async (filePath: string): Promise => { + // make sure we can write to the directory + try { + await fs.promises.mkdir(dirname(filePath), { recursive: true }); + } catch (err) { + throw SfError.wrap(err as Error); + } + + const [unlock] = await Promise.all( + fs.existsSync(filePath) + ? // if the file exists, wait for it to be unlocked + [lock(filePath, lockRetryOptions)] + : // lock the entire directory to keep others from trying to create the file while we are + [ + lock(dirname(filePath), lockRetryOptions), + ( + await Logger.child('fileLocking.lockInit') + ).debug( + `No file found at ${filePath}. Write will create it. Locking the entire directory until file is written.` + ), + ] + ); + + return { + writeAndUnlock: async (data: string): Promise => { + const logger = await Logger.child('fileLocking.writeAndUnlock'); + logger.debug(`Writing to file: ${filePath}`); + try { + await fs.promises.writeFile(filePath, data); + } finally { + await unlock(); + } + }, + unlock, + }; +}; + +/** + * prefer async {@link lockInit}. + * See its documentation for details. + */ +export const lockInitSync = (filePath: string): LockInitSyncResponse => { + // make sure we can write to the directory + try { + fs.mkdirSync(dirname(filePath), { recursive: true }); + } catch (err) { + throw SfError.wrap(err as Error); + } + + const [unlock] = fs.existsSync(filePath) + ? // if the file exists, wait for it to be unlocked + [lockSync(filePath, lockOptions)] + : // lock the entire directory to keep others from trying to create the file while we are + [ + lockSync(dirname(filePath), lockOptions), + Logger.childFromRoot('fileLocking.lockInit').debug( + `No file found at ${filePath}. Write will create it. Locking the entire directory until file is written.` + ), + ]; + return { + writeAndUnlock: (data: string): void => { + const logger = Logger.childFromRoot('fileLocking.writeAndUnlock'); + logger.debug(`Writing to file: ${filePath}`); + try { + fs.writeFileSync(filePath, data); + } finally { + unlock(); + } + }, + unlock, + }; +}; diff --git a/src/util/findUppercaseKeys.ts b/src/util/findUppercaseKeys.ts new file mode 100644 index 0000000000..3452647d56 --- /dev/null +++ b/src/util/findUppercaseKeys.ts @@ -0,0 +1,25 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +import { JsonMap, Optional, isJsonMap, asJsonMap, AnyJson } from '@salesforce/ts-types'; +import { findKey } from '@salesforce/kit'; + +export const findUpperCaseKeys = (data?: JsonMap, sectionBlocklist: string[] = []): Optional => { + let key: Optional; + findKey(data, (val: AnyJson, k: string) => { + if (/^[A-Z]/.test(k)) { + key = k; + } else if (isJsonMap(val)) { + if (sectionBlocklist.includes(k)) { + return key; + } + key = findUpperCaseKeys(asJsonMap(val)); + } + return key; + }); + return key; +}; diff --git a/src/util/internal.ts b/src/util/internal.ts index ccbfff216e..1b2f538264 100644 --- a/src/util/internal.ts +++ b/src/util/internal.ts @@ -5,8 +5,8 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as fs from 'fs'; -import { join, resolve } from 'path'; +import * as fs from 'node:fs'; +import { join, resolve } from 'node:path'; import { Optional } from '@salesforce/ts-types'; import { Messages } from '../messages'; import { SfError } from '../sfError'; diff --git a/src/util/jsonXmlTools.ts b/src/util/jsonXmlTools.ts deleted file mode 100644 index ba7c79cb63..0000000000 --- a/src/util/jsonXmlTools.ts +++ /dev/null @@ -1,54 +0,0 @@ -/* - * Copyright (c) 2021, salesforce.com, inc. - * All rights reserved. - * Licensed under the BSD 3-Clause license. - * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause - */ - -import { promises as fs } from 'fs'; -import * as jsToXml from 'js2xmlparser'; -import { JsonMap } from '@salesforce/ts-types'; -import { IOptions } from 'js2xmlparser/lib/options'; - -export interface JSONasXML { - json: JsonMap; - type: string; - options?: IOptions; -} - -export interface WriteJSONasXMLInputs extends JSONasXML { - path: string; -} - -export const standardOptions: IOptions = { - declaration: { - include: true, - encoding: 'UTF-8', - version: '1.0', - }, - format: { - doubleQuotes: true, - }, -}; - -export const writeJSONasXML = async ({ - path, - json, - type, - options = standardOptions, -}: WriteJSONasXMLInputs): Promise => { - const xml = jsToXml.parse(type, fixExistingDollarSign(json), options); - return fs.writeFile(path, xml); -}; - -export const JsonAsXml = ({ json, type, options = standardOptions }: JSONasXML): string => jsToXml.parse(type, fixExistingDollarSign(json), options); - -export const fixExistingDollarSign = (existing: WriteJSONasXMLInputs['json']): Record => { - const existingCopy = { ...existing } as Record; - if (existingCopy.$) { - const temp = existingCopy.$; - delete existingCopy.$; - existingCopy['@'] = temp; - } - return existingCopy; -}; diff --git a/src/util/lockRetryOptions.ts b/src/util/lockRetryOptions.ts new file mode 100644 index 0000000000..fe1060fddd --- /dev/null +++ b/src/util/lockRetryOptions.ts @@ -0,0 +1,14 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +// docs: https://github.com/moxystudio/node-proper-lockfile + +export const lockOptions = { stale: 10_000 }; +export const lockRetryOptions = { + ...lockOptions, + retries: { retries: 10, maxTimeout: 1_000, factor: 2 }, +}; diff --git a/src/util/sfdc.ts b/src/util/sfdc.ts index 56a1797beb..c4fee36f75 100644 --- a/src/util/sfdc.ts +++ b/src/util/sfdc.ts @@ -5,10 +5,6 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { findKey } from '@salesforce/kit'; -import { AnyJson, asJsonMap, isJsonMap, JsonMap, Optional } from '@salesforce/ts-types'; -import { SfdcUrl } from './sfdcUrl'; - /** * Converts an 18 character Salesforce ID to 15 characters. * @@ -41,13 +37,6 @@ export const validateApiVersion = (value: string): boolean => value == null || / */ export const validateEmail = (value: string): boolean => /^[^.][^@]*@[^.]+(\.[^.\s]+)+$/.test(value); -/** - * Tests whether a given url is an internal Salesforce domain - * - * @param url - */ -export const isInternalUrl = (url: string): boolean => new SfdcUrl(url).isInternalUrl(); - /** * Tests whether a Salesforce ID is in the correct format, a 15- or 18-character length string with only letters and numbers * @@ -64,43 +53,14 @@ export const validateSalesforceId = (value: string): boolean => export const validatePathDoesNotContainInvalidChars = (value: string): boolean => // eslint-disable-next-line no-useless-escape !/[\["\?<>\|\]]+/.test(value); -/** - * Returns the first key within the object that has an upper case first letter. - * - * @param data The object in which to check key casing. - * @param sectionBlocklist properties in the object to exclude from the search. e.g. a blocklist of `["a"]` and data of `{ "a": { "B" : "b"}}` would ignore `B` because it is in the object value under `a`. - */ -export const findUpperCaseKeys = (data?: JsonMap, sectionBlocklist: string[] = []): Optional => { - let key: Optional; - findKey(data, (val: AnyJson, k: string) => { - if (/^[A-Z]/.test(k)) { - key = k; - } else if (isJsonMap(val)) { - if (sectionBlocklist.includes(k)) { - return key; - } - key = findUpperCaseKeys(asJsonMap(val)); - } - return key; - }); - return key; -}; + +export const accessTokenRegex = /(00D\w{12,15})![.\w]*/; +export const sfdxAuthUrlRegex = + /force:\/\/([a-zA-Z0-9._-]+):([a-zA-Z0-9._-]*):([a-zA-Z0-9._-]+={0,2})@([a-zA-Z0-9._-]+)/; /** * Tests whether a given string is an access token * * @param value */ -export const matchesAccessToken = (value: string): boolean => /^(00D\w{12,15})![.\w]*$/.test(value); - -/** @deprecated import the individual functions instead of the whole object */ -export const sfdc = { - trimTo15, - validateApiVersion, - validateEmail, - isInternalUrl, - matchesAccessToken, - validateSalesforceId, - validatePathDoesNotContainInvalidChars, - findUpperCaseKeys, -}; +export const matchesAccessToken = (value: string): boolean => accessTokenRegex.test(value); diff --git a/src/util/sfdcUrl.ts b/src/util/sfdcUrl.ts index a0207aae26..9db6deec71 100644 --- a/src/util/sfdcUrl.ts +++ b/src/util/sfdcUrl.ts @@ -5,11 +5,11 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { URL } from 'url'; +import { URL } from 'node:url'; import { Env, Duration } from '@salesforce/kit'; import { ensureNumber, ensureArray } from '@salesforce/ts-types'; import { MyDomainResolver } from '../status/myDomainResolver'; -import { Logger } from '../logger'; +import { Logger } from '../logger/logger'; import { Lifecycle } from '../lifecycleEvents'; export function getLoginAudienceCombos(audienceUrl: string, loginUrl: string): Array<[string, string]> { @@ -83,7 +83,10 @@ export class SfdcUrl extends URL { return envVarVal; } - if ((createdOrgInstance && /^gs1/gi.test(createdOrgInstance)) || /(gs1.my.salesforce.com)/gi.test(this.origin)) { + if ( + Boolean(createdOrgInstance && /^gs1/gi.test(createdOrgInstance)) || + /(gs1.my.salesforce.com)/gi.test(this.origin) + ) { return 'https://gs1.salesforce.com'; } @@ -173,7 +176,7 @@ export class SfdcUrl extends URL { * @returns {Promise} The resolved ip address or never * @throws {@link SfError} If can't resolve DNS. */ - public async checkLightningDomain(): Promise { + public async checkLightningDomain(): Promise { const quantity = ensureNumber(new Env().getNumber('SFDX_DOMAIN_RETRY', 240)); const timeout = new Duration(quantity, Duration.Unit.SECONDS); @@ -209,28 +212,6 @@ export class SfdcUrl extends URL { return resolver.resolve(); } - /** - * Tests whether this url is a sandbox url - * - * @Deprecated - identification of a sandbox instance by URL alone is not deterministic - * @param createdOrgInstance The Salesforce instance the org was created on. e.g. `cs42` - * @returns {boolean} - */ - // TODO: how to get rid of this? - public isSandboxUrl(createdOrgInstance?: string): boolean { - return ( - (createdOrgInstance && /^cs|s$/gi.test(createdOrgInstance)) || - this.origin.endsWith('sandbox.my.salesforce.mil') || - /sandbox\.my\.salesforce\.com/gi.test(this.origin) || // enhanced domains >= 230 - /(cs[0-9]+(\.my|)\.salesforce\.com)/gi.test(this.origin) || // my domains on CS instance OR CS instance without my domain - /(cs[0-9]+\.force\.com)/gi.test(this.origin) || // sandboxes have cnames like cs123.force.com - /(\w+--\w+\.my\.salesforce\.com)/gi.test(this.origin) || // sandboxes myDomain like foo--bar.my.salesforce.com - /([a-z]{3}[0-9]+s\.sfdc-.+\.salesforce\.com)/gi.test(this.origin) || // falcon sandbox ex: usa2s.sfdc-whatever.salesforce.com - /([a-z]{3}[0-9]+s\.sfdc-.+\.force\.com)/gi.test(this.origin) || // falcon sandbox ex: usa2s.sfdc-whatever.force.com - this.hostname === 'test.salesforce.com' - ); - } - /** * Test whether this url represents a lightning domain * diff --git a/src/util/structuredWriter.ts b/src/util/structuredWriter.ts index 119c095a48..5f8fad2cea 100644 --- a/src/util/structuredWriter.ts +++ b/src/util/structuredWriter.ts @@ -4,7 +4,7 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { Readable } from 'stream'; +import { Readable } from 'node:stream'; export interface StructuredWriter { addToStore(contents: string | Readable | Buffer, path: string): Promise; diff --git a/src/util/time.ts b/src/util/time.ts new file mode 100644 index 0000000000..f61cea95ef --- /dev/null +++ b/src/util/time.ts @@ -0,0 +1,9 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { performance } from 'node:perf_hooks'; + +export const nowBigInt = (): bigint => BigInt((performance.now() + performance.timeOrigin) * 1_000_000); diff --git a/src/util/uniqid.ts b/src/util/uniqid.ts new file mode 100644 index 0000000000..f64fd759d5 --- /dev/null +++ b/src/util/uniqid.ts @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { randomBytes } from 'node:crypto'; +import * as util from 'node:util'; + +/** + * A function to generate a unique id and return it in the context of a template, if supplied. + * + * A template is a string that can contain `${%s}` to be replaced with a unique id. + * If the template contains the "%s" placeholder, it will be replaced with the unique id otherwise the id will be appended to the template. + * + * @param options an object with the following properties: + * - template: a template string. + * - length: the length of the unique id as presented in hexadecimal. + */ + +export function uniqid(options?: { template?: string; length?: number }): string { + const uniqueString = randomBytes(Math.ceil((options?.length ?? 32) / 2)) + .toString('hex') + .slice(0, options?.length ?? 32); + if (!options?.template) { + return uniqueString; + } + return options.template.includes('%s') + ? util.format(options.template, uniqueString) + : `${options.template}${uniqueString}`; +} diff --git a/src/util/unwrapArray.ts b/src/util/unwrapArray.ts new file mode 100644 index 0000000000..cb7be7f4c5 --- /dev/null +++ b/src/util/unwrapArray.ts @@ -0,0 +1,12 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +export const unwrapArray = (args: unknown): unknown => { + if (Array.isArray(args) && args.length === 1) { + return Array.isArray(args[0]) ? unwrapArray(args[0]) : args[0]; + } + return args; +}; diff --git a/src/util/zipWriter.ts b/src/util/zipWriter.ts index 3f5d6e3411..aad397ba92 100644 --- a/src/util/zipWriter.ts +++ b/src/util/zipWriter.ts @@ -5,68 +5,51 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { createWriteStream, createReadStream } from 'fs'; -import { pipeline as cbPipeline, Readable, Writable } from 'stream'; -import { promisify } from 'util'; -import { Archiver, create as createArchive } from 'archiver'; +import { Readable, Writable } from 'node:stream'; +import * as JSZip from 'jszip'; +import { Logger } from '../logger/logger'; +import { SfError } from '../sfError'; import { StructuredWriter } from './structuredWriter'; -const pipeline = promisify(cbPipeline); - export class ZipWriter extends Writable implements StructuredWriter { - // compression-/speed+ (0)<---(3)---------->(9) compression+/speed- - // 3 appears to be a decent balance of compression and speed. It felt like - // higher values = diminishing returns on compression and made conversion slower - private zip: Archiver = createArchive('zip', { zlib: { level: 3 } }); - private buffers: Buffer[] = []; + private zip = JSZip(); + private zipBuffer?: Buffer; + private logger: Logger; public constructor(private readonly rootDestination?: string) { super({ objectMode: true }); - void pipeline(this.zip, this.getOutputStream()); + const destination = rootDestination ? `for: ${rootDestination}` : 'in memory'; + this.logger = Logger.childFromRoot(this.constructor.name); + this.logger.debug(`generating zip ${destination}`); } public get buffer(): Buffer { - return Buffer.concat(this.buffers); + if (!this.zipBuffer) { + throw new SfError('Must finalize the ZipWriter before getting a buffer'); + } + return this.zipBuffer; } public async addToStore(contents: string | Readable | Buffer, path: string): Promise { - this.zip.append(contents, { name: path }); + // Ensure only posix paths are added to zip files + const posixPath = path.replace(/\\/g, '/'); + this.zip.file(posixPath, contents); return Promise.resolve(); } public async finalize(): Promise { - await this.zip.finalize(); - await this.getInputBuffer(); + // compression-/speed+ (0)<---(3)---------->(9) compression+/speed- + // 3 appears to be a decent balance of compression and speed. It felt like + // higher values = diminishing returns on compression and made conversion slower + this.zipBuffer = await this.zip.generateAsync({ + type: 'nodebuffer', + compression: 'DEFLATE', + compressionOptions: { level: 3 }, + }); + this.logger.debug('Generated zip complete'); } public getDestinationPath(): string | undefined { return this.rootDestination; } - - private getOutputStream(): Writable { - if (this.rootDestination) { - return createWriteStream(this.rootDestination); - } else { - const bufferWritable = new Writable(); - // eslint-disable-next-line no-underscore-dangle - bufferWritable._write = (chunk: Buffer, encoding: string, cb: () => void): void => { - this.buffers.push(chunk); - cb(); - }; - return bufferWritable; - } - } - - private async getInputBuffer(): Promise { - if (this.rootDestination) { - const inputStream = createReadStream(this.rootDestination); - return new Promise((resolve, reject) => { - inputStream.on('data', (chunk: Buffer) => { - this.buffers.push(chunk); - }); - inputStream.once('end', () => resolve()); - inputStream.once('error', (error: Error) => reject(error)); - }); - } - } } diff --git a/src/webOAuthServer.ts b/src/webOAuthServer.ts index 7a5c8178fb..7695bb82ac 100644 --- a/src/webOAuthServer.ts +++ b/src/webOAuthServer.ts @@ -7,22 +7,27 @@ /* eslint-disable class-methods-use-this */ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ -import * as http from 'http'; -import { parse as parseQueryString } from 'querystring'; -import { parse as parseUrl } from 'url'; -import { Socket } from 'net'; -import { JwtOAuth2Config, OAuth2 } from 'jsforce'; +import * as http from 'node:http'; +import { parse as parseQueryString } from 'node:querystring'; +import { parse as parseUrl } from 'node:url'; +import { Socket } from 'node:net'; +import { EventEmitter } from 'node:events'; +import { OAuth2 } from 'jsforce'; import { AsyncCreatable, Env, set, toNumber } from '@salesforce/kit'; import { asString, get, Nullable } from '@salesforce/ts-types'; -import { Logger } from './logger'; -import { AuthInfo, DEFAULT_CONNECTED_APP_INFO } from './org'; +import { Logger } from './logger/logger'; +import { AuthInfo, DEFAULT_CONNECTED_APP_INFO } from './org/authInfo'; import { SfError } from './sfError'; import { Messages } from './messages'; import { SfProjectJson } from './sfProject'; +import { JwtOAuth2Config } from './org/authInfo'; Messages.importMessagesDirectory(__dirname); const messages = Messages.loadMessages('@salesforce/core', 'auth'); +// Server ignores requests for site icons +const iconPaths = ['/favicon.ico', '/apple-touch-icon-precomposed.png']; + /** * Handles the creation of a web server for web based login flows. * @@ -46,6 +51,7 @@ export class WebOAuthServer extends AsyncCreatable { private webServer!: WebServer; private oauth2!: OAuth2; private oauthConfig: JwtOAuth2Config; + private oauthError = new Error('Oauth Error'); public constructor(options: WebOAuthServer.Options) { super(options); @@ -94,11 +100,12 @@ export class WebOAuthServer extends AsyncCreatable { oauth2: this.oauth2, }); await authInfo.save(); - this.webServer.doRedirect(303, authInfo.getOrgFrontDoorUrl(), response); + await this.webServer.handleSuccess(response); response.end(); resolve(authInfo); } catch (err) { - this.webServer.reportError(err as Error, response); + this.oauthError = err as Error; + await this.webServer.handleError(response); reject(err); } }) @@ -148,40 +155,54 @@ export class WebOAuthServer extends AsyncCreatable { private async executeOauthRequest(): Promise { return new Promise((resolve, reject) => { this.logger.debug('Starting web auth flow'); - // eslint-disable-next-line @typescript-eslint/no-misused-promises, @typescript-eslint/no-explicit-any, @typescript-eslint/require-await - this.webServer.server.on('request', async (request: any, response) => { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const url = parseUrl(request.url); - this.logger.debug(`processing request for uri: ${url.pathname as string}`); - if (request.method === 'GET') { - if (url.pathname?.startsWith('/OauthRedirect')) { - request.query = parseQueryString(url.query as string); - if (request.query.error) { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const err = new SfError(request.query.error_description ?? request.query.error, request.query.error); - this.webServer.reportError(err, response); - return reject(err); - } - this.logger.debug(`request.query.state: ${request.query.state as string}`); - try { - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - this.oauthConfig.authCode = asString(this.parseAuthCodeFromRequest(response, request)); - resolve(response); - } catch (err) { - reject(err); + // - async method when sync expected + // eslint-disable-next-line @typescript-eslint/no-misused-promises + this.webServer.server.on('request', async (request: WebOAuthServer.Request, response) => { + if (request.url) { + const url = parseUrl(request.url); + this.logger.debug(`processing request for uri: ${url.pathname}`); + if (request.method === 'GET') { + if (url.pathname?.startsWith('/OauthRedirect') && url.query) { + request.query = parseQueryString(url.query) as { + code: string; + state: string; + error?: string | undefined; + error_description?: string; + }; + if (request.query.error) { + const errorName: string = + typeof request.query.error_description === 'string' + ? request.query.error_description + : request.query.error; + this.oauthError = new SfError(errorName, request.query.error); + await this.webServer.handleError(response); + return reject(this.oauthError); + } + this.logger.debug(`request.query.state: ${request.query.state}`); + try { + this.oauthConfig.authCode = asString(this.parseAuthCodeFromRequest(response, request)); + resolve(response); + } catch (err) { + reject(err); + } + } else if (url.pathname === '/OauthSuccess') { + this.webServer.reportSuccess(response); + } else if (url.pathname === '/OauthError') { + this.webServer.reportError(this.oauthError, response); + } else if (iconPaths.includes(url.pathname ?? '')) { + this.logger.debug(`Ignoring request for icon path: ${url.pathname}`); + } else { + this.webServer.sendError(404, 'Resource not found', response); + const errName = 'invalidRequestUri'; + const errMessage = messages.getMessage(errName, [url.pathname]); + reject(new SfError(errMessage, errName)); } } else { - this.webServer.sendError(404, 'Resource not found', response); - const errName = 'invalidRequestUri'; - const errMessage = messages.getMessage(errName, [url.pathname]); + this.webServer.sendError(405, 'Unsupported http methods', response); + const errName = 'invalidRequestMethod'; + const errMessage = messages.getMessage(errName, [request.method]); reject(new SfError(errMessage, errName)); } - } else { - this.webServer.sendError(405, 'Unsupported http methods', response); - const errName = 'invalidRequestMethod'; - // eslint-disable-next-line @typescript-eslint/no-unsafe-argument - const errMessage = messages.getMessage(errName, [request.method]); - reject(new SfError(errMessage, errName)); } }); }); @@ -197,7 +218,7 @@ export class WebOAuthServer extends AsyncCreatable { private parseAuthCodeFromRequest(response: http.ServerResponse, request: WebOAuthServer.Request): Nullable { if (!this.validateState(request)) { const error = new SfError('urlStateMismatch'); - this.webServer.sendError(400, `${error.message}\n`, response); + this.webServer.sendError(400, error.message, response); this.closeRequest(request); this.logger.warn('urlStateMismatchAttempt detected.'); if (!get(this.webServer.server, 'urlStateMismatchAttempt')) { @@ -249,7 +270,9 @@ export namespace WebOAuthServer { oauthConfig: JwtOAuth2Config; } - export type Request = http.IncomingMessage & { query: { code: string; state: string } }; + export type Request = http.IncomingMessage & { + query: { code: string; state: string; error?: string; error_description?: string }; + }; } /** @@ -262,6 +285,7 @@ export class WebServer extends AsyncCreatable { public host = 'localhost'; private logger!: Logger; private sockets: Socket[] = []; + private redirectStatus = new EventEmitter(); public constructor(options: WebServer.Options) { super(options); @@ -312,7 +336,7 @@ export class WebServer extends AsyncCreatable { /** * sends a response error. * - * @param statusCode he statusCode for the response. + * @param status the statusCode for the response. * @param message the message for the http body. * @param response the response to write the error to. */ @@ -325,11 +349,12 @@ export class WebServer extends AsyncCreatable { /** * sends a response redirect. * - * @param statusCode the statusCode for the response. + * @param status the statusCode for the response. * @param url the url to redirect to. * @param response the response to write the redirect to. */ public doRedirect(status: number, url: string, response: http.ServerResponse): void { + this.logger.debug(`Redirecting to ${url}`); response.setHeader('Content-Type', 'text/plain'); const body = `${status} - Redirecting to ${url}`; response.setHeader('Content-Length', Buffer.byteLength(body)); @@ -340,20 +365,59 @@ export class WebServer extends AsyncCreatable { /** * sends a response to the browser reporting an error. * - * @param error the error - * @param response the response to write the redirect to. + * @param error the oauth error + * @param response the HTTP response. */ public reportError(error: Error, response: http.ServerResponse): void { response.setHeader('Content-Type', 'text/html'); - const body = messages.getMessage('serverErrorHTMLResponse', [error.message]); - response.setHeader('Content-Length', Buffer.byteLength(body)); + const currentYear = new Date().getFullYear(); + const encodedImg = messages.getMessage('serverSfdcImage'); + const body = messages.getMessage('serverErrorHTMLResponse', [encodedImg, error.name, error.message, currentYear]); + response.setHeader('Content-Length', Buffer.byteLength(body, 'utf8')); response.end(body); + if (error.stack) { + this.logger.debug(error.stack); + } + this.redirectStatus.emit('complete'); + } + + /** + * sends a response to the browser reporting the success. + * + * @param response the HTTP response. + */ + public reportSuccess(response: http.ServerResponse): void { + response.setHeader('Content-Type', 'text/html'); + const currentYear = new Date().getFullYear(); + const encodedImg = messages.getMessage('serverSfdcImage'); + const body = messages.getMessage('serverSuccessHTMLResponse', [encodedImg, currentYear]); + response.setHeader('Content-Length', Buffer.byteLength(body, 'utf8')); + response.end(body); + this.redirectStatus.emit('complete'); + } + + public async handleSuccess(response: http.ServerResponse): Promise { + return this.handleRedirect(response, '/OauthSuccess'); + } + + public async handleError(response: http.ServerResponse): Promise { + return this.handleRedirect(response, '/OauthError'); } protected async init(): Promise { this.logger = await Logger.child(this.constructor.name); } + private async handleRedirect(response: http.ServerResponse, url: '/OauthSuccess' | '/OauthError'): Promise { + return new Promise((resolve) => { + this.redirectStatus.on('complete', () => { + this.logger.debug('Redirect complete'); + resolve(); + }); + this.doRedirect(303, url, response); + }); + } + /** * Make sure we can't open a socket on the localhost/host port. It's important because we don't want to send * auth tokens to a random strange port listener. We want to make sure we can startup our server first. diff --git a/test/.eslintrc.js b/test/.eslintrc.cjs similarity index 97% rename from test/.eslintrc.js rename to test/.eslintrc.cjs index f1c7d4ff18..43cb31b5c2 100644 --- a/test/.eslintrc.js +++ b/test/.eslintrc.cjs @@ -9,7 +9,7 @@ // See more at https://github.com/forcedotcom/sfdx-dev-packages/tree/master/packages/dev-scripts module.exports = { - extends: '../.eslintrc.js', + extends: '../.eslintrc.cjs', // Allow describe and it env: { mocha: true }, rules: { diff --git a/test/perf/logger/main.test.ts b/test/perf/logger/main.test.ts new file mode 100644 index 0000000000..2c8e9741d6 --- /dev/null +++ b/test/perf/logger/main.test.ts @@ -0,0 +1,44 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { Suite } from 'benchmark'; +import { Logger } from '../../../src/exported'; +import { cleanup } from '../../../src/logger/cleanup'; + +const suite = new Suite(); + +const logger = new Logger('Benchmarks'); + +// add tests +suite + .add('Child logger creation', () => { + Logger.childFromRoot('benchmarkChild'); + }) + .add('Logging a string on root logger', () => { + logger.warn('this is a string'); + }) + .add('Logging an object on root logger', () => { + logger.warn({ foo: 1, bar: 2, baz: 3 }); + }) + .add('Logging an object with a message on root logger', () => { + logger.warn({ foo: 1, bar: 2, baz: 3 }, 'this is a message'); + }) + .add('Logging an object with a redacted prop on root logger', () => { + logger.warn({ foo: 1, bar: 2, accessToken: '00D' }); + }) + .add('Logging a nested 3-level object on root logger', () => { + logger.warn({ foo: 1, bar: 2, baz: { foo: 1, bar: 2, baz: { foo: 1, bar: 2, baz: 3 } } }); + }) + // add listeners + .on('cycle', (event: any) => { + // eslint-disable-next-line no-console, @typescript-eslint/no-unsafe-member-access + console.log(String(event.target)); + }) + .on('complete', async () => { + // will clear sf log files, since this generates a LOT of them! + await cleanup(0, true); + }) + .run({ async: true }); diff --git a/test/tsconfig.json b/test/tsconfig.json index 4cd4d8cb7c..9bd21999ad 100644 --- a/test/tsconfig.json +++ b/test/tsconfig.json @@ -1,6 +1,6 @@ { "extends": "@salesforce/dev-config/tsconfig-test-strict", - "include": ["unit/**/*.ts"], + "include": ["unit/**/*.ts", "perf/**/*.ts"], "compilerOptions": { "noEmit": true, "skipLibCheck": true, diff --git a/test/unit/config/configAggregatorTest.ts b/test/unit/config/configAggregatorTest.ts index da7d37e03a..db7761f8db 100644 --- a/test/unit/config/configAggregatorTest.ts +++ b/test/unit/config/configAggregatorTest.ts @@ -6,22 +6,36 @@ */ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ /* eslint-disable @typescript-eslint/no-unsafe-call */ -import * as fs from 'fs'; -import { assert, expect } from 'chai'; -import { Config, ConfigProperties } from '../../../src/config/config'; -import { ConfigAggregator } from '../../../src/config/configAggregator'; +import * as fs from 'node:fs'; +import { assert, expect, config as chaiConfig } from 'chai'; +import { Config, ConfigProperties, SFDX_ALLOWED_PROPERTIES, SfdxPropertyKeys } from '../../../src/config/config'; +import { ConfigAggregator, ConfigInfo } from '../../../src/config/configAggregator'; import { ConfigFile } from '../../../src/config/configFile'; -import { OrgConfigProperties } from '../../../src/exported'; +import { Messages, OrgConfigProperties, Lifecycle, ORG_CONFIG_ALLOWED_PROPERTIES } from '../../../src/exported'; import { TestContext } from '../../../src/testSetup'; -const testEnvVars = ['SF_TARGET_ORG', 'SFDX_MAX_QUERY_LIMIT']; +// if you add to this, make sure you use both the old and new name +const testEnvVars = ['SF_TARGET_ORG', 'SFDX_MAX_QUERY_LIMIT', 'SF_ORG_MAX_QUERY_LIMIT', 'SFDX_DEFAULTUSERNAME']; + +chaiConfig.truncateThreshold = 0; + +Messages.importMessagesDirectory(__dirname); +const messages = Messages.loadMessages('@salesforce/core', 'config'); +const envMessages = Messages.loadMessages('@salesforce/core', 'envVars'); + +const telemetryConfigFilter = (i: ConfigInfo) => i.key !== 'disable-telemetry'; describe('ConfigAggregator', () => { let id: string; + let warnStub: sinon.SinonStub; + const $$ = new TestContext(); + beforeEach(() => { // Testing config functionality, so restore global stubs. $$.SANDBOXES.CONFIG.restore(); + $$.SANDBOX.stub(Lifecycle, 'getInstance').returns(Lifecycle.prototype); + warnStub = $$.SANDBOX.stub(Lifecycle.prototype, 'emitWarning'); id = $$.uniqid(); $$.SANDBOX.stub(ConfigFile, 'resolveRootFolder').callsFake((isGlobal: boolean) => @@ -38,95 +52,11 @@ describe('ConfigAggregator', () => { } }); - describe('instantiation', () => { - it('creates local and global config', async () => { - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getLocalConfig()).to.be.exist; - expect(aggregator.getGlobalConfig()).to.be.exist; - }); - - it('converts env vars', async () => { - process.env.SF_TARGET_ORG = 'test'; - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal('test'); - }); - - it('converts env var synonyms (sfdx -> sf)', async () => { - process.env.SFDX_MAX_QUERY_LIMIT = '5'; - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getPropertyValue(OrgConfigProperties.ORG_MAX_QUERY_LIMIT)).to.equal('5'); - }); - - it('constructor creates local and global config', async () => { - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getLocalConfig()).to.be.exist; - expect(aggregator.getGlobalConfig()).to.be.exist; - }); - - describe('with no workspace', () => { - it('does not have a local config', async () => { - try { - // Should not throw - await ConfigAggregator.create(); - } catch (err) { - assert.fail('expected an error to be thrown'); - } - }); - }); - }); - - it('static getter', async () => { - const expected = '49.0'; - $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ 'org-api-version': expected }); - expect(ConfigAggregator.getValue(OrgConfigProperties.ORG_API_VERSION).value, expected); - }); - - it('reload decrypts config values', async () => { - // readSync doesn't decrypt values - $$.SANDBOX.stub(Config.prototype, 'readSync').callsFake(function () { - // @ts-expect-error this is any - this.setContents({ 'org-isv-debugger-sid': 'encrypted' }); - // @ts-expect-error this is any - // eslint-disable-next-line @typescript-eslint/no-unsafe-return - return this.getContents(); - }); - // read decrypts values - $$.SANDBOX.stub(Config.prototype, 'read').callsFake(async function () { - // @ts-expect-error this is any - this.setContents({ 'org-isv-debugger-sid': 'decrypted' }); - // @ts-expect-error this is any - // eslint-disable-next-line @typescript-eslint/no-unsafe-return - return this.getContents(); - }); - - // @ts-expect-error because private method - const aggregator = ConfigAggregator.getInstance(); - expect(aggregator.getInfo('org-isv-debugger-sid').value).to.equal('encrypted'); - await aggregator.reload(); - expect(aggregator.getInfo('org-isv-debugger-sid').value).to.equal('decrypted'); - }); - - describe('initialization', () => { + describe('locations', () => { beforeEach(() => { - $$.SANDBOX.stub(Config.prototype, 'read').callsFake(async function (this: Config) { - const config: ConfigProperties = this.isGlobal() ? { 'target-org': 2 } : { 'target-org': 1 }; - this.setContents(config); - return config; - }); - }); - it('local overrides global', async () => { - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal(1); - }); - - it('env overrides local and global', async () => { - process.env.SF_TARGET_ORG = 'test'; - const aggregator = await ConfigAggregator.create(); - expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal('test'); + // @ts-expect-error there's a lot more properties we're not mocking + $$.SANDBOX.stub(fs.promises, 'stat').resolves({ mtimeNs: BigInt(new Date().valueOf() - 1_000 * 60 * 5) }); }); - }); - - describe('locations', () => { it('local', async () => { // @ts-expect-error async function signature not quite same as expected $$.SANDBOX.stub(fs.promises, 'readFile').callsFake(async (path: string) => { @@ -182,7 +112,7 @@ describe('ConfigAggregator', () => { $$.SANDBOX.stub(fs, 'readFile').resolves({}); const aggregator = await ConfigAggregator.create(); - const info = aggregator.getConfigInfo()[0]; + const info = aggregator.getConfigInfo().filter(telemetryConfigFilter)[0]; expect(info.key).to.equal('target-org'); expect(info.value).to.equal('test'); expect(info.location).to.equal('Environment'); @@ -192,10 +122,212 @@ describe('ConfigAggregator', () => { $$.SANDBOX.stub(fs.promises, 'readFile').resolves('{ "invalid": "entry", "org-api-version": 49.0 }'); const aggregator = await ConfigAggregator.create(); - const info = aggregator.getConfigInfo()[0]; + const info = aggregator.getConfigInfo().filter(telemetryConfigFilter)[0]; expect(info.key).to.equal('org-api-version'); expect(info.value).to.equal(49.0); expect(info.location).to.equal('Local'); }); }); + + describe('initialization', () => { + beforeEach(() => { + $$.SANDBOX.stub(Config.prototype, 'read').callsFake(async function (this: Config) { + const config: ConfigProperties = this.isGlobal() ? { 'target-org': 2 } : { 'target-org': 1 }; + this.setContents(config); + return config; + }); + }); + it('local overrides global', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal(1); + }); + + it('env overrides local and global', async () => { + process.env.SF_TARGET_ORG = 'test'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal('test'); + }); + }); + + describe('instantiation', () => { + it('creates local and global config', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getLocalConfig()).to.exist; + expect(aggregator.getGlobalConfig()).to.exist; + }); + + it('converts env vars', async () => { + process.env.SF_TARGET_ORG = 'test'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.TARGET_ORG)).to.equal('test'); + }); + + it('converts env var synonyms (sfdx -> sf)', async () => { + process.env.SFDX_MAX_QUERY_LIMIT = '5'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.ORG_MAX_QUERY_LIMIT)).to.equal('5'); + expect(warnStub.getCalls().flatMap((call) => call.args as string[])).to.deep.include( + envMessages.getMessage('deprecatedEnv', ['SFDX_MAX_QUERY_LIMIT', 'SF_ORG_MAX_QUERY_LIMIT']) + ); + }); + + it('converts env var synonyms (sf -> sfdx)', async () => { + process.env.SF_ORG_MAX_QUERY_LIMIT = '5'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(SfdxPropertyKeys.MAX_QUERY_LIMIT)).to.equal('5'); + expect(warnStub.getCalls().flatMap((call) => call.args as string[])).to.deep.include( + messages.getMessage('deprecatedConfigKey', [SfdxPropertyKeys.MAX_QUERY_LIMIT, 'org-max-query-limit']) + ); + }); + + it('both versions of an env and they match', async () => { + process.env.SF_ORG_MAX_QUERY_LIMIT = '5'; + process.env.SFDX_MAX_QUERY_LIMIT = '5'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.ORG_MAX_QUERY_LIMIT)).to.equal('5'); + expect(warnStub.callCount).to.equal(0); + }); + + it('when both versions of an envs are present, sf wins when asked for old name', async () => { + process.env.SF_ORG_MAX_QUERY_LIMIT = '5'; + process.env.SFDX_MAX_QUERY_LIMIT = '4'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(SfdxPropertyKeys.MAX_QUERY_LIMIT)).to.equal('5'); + expect(warnStub.getCalls().flatMap((call) => call.args as string[])).to.deep.include( + messages.getMessage('deprecatedConfigKey', [SfdxPropertyKeys.MAX_QUERY_LIMIT, 'org-max-query-limit']) + ); + expect(warnStub.getCalls().flatMap((call) => call.args as string[])).to.deep.include( + envMessages.getMessage('deprecatedEnvDisagreement', [ + 'SFDX_MAX_QUERY_LIMIT', + 'SF_ORG_MAX_QUERY_LIMIT', + 'SF_ORG_MAX_QUERY_LIMIT', + ]) + ); + }); + + it('when both versions of an envs are present, sf wins when asked for new name', async () => { + process.env.SF_ORG_MAX_QUERY_LIMIT = '5'; + process.env.SFDX_MAX_QUERY_LIMIT = '4'; + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyValue(OrgConfigProperties.ORG_MAX_QUERY_LIMIT)).to.equal('5'); + expect(warnStub.getCalls().flatMap((call) => call.args as string[])).to.deep.include( + envMessages.getMessage('deprecatedEnvDisagreement', [ + 'SFDX_MAX_QUERY_LIMIT', + 'SF_ORG_MAX_QUERY_LIMIT', + 'SF_ORG_MAX_QUERY_LIMIT', + ]) + ); + expect(warnStub.callCount).to.equal(1); + }); + + it('constructor creates local and global config', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getLocalConfig()).to.exist; + expect(aggregator.getGlobalConfig()).to.exist; + }); + + describe('with no workspace', () => { + it('does not have a local config', async () => { + try { + // Should not throw + await ConfigAggregator.create(); + } catch (err) { + assert.fail('expected an error to be thrown'); + } + }); + }); + it('reload decrypts config values', async () => { + // readSync doesn't decrypt values + $$.SANDBOX.stub(Config.prototype, 'readSync').callsFake(function () { + // @ts-expect-error this is any + this.setContents({ 'org-isv-debugger-sid': 'encrypted' }); + // @ts-expect-error this is any + // eslint-disable-next-line @typescript-eslint/no-unsafe-return + return this.getContents(); + }); + // read decrypts values + $$.SANDBOX.stub(Config.prototype, 'read').callsFake(async function () { + // @ts-expect-error this is any + this.setContents({ 'org-isv-debugger-sid': 'decrypted' }); + // @ts-expect-error this is any + // eslint-disable-next-line @typescript-eslint/no-unsafe-return + return this.getContents(); + }); + + // @ts-expect-error because private method + const aggregator = ConfigAggregator.getInstance(); + expect(aggregator.getInfo('org-isv-debugger-sid').value).to.equal('encrypted'); + await aggregator.reload(); + expect(aggregator.getInfo('org-isv-debugger-sid').value).to.equal('decrypted'); + }); + }); + + describe('static getter', () => { + it('request by current key', async () => { + const expected = '47.0'; + $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ 'org-api-version': expected }); + expect(ConfigAggregator.getValue(OrgConfigProperties.ORG_API_VERSION)?.value, expected); + }); + + it('request by current key matches value stored under old key', async () => { + const expected = '48.0'; + $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ apiVersion: expected }); + expect(ConfigAggregator.getValue(OrgConfigProperties.ORG_API_VERSION)?.value, expected); + }); + + it('request by old key matches value stored under current key', async () => { + const expected = '49.0'; + $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ 'org-api-version': expected }); + expect(ConfigAggregator.getValue(SfdxPropertyKeys.API_VERSION)?.value, expected); + }); + + it('request by old key matches new when both new and old are present', async () => { + const expected = '50.0'; + $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ 'org-api-version': expected, apiVersion: '50.0' }); + expect(ConfigAggregator.getValue(SfdxPropertyKeys.API_VERSION)?.value, expected); + }); + + it('request by new key matches new when both new and old are present', async () => { + const expected = '51.0'; + $$.SANDBOX.stub(Config.prototype, 'readSync').returns({ 'org-api-version': expected, apiVersion: '50.0' }); + expect(ConfigAggregator.getValue(OrgConfigProperties.ORG_API_VERSION)?.value, expected); + }); + }); + + describe('getPropertyMeta', () => { + it('key is current, has matching meta', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyMeta(OrgConfigProperties.ORG_API_VERSION)).to.equal( + ORG_CONFIG_ALLOWED_PROPERTIES.find((meta) => meta.key === OrgConfigProperties.ORG_API_VERSION) + ); + expect(warnStub.callCount).to.equal(0); + }); + it('key is deprecated, has matching meta', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyMeta(SfdxPropertyKeys.INSTANCE_URL)).to.equal( + SFDX_ALLOWED_PROPERTIES.find((meta) => meta.key === SfdxPropertyKeys.INSTANCE_URL) + ); + expect(warnStub.callCount).to.equal(1); + }); + describe('old key is known, new key comes from outside sfdx-core, but has matching meta for old key', () => { + it('permanent generic example', async () => { + // this scenario happens for 'org-metadata-rest-deploy' because 'restDeploy' is still in core, and knows its new key, + // but that config lives in PDR + // we want to fall back to avoid "Error (1): Unknown config name: org-metadata-rest-deploy." + const aggregator = await ConfigAggregator.create(); + // simulate 'restDeploy` + const oldConfigMeta = { key: 'oldProp', deprecated: true, newKey: 'newProp', description: 'whatever' }; + aggregator.addAllowedProperties([oldConfigMeta]); + expect(aggregator.getPropertyMeta('newProp')).to.equal(oldConfigMeta); + expect(warnStub.callCount).to.equal(0); + }); + it('org-metadata-rest-deploy finds restDeploy', async () => { + const aggregator = await ConfigAggregator.create(); + expect(aggregator.getPropertyMeta('org-metadata-rest-deploy')).to.equal( + SFDX_ALLOWED_PROPERTIES.find((meta) => meta.key === SfdxPropertyKeys.REST_DEPLOY) + ); + expect(warnStub.callCount).to.equal(0); + }); + }); + }); }); diff --git a/test/unit/config/configFileConcurrency.test.ts b/test/unit/config/configFileConcurrency.test.ts new file mode 100644 index 0000000000..f9f47ef29e --- /dev/null +++ b/test/unit/config/configFileConcurrency.test.ts @@ -0,0 +1,193 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { join } from 'node:path'; +import { tmpdir } from 'node:os'; +import { rm } from 'node:fs/promises'; +import { expect } from 'chai'; +import { sleep } from '@salesforce/kit'; +import { ConfigFile } from '../../../src/exported'; + +const FILENAME = 'concurrency.json'; +const sharedLocation = join('sfdx-core-ut', 'test', 'configFile'); + +class TestConfig extends ConfigFile { + public static getOptions( + filename: string, + isGlobal: boolean, + isState?: boolean, + filePath?: string + ): ConfigFile.Options { + return { + rootFolder: tmpdir(), + filename, + isGlobal, + isState, + filePath, + }; + } + + public static getFileName() { + return FILENAME; + } +} + +/* file and node - clock timestamps aren't precise enough to run in a UT. + * the goal of this and the `sleep` is to put a bit of space between operations + * to simulate real-world concurrency where it's unlikely to hit the same ms + */ +const SLEEP_FUDGE_MS = 5; + +describe('concurrency', () => { + beforeEach(async () => { + await rm(join(tmpdir(), '.sfdx', 'sfdx-core-ut'), { recursive: true, force: true }); + }); + afterEach(async () => { + await rm(join(tmpdir(), '.sfdx', 'sfdx-core-ut'), { recursive: true, force: true }); + }); + + it('merges in new props from file saved since a prop was set in memory', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config2.set('x', 1); + await config2.write(); + + const c1output = await config1.write(); + expect(c1output.x).to.equal(1); + }); + + it('newer props beat older files', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config2.set('x', 1); + await config2.write(); + await sleep(SLEEP_FUDGE_MS); + + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + + const c1output = await config1.write(); + expect(c1output.x).to.equal(0); + }); + + it('"deleted" (missing) props in a file do not delete from contents"', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config2.set('x', 1); + config2.unset('x'); + await sleep(SLEEP_FUDGE_MS); + + await config2.write(); + await sleep(SLEEP_FUDGE_MS); + + const c1output = await config1.write(); + expect(c1output.x).to.equal(0); + }); + + it('newer deleted props beat older files', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config2.set('x', 1); + + await config2.write(); + await sleep(SLEEP_FUDGE_MS); + + config1.unset('x'); + + const c1output = await config1.write(); + expect(c1output.x).to.equal(undefined); + }); + + it('deleted in both memory and file', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + config2.set('x', 1); + + await config2.write(); + await sleep(SLEEP_FUDGE_MS); + + config2.unset('x'); + await config2.write(); + + await sleep(SLEEP_FUDGE_MS); + config1.unset('x'); + + const c1output = await config1.write(); + expect(c1output.x).to.equal(undefined); + }); + + it('parallel writes from different processes produce valid json when file exists', async () => { + const config1 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + await config1.write(); + const config2 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + const config3 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + const config4 = new TestConfig(TestConfig.getOptions(FILENAME, true, true, sharedLocation)); + + config1.set('x', 0); + await sleep(SLEEP_FUDGE_MS); + config2.set('x', 1); + config2.set('b', 2); + await sleep(SLEEP_FUDGE_MS); + config3.set('x', 2); + config3.set('c', 3); + await sleep(SLEEP_FUDGE_MS); + config4.set('x', 3); + await sleep(SLEEP_FUDGE_MS); + + // simulate non-deterministic parallel operations from different processes. We can't guarantee the order of files, + // so this might result in a set prop being deleted. + await Promise.all([config1.write(), config2.write(), config3.write(), config4.write()]); + await Promise.all([config1.read(), config2.read(), config3.read(), config4.read()]); + // timestamps on the files are treated as the stamp for all props, + // since we lose the CRDT prop - level timestamps when writing to json + expect(config1.get('x')).to.be.greaterThanOrEqual(0).and.lessThanOrEqual(3); + if (config1.has('b')) { + expect(config1.get('b')).to.equal(2); + } + if (config1.has('c')) { + expect(config1.get('c')).to.equal(3); + } + if (config2.has('b')) { + expect(config2.get('b')).to.equal(2); + } + if (config2.has('c')) { + expect(config2.get('c')).to.equal(3); + } + }); + + it('parallel writes, reverse order, with deletes', async () => { + const config1 = new TestConfig(TestConfig.getOptions('test', true, true, sharedLocation)); + const config2 = new TestConfig(TestConfig.getOptions('test', true, true, sharedLocation)); + const config3 = new TestConfig(TestConfig.getOptions('test', true, true, sharedLocation)); + const config4 = new TestConfig(TestConfig.getOptions('test', true, true, sharedLocation)); + + config1.set('x', 7); + await sleep(SLEEP_FUDGE_MS); + config2.set('x', 8); + await sleep(SLEEP_FUDGE_MS); + config3.set('x', 9); + await sleep(SLEEP_FUDGE_MS); + config4.unset('x'); + + await Promise.all([config4.write(), config3.write(), config2.write(), config1.write()]); + await Promise.all([config1.read(), config2.read(), config3.read(), config4.read()]); + if (config4.has('x')) { + expect(config4.get('x')).to.be.greaterThanOrEqual(7).and.lessThanOrEqual(9); + } + }); +}); diff --git a/test/unit/config/configFileTest.ts b/test/unit/config/configFileTest.ts index 5e806d58a5..b07ca95452 100644 --- a/test/unit/config/configFileTest.ts +++ b/test/unit/config/configFileTest.ts @@ -7,11 +7,12 @@ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ /* eslint-disable @typescript-eslint/no-unsafe-call */ -import * as Path from 'path'; -import * as fs from 'fs'; +import * as Path from 'node:path'; +import * as fs from 'node:fs'; import { expect } from 'chai'; import { assert } from '@salesforce/ts-types'; +import * as lockfileLib from 'proper-lockfile'; import { ConfigFile } from '../../../src/config/configFile'; import { SfError } from '../../../src/exported'; import { shouldThrow, TestContext } from '../../../src/testSetup'; @@ -205,196 +206,217 @@ describe('Config', () => { $$.SANDBOXES.CONFIG.restore(); }); it('uses passed in contents', async () => { - // const mkdirpStub = $$.SANDBOX.stub(mkdirp, 'native'); + $$.SANDBOX.stub(fs.promises, 'readFile').resolves('{}'); + // @ts-expect-error --> we're only mocking on prop of many + $$.SANDBOX.stub(fs.promises, 'stat').resolves({ mtimeNs: BigInt(Date.now() - 1_000 * 60 * 5) }); + $$.SANDBOX.stub(fs.promises, 'mkdir').resolves(); + const lockStub = $$.SANDBOX.stub(lockfileLib, 'lock').resolves(() => Promise.resolve()); + const writeJson = $$.SANDBOX.stub(fs.promises, 'writeFile'); const config = await TestConfig.create({ isGlobal: true }); const expected = { test: 'test' }; - const actual = await config.write(expected); - expect(expected).to.equal(actual); - expect(expected).to.equal(config.getContents()); - // expect(mkdirpStub.called).to.be.true; + config.set('test', 'test'); + const actual = await config.write(); + expect(lockStub.callCount).to.equal(1); + expect(expected).to.deep.equal(actual); + expect(expected).to.deep.equal(config.getContents()); + // // expect(mkdirpStub.called).to.be.true; expect(writeJson.called).to.be.true; }); it('sync uses passed in contents', async () => { + $$.SANDBOX.stub(fs, 'readFileSync').returns('{}'); + // @ts-expect-error --> we're only mocking on prop of many + $$.SANDBOX.stub(fs, 'statSync').returns({ mtimeNs: BigInt(Date.now() - 1_000 * 60 * 5) }); + const lockStub = $$.SANDBOX.stub(lockfileLib, 'lockSync').returns(() => undefined); + const mkdirpStub = $$.SANDBOX.stub(fs, 'mkdirSync'); const writeJson = $$.SANDBOX.stub(fs, 'writeFileSync'); const config = await TestConfig.create({ isGlobal: true }); const expected = { test: 'test' }; - const actual = config.writeSync(expected); - expect(expected).to.equal(actual); - expect(expected).to.equal(config.getContents()); + config.set('test', 'test'); + const actual = config.writeSync(); + expect(lockStub.callCount).to.equal(1); + expect(expected).to.deep.equal(actual); + expect(expected).to.deep.equal(config.getContents()); expect(mkdirpStub.called).to.be.true; expect(writeJson.called).to.be.true; }); }); - const testFileContentsString = '{"foo":"bar"}'; - const testFileContentsJson = { foo: 'bar' }; - - describe('read()', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any - let readFileStub: any; - let config: TestConfig; - - beforeEach(async () => { - $$.SANDBOXES.CONFIG.restore(); - readFileStub = $$.SANDBOX.stub(fs.promises, 'readFile'); - }); - - it('caches file contents', async () => { - readFileStub.resolves(testFileContentsString); - // TestConfig.create() calls read() - config = await TestConfig.create(TestConfig.getOptions('test', false, true)); - expect(readFileStub.calledOnce).to.be.true; - - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - expect(config.getContents()).to.deep.equal(testFileContentsJson); - - // Read again. Stub should still only be called once. - const contents2 = await config.read(false, false); - expect(readFileStub.calledOnce).to.be.true; - expect(contents2).to.deep.equal(testFileContentsJson); - }); - - it('sets contents as empty object when file does not exist', async () => { - const err = SfError.wrap(new Error()); - err.code = 'ENOENT'; - readFileStub.throws(err); - - config = await TestConfig.create(TestConfig.getOptions('test', false, true)); - expect(readFileStub.calledOnce).to.be.true; - - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - expect(config.getContents()).to.deep.equal({}); - }); - it('throws when file does not exist and throwOnNotFound=true', async () => { - const err = new Error('not here'); - err.name = 'FileNotFound'; - (err as any).code = 'ENOENT'; - readFileStub.throws(SfError.wrap(err)); - - const configOptions = { - filename: 'test', - isGlobal: true, - throwOnNotFound: true, - }; - - try { - await shouldThrow(TestConfig.create(configOptions)); - } catch (e) { - expect(e).to.have.property('name', 'FileNotFound'); - } - }); - - it('sets hasRead=false by default', async () => { - const configOptions = TestConfig.getOptions('test', false, true); - const testConfig = new TestConfig(configOptions); - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(testConfig.hasRead).to.be.false; - }); - - it('forces another read of the config file with force=true', async () => { - readFileStub.resolves(testFileContentsString); - // TestConfig.create() calls read() - config = await TestConfig.create(TestConfig.getOptions('test', false, true)); - expect(readFileStub.calledOnce).to.be.true; - - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - expect(config.getContents()).to.deep.equal(testFileContentsJson); - - // Read again. Stub should now be called twice. - const contents2 = await config.read(false, true); - expect(readFileStub.calledTwice).to.be.true; - expect(contents2).to.deep.equal(testFileContentsJson); - }); - }); - - describe('readSync()', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any - let readFileStub: any; - let config: TestConfig; - - beforeEach(async () => { - $$.SANDBOXES.CONFIG.restore(); - readFileStub = $$.SANDBOX.stub(fs, 'readFileSync'); - }); - - it('caches file contents', () => { - readFileStub.returns(testFileContentsString); - // TestConfig.create() calls read() - config = new TestConfig(TestConfig.getOptions('test', false, true)); - expect(readFileStub.calledOnce).to.be.false; - - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.false; - - config.readSync(false, false); - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - expect(config.getContents()).to.deep.equal(testFileContentsJson); - - // Read again. Stub should still only be called once. - const contents2 = config.readSync(false, false); - expect(readFileStub.calledOnce).to.be.true; - expect(contents2).to.deep.equal(testFileContentsJson); - }); - - it('sets contents as empty object when file does not exist', () => { - const err = SfError.wrap(new Error()); - err.code = 'ENOENT'; - readFileStub.throws(err); - - config = new TestConfig(TestConfig.getOptions('test', false, true)); - config.readSync(); - expect(readFileStub.calledOnce).to.be.true; - - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - expect(config.getContents()).to.deep.equal({}); - }); - - it('throws when file does not exist and throwOnNotFound=true on method call', () => { - const err = new Error('not here'); - err.name = 'FileNotFound'; - (err as any).code = 'ENOENT'; - readFileStub.throws(SfError.wrap(err)); - - const configOptions = { - filename: 'test', - isGlobal: true, - throwOnNotFound: false, - }; - - try { - // The above config doesn't matter because we don't read on creation and it is overridden in the read method. - new TestConfig(configOptions).readSync(true); - assert(false, 'should throw'); - } catch (e) { - expect(e).to.have.property('name', 'FileNotFound'); - } - }); - - it('forces another read of the config file with force=true', () => { - readFileStub.returns(testFileContentsString); - // TestConfig.create() calls read() - config = new TestConfig(TestConfig.getOptions('test', false, true)); - config.readSync(); - - // -> hasRead is protected. Ignore for testing. - // @ts-expect-error -> hasRead is protected. Ignore for testing. - expect(config.hasRead).to.be.true; - - // Read again. Stub should now be called twice. - const contents2 = config.readSync(false, true); - expect(readFileStub.calledTwice).to.be.true; - expect(contents2).to.deep.equal(testFileContentsJson); + describe('read', () => { + const testFileContentsString = '{"foo":"bar"}'; + const testFileContentsJson = { foo: 'bar' }; + + describe('read()', () => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + let readFileStub: any; + let config: TestConfig; + + beforeEach(async () => { + $$.SANDBOXES.CONFIG.restore(); + readFileStub = $$.SANDBOX.stub(fs.promises, 'readFile'); + // @ts-expect-error --> we're only mocking on prop of many + $$.SANDBOX.stub(fs.promises, 'stat').resolves({ mtimeNs: BigInt(Date.now() - 1_000 * 60 * 5) }); + }); + + it('caches file contents', async () => { + readFileStub.resolves(testFileContentsString); + // TestConfig.create() calls read() + config = await TestConfig.create(TestConfig.getOptions('test', false, true)); + expect(readFileStub.calledOnce).to.be.true; + + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + expect(config.getContents()).to.deep.equal(testFileContentsJson); + + // Read again. Stub should still only be called once. + const contents2 = await config.read(false, false); + expect(readFileStub.calledOnce).to.be.true; + expect(contents2).to.deep.equal(testFileContentsJson); + }); + + it('sets contents as empty object when file does not exist', async () => { + const err = SfError.wrap(new Error()); + err.code = 'ENOENT'; + readFileStub.throws(err); + + config = await TestConfig.create(TestConfig.getOptions('test', false, true)); + expect(readFileStub.calledOnce).to.be.true; + + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + expect(config.getContents()).to.deep.equal({}); + }); + + it('throws when file does not exist and throwOnNotFound=true', async () => { + const err = new Error('not here'); + err.name = 'FileNotFound'; + (err as any).code = 'ENOENT'; + readFileStub.throws(SfError.wrap(err)); + + const configOptions = { + filename: 'test', + isGlobal: true, + throwOnNotFound: true, + }; + + try { + await shouldThrow(TestConfig.create(configOptions)); + } catch (e) { + expect(e).to.have.property('name', 'FileNotFound'); + } + }); + + it('sets hasRead=false by default', async () => { + const configOptions = TestConfig.getOptions('test', false, true); + const testConfig = new TestConfig(configOptions); + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(testConfig.hasRead).to.be.false; + }); + + it('forces another read of the config file with force=true', async () => { + readFileStub.resolves(testFileContentsString); + // TestConfig.create() calls read() + config = await TestConfig.create(TestConfig.getOptions('test', false, true)); + expect(readFileStub.calledOnce).to.be.true; + + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + expect(config.getContents()).to.deep.equal(testFileContentsJson); + + // Read again. Stub should now be called twice. + const contents2 = await config.read(false, true); + expect(readFileStub.calledTwice).to.be.true; + expect(contents2).to.deep.equal(testFileContentsJson); + }); + }); + + describe('readSync()', () => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + let readFileStub: any; + let config: TestConfig; + + beforeEach(async () => { + $$.SANDBOXES.CONFIG.restore(); + readFileStub = $$.SANDBOX.stub(fs, 'readFileSync'); + // @ts-expect-error --> we're only mocking on prop of many + $$.SANDBOX.stub(fs, 'statSync').returns({ mtimeNs: BigInt(Date.now() - 1_000 * 60 * 5) }); + }); + + it('caches file contents', () => { + readFileStub.returns(testFileContentsString); + // TestConfig.create() calls read() + config = new TestConfig(TestConfig.getOptions('test', false, true)); + expect(readFileStub.calledOnce).to.be.false; + + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.false; + + config.readSync(false, false); + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + expect(config.getContents()).to.deep.equal(testFileContentsJson); + + // Read again. Stub should still only be called once. + const contents2 = config.readSync(false, false); + expect(readFileStub.calledOnce).to.be.true; + expect(contents2).to.deep.equal(testFileContentsJson); + }); + + it('sets contents as empty object when file does not exist', () => { + const err = SfError.wrap(new Error()); + err.code = 'ENOENT'; + readFileStub.throws(err); + + config = new TestConfig(TestConfig.getOptions('test', false, true)); + config.readSync(); + expect(readFileStub.calledOnce).to.be.true; + + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + expect(config.getContents()).to.deep.equal({}); + }); + + it('throws when file does not exist and throwOnNotFound=true on method call', () => { + const err = new Error('not here'); + err.name = 'FileNotFound'; + (err as any).code = 'ENOENT'; + readFileStub.throws(SfError.wrap(err)); + + const configOptions = { + filename: 'test', + isGlobal: true, + throwOnNotFound: false, + }; + + try { + // The above config doesn't matter because we don't read on creation and it is overridden in the read method. + new TestConfig(configOptions).readSync(true); + assert(false, 'should throw'); + } catch (e) { + expect(e).to.have.property('name', 'FileNotFound'); + } + }); + + it('forces another read of the config file with force=true', () => { + readFileStub.returns(testFileContentsString); + // TestConfig.create() calls read() + config = new TestConfig(TestConfig.getOptions('test', false, true)); + config.readSync(); + + // -> hasRead is protected. Ignore for testing. + // @ts-expect-error -> hasRead is protected. Ignore for testing. + expect(config.hasRead).to.be.true; + + // Read again. Stub should now be called twice. + const contents2 = config.readSync(false, true); + expect(readFileStub.calledTwice).to.be.true; + expect(contents2).to.deep.equal(testFileContentsJson); + }); }); }); }); diff --git a/test/unit/config/configStoreTest.ts b/test/unit/config/configStoreTest.ts index 4d92c23cba..f42608b201 100644 --- a/test/unit/config/configStoreTest.ts +++ b/test/unit/config/configStoreTest.ts @@ -4,10 +4,10 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import { expect } from 'chai'; +import { expect, assert } from 'chai'; import { AuthInfoConfig } from '../../../src/config/authInfoConfig'; -import { BaseConfigStore, ConfigContents } from '../../../src/config/configStore'; -import { AuthFields } from '../../../src/org/authInfo'; +import { BaseConfigStore } from '../../../src/config/configStore'; +import { ConfigContents } from '../../../src/config/configStackTypes'; import { TestContext } from '../../../src/testSetup'; const specialKey = 'spe@cial.property'; @@ -48,26 +48,14 @@ describe('ConfigStore', () => { }); expect(st).to.equal('1a2b'); }); - it('await each value', async () => { - const config = await TestConfig.create(); - config.set('1', 'a'); - config.set('2', 'b'); - - let st = ''; - await config.awaitEach(async (key, val) => { - st += `${key}${val}`; - }); - expect(st).to.equal('1a2b'); - }); it('returns the object reference', async () => { const config = new TestConfig<{ '1': { a: string } }>(); config.set('1', { a: 'a' }); - config.get('1').a = 'b'; + config.get('1')!.a = 'b'; - expect(config.get('1').a).to.equal('b'); - expect(config.get('1.a')).to.equal('b'); + expect(config.get('1')!.a).to.equal('b'); }); it('updates the object reference', async () => { @@ -76,8 +64,13 @@ describe('ConfigStore', () => { config.update('1', { b: 'c' }); - expect(config.get('1').a).to.equal('a'); - expect(config.get('1').b).to.equal('c'); + expect(config.get('1')!.a).to.equal('a'); + expect(config.get('1')!.b).to.equal('c'); + }); + + it('undefined keys return undefined', async () => { + const config = new TestConfig<{ '1': { a: string } }>(); + expect(config.get('not-a-thing')).to.equal(undefined); }); describe('encryption', () => { @@ -88,14 +81,15 @@ describe('ConfigStore', () => { it('throws if crypto is not initialized', () => { const config = new CarConfig({}); - expect(() => config.set('owner.creditCardNumber', 'n/a')) + expect(() => config.update('owner', { creditCardNumber: 'n/a' })) .to.throw() .property('name', 'CryptoNotInitializedError'); }); it('throws if value is not strings', async () => { const config = await CarConfig.create(); - expect(() => config.set('owner.creditCardNumber', 12)) + // @ts-expect-error it should be a string, but testing what happens when it's not + expect(() => config.update('owner', { creditCardNumber: 12 })) .to.throw() .property('name', 'InvalidCryptoValueError'); }); @@ -113,7 +107,7 @@ describe('ConfigStore', () => { it('encrypts nested key', async () => { const expected = 'a29djf0kq3dj90d3q'; const config = await CarConfig.create(); - config.set('owner', { + config.update('owner', { name: 'Bob', creditCardNumber: expected, phone: '707-bob-cell', @@ -122,9 +116,9 @@ describe('ConfigStore', () => { }); const owner = config.get('owner'); // encrypted - expect(owner.creditCardNumber).to.not.equal(expected); + expect(owner?.creditCardNumber).to.not.equal(expected); // decrypted - expect(config.get('owner', true).creditCardNumber).to.equal(expected); + expect(config.get('owner', true)?.creditCardNumber).to.equal(expected); }); it('encrypts nested key using regexp', async () => { @@ -140,77 +134,25 @@ describe('ConfigStore', () => { }); const owner = config.get('owner'); // encrypted - expect(owner.superPassword).to.not.equal(expected); - // decrypted - expect(config.get('owner', true).superPassword).to.equal(expected); - }); - - it('encrypts nested query key using dot notation', async () => { - const expected = 'a29djf0kq3dj90d3q'; - const config = await CarConfig.create(); - config.set('owner.creditCardNumber', expected); - // encrypted - expect(config.get('owner.creditCardNumber')).to.not.equal(expected); - // decrypted - expect(config.get('owner.creditCardNumber', true)).to.equal(expected); - }); - - it('encrypts nested query key using accessor with single quotes', async () => { - const expected = 'a29djf0kq3dj90d3q'; - const config = await CarConfig.create(); - config.set('owner["creditCardNumber"]', expected); - // encrypted - expect(config.get("owner['creditCardNumber']")).to.not.equal(expected); - // decrypted - expect(config.get("owner['creditCardNumber']", true)).to.equal(expected); - }); - - it('encrypts nested query key using accessor with double quotes', async () => { - const expected = 'a29djf0kq3dj90d3q'; - const config = await CarConfig.create(); - config.set('owner["creditCardNumber"]', expected); - // encrypted - expect(config.get('owner["creditCardNumber"]')).to.not.equal(expected); - // decrypted - expect(config.get('owner["creditCardNumber"]', true)).to.equal(expected); - }); - - it('encrypts nested query special key using accessor with single quotes', async () => { - const expected = 'a29djf0kq3dj90d3q'; - const config = await CarConfig.create(); - const query = `owner['${specialKey}']`; - config.set(query, expected); - // encrypted - expect(config.get(query)).to.not.equal(expected); - // decrypted - expect(config.get(query, true)).to.equal(expected); - }); - - it('encrypts nested query special key using accessor with double quotes', async () => { - const expected = 'a29djf0kq3dj90d3q'; - const config = await CarConfig.create(); - const query = `owner["${specialKey}"]`; - config.set(query, expected); - // encrypted - expect(config.get(query)).to.not.equal(expected); + expect(owner?.superPassword).to.not.equal(expected); // decrypted - expect(config.get(query, true)).to.equal(expected); + expect(config.get('owner', true)?.superPassword).to.equal(expected); }); it('decrypt returns copies', async () => { const expected = 'a29djf0kq3dj90d3q'; const config = await CarConfig.create(); const owner = { name: 'Bob', creditCardNumber: expected }; - // I would love for this to throw an error, but the current typing doesn't quite work like get does. + // @ts-expect-error that's not a full owner, not all required props are set config.set('owner', owner); const decryptedOwner = config.get('owner', true); + assert(decryptedOwner); // Because we retrieved an decrypted object on a config with encryption, // it should return a clone so it doesn't accidentally save decrypted data. decryptedOwner.creditCardNumber = 'invalid'; - expect(config.get('owner').creditCardNumber).to.not.equal('invalid'); - expect(config.get('owner', true).creditCardNumber).to.equal(expected); - expect(config.get('owner.creditCardNumber', true)).to.equal(expected); + expect(config.get('owner')?.creditCardNumber).to.not.equal('invalid'); + expect(config.get('owner', true)?.creditCardNumber).to.equal(expected); }); // Ensures accessToken and refreshToken are both decrypted upon config.get() @@ -220,37 +162,40 @@ describe('ConfigStore', () => { const refreshToken = '5678'; const config = await AuthInfoConfig.create({}); const auth = { accessToken, refreshToken }; - config.set('auth', auth); + config.setContentsFromObject(auth); - expect(config.get('auth').accessToken).to.not.equal(accessToken); - expect(config.get('auth').refreshToken).to.not.equal(refreshToken); - expect(config.get('auth', true).accessToken).to.equal(accessToken); - expect(config.get('auth', true).refreshToken).to.equal(refreshToken); + expect(config.get('accessToken')).to.not.equal(accessToken); + expect(config.get('refreshToken')).to.not.equal(refreshToken); + expect(config.get('accessToken', true)).to.equal(accessToken); + expect(config.get('refreshToken', true)).to.equal(refreshToken); }); it('does not fail when saving an already encrypted object', async () => { const expected = 'a29djf0kq3dj90d3q'; const config = await CarConfig.create(); const owner = { name: 'Bob', creditCardNumber: expected }; + // @ts-expect-error incomplete owner config.set('owner', owner); - const encryptedCreditCardNumber = config.get('owner.creditCardNumber'); + const encryptedCreditCardNumber = config.get('owner')?.creditCardNumber; const contents = config.getContents(); contents.owner.name = 'Tim'; + // @ts-expect-error private method config.setContents(contents); - expect(config.get('owner.name')).to.equal(contents.owner.name); - expect(config.get('owner.creditCardNumber')).to.equal(encryptedCreditCardNumber); + expect(config.get('owner')?.name).to.equal(contents.owner.name); + expect(config.get('owner')?.creditCardNumber).to.equal(encryptedCreditCardNumber); }); it('updates encrypted object', async () => { const expected = 'a29djf0kq3dj90d3q'; const config = await CarConfig.create(); const owner = { name: 'Bob', creditCardNumber: 'old credit card number' }; + // @ts-expect-error incomplete owner config.set('owner', owner); config.update('owner', { creditCardNumber: expected }); - expect(config.get('owner.name')).to.equal(owner.name); - expect(config.get('owner.creditCardNumber', true)).to.equal(expected); + expect(config.get('owner')?.name).to.equal(owner.name); + expect(config.get('owner', true)?.creditCardNumber).to.equal(expected); }); }); }); diff --git a/test/unit/config/configTest.ts b/test/unit/config/configTest.ts index ea621713ea..8519484d9b 100644 --- a/test/unit/config/configTest.ts +++ b/test/unit/config/configTest.ts @@ -9,21 +9,20 @@ /* eslint-disable @typescript-eslint/no-unsafe-assignment */ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ -import * as fs from 'fs'; +import * as fs from 'node:fs'; import { stubMethod } from '@salesforce/ts-sinon'; -import { ensureString, JsonMap } from '@salesforce/ts-types'; +import { ensureString } from '@salesforce/ts-types'; import { expect } from 'chai'; +import * as lockfileLib from 'proper-lockfile'; import { Config, ConfigPropertyMeta } from '../../../src/config/config'; import { ConfigFile } from '../../../src/config/configFile'; -import { ConfigContents } from '../../../src/config/configStore'; +import { ConfigContents } from '../../../src/config/configStackTypes'; import { OrgConfigProperties } from '../../../src/exported'; import { shouldThrowSync, TestContext } from '../../../src/testSetup'; const configFileContentsString = '{"target-dev-hub": "configTest_devhub","target-org": "configTest_default"}'; const configFileContentsJson = { 'target-dev-hub': 'configTest_devhub', 'target-org': 'configTest_default' }; -const clone = (obj: JsonMap) => JSON.parse(JSON.stringify(obj)); - describe('Config', () => { const $$ = new TestContext(); @@ -74,7 +73,9 @@ describe('Config', () => { const config = await Config.create(Config.getDefaultOptions(true)); stubMethod($$.SANDBOX, fs.promises, 'readFile').withArgs(config.getPath()).resolves(configFileContentsString); - + stubMethod($$.SANDBOX, fs.promises, 'stat') + .withArgs(config.getPath()) + .resolves({ mtimeNs: BigInt(new Date().valueOf() - 1_000 * 60 * 5) }); // Manipulate config.hasRead to force a read // @ts-expect-error -> hasRead is protected. Ignore for testing. config.hasRead = false; @@ -88,11 +89,15 @@ describe('Config', () => { }); describe('set', () => { - it('calls Config.write with updated file contents', async () => { + beforeEach(() => { + $$.SANDBOX.stub(lockfileLib, 'lock').resolves(() => Promise.resolve()); stubMethod($$.SANDBOX, fs.promises, 'readFile').resolves(configFileContentsString); + stubMethod($$.SANDBOX, fs.promises, 'stat').resolves({ mtimeNs: BigInt(new Date().valueOf() - 1_000 * 60 * 5) }); + }); + it('calls Config.write with updated file contents', async () => { const writeStub = stubMethod($$.SANDBOX, fs.promises, 'writeFile'); - const expectedFileContents = clone(configFileContentsJson); + const expectedFileContents = structuredClone(configFileContentsJson); const newUsername = 'updated_val'; expectedFileContents['target-org'] = newUsername; @@ -102,13 +107,12 @@ describe('Config', () => { }); it('calls Config.write with deleted file contents', async () => { - const expectedFileContents = clone(configFileContentsJson); + const expectedFileContents = structuredClone(configFileContentsJson); const newUsername = 'updated_val'; expectedFileContents['target-org'] = newUsername; await Config.update(false, 'target-org', newUsername); - stubMethod($$.SANDBOX, fs.promises, 'readFile').resolves(configFileContentsString); const writeStub = stubMethod($$.SANDBOX, fs.promises, 'writeFile'); const targetDevhub = configFileContentsJson['target-dev-hub']; @@ -225,11 +229,13 @@ describe('Config', () => { describe('unset', () => { it('calls Config.write with updated file contents', async () => { + $$.SANDBOX.stub(lockfileLib, 'lock').resolves(() => Promise.resolve()); stubMethod($$.SANDBOX, fs.promises, 'readFile').resolves(configFileContentsString); + stubMethod($$.SANDBOX, fs.promises, 'stat').resolves({ mtimeNs: BigInt(new Date().valueOf() - 1_000 * 60 * 5) }); const writeStub = stubMethod($$.SANDBOX, fs.promises, 'writeFile'); - const expectedFileContents = clone(configFileContentsJson); - delete expectedFileContents['target-org']; + // eslint-disable-next-line @typescript-eslint/no-unused-vars + const { 'target-org': deleteThis, ...expectedFileContents } = structuredClone(configFileContentsJson); const config = await Config.create({ isGlobal: false }); config.unset('target-org'); @@ -273,7 +279,7 @@ describe('Config', () => { stubMethod($$.SANDBOX, ConfigFile.prototype, ConfigFile.prototype.read.name).callsFake(async function () { // @ts-expect-error -> this is any // eslint-disable-next-line @typescript-eslint/no-unsafe-call - this.setContentsFromObject({ unknown: 'unknown config key and value' }); + this.setContentsFromFileContents({ unknown: 'unknown config key and value' }); }); const config = await Config.create({ isGlobal: true }); diff --git a/test/unit/config/envVarsTest.ts b/test/unit/config/envVarsTest.ts index e4096f6d04..d65d1d39b6 100644 --- a/test/unit/config/envVarsTest.ts +++ b/test/unit/config/envVarsTest.ts @@ -7,14 +7,20 @@ import { expect } from 'chai'; import { describe } from 'mocha'; import { EnvVars } from '../../../src/config/envVars'; -import { Global } from '../../../src/global'; import { TestContext } from '../../../src/testSetup'; +import { Lifecycle } from '../../../src/lifecycleEvents'; +import { Messages } from '../../../src/messages'; + +Messages.importMessagesDirectory(__dirname); +const messages = Messages.loadMessages('@salesforce/core', 'envVars'); describe('envVars', () => { - const testEnvVars = ['foo', 'SFDX_ACCESS_TOKEN', 'SF_ACCESS_TOKEN', 'SF_SFDX_INTEROPERABILITY']; + const testEnvVars = ['foo', 'SFDX_ACCESS_TOKEN', 'SF_ACCESS_TOKEN']; + const $$ = new TestContext(); + let warnStub: sinon.SinonStub; beforeEach(() => { - Global.SFDX_INTEROPERABILITY = true; + warnStub = $$.SANDBOX.stub(Lifecycle.prototype, 'emitWarning'); }); afterEach(() => { @@ -27,39 +33,44 @@ describe('envVars', () => { process.env['foo'] = 'bar'; const envVars = new EnvVars(); expect(envVars.getString('foo')).to.equal('bar'); + expect(warnStub.callCount).to.equal(0); }); - it('should load well known env var', () => { - process.env['SFDX_ACCESS_TOKEN'] = 'some access token'; + it('should load well known env var (replaced)', () => { + process.env['SF_ACCESS_TOKEN'] = 'some access token'; const envVars = new EnvVars(); - expect(envVars.getString('SFDX_ACCESS_TOKEN')).to.equal('some access token'); + expect(envVars.getString('SF_ACCESS_TOKEN')).to.equal('some access token'); + expect(warnStub.callCount).to.equal(0); }); - it('should load well known env var and set synonym', () => { + it('should load well known env var (replaced)', () => { process.env['SFDX_ACCESS_TOKEN'] = 'some access token'; const envVars = new EnvVars(); expect(envVars.getString('SFDX_ACCESS_TOKEN')).to.equal('some access token'); - expect(envVars.getString('SF_ACCESS_TOKEN')).to.equal('some access token'); + expect(warnStub.getCalls().flatMap((c) => c.args)).to.deep.include( + messages.getMessage('deprecatedEnv', ['SFDX_ACCESS_TOKEN', 'SF_ACCESS_TOKEN']) + ); + expect(warnStub.callCount).to.equal(1); }); - it('should load well known env var and override existing synonym', () => { + it('should load well known env var and set synonym', () => { process.env['SFDX_ACCESS_TOKEN'] = 'some access token'; - process.env['SF_ACCESS_TOKEN'] = 'some other access token'; const envVars = new EnvVars(); expect(envVars.getString('SFDX_ACCESS_TOKEN')).to.equal('some access token'); expect(envVars.getString('SF_ACCESS_TOKEN')).to.equal('some access token'); + expect(warnStub.getCalls().flatMap((c) => c.args)).to.deep.include( + messages.getMessage('deprecatedEnv', ['SFDX_ACCESS_TOKEN', 'SF_ACCESS_TOKEN']) + ); }); -}); -describe('envVars - no interop', () => { - // TestContext disables interoperability - new TestContext(); - - it('should load well known env var not set synonym interoperability is disabled', () => { + it('should load well known env var and override existing synonym', () => { process.env['SFDX_ACCESS_TOKEN'] = 'some access token'; process.env['SF_ACCESS_TOKEN'] = 'some other access token'; const envVars = new EnvVars(); - expect(envVars.getString('SFDX_ACCESS_TOKEN')).to.equal('some access token'); + expect(envVars.getString('SFDX_ACCESS_TOKEN')).to.equal('some other access token'); expect(envVars.getString('SF_ACCESS_TOKEN')).to.equal('some other access token'); + expect(warnStub.getCalls().flatMap((c) => c.args)).to.deep.include( + messages.getMessage('deprecatedEnvDisagreement', ['SFDX_ACCESS_TOKEN', 'SF_ACCESS_TOKEN', 'SF_ACCESS_TOKEN']) + ); }); }); diff --git a/test/unit/config/lwwMapTest.ts b/test/unit/config/lwwMapTest.ts new file mode 100644 index 0000000000..cba9eb4d97 --- /dev/null +++ b/test/unit/config/lwwMapTest.ts @@ -0,0 +1,184 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { expect, config } from 'chai'; +import { LWWMap, LWWState, SYMBOL_FOR_DELETED } from '../../../src/config/lwwMap'; +import { nowBigInt } from '../../../src/util/time'; + +config.truncateThreshold = 0; +// unit is ns. 1_000_000_000 ns = 1s +const TIMESTAMP_OFFSET = BigInt(1_000_000_000); + +describe('LWWMap', () => { + type TestType = { foo: string; baz: string; opt?: number; optNull?: null }; + let state: LWWState; + + describe('all properties are known', () => { + let lwwMap: LWWMap; + + beforeEach(() => { + state = { + foo: { value: 'bar', timestamp: nowBigInt() }, + baz: { value: 'qux', timestamp: nowBigInt() }, + }; + lwwMap = new LWWMap(state); + }); + + it('should initialize with the correct state', () => { + expect(lwwMap.state).to.deep.equal(state); + }); + + it('should get the correct value for the entire object', () => { + expect(lwwMap.value).to.deep.equal({ foo: 'bar', baz: 'qux' }); + }); + + it('has when it has', () => { + expect(lwwMap.has('foo')).to.be.true; + }); + + it('sets a new key', () => { + lwwMap.set('opt', 4); + expect(lwwMap.has('opt')).to.be.true; + }); + + it('get by key', () => { + expect(lwwMap.get('foo')).to.equal('bar'); + }); + + it('get missing by key', () => { + expect(lwwMap.get('opt')).to.equal(undefined); + }); + + it('has when it does not have', () => { + expect(lwwMap.has('nope')).to.be.false; + expect(lwwMap.state).to.deep.equal(state); + }); + + it('has is false for deleted', () => { + lwwMap.delete('foo'); + expect(lwwMap.has('foo')).to.be.false; + }); + + it('deletes a key that exists', () => { + lwwMap.delete('foo'); + expect(lwwMap.has('foo')).to.be.false; + expect(lwwMap.value).to.deep.equal({ baz: 'qux' }); + expect(lwwMap.state.baz).to.deep.equal(state.baz); + expect(lwwMap.state.foo.value).to.equal(SYMBOL_FOR_DELETED); + }); + + it('set and get an optional null', () => { + lwwMap.set('optNull', null); + expect(lwwMap.get('optNull')).to.be.null; + }); + + describe('merge', () => { + beforeEach(() => { + lwwMap = new LWWMap(state); + }); + it('all are updated', () => { + const remoteState = { + foo: { value: 'bar2', timestamp: nowBigInt() }, + baz: { value: 'qux2', timestamp: nowBigInt() }, + } satisfies LWWState; + lwwMap.merge(remoteState); + expect(lwwMap.state).to.deep.equal(remoteState); + expect(lwwMap.get('foo')).to.equal('bar2'); + }); + it('all are deleted', () => { + const remoteState = { + foo: { value: SYMBOL_FOR_DELETED, timestamp: nowBigInt() }, + baz: { value: SYMBOL_FOR_DELETED, timestamp: nowBigInt() }, + } satisfies LWWState; + lwwMap.merge(remoteState); + expect(lwwMap.state).to.deep.equal(remoteState); + expect(lwwMap.get('foo')).to.equal(undefined); + }); + it('none are updated', () => { + const remoteState = { + foo: { value: 'bar2', timestamp: nowBigInt() - TIMESTAMP_OFFSET }, + baz: { value: 'qux2', timestamp: nowBigInt() - TIMESTAMP_OFFSET }, + } satisfies LWWState; + lwwMap.merge(remoteState); + expect(lwwMap.state).to.deep.equal(state); + expect(lwwMap.get('foo')).to.equal('bar'); + }); + it('one is update, one is added, one is deleted', () => { + lwwMap.set('opt', 4); + const remoteState = { + foo: { value: 'bar2', timestamp: nowBigInt() }, + baz: { value: 'qux2', timestamp: nowBigInt() - TIMESTAMP_OFFSET }, + opt: { value: SYMBOL_FOR_DELETED, timestamp: nowBigInt() + TIMESTAMP_OFFSET }, + optNull: { value: null, timestamp: nowBigInt() }, + } satisfies LWWState; + lwwMap.merge(remoteState); + expect(lwwMap.get('foo')).to.equal('bar2'); + expect(lwwMap.get('baz')).to.equal('qux'); + expect(lwwMap.state.opt?.value).to.equal(SYMBOL_FOR_DELETED); + expect(lwwMap.get('opt')).to.be.undefined; + }); + }); + }); + + describe('open-ended objects', () => { + type OpenEndedType = TestType & { [key: string]: string }; + const initialState = { + foo: { value: 'bar', timestamp: nowBigInt() }, + baz: { value: 'qux', timestamp: nowBigInt() }, + } satisfies LWWState; + + it('set a new prop', () => { + const lwwMap = new LWWMap(initialState); + lwwMap.set('thing', 'whatever'); + expect(lwwMap.get('thing')).to.equal('whatever'); + expect(lwwMap.value).to.deep.equal({ foo: 'bar', baz: 'qux', thing: 'whatever' }); + expect(lwwMap.state.thing.value).to.equal('whatever'); + }); + + it('set and delete new prop', () => { + const lwwMap = new LWWMap(initialState); + lwwMap.set('thing', 'whatever'); + expect(lwwMap.get('thing')).to.equal('whatever'); + lwwMap.delete('thing'); + expect(lwwMap.get('thing')).to.be.undefined; + expect(lwwMap.value).to.deep.equal({ foo: 'bar', baz: 'qux' }); + expect(lwwMap.state.thing.value).to.equal(SYMBOL_FOR_DELETED); + }); + + it('delete a non-existent prop', () => { + const lwwMap = new LWWMap(initialState); + expect(lwwMap.get('gone')).to.be.undefined; + lwwMap.delete('gone'); + expect(lwwMap.get('gone')).to.be.undefined; + expect(lwwMap.value).to.deep.equal({ foo: 'bar', baz: 'qux' }); + expect(lwwMap.state.gone.value).to.equal(SYMBOL_FOR_DELETED); + }); + }); +}); + +describe('nested objects', () => { + type NestedOpenEndedObject = { foo: string; baz: string; opt?: number; optNull?: null; obj: Record }; + + let state: LWWState; + let lwwMap: LWWMap; + + beforeEach(() => { + state = { + foo: { value: 'bar', timestamp: nowBigInt() }, + baz: { value: 'qux', timestamp: nowBigInt() }, + obj: { value: { a: 1, b: 2, c: 3 }, timestamp: nowBigInt() }, + }; + lwwMap = new LWWMap(state); + }); + + it('should initialize with the correct state', () => { + expect(lwwMap.state).to.deep.equal(state); + }); + + it('should get the correct value for the entire object', () => { + expect(lwwMap.value).to.deep.equal({ foo: 'bar', baz: 'qux', obj: { a: 1, b: 2, c: 3 } }); + }); +}); diff --git a/test/unit/config/ttlConfigTest.ts b/test/unit/config/ttlConfigTest.ts index cd7f1eb82c..144b5bd8d3 100644 --- a/test/unit/config/ttlConfigTest.ts +++ b/test/unit/config/ttlConfigTest.ts @@ -85,15 +85,42 @@ describe('TTLConfig', () => { it('should return true if timestamp is older than TTL', async () => { const config = await TestConfig.create(); config.set('1', { one: 'one' }); - const isExpired = config.isExpired(new Date().getTime() + Duration.days(7).milliseconds, config.get('1')); + const isExpired = config.isExpired(new Date().getTime() + Duration.days(7).milliseconds, config.get('1')!); expect(isExpired).to.be.true; }); it('should return false if timestamp is not older than TTL', async () => { const config = await TestConfig.create(); config.set('1', { one: 'one' }); - const isExpired = config.isExpired(new Date().getTime(), config.get('1')); + const isExpired = config.isExpired(new Date().getTime(), config.get('1')!); expect(isExpired).to.be.false; }); }); + + describe('filters expired keys on init', () => { + it('should omit expired keys', async () => { + $$.setConfigStubContents('TestConfig', { + contents: { + old: { + value: 1, + timestamp: new Date().getTime() - Duration.days(7).milliseconds, + }, + current: { + value: 2, + timestamp: new Date().getTime(), + }, + future: { + value: 3, + timestamp: new Date().getTime() + Duration.days(7).milliseconds, + }, + }, + }); + + const config = await TestConfig.create(); + const keys = config.keys(); + expect(keys).to.include('current'); + expect(keys).to.include('future'); + expect(keys).to.not.include('old'); + }); + }); }); diff --git a/test/unit/crypto/cryptoKeyFailuresTest.ts b/test/unit/crypto/cryptoKeyFailuresTest.ts index e5d3c7b768..4525d24ca0 100644 --- a/test/unit/crypto/cryptoKeyFailuresTest.ts +++ b/test/unit/crypto/cryptoKeyFailuresTest.ts @@ -6,9 +6,9 @@ */ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ -import * as childProcess from 'child_process'; -import * as _crypto from 'crypto'; -import * as os from 'os'; +import * as childProcess from 'node:child_process'; +import * as _crypto from 'node:crypto'; +import * as os from 'node:os'; import { AnyJson } from '@salesforce/ts-types'; import { assert, expect } from 'chai'; import { Crypto } from '../../../src/crypto/crypto'; @@ -39,14 +39,14 @@ if (os.platform() === 'darwin') { describe('CryptoKeyFailureTests', () => { const $$ = new TestContext(); - const OLD_GENERIC_VAL = process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN; + const OLD_GENERIC_VAL = process.env.SF_USE_GENERIC_UNIX_KEYCHAIN; before(() => { - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = 'false'; + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = 'false'; }); after(() => { - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = OLD_GENERIC_VAL ?? ''; + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = OLD_GENERIC_VAL ?? ''; Cache.enable(); }); diff --git a/test/unit/crypto/cryptoTest.ts b/test/unit/crypto/cryptoTest.ts index 81995aab64..461c018e4f 100644 --- a/test/unit/crypto/cryptoTest.ts +++ b/test/unit/crypto/cryptoTest.ts @@ -6,7 +6,7 @@ */ /* eslint-disable @typescript-eslint/ban-types */ -import * as os from 'os'; +import * as os from 'node:os'; import { stubMethod } from '@salesforce/ts-sinon'; import { expect } from 'chai'; import { Crypto } from '../../../src/crypto/crypto'; @@ -146,9 +146,7 @@ describe('CryptoTest', function () { }); it('Decrypt should fail without env var, and add extra message', async () => { - const message = Messages.load('@salesforce/core', 'encryption', ['macKeychainOutOfSync']).getMessage( - 'macKeychainOutOfSync' - ); + const message = Messages.loadMessages('@salesforce/core', 'encryption').getMessage('macKeychainOutOfSync'); const err = Error('Failed to decipher auth data. reason: Unsupported state or unable to authenticate data.'); const sfdxErr = SfError.wrap(err); sfdxErr.actions = []; @@ -171,10 +169,8 @@ describe('CryptoTest', function () { }); it('Decrypt should fail but not add extra message with env var', async () => { - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = 'false'; - const message: string = Messages.load('@salesforce/core', 'encryption', ['authDecryptError']).getMessage( - 'authDecryptError' - ); + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = 'false'; + const message: string = Messages.loadMessages('@salesforce/core', 'encryption').getMessage('authDecryptError'); const errorMessage: object = SfError.wrap(new Error(message)); stubMethod($$.SANDBOX, os, 'platform').returns('darwin'); stubMethod($$.SANDBOX, crypto, 'decrypt').callsFake(() => ({ @@ -189,7 +185,7 @@ describe('CryptoTest', function () { await crypto.init(); // @ts-expect-error: secret is not a string expect(() => crypto.decrypt(secret)).to.not.throw(message); - delete process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN; + delete process.env.SF_USE_GENERIC_UNIX_KEYCHAIN; }); } }); diff --git a/test/unit/crypto/keyChainImplTest.ts b/test/unit/crypto/keyChainImplTest.ts index c597dba2b7..fa2e370b63 100644 --- a/test/unit/crypto/keyChainImplTest.ts +++ b/test/unit/crypto/keyChainImplTest.ts @@ -11,7 +11,7 @@ /* eslint-disable no-underscore-dangle */ /* eslint-disable @typescript-eslint/no-unsafe-assignment */ -import * as fs from 'fs'; +import * as fs from 'node:fs'; import { assert, expect } from 'chai'; import { KeychainAccess, keyChainImpl } from '../../../src/crypto/keyChainImpl'; import { shouldThrow, TestContext } from '../../../src/testSetup'; diff --git a/test/unit/crypto/keyChainTest.ts b/test/unit/crypto/keyChainTest.ts index c494fc1693..ce743232b9 100644 --- a/test/unit/crypto/keyChainTest.ts +++ b/test/unit/crypto/keyChainTest.ts @@ -5,11 +5,10 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as path from 'path'; -import * as fs from 'fs'; +import * as path from 'node:path'; +import * as fs from 'node:fs'; import { Nullable } from '@salesforce/ts-types'; import { expect } from 'chai'; -import * as _ from 'lodash'; import { retrieveKeychain } from '../../../src/crypto/keyChain'; import { GenericUnixKeychainAccess, @@ -20,23 +19,23 @@ import { TestContext } from '../../../src/testSetup'; describe('keyChain', () => { const $$ = new TestContext(); - const OLD_SFDX_GENERIC_VAL = process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN; + const OLD_SFDX_GENERIC_VAL = process.env.SF_USE_GENERIC_UNIX_KEYCHAIN; const OLD_GENERIC_VAL = process.env.USE_GENERIC_UNIX_KEYCHAIN; beforeEach(() => { // Testing crypto functionality, so restore global stubs. $$.SANDBOXES.CRYPTO.restore(); - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = 'false'; + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = 'false'; process.env.USE_GENERIC_UNIX_KEYCHAIN = 'false'; }); after(() => { - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = OLD_SFDX_GENERIC_VAL || ''; - process.env.USE_GENERIC_UNIX_KEYCHAIN = OLD_GENERIC_VAL || ''; + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = OLD_SFDX_GENERIC_VAL ?? ''; + process.env.USE_GENERIC_UNIX_KEYCHAIN = OLD_GENERIC_VAL ?? ''; }); - it('should return OSX keychain and lib secret', () => { + it('should return OSX keychain and lib secret', async () => { $$.SANDBOX.stub(keyChainImpl.linux, 'validateProgram').resolves(); const testArray = [ @@ -47,22 +46,30 @@ describe('keyChain', () => { }, ]; - const promiseArray = testArray.map((obj) => retrieveKeychain(obj.osName)); - - return Promise.all(promiseArray).then((_keychains) => { - _.forEach(_keychains, (_keychain: any) => { - expect(_keychain).to.have.property('osImpl'); - // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call - const program = _keychain['osImpl'].getProgram(); - // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call - const testArrayMeta = _.find(testArray, (elem: any) => program.includes(elem.validateString)); - expect(testArrayMeta == null).to.be.false; - }); + const keyChains = await Promise.all(testArray.map((obj) => retrieveKeychain(obj.osName))); + keyChains.map((kc) => { + expect(kc).to.have.property('osImpl'); + // @ts-expect-error osImpl is a private member + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call + const program = kc['osImpl'].getProgram(); + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call + const testArrayMeta = testArray.find((elem) => program.includes(elem.validateString)); + expect(testArrayMeta == null).to.be.false; }); + // return Promise.all(promiseArray).then((_keychains) => { + // _.forEach(_keychains, (_keychain: any) => { + // expect(_keychain).to.have.property('osImpl'); + // // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call + // const program = _keychain['osImpl'].getProgram(); + // // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call + // const testArrayMeta = _.find(testArray, (elem: any) => program.includes(elem.validateString)); + // expect(testArrayMeta == null).to.be.false; + // }); + // }); }); it('should return generic unix for OSX and Linux', async () => { - process.env.SFDX_USE_GENERIC_UNIX_KEYCHAIN = 'true'; + process.env.SF_USE_GENERIC_UNIX_KEYCHAIN = 'true'; const darwinKeychain = await retrieveKeychain('darwin'); const linuxKeychain = await retrieveKeychain('linux'); diff --git a/test/unit/crypto/secureStringTest.ts b/test/unit/crypto/secureStringTest.ts index e7548433ef..9eb6e2752f 100644 --- a/test/unit/crypto/secureStringTest.ts +++ b/test/unit/crypto/secureStringTest.ts @@ -4,7 +4,7 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as crypto from 'crypto'; +import * as crypto from 'node:crypto'; import { expect } from 'chai'; import { stub } from 'sinon'; import { SecureBuffer } from '../../../src/crypto/secureBuffer'; diff --git a/test/unit/deviceOauthServiceTest.ts b/test/unit/deviceOauthServiceTest.ts index bca1766a6c..fc0bd9ce73 100644 --- a/test/unit/deviceOauthServiceTest.ts +++ b/test/unit/deviceOauthServiceTest.ts @@ -12,7 +12,8 @@ import { StubbedType, stubInterface, stubMethod } from '@salesforce/ts-sinon'; import { expect } from 'chai'; import { MockTestOrgData, TestContext } from '../../src/testSetup'; import { DeviceOauthService } from '../../src/deviceOauthService'; -import { AuthFields, AuthInfo, DEFAULT_CONNECTED_APP_INFO, SFDX_HTTP_HEADERS } from '../../src/org'; +import { AuthFields, AuthInfo, DEFAULT_CONNECTED_APP_INFO } from '../../src/org/authInfo'; +import { SFDX_HTTP_HEADERS } from '../../src/org/connection'; const deviceCodeResponse = { device_code: '1234', @@ -32,6 +33,8 @@ const devicePollingResponse = { issued_at: '1234', }; +const htmlResponse = 'Server down for maintenance'; + type UnknownError = { error: string; status: number; @@ -70,18 +73,40 @@ describe('DeviceOauthService', () => { describe('requestDeviceLogin', () => { it('should return the device code response', async () => { stubMethod($$.SANDBOX, Transport.prototype, 'httpRequest').returns( - Promise.resolve({ body: JSON.stringify(deviceCodeResponse) }) + Promise.resolve({ + body: JSON.stringify(deviceCodeResponse), + headers: { 'content-type': 'application/json;charset=UTF-8' }, + }) ); const service = await DeviceOauthService.create({}); const login = await service.requestDeviceLogin(); expect(login).to.deep.equal(deviceCodeResponse); }); + + it('should handle HTML response with proper error', async () => { + stubMethod($$.SANDBOX, Transport.prototype, 'httpRequest').returns( + Promise.resolve({ body: htmlResponse, headers: { 'content-type': 'text/html' } }) + ); + const service = await DeviceOauthService.create({}); + try { + await service.requestDeviceLogin(); + expect(true).to.be.false; + } catch (err) { + expect(err).to.have.property('name', 'HttpApiError'); + expect(err) + .to.have.property('message') + .and.contain('HTTP response contains html content. Check that the org exists and can be reached.'); + } + }); }); describe('awaitDeviceApproval', () => { it('should return the device polling response', async () => { stubMethod($$.SANDBOX, Transport.prototype, 'httpRequest').returns( - Promise.resolve({ body: JSON.stringify(devicePollingResponse) }) + Promise.resolve({ + body: JSON.stringify(devicePollingResponse), + headers: { 'content-type': 'application/json;charset=UTF-8' }, + }) ); const service = await DeviceOauthService.create({}); const approval = await service.awaitDeviceApproval(deviceCodeResponse); @@ -95,10 +120,16 @@ describe('DeviceOauthService', () => { Promise.resolve({ statusCode: 400, body: JSON.stringify({ error: 'authorization_pending' }), + headers: { 'content-type': 'application/json;charset=UTF-8' }, }) ) .onSecondCall() - .returns(Promise.resolve({ body: JSON.stringify(devicePollingResponse) })); + .returns( + Promise.resolve({ + body: JSON.stringify(devicePollingResponse), + headers: { 'content-type': 'application/json;charset=UTF-8' }, + }) + ); const shouldContinuePollingStub = stubMethod($$.SANDBOX, DeviceOauthService.prototype, 'shouldContinuePolling') .onFirstCall() .returns(true) @@ -118,6 +149,7 @@ describe('DeviceOauthService', () => { service.pollingCount = DeviceOauthService.POLLING_COUNT_MAX + 1; try { await service.awaitDeviceApproval(deviceCodeResponse); + expect(true).to.be.false; } catch (err) { expect((err as Error).name).to.equal('PollingTimeoutError'); } @@ -131,6 +163,7 @@ describe('DeviceOauthService', () => { const service = await DeviceOauthService.create({}); try { await service.awaitDeviceApproval(deviceCodeResponse); + expect(true).to.be.false; } catch (err) { // @ts-expect-error: because private member expect(service.pollingCount).to.equal(0); @@ -145,10 +178,12 @@ describe('DeviceOauthService', () => { error: 'Invalid grant type', error_description: 'Invalid grant type', }), + headers: { 'content-type': 'application/json;charset=UTF-8' }, })); const service = await DeviceOauthService.create({}); try { await service.awaitDeviceApproval(deviceCodeResponse); + expect(true).to.be.false; } catch (err) { // @ts-expect-error: because private member expect(service.pollingCount).to.equal(0); diff --git a/test/unit/globalTest.ts b/test/unit/globalTest.ts index cae4620e48..5ccbf88b54 100644 --- a/test/unit/globalTest.ts +++ b/test/unit/globalTest.ts @@ -5,17 +5,28 @@ * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ import { expect } from 'chai'; +import { isString } from '@salesforce/ts-types'; import { Global, Mode } from '../../src/global'; describe('Global', () => { describe('environmentMode', () => { - const sfdxEnv = process.env.SFDX_ENV; + const originalEnv = { SFDX_ENV: process.env.SFDX_ENV, SF_ENV: process.env.SF_ENV }; + const cleanEnv = () => Object.keys(originalEnv).map((key) => delete process.env[key]); + + beforeEach(() => { + cleanEnv(); + }); after(() => { - process.env.SFDX_ENV = sfdxEnv; + cleanEnv(); + Object.entries(originalEnv) + .filter(([, value]) => isString(value)) + .map(([key, value]) => { + process.env[key] = value; + }); }); - it('uses SFDX_ENV mode', () => { + it('uses SFDX_ENV mode alone', () => { process.env.SFDX_ENV = 'development'; expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.true; expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; @@ -23,8 +34,64 @@ describe('Global', () => { expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; }); + it('uses SF_ENV mode alone', () => { + process.env.SF_ENV = 'development'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.true; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; + }); + + it('prefers SF_ENV mode', () => { + process.env.SF_ENV = 'test'; + process.env.SFDX_ENV = 'development'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.true; + }); + + it('finds uppercase', () => { + process.env.SF_ENV = 'TEST'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.true; + }); + + it('finds lowercase', () => { + process.env.SF_ENV = 'demo'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.true; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; + }); + + it('finds mixed case', () => { + process.env.SF_ENV = 'dEvelOpment'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.true; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.false; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; + }); + it('is production by default', () => { - delete process.env.SFDX_ENV; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.true; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; + }); + + it('defaults to production when invalid values are specified (SFDX)', () => { + process.env.SFDX_ENV = 'notARealMode'; + expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; + expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.true; + expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; + expect(Global.getEnvironmentMode() === Mode.TEST).to.be.false; + }); + + it('defaults to production when invalid values are specified (SF)', () => { + process.env.SF_ENV = 'notARealMode'; expect(Global.getEnvironmentMode() === Mode.DEVELOPMENT).to.be.false; expect(Global.getEnvironmentMode() === Mode.PRODUCTION).to.be.true; expect(Global.getEnvironmentMode() === Mode.DEMO).to.be.false; diff --git a/test/unit/helpers.ts b/test/unit/helpers.ts index 9e27d8520e..a7149c0e72 100644 --- a/test/unit/helpers.ts +++ b/test/unit/helpers.ts @@ -28,6 +28,6 @@ export class ErrnoException extends Error implements NodeJS.ErrnoException { super(); options = messageOrOptions; } - Object.assign(this, options || {}); + Object.assign(this, options ?? {}); } } diff --git a/test/unit/lifecycleEventsTest.ts b/test/unit/lifecycleEventsTest.ts index 4a1ca09d6f..d84a4a9121 100644 --- a/test/unit/lifecycleEventsTest.ts +++ b/test/unit/lifecycleEventsTest.ts @@ -26,7 +26,7 @@ describe('lifecycleEvents', () => { const fake = new Foo(); beforeEach(() => { - loggerSpy = spyMethod($$.SANDBOX, Lifecycle.getInstance(), 'debug'); + loggerSpy = spyMethod($$.SANDBOX, $$.TEST_LOGGER, 'debug'); fakeSpy = spyMethod($$.SANDBOX, fake, 'bar'); }); @@ -69,6 +69,45 @@ describe('lifecycleEvents', () => { Lifecycle.getInstance().removeAllListeners('telemetry'); }); + it("uniqueListeners adds listeners only when they don't already exist", async () => { + Lifecycle.getInstance().on( + 'test1', + async (result) => { + // @ts-expect-error: called is a sinon spy property + fake.bar('test1', result); + }, + 'id000' + ); + chai.expect(Lifecycle.getInstance().getListeners('test1').length).to.equal(1); + Lifecycle.getInstance().on( + 'test1', + async (result) => { + // @ts-expect-error: called is a sinon spy property + fake.bar('test1', result); + }, + 'id001' + ); + // both of these should be ignored + chai.expect(Lifecycle.getInstance().getListeners('test1').length).to.equal(2); + Lifecycle.getInstance().on( + 'test1', + async (result) => { + // @ts-expect-error: called is a sinon spy property + fake.bar('test1', result); + }, + 'id000' + ); + chai.expect(Lifecycle.getInstance().getListeners('test1').length).to.equal(2); + Lifecycle.getInstance().on( + 'test1', + async (result) => { + // @ts-expect-error: called is a sinon spy property + fake.bar('test1', result); + }, + 'id001' + ); + Lifecycle.getInstance().removeAllListeners('test1'); + }); it('successful event registration and emitting causes the callback to be called', async () => { Lifecycle.getInstance().on('test1', async (result) => { // @ts-expect-error: called is a sinon spy property @@ -131,13 +170,24 @@ describe('lifecycleEvents', () => { // @ts-expect-error: called is a sinon spy property fake.bar('test5', result); }); + Lifecycle.getInstance().on( + 'test5', + async (result) => { + // @ts-expect-error: called is a sinon spy property + fake.bar('test5', result); + }, + 'id000' + ); await Lifecycle.getInstance().emit('test5', 'Success'); - chai.expect(fakeSpy.callCount).to.be.equal(1); + chai.expect(fakeSpy.callCount).to.be.equal(2); chai.expect(fakeSpy.args[0][1]).to.be.equal('Success'); - + chai.expect(fakeSpy.args[1][1]).to.be.equal('Success'); + loggerSpy.resetHistory(); + fakeSpy.resetHistory(); Lifecycle.getInstance().removeAllListeners('test5'); await Lifecycle.getInstance().emit('test5', 'Failure: Listener Removed'); - chai.expect(fakeSpy.callCount).to.be.equal(1); + chai.expect(fakeSpy.callCount).to.be.equal(0); + chai.expect(loggerSpy.callCount).to.be.equal(1); chai .expect(loggerSpy.args[0][0]) @@ -146,7 +196,7 @@ describe('lifecycleEvents', () => { ); }); - it('getListeners works', async () => { + it('getListeners works, including uniqueListeners', async () => { const x = async (result: Record) => { // eslint-disable-next-line @typescript-eslint/no-unsafe-argument fake.bar('test6', result); @@ -159,6 +209,36 @@ describe('lifecycleEvents', () => { Lifecycle.getInstance().removeAllListeners('test6'); }); + it('getListeners works (unique Listeners)', async () => { + const x = async (result: Record) => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-argument + fake.bar('test6', result); + }; + Lifecycle.getInstance().on('test6', x, 'id000'); + + chai.expect(Lifecycle.getInstance().getListeners('test6')).to.have.lengthOf(1); + chai.expect(Lifecycle.getInstance().getListeners('test6')[0]).to.deep.equal(x); + + chai.expect(Lifecycle.getInstance().getListeners('undefinedKey').length).to.be.equal(0); + Lifecycle.getInstance().removeAllListeners('test6'); + }); + + it('getListeners works (mixed unique and non-unique)', async () => { + const x = async (result: Record) => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-argument + fake.bar('test6', result); + }; + Lifecycle.getInstance().on('test6', x); + Lifecycle.getInstance().on('test6', x, 'id000'); + + chai.expect(Lifecycle.getInstance().getListeners('test6')).to.have.lengthOf(2); + chai.expect(Lifecycle.getInstance().getListeners('test6')[0]).to.deep.equal(x); + chai.expect(Lifecycle.getInstance().getListeners('test6')[1]).to.deep.equal(x); + + chai.expect(Lifecycle.getInstance().getListeners('undefinedKey').length).to.be.equal(0); + Lifecycle.getInstance().removeAllListeners('test6'); + }); + it('will use a newer version and transfer the listeners', () => { // the original const lifecycle = Lifecycle.getInstance(); diff --git a/test/unit/logger/cleanupTest.ts b/test/unit/logger/cleanupTest.ts new file mode 100644 index 0000000000..cce40460e2 --- /dev/null +++ b/test/unit/logger/cleanupTest.ts @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { expect } from 'chai'; +import { getOldLogFiles } from '../../../src/logger/cleanup'; + +describe('cleanup', () => { + describe('not deleted', () => { + it('non log files', () => { + expect(getOldLogFiles(['foo.txt', 'sf-2021-08-10.not-a-log'])).to.deep.equal([]); + }); + it('files from bunyan logger', () => { + const files = ['sf.log', 'sf.log.1', 'sf.log.2']; + expect(getOldLogFiles(files)).to.deep.equal([]); + }); + it('very recent files', () => { + const files = [`sf-${new Date().toISOString().slice(0, 10)}.log`]; + expect(getOldLogFiles(files)).to.deep.equal([]); + }); + it('6 days old files', () => { + const files = [`sf-${new Date(Date.now() - 1000 * 60 * 60 * 24 * 6).toISOString().slice(0, 10)}.log`]; + expect(getOldLogFiles(files)).to.deep.equal([]); + }); + it('100 days old files when maxMS is higher', () => { + const files = [`sf-${new Date(Date.now() - 1000 * 60 * 60 * 24 * 100).toISOString().slice(0, 10)}.log`]; + expect(getOldLogFiles(files, 1000 * 60 * 60 * 24 * 200)).to.deep.equal([]); + }); + }); + describe('deleted', () => { + it('will delete an old daily file', () => { + const files = ['sf-2021-08-10.log']; + expect(getOldLogFiles(files)).to.deep.equal(files); + }); + it('will delete an old hourly file', () => { + const files = ['sf-2021-08-10T18.log']; + expect(getOldLogFiles(files)).to.deep.equal(files); + }); + it('8 day old files', () => { + const files = [`sf-${new Date(Date.now() - 1000 * 60 * 60 * 24 * 8).toISOString().slice(0, 10)}.log`]; + expect(getOldLogFiles(files)).to.deep.equal(files); + }); + it('1 day old files when maxMs = 0', () => { + const files = [`sf-${new Date(Date.now() - 1000 * 60 * 60 * 24 * 1).toISOString().slice(0, 10)}.log`]; + expect(getOldLogFiles(files, 0)).to.deep.equal(files); + }); + }); +}); diff --git a/test/unit/logger/filterTest.ts b/test/unit/logger/filterTest.ts new file mode 100644 index 0000000000..7914dba225 --- /dev/null +++ b/test/unit/logger/filterTest.ts @@ -0,0 +1,107 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ +import { assert, expect, config } from 'chai'; +import { filterSecrets, HIDDEN } from '../../../src/logger/filters'; +import { unwrapArray } from '../../../src/util/unwrapArray'; + +config.truncateThreshold = 0; + +describe('filters', () => { + const sid = '00D55000000M2qA!AQ0AQHg3LnYDOyobmH07'; + const simpleString = `sid=${sid}`; + const stringWithObject = ` The rain in Spain: ${JSON.stringify({ + // eslint-disable-next-line camelcase + access_token: sid, + })}`; + const obj1 = { accessToken: `${sid}`, refreshToken: `${sid}` }; + const obj2 = { key: 'Access Token', value: `${sid}` }; + const arr1 = [ + { key: 'ACCESS token ', value: `${sid}` }, + { key: 'refresh TOKEN', value: `${sid}` }, + { key: 'Sfdx Auth Url', value: `${sid}` }, + ]; + const arr2 = [ + { key: ' AcCESS 78token', value: ` ${sid} ` }, + { key: ' refresh _TOKEn ', value: ` ${sid} ` }, + { key: ' SfdX__AuthUrl ', value: ` ${sid} ` }, + ]; + + it(`filters ${simpleString} correctly`, () => { + const result = getUnwrapped(simpleString); + expect(result).to.not.contain(sid); + expect(result).to.contain('REDACTED ACCESS TOKEN'); + }); + + it(`filters ${stringWithObject} correctly`, () => { + const result = getUnwrapped(stringWithObject); + expect(result).to.not.contain(sid); + expect(result).to.contain('REDACTED ACCESS TOKEN'); + }); + + it('filters obj1 correctly', () => { + const result = getUnwrapped(obj1); + assert(result); + const bigString = JSON.stringify(result); + expect(bigString).to.not.contain(sid); + expect(bigString).to.contain('REDACTED ACCESS TOKEN'); + expect(bigString).to.contain('refresh_token - HIDDEN'); + }); + + it('filters obj2 correctly', () => { + const result = getUnwrapped(obj2); + assert(result); + const bigString = JSON.stringify(result); + expect(bigString).to.not.contain(sid); + expect(bigString).to.contain('REDACTED ACCESS TOKEN'); + }); + + it('filters arr1 correctly', () => { + const result = getUnwrapped(arr1); + assert(result); + assert(Array.isArray(result)); + const bigString = JSON.stringify(result); + + expect(bigString).to.not.contain(sid); + expect(bigString).to.contain('REDACTED ACCESS TOKEN'); + expect(bigString).to.contain('refresh_token - HIDDEN'); + }); + + it('filters arr2 correctly', () => { + const result = getUnwrapped(arr2); + assert(result); + assert(Array.isArray(result)); + const bigString = JSON.stringify(result); + expect(bigString).to.not.contain(sid); + expect(bigString).to.contain(HIDDEN); + expect(bigString).to.contain('refresh_token - HIDDEN'); + }); + + describe('does not filter innocent stuff', () => { + it('basic string', () => { + const result = getUnwrapped('some string'); + expect(result).to.equal('some string'); + }); + it('basic object', () => { + const input = { foo: 'bar' }; + const result = getUnwrapped(input); + expect(result).to.deep.equal(input); + }); + it('basic array', () => { + const input = ['foo', 'bar']; + const result = getUnwrapped(input); + expect(result).to.deep.equal(input); + }); + it('object with one bad prop', () => { + const input = { foo: 'bar', accessToken: `${sid}` }; + const result = getUnwrapped(input); + expect(result).to.have.property('foo', 'bar'); + expect(result).to.have.property('accessToken').contains('REDACTED ACCESS TOKEN'); + }); + }); +}); + +const getUnwrapped = (input: unknown): unknown => unwrapArray(filterSecrets(input)); diff --git a/test/unit/loggerTest.ts b/test/unit/loggerTest.ts index aa5b5afc8d..cfac7013cd 100644 --- a/test/unit/loggerTest.ts +++ b/test/unit/loggerTest.ts @@ -8,25 +8,31 @@ /* eslint-disable @typescript-eslint/no-unsafe-call */ /* eslint-disable @typescript-eslint/no-unsafe-return */ -import * as fs from 'fs'; -import { isBoolean, isNumber, isString } from '@salesforce/ts-types'; -import { expect } from 'chai'; -import * as debug from 'debug'; -import * as _ from 'lodash'; -import { Logger, LoggerFormat, LoggerLevel, LoggerStream } from '../../src/logger'; +import { expect, config as chaiConfig } from 'chai'; +import { isString } from '@salesforce/ts-types'; +import { Logger, LoggerLevel, computeLevel } from '../../src/logger/logger'; import { shouldThrowSync, TestContext } from '../../src/testSetup'; // NOTE: These tests still use 'await' which is how it use to work and were left to make // sure we didn't regress the way they were used. +chaiConfig.truncateThreshold = 0; describe('Logger', () => { const $$ = new TestContext(); - const sfdxEnv = process.env.SFDX_ENV; - const logRotationPeriodBackup = process.env.SF_LOG_ROTATION_PERIOD; - const logRotationCountBackup = process.env.SF_LOG_ROTATION_COUNT; - - beforeEach(async () => { + const originalEnv = { + SFDX_ENV: process.env.SFDX_ENV, + SF_ENV: process.env.SF_ENV, + SF_LOG_LEVEL: process.env.SF_LOG_LEVEL, + SF_DISABLE_LOG_FILE: process.env.SF_DISABLE_LOG_FILE, + SF_LOG_ROTATION_PERIOD: process.env.SF_LOG_ROTATION_PERIOD, + SF_LOG_ROTATION_COUNT: process.env.SF_LOG_ROTATION_COUNT, + }; + + const cleanEnv = () => Object.keys(originalEnv).map((key) => delete process.env[key]); + beforeEach(() => { + cleanEnv(); process.env.SFDX_ENV = 'test'; + process.env.SF_ENV = 'test'; // Must restore the globally stubbed Logger.child method here. Stubbed in testSetup. // @ts-expect-error: called is a sinon spy property @@ -35,24 +41,86 @@ describe('Logger', () => { afterEach(() => { Logger.destroyRoot(); - if (sfdxEnv) process.env.SFDX_ENV = sfdxEnv; - if (logRotationPeriodBackup) process.env.SF_LOG_ROTATION_PERIOD = logRotationPeriodBackup; - if (logRotationCountBackup) process.env.SF_LOG_ROTATION_COUNT = logRotationCountBackup; + }); + + after(() => { + cleanEnv(); + Object.entries(originalEnv) + .filter(([, value]) => isString(value)) + .map(([key, value]) => { + process.env[key] = value; + }); }); describe('constructor', () => { it('should construct a new named logger', async () => { - const logger1 = new Logger('testLogger'); + const logger1 = new Logger({ name: 'testLogger', useMemoryLogger: true }); expect(logger1).to.be.instanceof(Logger); expect(logger1.getName()).to.equal('testLogger'); const logger2 = await Logger.root(); expect(logger2).to.not.equal(logger1); }); + + describe('DISABLE_LOG_FILE', () => { + before(() => { + process.env.SF_DISABLE_LOG_FILE = 'true'; + }); + + it('should construct a new named logger', async () => { + const logger1 = new Logger({ name: 'testLogger-noop' }); + expect(logger1).to.be.instanceof(Logger); + // @ts-expect-error testing a private property + expect(logger1.memoryLogger).to.be.ok; + expect(logger1.getName()).to.equal('testLogger-noop'); + }); + }); }); describe('levels', () => { + describe('level computation', () => { + it('should use a matching a level name when passed in', () => { + expect(computeLevel('error')).to.equal('error'); + }); + it('number passed in matching a level number', () => { + expect(computeLevel(30)).to.equal('info'); + }); + it('number passed in not matching a level number', () => { + expect(computeLevel(28)).to.equal('info'); + expect(computeLevel(1)).to.equal('trace'); + }); + it('should use default level when nothing passed in and no env', () => { + expect(computeLevel()).to.equal('warn'); + }); + it('env var set to a level name', () => { + process.env.SF_LOG_LEVEL = 'warn'; + expect(computeLevel()).to.equal('warn'); + }); + it('env var set to a level number matching a level number', () => { + process.env.SF_LOG_LEVEL = '30'; + expect(computeLevel()).to.equal('info'); + }); + it('env var set to a level number not matching a level number', () => { + process.env.SF_LOG_LEVEL = '28'; + expect(computeLevel()).to.equal('info'); + process.env.SF_LOG_LEVEL = '1'; + expect(computeLevel()).to.equal('trace'); + }); + it('env var set to an invalid level name', () => { + process.env.SF_LOG_LEVEL = 'goat'; + expect(computeLevel()).to.equal('goat'); + }); + it('should use the env var when env var and value passed in', () => { + process.env.SF_LOG_LEVEL = 'debug'; + expect(computeLevel('error')).to.equal('debug'); + }); + it('should use the env var when env var and value passed in', () => { + process.env.SF_LOG_LEVEL = '30'; + expect(computeLevel('error')).to.equal('info'); + }); + }); + it('should set the log level using a number', () => { - const logger = new Logger('testLogger'); + const logger = new Logger({ name: 'testLogger', useMemoryLogger: true }); logger.setLevel(LoggerLevel.ERROR); expect(logger.getLevel()).to.equal(LoggerLevel.ERROR); logger.setLevel(); @@ -60,7 +128,7 @@ describe('Logger', () => { }); it('should set the log level using a string', () => { - const logger = new Logger('testLogger'); + const logger = new Logger({ name: 'testLogger', useMemoryLogger: true }); logger.setLevel(Logger.getLevelByName('ERROR')); expect(logger.getLevel()).to.equal(LoggerLevel.ERROR); logger.setLevel(Logger.getLevelByName('warn')); @@ -85,7 +153,7 @@ describe('Logger', () => { describe('shouldLog', () => { it('returns correct boolean', () => { - const logger = new Logger('test'); + const logger = new Logger({ name: 'test', useMemoryLogger: true }); logger.setLevel(); expect(logger.shouldLog(LoggerLevel.ERROR)).to.be.true; expect(logger.shouldLog(LoggerLevel.WARN)).to.be.true; @@ -94,69 +162,14 @@ describe('Logger', () => { expect(logger.shouldLog(LoggerLevel.INFO)).to.be.true; expect(logger.shouldLog(LoggerLevel.DEBUG)).to.be.true; expect(logger.shouldLog(LoggerLevel.TRACE)).to.be.false; - logger.setLevel(7); - expect(logger.shouldLog(LoggerLevel.TRACE)).to.be.true; - }); - }); - - describe('addLogFileStream', () => { - const testLogFile = 'some/dir/mylogfile.json'; - let utilAccessStub: sinon.SinonStub; - let utilWriteFileStub: sinon.SinonStub; - - beforeEach(() => { - utilAccessStub = $$.SANDBOX.stub(fs.promises, 'access'); - utilWriteFileStub = $$.SANDBOX.stub(fs.promises, 'writeFile'); - }); - - it('should not create a new log file if it exists already', async () => { - utilAccessStub.resolves({}); - const logger = new Logger('test'); - const addStreamStub = $$.SANDBOX.stub(logger, 'addStream'); - await logger.addLogFileStream(testLogFile); - expect(utilAccessStub.firstCall.args[0]).to.equal(testLogFile); - expect(utilWriteFileStub.called).to.be.false; - const addStreamArgs = addStreamStub.firstCall.args[0]; - expect(addStreamArgs).to.have.property('type', 'rotating-file'); - expect(addStreamArgs).to.have.property('path', testLogFile); - expect(addStreamArgs).to.have.property('level', logger.getLevel()); - }); - - it('should allow log rotation count and period overrides', async () => { - process.env.SF_LOG_ROTATION_PERIOD = '1w'; - process.env.SF_LOG_ROTATION_COUNT = '3'; - - utilAccessStub.returns(Promise.resolve({})); - const logger = new Logger('testing-env-vars'); - const addStreamStub = $$.SANDBOX.stub(logger, 'addStream'); - await logger.addLogFileStream(testLogFile); - - const addStreamArgs = addStreamStub.firstCall.args[0]; - expect(addStreamArgs).to.have.property('period', '1w'); - expect(addStreamArgs).to.have.property('count', 3); - }); - - it('should create a new log file and all directories if nonexistent', async () => { - utilAccessStub.throws(); - const logger = new Logger('testLogger'); - const addStreamStub = $$.SANDBOX.stub(logger, 'addStream'); - await logger.addLogFileStream(testLogFile); - expect(utilAccessStub.firstCall.args[0]).to.equal(testLogFile); - expect(utilWriteFileStub.firstCall.args[0]).to.equal(testLogFile); - expect(utilWriteFileStub.firstCall.args[1]).to.equal(''); - expect(utilWriteFileStub.firstCall.args[2]).to.have.property('mode', '600'); - expect(addStreamStub.called).to.be.true; }); }); describe('root', () => { it('should construct the root SF logger', async () => { - $$.SANDBOX.spy(Logger.prototype, 'addFilter'); const defaultLogger = await Logger.root(); expect(defaultLogger).to.be.instanceof(Logger); expect(defaultLogger.getName()).to.equal('sf'); - // @ts-expect-error: called is a sinon spy property - expect(defaultLogger.addFilter['called'], 'new Logger() should have called addFilter()').to.be.true; const logger = await Logger.root(); expect(logger).to.equal(defaultLogger); }); @@ -168,27 +181,12 @@ describe('Logger', () => { }); it('should create the root logger if not already created', async () => { - $$.SANDBOX.stub(Logger.prototype, 'addLogFileStream'); $$.SANDBOX.spy(Logger, 'root'); const rootLogger = await Logger.root(); expect(rootLogger.getName()).to.equal('sf'); expect(await Logger.root()).to.equal(rootLogger); // @ts-expect-error: called is a sinon spy property expect(Logger.root['called']).to.be.true; - // @ts-expect-error: called is a sinon spy property - expect(rootLogger.addLogFileStream['called']).to.be.false; - }); - - it('should log uncaught exception in root logger', async () => { - process.env.SFDX_ENV = 'dev'; - - const rootLogger = await Logger.root(); - $$.SANDBOX.stub(rootLogger, 'fatal'); - - // @ts-expect-error to access private property `lifecycle` for testing uncaughtException - Logger.lifecycle.emit('uncaughtException', 'testException'); - // @ts-expect-error: called is a sinon spy property - expect(rootLogger.fatal['called']).to.be.true; }); }); @@ -197,101 +195,13 @@ describe('Logger', () => { const childLoggerName = 'myChildLogger'; const childLogger = await Logger.child(childLoggerName); expect(childLogger).to.be.instanceof(Logger); - expect(childLogger.getName()).to.equal(childLoggerName); - }); - - it('should not log uncaught exception in child logger', async () => { - process.env.SFDX_ENV = 'dev'; - - const childLoggerName = 'myChildLogger'; - const childLogger = await Logger.child(childLoggerName); - $$.SANDBOX.stub(childLogger, 'fatal'); - - // @ts-expect-error to access private property `lifecycle` for testing uncaughtException - Logger.lifecycle.emit('uncaughtException', 'testException'); - // @ts-expect-error: called is a sinon spy property - expect(childLogger.fatal['called']).to.be.false; - }); - }); - - describe('debugCallback', () => { - it('should log', async () => { - const logger = (await Logger.child('testLogger')).useMemoryLogging(); - logger.setLevel(LoggerLevel.DEBUG); - const FOO = 'foo'; - const BAR = 'bar'; - const spy = $$.SANDBOX.spy(() => [FOO, BAR]); - logger.debugCallback(spy); - expect(spy.callCount).to.be.equal(1); - expect(logger.readLogContentsAsText()).to.include(FOO).and.to.include(BAR); - }); - - it("shouldn't log", async () => { - const logger = (await Logger.child('testLogger')).useMemoryLogging(); - const fooSpy = $$.SANDBOX.spy(() => 'FOO'); - const cbSpy = $$.SANDBOX.spy(() => `${fooSpy()}`); - logger.debugCallback(cbSpy); - expect(fooSpy.callCount).to.be.equal(0); - expect(cbSpy.callCount).to.be.equal(0); - }); - }); - - describe('filters', () => { - const sid = '00D55000000M2qA!AQ0AQHg3LnYDOyobmH07'; - const simpleString = `sid=${sid}`; - const stringWithObject = ` The rain in Spain: ${JSON.stringify({ - // eslint-disable-next-line camelcase - access_token: sid, - })}`; - const obj1 = { accessToken: `${sid}`, refreshToken: `${sid}` }; - const obj2 = { key: 'Access Token', value: `${sid}` }; - const arr1 = [ - { key: 'ACCESS token ', value: `${sid}` }, - { key: 'refresh TOKEN', value: `${sid}` }, - { key: 'Sfdx Auth Url', value: `${sid}` }, - ]; - const arr2 = [ - { key: ' AcCESS 78token', value: ` ${sid} ` }, - { key: ' refresh _TOKEn ', value: ` ${sid} ` }, - { key: ' SfdX__AuthUrl ', value: ` ${sid} ` }, - ]; - const testLogEntries = [simpleString, stringWithObject, obj1, obj2, arr1, arr2]; - - async function runTest(logLevel: [string, number]) { - const logger = (await Logger.child('testLogger')).useMemoryLogging().setLevel(0); - - // Log at the provided log level for each test entry - // @ts-expect-error suppress any type - testLogEntries.forEach((entry) => logger[logLevel[0]](entry)); - - const logData = logger.readLogContentsAsText(); - expect(logData, `Logs should NOT contain '${sid}'`).to.not.contain(sid); - const logRecords = logger.getBufferedRecords(); - expect(logRecords[0], `expected to log at level: ${logLevel[0]}`).to.have.property('level', logLevel[1]); - } - - it('should apply for log level: trace', () => runTest(['trace', 10])); - - it('should apply for log level: debug', () => runTest(['debug', 20])); - - it('should apply for log level: info', () => runTest(['info', 30])); - - it('should apply for log level: warn', () => runTest(['warn', 40])); - - it('should apply for log level: error', () => runTest(['error', 50])); - - it('should apply for log level: fatal', async () => { - // logger.fatal() necessarily writes to stderr so stub it here - $$.SANDBOX.stub(process.stderr, 'write'); - await runTest(['fatal', 60]); - // @ts-expect-error: called is a sinon spy property - expect(process.stderr.write['called']).to.be.true; + expect(childLogger.getName()).to.equal(`${Logger.ROOT_NAME}:${childLoggerName}`); }); }); describe('addField', () => { it('should add a field to the log record', async () => { - const logger = (await Logger.child('testLogger')).useMemoryLogging(); + const logger = await Logger.child('testLogger'); logger.addField('newField1', 'stringVal'); logger.addField('newField2', 9); logger.addField('newField3', true); @@ -305,145 +215,4 @@ describe('Logger', () => { expect(logRecords[0]).to.have.property('newField3', true); }); }); - - describe('serializers', () => { - it('should run properly after filters are applied', async () => { - const logger = (await Logger.child('testSerializersLogger')).useMemoryLogging(); - - // A test serializer - logger.getBunyanLogger().serializers.config = (obj: Record) => - _.reduce( - obj, - (acc, val, key) => { - if (isString(val) || isNumber(val) || isBoolean(val)) { - // @ts-expect-error string cannot index value - acc[key] = val; - } - return acc; - }, - {} - ); - - logger.warn({ config: { foo: { bar: 1 }, sid: 'secret' } }); - const logRecords = logger.getBufferedRecords(); - - // If the serializer was applied it should not log the 'foo' entry - const msgOnError = 'Expected the config serializer to remove the "foo" entry from the log record '; - expect(logRecords[0], msgOnError).to.have.deep.property('config', { - sid: '

Ocean Drive 101
\n 123456789\n Anita\n Anny\n \n \n Honda\n Civic\n 2016\n \n \n'; -const DOLLARSIGN_OBJECT = { - $: 'value', -}; - -describe('jsonXmlTools', () => { - const $$ = new TestContext(); - - let fsWriteFileStub: SinonStub; - beforeEach(() => { - fsWriteFileStub = stubMethod($$.SANDBOX, fs, 'writeFile').callsFake((fsPath, xml) => { - expect(fsPath).to.be.a('string').and.to.have.length.greaterThan(0).and.to.be.equal(XML_PATH); - expect(xml).to.be.a('string').and.to.have.length.greaterThan(0); - return Promise.resolve(); - }); - }); - - afterEach(() => { - $$.SANDBOX.restore(); - }); - - it('writes json as xml', async () => { - const result = await writeJSONasXML({ - path: XML_PATH, - type: 'RecordType', - json: TEST_JSON, - }); - expect(fsWriteFileStub.callCount).to.be.equal(1); - expect(fsWriteFileStub.firstCall.args[1]).to.equal(TEST_XML); - // undefined means write operation succeeded https://nodejs.org/api/fs.html#fs_fspromises_writefile_file_data_options - expect(result).to.be.undefined; - }); - - it('fails to write json as xml but fails', async () => { - fsWriteFileStub.restore(); - fsWriteFileStub = stubMethod($$.SANDBOX, fs, 'writeFile').rejects(); - try { - // create() calls read() which calls schemaValidate() - await shouldThrow( - writeJSONasXML({ - path: XML_PATH, - type: 'RecordType', - json: TEST_JSON, - }) - ); - } catch (e) { - const error = e as Error; - expect(error.name).to.equal('Error'); - expect(error.message).to.equal('Error'); - } - }); -}); - -describe('fixExistingDollarSign', () => { - it('fixes existing dollar sing key in object', () => { - const result = fixExistingDollarSign(DOLLARSIGN_OBJECT); - expect(result).to.deep.equal({ - '@': 'value', - }); - }); -}); diff --git a/test/unit/util/sfdcTest.ts b/test/unit/util/sfdcTest.ts index 3b7d8e5fa7..205049032a 100644 --- a/test/unit/util/sfdcTest.ts +++ b/test/unit/util/sfdcTest.ts @@ -6,9 +6,7 @@ */ import { expect } from 'chai'; import { - findUpperCaseKeys, matchesAccessToken, - sfdc, trimTo15, validateApiVersion, validateEmail, @@ -19,8 +17,8 @@ import { describe('util/sfdc', () => { describe('trimTo15', () => { it('should trim an 18 character id to 15 characters', () => { - const id = sfdc.trimTo15('ABCDEFGHIJKLMNOPQR'); - const trimmed = sfdc.trimTo15(id); + const id = trimTo15('ABCDEFGHIJKLMNOPQR'); + const trimmed = trimTo15(id); expect(trimmed.length).to.eq(15); expect(trimmed.endsWith('O')).to.be.true; }); @@ -42,149 +40,70 @@ describe('util/sfdc', () => { describe('validateApiVersion', () => { it('should return true for "42.0"', () => { - expect(sfdc.validateApiVersion('42.0')).to.be.true; expect(validateApiVersion('42.0')).to.be.true; }); it('should return false for "42"', () => { - expect(sfdc.validateApiVersion('42')).to.be.false; expect(validateApiVersion('42')).to.be.false; }); it('should return false for 42.0', () => { const num = 42.0; - expect(sfdc.validateApiVersion(num as never)).to.be.false; expect(validateApiVersion(num as never)).to.be.false; }); }); describe('validateEmail', () => { it('should return true for "me@my.org"', () => { - expect(sfdc.validateEmail('me@my.org')).to.be.true; expect(validateEmail('me@my.org')).to.be.true; }); it('should return false for "me@my."', () => { - expect(sfdc.validateEmail('me@my.')).to.be.false; expect(validateEmail('me@my.')).to.be.false; }); it('should return false for "@my.com"', () => { - expect(sfdc.validateEmail('@my')).to.be.false; expect(validateEmail('@my')).to.be.false; }); }); describe('validateSalesforceId', () => { it('should return true for "00DB0000003uuuuuuu"', () => { - expect(sfdc.validateSalesforceId('00DB0000003uuuuuuu')).to.be.true; expect(validateSalesforceId('00DB0000003uuuuuuu')).to.be.true; }); it('should return false for "00D"', () => { - expect(sfdc.validateSalesforceId('00D')).to.be.false; expect(validateSalesforceId('00D')).to.be.false; }); it('should return false for "00D***11100000K"', () => { - expect(sfdc.validateSalesforceId('00D***11100000K')).to.be.false; expect(validateSalesforceId('00D***11100000K')).to.be.false; }); }); describe('validatePathDoesNotContainInvalidChars', () => { it('should return true for "/this/is/my/path"', () => { - expect(sfdc.validatePathDoesNotContainInvalidChars('/this/is/my/path')).to.be.true; expect(validatePathDoesNotContainInvalidChars('/this/is/my/path')).to.be.true; }); it('should return false for "this/is/path??"', () => { - expect(sfdc.validatePathDoesNotContainInvalidChars('this/is/path??')).to.be.false; expect(validatePathDoesNotContainInvalidChars('this/is/path??')).to.be.false; }); it('should return false for "[this/is/path]"', () => { - expect(sfdc.validatePathDoesNotContainInvalidChars('[this/is/path]')).to.be.false; expect(validatePathDoesNotContainInvalidChars('[this/is/path]')).to.be.false; }); it('should return false for "/my/path > err.log"', () => { - expect(sfdc.validatePathDoesNotContainInvalidChars('/my/path > err.log')).to.be.false; expect(validatePathDoesNotContainInvalidChars('/my/path > err.log')).to.be.false; }); it('should return true for "c:\\myfile"', () => { - expect(sfdc.validatePathDoesNotContainInvalidChars('c:\\myfile')).to.be.true; expect(validatePathDoesNotContainInvalidChars('c:\\myfile')).to.be.true; }); }); - describe('findUpperCaseKeys', () => { - it('should return the first upper case key', () => { - const testObj = { - lowercase: true, - UpperCase: false, - nested: { camelCase: true }, - }; - expect(sfdc.findUpperCaseKeys(testObj)).to.equal('UpperCase'); - expect(findUpperCaseKeys(testObj)).to.equal('UpperCase'); - }); - - it('should return the first nested upper case key', () => { - const testObj = { - lowercase: true, - uppercase: false, - nested: { NestedUpperCase: true }, - }; - expect(sfdc.findUpperCaseKeys(testObj)).to.equal('NestedUpperCase'); - expect(findUpperCaseKeys(testObj)).to.equal('NestedUpperCase'); - }); - - it('should return undefined when no upper case key is found', () => { - const testObj = { - lowercase: true, - uppercase: false, - nested: { camelCase: true }, - }; - expect(sfdc.findUpperCaseKeys(testObj)).to.be.undefined; - expect(findUpperCaseKeys(testObj)).to.be.undefined; - }); - - it('should return the first nested upper case key unless blocklisted', () => { - const testObj = { - lowercase: true, - uppercase: false, - nested: { NestedUpperCase: true }, - }; - expect(sfdc.findUpperCaseKeys(testObj, ['nested'])).to.equal(undefined); - expect(findUpperCaseKeys(testObj, ['nested'])).to.equal(undefined); - }); - - it('handles keys starting with numbers', () => { - const testObj = { - '1abc': true, - Abc: false, - nested: { '2abc': true }, - }; - expect(sfdc.findUpperCaseKeys(testObj)).to.equal('Abc'); - expect(findUpperCaseKeys(testObj)).to.equal('Abc'); - }); - it('handles keys starting with numbers', () => { - const testObj = { - '1abc': true, - nested: { '2abc': true, Upper: false }, - }; - expect(sfdc.findUpperCaseKeys(testObj)).to.equal('Upper'); - expect(findUpperCaseKeys(testObj)).to.equal('Upper'); - }); - }); - describe('matchesAccessToken', () => { it('should return true for a valid access token', () => { - expect( - sfdc.matchesAccessToken( - '00D0t000000HkBf!AQ8AQAuHh7lXOFdOA202PMQuGflRrtUkVIfSNK1BrWLlJTJuvypx3r8dLONoJdniYKap1nsTlbxRbbGDqT6r2Rze_Ii5no2y' - ) - ).to.equal(true); expect( matchesAccessToken( '00D0t000000HkBf!AQ8AQAuHh7lXOFdOA202PMQuGflRrtUkVIfSNK1BrWLlJTJuvypx3r8dLONoJdniYKap1nsTlbxRbbGDqT6r2Rze_Ii5no2y' @@ -192,7 +111,6 @@ describe('util/sfdc', () => { ).to.equal(true); }); it('should return false for an invalid access token', () => { - expect(sfdc.matchesAccessToken('iamjustaregularusername@example.com')).to.equal(false); expect(matchesAccessToken('iamjustaregularusername@example.com')).to.equal(false); }); }); diff --git a/test/unit/util/sfdcUrlTest.ts b/test/unit/util/sfdcUrlTest.ts index 4cc79c7993..112aefa597 100644 --- a/test/unit/util/sfdcUrlTest.ts +++ b/test/unit/util/sfdcUrlTest.ts @@ -321,28 +321,6 @@ describe('util/sfdcUrl', () => { }); }); - describe('isSandboxUrl', () => { - it('regular sandboxes with -- in domain but not the word "sandbox" ', () => { - const url = new SfdcUrl('https://some--thing.my.salesforce.com'); - expect(url.isSandboxUrl()).to.be.true; - }); - it('false for "normal" myDomains', () => { - const url = new SfdcUrl('https://something.my.salesforce.com'); - expect(url.isSandboxUrl()).to.be.false; - }); - it('.mil sandboxes with trailing slash', () => { - const url = new SfdcUrl('https://domain--sboxname.sandbox.my.salesforce.mil/'); - expect(url.isSandboxUrl()).to.be.true; - }); - it('.mil sandboxes without trailing slash', () => { - const url = new SfdcUrl('https://domain--sboxname.sandbox.my.salesforce.mil'); - expect(url.isSandboxUrl()).to.be.true; - }); - it('cs123', () => { - const url = new SfdcUrl('https://cs123.force.com'); - expect(url.isSandboxUrl()).to.be.true; - }); - }); describe('getLoginAudienceCombos', () => { it('should return 11 combos when login and audience URLs are not test/prod and are different', () => { const combos = getLoginAudienceCombos('https://foo.bar.baz', 'https://foo.bar.bat'); diff --git a/test/unit/util/unwrapArrayTest.ts b/test/unit/util/unwrapArrayTest.ts new file mode 100644 index 0000000000..70fd7e58f7 --- /dev/null +++ b/test/unit/util/unwrapArrayTest.ts @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2023, salesforce.com, inc. + * All rights reserved. + * Licensed under the BSD 3-Clause license. + * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause + */ + +import { expect } from 'chai'; +import { unwrapArray } from '../../../src/util/unwrapArray'; + +describe('unwrapArray', () => { + it('empty array', () => { + expect(unwrapArray([])).to.deep.equal([]); + }); + it('single object in array', () => { + expect(unwrapArray([{ foo: 'bar' }])).to.deep.equal({ foo: 'bar' }); + }); + it('single string in array', () => { + expect(unwrapArray(['foo'])).to.equal('foo'); + }); + it('2 strings in an array', () => { + expect(unwrapArray(['foo', 'bar'])).to.deep.equal(['foo', 'bar']); + }); + it('2 objects in array', () => { + expect(unwrapArray([{ foo: 'bar' }, { bar: 'foo' }])).to.deep.equal([{ foo: 'bar' }, { bar: 'foo' }]); + }); + it('nested array with single object at the botom', () => { + expect(unwrapArray([[{ foo: 'bar' }]])).to.deep.equal({ foo: 'bar' }); + }); + it('nested arrays with two strings at the bottom', () => { + expect(unwrapArray([['foo', 'bar']])).to.deep.equal(['foo', 'bar']); + }); +}); diff --git a/test/unit/util/zipWriterTest.ts b/test/unit/util/zipWriterTest.ts index 50319f24f5..94427b834e 100644 --- a/test/unit/util/zipWriterTest.ts +++ b/test/unit/util/zipWriterTest.ts @@ -4,195 +4,79 @@ * Licensed under the BSD 3-Clause license. * For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause */ -import * as os from 'os'; -import * as fs from 'fs'; -import * as path from 'path'; -import * as stream from 'stream'; +import * as os from 'node:os'; +import * as fs from 'node:fs'; +import * as path from 'node:path'; import { expect } from 'chai'; import * as sinon from 'sinon'; -import * as ZipArchiver from 'archiver'; +import * as JSZip from 'jszip'; import { ZipWriter } from '../../../src/util/zipWriter'; -import { shouldThrow } from '../../../src/testSetup'; - -class WritableFileStream extends fs.WriteStream {} -class ReadableFileStream extends fs.ReadStream {} describe('ZipWriter', () => { - const sandbox: sinon.SinonSandbox = sinon.createSandbox(); - const appendStub = sandbox - .stub() - .callsFake( - ( - source: string | stream.Readable | Buffer, - data?: ZipArchiver.EntryData | ZipArchiver.ZipEntryData | undefined - ) => { - expect(source).to.be.a('string').and.to.have.length.greaterThan(0); - expect(data).to.be.a('object').and.to.have.property('name'); - } - ); - const createMock = { - append: appendStub, - } as unknown as ZipArchiver.Archiver; - - beforeEach(() => { - sandbox.stub(ZipArchiver, 'create').returns(createMock); - }); + const sandbox = sinon.createSandbox(); + const contents = 'my-contents'; + const filePath = path.join('path', 'to', 'my-file.xml'); afterEach(() => { sandbox.restore(); }); - it('addToStore', async () => { - const contents = 'my-contents'; - const filename = 'path/to/my-file.xml'; + it('addToStore() should add posix file path and content', async () => { + const jsZipFileStub = sandbox.stub(JSZip.prototype, 'file'); + const posixFilePath = 'path/to/my-file.xml'; const zipWriter = new ZipWriter(); - await zipWriter.addToStore(contents, filename); - expect(appendStub.callCount).to.equal(1); - expect(appendStub.firstCall.args[0]).to.equal(contents); - expect(appendStub.firstCall.args[1]).to.deep.equal({ - name: filename, - }); - }); -}); - -describe('ZipWriter write to buffer', () => { - const sandbox: sinon.SinonSandbox = sinon.createSandbox(); - beforeEach(() => { - const zip = ZipArchiver.create('json'); - sandbox.stub(ZipArchiver, 'create').returns(zip); - }); - - afterEach(() => { - sandbox.restore(); + await zipWriter.addToStore(contents, filePath); + expect(jsZipFileStub.callCount).to.equal(1); + expect(jsZipFileStub.firstCall.args[0]).to.equal(posixFilePath); + expect(jsZipFileStub.firstCall.args[1]).to.equal(contents); + expect(zipWriter.getDestinationPath()).to.be.undefined; }); - it('addToZip and finalize and write to buffer', async () => { - const contents = 'my-contents'; - const filename = 'path/to/my-file.xml'; + it('finalize() should generate a zipBuffer with expected compression level', async () => { + const buf = Buffer.from('hi'); + const jsZipGenerateAsyncStub = sandbox.stub(JSZip.prototype, 'generateAsync').resolves(buf); const zipWriter = new ZipWriter(); - await zipWriter.addToStore(contents, filename); await zipWriter.finalize(); - // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call - const result = JSON.parse(zipWriter.buffer.toString()).pop(); - expect(result) - .to.be.a('object') - .and.to.have.keys([ - 'name', - 'type', - 'date', - 'mode', - 'prefix', - 'sourcePath', - 'stats', - 'sourceType', - 'crc32', - 'size', - ]); - // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access - expect(result.name).to.be.equal(filename); - }); -}); - -describe('ZipWriter write to file and throws', () => { - const sandbox: sinon.SinonSandbox = sinon.createSandbox(); - const rootDestination = path.join(os.tmpdir(), 'my-zip.zip'); - const bufferString = 'DEADBEEF'; - // const rootDestination = path.join('/Users', 'bmaggi', 'tmp', 'my-zip.zip'); - let writeStreamStub: sinon.SinonStubbedInstance; - let readStreamStub: sinon.SinonStubbedInstance; - let createWriteStreamStub: sinon.SinonStub; - let createReadStreamStub: sinon.SinonStub; - beforeEach(() => { - writeStreamStub = sinon.createStubInstance(WritableFileStream); - readStreamStub = sinon.createStubInstance(ReadableFileStream); - createWriteStreamStub = sandbox.stub(fs, 'createWriteStream').withArgs(rootDestination).returns(writeStreamStub); - createReadStreamStub = sandbox.stub(fs, 'createReadStream').withArgs(rootDestination).returns(readStreamStub); - // @ts-expect-error - fake function signature not quite complete - readStreamStub.on.callsFake((event: string, listener: (...args: any[]) => void): ReadableFileStream => { - if (event === 'data') { - setImmediate(() => listener(Buffer.from(bufferString, 'utf8'))); - } - return readStreamStub; + expect(zipWriter.buffer).to.equal(buf); + expect(jsZipGenerateAsyncStub.firstCall.args[0]).to.deep.equal({ + type: 'nodebuffer', + compression: 'DEFLATE', + compressionOptions: { level: 3 }, }); - // @ts-expect-error - fake function signature not quite complete - readStreamStub.once.callsFake((event: string, listener: (...args: any[]) => void): ReadableFileStream => { - if (event === 'end') { - setImmediate(() => listener()); - } - return readStreamStub; - }); - const createMock = { - append: sinon.spy(), - finalize: sinon.stub().resolves(), - } as unknown as ZipArchiver.Archiver; - sandbox.stub(ZipArchiver, 'create').returns(createMock); - }); - - afterEach(() => { - sandbox.restore(); }); - it('addToZip and finalize and write to buffer', async () => { - const contents = 'my-contents'; - const filename = 'my-file.xml'; - const zipWriter = new ZipWriter(rootDestination); - await zipWriter.addToStore(contents, filename); - await zipWriter.finalize(); - expect(createWriteStreamStub.firstCall.firstArg).to.equal(rootDestination); - expect(createReadStreamStub.firstCall.firstArg).to.equal(rootDestination); + it('should throw when buffer() is called before finalize()', async () => { + try { + new ZipWriter().buffer; + expect(false, 'Expected an error to be thrown'); + } catch (e) { + expect(e).to.be.instanceOf(Error); + expect((e as Error).message).to.equal('Must finalize the ZipWriter before getting a buffer'); + } }); -}); -describe('ZipWriter write to file', () => { - const sandbox: sinon.SinonSandbox = sinon.createSandbox(); - const rootDestination = path.join(os.tmpdir(), 'my-zip.zip'); - const bufferString = 'DEADBEEF'; - let writeStreamStub: sinon.SinonStubbedInstance; - let readStreamStub: sinon.SinonStubbedInstance; - let createWriteStreamStub: sinon.SinonStub; - let createReadStreamStub: sinon.SinonStub; - beforeEach(() => { - writeStreamStub = sinon.createStubInstance(WritableFileStream); - readStreamStub = sinon.createStubInstance(ReadableFileStream); - createWriteStreamStub = sandbox.stub(fs, 'createWriteStream').withArgs(rootDestination).returns(writeStreamStub); - createReadStreamStub = sandbox.stub(fs, 'createReadStream').withArgs(rootDestination).returns(readStreamStub); - // @ts-expect-error - fake function signature not quite complete - readStreamStub.on.callsFake((event: string, listener: (...args: any[]) => void): ReadableFileStream => { - if (event === 'data') { - setImmediate(() => listener(Buffer.from(bufferString, 'utf8'))); - } - return readStreamStub; - }); - // @ts-expect-error - fake function signature not quite complete - readStreamStub.once.callsFake((event: string, listener: (...args: any[]) => void): ReadableFileStream => { - if (event === 'error') { - setImmediate(() => listener(new Error('FileReadError'))); - } - return readStreamStub; - }); - const createMock = { - append: sinon.spy(), - finalize: sinon.stub().resolves(), - } as unknown as ZipArchiver.Archiver; - sandbox.stub(ZipArchiver, 'create').returns(createMock); - }); + // NOTE: This is a "NUT style" test versus a unit test since it does some file system operations + it('should generate a valid zip file', async () => { + const buf = Buffer.from('hi'); + const rootDestination = path.join(os.tmpdir(), 'zipWriterTest'); + if (fs.existsSync(rootDestination)) { + fs.rmSync(rootDestination, { recursive: true, force: true }); + } + const zipFilePath = path.join(rootDestination, 'myZip.zip'); + try { + fs.mkdirSync(rootDestination, { recursive: true }); + const fileToBeZippedPath = path.join(rootDestination, 'foo.txt'); - afterEach(() => { - sandbox.restore(); - }); + const zipWriter = new ZipWriter(rootDestination); + await zipWriter.addToStore(buf, fileToBeZippedPath); + await zipWriter.finalize(); + fs.writeFileSync(zipFilePath, zipWriter.buffer); - it('addToZip and finalize and write to buffer and throws', async () => { - const contents = 'my-contents'; - const filename = 'my-file.xml'; - const zipWriter = new ZipWriter(rootDestination); - // eslint-disable-next-line @typescript-eslint/await-thenable - await zipWriter.addToStore(contents, filename); - try { - await shouldThrow(zipWriter.finalize()); - } catch (error) { - expect(error).to.exist; + expect(zipWriter.getDestinationPath()).to.equal(rootDestination); + expect(fs.existsSync(zipFilePath)).to.be.true; + expect(fs.statSync(zipFilePath).size).to.be.greaterThan(0); + } finally { + fs.rmSync(rootDestination, { recursive: true, force: true }); } - expect(createWriteStreamStub.firstCall.firstArg).to.equal(rootDestination); - expect(createReadStreamStub.firstCall.firstArg).to.equal(rootDestination); }); }); diff --git a/test/unit/webOauthServerTest.ts b/test/unit/webOauthServerTest.ts index a153e466db..720c40942a 100644 --- a/test/unit/webOauthServerTest.ts +++ b/test/unit/webOauthServerTest.ts @@ -6,11 +6,11 @@ */ /* eslint-disable @typescript-eslint/no-unsafe-member-access */ -import * as http from 'http'; +import * as http from 'node:http'; import { expect } from 'chai'; import { assert } from '@salesforce/ts-types'; -import { StubbedType, stubInterface, stubMethod } from '@salesforce/ts-sinon'; +import { StubbedType, spyMethod, stubInterface, stubMethod } from '@salesforce/ts-sinon'; import { Env } from '@salesforce/kit'; import { MockTestOrgData, TestContext } from '../../src/testSetup'; import { SfProjectJson } from '../../src/sfProject'; @@ -19,6 +19,8 @@ import { AuthFields, AuthInfo } from '../../src/org/authInfo'; describe('WebOauthServer', () => { const $$ = new TestContext(); + const authCode = 'abc123456'; + describe('determineOauthPort', () => { it('should return configured oauth port if it exists', async () => { $$.SANDBOX.stub(SfProjectJson.prototype, 'get').withArgs('oauthLocalPort').returns(8080); @@ -43,7 +45,6 @@ describe('WebOauthServer', () => { describe('authorizeAndSave', () => { const testData = new MockTestOrgData(); - const frontDoorUrl = 'https://www.frontdoor.com'; let authFields: AuthFields; let authInfoStub: StubbedType; let serverResponseStub: StubbedType; @@ -54,36 +55,131 @@ describe('WebOauthServer', () => { authFields = await testData.getConfig(); authInfoStub = stubInterface($$.SANDBOX, { getFields: () => authFields, - getOrgFrontDoorUrl: () => frontDoorUrl, }); serverResponseStub = stubInterface($$.SANDBOX, {}); - stubMethod($$.SANDBOX, WebOAuthServer.prototype, 'executeOauthRequest').callsFake(async () => serverResponseStub); authStub = stubMethod($$.SANDBOX, AuthInfo, 'create').callsFake(async () => authInfoStub); - redirectStub = stubMethod($$.SANDBOX, WebServer.prototype, 'doRedirect').callsFake(async () => {}); }); it('should save new AuthInfo', async () => { + redirectStub = stubMethod($$.SANDBOX, WebServer.prototype, 'doRedirect').callsFake(async () => {}); + stubMethod($$.SANDBOX, WebOAuthServer.prototype, 'executeOauthRequest').callsFake(async () => serverResponseStub); const oauthServer = await WebOAuthServer.create({ oauthConfig: {} }); await oauthServer.start(); + // @ts-expect-error because private member + const handleSuccessStub = stubMethod($$.SANDBOX, oauthServer.webServer, 'handleSuccess').resolves(); const authInfo = await oauthServer.authorizeAndSave(); expect(authInfoStub.save.callCount).to.equal(1); expect(authInfo.getFields()).to.deep.equal(authFields); + expect(handleSuccessStub.calledOnce).to.be.true; }); - it('should redirect to front door url', async () => { + it('should redirect and handle /OauthSuccess on success', async () => { const oauthServer = await WebOAuthServer.create({ oauthConfig: {} }); + const validateStateStub = stubMethod($$.SANDBOX, oauthServer, 'validateState').returns(true); await oauthServer.start(); - await oauthServer.authorizeAndSave(); + + // @ts-expect-error because private member + const webServer = oauthServer.webServer; + const reportSuccessSpy = spyMethod($$.SANDBOX, webServer, 'reportSuccess'); + + const origOn = webServer.server.on; + let requestListener: http.RequestListener; + stubMethod($$.SANDBOX, webServer.server, 'on').callsFake((event, callback) => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument + if (event !== 'request') return origOn.call(webServer.server, event, callback); + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + requestListener = callback; + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + callback( + { + method: 'GET', + url: `http://localhost:1717/OauthRedirect?code=${authCode}&state=972475373f51`, + query: { code: authCode }, + }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + + // stub the redirect to ensure proper redirect handling and the web server is closed. + redirectStub = stubMethod($$.SANDBOX, webServer, 'doRedirect').callsFake(async (status, url, response) => { + expect(status).to.equal(303); + expect(url).to.equal('/OauthSuccess'); + expect(response).to.be.ok; + // eslint-disable-next-line @typescript-eslint/await-thenable + await requestListener( + // @ts-expect-error + { method: 'GET', url: `http://localhost:1717${url}` }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + + const authInfo = await oauthServer.authorizeAndSave(); + expect(authInfo.getFields()).to.deep.equal(authFields); expect(redirectStub.callCount).to.equal(1); - expect(redirectStub.args).to.deep.equal([[303, frontDoorUrl, serverResponseStub]]); + expect(validateStateStub.callCount).to.equal(1); + expect(reportSuccessSpy.callCount).to.equal(1); }); - it('should report error', async () => { - const reportErrorStub = stubMethod($$.SANDBOX, WebServer.prototype, 'reportError').callsFake(async () => {}); - authStub.rejects(new Error('BAD ERROR')); + it('should redirect and handle /OauthError on error', async () => { const oauthServer = await WebOAuthServer.create({ oauthConfig: {} }); + const validateStateStub = stubMethod($$.SANDBOX, oauthServer, 'validateState').returns(true); await oauthServer.start(); + + // @ts-expect-error because private member + const webServer = oauthServer.webServer; + const reportErrorSpy = spyMethod($$.SANDBOX, webServer, 'reportError'); + + const authError = new Error('BAD ERROR'); + authStub.rejects(authError); + + const origOn = webServer.server.on; + let requestListener: http.RequestListener; + stubMethod($$.SANDBOX, webServer.server, 'on').callsFake((event, callback) => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument + if (event !== 'request') return origOn.call(webServer.server, event, callback); + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + requestListener = callback; + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + callback( + { + method: 'GET', + url: `http://localhost:1717/OauthRedirect?code=${authCode}&state=972475373f51`, + query: { code: authCode }, + }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + + // stub the redirect to ensure proper redirect handling and the web server is closed. + redirectStub = stubMethod($$.SANDBOX, webServer, 'doRedirect').callsFake(async (status, url, response) => { + expect(status).to.equal(303); + expect(url).to.equal('/OauthError'); + expect(response).to.be.ok; + // eslint-disable-next-line @typescript-eslint/await-thenable + await requestListener( + // @ts-expect-error + { method: 'GET', url: `http://localhost:1717${url}` }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + try { await oauthServer.authorizeAndSave(); assert(false, 'authorizeAndSave should fail'); @@ -91,7 +187,77 @@ describe('WebOauthServer', () => { expect((e as Error).message, 'BAD ERROR'); } expect(authStub.callCount).to.equal(1); - expect(reportErrorStub.args[0][0].message).to.equal('BAD ERROR'); + expect(redirectStub.callCount).to.equal(1); + expect(validateStateStub.callCount).to.equal(1); + expect(reportErrorSpy.callCount).to.equal(1); + expect(reportErrorSpy.args[0][0]).to.equal(authError); + }); + + it('should ignore requests for favicon and continue', async () => { + const oauthServer = await WebOAuthServer.create({ oauthConfig: {} }); + const validateStateStub = stubMethod($$.SANDBOX, oauthServer, 'validateState').returns(true); + await oauthServer.start(); + + // @ts-expect-error because private member + const webServer = oauthServer.webServer; + const reportSuccessSpy = spyMethod($$.SANDBOX, webServer, 'reportSuccess'); + + const origOn = webServer.server.on; + let requestListener: http.RequestListener; + stubMethod($$.SANDBOX, webServer.server, 'on').callsFake((event, callback) => { + // eslint-disable-next-line @typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument + if (event !== 'request') return origOn.call(webServer.server, event, callback); + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + requestListener = callback; + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + callback( + { + method: 'GET', + url: 'http://localhost:1717/favicon.ico', + }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + // eslint-disable-next-line @typescript-eslint/no-unsafe-call + callback( + { + method: 'GET', + url: `http://localhost:1717/OauthRedirect?code=${authCode}&state=972475373f51`, + query: { code: authCode }, + }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + + // stub the redirect to ensure proper redirect handling and the web server is closed. + redirectStub = stubMethod($$.SANDBOX, webServer, 'doRedirect').callsFake(async (status, url, response) => { + expect(status).to.equal(303); + expect(url).to.equal('/OauthSuccess'); + expect(response).to.be.ok; + // eslint-disable-next-line @typescript-eslint/await-thenable + await requestListener( + // @ts-expect-error + { method: 'GET', url: `http://localhost:1717${url}` }, + { + setHeader: () => {}, + writeHead: () => {}, + end: () => {}, + } + ); + }); + + const authInfo = await oauthServer.authorizeAndSave(); + expect(authInfo.getFields()).to.deep.equal(authFields); + expect(redirectStub.callCount).to.equal(1); + expect(validateStateStub.callCount).to.equal(1); + expect(reportSuccessSpy.callCount).to.equal(1); }); }); @@ -104,9 +270,12 @@ describe('WebOauthServer', () => { const endSpy = $$.SANDBOX.spy(); const origOn = webServer.server.on; + let requestListener: http.RequestListener; stubMethod($$.SANDBOX, webServer.server, 'on').callsFake((event, callback) => { // eslint-disable-next-line @typescript-eslint/no-unsafe-return,@typescript-eslint/no-unsafe-argument if (event !== 'request') return origOn.call(webServer.server, event, callback); + // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment + requestListener = callback; // eslint-disable-next-line @typescript-eslint/no-unsafe-call callback( { @@ -115,6 +284,24 @@ describe('WebOauthServer', () => { }, { setHeader: () => {}, + writeHead: () => {}, + end: endSpy, + } + ); + }); + + // stub the redirect to ensure proper redirect handling and the web server is closed. + stubMethod($$.SANDBOX, webServer, 'doRedirect').callsFake(async (status, url, response) => { + expect(status).to.equal(303); + expect(url).to.equal('/OauthError'); + expect(response).to.be.ok; + // eslint-disable-next-line @typescript-eslint/await-thenable + await requestListener( + // @ts-expect-error + { method: 'GET', url: `http://localhost:1717${url}` }, + { + setHeader: () => {}, + writeHead: () => {}, end: endSpy, } ); @@ -130,7 +317,6 @@ describe('WebOauthServer', () => { }); describe('parseAuthCodeFromRequest', () => { - const authCode = 'abc123456'; let serverResponseStub: StubbedType; let serverRequestStub: StubbedType; diff --git a/tsconfig.json b/tsconfig.json index 1f2d165533..98e0fe92ed 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -4,7 +4,7 @@ "outDir": "./lib", "resolveJsonModule": true, "rootDir": "./src", - "plugins": [{ "transform": "./messageTransformer/messageTransformer.ts" }] + "plugins": [{ "transform": "./src/messageTransformer.ts" }] }, "include": ["./src/**/*.ts"] } diff --git a/typedocExamples/orgExamples.ts b/typedocExamples/orgExamples.ts index 2879f5f6ad..1e7f911af2 100644 --- a/typedocExamples/orgExamples.ts +++ b/typedocExamples/orgExamples.ts @@ -1,6 +1,6 @@ import { AuthInfo } from '../src/org/authInfo'; import { Connection } from '../src/org/connection'; -import { Org } from '../src/org'; +import { Org } from '../src/org/org'; // tslint:disable export const orgExamples = { diff --git a/typedocExamples/status/streamingClientExamples.ts b/typedocExamples/status/streamingClientExamples.ts index 72efabc54c..adf18da5f5 100644 --- a/typedocExamples/status/streamingClientExamples.ts +++ b/typedocExamples/status/streamingClientExamples.ts @@ -1,5 +1,5 @@ import { ensureJsonMap, ensureString, JsonCollection, JsonMap } from '@salesforce/ts-types'; -import { Org } from '../../src/org'; +import { Org } from '../../src/org/org'; import { StreamingClient, StatusResult } from '../../src/status/streamingClient'; import { HttpRequest } from 'jsforce'; diff --git a/typedocExamples/userExamples.ts b/typedocExamples/userExamples.ts index dc6545d938..05c6cb2c7e 100644 --- a/typedocExamples/userExamples.ts +++ b/typedocExamples/userExamples.ts @@ -1,5 +1,5 @@ import { DefaultUserFields, User, UserFields } from '../src/org/user'; -import { Org } from '../src/org'; +import { Org } from '../src/org/org'; import { Connection } from '../src/org/connection'; import { AuthInfo } from '../src/org/authInfo'; diff --git a/yarn.lock b/yarn.lock index cc1e300498..6b4f43df57 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,6 +2,11 @@ # yarn lockfile v1 +"@aashutoshrathi/word-wrap@^1.2.3": + version "1.2.6" + resolved "https://registry.yarnpkg.com/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz#bd9154aec9983f77b3a034ecaa015c2e4201f6cf" + integrity sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA== + "@ampproject/remapping@^2.1.0": version "2.2.0" resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.2.0.tgz#56c133824780de3174aed5ab6834f3026790154d" @@ -117,10 +122,10 @@ dependencies: "@babel/types" "^7.18.6" -"@babel/helper-validator-identifier@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz#9c97e30d31b2b8c72a1d08984f2ca9b574d7a076" - integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== +"@babel/helper-validator-identifier@^7.18.6", "@babel/helper-validator-identifier@^7.22.20": + version "7.22.20" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz#c4ae002c61d2879e724581d96665583dbc1dc0e0" + integrity sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A== "@babel/helper-validator-option@^7.18.6": version "7.18.6" @@ -151,19 +156,19 @@ integrity sha512-RSKRfYX20dyH+elbJK2uqAkVyucL+xXzhqlMD5/ZXx+dAAwpyB7HsvnHe/ZUGOF+xLr5Wx9/JoXVTj6BQE2/oA== "@babel/runtime-corejs3@^7.12.5": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.19.1.tgz#f0cbbe7edda7c4109cd253bb1dee99aba4594ad9" - integrity sha512-j2vJGnkopRzH+ykJ8h68wrHnEUmtK//E723jjixiAl/PPf6FhqY/vYRcMVlNydRKQjQsTsYEjpx+DZMIvnGk/g== + version "7.23.2" + resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.23.2.tgz#a5cd9d8b408fb946b2f074b21ea40c04e516795c" + integrity sha512-54cIh74Z1rp4oIjsHjqN+WM4fMyCBYe+LpZ9jWm51CZ1fbH3SkAzQD/3XLoNkjbJ7YEmjobLXyvQrFypRHOrXw== dependencies: - core-js-pure "^3.25.1" - regenerator-runtime "^0.13.4" + core-js-pure "^3.30.2" + regenerator-runtime "^0.14.0" "@babel/runtime@^7.12.5": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.19.0.tgz#22b11c037b094d27a8a2504ea4dcff00f50e2259" - integrity sha512-eR8Lo9hnDS7tqkO7NsV+mKvCmv5boaXFSZ70DnfhcgiEne8hv9oCEd36Klw74EtizEqLsy4YnW8UWwpBVolHZA== + version "7.23.2" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.23.2.tgz#062b0ac103261d68a966c4c7baf2ae3e62ec3885" + integrity sha512-mM8eg4yl5D6i3lu2QKPuPH4FArvJ8KhTofbE7jwMUv9KX5mBvwPAqnV3MlyBNqdp9RyRKP6Yck8TrfYrPvX3bg== dependencies: - regenerator-runtime "^0.13.4" + regenerator-runtime "^0.14.0" "@babel/template@^7.18.6": version "7.18.6" @@ -366,44 +371,35 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" -"@es-joy/jsdoccomment@0.9.0-alpha.1": - version "0.9.0-alpha.1" - resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.9.0-alpha.1.tgz#f48bd162e185ec7f9f222273a282d10e52fe52f7" - integrity sha512-Clxxc0PwpISoYYBibA+1L2qFJ7gvFVhI2Hos87S06K+Q0cXdOhZQJNKWuaQGPAeHjZEuUB/YoWOfwjuF2wirqA== - dependencies: - comment-parser "1.1.6-beta.0" - esquery "^1.4.0" - jsdoc-type-pratt-parser "1.0.4" - -"@es-joy/jsdoccomment@~0.36.1": - version "0.36.1" - resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.36.1.tgz#c37db40da36e4b848da5fd427a74bae3b004a30f" - integrity sha512-922xqFsTpHs6D0BUiG4toiyPOMc8/jafnWKxz1KWgS4XzKPy2qXf1Pe6UFuNSCQqt6tOuhAWXBNuuyUhJmw9Vg== +"@es-joy/jsdoccomment@~0.41.0": + version "0.41.0" + resolved "https://registry.yarnpkg.com/@es-joy/jsdoccomment/-/jsdoccomment-0.41.0.tgz#4a2f7db42209c0425c71a1476ef1bdb6dcd836f6" + integrity sha512-aKUhyn1QI5Ksbqcr3fFJj16p99QdjUxXAEuFst1Z47DRyoiMwivIH9MV/ARcJOCXVjPfjITciej8ZD2O/6qUmw== dependencies: - comment-parser "1.3.1" - esquery "^1.4.0" - jsdoc-type-pratt-parser "~3.1.0" + comment-parser "1.4.1" + esquery "^1.5.0" + jsdoc-type-pratt-parser "~4.0.0" -"@eslint-community/eslint-utils@^4.2.0": - version "4.3.0" - resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.3.0.tgz#a556790523a351b4e47e9d385f47265eaaf9780a" - integrity sha512-v3oplH6FYCULtFuCeqyuTd9D2WKO937Dxdq+GmHOLL72TTRriLxz2VLlNfkZRsvj6PKnOPAtuT6dwrs/pA5DvA== +"@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== dependencies: eslint-visitor-keys "^3.3.0" -"@eslint-community/regexpp@^4.4.0": - version "4.4.0" - resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.4.0.tgz#3e61c564fcd6b921cb789838631c5ee44df09403" - integrity sha512-A9983Q0LnDGdLPjxyXQ00sbV+K+O+ko2Dr+CZigbHWtX9pNfxlaBkMR8X1CztI73zuEyEBXTVjx7CE+/VSwDiQ== +"@eslint-community/regexpp@^4.5.1", "@eslint-community/regexpp@^4.6.1": + version "4.10.0" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63" + integrity sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA== -"@eslint/eslintrc@^2.0.2": - version "2.0.2" - resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.0.2.tgz#01575e38707add677cf73ca1589abba8da899a02" - integrity sha512-3W4f5tDUra+pA+FzgugqL2pRimUTDJWKr7BINqOpkZrC0uYI0NIc0/JFgBROCU07HR6GieA5m3/rsPIhDmCXTQ== +"@eslint/eslintrc@^2.1.3": + version "2.1.3" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.1.3.tgz#797470a75fe0fbd5a53350ee715e85e87baff22d" + integrity sha512-yZzuIG+jnVu6hNSzFEN07e8BxF3uAzYtQb6uDkaYZLo6oYZDCq454c5kB8zxnzfCYyP4MIuyBn10L0DqwujTmA== dependencies: ajv "^6.12.4" debug "^4.3.2" - espree "^9.5.1" + espree "^9.6.0" globals "^13.19.0" ignore "^5.2.0" import-fresh "^3.2.1" @@ -411,17 +407,17 @@ minimatch "^3.1.2" strip-json-comments "^3.1.1" -"@eslint/js@8.37.0": - version "8.37.0" - resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.37.0.tgz#cf1b5fa24217fe007f6487a26d765274925efa7d" - integrity sha512-x5vzdtOOGgFVDCUs81QRB2+liax8rFg3+7hqM+QhBG0/G3F1ZsoYl97UrqgHgQ9KKT7G6c4V+aTUCgu/n22v1A== +"@eslint/js@8.54.0": + version "8.54.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.54.0.tgz#4fab9a2ff7860082c304f750e94acd644cf984cf" + integrity sha512-ut5V+D+fOoWPgGGNj83GGjnntO39xDy6DWxO0wb7Jp3DcMX0TfIqdzHF85VTQkerdyGmuuMD9AKAo5KiNlf/AQ== -"@humanwhocodes/config-array@^0.11.8": - version "0.11.8" - resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.8.tgz#03595ac2075a4dc0f191cc2131de14fbd7d410b9" - integrity sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g== +"@humanwhocodes/config-array@^0.11.13": + version "0.11.13" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.13.tgz#075dc9684f40a531d9b26b0822153c1e832ee297" + integrity sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ== dependencies: - "@humanwhocodes/object-schema" "^1.2.1" + "@humanwhocodes/object-schema" "^2.0.1" debug "^4.1.1" minimatch "^3.0.5" @@ -430,10 +426,10 @@ resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== -"@humanwhocodes/object-schema@^1.2.1": - version "1.2.1" - resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" - integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== +"@humanwhocodes/object-schema@^2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz#e5211452df060fa8522b55c7b3c0c4d1981cb044" + integrity sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw== "@istanbuljs/load-nyc-config@^1.0.0": version "1.1.0" @@ -520,215 +516,75 @@ "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" -"@oclif/command@^1.8.14", "@oclif/command@^1.8.15": - version "1.8.16" - resolved "https://registry.yarnpkg.com/@oclif/command/-/command-1.8.16.tgz#bea46f81b2061b47e1cda318a0b923e62ca4cc0c" - integrity sha512-rmVKYEsKzurfRU0xJz+iHelbi1LGlihIWZ7Qvmb/CBz1EkhL7nOkW4SVXmG2dA5Ce0si2gr88i6q4eBOMRNJ1w== - dependencies: - "@oclif/config" "^1.18.2" - "@oclif/errors" "^1.3.5" - "@oclif/help" "^1.0.1" - "@oclif/parser" "^3.8.6" - debug "^4.1.1" - semver "^7.3.2" - -"@oclif/config@1.18.2": - version "1.18.2" - resolved "https://registry.yarnpkg.com/@oclif/config/-/config-1.18.2.tgz#5bfe74a9ba6a8ca3dceb314a81bd9ce2e15ebbfe" - integrity sha512-cE3qfHWv8hGRCP31j7fIS7BfCflm/BNZ2HNqHexH+fDrdF2f1D5S8VmXWLC77ffv3oDvWyvE9AZeR0RfmHCCaA== - dependencies: - "@oclif/errors" "^1.3.3" - "@oclif/parser" "^3.8.0" - debug "^4.1.1" - globby "^11.0.1" - is-wsl "^2.1.1" - tslib "^2.0.0" - -"@oclif/config@^1.18.2": - version "1.18.3" - resolved "https://registry.yarnpkg.com/@oclif/config/-/config-1.18.3.tgz#ddfc144fdab66b1658c2f1b3478fa7fbfd317e79" - integrity sha512-sBpko86IrTscc39EvHUhL+c++81BVTsIZ3ETu/vG+cCdi0N6vb2DoahR67A9FI2CGnxRRHjnTfa3m6LulwNATA== - dependencies: - "@oclif/errors" "^1.3.5" - "@oclif/parser" "^3.8.0" - debug "^4.1.1" - globby "^11.0.1" - is-wsl "^2.1.1" - tslib "^2.3.1" - -"@oclif/dev-cli@^1": - version "1.26.10" - resolved "https://registry.yarnpkg.com/@oclif/dev-cli/-/dev-cli-1.26.10.tgz#d8df3a79009b68552f5e7f249d1d19ca52278382" - integrity sha512-dJ+II9rVXckzFvG+82PbfphMTnoqiHvsuAAbcHrLdZWPBnFAiDKhNYE0iHnA/knAC4VGXhogsrAJ3ERT5d5r2g== - dependencies: - "@oclif/command" "^1.8.15" - "@oclif/config" "^1.18.2" - "@oclif/errors" "^1.3.5" - "@oclif/plugin-help" "3.2.18" - cli-ux "5.6.7" - debug "^4.1.1" - find-yarn-workspace-root "^2.0.0" - fs-extra "^8.1" - github-slugger "^1.2.1" - lodash "^4.17.11" - normalize-package-data "^3.0.0" - qqjs "^0.3.10" - tslib "^2.0.3" - -"@oclif/errors@1.3.5", "@oclif/errors@^1.3.3", "@oclif/errors@^1.3.5": - version "1.3.5" - resolved "https://registry.yarnpkg.com/@oclif/errors/-/errors-1.3.5.tgz#a1e9694dbeccab10fe2fe15acb7113991bed636c" - integrity sha512-OivucXPH/eLLlOT7FkCMoZXiaVYf8I/w1eTAM1+gKzfhALwWTusxEx7wBmW0uzvkSg/9ovWLycPaBgJbM3LOCQ== - dependencies: - clean-stack "^3.0.0" - fs-extra "^8.1" - indent-string "^4.0.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" - -"@oclif/help@^1.0.0", "@oclif/help@^1.0.1": - version "1.0.1" - resolved "https://registry.yarnpkg.com/@oclif/help/-/help-1.0.1.tgz#fd96a3dd9fb2314479e6c8584c91b63754a7dff5" - integrity sha512-8rsl4RHL5+vBUAKBL6PFI3mj58hjPCp2VYyXD4TAa7IMStikFfOH2gtWmqLzIlxAED2EpD0dfYwo9JJxYsH7Aw== - dependencies: - "@oclif/config" "1.18.2" - "@oclif/errors" "1.3.5" - chalk "^4.1.2" - indent-string "^4.0.0" - lodash "^4.17.21" - string-width "^4.2.0" - strip-ansi "^6.0.0" - widest-line "^3.1.0" - wrap-ansi "^6.2.0" - -"@oclif/linewrap@^1.0.0": - version "1.0.0" - resolved "https://registry.yarnpkg.com/@oclif/linewrap/-/linewrap-1.0.0.tgz#aedcb64b479d4db7be24196384897b5000901d91" - integrity sha512-Ups2dShK52xXa8w6iBWLgcjPJWjais6KPJQq3gQ/88AY6BXoTX+MIGFPrWQO1KLMiQfoTpcLnUwloN4brrVUHw== - -"@oclif/parser@^3.8.0", "@oclif/parser@^3.8.6": - version "3.8.7" - resolved "https://registry.yarnpkg.com/@oclif/parser/-/parser-3.8.7.tgz#236d48db05d0b00157d3b42d31f9dac7550d2a7c" - integrity sha512-b11xBmIUK+LuuwVGJpFs4LwQN2xj2cBWj2c4z1FtiXGrJ85h9xV6q+k136Hw0tGg1jQoRXuvuBnqQ7es7vO9/Q== - dependencies: - "@oclif/errors" "^1.3.5" - "@oclif/linewrap" "^1.0.0" - chalk "^4.1.0" - tslib "^2.3.1" - -"@oclif/plugin-help@3.2.18": - version "3.2.18" - resolved "https://registry.yarnpkg.com/@oclif/plugin-help/-/plugin-help-3.2.18.tgz#f2bf6ba86719c174fc0e4c2149f73b46006bfdbd" - integrity sha512-5n5Pkz4L0duknIvFwx2Ko9Xda3miT6RZP8bgaaK3Q/9fzVBrhi4bOM0u05/OThI6V+3NsSdxYS2o1NLcXToWDg== - dependencies: - "@oclif/command" "^1.8.14" - "@oclif/config" "1.18.2" - "@oclif/errors" "1.3.5" - "@oclif/help" "^1.0.0" - chalk "^4.1.2" - indent-string "^4.0.0" - lodash "^4.17.21" - string-width "^4.2.0" - strip-ansi "^6.0.0" - widest-line "^3.1.0" - wrap-ansi "^6.2.0" - -"@oclif/screen@^1.0.4": - version "1.0.4" - resolved "https://registry.yarnpkg.com/@oclif/screen/-/screen-1.0.4.tgz#b740f68609dfae8aa71c3a6cab15d816407ba493" - integrity sha512-60CHpq+eqnTxLZQ4PGHYNwUX572hgpMHGPtTWMjdTMsAvlm69lZV/4ly6O3sAYkomo4NggGcomrDpBe34rxUqw== - -"@salesforce/bunyan@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@salesforce/bunyan/-/bunyan-2.0.0.tgz#8dbe377f2cf7d35348a23260416fee15adba5f97" - integrity sha512-5hq+HWQSeymuygl3i9ehlQo3XWrlBE+A+QzmpDaoK37op4u9M+SBUbXfOW0IABOQCg+JmfQPocSMV74hRoqU9w== - dependencies: - dayjs "^1.8.16" - dayjs-plugin-utc "^0.1.2" - optionalDependencies: - dtrace-provider "~0.6" - mv "~2" - safe-json-stringify "~1" - -"@salesforce/dev-config@^3.0.0", "@salesforce/dev-config@^3.0.1": - version "3.1.0" - resolved "https://registry.yarnpkg.com/@salesforce/dev-config/-/dev-config-3.1.0.tgz#8eb5b35860ff60d1c1dc3fd9329b01a28475d5b9" - integrity sha512-cPph7ibj3DeSzWDFLcLtxOh5fmUlDUY2Ezq43n0V6auVP+l8orxRHjCExHS86SB3QKVgXkC8yYhryXiS8KF7Zw== +"@salesforce/dev-config@^4.1.0": + version "4.1.0" + resolved "https://registry.yarnpkg.com/@salesforce/dev-config/-/dev-config-4.1.0.tgz#e529576466d074e7a5f1441236510fef123da01e" + integrity sha512-2iDDepiIwjXHS5IVY7pwv8jMo4xWosJ7p/UTj+lllpB/gnJiYLhjJPE4Z3FCGFKyvfg5jGaimCd8Ca6bLGsCQA== -"@salesforce/dev-scripts@^4.0.0-beta.7": - version "4.0.0-beta.7" - resolved "https://registry.yarnpkg.com/@salesforce/dev-scripts/-/dev-scripts-4.0.0-beta.7.tgz#b704b8a4618694b14492fe95009028f6f7be933e" - integrity sha512-8P62xeXQz40xym/9+dT/F0KQIRJCGGS6n0VcXBSmupO3hInGXZA7mdM/W7BQHbDr59xk5TmB3PscmGew8Buj6g== +"@salesforce/dev-scripts@^7.1.1": + version "7.1.1" + resolved "https://registry.yarnpkg.com/@salesforce/dev-scripts/-/dev-scripts-7.1.1.tgz#549b58fb7e8c2410ce594c46f780a0907618f19f" + integrity sha512-6SL+QDOMZCnmU4Lu2ZCjqsMRcHw96mnjUOPE7b2HcfmfPo2a/hAYUtv8v7UsZ/+3UPbSf+XsLJfUsF15QIUWrg== dependencies: "@commitlint/cli" "^17.1.2" "@commitlint/config-conventional" "^17.1.0" - "@oclif/dev-cli" "^1" - "@salesforce/dev-config" "^3.0.0" - "@salesforce/prettier-config" "^0.0.2" - "@types/chai" "^4.2.11" - "@types/mocha" "^9.0.0" - "@types/node" "^15.6.1" - "@types/sinon" "10.0.11" - chai "^4.2.0" + "@salesforce/dev-config" "^4.1.0" + "@salesforce/prettier-config" "^0.0.3" + "@types/chai" "^4.3.10" + "@types/mocha" "^10.0.4" + "@types/node" "^18" + "@types/sinon" "^10.0.20" + chai "^4.3.10" chalk "^4.0.0" cosmiconfig "^7.0.0" - eslint "^8.32.0" - eslint-config-prettier "^8.5.0" - eslint-config-salesforce "^1.1.0" - eslint-config-salesforce-license "^0.1.6" - eslint-config-salesforce-typescript "^1.1.1" - eslint-plugin-header "^3.0.0" - eslint-plugin-import "2.26.0" - eslint-plugin-jsdoc "^35.1.2" - eslint-plugin-prefer-arrow "^1.2.1" + eslint-config-salesforce-typescript "^3.0.5" husky "^7.0.4" - mocha "^9.1.3" + mocha "^10.2.0" nyc "^15.1.0" - prettier "^2.7.1" - pretty-quick "^3.1.0" - shelljs "~0.8.4" + prettier "^2.8.8" + pretty-quick "^3.1.3" + shelljs "^0.8.5" sinon "10.0.0" - source-map-support "~0.5.19" - ts-node "^10.0.0" - typedoc "0.23.16" + source-map-support "^0.5.21" + ts-node "^10.9.1" + typedoc "^0.25.3" typedoc-plugin-missing-exports "0.23.0" - typescript "^4.1.3" - wireit "^0.9.3" + typescript "^4.9.5" + wireit "^0.14.1" -"@salesforce/kit@^1.9.2": - version "1.9.2" - resolved "https://registry.yarnpkg.com/@salesforce/kit/-/kit-1.9.2.tgz#d232f135428363cdfe2649cb99a94bc2eb0a12fd" - integrity sha512-kjZvjFNP6njhAiEa/ErdLXSDWZKafHYJyKCKz1wnSFmDM8TOpKHCCVw5cQo87ZQr8OqxqwUDIAlSBLyMzKi4Lg== +"@salesforce/kit@^3.0.15": + version "3.0.15" + resolved "https://registry.yarnpkg.com/@salesforce/kit/-/kit-3.0.15.tgz#713df3f5767f874c70a2e731c7cb5ba677989559" + integrity sha512-XkA8jsuLvVnyP460dAbU3pBFP2IkmmmsVxMQVifcKKbNWaIBbZBzAfj+vdaQfnvZyflLhsrFT3q2xkb0vHouPg== dependencies: - "@salesforce/ts-types" "^1.7.3" - shx "^0.3.3" - tslib "^2.5.0" + "@salesforce/ts-types" "^2.0.9" + tslib "^2.6.2" -"@salesforce/prettier-config@^0.0.2": - version "0.0.2" - resolved "https://registry.yarnpkg.com/@salesforce/prettier-config/-/prettier-config-0.0.2.tgz#ded39bf7cb75238edc9db6dd093649111350f8bc" - integrity sha512-KExM355BLbxCW6siGBV7oUOotXvvVp0tAWERgzUkM2FcMb9fWrjwXDrIHc8V0UdDlA3UXtFltDWgN+Yqi+BA/g== +"@salesforce/prettier-config@^0.0.3": + version "0.0.3" + resolved "https://registry.yarnpkg.com/@salesforce/prettier-config/-/prettier-config-0.0.3.tgz#ba648d4886bb38adabe073dbea0b3a91b3753bb0" + integrity sha512-hYOhoPTCSYMDYn+U1rlEk16PoBeAJPkrdg4/UtAzupM1mRRJOwEPMG1d7U8DxJFKuXW3DMEYWr2MwAIBDaHmFg== -"@salesforce/schemas@^1.5.1": - version "1.5.1" - resolved "https://registry.yarnpkg.com/@salesforce/schemas/-/schemas-1.5.1.tgz#2d1bfdcf593caaa04cd4b3e6fe621097ff7f28fe" - integrity sha512-MRqU+tn8w5IFvZ0Lm9YKLgxYxr2MQMI+fXXsTrwfUnijsps+ybF9IOTu6MOMxxl2vCUkO8XDjA435wXlWSLI6g== +"@salesforce/schemas@^1.6.1": + version "1.6.1" + resolved "https://registry.yarnpkg.com/@salesforce/schemas/-/schemas-1.6.1.tgz#7d1c071e1e509ca9d2d8a6e48ac7447dd67a534d" + integrity sha512-eVy947ZMxCJReKJdgfddUIsBIbPTa/i8RwQGwxq4/ss38H5sLOAeSTaun9V7HpJ1hkpDznWKfgzYvjsst9K6ig== -"@salesforce/ts-sinon@^1.4.6": - version "1.4.6" - resolved "https://registry.yarnpkg.com/@salesforce/ts-sinon/-/ts-sinon-1.4.6.tgz#50ac8f091ae546bcc5b1a2b0937f566e3f9683c6" - integrity sha512-yWed+QzGU3UOSX9ytg09ELWA7Oc5BAK4MVYv8Ap9uUbkg6tylETF7nzuMkvP49TaZcKC7zOG6MBebKNVZqUjPw== +"@salesforce/ts-sinon@^1.4.19": + version "1.4.19" + resolved "https://registry.yarnpkg.com/@salesforce/ts-sinon/-/ts-sinon-1.4.19.tgz#64157b6c8cf4a3c637867e2ddd90c2d058c334f7" + integrity sha512-vopxKrI6QD0OCtPlge1eGGHFWLkoDee7KaB/dpGeRwioeNfCVJ8ikELN0hv0zq9Ys6gUYWYcdpxzTP1upslCJA== dependencies: - "@salesforce/ts-types" "^1.7.3" + "@salesforce/ts-types" "^2.0.9" sinon "^5.1.1" - tslib "^2.5.0" + tslib "^2.6.1" -"@salesforce/ts-types@^1.7.2", "@salesforce/ts-types@^1.7.3": - version "1.7.3" - resolved "https://registry.yarnpkg.com/@salesforce/ts-types/-/ts-types-1.7.3.tgz#89b79ff0aaa55fea9f2de0afa8e515be3e17d0d8" - integrity sha512-jpmekGqZ7tpHRJwf1rF0yBJ/IMC5mOrryNi4HZkKuNQn8RF97WpynmL8Om04mLTCESvCiif3y7NWfIcxtID2Gw== +"@salesforce/ts-types@^2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@salesforce/ts-types/-/ts-types-2.0.9.tgz#66bff7b41720065d6b01631b6f6a3ccca02857c5" + integrity sha512-boUD9jw5vQpTCPCCmK/NFTWjSuuW+lsaxOynkyNXLW+zxOc4GDjhtKc4j0vWZJQvolpafbyS8ZLFHZJvs12gYA== dependencies: - tslib "^2.5.0" + tslib "^2.6.2" "@sinonjs/commons@^1", "@sinonjs/commons@^1.3.0", "@sinonjs/commons@^1.6.0", "@sinonjs/commons@^1.7.0", "@sinonjs/commons@^1.8.1": version "1.8.3" @@ -737,13 +593,6 @@ dependencies: type-detect "4.0.8" -"@sinonjs/commons@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-2.0.0.tgz#fd4ca5b063554307e8327b4564bd56d3b73924a3" - integrity sha512-uLa0j859mMrg2slwQYdO/AkrOfmH+X6LTVmNTS9CqexuE2IvVORIkSpJLqePAbEnKJ77aMmCwr1NUZ57120Xcg== - dependencies: - type-detect "4.0.8" - "@sinonjs/fake-timers@^6.0.0", "@sinonjs/fake-timers@^6.0.1": version "6.0.1" resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-6.0.1.tgz#293674fccb3262ac782c7aadfdeca86b10c75c40" @@ -751,20 +600,6 @@ dependencies: "@sinonjs/commons" "^1.7.0" -"@sinonjs/fake-timers@^7.0.4": - version "7.1.2" - resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-7.1.2.tgz#2524eae70c4910edccf99b2f4e6efc5894aff7b5" - integrity sha512-iQADsW4LBMISqZ6Ci1dupJL9pprqwcVFTcOsEmQOEhW+KLCVn/Y4Jrvg2k19fIHCp+iFprriYPTdRcQR8NbUPg== - dependencies: - "@sinonjs/commons" "^1.7.0" - -"@sinonjs/fake-timers@^9.1.2": - version "9.1.2" - resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-9.1.2.tgz#4eaab737fab77332ab132d396a3c0d364bd0ea8c" - integrity sha512-BPS4ynJW/o92PUR4wgriz2Ud5gpST5vz6GQfMixEDK0Z8ZCUv2M7SkBLykH56T++Xs+8ln9zTGbOvNGIe02/jw== - dependencies: - "@sinonjs/commons" "^1.7.0" - "@sinonjs/formatio@^2.0.0": version "2.0.0" resolved "https://registry.yarnpkg.com/@sinonjs/formatio/-/formatio-2.0.0.tgz#84db7e9eb5531df18a8c5e0bfb6e449e55e654b2" @@ -798,15 +633,6 @@ lodash.get "^4.4.2" type-detect "^4.0.8" -"@sinonjs/samsam@^7.0.1": - version "7.0.1" - resolved "https://registry.yarnpkg.com/@sinonjs/samsam/-/samsam-7.0.1.tgz#5b5fa31c554636f78308439d220986b9523fc51f" - integrity sha512-zsAk2Jkiq89mhZovB2LLOdTCxJF4hqqTToGP0ASWlhp4I1hqOjcfmZGafXntCN7MDC6yySH0mFHrYtHceOeLmw== - dependencies: - "@sinonjs/commons" "^2.0.0" - lodash.get "^4.4.2" - type-detect "^4.0.8" - "@sinonjs/text-encoding@^0.7.1": version "0.7.1" resolved "https://registry.yarnpkg.com/@sinonjs/text-encoding/-/text-encoding-0.7.1.tgz#8da5c6530915653f3a1f38fd5f101d8c3f8079c5" @@ -832,73 +658,41 @@ resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.3.tgz#472eaab5f15c1ffdd7f8628bd4c4f753995ec79e" integrity sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ== -"@types/archiver@^5.3.2": - version "5.3.2" - resolved "https://registry.yarnpkg.com/@types/archiver/-/archiver-5.3.2.tgz#a9f0bcb0f0b991400e7766d35f6e19d163bdadcc" - integrity sha512-IctHreBuWE5dvBDz/0WeKtyVKVRs4h75IblxOACL92wU66v+HGAfEYAOyXkOFphvRJMhuXdI9huDXpX0FC6lCw== - dependencies: - "@types/readdir-glob" "*" +"@types/benchmark@^2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@types/benchmark/-/benchmark-2.1.5.tgz#940c1850c18fdfdaee3fd6ed29cd92ae0d445b45" + integrity sha512-cKio2eFB3v7qmKcvIHLUMw/dIx/8bhWPuzpzRT4unCPRTD8VdA9Zb0afxpcxOqR4PixRS7yT42FqGS8BYL8g1w== -"@types/chai-string@^1.4.2": - version "1.4.2" - resolved "https://registry.yarnpkg.com/@types/chai-string/-/chai-string-1.4.2.tgz#0f116504a666b6c6a3c42becf86634316c9a19ac" - integrity sha512-ld/1hV5qcPRGuwlPdvRfvM3Ka/iofOk2pH4VkasK4b1JJP1LjNmWWn0LsISf6RRzyhVOvs93rb9tM09e+UuF8Q== +"@types/chai-string@^1.4.5": + version "1.4.5" + resolved "https://registry.yarnpkg.com/@types/chai-string/-/chai-string-1.4.5.tgz#988ff37526386e9c354219b163d7ecf81bab8d2d" + integrity sha512-IecXRMSnpUvRnTztdpSdjcmcW7EdNme65bfDCQMi7XrSEPGmyDYYTEfc5fcactWDA6ioSm8o7NUqg9QxjBCCEw== dependencies: "@types/chai" "*" -"@types/chai@*", "@types/chai@^4.2.11": - version "4.3.1" - resolved "https://registry.yarnpkg.com/@types/chai/-/chai-4.3.1.tgz#e2c6e73e0bdeb2521d00756d099218e9f5d90a04" - integrity sha512-/zPMqDkzSZ8t3VtxOa4KPq7uzzW978M9Tvh+j7GHKuo6k6GTLxPJ4J5gE5cjfJ26pnXst0N5Hax8Sr0T2Mi9zQ== - -"@types/debug@0.0.31": - version "0.0.31" - resolved "https://registry.yarnpkg.com/@types/debug/-/debug-0.0.31.tgz#bac8d8aab6a823e91deb7f79083b2a35fa638f33" - integrity sha512-LS1MCPaQKqspg7FvexuhmDbWUhE2yIJ+4AgVIyObfc06/UKZ8REgxGNjZc82wPLWmbeOm7S+gSsLgo75TanG4A== - -"@types/glob@*", "@types/glob@^7.1.1": - version "7.2.0" - resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.2.0.tgz#bc1b5bf3aa92f25bd5dd39f35c57361bdce5b2eb" - integrity sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA== - dependencies: - "@types/minimatch" "*" - "@types/node" "*" - -"@types/graceful-fs@^4.1.6": - version "4.1.6" - resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.6.tgz#e14b2576a1c25026b7f02ede1de3b84c3a1efeae" - integrity sha512-Sig0SNORX9fdW+bQuTEovKj3uHcUL6LQKbCrrqb1X7J6/ReAbhCXRAhc+SMejhLELFj2QcyuxmUooZ4bt5ReSw== - dependencies: - "@types/node" "*" - -"@types/jsen@0.0.21": - version "0.0.21" - resolved "https://registry.yarnpkg.com/@types/jsen/-/jsen-0.0.21.tgz#5241c11d22342743387ca7dde721e88efe7d0a27" - integrity sha512-NVmkiChwbwiWWiaNCkjMViu0g4+cOJYp1OTatqSd8BjUP8a1Yp6z1ZIu7P0o1qSlM95e541PwKQGbf8+dVi2Wg== +"@types/chai@*", "@types/chai@^4.3.10": + version "4.3.10" + resolved "https://registry.yarnpkg.com/@types/chai/-/chai-4.3.10.tgz#2ad2959d1767edee5b0e4efb1a0cd2b500747317" + integrity sha512-of+ICnbqjmFCiixUnqRulbylyXQrPqIGf/B3Jax1wIF3DvSheysQxAWvqHhZiW3IQrycvokcLcFQlveGp+vyNg== -"@types/json-schema@^7.0.9": - version "7.0.11" - resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" - integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== +"@types/json-schema@^7.0.12": + version "7.0.15" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.15.tgz#596a1747233694d50f6ad8a7869fcb6f56cf5841" + integrity sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA== "@types/json5@^0.0.29": version "0.0.29" resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ== -"@types/jsonwebtoken@9.0.1": - version "9.0.1" - resolved "https://registry.yarnpkg.com/@types/jsonwebtoken/-/jsonwebtoken-9.0.1.tgz#29b1369c4774200d6d6f63135bf3d1ba3ef997a4" - integrity sha512-c5ltxazpWabia/4UzhIoaDcIza4KViOQhdbjRlfcIGVnsE3c3brkz9Z+F/EeJIECOQP7W7US2hNE930cWWkPiw== +"@types/jsonwebtoken@9.0.5": + version "9.0.5" + resolved "https://registry.yarnpkg.com/@types/jsonwebtoken/-/jsonwebtoken-9.0.5.tgz#0bd9b841c9e6c5a937c17656e2368f65da025588" + integrity sha512-VRLSGzik+Unrup6BsouBeHsf4d1hOEgYWTm/7Nmw1sXoN1+tRly/Gy/po3yeahnP4jfnQWWAhQAqcNfH7ngOkA== dependencies: "@types/node" "*" -"@types/lodash@^4.14.192": - version "4.14.192" - resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.192.tgz#5790406361a2852d332d41635d927f1600811285" - integrity sha512-km+Vyn3BYm5ytMO13k9KTp27O75rbQ0NFw+U//g+PX7VZyjCioXaRFisqSIJRECljcTv73G3i6BpglNGHgUQ5A== - -"@types/minimatch@*", "@types/minimatch@^3.0.3": +"@types/minimatch@^3.0.3": version "3.0.5" resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-3.0.5.tgz#1001cc5e6a3704b83c236027e77f2f58ea010f40" integrity sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ== @@ -908,26 +702,23 @@ resolved "https://registry.yarnpkg.com/@types/minimist/-/minimist-1.2.2.tgz#ee771e2ba4b3dc5b372935d549fd9617bf345b8c" integrity sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ== -"@types/mocha@^9.0.0": - version "9.1.1" - resolved "https://registry.yarnpkg.com/@types/mocha/-/mocha-9.1.1.tgz#e7c4f1001eefa4b8afbd1eee27a237fee3bf29c4" - integrity sha512-Z61JK7DKDtdKTWwLeElSEBcWGRLY8g95ic5FoQqI9CMx0ns/Ghep3B4DfcEimiKMvtamNVULVNKEsiwV3aQmXw== +"@types/mocha@^10.0.4": + version "10.0.4" + resolved "https://registry.yarnpkg.com/@types/mocha/-/mocha-10.0.4.tgz#b5331955ebca216604691fd4fcd2dbdc2bd559a4" + integrity sha512-xKU7bUjiFTIttpWaIZ9qvgg+22O1nmbA+HRxdlR+u6TWsGfmFdXrheJoK4fFxrHNVIOBDvDNKZG+LYBpMHpX3w== -"@types/node@*": - version "18.0.3" - resolved "https://registry.yarnpkg.com/@types/node/-/node-18.0.3.tgz#463fc47f13ec0688a33aec75d078a0541a447199" - integrity sha512-HzNRZtp4eepNitP+BD6k2L6DROIDG4Q0fm4x+dwfsr6LGmROENnok75VGw40628xf+iR24WeMFcHuuBDUAzzsQ== +"@types/node@*", "@types/node@^18": + version "18.18.9" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.18.9.tgz#5527ea1832db3bba8eb8023ce8497b7d3f299592" + integrity sha512-0f5klcuImLnG4Qreu9hPj/rEfFq6YRc5n2mAjSsH+ec/mJL+3voBH0+8T7o8RpFjH7ovc+TRsL/c7OYIQsPTfQ== + dependencies: + undici-types "~5.26.4" "@types/node@^12.19.9": version "12.20.55" resolved "https://registry.yarnpkg.com/@types/node/-/node-12.20.55.tgz#c329cbd434c42164f846b909bd6f85b5537f6240" integrity sha512-J8xLz7q2OFulZ2cyGTLE1TbbZcjpno7FaN6zdJNrgAdrJ+DZzh/uFR6YrTb4C+nXakvud8Q4+rbhoIWlYQbUFQ== -"@types/node@^15.6.1": - version "15.14.9" - resolved "https://registry.yarnpkg.com/@types/node/-/node-15.14.9.tgz#bc43c990c3c9be7281868bbc7b8fdd6e2b57adfa" - integrity sha512-qjd88DrCxupx/kJD5yQgZdcYKZKSIGBVDIBE1/LTGcNm3d2Np/jxojkdePDdfnBHJc5W7vSMpbJ1aB7p/Py69A== - "@types/normalize-package-data@^2.4.0": version "2.4.1" resolved "https://registry.yarnpkg.com/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz#d3357479a0fdfdd5907fe67e17e0a85c906e1301" @@ -938,30 +729,27 @@ resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== -"@types/readdir-glob@*": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@types/readdir-glob/-/readdir-glob-1.1.1.tgz#27ac2db283e6aa3d110b14ff9da44fcd1a5c38b1" - integrity sha512-ImM6TmoF8bgOwvehGviEj3tRdRBbQujr1N+0ypaln/GWjaerOB26jb93vsRHmdMtvVQZQebOlqt2HROark87mQ== +"@types/proper-lockfile@^4.1.4": + version "4.1.4" + resolved "https://registry.yarnpkg.com/@types/proper-lockfile/-/proper-lockfile-4.1.4.tgz#cd9fab92bdb04730c1ada542c356f03620f84008" + integrity sha512-uo2ABllncSqg9F1D4nugVl9v93RmjxF6LJzQLMLDdPaXCUIDPeOJ21Gbqi43xNKzBi/WQ0Q0dICqufzQbMjipQ== dependencies: - "@types/node" "*" + "@types/retry" "*" -"@types/semver@^7.3.12", "@types/semver@^7.3.13": - version "7.3.13" - resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.3.13.tgz#da4bfd73f49bd541d28920ab0e2bf0ee80f71c91" - integrity sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw== +"@types/retry@*": + version "0.12.2" + resolved "https://registry.yarnpkg.com/@types/retry/-/retry-0.12.2.tgz#ed279a64fa438bb69f2480eda44937912bb7480a" + integrity sha512-XISRgDJ2Tc5q4TRqvgJtzsRkFYNJzZrhTdtMoGVBttwzzQJkPnS3WWTFc7kuDRoPtPakl+T+OfdEUjYJj7Jbow== -"@types/shelljs@0.8.11": - version "0.8.11" - resolved "https://registry.yarnpkg.com/@types/shelljs/-/shelljs-0.8.11.tgz#17a5696c825974e96828e96e89585d685646fcb8" - integrity sha512-x9yaMvEh5BEaZKeVQC4vp3l+QoFj3BXcd4aYfuKSzIIyihjdVARAadYy3SMNIz0WCCdS2vB9JL/U6GQk5PaxQw== - dependencies: - "@types/glob" "*" - "@types/node" "*" +"@types/semver@^7.5.0", "@types/semver@^7.5.6": + version "7.5.6" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.6.tgz#c65b2bfce1bec346582c07724e3f8c1017a20339" + integrity sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A== -"@types/sinon@10.0.11": - version "10.0.11" - resolved "https://registry.yarnpkg.com/@types/sinon/-/sinon-10.0.11.tgz#8245827b05d3fc57a6601bd35aee1f7ad330fc42" - integrity sha512-dmZsHlBsKUtBpHriNjlK0ndlvEh8dcb9uV9Afsbt89QIyydpC7NcR+nWlAhASfy3GHnxTl4FX/aKE7XZUt/B4g== +"@types/sinon@^10.0.20": + version "10.0.20" + resolved "https://registry.yarnpkg.com/@types/sinon/-/sinon-10.0.20.tgz#f1585debf4c0d99f9938f4111e5479fb74865146" + integrity sha512-2APKKruFNCAZgx3daAyACGzWuJ028VVCUDk6o2rw/Z4PXT0ogwdV4KUegW0MwVs0Zu59auPXbbuBJHF12Sx1Eg== dependencies: "@types/sinonjs__fake-timers" "*" @@ -970,94 +758,95 @@ resolved "https://registry.yarnpkg.com/@types/sinonjs__fake-timers/-/sinonjs__fake-timers-8.1.2.tgz#bf2e02a3dbd4aecaf95942ecd99b7402e03fad5e" integrity sha512-9GcLXF0/v3t80caGs5p2rRfkB+a8VBGLJZVih6CNFkx8IZ994wiKKLSRs9nuFwk1HevWs/1mnUmkApGrSGsShA== -"@typescript-eslint/eslint-plugin@^5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.57.0.tgz#52c8a7a4512f10e7249ca1e2e61f81c62c34365c" - integrity sha512-itag0qpN6q2UMM6Xgk6xoHa0D0/P+M17THnr4SVgqn9Rgam5k/He33MA7/D7QoJcdMxHFyX7U9imaBonAX/6qA== +"@typescript-eslint/eslint-plugin@^6.10.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.12.0.tgz#2a647d278bb48bf397fef07ba0507612ff9dd812" + integrity sha512-XOpZ3IyJUIV1b15M7HVOpgQxPPF7lGXgsfcEIu3yDxFPaf/xZKt7s9QO/pbk7vpWQyVulpJbu4E5LwpZiQo4kA== dependencies: - "@eslint-community/regexpp" "^4.4.0" - "@typescript-eslint/scope-manager" "5.57.0" - "@typescript-eslint/type-utils" "5.57.0" - "@typescript-eslint/utils" "5.57.0" + "@eslint-community/regexpp" "^4.5.1" + "@typescript-eslint/scope-manager" "6.12.0" + "@typescript-eslint/type-utils" "6.12.0" + "@typescript-eslint/utils" "6.12.0" + "@typescript-eslint/visitor-keys" "6.12.0" debug "^4.3.4" - grapheme-splitter "^1.0.4" - ignore "^5.2.0" - natural-compare-lite "^1.4.0" - semver "^7.3.7" - tsutils "^3.21.0" - -"@typescript-eslint/parser@^5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.57.0.tgz#f675bf2cd1a838949fd0de5683834417b757e4fa" - integrity sha512-orrduvpWYkgLCyAdNtR1QIWovcNZlEm6yL8nwH/eTxWLd8gsP+25pdLHYzL2QdkqrieaDwLpytHqycncv0woUQ== - dependencies: - "@typescript-eslint/scope-manager" "5.57.0" - "@typescript-eslint/types" "5.57.0" - "@typescript-eslint/typescript-estree" "5.57.0" + graphemer "^1.4.0" + ignore "^5.2.4" + natural-compare "^1.4.0" + semver "^7.5.4" + ts-api-utils "^1.0.1" + +"@typescript-eslint/parser@^6.10.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-6.12.0.tgz#9fb21ed7d88065a4a2ee21eb80b8578debb8217c" + integrity sha512-s8/jNFPKPNRmXEnNXfuo1gemBdVmpQsK1pcu+QIvuNJuhFzGrpD7WjOcvDc/+uEdfzSYpNu7U/+MmbScjoQ6vg== + dependencies: + "@typescript-eslint/scope-manager" "6.12.0" + "@typescript-eslint/types" "6.12.0" + "@typescript-eslint/typescript-estree" "6.12.0" + "@typescript-eslint/visitor-keys" "6.12.0" debug "^4.3.4" -"@typescript-eslint/scope-manager@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.57.0.tgz#79ccd3fa7bde0758059172d44239e871e087ea36" - integrity sha512-NANBNOQvllPlizl9LatX8+MHi7bx7WGIWYjPHDmQe5Si/0YEYfxSljJpoTyTWFTgRy3X8gLYSE4xQ2U+aCozSw== +"@typescript-eslint/scope-manager@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-6.12.0.tgz#5833a16dbe19cfbad639d4d33bcca5e755c7044b" + integrity sha512-5gUvjg+XdSj8pcetdL9eXJzQNTl3RD7LgUiYTl8Aabdi8hFkaGSYnaS6BLc0BGNaDH+tVzVwmKtWvu0jLgWVbw== dependencies: - "@typescript-eslint/types" "5.57.0" - "@typescript-eslint/visitor-keys" "5.57.0" + "@typescript-eslint/types" "6.12.0" + "@typescript-eslint/visitor-keys" "6.12.0" -"@typescript-eslint/type-utils@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.57.0.tgz#98e7531c4e927855d45bd362de922a619b4319f2" - integrity sha512-kxXoq9zOTbvqzLbdNKy1yFrxLC6GDJFE2Yuo3KqSwTmDOFjUGeWSakgoXT864WcK5/NAJkkONCiKb1ddsqhLXQ== +"@typescript-eslint/type-utils@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-6.12.0.tgz#968f7c95162808d69950ab5dff710ad730e58287" + integrity sha512-WWmRXxhm1X8Wlquj+MhsAG4dU/Blvf1xDgGaYCzfvStP2NwPQh6KBvCDbiOEvaE0filhranjIlK/2fSTVwtBng== dependencies: - "@typescript-eslint/typescript-estree" "5.57.0" - "@typescript-eslint/utils" "5.57.0" + "@typescript-eslint/typescript-estree" "6.12.0" + "@typescript-eslint/utils" "6.12.0" debug "^4.3.4" - tsutils "^3.21.0" + ts-api-utils "^1.0.1" -"@typescript-eslint/types@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.57.0.tgz#727bfa2b64c73a4376264379cf1f447998eaa132" - integrity sha512-mxsod+aZRSyLT+jiqHw1KK6xrANm19/+VFALVFP5qa/aiJnlP38qpyaTd0fEKhWvQk6YeNZ5LGwI1pDpBRBhtQ== +"@typescript-eslint/types@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-6.12.0.tgz#ffc5297bcfe77003c8b7b545b51c2505748314ac" + integrity sha512-MA16p/+WxM5JG/F3RTpRIcuOghWO30//VEOvzubM8zuOOBYXsP+IfjoCXXiIfy2Ta8FRh9+IO9QLlaFQUU+10Q== -"@typescript-eslint/typescript-estree@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.57.0.tgz#ebcd0ee3e1d6230e888d88cddf654252d41e2e40" - integrity sha512-LTzQ23TV82KpO8HPnWuxM2V7ieXW8O142I7hQTxWIHDcCEIjtkat6H96PFkYBQqGFLW/G/eVVOB9Z8rcvdY/Vw== +"@typescript-eslint/typescript-estree@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-6.12.0.tgz#764ccc32598549e5b48ec99e3b85f89b1385310c" + integrity sha512-vw9E2P9+3UUWzhgjyyVczLWxZ3GuQNT7QpnIY3o5OMeLO/c8oHljGc8ZpryBMIyympiAAaKgw9e5Hl9dCWFOYw== dependencies: - "@typescript-eslint/types" "5.57.0" - "@typescript-eslint/visitor-keys" "5.57.0" + "@typescript-eslint/types" "6.12.0" + "@typescript-eslint/visitor-keys" "6.12.0" debug "^4.3.4" globby "^11.1.0" is-glob "^4.0.3" - semver "^7.3.7" - tsutils "^3.21.0" - -"@typescript-eslint/utils@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.57.0.tgz#eab8f6563a2ac31f60f3e7024b91bf75f43ecef6" - integrity sha512-ps/4WohXV7C+LTSgAL5CApxvxbMkl9B9AUZRtnEFonpIxZDIT7wC1xfvuJONMidrkB9scs4zhtRyIwHh4+18kw== - dependencies: - "@eslint-community/eslint-utils" "^4.2.0" - "@types/json-schema" "^7.0.9" - "@types/semver" "^7.3.12" - "@typescript-eslint/scope-manager" "5.57.0" - "@typescript-eslint/types" "5.57.0" - "@typescript-eslint/typescript-estree" "5.57.0" - eslint-scope "^5.1.1" - semver "^7.3.7" - -"@typescript-eslint/visitor-keys@5.57.0": - version "5.57.0" - resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.57.0.tgz#e2b2f4174aff1d15eef887ce3d019ecc2d7a8ac1" - integrity sha512-ery2g3k0hv5BLiKpPuwYt9KBkAp2ugT6VvyShXdLOkax895EC55sP0Tx5L0fZaQueiK3fBLvHVvEl3jFS5ia+g== - dependencies: - "@typescript-eslint/types" "5.57.0" - eslint-visitor-keys "^3.3.0" - -"@ungap/promise-all-settled@1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@ungap/promise-all-settled/-/promise-all-settled-1.1.2.tgz#aa58042711d6e3275dd37dc597e5d31e8c290a44" - integrity sha512-sL/cEvJWAnClXw0wHk85/2L0G6Sj8UB0Ctc1TEMbKSsmpRosqhwj9gWgFRZSrBr2f9tiXISwNhCPmlfqUqyb9Q== + semver "^7.5.4" + ts-api-utils "^1.0.1" + +"@typescript-eslint/utils@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-6.12.0.tgz#c6ce8c06fe9b0212620e5674a2036f6f8f611754" + integrity sha512-LywPm8h3tGEbgfyjYnu3dauZ0U7R60m+miXgKcZS8c7QALO9uWJdvNoP+duKTk2XMWc7/Q3d/QiCuLN9X6SWyQ== + dependencies: + "@eslint-community/eslint-utils" "^4.4.0" + "@types/json-schema" "^7.0.12" + "@types/semver" "^7.5.0" + "@typescript-eslint/scope-manager" "6.12.0" + "@typescript-eslint/types" "6.12.0" + "@typescript-eslint/typescript-estree" "6.12.0" + semver "^7.5.4" + +"@typescript-eslint/visitor-keys@6.12.0": + version "6.12.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-6.12.0.tgz#5877950de42a0f3344261b7a1eee15417306d7e9" + integrity sha512-rg3BizTZHF1k3ipn8gfrzDXXSFKyOEB5zxYXInQ6z0hUvmQlhaZQzK+YmHmNViMA9HzW5Q9+bPPt90bU6GQwyw== + dependencies: + "@typescript-eslint/types" "6.12.0" + eslint-visitor-keys "^3.4.1" + +"@ungap/structured-clone@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@ungap/structured-clone/-/structured-clone-1.2.0.tgz#756641adb587851b5ccb3e095daf27ae581c8406" + integrity sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ== JSONStream@^1.0.4: version "1.3.5" @@ -1084,10 +873,10 @@ acorn-walk@^8.1.1: resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== -acorn@^8.4.1, acorn@^8.8.0: - version "8.8.0" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.0.tgz#88c0187620435c7f6015803f5539dae05a9dbea8" - integrity sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w== +acorn@^8.4.1, acorn@^8.9.0: + version "8.9.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.9.0.tgz#78a16e3b2bcc198c10822786fa6679e245db5b59" + integrity sha512-jaVNAFBHNLXspO543WnNNPZFRtavh3skAkITqD0/2aeMkKZTN+254PyhwxFYrk3vQ1xfY+2wbesJMs/JC8/PwQ== agent-base@6: version "6.0.2" @@ -1104,7 +893,7 @@ aggregate-error@^3.0.0: clean-stack "^2.0.0" indent-string "^4.0.0" -ajv@^6.10.0, ajv@^6.12.4: +ajv@^6.12.4: version "6.12.6" resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== @@ -1129,28 +918,23 @@ ansi-colors@4.1.1: resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== -ansi-escapes@^3.0.0, ansi-escapes@^3.1.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.2.0.tgz#8780b98ff9dbf5638152d1f1fe5c1d7b4442976b" - integrity sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ== - -ansi-escapes@^4.2.1, ansi-escapes@^4.3.0: +ansi-escapes@^4.2.1: version "4.3.2" resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== dependencies: type-fest "^0.21.3" -ansi-regex@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.1.tgz#123d6479e92ad45ad897d4054e3c7ca7db4944e1" - integrity sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw== - ansi-regex@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== +ansi-sequence-parser@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ansi-sequence-parser/-/ansi-sequence-parser-1.1.1.tgz#e0aa1cdcbc8f8bb0b5bca625aac41f5f056973cf" + integrity sha512-vJXt3yiaUL4UU546s3rPXlsry/RnM730G1+HkpKE012AN0sx1eOrxSu95oKDIonskeLTijMgqWZ3uDEe3NFvyg== + ansi-styles@^3.2.1: version "3.2.1" resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" @@ -1158,18 +942,13 @@ ansi-styles@^3.2.1: dependencies: color-convert "^1.9.0" -ansi-styles@^4.0.0, ansi-styles@^4.1.0, ansi-styles@^4.2.0: +ansi-styles@^4.0.0, ansi-styles@^4.1.0: version "4.3.0" resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== dependencies: color-convert "^2.0.1" -ansicolors@~0.3.2: - version "0.3.2" - resolved "https://registry.yarnpkg.com/ansicolors/-/ansicolors-0.3.2.tgz#665597de86a9ffe3aa9bfbe6cae5c6ea426b4979" - integrity sha512-QXu7BPrP29VllRxH8GwB7x5iX5qWKAAMLqKQGWTeLWVlNHNOpVMJ91dsxQAIWXpjuW5wqvxu3Jd/nRjrJ+0pqg== - anymatch@~3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" @@ -1185,40 +964,16 @@ append-transform@^2.0.0: dependencies: default-require-extensions "^3.0.0" -archiver-utils@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/archiver-utils/-/archiver-utils-2.1.0.tgz#e8a460e94b693c3e3da182a098ca6285ba9249e2" - integrity sha512-bEL/yUb/fNNiNTuUz979Z0Yg5L+LzLxGJz8x79lYmR54fmTIb6ob/hNQgkQnIUDWIFjZVQwl9Xs356I6BAMHfw== - dependencies: - glob "^7.1.4" - graceful-fs "^4.2.0" - lazystream "^1.0.0" - lodash.defaults "^4.2.0" - lodash.difference "^4.5.0" - lodash.flatten "^4.4.0" - lodash.isplainobject "^4.0.6" - lodash.union "^4.6.0" - normalize-path "^3.0.0" - readable-stream "^2.0.0" - -archiver@^5.3.0: - version "5.3.1" - resolved "https://registry.yarnpkg.com/archiver/-/archiver-5.3.1.tgz#21e92811d6f09ecfce649fbefefe8c79e57cbbb6" - integrity sha512-8KyabkmbYrH+9ibcTScQ1xCJC/CGcugdVIwB+53f5sZziXgwUh3iXlAlANMxcZyDEfTHMe6+Z5FofV8nopXP7w== - dependencies: - archiver-utils "^2.1.0" - async "^3.2.3" - buffer-crc32 "^0.2.1" - readable-stream "^3.6.0" - readdir-glob "^1.0.0" - tar-stream "^2.2.0" - zip-stream "^4.1.0" - archy@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/archy/-/archy-1.0.0.tgz#f9c8c13757cc1dd7bc379ac77b2c62a5c2868c40" integrity sha512-Xg+9RwCg/0p32teKdGMPTPnVXKD0w3DfHnFTficozsAgsvq2XenPJq/MYpzzQ/v8zrOyJn6Ds39VA4JIDwFfqw== +are-docs-informative@^0.0.2: + version "0.0.2" + resolved "https://registry.yarnpkg.com/are-docs-informative/-/are-docs-informative-0.0.2.tgz#387f0e93f5d45280373d387a59d34c96db321963" + integrity sha512-ixiS0nLNNG5jNQzgZJNoUpBKdo9yTYZMGJ+QgT2jmjR7G7+QHRCc4v6LQ3NgE7EBJq+o0ams3waJwkrlBom8Ig== + arg@^4.1.0: version "4.1.3" resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" @@ -1236,20 +991,13 @@ argparse@^2.0.1: resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== -arr-diff@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520" - integrity sha512-YVIQ82gZPGBebQV/a8dar4AitzCQs0jjXwMPZllpXMaGjXPYVUawSxQrRsjhjupyVxEvbHgUmIhKVlND+j02kA== - -arr-flatten@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" - integrity sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg== - -arr-union@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4" - integrity sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q== +array-buffer-byte-length@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz#fabe8bc193fea865f317fe7807085ee0dee5aead" + integrity sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A== + dependencies: + call-bind "^1.0.2" + is-array-buffer "^3.0.1" array-differ@^3.0.0: version "3.0.0" @@ -1266,15 +1014,15 @@ array-ify@^1.0.0: resolved "https://registry.yarnpkg.com/array-ify/-/array-ify-1.0.0.tgz#9e528762b4a9066ad163a6962a364418e9626ece" integrity sha512-c5AMf34bKdvPhQ7tBGhqkgKNUzMr4WUs+WDtC2ZUGOUncbxKMTvqxYctiseW3+L4bA8ec+GcZ6/A/FW4m8ukng== -array-includes@^3.1.4, array-includes@^3.1.6: - version "3.1.6" - resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.6.tgz#9e9e720e194f198266ba9e18c29e6a9b0e4b225f" - integrity sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw== +array-includes@^3.1.7: + version "3.1.7" + resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.7.tgz#8cd2e01b26f7a3086cbc87271593fe921c62abda" + integrity sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" - get-intrinsic "^1.1.3" + define-properties "^1.2.0" + es-abstract "^1.22.1" + get-intrinsic "^1.2.1" is-string "^1.0.7" array-union@^2.1.0: @@ -1282,31 +1030,50 @@ array-union@^2.1.0: resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== -array-unique@^0.3.2: - version "0.3.2" - resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428" - integrity sha512-SleRWjh9JUud2wH1hPs9rZBZ33H6T9HOiL0uwGnGx9FpE6wKGyfWugmbkEOIs6qWrZhg0LWeLziLrEwQJhs5mQ== +array.prototype.findlastindex@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.3.tgz#b37598438f97b579166940814e2c0493a4f50207" + integrity sha512-LzLoiOMAxvy+Gd3BAq3B7VeIgPdo+Q8hthvKtXybMvRV0jrXfJM/t8mw7nNlpEcVlVUnCnM2KSX4XU5HmpodOA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" + es-shim-unscopables "^1.0.0" + get-intrinsic "^1.2.1" -array.prototype.flat@^1.2.5, array.prototype.flat@^1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.3.1.tgz#ffc6576a7ca3efc2f46a143b9d1dda9b4b3cf5e2" - integrity sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA== +array.prototype.flat@^1.3.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz#1476217df8cff17d72ee8f3ba06738db5b387d18" + integrity sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" + define-properties "^1.2.0" + es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" -array.prototype.flatmap@^1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz#1aae7903c2100433cb8261cd4ed310aab5c4a183" - integrity sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ== +array.prototype.flatmap@^1.3.2: + version "1.3.2" + resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz#c9a7c6831db8e719d6ce639190146c24bbd3e527" + integrity sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" + define-properties "^1.2.0" + es-abstract "^1.22.1" es-shim-unscopables "^1.0.0" +arraybuffer.prototype.slice@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz#98bd561953e3e74bb34938e77647179dfe6e9f12" + integrity sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw== + dependencies: + array-buffer-byte-length "^1.0.0" + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" + get-intrinsic "^1.2.1" + is-array-buffer "^3.0.2" + is-shared-array-buffer "^1.0.2" + arrify@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz#898508da2226f380df904728456849c1501a4b0d" @@ -1327,25 +1094,15 @@ assertion-error@^1.1.0: resolved "https://registry.yarnpkg.com/assertion-error/-/assertion-error-1.1.0.tgz#e60b6b0e8f301bd97e5375215bda406c85118c0b" integrity sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw== -assign-symbols@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367" - integrity sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw== - -async@^3.2.3: - version "3.2.4" - resolved "https://registry.yarnpkg.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" - integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== - asynckit@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== -atob@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9" - integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg== +atomic-sleep@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/atomic-sleep/-/atomic-sleep-1.0.0.tgz#eb85b77a601fc932cfe432c5acd364a9e2c9075b" + integrity sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ== available-typed-arrays@^1.0.5: version "1.0.5" @@ -1367,33 +1124,19 @@ base64url@^3.0.1: resolved "https://registry.yarnpkg.com/base64url/-/base64url-3.0.1.tgz#6399d572e2bc3f90a9a8b22d5dbb0a32d33f788d" integrity sha512-ir1UPr3dkwexU7FdV8qBBbNDRUhMmIekYMFZfi+C/sLNnRESKPl23nB9b2pltqfOQNnGzsDdId90AEtG5tCx4A== -base@^0.11.1: - version "0.11.2" - resolved "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz#7bde5ced145b6d551a90db87f83c558b4eb48a8f" - integrity sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg== +benchmark@^2.1.4: + version "2.1.4" + resolved "https://registry.yarnpkg.com/benchmark/-/benchmark-2.1.4.tgz#09f3de31c916425d498cc2ee565a0ebf3c2a5629" + integrity sha512-l9MlfN4M1K/H2fbhfMy3B7vJd6AGKJVQn2h6Sg/Yx+KckoUA7ewS5Vv6TjSq18ooE1kS9hhAlQRH3AkXIh/aOQ== dependencies: - cache-base "^1.0.1" - class-utils "^0.3.5" - component-emitter "^1.2.1" - define-property "^1.0.0" - isobject "^3.0.1" - mixin-deep "^1.2.0" - pascalcase "^0.1.1" + lodash "^4.17.4" + platform "^1.3.3" binary-extensions@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== -bl@^4.0.3: - version "4.1.0" - resolved "https://registry.yarnpkg.com/bl/-/bl-4.1.0.tgz#451535264182bec2fbbc83a62ab98cf11d9f7b3a" - integrity sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w== - dependencies: - buffer "^5.5.0" - inherits "^2.0.4" - readable-stream "^3.4.0" - brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" @@ -1409,22 +1152,6 @@ brace-expansion@^2.0.1: dependencies: balanced-match "^1.0.0" -braces@^2.3.1: - version "2.3.2" - resolved "https://registry.yarnpkg.com/braces/-/braces-2.3.2.tgz#5979fd3f14cd531565e5fa2df1abfff1dfaee729" - integrity sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w== - dependencies: - arr-flatten "^1.1.0" - array-unique "^0.3.2" - extend-shallow "^2.0.1" - fill-range "^4.0.0" - isobject "^3.0.1" - repeat-element "^1.1.2" - snapdragon "^0.8.1" - snapdragon-node "^2.0.1" - split-string "^3.0.2" - to-regex "^3.0.1" - braces@^3.0.2, braces@~3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" @@ -1447,11 +1174,6 @@ browserslist@^4.20.2: node-releases "^2.0.5" update-browserslist-db "^1.0.4" -buffer-crc32@^0.2.1, buffer-crc32@^0.2.13: - version "0.2.13" - resolved "https://registry.yarnpkg.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" - integrity sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ== - buffer-equal-constant-time@1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz#f8e71132f7ffe6e01a5c9697a4c6f3e48d5cc819" @@ -1462,33 +1184,18 @@ buffer-from@^1.0.0: resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== -buffer@^5.5.0: - version "5.7.1" - resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" - integrity sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ== +buffer@^6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== dependencies: base64-js "^1.3.1" - ieee754 "^1.1.13" + ieee754 "^1.2.1" -cache-base@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2" - integrity sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ== - dependencies: - collection-visit "^1.0.0" - component-emitter "^1.2.1" - get-value "^2.0.6" - has-value "^1.0.0" - isobject "^3.0.1" - set-value "^2.0.0" - to-object-path "^0.3.0" - union-value "^1.0.0" - unset-value "^1.0.0" - -cachedir@2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/cachedir/-/cachedir-2.1.0.tgz#b448c32b44cd9c0cd6ce4c419fa5b3c112c02191" - integrity sha512-xGBpPqoBvn3unBW7oxgb8aJn42K0m9m1/wyjmazah10Fq7bROGG3kRAE6OIyr3U3PIJUqGuebhCEdMk9OKJG0A== +builtin-modules@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-3.3.0.tgz#cae62812b89801e9656336e46223e030386be7b6" + integrity sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw== caching-transform@^4.0.0: version "4.0.0" @@ -1500,13 +1207,14 @@ caching-transform@^4.0.0: package-hash "^4.0.0" write-file-atomic "^3.0.0" -call-bind@^1.0.0, call-bind@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" - integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== +call-bind@^1.0.0, call-bind@^1.0.2, call-bind@^1.0.4, call-bind@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.5.tgz#6fa2b7845ce0ea49bf4d8b9ef64727a2c2e2e513" + integrity sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ== dependencies: - function-bind "^1.1.1" - get-intrinsic "^1.0.2" + function-bind "^1.1.2" + get-intrinsic "^1.2.1" + set-function-length "^1.1.1" callsites@^3.0.0: version "3.1.0" @@ -1554,33 +1262,25 @@ capital-case@^1.0.4: tslib "^2.0.3" upper-case-first "^2.0.2" -cardinal@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/cardinal/-/cardinal-2.1.1.tgz#7cc1055d822d212954d07b085dea251cc7bc5505" - integrity sha512-JSr5eOgoEymtYHBjNWyjrMqet9Am2miJhlfKNdqLp6zoeAh0KN5dRAcxlecj5mAJrmQomgiOBj35xHLrFjqBpw== - dependencies: - ansicolors "~0.3.2" - redeyed "~2.1.0" - chai-string@^1.5.0: version "1.5.0" resolved "https://registry.yarnpkg.com/chai-string/-/chai-string-1.5.0.tgz#0bdb2d8a5f1dbe90bc78ec493c1c1c180dd4d3d2" integrity sha512-sydDC3S3pNAQMYwJrs6dQX0oBQ6KfIPuOZ78n7rocW0eJJlsHPh2t3kwW7xfwYA/1Bf6/arGtSUo16rxR2JFlw== -chai@^4.2.0, chai@^4.3.7: - version "4.3.7" - resolved "https://registry.yarnpkg.com/chai/-/chai-4.3.7.tgz#ec63f6df01829088e8bf55fca839bcd464a8ec51" - integrity sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A== +chai@^4.3.10: + version "4.3.10" + resolved "https://registry.yarnpkg.com/chai/-/chai-4.3.10.tgz#d784cec635e3b7e2ffb66446a63b4e33bd390384" + integrity sha512-0UXG04VuVbruMUYbJ6JctvH0YnC/4q3/AkT18q4NaITo91CUm0liMS9VqzT9vZhVQ/1eqPanMWjBM+Juhfb/9g== dependencies: assertion-error "^1.1.0" - check-error "^1.0.2" - deep-eql "^4.1.2" - get-func-name "^2.0.0" - loupe "^2.3.1" + check-error "^1.0.3" + deep-eql "^4.1.3" + get-func-name "^2.0.2" + loupe "^2.3.6" pathval "^1.1.1" - type-detect "^4.0.5" + type-detect "^4.0.8" -chalk@^2.0.0, chalk@^2.4.1: +chalk@^2.0.0: version "2.4.2" resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== @@ -1628,10 +1328,12 @@ chardet@^0.7.0: resolved "https://registry.yarnpkg.com/chardet/-/chardet-0.7.0.tgz#90094849f0937f2eedc2425d0d28a9e5f0cbad9e" integrity sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA== -check-error@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.2.tgz#574d312edd88bb5dd8912e9286dd6c0aed4aac82" - integrity sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA== +check-error@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/check-error/-/check-error-1.0.3.tgz#a6502e4312a7ee969f646e83bb3ddd56281bd694" + integrity sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg== + dependencies: + get-func-name "^2.0.2" chokidar@3.5.3, chokidar@^3.5.3: version "3.5.3" @@ -1648,40 +1350,23 @@ chokidar@3.5.3, chokidar@^3.5.3: optionalDependencies: fsevents "~2.3.2" -chownr@^1.1.1: - version "1.1.4" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" - integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== +ci-info@^3.8.0: + version "3.9.0" + resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.9.0.tgz#4279a62028a7b1f262f3473fc9605f5e218c59b4" + integrity sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ== -class-utils@^0.3.5: - version "0.3.6" - resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463" - integrity sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg== +clean-regexp@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/clean-regexp/-/clean-regexp-1.0.0.tgz#8df7c7aae51fd36874e8f8d05b9180bc11a3fed7" + integrity sha512-GfisEZEJvzKrmGWkvfhgzcz/BllN1USeqD2V6tg14OAOgaCD2Z/PUEuxnAZ/nPvmaHRG7a8y77p1T/IRQ4D1Hw== dependencies: - arr-union "^3.1.0" - define-property "^0.2.5" - isobject "^3.0.0" - static-extend "^0.1.1" + escape-string-regexp "^1.0.5" clean-stack@^2.0.0: version "2.2.0" resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== -clean-stack@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-3.0.1.tgz#155bf0b2221bf5f4fba89528d24c5953f17fe3a8" - integrity sha512-lR9wNiMRcVQjSB3a7xXGLuz4cr4wJuuXlaAEbRutGowQTmlp7R72/DOgN21e8jdwblMWl9UOJMJXarX94pzKdg== - dependencies: - escape-string-regexp "4.0.0" - -cli-cursor@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz#b35dac376479facc3e94747d41d0d0f5238ffcb5" - integrity sha512-8lgKz8LmCRYZZQDpRyT2m5rKJ08TnU4tR9FFFW2rxpxR1FzWi4PQ/NfyODchAatHaUgnSPVcx/R5w6NuTBzFiw== - dependencies: - restore-cursor "^2.0.0" - cli-cursor@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-3.1.0.tgz#264305a7ae490d1d03bf0c9ba7c925d1753af307" @@ -1689,50 +1374,6 @@ cli-cursor@^3.1.0: dependencies: restore-cursor "^3.1.0" -cli-progress@^3.4.0: - version "3.11.2" - resolved "https://registry.yarnpkg.com/cli-progress/-/cli-progress-3.11.2.tgz#f8c89bd157e74f3f2c43bcfb3505670b4d48fc77" - integrity sha512-lCPoS6ncgX4+rJu5bS3F/iCz17kZ9MPZ6dpuTtI0KXKABkhyXIdYB3Inby1OpaGti3YlI3EeEkM9AuWpelJrVA== - dependencies: - string-width "^4.2.3" - -cli-ux@5.6.7: - version "5.6.7" - resolved "https://registry.yarnpkg.com/cli-ux/-/cli-ux-5.6.7.tgz#32ef9e6cb2b457be834280cc799028a11c8235a8" - integrity sha512-dsKAurMNyFDnO6X1TiiRNiVbL90XReLKcvIq4H777NMqXGBxBws23ag8ubCJE97vVZEgWG2eSUhsyLf63Jv8+g== - dependencies: - "@oclif/command" "^1.8.15" - "@oclif/errors" "^1.3.5" - "@oclif/linewrap" "^1.0.0" - "@oclif/screen" "^1.0.4" - ansi-escapes "^4.3.0" - ansi-styles "^4.2.0" - cardinal "^2.1.1" - chalk "^4.1.0" - clean-stack "^3.0.0" - cli-progress "^3.4.0" - extract-stack "^2.0.0" - fs-extra "^8.1" - hyperlinker "^1.0.0" - indent-string "^4.0.0" - is-wsl "^2.2.0" - js-yaml "^3.13.1" - lodash "^4.17.21" - natural-orderby "^2.0.1" - object-treeify "^1.1.4" - password-prompt "^1.1.2" - semver "^7.3.2" - string-width "^4.2.0" - strip-ansi "^6.0.0" - supports-color "^8.1.0" - supports-hyperlinks "^2.1.0" - tslib "^2.0.0" - -cli-width@^2.0.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.1.tgz#b0433d0b4e9c847ef18868a4ef16fd5fc8271c48" - integrity sha512-GRMWDxpOB6Dgk2E5Uo+3eEBvtOOlimMmpbFiKuLFnQzYDavtLFY3K5ona41jgN/WdRZtG7utuVSVTL4HbZHGkw== - cli-width@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-3.0.0.tgz#a2f48437a2caa9a22436e794bf071ec9e61cedf6" @@ -1756,13 +1397,14 @@ cliui@^7.0.2: strip-ansi "^6.0.0" wrap-ansi "^7.0.0" -collection-visit@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz#4bc0373c164bc3291b4d368c829cf1a80a59dca0" - integrity sha512-lNkKvzEeMBBjUGHZ+q6z9pSJla0KWAQPvtzhEV9+iGyQYG+pBpl7xKDhxoNSOZH2hhv0v5k0y2yAM4o4SjoSkw== +cliui@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-8.0.1.tgz#0c04b075db02cbfe60dc8e6cf2f5486b1a3608aa" + integrity sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ== dependencies: - map-visit "^1.0.0" - object-visit "^1.0.0" + string-width "^4.2.0" + strip-ansi "^6.0.1" + wrap-ansi "^7.0.0" color-convert@^1.9.0: version "1.9.3" @@ -1788,6 +1430,11 @@ color-name@~1.1.4: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== +colorette@^2.0.7: + version "2.0.20" + resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.20.tgz#9eb793e6833067f7235902fcd3b09917a000a95a" + integrity sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w== + combined-stream@^1.0.8: version "1.0.8" resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" @@ -1800,36 +1447,10 @@ commander@^4.0.1: resolved "https://registry.yarnpkg.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068" integrity sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA== -comment-parser@1.1.6-beta.0: - version "1.1.6-beta.0" - resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.1.6-beta.0.tgz#57e503b18d0a5bd008632dcc54b1f95c2fffe8f6" - integrity sha512-q3cA8TSMyqW7wcPSYWzbO/rMahnXgzs4SLG/UIWXdEsnXTFPZkEkWAdNgPiHig2OzxgpPLOh4WwsmClDxndwHw== - -comment-parser@1.3.1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.3.1.tgz#3d7ea3adaf9345594aedee6563f422348f165c1b" - integrity sha512-B52sN2VNghyq5ofvUsqZjmk6YkihBX5vMSChmSK9v4ShjKf3Vk5Xcmgpw4o+iIgtrnM/u5FiMpz9VKb8lpBveA== - -commitizen@^3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/commitizen/-/commitizen-3.1.2.tgz#29ddd8b39396923e9058a0e4840cbeef144290be" - integrity sha512-eD0uTUsogu8ksFjFFYq75LLfXeLXsCIa27TPfOqvBI+tCx1Pp5QfKqC9oC+qTpSz3nTn9/+7TL5mE/wurB22JQ== - dependencies: - cachedir "2.1.0" - cz-conventional-changelog "2.1.0" - dedent "0.7.0" - detect-indent "^5.0.0" - find-node-modules "2.0.0" - find-root "1.1.0" - fs-extra "^7.0.0" - glob "7.1.3" - inquirer "6.2.0" - is-utf8 "^0.2.1" - lodash "4.17.14" - minimist "1.2.0" - shelljs "0.7.6" - strip-bom "3.0.0" - strip-json-comments "2.0.1" +comment-parser@1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/comment-parser/-/comment-parser-1.4.1.tgz#bdafead37961ac079be11eb7ec65c4d021eaf9cc" + integrity sha512-buhp5kePrmda3vhc5B9t7pUQXAb2Tnd0qgpkIhPhkHXxJpiPJ11H0ZEU0oBpJ2QztSbzG/ZxMj/CHsYJqRHmyg== commondir@^1.0.1: version "1.0.1" @@ -1844,21 +1465,6 @@ compare-func@^2.0.0: array-ify "^1.0.0" dot-prop "^5.1.0" -component-emitter@^1.2.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" - integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== - -compress-commons@^4.1.0: - version "4.1.1" - resolved "https://registry.yarnpkg.com/compress-commons/-/compress-commons-4.1.1.tgz#df2a09a7ed17447642bad10a85cc9a19e5c42a7d" - integrity sha512-QLdDLCKNV2dtoTorqgxngQCMA+gWXkM/Nwu7FpeBhk/RdkzimqC3jueb/FDmaZeXh+uby1jkBqE3xArsLBE5wQ== - dependencies: - buffer-crc32 "^0.2.13" - crc32-stream "^4.0.2" - normalize-path "^3.0.0" - readable-stream "^3.6.0" - concat-map@0.0.1: version "0.0.1" resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" @@ -1873,11 +1479,6 @@ constant-case@^3.0.4: tslib "^2.0.3" upper-case "^2.0.2" -content-type@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" - integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== - conventional-changelog-angular@^5.0.11: version "5.0.13" resolved "https://registry.yarnpkg.com/conventional-changelog-angular/-/conventional-changelog-angular-5.0.13.tgz#896885d63b914a70d4934b59d2fe7bde1832b28c" @@ -1895,11 +1496,6 @@ conventional-changelog-conventionalcommits@^5.0.0: lodash "^4.17.15" q "^1.5.1" -conventional-commit-types@^2.0.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/conventional-commit-types/-/conventional-commit-types-2.3.0.tgz#bc3c8ebba0a9e4b3ecc548f1d0674e251ab8be22" - integrity sha512-6iB39PrcGYdz0n3z31kj6/Km6mK9hm9oMRhwcLnKxE7WNoeRKZbTAobliKrbYZ5jqyCvtcVEfjCiaEzhL3AVmQ== - conventional-commits-parser@^3.2.2: version "3.2.4" resolved "https://registry.yarnpkg.com/conventional-commits-parser/-/conventional-commits-parser-3.2.4.tgz#a7d3b77758a202a9b2293d2112a8d8052c740972" @@ -1919,20 +1515,15 @@ convert-source-map@^1.7.0: dependencies: safe-buffer "~5.1.1" -copy-descriptor@^0.1.0: - version "0.1.1" - resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d" - integrity sha512-XgZ0pFcakEUlbwQEVNg3+QAis1FyTL3Qel9FYy8pSkQqoG3PNoT0bOCQtOXcOkur21r2Eq2kI+IE+gsmAEVlYw== - -core-js-pure@^3.25.1: - version "3.25.5" - resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.25.5.tgz#79716ba54240c6aa9ceba6eee08cf79471ba184d" - integrity sha512-oml3M22pHM+igfWHDfdLVq2ShWmjM2V4L+dQEBs0DWVIqEm9WHCwGAlZ6BmyBQGy5sFrJmcx+856D9lVKyGWYg== +core-js-pure@^3.30.2: + version "3.33.0" + resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.33.0.tgz#938a28754b4d82017a7a8cbd2727b1abecc63591" + integrity sha512-FKSIDtJnds/YFIEaZ4HszRX7hkxGpNKM7FC9aJ9WLJbSd3lD4vOltFuVIBLR8asSx9frkTSqL0dw90SKQxgKrg== core-js@^3.6.4: - version "3.25.5" - resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.25.5.tgz#e86f651a2ca8a0237a5f064c2fe56cef89646e27" - integrity sha512-nbm6eZSjm+ZuBQxCUPQKQCoUEfFOXjUZ8dTTyikyKaWrTYmAVbykQfwsKE5dBK88u3QCkCrzsx/PPlKfhsvgpw== + version "3.33.0" + resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.33.0.tgz#70366dbf737134761edb017990cf5ce6c6369c40" + integrity sha512-HoZr92+ZjFEKar5HS6MC776gYslNOKHt75mEBKWKnPeFDpZ6nH5OeF3S6HFT1mUAUZKrzkez05VboaX8myjSuw== core-util-is@~1.0.0: version "1.0.3" @@ -1965,35 +1556,11 @@ cosmiconfig@^8.0.0: parse-json "^5.0.0" path-type "^4.0.0" -crc-32@^1.2.0: - version "1.2.2" - resolved "https://registry.yarnpkg.com/crc-32/-/crc-32-1.2.2.tgz#3cad35a934b8bf71f25ca524b6da51fb7eace2ff" - integrity sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ== - -crc32-stream@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/crc32-stream/-/crc32-stream-4.0.2.tgz#c922ad22b38395abe9d3870f02fa8134ed709007" - integrity sha512-DxFZ/Hk473b/muq1VJ///PMNLj0ZMnzye9thBpmjpJKCc5eMgB95aK8zCGrGfQ90cWo561Te6HK9D+j4KPdM6w== - dependencies: - crc-32 "^1.2.0" - readable-stream "^3.4.0" - create-require@^1.1.0: version "1.1.1" resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== -cross-spawn@^6.0.0, cross-spawn@^6.0.5: - version "6.0.5" - resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz#4a5ec7c64dfae22c3a14124dbacdee846d80cbc4" - integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== - dependencies: - nice-try "^1.0.4" - path-key "^2.0.1" - semver "^5.5.0" - shebang-command "^1.2.0" - which "^1.2.9" - cross-spawn@^7.0.0, cross-spawn@^7.0.2, cross-spawn@^7.0.3: version "7.0.3" resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" @@ -2020,53 +1587,23 @@ csv-stringify@^5.3.4: resolved "https://registry.yarnpkg.com/csv-stringify/-/csv-stringify-5.6.5.tgz#c6d74badda4b49a79bf4e72f91cce1e33b94de00" integrity sha512-PjiQ659aQ+fUTQqSrd1XEDnOr52jh30RBurfzkscaE2tPaFsDH5wOAHJiw8XAHphRknCwMUE9KRayc4K/NbO8A== -cz-conventional-changelog@2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/cz-conventional-changelog/-/cz-conventional-changelog-2.1.0.tgz#2f4bc7390e3244e4df293e6ba351e4c740a7c764" - integrity sha512-TMjkSrvju5fPQV+Ho8TIioAgXkly8h3vJ/txiczJrlUaLpgMGA6ssnwquLMWzNZZyCsJK5r4kPgwdohC4UAGmQ== - dependencies: - conventional-commit-types "^2.0.0" - lodash.map "^4.5.1" - longest "^1.0.1" - right-pad "^1.0.1" - word-wrap "^1.0.3" - dargs@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/dargs/-/dargs-7.0.0.tgz#04015c41de0bcb69ec84050f3d9be0caf8d6d5cc" integrity sha512-2iy1EkLdlBzQGvbweYRFxmFath8+K7+AKB0TlhHWkNuH+TmovaMH/Wp7V7R4u7f4SnX3OgLsU9t1NI9ioDnUpg== -dayjs-plugin-utc@^0.1.2: - version "0.1.2" - resolved "https://registry.yarnpkg.com/dayjs-plugin-utc/-/dayjs-plugin-utc-0.1.2.tgz#48e552407024143922d6499a40f6c765f8c93d03" - integrity sha512-ExERH5o3oo6jFOdkvMP3gytTCQ9Ksi5PtylclJWghr7k7m3o2U5QrwtdiJkOxLOH4ghr0EKhpqGefzGz1VvVJg== - -dayjs@^1.8.16: - version "1.11.5" - resolved "https://registry.yarnpkg.com/dayjs/-/dayjs-1.11.5.tgz#00e8cc627f231f9499c19b38af49f56dc0ac5e93" - integrity sha512-CAdX5Q3YW3Gclyo5Vpqkgpj8fSdLQcRuzfX6mC6Phy0nfJ0eGYOeS7m4mt2plDWLAtA4TqTakvbboHvUxfe4iA== +dateformat@^4.6.3: + version "4.6.3" + resolved "https://registry.yarnpkg.com/dateformat/-/dateformat-4.6.3.tgz#556fa6497e5217fedb78821424f8a1c22fa3f4b5" + integrity sha512-2P0p0pFGzHS5EMnhdxQi7aJN+iMheud0UhG4dlE1DLAlvL8JHjJJTX/CSm4JXwV0Ka5nGk3zC5mcb5bUQUxxMA== -debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: +debug@4, debug@4.3.4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: version "4.3.4" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== dependencies: ms "2.1.2" -debug@4.3.3: - version "4.3.3" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" - integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q== - dependencies: - ms "2.1.2" - -debug@^2.2.0, debug@^2.3.3, debug@^2.6.9: - version "2.6.9" - resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - debug@^3.2.7: version "3.2.7" resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" @@ -2092,17 +1629,7 @@ decamelize@^4.0.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== -decode-uri-component@^0.2.0: - version "0.2.2" - resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.2.tgz#e69dbe25d37941171dd540e024c444cd5188e1e9" - integrity sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ== - -dedent@0.7.0: - version "0.7.0" - resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" - integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== - -deep-eql@^4.1.2: +deep-eql@^4.1.3: version "4.1.3" resolved "https://registry.yarnpkg.com/deep-eql/-/deep-eql-4.1.3.tgz#7c7775513092f7df98d8df9996dd085eb668cc6d" integrity sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw== @@ -2121,56 +1648,28 @@ default-require-extensions@^3.0.0: dependencies: strip-bom "^4.0.0" -define-properties@^1.1.3, define-properties@^1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.4.tgz#0b14d7bd7fbeb2f3572c3a7eda80ea5d57fb05b1" - integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== +define-data-property@^1.0.1, define-data-property@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/define-data-property/-/define-data-property-1.1.1.tgz#c35f7cd0ab09883480d12ac5cb213715587800b3" + integrity sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ== dependencies: + get-intrinsic "^1.2.1" + gopd "^1.0.1" has-property-descriptors "^1.0.0" - object-keys "^1.1.1" -define-property@^0.2.5: - version "0.2.5" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz#c35b1ef918ec3c990f9a5bc57be04aacec5c8116" - integrity sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA== - dependencies: - is-descriptor "^0.1.0" - -define-property@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz#769ebaaf3f4a63aad3af9e8d304c9bbe79bfb0e6" - integrity sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA== - dependencies: - is-descriptor "^1.0.0" - -define-property@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz#d459689e8d654ba77e02a817f8710d702cb16e9d" - integrity sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ== +define-properties@^1.1.3, define-properties@^1.1.4, define-properties@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.2.0.tgz#52988570670c9eacedd8064f4a990f2405849bd5" + integrity sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA== dependencies: - is-descriptor "^1.0.2" - isobject "^3.0.1" + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" delayed-stream@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== -detect-file@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/detect-file/-/detect-file-1.0.0.tgz#f0d66d03672a825cb1b73bdb3fe62310c8e552b7" - integrity sha512-DtCOLG98P007x7wiiOmfI0fi3eIKyWiLTGJ2MDnVi/E04lWGbf+JzrRHMm0rgIIZJGtHpKpbVgLWHrv8xXpc3Q== - -detect-indent@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-5.0.0.tgz#3871cc0a6a002e8c3e5b3cf7f336264675f06b9d" - integrity sha512-rlpvsxUtM0PQvy9iZe640/IWwWYyBsTApREbA1pHOpmOUIl9MkP/U4z7vTtg4Oaojvqhxt7sdufnT0EzGaR31g== - -detect-indent@^6.0.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-6.1.0.tgz#592485ebbbf6b3b1ab2be175c8393d04ca0d57e6" - integrity sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA== - diff@5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/diff/-/diff-5.0.0.tgz#7ed6ad76d859d030787ec35855f5b1daf31d852b" @@ -2186,11 +1685,6 @@ diff@^4.0.1, diff@^4.0.2: resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== -diff@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/diff/-/diff-5.1.0.tgz#bc52d298c5ea8df9194800224445ed43ffc87e40" - integrity sha512-D+mk+qE8VC/PAUrlAU34N+VfXev0ghe5ywmpqrawphmVZc1bEfn56uo9qpyGp1p4xpzOHkSW4ztBd6L7Xx4ACw== - dir-glob@^3.0.1: version "3.0.1" resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" @@ -2227,13 +1721,6 @@ dot-prop@^5.1.0: dependencies: is-obj "^2.0.0" -dtrace-provider@~0.6: - version "0.6.0" - resolved "https://registry.yarnpkg.com/dtrace-provider/-/dtrace-provider-0.6.0.tgz#0b078d5517937d873101452d9146737557b75e51" - integrity sha512-yqNrDWYWOR3wumcWPhlIGIKRSFMbDEwilGi+xYeaY4wW82cZrWsqGE+jsVnouxMqt/kCVsNmy/XDXLrm/J6SJg== - dependencies: - nan "^2.0.8" - ecdsa-sig-formatter@1.0.11: version "1.0.11" resolved "https://registry.yarnpkg.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz#ae0f0fa2d85045ef14a817daa3ce9acd0489e5bf" @@ -2251,7 +1738,7 @@ emoji-regex@^8.0.0: resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== -end-of-stream@^1.1.0, end-of-stream@^1.4.1: +end-of-stream@^1.1.0: version "1.4.4" resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== @@ -2265,44 +1752,50 @@ error-ex@^1.3.1: dependencies: is-arrayish "^0.2.1" -es-abstract@^1.19.0, es-abstract@^1.20.4: - version "1.21.1" - resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.21.1.tgz#e6105a099967c08377830a0c9cb589d570dd86c6" - integrity sha512-QudMsPOz86xYz/1dG1OuGBKOELjCh99IIWHLzy5znUB6j8xG2yMA7bfTV86VSqKF+Y/H08vQPR+9jyXpuC6hfg== +es-abstract@^1.22.1: + version "1.22.3" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.22.3.tgz#48e79f5573198de6dee3589195727f4f74bc4f32" + integrity sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA== dependencies: + array-buffer-byte-length "^1.0.0" + arraybuffer.prototype.slice "^1.0.2" available-typed-arrays "^1.0.5" - call-bind "^1.0.2" + call-bind "^1.0.5" es-set-tostringtag "^2.0.1" es-to-primitive "^1.2.1" - function-bind "^1.1.1" - function.prototype.name "^1.1.5" - get-intrinsic "^1.1.3" + function.prototype.name "^1.1.6" + get-intrinsic "^1.2.2" get-symbol-description "^1.0.0" globalthis "^1.0.3" gopd "^1.0.1" - has "^1.0.3" has-property-descriptors "^1.0.0" has-proto "^1.0.1" has-symbols "^1.0.3" - internal-slot "^1.0.4" - is-array-buffer "^3.0.1" + hasown "^2.0.0" + internal-slot "^1.0.5" + is-array-buffer "^3.0.2" is-callable "^1.2.7" is-negative-zero "^2.0.2" is-regex "^1.1.4" is-shared-array-buffer "^1.0.2" is-string "^1.0.7" - is-typed-array "^1.1.10" + is-typed-array "^1.1.12" is-weakref "^1.0.2" - object-inspect "^1.12.2" + object-inspect "^1.13.1" object-keys "^1.1.1" object.assign "^4.1.4" - regexp.prototype.flags "^1.4.3" + regexp.prototype.flags "^1.5.1" + safe-array-concat "^1.0.1" safe-regex-test "^1.0.0" - string.prototype.trimend "^1.0.6" - string.prototype.trimstart "^1.0.6" + string.prototype.trim "^1.2.8" + string.prototype.trimend "^1.0.7" + string.prototype.trimstart "^1.0.7" + typed-array-buffer "^1.0.0" + typed-array-byte-length "^1.0.0" + typed-array-byte-offset "^1.0.0" typed-array-length "^1.0.4" unbox-primitive "^1.0.2" - which-typed-array "^1.1.9" + which-typed-array "^1.1.13" es-set-tostringtag@^2.0.1: version "2.0.1" @@ -2349,167 +1842,151 @@ escape-string-regexp@^1.0.5: resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== -eslint-config-prettier@^8.5.0, eslint-config-prettier@^8.8.0: - version "8.8.0" - resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.8.0.tgz#bfda738d412adc917fd7b038857110efe98c9348" - integrity sha512-wLbQiFre3tdGgpDv67NQKnJuTlcUVYHas3k+DZCc2U2BadthoEY4B7hLPvAxaqdyOGCzuLfii2fqGph10va7oA== - -eslint-config-salesforce-license@^0.1.6: - version "0.1.6" - resolved "https://registry.yarnpkg.com/eslint-config-salesforce-license/-/eslint-config-salesforce-license-0.1.6.tgz#75b475cf90f92e1dcb4340124466288915fed3f8" - integrity sha512-PH1nkm6MaouON4Ac4fgJh29oQiHlpU/G2xS45FAYeAWkh1up88j1UpjXt2ISNniQVvU4uqfVAOOaEb5X5hDqYw== +eslint-config-prettier@^9.0.0: + version "9.0.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-9.0.0.tgz#eb25485946dd0c66cd216a46232dc05451518d1f" + integrity sha512-IcJsTkJae2S35pRsRAwoCE+925rJJStOdkKnLVgtE+tEpqU0EVVM7OqrwxqgptKdX29NUwC82I5pXsGFIgSevw== eslint-config-salesforce-license@^0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/eslint-config-salesforce-license/-/eslint-config-salesforce-license-0.2.0.tgz#323193f1aa15dd33fbf108d25fc1210afc11065e" integrity sha512-DJdBvgj82Erum82YMe+YvG/o6ukna3UA++lRl0HSTldj0VlBl3Q8hzCp97nRXZHra6JH1I912yievZzklXDw6w== -eslint-config-salesforce-typescript@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/eslint-config-salesforce-typescript/-/eslint-config-salesforce-typescript-1.1.1.tgz#fb038f6423c5472d6439e9f780184b00ebcd2685" - integrity sha512-cjj2tU5wkushOUynecjg0JQtb/y61pWSjtOKKnNzWEdtbZEs7pe1/w5hsaZ79urdeFFUHQW2mr3qpzsWzUjgxQ== - -eslint-config-salesforce@^1.1.0, eslint-config-salesforce@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/eslint-config-salesforce/-/eslint-config-salesforce-1.1.1.tgz#0d25735324675cae3fefcbc4e6021aa2c77ea12f" - integrity sha512-xDp5ucbmSOAemFHOmzhli5RL864RoAghq/Yf5HeLvNz2JsrUvgW8n97LeZAJxlhj82JqKRg87IEHERUE4BRVPg== +eslint-config-salesforce-typescript@^3.0.5: + version "3.0.5" + resolved "https://registry.yarnpkg.com/eslint-config-salesforce-typescript/-/eslint-config-salesforce-typescript-3.0.5.tgz#1fa7b224551255b520f19d208be5d1bb2410c2b4" + integrity sha512-p+Do1i8Al1HANKubYV9WnJl9P/ChP/gvM+1tjtYiGqVjaO2Gf6V1ejM51r//uw4OoiFEldqKJK/gyMzSvRHkaw== + dependencies: + "@typescript-eslint/eslint-plugin" "^6.10.0" + "@typescript-eslint/parser" "^6.10.0" + eslint "^8.53.0" + eslint-config-prettier "^9.0.0" + eslint-config-salesforce "^2.0.2" + eslint-config-salesforce-license "^0.2.0" + eslint-plugin-header "^3.1.1" + eslint-plugin-import "^2.29.0" + eslint-plugin-jsdoc "^46.9.0" + eslint-plugin-unicorn "^49.0.0" + +eslint-config-salesforce@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/eslint-config-salesforce/-/eslint-config-salesforce-2.0.2.tgz#38eb2d8eb2824c66967ed9b45bc92082eba2f225" + integrity sha512-3jbrI+QFu/KaQbPYIBxItB3okqUtA4EBCGiR6s2kcUMIZBLBBGAURW0k62f9WAv1EagR3eUoO0m9ru7LTj2F5Q== -eslint-import-resolver-node@^0.3.6, eslint-import-resolver-node@^0.3.7: - version "0.3.7" - resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.7.tgz#83b375187d412324a1963d84fa664377a23eb4d7" - integrity sha512-gozW2blMLJCeFpBwugLTGyvVjNoeo1knonXAcatC6bjPBZitotxdWf7Gimr25N4c0AAOo4eOUfaG82IJPDpqCA== +eslint-import-resolver-node@^0.3.9: + version "0.3.9" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz#d4eaac52b8a2e7c3cd1903eb00f7e053356118ac" + integrity sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g== dependencies: debug "^3.2.7" - is-core-module "^2.11.0" - resolve "^1.22.1" + is-core-module "^2.13.0" + resolve "^1.22.4" -eslint-module-utils@^2.7.3, eslint-module-utils@^2.7.4: - version "2.7.4" - resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.7.4.tgz#4f3e41116aaf13a20792261e61d3a2e7e0583974" - integrity sha512-j4GT+rqzCoRKHwURX7pddtIPGySnX9Si/cgMI5ztrcqOPtk5dDEeZ34CQVPphnqkJytlc97Vuk05Um2mJ3gEQA== +eslint-module-utils@^2.8.0: + version "2.8.0" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz#e439fee65fc33f6bba630ff621efc38ec0375c49" + integrity sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw== dependencies: debug "^3.2.7" -eslint-plugin-header@^3.0.0, eslint-plugin-header@^3.1.1: +eslint-plugin-header@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/eslint-plugin-header/-/eslint-plugin-header-3.1.1.tgz#6ce512432d57675265fac47292b50d1eff11acd6" integrity sha512-9vlKxuJ4qf793CmeeSrZUvVClw6amtpghq3CuWcB5cUNnWHQhgcqy5eF8oVKFk1G3Y/CbchGfEaw3wiIJaNmVg== -eslint-plugin-import@2.26.0: - version "2.26.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz#f812dc47be4f2b72b478a021605a59fc6fe8b88b" - integrity sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA== +eslint-plugin-import@^2.29.0: + version "2.29.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.29.0.tgz#8133232e4329ee344f2f612885ac3073b0b7e155" + integrity sha512-QPOO5NO6Odv5lpoTkddtutccQjysJuFxoPS7fAHO+9m9udNHvTCPSAMW9zGAYj8lAIdr40I8yPCdUYrncXtrwg== dependencies: - array-includes "^3.1.4" - array.prototype.flat "^1.2.5" - debug "^2.6.9" - doctrine "^2.1.0" - eslint-import-resolver-node "^0.3.6" - eslint-module-utils "^2.7.3" - has "^1.0.3" - is-core-module "^2.8.1" - is-glob "^4.0.3" - minimatch "^3.1.2" - object.values "^1.1.5" - resolve "^1.22.0" - tsconfig-paths "^3.14.1" - -eslint-plugin-import@^2.27.5: - version "2.27.5" - resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.27.5.tgz#876a6d03f52608a3e5bb439c2550588e51dd6c65" - integrity sha512-LmEt3GVofgiGuiE+ORpnvP+kAm3h6MLZJ4Q5HCyHADofsb4VzXFsRiWj3c0OFiV+3DWFh0qg3v9gcPlfc3zRow== - dependencies: - array-includes "^3.1.6" - array.prototype.flat "^1.3.1" - array.prototype.flatmap "^1.3.1" + array-includes "^3.1.7" + array.prototype.findlastindex "^1.2.3" + array.prototype.flat "^1.3.2" + array.prototype.flatmap "^1.3.2" debug "^3.2.7" doctrine "^2.1.0" - eslint-import-resolver-node "^0.3.7" - eslint-module-utils "^2.7.4" - has "^1.0.3" - is-core-module "^2.11.0" + eslint-import-resolver-node "^0.3.9" + eslint-module-utils "^2.8.0" + hasown "^2.0.0" + is-core-module "^2.13.1" is-glob "^4.0.3" minimatch "^3.1.2" - object.values "^1.1.6" - resolve "^1.22.1" - semver "^6.3.0" - tsconfig-paths "^3.14.1" - -eslint-plugin-jsdoc@^35.1.2: - version "35.5.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-35.5.1.tgz#45932ee22669bbe06c97b82b936d56361efad370" - integrity sha512-pPYPWtsykwVEue1tYEyoppBj4dgF7XicF67tLLLraY6RQYBq7qMKjUHji19+hfiTtYKKBD0YfeK8hgjPAE5viw== - dependencies: - "@es-joy/jsdoccomment" "0.9.0-alpha.1" - comment-parser "1.1.6-beta.0" - debug "^4.3.2" - esquery "^1.4.0" - jsdoc-type-pratt-parser "^1.0.4" - lodash "^4.17.21" - regextras "^0.8.0" - semver "^7.3.5" - spdx-expression-parse "^3.0.1" - -eslint-plugin-jsdoc@^39.9.1: - version "39.9.1" - resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-39.9.1.tgz#e9ce1723411fd7ea0933b3ef0dd02156ae3068e2" - integrity sha512-Rq2QY6BZP2meNIs48aZ3GlIlJgBqFCmR55+UBvaDkA3ZNQ0SvQXOs2QKkubakEijV8UbIVbVZKsOVN8G3MuqZw== - dependencies: - "@es-joy/jsdoccomment" "~0.36.1" - comment-parser "1.3.1" + object.fromentries "^2.0.7" + object.groupby "^1.0.1" + object.values "^1.1.7" + semver "^6.3.1" + tsconfig-paths "^3.14.2" + +eslint-plugin-jsdoc@^46.9.0: + version "46.9.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-46.9.0.tgz#9887569dbeef0a008a2770bfc5d0f7fc39f21f2b" + integrity sha512-UQuEtbqLNkPf5Nr/6PPRCtr9xypXY+g8y/Q7gPa0YK7eDhh0y2lWprXRnaYbW7ACgIUvpDKy9X2bZqxtGzBG9Q== + dependencies: + "@es-joy/jsdoccomment" "~0.41.0" + are-docs-informative "^0.0.2" + comment-parser "1.4.1" debug "^4.3.4" escape-string-regexp "^4.0.0" - esquery "^1.4.0" - semver "^7.3.8" + esquery "^1.5.0" + is-builtin-module "^3.2.1" + semver "^7.5.4" spdx-expression-parse "^3.0.1" -eslint-plugin-prefer-arrow@^1.2.1: - version "1.2.3" - resolved "https://registry.yarnpkg.com/eslint-plugin-prefer-arrow/-/eslint-plugin-prefer-arrow-1.2.3.tgz#e7fbb3fa4cd84ff1015b9c51ad86550e55041041" - integrity sha512-J9I5PKCOJretVuiZRGvPQxCbllxGAV/viI20JO3LYblAodofBxyMnZAJ+WGeClHgANnSJberTNoFWWjrWKBuXQ== - -eslint-scope@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" - integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== +eslint-plugin-unicorn@^49.0.0: + version "49.0.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-unicorn/-/eslint-plugin-unicorn-49.0.0.tgz#4449ea954d7e1455eec8518f9417d7021b245fa8" + integrity sha512-0fHEa/8Pih5cmzFW5L7xMEfUTvI9WKeQtjmKpTUmY+BiFCDxkxrTdnURJOHKykhtwIeyYsxnecbGvDCml++z4Q== dependencies: - esrecurse "^4.3.0" - estraverse "^4.1.1" + "@babel/helper-validator-identifier" "^7.22.20" + "@eslint-community/eslint-utils" "^4.4.0" + ci-info "^3.8.0" + clean-regexp "^1.0.0" + esquery "^1.5.0" + indent-string "^4.0.0" + is-builtin-module "^3.2.1" + jsesc "^3.0.2" + pluralize "^8.0.0" + read-pkg-up "^7.0.1" + regexp-tree "^0.1.27" + regjsparser "^0.10.0" + semver "^7.5.4" + strip-indent "^3.0.0" -eslint-scope@^7.1.1: - version "7.1.1" - resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.1.1.tgz#fff34894c2f65e5226d3041ac480b4513a163642" - integrity sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw== +eslint-scope@^7.2.2: + version "7.2.2" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.2.2.tgz#deb4f92563390f32006894af62a22dba1c46423f" + integrity sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg== dependencies: esrecurse "^4.3.0" estraverse "^5.2.0" -eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.0: - version "3.4.0" - resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.0.tgz#c7f0f956124ce677047ddbc192a68f999454dedc" - integrity sha512-HPpKPUBQcAsZOsHAFwTtIKcYlCje62XB7SEAcxjtmW6TD1WVpkS6i6/hOVtTZIl4zGj/mBqpFVGvaDneik+VoQ== +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1, eslint-visitor-keys@^3.4.3: + version "3.4.3" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800" + integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== -eslint@^8.32.0, eslint@^8.37.0: - version "8.37.0" - resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.37.0.tgz#1f660ef2ce49a0bfdec0b0d698e0b8b627287412" - integrity sha512-NU3Ps9nI05GUoVMxcZx1J8CNR6xOvUT4jAUMH5+z8lpp3aEdPVCImKw6PWG4PY+Vfkpr+jvMpxs/qoE7wq0sPw== +eslint@^8.53.0: + version "8.54.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.54.0.tgz#588e0dd4388af91a2e8fa37ea64924074c783537" + integrity sha512-NY0DfAkM8BIZDVl6PgSa1ttZbx3xHgJzSNJKYcQglem6CppHyMhRIQkBVSSMaSRnLhig3jsDbEzOjwCVt4AmmA== dependencies: "@eslint-community/eslint-utils" "^4.2.0" - "@eslint-community/regexpp" "^4.4.0" - "@eslint/eslintrc" "^2.0.2" - "@eslint/js" "8.37.0" - "@humanwhocodes/config-array" "^0.11.8" + "@eslint-community/regexpp" "^4.6.1" + "@eslint/eslintrc" "^2.1.3" + "@eslint/js" "8.54.0" + "@humanwhocodes/config-array" "^0.11.13" "@humanwhocodes/module-importer" "^1.0.1" "@nodelib/fs.walk" "^1.2.8" - ajv "^6.10.0" + "@ungap/structured-clone" "^1.2.0" + ajv "^6.12.4" chalk "^4.0.0" cross-spawn "^7.0.2" debug "^4.3.2" doctrine "^3.0.0" escape-string-regexp "^4.0.0" - eslint-scope "^7.1.1" - eslint-visitor-keys "^3.4.0" - espree "^9.5.1" + eslint-scope "^7.2.2" + eslint-visitor-keys "^3.4.3" + espree "^9.6.1" esquery "^1.4.2" esutils "^2.0.2" fast-deep-equal "^3.1.3" @@ -2517,39 +1994,36 @@ eslint@^8.32.0, eslint@^8.37.0: find-up "^5.0.0" glob-parent "^6.0.2" globals "^13.19.0" - grapheme-splitter "^1.0.4" + graphemer "^1.4.0" ignore "^5.2.0" - import-fresh "^3.0.0" imurmurhash "^0.1.4" is-glob "^4.0.0" is-path-inside "^3.0.3" - js-sdsl "^4.1.4" js-yaml "^4.1.0" json-stable-stringify-without-jsonify "^1.0.1" levn "^0.4.1" lodash.merge "^4.6.2" minimatch "^3.1.2" natural-compare "^1.4.0" - optionator "^0.9.1" + optionator "^0.9.3" strip-ansi "^6.0.1" - strip-json-comments "^3.1.0" text-table "^0.2.0" -espree@^9.5.1: - version "9.5.1" - resolved "https://registry.yarnpkg.com/espree/-/espree-9.5.1.tgz#4f26a4d5f18905bf4f2e0bd99002aab807e96dd4" - integrity sha512-5yxtHSZXRSW5pvv3hAlXM5+/Oswi1AUFqBmbibKb5s6bp3rGIDkyXU6xCoyuuLhijr4SFwPrXRoZjz0AZDN9tg== +espree@^9.6.0, espree@^9.6.1: + version "9.6.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.6.1.tgz#a2a17b8e434690a5432f2f8018ce71d331a48c6f" + integrity sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ== dependencies: - acorn "^8.8.0" + acorn "^8.9.0" acorn-jsx "^5.3.2" - eslint-visitor-keys "^3.4.0" + eslint-visitor-keys "^3.4.1" -esprima@^4.0.0, esprima@~4.0.0: +esprima@^4.0.0: version "4.0.1" resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== -esquery@^1.4.0, esquery@^1.4.2: +esquery@^1.4.2, esquery@^1.5.0: version "1.5.0" resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== @@ -2563,11 +2037,6 @@ esrecurse@^4.3.0: dependencies: estraverse "^5.2.0" -estraverse@^4.1.1: - version "4.3.0" - resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" - integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== - estraverse@^5.1.0, estraverse@^5.2.0: version "5.3.0" resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" @@ -2583,18 +2052,10 @@ event-target-shim@^5.0.0: resolved "https://registry.yarnpkg.com/event-target-shim/-/event-target-shim-5.0.1.tgz#5d4d3ebdf9583d63a5333ce2deb7480ab2b05789" integrity sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ== -execa@^0.10.0: - version "0.10.0" - resolved "https://registry.yarnpkg.com/execa/-/execa-0.10.0.tgz#ff456a8f53f90f8eccc71a96d11bdfc7f082cb50" - integrity sha512-7XOMnz8Ynx1gGo/3hyV9loYNPWM94jG3+3T3Y8tsfSstFmETmENCMU/A/zj8Lyaj1lkgEepKepvd6240tBRvlw== - dependencies: - cross-spawn "^6.0.0" - get-stream "^3.0.0" - is-stream "^1.1.0" - npm-run-path "^2.0.0" - p-finally "^1.0.0" - signal-exit "^3.0.0" - strip-eof "^1.0.0" +events@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" + integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== execa@^4.0.0: version "4.1.0" @@ -2626,42 +2087,7 @@ execa@^5.0.0: signal-exit "^3.0.3" strip-final-newline "^2.0.0" -expand-brackets@^2.1.4: - version "2.1.4" - resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz#b77735e315ce30f6b6eff0f83b04151a22449622" - integrity sha512-w/ozOKR9Obk3qoWeY/WDi6MFta9AoMR+zud60mdnbniMcBxRuFJyDt2LdX/14A1UABeqk+Uk+LDfUpvoGKppZA== - dependencies: - debug "^2.3.3" - define-property "^0.2.5" - extend-shallow "^2.0.1" - posix-character-classes "^0.1.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - -expand-tilde@^2.0.0, expand-tilde@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/expand-tilde/-/expand-tilde-2.0.2.tgz#97e801aa052df02454de46b02bf621642cdc8502" - integrity sha512-A5EmesHW6rfnZ9ysHQjPdJRni0SRar0tjtG5MNtm9n5TUvsYU8oozprtRD4AqHxcZWWlVuAmQo2nWKfN9oyjTw== - dependencies: - homedir-polyfill "^1.0.1" - -extend-shallow@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f" - integrity sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug== - dependencies: - is-extendable "^0.1.0" - -extend-shallow@^3.0.0, extend-shallow@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8" - integrity sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q== - dependencies: - assign-symbols "^1.0.0" - is-extendable "^1.0.1" - -external-editor@^3.0.0, external-editor@^3.0.3: +external-editor@^3.0.3: version "3.1.0" resolved "https://registry.yarnpkg.com/external-editor/-/external-editor-3.1.0.tgz#cb03f740befae03ea4d283caed2741a83f335495" integrity sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew== @@ -2670,31 +2096,17 @@ external-editor@^3.0.0, external-editor@^3.0.3: iconv-lite "^0.4.24" tmp "^0.0.33" -extglob@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543" - integrity sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw== - dependencies: - array-unique "^0.3.2" - define-property "^1.0.0" - expand-brackets "^2.1.4" - extend-shallow "^2.0.1" - fragment-cache "^0.2.1" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - -extract-stack@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/extract-stack/-/extract-stack-2.0.0.tgz#11367bc865bfcd9bc0db3123e5edb57786f11f9b" - integrity sha512-AEo4zm+TenK7zQorGK1f9mJ8L14hnTDi2ZQPR+Mub1NX8zimka1mXpV5LpH8x9HoUmFSHZCfLHqWvp0Y4FxxzQ== +fast-copy@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/fast-copy/-/fast-copy-3.0.1.tgz#9e89ef498b8c04c1cd76b33b8e14271658a732aa" + integrity sha512-Knr7NOtK3HWRYGtHoJrjkaWepqT8thIVGAwt0p0aUs1zqkAzXZV4vo9fFNwyb5fcqK1GKYFYxldQdIDVKhUAfA== fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.0.3, fast-glob@^3.2.11, fast-glob@^3.2.9: +fast-glob@^3.2.11, fast-glob@^3.2.9: version "3.2.12" resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.12.tgz#7f39ec99c2e6ab030337142da9e0c18f37afae80" integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w== @@ -2715,6 +2127,16 @@ fast-levenshtein@^2.0.6: resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== +fast-redact@^3.1.1: + version "3.2.0" + resolved "https://registry.yarnpkg.com/fast-redact/-/fast-redact-3.2.0.tgz#b1e2d39bc731376d28bde844454fa23e26919987" + integrity sha512-zaTadChr+NekyzallAMXATXLOR8MNx3zqpZ0MUF2aGf4EathnG0f32VLODNlY8IuGY3HoRO2L6/6fSzNsLaHIw== + +fast-safe-stringify@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz#c406a83b6e70d9e35ce3b30a81141df30aeba884" + integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== + fastq@^1.6.0: version "1.13.0" resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.13.0.tgz#616760f88a7526bdfc596b7cab8c18938c36b98c" @@ -2741,13 +2163,6 @@ faye@^1.4.0: tough-cookie "*" tunnel-agent "*" -figures@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz#3ab1a2d2a62c8bfb431a0c94cb797a2fce27c962" - integrity sha512-Oa2M9atig69ZkfwiApY8F2Yy+tzMbazyvqv21R0NsSC8floSOC09BbT1ITWAdoMGQvJ/aZnR1KMwdx9tvHnTNA== - dependencies: - escape-string-regexp "^1.0.5" - figures@^3.0.0: version "3.2.0" resolved "https://registry.yarnpkg.com/figures/-/figures-3.2.0.tgz#625c18bd293c604dc4a8ddb2febf0c88341746af" @@ -2762,16 +2177,6 @@ file-entry-cache@^6.0.1: dependencies: flat-cache "^3.0.4" -fill-range@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7" - integrity sha512-VcpLTWqWDiTerugjj8e3+esbg+skS3M9e54UuR3iCeIDMXCLTsAH8hTSzDQU/X6/6t3eYkOKoZSef2PlU6U1XQ== - dependencies: - extend-shallow "^2.0.1" - is-number "^3.0.0" - repeat-string "^1.6.1" - to-regex-range "^2.1.0" - fill-range@^7.0.1: version "7.0.1" resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" @@ -2788,19 +2193,6 @@ find-cache-dir@^3.2.0: make-dir "^3.0.2" pkg-dir "^4.1.0" -find-node-modules@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/find-node-modules/-/find-node-modules-2.0.0.tgz#5db1fb9e668a3d451db3d618cd167cdd59e41b69" - integrity sha512-8MWIBRgJi/WpjjfVXumjPKCtmQ10B+fjx6zmSA+770GMJirLhWIzg8l763rhjl9xaeaHbnxPNRQKq2mgMhr+aw== - dependencies: - findup-sync "^3.0.0" - merge "^1.2.1" - -find-root@1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/find-root/-/find-root-1.1.0.tgz#abcfc8ba76f708c42a97b3d685b7e9450bfb9ce4" - integrity sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng== - find-up@5.0.0, find-up@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" @@ -2817,23 +2209,6 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" -find-yarn-workspace-root@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz#f47fb8d239c900eb78179aa81b66673eac88f7bd" - integrity sha512-1IMnbjt4KzsQfnhnzNd8wUEgXZ44IzZaZmnLYx7D5FZlaHt2gW20Cri8Q+E/t5tIj4+epTBub+2Zxu/vNILzqQ== - dependencies: - micromatch "^4.0.2" - -findup-sync@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/findup-sync/-/findup-sync-3.0.0.tgz#17b108f9ee512dfb7a5c7f3c8b27ea9e1a9c08d1" - integrity sha512-YbffarhcicEhOrm4CtrwdKBdCuz576RLdhJDsIfvNtxUuhdRet1qZcsMjqbePtAseKdAnDyM/IyXbu7PRPRLYg== - dependencies: - detect-file "^1.0.0" - is-glob "^4.0.0" - micromatch "^3.0.4" - resolve-dir "^1.0.1" - flat-cache@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" @@ -2859,11 +2234,6 @@ for-each@^0.3.3: dependencies: is-callable "^1.1.3" -for-in@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" - integrity sha512-7EwmXrOjyL+ChxMhmG5lnW9MPt1aIeZEwKhQzoBUdTV0N3zuwWDZYVJatDvZ2OyzPUvdIAZDsCetk3coyMfcnQ== - foreground-child@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/foreground-child/-/foreground-child-2.0.0.tgz#71b32800c9f15aa8f2f83f4a6bd9bff35d861a53" @@ -2881,23 +2251,11 @@ form-data@^4.0.0: combined-stream "^1.0.8" mime-types "^2.1.12" -fragment-cache@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" - integrity sha512-GMBAbW9antB8iZRHLoGw0b3HANt57diZYFO/HL1JGIC1MjKrdmhxvrJbupnVvpys0zsz7yBApXdQyfepKly2kA== - dependencies: - map-cache "^0.2.2" - fromentries@^1.2.0: version "1.3.2" resolved "https://registry.yarnpkg.com/fromentries/-/fromentries-1.3.2.tgz#e4bca6808816bf8f93b52750f1127f5a6fd86e3a" integrity sha512-cHEpEQHUg0f8XdtZCc2ZAhrHzKzT0MrFUTcvx+hfxYu7rGMDc5SKoXFh+n4YigxsHXRzc6OrCshdR1bWH6HHyg== -fs-constants@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/fs-constants/-/fs-constants-1.0.0.tgz#6be0de9be998ce16af8afc24497b9ee9b7ccd9ad" - integrity sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow== - fs-extra@^11.0.0: version "11.1.0" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-11.1.0.tgz#5784b102104433bb0e090f48bfc4a30742c357ed" @@ -2907,25 +2265,7 @@ fs-extra@^11.0.0: jsonfile "^6.0.1" universalify "^2.0.0" -fs-extra@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-6.0.1.tgz#8abc128f7946e310135ddc93b98bddb410e7a34b" - integrity sha512-GnyIkKhhzXZUWFCaJzvyDLEEgDkPfb4/TPvJCJVuS8MWZgoSsErf++QpiAlDnKFcqhRlm+tIOcencCjyJE6ZCA== - dependencies: - graceful-fs "^4.1.2" - jsonfile "^4.0.0" - universalify "^0.1.0" - -fs-extra@^7.0.0: - version "7.0.1" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-7.0.1.tgz#4f189c44aa123b895f722804f55ea23eadc348e9" - integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== - dependencies: - graceful-fs "^4.1.2" - jsonfile "^4.0.0" - universalify "^0.1.0" - -fs-extra@^8.1, fs-extra@^8.1.0: +fs-extra@^8.1.0: version "8.1.0" resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== @@ -2944,22 +2284,22 @@ fsevents@~2.3.2: resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== -function-bind@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" - integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== +function-bind@^1.1.1, function-bind@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" + integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== -function.prototype.name@^1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" - integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== +function.prototype.name@^1.1.6: + version "1.1.6" + resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.6.tgz#cdf315b7d90ee77a4c6ee216c3c3362da07533fd" + integrity sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg== dependencies: call-bind "^1.0.2" - define-properties "^1.1.3" - es-abstract "^1.19.0" - functions-have-names "^1.2.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" + functions-have-names "^1.2.3" -functions-have-names@^1.2.2: +functions-have-names@^1.2.3: version "1.2.3" resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== @@ -2974,31 +2314,27 @@ get-caller-file@^2.0.1, get-caller-file@^2.0.5: resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== -get-func-name@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.0.tgz#ead774abee72e20409433a066366023dd6887a41" - integrity sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig== +get-func-name@^2.0.0, get-func-name@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/get-func-name/-/get-func-name-2.0.2.tgz#0d7cf20cd13fda808669ffa88f4ffc7a3943fc41" + integrity sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ== -get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.0.tgz#7ad1dc0535f3a2904bba075772763e5051f6d05f" - integrity sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q== +get-intrinsic@^1.0.2, get-intrinsic@^1.1.1, get-intrinsic@^1.1.3, get-intrinsic@^1.2.0, get-intrinsic@^1.2.1, get-intrinsic@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.2.2.tgz#281b7622971123e1ef4b3c90fd7539306da93f3b" + integrity sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA== dependencies: - function-bind "^1.1.1" - has "^1.0.3" + function-bind "^1.1.2" + has-proto "^1.0.1" has-symbols "^1.0.3" + hasown "^2.0.0" get-package-type@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== -get-stream@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14" - integrity sha512-GlhdIUuVakc8SJ6kK0zAFbiGzRFzNnY4jUuEbV9UROo4Y+0Ny4fjvcZFVTeDA4odpFyOQzaw6hXukJSq/f28sQ== - -get-stream@^5.0.0, get-stream@^5.1.0: +get-stream@^5.0.0: version "5.2.0" resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== @@ -3018,11 +2354,6 @@ get-symbol-description@^1.0.0: call-bind "^1.0.2" get-intrinsic "^1.1.1" -get-value@^2.0.3, get-value@^2.0.6: - version "2.0.6" - resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" - integrity sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA== - git-raw-commits@^2.0.0: version "2.0.11" resolved "https://registry.yarnpkg.com/git-raw-commits/-/git-raw-commits-2.0.11.tgz#bc3576638071d18655e1cc60d7f524920008d723" @@ -3034,11 +2365,6 @@ git-raw-commits@^2.0.0: split2 "^3.0.0" through2 "^4.0.0" -github-slugger@^1.2.1: - version "1.4.0" - resolved "https://registry.yarnpkg.com/github-slugger/-/github-slugger-1.4.0.tgz#206eb96cdb22ee56fdc53a28d5a302338463444e" - integrity sha512-w0dzqw/nt51xMVmlaV1+JRzN+oCa1KfcgGEWhxUG16wbdA+Xnt/yoFO8Z8x/V82ZcZ0wy6ln9QDup5avbhiDhQ== - glob-parent@^5.1.2, glob-parent@~5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" @@ -3053,18 +2379,6 @@ glob-parent@^6.0.2: dependencies: is-glob "^4.0.3" -glob@7.1.3: - version "7.1.3" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.3.tgz#3960832d3f1574108342dafd3a67b332c0969df1" - integrity sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^3.0.4" - once "^1.3.0" - path-is-absolute "^1.0.0" - glob@7.2.0: version "7.2.0" resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" @@ -3077,18 +2391,7 @@ glob@7.2.0: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^6.0.1: - version "6.0.4" - resolved "https://registry.yarnpkg.com/glob/-/glob-6.0.4.tgz#0f08860f6a155127b2fadd4f9ce24b1aab6e4d22" - integrity sha512-MKZeRNyYZAVVVG1oZeLaWie1uweH40m9AZwIwxyPbTSX4hHrVYSzLg0Ro5Z5R7XKkIX+Cc6oD1rqeDJnwsB8/A== - dependencies: - inflight "^1.0.4" - inherits "2" - minimatch "2 || 3" - once "^1.3.0" - path-is-absolute "^1.0.0" - -glob@^7.0.0, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: +glob@^7.0.0, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: version "7.2.3" resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== @@ -3107,25 +2410,14 @@ global-dirs@^0.1.1: dependencies: ini "^1.3.4" -global-modules@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/global-modules/-/global-modules-1.0.0.tgz#6d770f0eb523ac78164d72b5e71a8877265cc3ea" - integrity sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg== - dependencies: - global-prefix "^1.0.1" - is-windows "^1.0.1" - resolve-dir "^1.0.0" - -global-prefix@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/global-prefix/-/global-prefix-1.0.2.tgz#dbf743c6c14992593c655568cb66ed32c0122ebe" - integrity sha512-5lsx1NUDHtSjfg0eHlmYvZKv8/nVqX4ckFbM+FrGcQ+04KWcWFo9P5MxPZYSzUvyzmdTbI7Eix8Q4IbELDqzKg== +global-prefix@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/global-prefix/-/global-prefix-3.0.0.tgz#fc85f73064df69f50421f47f883fe5b913ba9b97" + integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== dependencies: - expand-tilde "^2.0.2" - homedir-polyfill "^1.0.1" - ini "^1.3.4" - is-windows "^1.0.1" - which "^1.2.14" + ini "^1.3.5" + kind-of "^6.0.2" + which "^1.3.1" globals@^11.1.0: version "11.12.0" @@ -3146,21 +2438,7 @@ globalthis@^1.0.3: dependencies: define-properties "^1.1.3" -globby@^10.0.1: - version "10.0.2" - resolved "https://registry.yarnpkg.com/globby/-/globby-10.0.2.tgz#277593e745acaa4646c3ab411289ec47a0392543" - integrity sha512-7dUi7RvCoT/xast/o/dLN53oqND4yk0nsHkhRgn9w65C4PofCLOoJ39iSOg+qVDdWQPIEj+eszMHQ+aLVwwQSg== - dependencies: - "@types/glob" "^7.1.1" - array-union "^2.1.0" - dir-glob "^3.0.1" - fast-glob "^3.0.3" - glob "^7.1.3" - ignore "^5.1.1" - merge2 "^1.2.3" - slash "^3.0.0" - -globby@^11.0.1, globby@^11.1.0: +globby@^11.1.0: version "11.1.0" resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== @@ -3179,20 +2457,15 @@ gopd@^1.0.1: dependencies: get-intrinsic "^1.1.3" -graceful-fs@^4.1.15, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.11, graceful-fs@^4.2.4: +graceful-fs@^4.1.15, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4: version "4.2.11" resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== -grapheme-splitter@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz#9cf3a665c6247479896834af35cf1dbb4400767e" - integrity sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ== - -growl@1.10.5: - version "1.10.5" - resolved "https://registry.yarnpkg.com/growl/-/growl-1.10.5.tgz#f2735dc2283674fa67478b10181059355c369e5e" - integrity sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA== +graphemer@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" + integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== hard-rejection@^2.1.0: version "2.1.0" @@ -3238,37 +2511,6 @@ has-tostringtag@^1.0.0: dependencies: has-symbols "^1.0.2" -has-value@^0.3.1: - version "0.3.1" - resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" - integrity sha512-gpG936j8/MzaeID5Yif+577c17TxaDmhuyVgSwtnL/q8UUTySg8Mecb+8Cf1otgLoD7DDH75axp86ER7LFsf3Q== - dependencies: - get-value "^2.0.3" - has-values "^0.1.4" - isobject "^2.0.0" - -has-value@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz#18b281da585b1c5c51def24c930ed29a0be6b177" - integrity sha512-IBXk4GTsLYdQ7Rvt+GRBrFSVEkmuOUy4re0Xjd9kJSUQpnTrWR4/y9RpfexN9vkAPMFuQoeWKwqzPozRTlasGw== - dependencies: - get-value "^2.0.6" - has-values "^1.0.0" - isobject "^3.0.0" - -has-values@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz#6d61de95d91dfca9b9a02089ad384bff8f62b771" - integrity sha512-J8S0cEdWuQbqD9//tlZxiMuMNmxB8PlEwvYwuxsTmR1G5RXUePEX/SJn7aD0GMLieuZYSwNH0cQuJGwnYunXRQ== - -has-values@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz#95b0b63fec2146619a6fe57fe75628d5a39efe4f" - integrity sha512-ODYZC64uqzmtfGMEAX/FvZiRyWLpAC3vYnNunURUnkGVTS+mI0smVsWaPydRBsE3g+ok7h960jChO8mFcWlHaQ== - dependencies: - is-number "^3.0.0" - kind-of "^4.0.0" - has@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" @@ -3284,6 +2526,13 @@ hasha@^5.0.0: is-stream "^2.0.0" type-fest "^0.8.0" +hasown@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/hasown/-/hasown-2.0.0.tgz#f4c513d454a57b7c7e1650778de226b11700546c" + integrity sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA== + dependencies: + function-bind "^1.1.2" + he@1.2.0: version "1.2.0" resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" @@ -3297,12 +2546,10 @@ header-case@^2.0.4: capital-case "^1.0.4" tslib "^2.0.3" -homedir-polyfill@^1.0.1: - version "1.0.3" - resolved "https://registry.yarnpkg.com/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz#743298cef4e5af3e194161fbadcc2151d3a058e8" - integrity sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA== - dependencies: - parse-passwd "^1.0.0" +help-me@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/help-me/-/help-me-5.0.0.tgz#b1ebe63b967b74060027c2ac61f9be12d354a6f6" + integrity sha512-7xgomUX6ADmcYzFik0HzAxh/73YlKR9bmFzf51CZwR+b6YtzU2m0u49hQCqV6SvlqIqsaxovfwdvbnsw3b/zpg== hosted-git-info@^2.1.4: version "2.8.9" @@ -3321,18 +2568,6 @@ html-escaper@^2.0.0: resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== -http-call@^5.1.2: - version "5.3.0" - resolved "https://registry.yarnpkg.com/http-call/-/http-call-5.3.0.tgz#4ded815b13f423de176eb0942d69c43b25b148db" - integrity sha512-ahwimsC23ICE4kPl9xTBjKB4inbRaeLyZeRunC/1Jy/Z6X8tv22MEAjK+KBOMSVLaqXPTTmd8638waVIKLGx2w== - dependencies: - content-type "^1.0.4" - debug "^4.1.1" - is-retry-allowed "^1.1.0" - is-stream "^2.0.0" - parse-json "^4.0.0" - tunnel-agent "^0.6.0" - http-parser-js@>=0.5.1: version "0.5.8" resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.8.tgz#af23090d9ac4e24573de6f6aecc9d84a48bf20e3" @@ -3361,11 +2596,6 @@ husky@^7.0.4: resolved "https://registry.yarnpkg.com/husky/-/husky-7.0.4.tgz#242048245dc49c8fb1bf0cc7cfb98dd722531535" integrity sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ== -hyperlinker@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/hyperlinker/-/hyperlinker-1.0.0.tgz#23dc9e38a206b208ee49bc2d6c8ef47027df0c0e" - integrity sha512-Ty8UblRWFEcfSuIaajM34LdPXIhbs1ajEX/BBPv24J+enSVaEVY63xQ6lTO9VRYS5LAoghIG0IDJ+p+IPzKUQQ== - iconv-lite@^0.4.24: version "0.4.24" resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" @@ -3373,15 +2603,20 @@ iconv-lite@^0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" -ieee754@^1.1.13: +ieee754@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== -ignore@^5.1.1, ignore@^5.1.4, ignore@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.0.tgz#6d3bac8fa7fe0d45d9f9be7bac2fc279577e345a" - integrity sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ== +ignore@^5.1.4, ignore@^5.2.0, ignore@^5.2.4: + version "5.2.4" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.4.tgz#a291c0c6178ff1b960befe47fcdec301674a6324" + integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ== + +immediate@~3.0.5: + version "3.0.6" + resolved "https://registry.yarnpkg.com/immediate/-/immediate-3.0.6.tgz#9db1dbd0faf8de6fbe0f5dd5e56bb606280de69b" + integrity sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ== import-fresh@^3.0.0, import-fresh@^3.2.1: version "3.3.0" @@ -3409,35 +2644,16 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@2, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.3: +inherits@2, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.3: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== -ini@^1.3.4: +ini@^1.3.4, ini@^1.3.5: version "1.3.8" resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== -inquirer@6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-6.2.0.tgz#51adcd776f661369dc1e894859c2560a224abdd8" - integrity sha512-QIEQG4YyQ2UYZGDC4srMZ7BjHOmNk1lR2JQj5UknBapklm6WHA+VVH7N+sUdX3A7NeCfGF8o4X1S3Ao7nAcIeg== - dependencies: - ansi-escapes "^3.0.0" - chalk "^2.0.0" - cli-cursor "^2.1.0" - cli-width "^2.0.0" - external-editor "^3.0.0" - figures "^2.0.0" - lodash "^4.17.10" - mute-stream "0.0.7" - run-async "^2.2.0" - rxjs "^6.1.0" - string-width "^2.1.0" - strip-ansi "^4.0.0" - through "^2.3.6" - inquirer@^7.0.0: version "7.3.3" resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-7.3.3.tgz#04d176b2af04afc157a83fd7c100e98ee0aad003" @@ -3457,7 +2673,7 @@ inquirer@^7.0.0: strip-ansi "^6.0.0" through "^2.3.6" -internal-slot@^1.0.4: +internal-slot@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.5.tgz#f2a2ee21f668f8627a4667f309dc0f4fb6674986" integrity sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ== @@ -3471,21 +2687,7 @@ interpret@^1.0.0: resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.4.0.tgz#665ab8bc4da27a774a40584e812e3e0fa45b1a1e" integrity sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA== -is-accessor-descriptor@^0.1.6: - version "0.1.6" - resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz#a9e12cb3ae8d876727eeef3843f8a0897b5c98d6" - integrity sha512-e1BM1qnDbMRG3ll2U9dSK0UMHuWOs3pY3AtcFsmvwPtKL3MML/Q86i+GilLfvqEs4GW+ExB91tQ3Ig9noDIZ+A== - dependencies: - kind-of "^3.0.2" - -is-accessor-descriptor@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz#169c2f6d3df1f992618072365c9b0ea1f6878656" - integrity sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ== - dependencies: - kind-of "^6.0.0" - -is-array-buffer@^3.0.1: +is-array-buffer@^3.0.1, is-array-buffer@^3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/is-array-buffer/-/is-array-buffer-3.0.2.tgz#f2653ced8412081638ecb0ebbd0c41c6e0aecbbe" integrity sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w== @@ -3521,36 +2723,24 @@ is-boolean-object@^1.1.0: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-buffer@^1.1.5: - version "1.1.6" - resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" - integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w== +is-builtin-module@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-3.2.1.tgz#f03271717d8654cfcaf07ab0463faa3571581169" + integrity sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A== + dependencies: + builtin-modules "^3.3.0" is-callable@^1.1.3, is-callable@^1.1.4, is-callable@^1.2.7: version "1.2.7" resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.7.tgz#3bc2a85ea742d9e36205dcacdd72ca1fdc51b055" integrity sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA== -is-core-module@^2.11.0, is-core-module@^2.5.0, is-core-module@^2.8.1, is-core-module@^2.9.0: - version "2.11.0" - resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.11.0.tgz#ad4cb3e3863e814523c96f3f58d26cc570ff0144" - integrity sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw== - dependencies: - has "^1.0.3" - -is-data-descriptor@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56" - integrity sha512-+w9D5ulSoBNlmw9OHn3U2v51SyoCd0he+bB3xMl62oijhrspxowjU+AIcDY0N3iEJbUEkB15IlMASQsxYigvXg== - dependencies: - kind-of "^3.0.2" - -is-data-descriptor@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz#d84876321d0e7add03990406abbbbd36ba9268c7" - integrity sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ== +is-core-module@^2.13.0, is-core-module@^2.13.1, is-core-module@^2.5.0: + version "2.13.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" + integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== dependencies: - kind-of "^6.0.0" + hasown "^2.0.0" is-date-object@^1.0.1: version "1.0.5" @@ -3559,51 +2749,16 @@ is-date-object@^1.0.1: dependencies: has-tostringtag "^1.0.0" -is-descriptor@^0.1.0: - version "0.1.6" - resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz#366d8240dde487ca51823b1ab9f07a10a78251ca" - integrity sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg== - dependencies: - is-accessor-descriptor "^0.1.6" - is-data-descriptor "^0.1.4" - kind-of "^5.0.0" - -is-descriptor@^1.0.0, is-descriptor@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz#3b159746a66604b04f8c81524ba365c5f14d86ec" - integrity sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg== - dependencies: - is-accessor-descriptor "^1.0.0" - is-data-descriptor "^1.0.0" - kind-of "^6.0.2" - is-docker@^2.0.0: version "2.2.1" resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa" integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== -is-extendable@^0.1.0, is-extendable@^0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" - integrity sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw== - -is-extendable@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4" - integrity sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA== - dependencies: - is-plain-object "^2.0.4" - is-extglob@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== -is-fullwidth-code-point@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" - integrity sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w== - is-fullwidth-code-point@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" @@ -3628,13 +2783,6 @@ is-number-object@^1.0.4: dependencies: has-tostringtag "^1.0.0" -is-number@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" - integrity sha512-4cboCqIpliH+mAvFNegjZQ4kgKc3ZUhQVr3HvWbSh5q3WH2v82ct+T2Y1hdU5Gdtorx/cLifQjqCbL7bpznLTg== - dependencies: - kind-of "^3.0.2" - is-number@^7.0.0: version "7.0.0" resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" @@ -3655,18 +2803,11 @@ is-plain-obj@^1.1.0: resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e" integrity sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg== -is-plain-obj@^2.0.0, is-plain-obj@^2.1.0: +is-plain-obj@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-2.1.0.tgz#45e42e37fccf1f40da8e5f76ee21515840c09287" integrity sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA== -is-plain-object@^2.0.3, is-plain-object@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" - integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== - dependencies: - isobject "^3.0.1" - is-regex@^1.1.4: version "1.1.4" resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" @@ -3675,11 +2816,6 @@ is-regex@^1.1.4: call-bind "^1.0.2" has-tostringtag "^1.0.0" -is-retry-allowed@^1.1.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz#d778488bd0a4666a3be8a1482b9f2baafedea8b4" - integrity sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg== - is-shared-array-buffer@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" @@ -3687,11 +2823,6 @@ is-shared-array-buffer@^1.0.2: dependencies: call-bind "^1.0.2" -is-stream@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" - integrity sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ== - is-stream@^2.0.0: version "2.0.1" resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" @@ -3718,16 +2849,12 @@ is-text-path@^1.0.1: dependencies: text-extensions "^1.0.0" -is-typed-array@^1.1.10, is-typed-array@^1.1.9: - version "1.1.10" - resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.10.tgz#36a5b5cb4189b575d1a3e4b08536bfb485801e3f" - integrity sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A== +is-typed-array@^1.1.10, is-typed-array@^1.1.12, is-typed-array@^1.1.9: + version "1.1.12" + resolved "https://registry.yarnpkg.com/is-typed-array/-/is-typed-array-1.1.12.tgz#d0bab5686ef4a76f7a73097b95470ab199c57d4a" + integrity sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg== dependencies: - available-typed-arrays "^1.0.5" - call-bind "^1.0.2" - for-each "^0.3.3" - gopd "^1.0.1" - has-tostringtag "^1.0.0" + which-typed-array "^1.1.11" is-typedarray@^1.0.0: version "1.0.0" @@ -3739,11 +2866,6 @@ is-unicode-supported@^0.1.0: resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== -is-utf8@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/is-utf8/-/is-utf8-0.2.1.tgz#4b0da1442104d1b336340e80797e865cf39f7d72" - integrity sha512-rMYPYvCzsXywIsldgLaSoPlw5PfoB/ssr7hY4pLfcodrA5M/eArza1a9VmTiNIBNMjOGr1Ow9mTyU2o69U6U9Q== - is-weakref@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" @@ -3751,12 +2873,12 @@ is-weakref@^1.0.2: dependencies: call-bind "^1.0.2" -is-windows@^1.0.1, is-windows@^1.0.2: +is-windows@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz#d1850eb9791ecd18e6182ce12a30f396634bb19d" integrity sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA== -is-wsl@^2.1.1, is-wsl@^2.2.0: +is-wsl@^2.1.1: version "2.2.0" resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== @@ -3768,7 +2890,12 @@ isarray@0.0.1: resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== -isarray@1.0.0, isarray@~1.0.0: +isarray@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/isarray/-/isarray-2.0.5.tgz#8af1e4c1221244cc62459faf38940d4e644a5723" + integrity sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw== + +isarray@~1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== @@ -3778,18 +2905,6 @@ isexe@^2.0.0: resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== -isobject@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" - integrity sha512-+OUdGJlgjOBZDfxnDjYYG6zp487z0JGNQq3cYQYg5f5hKR+syHMsaztzGeml/4kGG55CSpKSpWTY+jYGgsHLgA== - dependencies: - isarray "1.0.0" - -isobject@^3.0.0, isobject@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" - integrity sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg== - istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: version "3.2.0" resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz#189e7909d0a39fa5a3dfad5b03f71947770191d3" @@ -3850,10 +2965,10 @@ istanbul-reports@^3.0.2: html-escaper "^2.0.0" istanbul-lib-report "^3.0.0" -js-sdsl@^4.1.4: - version "4.1.5" - resolved "https://registry.yarnpkg.com/js-sdsl/-/js-sdsl-4.1.5.tgz#1ff1645e6b4d1b028cd3f862db88c9d887f26e2a" - integrity sha512-08bOAKweV2NUC1wqTtf3qZlnpOX/R2DU9ikpjOHs0H+ibQv3zpncVQg6um4uYtRtrwIX8M4Nh3ytK4HGlYAq7Q== +joycon@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/joycon/-/joycon-3.1.1.tgz#bce8596d6ae808f8b68168f5fc69280996894f03" + integrity sha512-34wB/Y7MW7bzjKRjUKTa46I2Z7eV62Rkhva+KkopW7Qvv/OSWBqvkSY7vusOPrNuZcUG3tApvdVgNB8POj3SPw== js-tokens@^4.0.0: version "4.0.0" @@ -3882,30 +2997,30 @@ js2xmlparser@^4.0.1: dependencies: xmlcreate "^2.0.4" -jsdoc-type-pratt-parser@1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-1.0.4.tgz#5750d2d32ffb001866537d3baaedea7cf84c7036" - integrity sha512-jzmW9gokeq9+bHPDR1nCeidMyFUikdZlbOhKzh9+/nJqB75XhpNKec1/UuxW5c4+O+Pi31Gc/dCboyfSm/pSpQ== - -jsdoc-type-pratt-parser@^1.0.4: - version "1.2.0" - resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-1.2.0.tgz#3482a3833b74a88c95a6ba7253f0c0de3b77b9f5" - integrity sha512-4STjeF14jp4bqha44nKMY1OUI6d2/g6uclHWUCZ7B4DoLzaB5bmpTkQrpqU+vSVzMD0LsKAOskcnI3I3VfIpmg== - -jsdoc-type-pratt-parser@~3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-3.1.0.tgz#a4a56bdc6e82e5865ffd9febc5b1a227ff28e67e" - integrity sha512-MgtD0ZiCDk9B+eI73BextfRrVQl0oyzRG8B2BjORts6jbunj4ScKPcyXGTbB6eXL4y9TzxCm6hyeLq/2ASzNdw== +jsdoc-type-pratt-parser@~4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-4.0.0.tgz#136f0571a99c184d84ec84662c45c29ceff71114" + integrity sha512-YtOli5Cmzy3q4dP26GraSOeAhqecewG04hoO8DY56CH4KJ9Fvv5qKWUCCo3HZob7esJQHCv6/+bnTy72xZZaVQ== jsesc@^2.5.1: version "2.5.2" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== -jsforce@^2.0.0-beta.20: - version "2.0.0-beta.20" - resolved "https://registry.yarnpkg.com/jsforce/-/jsforce-2.0.0-beta.20.tgz#907630942b2ecd653098caa3f87e7710874cb207" - integrity sha512-5TpdU0MEUN34M0mSKmBwOMKaI8dllTYF8NzpJn0/9akrwqKEERK6K2jGiMWcs85Vx1HCHEcwU2n+5ij6z6zr2g== +jsesc@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-3.0.2.tgz#bb8b09a6597ba426425f2e4a07245c3d00b9343e" + integrity sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g== + +jsesc@~0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" + integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== + +jsforce@^2.0.0-beta.29: + version "2.0.0-beta.29" + resolved "https://registry.yarnpkg.com/jsforce/-/jsforce-2.0.0-beta.29.tgz#0b59b026eb0b90dfb199a53656af32a4c8acc48f" + integrity sha512-Fq7xjOYOikyozZZDQNTfzsAdhcO0rUXwtavsjM+cCYUFiCMVOJJavgco303zOsJk3v8sdAYnGgHyKckLIhnyAg== dependencies: "@babel/runtime" "^7.12.5" "@babel/runtime-corejs3" "^7.12.5" @@ -3926,12 +3041,7 @@ jsforce@^2.0.0-beta.20: open "^7.0.0" regenerator-runtime "^0.13.3" strip-ansi "^6.0.0" - xml2js "^0.4.22" - -json-parse-better-errors@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9" - integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw== + xml2js "^0.5.0" json-parse-even-better-errors@^2.3.0: version "2.3.1" @@ -3953,7 +3063,7 @@ json-stable-stringify-without-jsonify@^1.0.1: resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== -json5@^1.0.1: +json5@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.2.tgz#63d98d60f21b313b77c4d6da18bfa69d80e1d593" integrity sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA== @@ -3965,10 +3075,10 @@ json5@^2.2.1: resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== -jsonc-parser@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-3.1.0.tgz#73b8f0e5c940b83d03476bc2e51a20ef0932615d" - integrity sha512-DRf0QjnNeCUds3xTjKlQQ3DpJD51GvDjJfnxUVWg6PZTo2otSm+slzNAxU/35hF8/oJIKoG9slq30JYOsF2azg== +jsonc-parser@^3.0.0, jsonc-parser@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/jsonc-parser/-/jsonc-parser-3.2.0.tgz#31ff3f4c2b9793f89c67212627c51c6394f88e76" + integrity sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w== jsonfile@^4.0.0: version "4.0.0" @@ -3991,15 +3101,31 @@ jsonparse@^1.2.0: resolved "https://registry.yarnpkg.com/jsonparse/-/jsonparse-1.3.1.tgz#3f4dae4a91fac315f71062f8521cc239f1366280" integrity sha512-POQXvpdL69+CluYsillJ7SUhKvytYjW9vG/GKpnf+xP8UWgYEM/RaMzHHofbALDiKbbP1W8UEYmgGl39WkPZsg== -jsonwebtoken@9.0.0: - version "9.0.0" - resolved "https://registry.yarnpkg.com/jsonwebtoken/-/jsonwebtoken-9.0.0.tgz#d0faf9ba1cc3a56255fe49c0961a67e520c1926d" - integrity sha512-tuGfYXxkQGDPnLJ7SibiQgVgeDgfbPq2k2ICcbgqW8WxWLBAxKQM/ZCu/IT8SOSwmaYl4dpTFCW5xZv7YbbWUw== +jsonwebtoken@9.0.2: + version "9.0.2" + resolved "https://registry.yarnpkg.com/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz#65ff91f4abef1784697d40952bb1998c504caaf3" + integrity sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ== dependencies: jws "^3.2.2" - lodash "^4.17.21" + lodash.includes "^4.3.0" + lodash.isboolean "^3.0.3" + lodash.isinteger "^4.0.4" + lodash.isnumber "^3.0.3" + lodash.isplainobject "^4.0.6" + lodash.isstring "^4.0.1" + lodash.once "^4.0.0" ms "^2.1.1" - semver "^7.3.8" + semver "^7.5.4" + +jszip@3.10.1: + version "3.10.1" + resolved "https://registry.yarnpkg.com/jszip/-/jszip-3.10.1.tgz#34aee70eb18ea1faec2f589208a157d1feb091c2" + integrity sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g== + dependencies: + lie "~3.3.0" + pako "~1.0.2" + readable-stream "~2.3.6" + setimmediate "^1.0.5" just-extend@^4.0.2: version "4.2.1" @@ -4023,37 +3149,11 @@ jws@^3.2.2: jwa "^1.4.1" safe-buffer "^5.0.1" -kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0: - version "3.2.2" - resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" - integrity sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ== - dependencies: - is-buffer "^1.1.5" - -kind-of@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" - integrity sha512-24XsCxmEbRwEDbz/qz3stgin8TTzZ1ESR56OMCN0ujYg+vRutNSiOj9bHH9u85DKgXguraugV5sFuvbD4FW/hw== - dependencies: - is-buffer "^1.1.5" - -kind-of@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz#729c91e2d857b7a419a1f9aa65685c4c33f5845d" - integrity sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw== - -kind-of@^6.0.0, kind-of@^6.0.2, kind-of@^6.0.3: +kind-of@^6.0.2, kind-of@^6.0.3: version "6.0.3" resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== -lazystream@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/lazystream/-/lazystream-1.0.1.tgz#494c831062f1f9408251ec44db1cba29242a2638" - integrity sha512-b94GiNHQNy6JNTrt5w6zNyffMrNkXZb3KTkCZJb2V1xaEGCk093vkZ2jk3tpaeP33/OiXC+WvK9AxUebnf5nbw== - dependencies: - readable-stream "^2.0.5" - levn@^0.4.1: version "0.4.1" resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" @@ -4062,21 +3162,18 @@ levn@^0.4.1: prelude-ls "^1.2.1" type-check "~0.4.0" +lie@~3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/lie/-/lie-3.3.0.tgz#dcf82dee545f46074daf200c7c1c5a08e0f40f6a" + integrity sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ== + dependencies: + immediate "~3.0.5" + lines-and-columns@^1.1.6: version "1.2.4" resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== -load-json-file@^6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-6.2.0.tgz#5c7770b42cafa97074ca2848707c61662f4251a1" - integrity sha512-gUD/epcRms75Cw8RT1pUdHugZYM5ce64ucs2GEISABwkRsOQr0q2wm/MV2TKThycIe5e0ytRweW2RZxclogCdQ== - dependencies: - graceful-fs "^4.1.15" - parse-json "^5.0.0" - strip-bom "^4.0.0" - type-fest "^0.6.0" - locate-path@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" @@ -4096,21 +3193,6 @@ lodash.camelcase@^4.3.0: resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6" integrity sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA== -lodash.defaults@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/lodash.defaults/-/lodash.defaults-4.2.0.tgz#d09178716ffea4dde9e5fb7b37f6f0802274580c" - integrity sha512-qjxPLHd3r5DnsdGacqOMU6pb/avJzdh9tFX2ymgoZE27BmjXrNy/y4LoaiTeAb+O3gL8AfpJGtqfX/ae2leYYQ== - -lodash.difference@^4.5.0: - version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.difference/-/lodash.difference-4.5.0.tgz#9ccb4e505d486b91651345772885a2df27fd017c" - integrity sha512-dS2j+W26TQ7taQBGN8Lbbq04ssV3emRw4NY58WErlTO29pIqS0HmoT5aJ9+TUQ1N3G+JOZSji4eugsWwGp9yPA== - -lodash.flatten@^4.4.0: - version "4.4.0" - resolved "https://registry.yarnpkg.com/lodash.flatten/-/lodash.flatten-4.4.0.tgz#f31c22225a9632d2bbf8e4addbef240aa765a61f" - integrity sha512-C5N2Z3DgnnKr0LOpv/hKCgKdb7ZZwafIrsesve6lmzvZIRZRGaZ/l6Q8+2W7NaT+ZwO3fFlSCzCzrDCFdJfZ4g== - lodash.flattendeep@^4.4.0: version "4.4.0" resolved "https://registry.yarnpkg.com/lodash.flattendeep/-/lodash.flattendeep-4.4.0.tgz#fb030917f86a3134e5bc9bec0d69e0013ddfedb2" @@ -4121,26 +3203,46 @@ lodash.get@^4.4.2: resolved "https://registry.yarnpkg.com/lodash.get/-/lodash.get-4.4.2.tgz#2d177f652fa31e939b4438d5341499dfa3825e99" integrity sha512-z+Uw/vLuy6gQe8cfaFWD7p0wVv8fJl3mbzXh33RS+0oW2wvUqiRXiQ69gLWSLpgB5/6sU+r6BlQR0MBILadqTQ== +lodash.includes@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/lodash.includes/-/lodash.includes-4.3.0.tgz#60bb98a87cb923c68ca1e51325483314849f553f" + integrity sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w== + +lodash.isboolean@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz#6c2e171db2a257cd96802fd43b01b20d5f5870f6" + integrity sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg== + lodash.isfunction@^3.0.9: version "3.0.9" resolved "https://registry.yarnpkg.com/lodash.isfunction/-/lodash.isfunction-3.0.9.tgz#06de25df4db327ac931981d1bdb067e5af68d051" integrity sha512-AirXNj15uRIMMPihnkInB4i3NHeb4iBtNg9WRWuK2o31S+ePwwNmDPaTL3o7dTJ+VXNZim7rFs4rxN4YU1oUJw== +lodash.isinteger@^4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz#619c0af3d03f8b04c31f5882840b77b11cd68343" + integrity sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA== + +lodash.isnumber@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz#3ce76810c5928d03352301ac287317f11c0b1ffc" + integrity sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw== + lodash.isplainobject@^4.0.6: version "4.0.6" resolved "https://registry.yarnpkg.com/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz#7c526a52d89b45c45cc690b88163be0497f550cb" integrity sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA== +lodash.isstring@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/lodash.isstring/-/lodash.isstring-4.0.1.tgz#d527dfb5456eca7cc9bb95d5daeaf88ba54a5451" + integrity sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw== + lodash.kebabcase@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/lodash.kebabcase/-/lodash.kebabcase-4.1.1.tgz#8489b1cb0d29ff88195cceca448ff6d6cc295c36" integrity sha512-N8XRTIMMqqDgSy4VLKPnJ/+hpGZN+PHQiJnSenYqPaVV/NCqEogTnAdZLQiGKhxX+JCs8waWq2t1XHWKOmlY8g== -lodash.map@^4.5.1: - version "4.6.0" - resolved "https://registry.yarnpkg.com/lodash.map/-/lodash.map-4.6.0.tgz#771ec7839e3473d9c4cde28b19394c3562f4f6d3" - integrity sha512-worNHGKLDetmcEYDvh2stPCrrQRkP20E4l0iIS7F8EvzMqBBi7ltvFN5m1HvTf1P7Jk1txKhvFcmYsCr8O2F1Q== - lodash.merge@^4.6.2: version "4.6.2" resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" @@ -4151,6 +3253,11 @@ lodash.mergewith@^4.6.2: resolved "https://registry.yarnpkg.com/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz#617121f89ac55f59047c7aec1ccd6654c6590f55" integrity sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ== +lodash.once@^4.0.0: + version "4.1.1" + resolved "https://registry.yarnpkg.com/lodash.once/-/lodash.once-4.1.1.tgz#0dd3971213c7c56df880977d504c88fb471a97ac" + integrity sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg== + lodash.snakecase@^4.1.1: version "4.1.1" resolved "https://registry.yarnpkg.com/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz#39d714a35357147837aefd64b5dcbb16becd8f8d" @@ -4161,11 +3268,6 @@ lodash.startcase@^4.4.0: resolved "https://registry.yarnpkg.com/lodash.startcase/-/lodash.startcase-4.4.0.tgz#9436e34ed26093ed7ffae1936144350915d9add8" integrity sha512-+WKqsK294HMSc2jEbNgpHpd0JfIBhp7rEV4aqXWqFr6AlXov+SlcgB1Fv01y2kGe3Gc8nMW7VA0SrGuSkRfIEg== -lodash.union@^4.6.0: - version "4.6.0" - resolved "https://registry.yarnpkg.com/lodash.union/-/lodash.union-4.6.0.tgz#48bb5088409f16f1821666641c44dd1aaae3cd88" - integrity sha512-c4pB2CdGrGdjMKYLA+XiRDO7Y0PRQbm/Gzg8qMj+QH+pFVAoTp5sBpO0odL3FjoPCGjK96p6qsP+yQoiLoOBcw== - lodash.uniq@^4.5.0: version "4.5.0" resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" @@ -4176,12 +3278,7 @@ lodash.upperfirst@^4.3.1: resolved "https://registry.yarnpkg.com/lodash.upperfirst/-/lodash.upperfirst-4.3.1.tgz#1365edf431480481ef0d1c68957a5ed99d49f7ce" integrity sha512-sReKOYJIJf74dhJONhU4e0/shzi1trVbSWDOhKYE5XV2O+H7Sb2Dihwuc7xWxVl+DgFPyTqIN3zMfT9cq5iWDg== -lodash@4.17.14: - version "4.17.14" - resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.14.tgz#9ce487ae66c96254fe20b599f21b6816028078ba" - integrity sha512-mmKYbW3GLuJeX+iGP+Y7Gp1AiGHGbXHCOh/jZmrawMmsE7MS4znI3RL2FsjbqOyMayHInjOeykW7PEajUk1/xw== - -lodash@^4.17.10, lodash@^4.17.11, lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.21: +lodash@^4.17.15, lodash@^4.17.19, lodash@^4.17.4: version "4.17.21" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== @@ -4206,15 +3303,10 @@ lolex@^5.0.1: dependencies: "@sinonjs/commons" "^1.7.0" -longest@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" - integrity sha512-k+yt5n3l48JU4k8ftnKG6V7u32wyH2NfKzeMto9F/QRE0amxy/LayxwlvjjkZEIzqR+19IrtFO8p5kB9QaYUFg== - -loupe@^2.3.1: - version "2.3.4" - resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.4.tgz#7e0b9bffc76f148f9be769cb1321d3dcf3cb25f3" - integrity sha512-OvKfgCC2Ndby6aSTREl5aCCPTNIzlDfQZvZxNUrBrihDhL3xcrYegTblhmEiCrg2kKQz4XsFIaemE5BF4ybSaQ== +loupe@^2.3.6: + version "2.3.6" + resolved "https://registry.yarnpkg.com/loupe/-/loupe-2.3.6.tgz#76e4af498103c532d1ecc9be102036a21f787b53" + integrity sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA== dependencies: get-func-name "^2.0.0" @@ -4249,11 +3341,6 @@ make-error@^1.1.1: resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== -map-cache@^0.2.2: - version "0.2.2" - resolved "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz#c32abd0bd6525d9b051645bb4f26ac5dc98a0dbf" - integrity sha512-8y/eV9QQZCiyn1SprXSrCmqJN0yNRATe+PO8ztwqrvrbdRLA3eYJF0yaR0YayLWkMbsQSKWS9N2gPcGEc4UsZg== - map-obj@^1.0.0: version "1.0.1" resolved "https://registry.yarnpkg.com/map-obj/-/map-obj-1.0.1.tgz#d933ceb9205d82bdcf4886f6742bdc2b4dea146d" @@ -4264,17 +3351,10 @@ map-obj@^4.0.0: resolved "https://registry.yarnpkg.com/map-obj/-/map-obj-4.3.0.tgz#9304f906e93faae70880da102a9f1df0ea8bb05a" integrity sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ== -map-visit@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz#ecdca8f13144e660f1b5bd41f12f3479d98dfb8f" - integrity sha512-4y7uGv8bd2WdM9vpQsiQNo41Ln1NvhvDRuVt0k2JZQ+ezN2uaQes7lZeZ+QQUHOLQAtDaBJ+7wCbi+ab/KFs+w== - dependencies: - object-visit "^1.0.0" - -marked@^4.0.19: - version "4.2.12" - resolved "https://registry.yarnpkg.com/marked/-/marked-4.2.12.tgz#d69a64e21d71b06250da995dcd065c11083bebb5" - integrity sha512-yr8hSKa3Fv4D3jdZmtMMPghgVt6TWbk86WQaWhDloQjRSQhMMYCAro7jP7VDJrjjdV8pxVxMssXS8B8Y5DZ5aw== +marked@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/marked/-/marked-4.3.0.tgz#796362821b019f734054582038b116481b456cf3" + integrity sha512-PRsaiG84bK+AMvxziE/lCFss8juXjNaWzVbN5tXAm4XjeaS9NAHhop+PjQxz2A9h8Q4M/xGmzP8vqNwy6JeK0A== meow@^8.0.0: version "8.1.2" @@ -4298,36 +3378,12 @@ merge-stream@^2.0.0: resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== -merge2@^1.2.3, merge2@^1.3.0, merge2@^1.4.1: +merge2@^1.3.0, merge2@^1.4.1: version "1.4.1" resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== -merge@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/merge/-/merge-1.2.1.tgz#38bebf80c3220a8a487b6fcfb3941bb11720c145" - integrity sha512-VjFo4P5Whtj4vsLzsYBu5ayHhoHJ0UqNm7ibvShmbmoz7tGi0vXaoJbGdB+GmDMLUdg8DpQXEIeVDAe8MaABvQ== - -micromatch@^3.0.4: - version "3.1.10" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.10.tgz#70859bc95c9840952f359a068a3fc49f9ecfac23" - integrity sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg== - dependencies: - arr-diff "^4.0.0" - array-unique "^0.3.2" - braces "^2.3.1" - define-property "^2.0.2" - extend-shallow "^3.0.2" - extglob "^2.0.4" - fragment-cache "^0.2.1" - kind-of "^6.0.2" - nanomatch "^1.2.9" - object.pick "^1.3.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.2" - -micromatch@^4.0.2, micromatch@^4.0.4: +micromatch@^4.0.4: version "4.0.5" resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== @@ -4347,11 +3403,6 @@ mime-types@^2.1.12: dependencies: mime-db "1.52.0" -mimic-fn@^1.0.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz#820c86a39334640e99516928bd03fca88057d022" - integrity sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ== - mimic-fn@^2.1.0: version "2.1.0" resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" @@ -4362,24 +3413,24 @@ min-indent@^1.0.0: resolved "https://registry.yarnpkg.com/min-indent/-/min-indent-1.0.1.tgz#a63f681673b30571fbe8bc25686ae746eefa9869" integrity sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg== -"minimatch@2 || 3", minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: +minimatch@5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.0.1.tgz#fb9022f7528125187c92bd9e9b6366be1cf3415b" + integrity sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g== + dependencies: + brace-expansion "^2.0.1" + +minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== dependencies: brace-expansion "^1.1.7" -minimatch@4.2.1: - version "4.2.1" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-4.2.1.tgz#40d9d511a46bdc4e563c22c3080cde9c0d8299b4" - integrity sha512-9Uq1ChtSZO+Mxa/CL1eGizn2vRn3MlLgzhT0Iz8zaY8NdvxvB0d5QdPFmCKf7JKA9Lerx5vRrnwO03jsSfGG9g== - dependencies: - brace-expansion "^1.1.7" - -minimatch@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.0.tgz#1717b464f4971b144f6aabe8f2d0b8e4511e09c7" - integrity sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg== +minimatch@^9.0.3: + version "9.0.3" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.3.tgz#a6e00c3de44c3a542bfaae70abfc22420a6da825" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== dependencies: brace-expansion "^2.0.1" @@ -4392,62 +3443,34 @@ minimist-options@4.1.0: is-plain-obj "^1.1.0" kind-of "^6.0.3" -minimist@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" - integrity sha512-7Wl+Jz+IGWuSdgsQEJ4JunV0si/iMhg42MnQQG6h1R6TNeVenp4U9x5CC5v/gYqz/fENLQITAWXidNtVL0NNbw== - -minimist@^1.2.0, minimist@^1.2.3, minimist@^1.2.6: - version "1.2.6" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" - integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== - -mixin-deep@^1.2.0: - version "1.3.2" - resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" - integrity sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA== - dependencies: - for-in "^1.0.2" - is-extendable "^1.0.1" - -mkdirp-classic@^0.5.2: - version "0.5.3" - resolved "https://registry.yarnpkg.com/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz#fa10c9115cc6d8865be221ba47ee9bed78601113" - integrity sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A== - -mkdirp@~0.5.1: - version "0.5.6" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.6.tgz#7def03d2432dcae4ba1d611445c48396062255f6" - integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== - dependencies: - minimist "^1.2.6" +minimist@^1.2.0, minimist@^1.2.6, minimist@^1.2.8: + version "1.2.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== -mocha@^9.1.3: - version "9.2.2" - resolved "https://registry.yarnpkg.com/mocha/-/mocha-9.2.2.tgz#d70db46bdb93ca57402c809333e5a84977a88fb9" - integrity sha512-L6XC3EdwT6YrIk0yXpavvLkn8h+EU+Y5UcCHKECyMbdUIxyMuZj4bX4U9e1nvnvUUvQVsV2VHQr5zLdcUkhW/g== +mocha@^10.2.0: + version "10.2.0" + resolved "https://registry.yarnpkg.com/mocha/-/mocha-10.2.0.tgz#1fd4a7c32ba5ac372e03a17eef435bd00e5c68b8" + integrity sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg== dependencies: - "@ungap/promise-all-settled" "1.1.2" ansi-colors "4.1.1" browser-stdout "1.3.1" chokidar "3.5.3" - debug "4.3.3" + debug "4.3.4" diff "5.0.0" escape-string-regexp "4.0.0" find-up "5.0.0" glob "7.2.0" - growl "1.10.5" he "1.2.0" js-yaml "4.1.0" log-symbols "4.1.0" - minimatch "4.2.1" + minimatch "5.0.1" ms "2.1.3" - nanoid "3.3.1" + nanoid "3.3.3" serialize-javascript "6.0.0" strip-json-comments "3.1.1" supports-color "8.1.1" - which "2.0.2" - workerpool "6.2.0" + workerpool "6.2.1" yargs "16.2.0" yargs-parser "20.2.4" yargs-unparser "2.0.0" @@ -4457,11 +3480,6 @@ mri@^1.1.5: resolved "https://registry.yarnpkg.com/mri/-/mri-1.2.0.tgz#6721480fec2a11a4889861115a48b6cbe7cc8f0b" integrity sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA== -ms@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" - integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== - ms@2.1.2: version "2.1.2" resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" @@ -4491,77 +3509,21 @@ multistream@^3.1.0: inherits "^2.0.1" readable-stream "^3.4.0" -mute-stream@0.0.7: - version "0.0.7" - resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz#3075ce93bc21b8fab43e1bc4da7e8115ed1e7bab" - integrity sha512-r65nCZhrbXXb6dXOACihYApHw2Q6pV0M3V0PSxd74N0+D8nzAdEAITq2oAjA1jVnKI+tGvEBUpqiMh0+rW6zDQ== - mute-stream@0.0.8: version "0.0.8" resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.8.tgz#1630c42b2251ff81e2a283de96a5497ea92e5e0d" integrity sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA== -mv@~2: - version "2.1.1" - resolved "https://registry.yarnpkg.com/mv/-/mv-2.1.1.tgz#ae6ce0d6f6d5e0a4f7d893798d03c1ea9559b6a2" - integrity sha512-at/ZndSy3xEGJ8i0ygALh8ru9qy7gWW1cmkaqBN29JmMlIvM//MEO9y1sk/avxuwnPcfhkejkLsuPxH81BrkSg== - dependencies: - mkdirp "~0.5.1" - ncp "~2.0.0" - rimraf "~2.4.0" - -nan@^2.0.8: - version "2.16.0" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.16.0.tgz#664f43e45460fb98faf00edca0bb0d7b8dce7916" - integrity sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA== - -nanoid@3.3.1: - version "3.3.1" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.1.tgz#6347a18cac88af88f58af0b3594b723d5e99bb35" - integrity sha512-n6Vs/3KGyxPQd6uO0eH4Bv0ojGSUvuLlIHtC3Y0kEO23YRge8H9x1GCzLn28YX0H66pMkxuaeESFq4tKISKwdw== - -nanomatch@^1.2.9: - version "1.2.13" - resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" - integrity sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA== - dependencies: - arr-diff "^4.0.0" - array-unique "^0.3.2" - define-property "^2.0.2" - extend-shallow "^3.0.2" - fragment-cache "^0.2.1" - is-windows "^1.0.2" - kind-of "^6.0.2" - object.pick "^1.3.0" - regex-not "^1.0.0" - snapdragon "^0.8.1" - to-regex "^3.0.1" - -natural-compare-lite@^1.4.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz#17b09581988979fddafe0201e931ba933c96cbb4" - integrity sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g== +nanoid@3.3.3: + version "3.3.3" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.3.tgz#fd8e8b7aa761fe807dba2d1b98fb7241bb724a25" + integrity sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w== natural-compare@^1.4.0: version "1.4.0" resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== -natural-orderby@^2.0.1: - version "2.0.3" - resolved "https://registry.yarnpkg.com/natural-orderby/-/natural-orderby-2.0.3.tgz#8623bc518ba162f8ff1cdb8941d74deb0fdcc016" - integrity sha512-p7KTHxU0CUrcOXe62Zfrb5Z13nLvPhSWR/so3kFulUQU0sgUll2Z0LwpsLN351eOOD+hRGu/F1g+6xDfPeD++Q== - -ncp@~2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ncp/-/ncp-2.0.0.tgz#195a21d6c46e361d2fb1281ba38b91e9df7bdbb3" - integrity sha512-zIdGUrPRFTUELUvr3Gmc7KZ2Sw/h1PiVM0Af/oHB6zgnV1ikqSfRk+TOufi79aHYCW3NiOXmr1BP5nWbzojLaA== - -nice-try@^1.0.4: - version "1.0.5" - resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" - integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== - nise@^1.3.3: version "1.5.3" resolved "https://registry.yarnpkg.com/nise/-/nise-1.5.3.tgz#9d2cfe37d44f57317766c6e9408a359c5d3ac1f7" @@ -4584,17 +3546,6 @@ nise@^4.1.0: just-extend "^4.0.2" path-to-regexp "^1.7.0" -nise@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/nise/-/nise-5.1.2.tgz#a7b8909c216b3491fd4fc0b124efb69f3939b449" - integrity sha512-+gQjFi8v+tkfCuSCxfURHLhRhniE/+IaYbIphxAN2JRR9SHKhY8hgXpaXiYfHdw+gcGe4buxgbprBQFab9FkhA== - dependencies: - "@sinonjs/commons" "^2.0.0" - "@sinonjs/fake-timers" "^7.0.4" - "@sinonjs/text-encoding" "^0.7.1" - just-extend "^4.0.2" - path-to-regexp "^1.7.0" - no-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" @@ -4604,9 +3555,9 @@ no-case@^3.0.4: tslib "^2.0.3" node-fetch@^2.6.1: - version "2.6.7" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.7.tgz#24de9fba827e3b4ae44dc8b20256a379160052ad" - integrity sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ== + version "2.7.0" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.7.0.tgz#d0f0fa6e3e2dc1d27efcd8ad99d550bda94d187d" + integrity sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A== dependencies: whatwg-url "^5.0.0" @@ -4647,13 +3598,6 @@ normalize-path@^3.0.0, normalize-path@~3.0.0: resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== -npm-run-path@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" - integrity sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw== - dependencies: - path-key "^2.0.0" - npm-run-path@^4.0.0, npm-run-path@^4.0.1: version "4.0.1" resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" @@ -4694,37 +3638,16 @@ nyc@^15.1.0: test-exclude "^6.0.0" yargs "^15.0.2" -object-copy@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" - integrity sha512-79LYn6VAb63zgtmAteVOWo9Vdj71ZVBy3Pbse+VqxDpEP83XuujMrGqHIwAXJ5I/aM0zU7dIyIAhifVTPrNItQ== - dependencies: - copy-descriptor "^0.1.0" - define-property "^0.2.5" - kind-of "^3.0.3" - -object-inspect@^1.12.2, object-inspect@^1.9.0: - version "1.12.3" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.3.tgz#ba62dffd67ee256c8c086dfae69e016cd1f198b9" - integrity sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g== +object-inspect@^1.13.1, object-inspect@^1.9.0: + version "1.13.1" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.13.1.tgz#b96c6109324ccfef6b12216a956ca4dc2ff94bc2" + integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== object-keys@^1.1.1: version "1.1.1" resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== -object-treeify@^1.1.4: - version "1.1.33" - resolved "https://registry.yarnpkg.com/object-treeify/-/object-treeify-1.1.33.tgz#f06fece986830a3cba78ddd32d4c11d1f76cdf40" - integrity sha512-EFVjAYfzWqWsBMRHPMAXLCDIJnpMhdWAqR7xG6M6a2cs6PMFpl/+Z20w9zDW4vkxOFfddegBKq9Rehd0bxWE7A== - -object-visit@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz#f79c4493af0c5377b59fe39d395e41042dd045bb" - integrity sha512-GBaMwwAVK9qbQN3Scdo0OyvgPW7l3lnaVMj84uTOZlswkX0KpF6fyDBJhtTthf7pymztoN36/KEr1DyhF96zEA== - dependencies: - isobject "^3.0.0" - object.assign@^4.1.4: version "4.1.4" resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" @@ -4735,21 +3658,38 @@ object.assign@^4.1.4: has-symbols "^1.0.3" object-keys "^1.1.1" -object.pick@^1.3.0: - version "1.3.0" - resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747" - integrity sha512-tqa/UMy/CCoYmj+H5qc07qvSL9dqcs/WZENZ1JbtWBlATP+iVOe778gE6MSijnyCnORzDuX6hU+LA4SZ09YjFQ== +object.fromentries@^2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.7.tgz#71e95f441e9a0ea6baf682ecaaf37fa2a8d7e616" + integrity sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA== dependencies: - isobject "^3.0.1" + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" -object.values@^1.1.5, object.values@^1.1.6: - version "1.1.6" - resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.6.tgz#4abbaa71eba47d63589d402856f908243eea9b1d" - integrity sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw== +object.groupby@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/object.groupby/-/object.groupby-1.0.1.tgz#d41d9f3c8d6c778d9cbac86b4ee9f5af103152ee" + integrity sha512-HqaQtqLnp/8Bn4GL16cj+CUYbnpe1bh0TtEaWvybszDG4tgxCJuRpV8VGuvNaI1fAnI4lUJzDG55MXcOH4JZcQ== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" + define-properties "^1.2.0" + es-abstract "^1.22.1" + get-intrinsic "^1.2.1" + +object.values@^1.1.7: + version "1.1.7" + resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.7.tgz#617ed13272e7e1071b43973aa1655d9291b8442a" + integrity sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng== + dependencies: + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" + +on-exit-leak-free@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/on-exit-leak-free/-/on-exit-leak-free-2.1.0.tgz#5c703c968f7e7f851885f6459bf8a8a57edc9cc4" + integrity sha512-VuCaZZAjReZ3vUwgOB8LxAosIurDiAW0s13rI1YwmaP++jvcxP77AWoQvenZebpCA2m8WC1/EosPYPMjnRAp/w== once@^1.3.0, once@^1.3.1, once@^1.4.0: version "1.4.0" @@ -4758,13 +3698,6 @@ once@^1.3.0, once@^1.3.1, once@^1.4.0: dependencies: wrappy "1" -onetime@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz#067428230fd67443b2794b22bba528b6867962d4" - integrity sha512-oyyPpiMaKARvvcgip+JV+7zci5L8D1W9RZIz2l1o08AM3pfspitVWnPt3mzHcBPp12oYMTy0pqrFs/C+m3EwsQ== - dependencies: - mimic-fn "^1.0.0" - onetime@^5.1.0, onetime@^5.1.2: version "5.1.2" resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" @@ -4780,28 +3713,23 @@ open@^7.0.0: is-docker "^2.0.0" is-wsl "^2.1.1" -optionator@^0.9.1: - version "0.9.1" - resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" - integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== +optionator@^0.9.3: + version "0.9.3" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.3.tgz#007397d44ed1872fdc6ed31360190f81814e2c64" + integrity sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg== dependencies: + "@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" - word-wrap "^1.2.3" os-tmpdir@~1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== -p-finally@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae" - integrity sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow== - p-limit@^2.2.0: version "2.3.0" resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" @@ -4852,6 +3780,11 @@ package-hash@^4.0.0: lodash.flattendeep "^4.4.0" release-zalgo "^1.0.0" +pako@~1.0.2: + version "1.0.11" + resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" + integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== + param-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" @@ -4867,14 +3800,6 @@ parent-module@^1.0.0: dependencies: callsites "^3.0.0" -parse-json@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-4.0.0.tgz#be35f5425be1f7f6c747184f98a788cb99477ee0" - integrity sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw== - dependencies: - error-ex "^1.3.1" - json-parse-better-errors "^1.0.1" - parse-json@^5.0.0: version "5.2.0" resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" @@ -4885,11 +3810,6 @@ parse-json@^5.0.0: json-parse-even-better-errors "^2.3.0" lines-and-columns "^1.1.6" -parse-passwd@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/parse-passwd/-/parse-passwd-1.0.0.tgz#6d5b934a456993b23d37f40a382d6f1666a8e5c6" - integrity sha512-1Y1A//QUXEZK7YKz+rD9WydcE1+EuPr6ZBgKecAB8tmoW6UFv0NREVJe1p+jRxtThkcbbKkfwIbWJe/IeE6m2Q== - pascal-case@^3.1.2: version "3.1.2" resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" @@ -4898,19 +3818,6 @@ pascal-case@^3.1.2: no-case "^3.0.4" tslib "^2.0.3" -pascalcase@^0.1.1: - version "0.1.1" - resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14" - integrity sha512-XHXfu/yOQRy9vYOtUDVMN60OEJjW013GoObG1o+xwQTpB9eYJX/BjXMsdW13ZDPruFhYYn0AG22w0xgQMwl3Nw== - -password-prompt@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/password-prompt/-/password-prompt-1.1.2.tgz#85b2f93896c5bd9e9f2d6ff0627fa5af3dc00923" - integrity sha512-bpuBhROdrhuN3E7G/koAju0WjVw9/uQOG5Co5mokNj0MiOSBVZS1JTwM4zl55hu0WFmIEFvO9cU9sJQiBIYeIA== - dependencies: - ansi-escapes "^3.1.0" - cross-spawn "^6.0.5" - path-case@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/path-case/-/path-case-3.0.4.tgz#9168645334eb942658375c56f80b4c0cb5f82c6f" @@ -4929,11 +3836,6 @@ path-is-absolute@^1.0.0: resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== -path-key@^2.0.0, path-key@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" - integrity sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw== - path-key@^3.0.0, path-key@^3.1.0: version "3.1.1" resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" @@ -4971,29 +3873,84 @@ picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== -pkg-dir@^4.1.0, pkg-dir@^4.2.0: +pino-abstract-transport@^1.0.0, pino-abstract-transport@^1.1.0, pino-abstract-transport@v1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/pino-abstract-transport/-/pino-abstract-transport-1.1.0.tgz#083d98f966262164504afb989bccd05f665937a8" + integrity sha512-lsleG3/2a/JIWUtf9Q5gUNErBqwIu1tUKTT3dUzaf5DySw9ra1wcqKjJjLX1VTY64Wk1eEOYsVGSaGfCK85ekA== + dependencies: + readable-stream "^4.0.0" + split2 "^4.0.0" + +pino-pretty@^10.3.1: + version "10.3.1" + resolved "https://registry.yarnpkg.com/pino-pretty/-/pino-pretty-10.3.1.tgz#e3285a5265211ac6c7cd5988f9e65bf3371a0ca9" + integrity sha512-az8JbIYeN/1iLj2t0jR9DV48/LQ3RC6hZPpapKPkb84Q+yTidMCpgWxIT3N0flnBDilyBQ1luWNpOeJptjdp/g== + dependencies: + colorette "^2.0.7" + dateformat "^4.6.3" + fast-copy "^3.0.0" + fast-safe-stringify "^2.1.1" + help-me "^5.0.0" + joycon "^3.1.1" + minimist "^1.2.6" + on-exit-leak-free "^2.1.0" + pino-abstract-transport "^1.0.0" + pump "^3.0.0" + readable-stream "^4.0.0" + secure-json-parse "^2.4.0" + sonic-boom "^3.0.0" + strip-json-comments "^3.1.1" + +pino-std-serializers@^6.0.0: + version "6.2.2" + resolved "https://registry.yarnpkg.com/pino-std-serializers/-/pino-std-serializers-6.2.2.tgz#d9a9b5f2b9a402486a5fc4db0a737570a860aab3" + integrity sha512-cHjPPsE+vhj/tnhCy/wiMh3M3z3h/j15zHQX+S9GkTBgqJuTuJzYJ4gUyACLhDaJ7kk9ba9iRDmbH2tJU03OiA== + +pino@^8.17.2: + version "8.17.2" + resolved "https://registry.yarnpkg.com/pino/-/pino-8.17.2.tgz#0ed20175623a69d31664a1e8a5f85476272224be" + integrity sha512-LA6qKgeDMLr2ux2y/YiUt47EfgQ+S9LznBWOJdN3q1dx2sv0ziDLUBeVpyVv17TEcGCBuWf0zNtg3M5m1NhhWQ== + dependencies: + atomic-sleep "^1.0.0" + fast-redact "^3.1.1" + on-exit-leak-free "^2.1.0" + pino-abstract-transport v1.1.0 + pino-std-serializers "^6.0.0" + process-warning "^3.0.0" + quick-format-unescaped "^4.0.3" + real-require "^0.2.0" + safe-stable-stringify "^2.3.1" + sonic-boom "^3.7.0" + thread-stream "^2.0.0" + +pkg-dir@^4.1.0: version "4.2.0" resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== dependencies: find-up "^4.0.0" -posix-character-classes@^0.1.0: - version "0.1.1" - resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab" - integrity sha512-xTgYBc3fuo7Yt7JbiuFxSYGToMoz8fLoE6TC9Wx1P/u+LfeThMOAqmuyECnlBaaJb+u1m9hHiXUEtwW4OzfUJg== +platform@^1.3.3: + version "1.3.6" + resolved "https://registry.yarnpkg.com/platform/-/platform-1.3.6.tgz#48b4ce983164b209c2d45a107adb31f473a6e7a7" + integrity sha512-fnWVljUchTro6RiCFvCXBbNhJc2NijN7oIQxbwsyL0buWJPG85v81ehlHI9fXrJsMNgTofEoWIQeClKpgxFLrg== + +pluralize@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/pluralize/-/pluralize-8.0.0.tgz#1a6fa16a38d12a1901e0320fa017051c539ce3b1" + integrity sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA== prelude-ls@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== -prettier@^2.7.1, prettier@^2.8.7: - version "2.8.7" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.7.tgz#bb79fc8729308549d28fe3a98fce73d2c0656450" - integrity sha512-yPngTo3aXUUmyuTjeTUT75txrf+aMh9FiD7q9ZE/i6r0bPb22g4FsE6Y338PQX1bmfy08i9QQCB7/rcUAVntfw== +prettier@^2.8.8: + version "2.8.8" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.8.tgz#e8c5d7e98a4305ffe3de2e1fc4aca1a71c28b1da" + integrity sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q== -pretty-quick@^3.1.0, pretty-quick@^3.1.3: +pretty-quick@^3.1.3: version "3.1.3" resolved "https://registry.yarnpkg.com/pretty-quick/-/pretty-quick-3.1.3.tgz#15281108c0ddf446675157ca40240099157b638e" integrity sha512-kOCi2FJabvuh1as9enxYmrnBC6tVMoVOenMaBqRfsvBHB0cbpYHjdQEpSglpASDFEXVwplpcGR4CLEaisYAFcA== @@ -5017,6 +3974,16 @@ process-on-spawn@^1.0.0: dependencies: fromentries "^1.2.0" +process-warning@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/process-warning/-/process-warning-3.0.0.tgz#96e5b88884187a1dce6f5c3166d611132058710b" + integrity sha512-mqn0kFRl0EoqhnL0GQ0veqFHyIN1yig9RHh/InzORTUiZHFRAur+aMtRkELNwGs9aNwKS6tg/An4NYBPGwvtzQ== + +process@^0.11.10: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + integrity sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A== + proper-lockfile@^4.1.2: version "4.1.2" resolved "https://registry.yarnpkg.com/proper-lockfile/-/proper-lockfile-4.1.2.tgz#c8b9de2af6b2f1601067f98e01ac66baa223141f" @@ -5049,30 +4016,21 @@ q@^1.5.1: resolved "https://registry.yarnpkg.com/q/-/q-1.5.1.tgz#7e32f75b41381291d04611f1bf14109ac00651d7" integrity sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw== -qqjs@^0.3.10: - version "0.3.11" - resolved "https://registry.yarnpkg.com/qqjs/-/qqjs-0.3.11.tgz#795b9f7d00807d75c391b1241b5be3077143d9ea" - integrity sha512-pB2X5AduTl78J+xRSxQiEmga1jQV0j43jOPs/MTgTLApGFEOn6NgdE2dEjp7nvDtjkIOZbvFIojAiYUx6ep3zg== - dependencies: - chalk "^2.4.1" - debug "^4.1.1" - execa "^0.10.0" - fs-extra "^6.0.1" - get-stream "^5.1.0" - glob "^7.1.2" - globby "^10.0.1" - http-call "^5.1.2" - load-json-file "^6.2.0" - pkg-dir "^4.2.0" - tar-fs "^2.0.0" - tmp "^0.1.0" - write-json-file "^4.1.1" +querystringify@^2.1.1: + version "2.2.0" + resolved "https://registry.yarnpkg.com/querystringify/-/querystringify-2.2.0.tgz#3345941b4153cb9d082d8eee4cda2016a9aef7f6" + integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== queue-microtask@^1.2.2: version "1.2.3" resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== +quick-format-unescaped@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/quick-format-unescaped/-/quick-format-unescaped-4.0.4.tgz#93ef6dd8d3453cbc7970dd614fad4c5954d6b5a7" + integrity sha512-tYC1Q1hgyRuHgloV/YXs2w15unPVh8qfu/qCTfhTYamaw7fyhumKa2yGpdSo87vY32rIclj+4fWYQXUMs9EHvg== + quick-lru@^4.0.1: version "4.0.1" resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-4.0.1.tgz#5b8878f113a58217848c6482026c73e1ba57727f" @@ -5104,19 +4062,29 @@ read-pkg@^5.2.0: parse-json "^5.0.0" type-fest "^0.6.0" -readable-stream@3, readable-stream@^3.0.0, readable-stream@^3.1.1, readable-stream@^3.4.0, readable-stream@^3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== +readable-stream@3, readable-stream@^3.0.0, readable-stream@^3.4.0: + version "3.6.2" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" + integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== dependencies: inherits "^2.0.3" string_decoder "^1.1.1" util-deprecate "^1.0.1" -readable-stream@^2.0.0, readable-stream@^2.0.5: - version "2.3.7" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" - integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== +readable-stream@^4.0.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-4.4.0.tgz#55ce132d60a988c460d75c631e9ccf6a7229b468" + integrity sha512-kDMOq0qLtxV9f/SQv522h8cxZBqNZXuXNyjyezmfAAuribMyVXziljpQ/uQhfE1XLg2/TLTW2DsnoE4VAi/krg== + dependencies: + abort-controller "^3.0.0" + buffer "^6.0.3" + events "^3.3.0" + process "^0.11.10" + +readable-stream@~2.3.6: + version "2.3.8" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.8.tgz#91125e8042bba1b9887f49345f6277027ce8be9b" + integrity sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA== dependencies: core-util-is "~1.0.0" inherits "~2.0.3" @@ -5126,13 +4094,6 @@ readable-stream@^2.0.0, readable-stream@^2.0.5: string_decoder "~1.1.1" util-deprecate "~1.0.1" -readdir-glob@^1.0.0: - version "1.1.2" - resolved "https://registry.yarnpkg.com/readdir-glob/-/readdir-glob-1.1.2.tgz#b185789b8e6a43491635b6953295c5c5e3fd224c" - integrity sha512-6RLVvwJtVwEDfPdn6X6Ille4/lxGl0ATOY4FN/B9nxQcgOazvvI0nodiD19ScKq0PvA/29VpaOQML36o5IzZWA== - dependencies: - minimatch "^5.1.0" - readdirp@~3.6.0: version "3.6.0" resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" @@ -5140,6 +4101,11 @@ readdirp@~3.6.0: dependencies: picomatch "^2.2.1" +real-require@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/real-require/-/real-require-0.2.0.tgz#209632dea1810be2ae063a6ac084fee7e33fba78" + integrity sha512-57frrGM/OCTLqLOAh0mhVA9VBMHd+9U7Zb2THMGdBUoZVOtGbJzjxsYGDJ3A9AYYCP4hn6y1TVbaOfzWtm5GFg== + rechoir@^0.6.2: version "0.6.2" resolved "https://registry.yarnpkg.com/rechoir/-/rechoir-0.6.2.tgz#85204b54dba82d5742e28c96756ef43af50e3384" @@ -5155,39 +4121,36 @@ redent@^3.0.0: indent-string "^4.0.0" strip-indent "^3.0.0" -redeyed@~2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/redeyed/-/redeyed-2.1.1.tgz#8984b5815d99cb220469c99eeeffe38913e6cc0b" - integrity sha512-FNpGGo1DycYAdnrKFxCMmKYgo/mILAqtRYbkdQD8Ep/Hk2PQ5+aEAEx+IU713RTDmuBaH0c8P5ZozurNu5ObRQ== - dependencies: - esprima "~4.0.0" +regenerator-runtime@^0.13.3: + version "0.13.11" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz#f6dca3e7ceec20590d07ada785636a90cdca17f9" + integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== -regenerator-runtime@^0.13.3, regenerator-runtime@^0.13.4: - version "0.13.9" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz#8925742a98ffd90814988d7566ad30ca3b263b52" - integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== +regenerator-runtime@^0.14.0: + version "0.14.0" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.0.tgz#5e19d68eb12d486f797e15a3c6a918f7cec5eb45" + integrity sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA== -regex-not@^1.0.0, regex-not@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c" - integrity sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A== - dependencies: - extend-shallow "^3.0.2" - safe-regex "^1.1.0" +regexp-tree@^0.1.27: + version "0.1.27" + resolved "https://registry.yarnpkg.com/regexp-tree/-/regexp-tree-0.1.27.tgz#2198f0ef54518ffa743fe74d983b56ffd631b6cd" + integrity sha512-iETxpjK6YoRWJG5o6hXLwvjYAoW+FEZn9os0PD/b6AP6xQwsa/Y7lCVgIixBbUPMfhu+i2LtdeAqVTgGlQarfA== -regexp.prototype.flags@^1.4.3: - version "1.4.3" - resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz#87cab30f80f66660181a3bb7bf5981a872b367ac" - integrity sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA== +regexp.prototype.flags@^1.5.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz#90ce989138db209f81492edd734183ce99f9677e" + integrity sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg== dependencies: call-bind "^1.0.2" - define-properties "^1.1.3" - functions-have-names "^1.2.2" + define-properties "^1.2.0" + set-function-name "^2.0.0" -regextras@^0.8.0: - version "0.8.0" - resolved "https://registry.yarnpkg.com/regextras/-/regextras-0.8.0.tgz#ec0f99853d4912839321172f608b544814b02217" - integrity sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ== +regjsparser@^0.10.0: + version "0.10.0" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.10.0.tgz#b1ed26051736b436f22fdec1c8f72635f9f44892" + integrity sha512-qx+xQGZVsy55CH0a1hiVwHmqjLryfh7wQyF5HO07XJ9f7dQMY/gPQHhlyDkIzJKC+x2fUCpCcUODUUUFrm7SHA== + dependencies: + jsesc "~0.5.0" release-zalgo@^1.0.0: version "1.0.0" @@ -5196,16 +4159,6 @@ release-zalgo@^1.0.0: dependencies: es6-error "^4.0.1" -repeat-element@^1.1.2: - version "1.1.4" - resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.4.tgz#be681520847ab58c7568ac75fbfad28ed42d39e9" - integrity sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ== - -repeat-string@^1.6.1: - version "1.6.1" - resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" - integrity sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w== - require-directory@^2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" @@ -5221,13 +4174,10 @@ require-main-filename@^2.0.0: resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-2.0.0.tgz#d0b329ecc7cc0f61649f62215be69af54aa8989b" integrity sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg== -resolve-dir@^1.0.0, resolve-dir@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/resolve-dir/-/resolve-dir-1.0.1.tgz#79a40644c362be82f26effe739c9bb5382046f43" - integrity sha512-R7uiTjECzvOsWSfdM0QKFNBVFcK27aHOUwdvK53BcW8zqnGdYp0Fbj82cy54+2A4P2tFM22J5kRfe1R+lM/1yg== - dependencies: - expand-tilde "^2.0.0" - global-modules "^1.0.0" +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" + integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== resolve-from@5.0.0, resolve-from@^5.0.0: version "5.0.0" @@ -5246,28 +4196,15 @@ resolve-global@1.0.0, resolve-global@^1.0.0: dependencies: global-dirs "^0.1.1" -resolve-url@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a" - integrity sha512-ZuF55hVUQaaczgOIwqWzkEcEidmlD/xl44x1UZnhOXcYuFN2S6+rcxpG+C1N3So0wvNI3DmJICUFfu2SxhBmvg== - -resolve@>=1.9.0, resolve@^1.1.6, resolve@^1.10.0, resolve@^1.22.0, resolve@^1.22.1: - version "1.22.1" - resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.1.tgz#27cb2ebb53f91abb49470a928bba7558066ac177" - integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== +resolve@^1.1.6, resolve@^1.10.0, resolve@^1.22.2, resolve@^1.22.4: + version "1.22.8" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" + integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== dependencies: - is-core-module "^2.9.0" + is-core-module "^2.13.0" path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" -restore-cursor@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz#9f7ee287f82fd326d4fd162923d62129eee0dfaf" - integrity sha512-6IzJLuGi4+R14vwagDHX+JrXmPVtPpn4mffDJ1UdR7/Edm87fl6yi8mMBIVvFtJaNTUvjughmW4hwLhRG7gC1Q== - dependencies: - onetime "^2.0.0" - signal-exit "^3.0.2" - restore-cursor@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-3.1.0.tgz#39f67c54b3a7a58cea5236d95cf0034239631f7e" @@ -5276,11 +4213,6 @@ restore-cursor@^3.1.0: onetime "^5.1.0" signal-exit "^3.0.2" -ret@~0.1.10: - version "0.1.15" - resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc" - integrity sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg== - retry@^0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" @@ -5291,18 +4223,6 @@ reusify@^1.0.4: resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== -right-pad@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/right-pad/-/right-pad-1.0.1.tgz#8ca08c2cbb5b55e74dafa96bf7fd1a27d568c8d0" - integrity sha512-bYBjgxmkvTAfgIYy328fmkwhp39v8lwVgWhhrzxPV3yHtcSqyYKe9/XOhvW48UFjATg3VuJbpsp5822ACNvkmw== - -rimraf@^2.6.3: - version "2.7.1" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== - dependencies: - glob "^7.1.3" - rimraf@^3.0.0, rimraf@^3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" @@ -5310,14 +4230,7 @@ rimraf@^3.0.0, rimraf@^3.0.2: dependencies: glob "^7.1.3" -rimraf@~2.4.0: - version "2.4.5" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.4.5.tgz#ee710ce5d93a8fdb856fb5ea8ff0e2d75934b2da" - integrity sha512-J5xnxTyqaiw06JjMftq7L9ouA448dw/E7dKghkP9WpKNuwmARNNg+Gk8/u5ryb9N/Yo2+z3MCwuqFK/+qPOPfQ== - dependencies: - glob "^6.0.1" - -run-async@^2.2.0, run-async@^2.4.0: +run-async@^2.4.0: version "2.4.1" resolved "https://registry.yarnpkg.com/run-async/-/run-async-2.4.1.tgz#8440eccf99ea3e70bd409d49aab88e10c189a455" integrity sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ== @@ -5329,13 +4242,23 @@ run-parallel@^1.1.9: dependencies: queue-microtask "^1.2.2" -rxjs@^6.1.0, rxjs@^6.6.0: +rxjs@^6.6.0: version "6.6.7" resolved "https://registry.yarnpkg.com/rxjs/-/rxjs-6.6.7.tgz#90ac018acabf491bf65044235d5863c4dab804c9" integrity sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ== dependencies: tslib "^1.9.0" +safe-array-concat@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/safe-array-concat/-/safe-array-concat-1.0.1.tgz#91686a63ce3adbea14d61b14c99572a8ff84754c" + integrity sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.2.1" + has-symbols "^1.0.3" + isarray "^2.0.5" + safe-buffer@*, safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@~5.2.0: version "5.2.1" resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" @@ -5346,11 +4269,6 @@ safe-buffer@~5.1.0, safe-buffer@~5.1.1: resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -safe-json-stringify@~1: - version "1.2.0" - resolved "https://registry.yarnpkg.com/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz#356e44bc98f1f93ce45df14bcd7c01cda86e0afd" - integrity sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg== - safe-regex-test@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/safe-regex-test/-/safe-regex-test-1.0.0.tgz#793b874d524eb3640d1873aad03596db2d4f2295" @@ -5360,12 +4278,10 @@ safe-regex-test@^1.0.0: get-intrinsic "^1.1.3" is-regex "^1.1.4" -safe-regex@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" - integrity sha512-aJXcif4xnaNUzvUuC5gcb46oTS7zvg4jpMTnuqtrEPlR3vFr4pxtdTwaF1Qs3Enjn9HK+ZlwQui+a7z0SywIzg== - dependencies: - ret "~0.1.10" +safe-stable-stringify@^2.3.1: + version "2.4.3" + resolved "https://registry.yarnpkg.com/safe-stable-stringify/-/safe-stable-stringify-2.4.3.tgz#138c84b6f6edb3db5f8ef3ef7115b8f55ccbf886" + integrity sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g== "safer-buffer@>= 2.1.2 < 3": version "2.1.2" @@ -5378,26 +4294,38 @@ samsam@1.3.0: integrity sha512-1HwIYD/8UlOtFS3QO3w7ey+SdSDFE4HRNLZoZRYVQefrOY3l17epswImeB1ijgJFQJodIaHcwkp3r/myBjFVbg== sax@>=0.6.0: - version "1.2.4" - resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" - integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== + version "1.3.0" + resolved "https://registry.yarnpkg.com/sax/-/sax-1.3.0.tgz#a5dbe77db3be05c9d1ee7785dbd3ea9de51593d0" + integrity sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA== -"semver@2 || 3 || 4 || 5", semver@^5.5.0: - version "5.7.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" - integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== +secure-json-parse@^2.4.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/secure-json-parse/-/secure-json-parse-2.7.0.tgz#5a5f9cd6ae47df23dba3151edd06855d47e09862" + integrity sha512-6aU+Rwsezw7VR8/nyvKTx8QpWH9FrcYiXXlqC4z5d5XQBDRqtbfsRjnwGyqbi3gddNtWHuEk9OANUotL26qKUw== -semver@7.3.8, semver@^7.3.2, semver@^7.3.4, semver@^7.3.5, semver@^7.3.7, semver@^7.3.8: +"semver@2 || 3 || 4 || 5": + version "5.7.2" + resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.2.tgz#48d55db737c3287cd4835e17fa13feace1c41ef8" + integrity sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g== + +semver@7.3.8: version "7.3.8" resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.8.tgz#07a78feafb3f7b32347d725e33de7e2a2df67798" integrity sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A== dependencies: lru-cache "^6.0.0" -semver@^6.0.0, semver@^6.3.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" - integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== +semver@^6.0.0, semver@^6.3.0, semver@^6.3.1: + version "6.3.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" + integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== + +semver@^7.3.4, semver@^7.5.4: + version "7.5.4" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" + integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== + dependencies: + lru-cache "^6.0.0" sentence-case@^3.0.4: version "3.0.4" @@ -5425,22 +4353,29 @@ set-blocking@^2.0.0: resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== -set-value@^2.0.0, set-value@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.1.tgz#a18d40530e6f07de4228c7defe4227af8cad005b" - integrity sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw== +set-function-length@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/set-function-length/-/set-function-length-1.1.1.tgz#4bc39fafb0307224a33e106a7d35ca1218d659ed" + integrity sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ== dependencies: - extend-shallow "^2.0.1" - is-extendable "^0.1.1" - is-plain-object "^2.0.3" - split-string "^3.0.1" + define-data-property "^1.1.1" + get-intrinsic "^1.2.1" + gopd "^1.0.1" + has-property-descriptors "^1.0.0" -shebang-command@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea" - integrity sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg== +set-function-name@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/set-function-name/-/set-function-name-2.0.1.tgz#12ce38b7954310b9f61faa12701620a0c882793a" + integrity sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA== dependencies: - shebang-regex "^1.0.0" + define-data-property "^1.0.1" + functions-have-names "^1.2.3" + has-property-descriptors "^1.0.0" + +setimmediate@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" + integrity sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA== shebang-command@^2.0.0: version "2.0.0" @@ -5449,26 +4384,12 @@ shebang-command@^2.0.0: dependencies: shebang-regex "^3.0.0" -shebang-regex@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" - integrity sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ== - shebang-regex@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== -shelljs@0.7.6: - version "0.7.6" - resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.7.6.tgz#379cccfb56b91c8601e4793356eb5382924de9ad" - integrity sha512-sK/rjl+frweS4RL1ifxTb7eIXQaliSCDN5meqwwfDIHSWU7zH2KPTa/2hS6EAgGw7wHzJ3rQHfhnLzktfagSZA== - dependencies: - glob "^7.0.0" - interpret "^1.0.0" - rechoir "^0.6.2" - -shelljs@0.8.5, shelljs@^0.8.5, shelljs@~0.8.4: +shelljs@^0.8.5: version "0.8.5" resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c" integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow== @@ -5477,22 +4398,15 @@ shelljs@0.8.5, shelljs@^0.8.5, shelljs@~0.8.4: interpret "^1.0.0" rechoir "^0.6.2" -shiki@^0.11.1: - version "0.11.1" - resolved "https://registry.yarnpkg.com/shiki/-/shiki-0.11.1.tgz#df0f719e7ab592c484d8b73ec10e215a503ab8cc" - integrity sha512-EugY9VASFuDqOexOgXR18ZV+TbFrQHeCpEYaXamO+SZlsnT/2LxuLBX25GGtIrwaEVFXUAbUQ601SWE2rMwWHA== +shiki@^0.14.1: + version "0.14.5" + resolved "https://registry.yarnpkg.com/shiki/-/shiki-0.14.5.tgz#375dd214e57eccb04f0daf35a32aa615861deb93" + integrity sha512-1gCAYOcmCFONmErGTrS1fjzJLA7MGZmKzrBNX7apqSwhyITJg2O102uFzXUeBxNnEkDA9vHIKLyeKq0V083vIw== dependencies: - jsonc-parser "^3.0.0" - vscode-oniguruma "^1.6.1" - vscode-textmate "^6.0.0" - -shx@^0.3.3: - version "0.3.4" - resolved "https://registry.yarnpkg.com/shx/-/shx-0.3.4.tgz#74289230b4b663979167f94e1935901406e40f02" - integrity sha512-N6A9MLVqjxZYcVn8hLmtneQWIJtp8IKzMP4eMnx+nqkvXoqinUPCbUFLp2UcWTEIUONhlk0ewxr/jaVGlc+J+g== - dependencies: - minimist "^1.2.3" - shelljs "^0.8.5" + ansi-sequence-parser "^1.1.0" + jsonc-parser "^3.2.0" + vscode-oniguruma "^1.7.0" + vscode-textmate "^8.0.0" side-channel@^1.0.4: version "1.0.4" @@ -5503,7 +4417,7 @@ side-channel@^1.0.4: get-intrinsic "^1.0.2" object-inspect "^1.9.0" -signal-exit@^3.0.0, signal-exit@^3.0.2, signal-exit@^3.0.3: +signal-exit@^3.0.2, signal-exit@^3.0.3: version "3.0.7" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== @@ -5520,18 +4434,6 @@ sinon@10.0.0: nise "^4.1.0" supports-color "^7.1.0" -sinon@^14.0.2: - version "14.0.2" - resolved "https://registry.yarnpkg.com/sinon/-/sinon-14.0.2.tgz#585a81a3c7b22cf950762ac4e7c28eb8b151c46f" - integrity sha512-PDpV0ZI3ZCS3pEqx0vpNp6kzPhHrLx72wA0G+ZLaaJjLIYeE0n8INlgaohKuGy7hP0as5tbUd23QWu5U233t+w== - dependencies: - "@sinonjs/commons" "^2.0.0" - "@sinonjs/fake-timers" "^9.1.2" - "@sinonjs/samsam" "^7.0.1" - diff "^5.0.0" - nise "^5.1.2" - supports-color "^7.2.0" - sinon@^5.1.1: version "5.1.1" resolved "https://registry.yarnpkg.com/sinon/-/sinon-5.1.1.tgz#19c59810ffb733ea6e76a28b94a71fc4c2f523b8" @@ -5558,55 +4460,14 @@ snake-case@^3.0.4: dot-case "^3.0.4" tslib "^2.0.3" -snapdragon-node@^2.0.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b" - integrity sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw== +sonic-boom@^3.0.0, sonic-boom@^3.7.0: + version "3.7.0" + resolved "https://registry.yarnpkg.com/sonic-boom/-/sonic-boom-3.7.0.tgz#b4b7b8049a912986f4a92c51d4660b721b11f2f2" + integrity sha512-IudtNvSqA/ObjN97tfgNmOKyDOs4dNcg4cUUsHDebqsgb8wGBBwb31LIgShNO8fye0dFI52X1+tFoKKI6Rq1Gg== dependencies: - define-property "^1.0.0" - isobject "^3.0.0" - snapdragon-util "^3.0.1" + atomic-sleep "^1.0.0" -snapdragon-util@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz#f956479486f2acd79700693f6f7b805e45ab56e2" - integrity sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ== - dependencies: - kind-of "^3.2.0" - -snapdragon@^0.8.1: - version "0.8.2" - resolved "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz#64922e7c565b0e14204ba1aa7d6964278d25182d" - integrity sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg== - dependencies: - base "^0.11.1" - debug "^2.2.0" - define-property "^0.2.5" - extend-shallow "^2.0.1" - map-cache "^0.2.2" - source-map "^0.5.6" - source-map-resolve "^0.5.0" - use "^3.1.0" - -sort-keys@^4.0.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/sort-keys/-/sort-keys-4.2.0.tgz#6b7638cee42c506fff8c1cecde7376d21315be18" - integrity sha512-aUYIEU/UviqPgc8mHR6IW1EGxkAXpeRETYcrzg8cLAvUPZcpAlleSXHV2mY7G12GphSH6Gzv+4MMVSSkbdteHg== - dependencies: - is-plain-obj "^2.0.0" - -source-map-resolve@^0.5.0: - version "0.5.3" - resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a" - integrity sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw== - dependencies: - atob "^2.1.2" - decode-uri-component "^0.2.0" - resolve-url "^0.2.1" - source-map-url "^0.4.0" - urix "^0.1.0" - -source-map-support@~0.5.19: +source-map-support@^0.5.21: version "0.5.21" resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== @@ -5614,16 +4475,6 @@ source-map-support@~0.5.19: buffer-from "^1.0.0" source-map "^0.6.0" -source-map-url@^0.4.0: - version "0.4.1" - resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56" - integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw== - -source-map@^0.5.6: - version "0.5.7" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" - integrity sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ== - source-map@^0.6.0, source-map@^0.6.1: version "0.6.1" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" @@ -5667,13 +4518,6 @@ spdx-license-ids@^3.0.0: resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz#50c0d8c40a14ec1bf449bae69a0ea4685a9d9f95" integrity sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g== -split-string@^3.0.1, split-string@^3.0.2: - version "3.1.0" - resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2" - integrity sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw== - dependencies: - extend-shallow "^3.0.0" - split2@^3.0.0: version "3.2.2" resolved "https://registry.yarnpkg.com/split2/-/split2-3.2.2.tgz#bf2cf2a37d838312c249c89206fd7a17dd12365f" @@ -5681,28 +4525,17 @@ split2@^3.0.0: dependencies: readable-stream "^3.0.0" +split2@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/split2/-/split2-4.2.0.tgz#c9c5920904d148bab0b9f67145f245a86aadbfa4" + integrity sha512-UcjcJOWknrNkF6PLX83qcHM6KHgVKNkV62Y8a5uYDVv9ydGQVwAHMKqHdJje1VTWpljG0WYpCDhrCdAOYH4TWg== + sprintf-js@~1.0.2: version "1.0.3" resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== -static-extend@^0.1.1: - version "0.1.2" - resolved "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz#60809c39cbff55337226fd5e0b520f341f1fb5c6" - integrity sha512-72E9+uLc27Mt718pMHt9VMNiAL4LMsmDbBva8mxWUCkT07fSzEGMYUCk0XWY6lp0j6RBAG4cJ3mWuZv2OE3s0g== - dependencies: - define-property "^0.2.5" - object-copy "^0.1.0" - -string-width@^2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" - integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== - dependencies: - is-fullwidth-code-point "^2.0.0" - strip-ansi "^4.0.0" - -string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -5711,23 +4544,32 @@ string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2 is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" -string.prototype.trimend@^1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz#c4a27fa026d979d79c04f17397f250a462944533" - integrity sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ== +string.prototype.trim@^1.2.8: + version "1.2.8" + resolved "https://registry.yarnpkg.com/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz#f9ac6f8af4bd55ddfa8895e6aea92a96395393bd" + integrity sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" + define-properties "^1.2.0" + es-abstract "^1.22.1" -string.prototype.trimstart@^1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz#e90ab66aa8e4007d92ef591bbf3cd422c56bdcf4" - integrity sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA== +string.prototype.trimend@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz#1bb3afc5008661d73e2dc015cd4853732d6c471e" + integrity sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA== dependencies: call-bind "^1.0.2" - define-properties "^1.1.4" - es-abstract "^1.20.4" + define-properties "^1.2.0" + es-abstract "^1.22.1" + +string.prototype.trimstart@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz#d4cdb44b83a4737ffbac2d406e405d43d0184298" + integrity sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.2.0" + es-abstract "^1.22.1" string_decoder@^1.1.1: version "1.3.0" @@ -5743,13 +4585,6 @@ string_decoder@~1.1.1: dependencies: safe-buffer "~5.1.0" -strip-ansi@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" - integrity sha512-4XaJ2zQdCzROZDivEVIDPkcQn8LMFSa8kj8Gxb/Lnwzv9A8VctNZ+lfivC/sV3ivW8ElJTERXZoPBRrZKkNKow== - dependencies: - ansi-regex "^3.0.0" - strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" @@ -5757,7 +4592,7 @@ strip-ansi@^6.0.0, strip-ansi@^6.0.1: dependencies: ansi-regex "^5.0.1" -strip-bom@3.0.0, strip-bom@^3.0.0: +strip-bom@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== @@ -5767,11 +4602,6 @@ strip-bom@^4.0.0: resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== -strip-eof@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" - integrity sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q== - strip-final-newline@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" @@ -5784,17 +4614,12 @@ strip-indent@^3.0.0: dependencies: min-indent "^1.0.0" -strip-json-comments@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" - integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== - -strip-json-comments@3.1.1, strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: +strip-json-comments@3.1.1, strip-json-comments@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== -supports-color@8.1.1, supports-color@^8.1.0: +supports-color@8.1.1: version "8.1.1" resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== @@ -5808,47 +4633,18 @@ supports-color@^5.3.0, supports-color@^5.4.0: dependencies: has-flag "^3.0.0" -supports-color@^7.0.0, supports-color@^7.1.0, supports-color@^7.2.0: +supports-color@^7.1.0: version "7.2.0" resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== dependencies: has-flag "^4.0.0" -supports-hyperlinks@^2.1.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz#4f77b42488765891774b70c79babd87f9bd594bb" - integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ== - dependencies: - has-flag "^4.0.0" - supports-color "^7.0.0" - supports-preserve-symlinks-flag@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== -tar-fs@^2.0.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/tar-fs/-/tar-fs-2.1.1.tgz#489a15ab85f1f0befabb370b7de4f9eb5cbe8784" - integrity sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng== - dependencies: - chownr "^1.1.1" - mkdirp-classic "^0.5.2" - pump "^3.0.0" - tar-stream "^2.1.4" - -tar-stream@^2.1.4, tar-stream@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/tar-stream/-/tar-stream-2.2.0.tgz#acad84c284136b060dc3faa64474aa9aebd77287" - integrity sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ== - dependencies: - bl "^4.0.3" - end-of-stream "^1.4.1" - fs-constants "^1.0.0" - inherits "^2.0.3" - readable-stream "^3.1.1" - test-exclude@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-6.0.0.tgz#04a8698661d805ea6fa293b6cb9e63ac044ef15e" @@ -5868,6 +4664,13 @@ text-table@^0.2.0: resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== +thread-stream@^2.0.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/thread-stream/-/thread-stream-2.3.0.tgz#4fc07fb39eff32ae7bad803cb7dd9598349fed33" + integrity sha512-kaDqm1DET9pp3NXwR8382WHbnpXnRkN9xGN9dQt3B2+dmXiW8X1SOwmFOxAErEQ47ObhZ96J6yhZNXuyCOL7KA== + dependencies: + real-require "^0.2.0" + through2@^4.0.0: version "4.0.2" resolved "https://registry.yarnpkg.com/through2/-/through2-4.0.2.tgz#a7ce3ac2a7a8b0b966c80e7c49f0484c3b239764" @@ -5887,33 +4690,11 @@ tmp@^0.0.33: dependencies: os-tmpdir "~1.0.2" -tmp@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.1.0.tgz#ee434a4e22543082e294ba6201dcc6eafefa2877" - integrity sha512-J7Z2K08jbGcdA1kkQpJSqLF6T0tdQqpR2pnSUXsIchbPdTI9v3e85cLW0d6WDhwuAleOV71j2xWs8qMPfK7nKw== - dependencies: - rimraf "^2.6.3" - to-fast-properties@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== -to-object-path@^0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz#297588b7b0e7e0ac08e04e672f85c1f4999e17af" - integrity sha512-9mWHdnGRuh3onocaHzukyvCZhzvr6tiflAy/JRFXcJX0TjgfWA9pk9t8CMbzmBE4Jfw58pXbkngtBtqYxzNEyg== - dependencies: - kind-of "^3.0.2" - -to-regex-range@^2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38" - integrity sha512-ZZWNfCjUokXXDGXFpZehJIkZqq91BcULFq/Pi7M5i4JnxXdhMKAK682z8bCW3o8Hj1wuuzoKcW3DfVzaP6VuNg== - dependencies: - is-number "^3.0.0" - repeat-string "^1.6.1" - to-regex-range@^5.0.1: version "5.0.1" resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" @@ -5921,24 +4702,15 @@ to-regex-range@^5.0.1: dependencies: is-number "^7.0.0" -to-regex@^3.0.1, to-regex@^3.0.2: - version "3.0.2" - resolved "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz#13cfdd9b336552f30b51f33a8ae1b42a7a7599ce" - integrity sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw== - dependencies: - define-property "^2.0.2" - extend-shallow "^3.0.2" - regex-not "^1.0.2" - safe-regex "^1.1.0" - tough-cookie@*: - version "4.0.0" - resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" - integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg== + version "4.1.3" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.1.3.tgz#97b9adb0728b42280aa3d814b6b999b2ff0318bf" + integrity sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw== dependencies: psl "^1.1.33" punycode "^2.1.1" - universalify "^0.1.2" + universalify "^0.2.0" + url-parse "^1.5.3" tr46@~0.0.3: version "0.0.3" @@ -5950,10 +4722,15 @@ trim-newlines@^3.0.0: resolved "https://registry.yarnpkg.com/trim-newlines/-/trim-newlines-3.0.1.tgz#260a5d962d8b752425b32f3a7db0dcacd176c144" integrity sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw== -ts-node@^10.0.0, ts-node@^10.4.0, ts-node@^10.8.1: - version "10.9.1" - resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.1.tgz#e73de9102958af9e1f0b168a6ff320e25adcff4b" - integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== +ts-api-utils@^1.0.1: + version "1.0.3" + resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.0.3.tgz#f12c1c781d04427313dbac808f453f050e54a331" + integrity sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg== + +ts-node@^10.8.1, ts-node@^10.9.1, ts-node@^10.9.2: + version "10.9.2" + resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.2.tgz#70f021c9e185bccdca820e26dc413805c101c71f" + integrity sha512-f0FFpIdcHgn8zcPSbf1dRevwt047YMnaiJM3u2w2RewrB+fob/zePZcrOyQoLMMO7aBIddLcQIEK5dYjkLnGrQ== dependencies: "@cspotcode/source-map-support" "^0.8.0" "@tsconfig/node10" "^1.0.7" @@ -5969,46 +4746,44 @@ ts-node@^10.0.0, ts-node@^10.4.0, ts-node@^10.8.1: v8-compile-cache-lib "^3.0.1" yn "3.1.1" -ts-retry-promise@^0.7.0: - version "0.7.0" - resolved "https://registry.yarnpkg.com/ts-retry-promise/-/ts-retry-promise-0.7.0.tgz#08f2dcbbf5d2981495841cb63389a268324e8147" - integrity sha512-x6yWZXC4BfXy4UyMweOFvbS1yJ/Y5biSz/mEPiILtJZLrqD3ZxIpzVOGGgifHHdaSe3WxzFRtsRbychI6zofOg== +ts-patch@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/ts-patch/-/ts-patch-3.1.1.tgz#40207ee4f75d4a6cd7bc49dd16094a10a507eaa6" + integrity sha512-ReGYz9jQYC80PFafBx25TC0UI9cSgmUBtpT+WIy8IrhpLVzEHf430k03XQYOMldQMyZDBbzn5fBPELgtIl65cA== + dependencies: + chalk "^4.1.2" + global-prefix "^3.0.0" + minimist "^1.2.8" + resolve "^1.22.2" + semver "^7.5.4" + strip-ansi "^6.0.1" -tsconfig-paths@^3.14.1: - version "3.14.1" - resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz#ba0734599e8ea36c862798e920bcf163277b137a" - integrity sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ== +ts-retry-promise@^0.7.1: + version "0.7.1" + resolved "https://registry.yarnpkg.com/ts-retry-promise/-/ts-retry-promise-0.7.1.tgz#176d6eee6415f07b6c7c286d3657355e284a6906" + integrity sha512-NhHOCZ2AQORvH42hOPO5UZxShlcuiRtm7P2jIq2L2RY3PBxw2mLnUsEdHrIslVBFya1v5aZmrR55lWkzo13LrQ== + +tsconfig-paths@^3.14.2: + version "3.14.2" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.14.2.tgz#6e32f1f79412decd261f92d633a9dc1cfa99f088" + integrity sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g== dependencies: "@types/json5" "^0.0.29" - json5 "^1.0.1" + json5 "^1.0.2" minimist "^1.2.6" strip-bom "^3.0.0" -tslib@^1.8.1, tslib@^1.9.0: +tslib@^1.9.0: version "1.14.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== -tslib@^2.0.0, tslib@^2.0.3, tslib@^2.3.1, tslib@^2.5.0: - version "2.5.0" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.5.0.tgz#42bfed86f5787aeb41d031866c8f402429e0fddf" - integrity sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg== - -tsutils@^3.21.0: - version "3.21.0" - resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" - integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== - dependencies: - tslib "^1.8.1" - -ttypescript@^1.5.15: - version "1.5.15" - resolved "https://registry.yarnpkg.com/ttypescript/-/ttypescript-1.5.15.tgz#e45550ad69289d06d3bc3fd4a3c87e7c1ef3eba7" - integrity sha512-48ykDNHzFnPMnv4hYX1P8Q84TvCZyL1QlFxeuxsuZ48X2+ameBgPenvmCkHJtoOSxpoWTWi8NcgNrRnVDOmfSg== - dependencies: - resolve ">=1.9.0" +tslib@^2.0.3, tslib@^2.6.1, tslib@^2.6.2: + version "2.6.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.2.tgz#703ac29425e7b37cd6fd456e92404d46d1f3e4ae" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== -tunnel-agent@*, tunnel-agent@^0.6.0: +tunnel-agent@*: version "0.6.0" resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" integrity sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w== @@ -6022,7 +4797,7 @@ type-check@^0.4.0, type-check@~0.4.0: dependencies: prelude-ls "^1.2.1" -type-detect@4.0.8, type-detect@^4.0.0, type-detect@^4.0.5, type-detect@^4.0.8: +type-detect@4.0.8, type-detect@^4.0.0, type-detect@^4.0.8: version "4.0.8" resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== @@ -6052,6 +4827,36 @@ type-fest@^0.8.0, type-fest@^0.8.1: resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== +typed-array-buffer@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz#18de3e7ed7974b0a729d3feecb94338d1472cd60" + integrity sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.2.1" + is-typed-array "^1.1.10" + +typed-array-byte-length@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz#d787a24a995711611fb2b87a4052799517b230d0" + integrity sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA== + dependencies: + call-bind "^1.0.2" + for-each "^0.3.3" + has-proto "^1.0.1" + is-typed-array "^1.1.10" + +typed-array-byte-offset@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz#cbbe89b51fdef9cd6aaf07ad4707340abbc4ea0b" + integrity sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg== + dependencies: + available-typed-arrays "^1.0.5" + call-bind "^1.0.2" + for-each "^0.3.3" + has-proto "^1.0.1" + is-typed-array "^1.1.10" + typed-array-length@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/typed-array-length/-/typed-array-length-1.0.4.tgz#89d83785e5c4098bec72e08b319651f0eac9c1bb" @@ -6073,21 +4878,26 @@ typedoc-plugin-missing-exports@0.23.0: resolved "https://registry.yarnpkg.com/typedoc-plugin-missing-exports/-/typedoc-plugin-missing-exports-0.23.0.tgz#076df6ffce4d84e8097be009b7c62a17d58477a5" integrity sha512-9smahDSsFRno9ZwoEshQDuIYMHWGB1E6LUud5qMxR2wNZ0T4DlZz0QjoK3HzXtX34mUpTH0dYtt7NQUK4D6B6Q== -typedoc@0.23.16: - version "0.23.16" - resolved "https://registry.yarnpkg.com/typedoc/-/typedoc-0.23.16.tgz#09881ada725c2190ac5d3bb0edadcc5bfeda4bfe" - integrity sha512-rumYsCeNRXlyuZVzefD7050n7ptL2uudsCJg50dY0v/stKniqIlRpvx/F/6expC0/Q6Dbab+g/JpZuB7Sw90FA== +typedoc@^0.25.3: + version "0.25.3" + resolved "https://registry.yarnpkg.com/typedoc/-/typedoc-0.25.3.tgz#53c6d668e1001b3d488e9a750fcdfb05433554c0" + integrity sha512-Ow8Bo7uY1Lwy7GTmphRIMEo6IOZ+yYUyrc8n5KXIZg1svpqhZSWgni2ZrDhe+wLosFS8yswowUzljTAV/3jmWw== dependencies: lunr "^2.3.9" - marked "^4.0.19" - minimatch "^5.1.0" - shiki "^0.11.1" + marked "^4.3.0" + minimatch "^9.0.3" + shiki "^0.14.1" -typescript@^4.1.3, typescript@^4.6.4, typescript@^4.9.5: +typescript@^4.6.4, typescript@^4.9.5: version "4.9.5" resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== +typescript@^5.3.3: + version "5.3.3" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-5.3.3.tgz#b3ce6ba258e72e6305ba66f5c9b452aaee3ffe37" + integrity sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw== + unbox-primitive@^1.0.2: version "1.0.2" resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" @@ -6098,34 +4908,26 @@ unbox-primitive@^1.0.2: has-symbols "^1.0.3" which-boxed-primitive "^1.0.2" -union-value@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.1.tgz#0b6fe7b835aecda61c6ea4d4f02c14221e109847" - integrity sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg== - dependencies: - arr-union "^3.1.0" - get-value "^2.0.6" - is-extendable "^0.1.1" - set-value "^2.0.1" +undici-types@~5.26.4: + version "5.26.5" + resolved "https://registry.yarnpkg.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" + integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== -universalify@^0.1.0, universalify@^0.1.2: +universalify@^0.1.0: version "0.1.2" resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== +universalify@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.2.0.tgz#6451760566fa857534745ab1dde952d1b1761be0" + integrity sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg== + universalify@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== -unset-value@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559" - integrity sha512-PcA2tsuGSF9cnySLHTLSh2qrQiJ70mn+r+Glzxv2TWZblxsxCC52BDlZoPCsz7STd9pN7EZetkWZBAvk4cgZdQ== - dependencies: - has-value "^0.3.1" - isobject "^3.0.0" - update-browserslist-db@^1.0.4: version "1.0.4" resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz#dbfc5a789caa26b1db8990796c2c8ebbce304824" @@ -6155,15 +4957,13 @@ uri-js@^4.2.2: dependencies: punycode "^2.1.0" -urix@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72" - integrity sha512-Am1ousAhSLBeB9cG/7k7r2R0zj50uDRlZHPGbazid5s9rlF1F/QKYObEKSIunSjIOkJZqwRRLpvewjEkM7pSqg== - -use@^3.1.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" - integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== +url-parse@^1.5.3: + version "1.5.10" + resolved "https://registry.yarnpkg.com/url-parse/-/url-parse-1.5.10.tgz#9d3c2f736c1d75dd3bd2be507dcc111f1e2ea9c1" + integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== + dependencies: + querystringify "^2.1.1" + requires-port "^1.0.0" util-deprecate@^1.0.1, util-deprecate@~1.0.1: version "1.0.2" @@ -6188,15 +4988,15 @@ validate-npm-package-license@^3.0.1: spdx-correct "^3.0.0" spdx-expression-parse "^3.0.0" -vscode-oniguruma@^1.6.1: - version "1.6.2" - resolved "https://registry.yarnpkg.com/vscode-oniguruma/-/vscode-oniguruma-1.6.2.tgz#aeb9771a2f1dbfc9083c8a7fdd9cccaa3f386607" - integrity sha512-KH8+KKov5eS/9WhofZR8M8dMHWN2gTxjMsG4jd04YhpbPR91fUj7rYQ2/XjeHCJWbg7X++ApRIU9NUwM2vTvLA== +vscode-oniguruma@^1.7.0: + version "1.7.0" + resolved "https://registry.yarnpkg.com/vscode-oniguruma/-/vscode-oniguruma-1.7.0.tgz#439bfad8fe71abd7798338d1cd3dc53a8beea94b" + integrity sha512-L9WMGRfrjOhgHSdOYgCt/yRMsXzLDJSL7BPrOZt73gU0iWO4mpqzqQzOz5srxqTvMBaR0XZTSrVWo4j55Rc6cA== -vscode-textmate@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/vscode-textmate/-/vscode-textmate-6.0.0.tgz#a3777197235036814ac9a92451492f2748589210" - integrity sha512-gu73tuZfJgu+mvCSy4UZwd2JXykjK9zAZsfmDeut5dx/1a7FeTk0XwJsSuqQn+cuMCGVbIBfl+s53X4T19DnzQ== +vscode-textmate@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/vscode-textmate/-/vscode-textmate-8.0.0.tgz#2c7a3b1163ef0441097e0b5d6389cd5504b59e5d" + integrity sha512-AFbieoL7a5LMqcnOF04ji+rpXadgOXnZsxQr//r83kLPr7biP7am3g9zbaZIaBGwBRWeSvoMD4mgPdX3e4NWBg== webidl-conversions@^3.0.0: version "3.0.1" @@ -6241,43 +5041,35 @@ which-module@^2.0.0: resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a" integrity sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q== -which-typed-array@^1.1.9: - version "1.1.9" - resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.9.tgz#307cf898025848cf995e795e8423c7f337efbde6" - integrity sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA== +which-typed-array@^1.1.11, which-typed-array@^1.1.13: + version "1.1.13" + resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.13.tgz#870cd5be06ddb616f504e7b039c4c24898184d36" + integrity sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow== dependencies: available-typed-arrays "^1.0.5" - call-bind "^1.0.2" + call-bind "^1.0.4" for-each "^0.3.3" gopd "^1.0.1" has-tostringtag "^1.0.0" - is-typed-array "^1.1.10" - -which@2.0.2, which@^2.0.1: - version "2.0.2" - resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" - integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== - dependencies: - isexe "^2.0.0" -which@^1.2.14, which@^1.2.9: +which@^1.3.1: version "1.3.1" resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== dependencies: isexe "^2.0.0" -widest-line@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" - integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== dependencies: - string-width "^4.0.0" + isexe "^2.0.0" -wireit@^0.9.3, wireit@^0.9.5: - version "0.9.5" - resolved "https://registry.yarnpkg.com/wireit/-/wireit-0.9.5.tgz#7c3622f6ff5e63b7fac05783baf82f967f52562c" - integrity sha512-dKKNAwLxQjbPPMrltPxMUFKvLy2z6hlVjvR/qitvPm8GEQyb/1QYBG7ObvOQLsi95uAXpkWLJXBYkCKeVcMVgA== +wireit@^0.14.1: + version "0.14.1" + resolved "https://registry.yarnpkg.com/wireit/-/wireit-0.14.1.tgz#83b63598503573db6722ad49b1fe15b57ee71890" + integrity sha512-q5sixPM/vKQEpyaub6J9QoHAFAF9g4zBdnjoYelH9/RLAekcUf3x1dmFLACGZ6nYjqehCsTlXC1irmzU7znPhA== dependencies: braces "^3.0.2" chokidar "^3.5.3" @@ -6285,15 +5077,10 @@ wireit@^0.9.3, wireit@^0.9.5: jsonc-parser "^3.0.0" proper-lockfile "^4.1.2" -word-wrap@^1.0.3, word-wrap@^1.2.3: - version "1.2.3" - resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" - integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== - -workerpool@6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.0.tgz#827d93c9ba23ee2019c3ffaff5c27fccea289e8b" - integrity sha512-Rsk5qQHJ9eowMH28Jwhe8HEbmdYDX4lwoMWshiCXugjtHqMD9ZbiqSDLxcsfdqsETPzVUtX5s1Z5kStiIM6l4A== +workerpool@6.2.1: + version "6.2.1" + resolved "https://registry.yarnpkg.com/workerpool/-/workerpool-6.2.1.tgz#46fc150c17d826b86a008e5a4508656777e9c343" + integrity sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw== wrap-ansi@^6.2.0: version "6.2.0" @@ -6328,22 +5115,10 @@ write-file-atomic@^3.0.0: signal-exit "^3.0.2" typedarray-to-buffer "^3.1.5" -write-json-file@^4.1.1: - version "4.3.0" - resolved "https://registry.yarnpkg.com/write-json-file/-/write-json-file-4.3.0.tgz#908493d6fd23225344af324016e4ca8f702dd12d" - integrity sha512-PxiShnxf0IlnQuMYOPPhPkhExoCQuTUNPOa/2JWCYTmBquU9njyyDuwRKN26IZBlp4yn1nt+Agh2HOOBl+55HQ== - dependencies: - detect-indent "^6.0.0" - graceful-fs "^4.1.15" - is-plain-obj "^2.0.0" - make-dir "^3.0.0" - sort-keys "^4.0.0" - write-file-atomic "^3.0.0" - -xml2js@^0.4.22: - version "0.4.23" - resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.23.tgz#a0c69516752421eb2ac758ee4d4ccf58843eac66" - integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== +xml2js@^0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.5.0.tgz#d9440631fbb2ed800203fad106f2724f62c493b7" + integrity sha512-drPFnkQJik/O+uPKpqSgr22mpuFHqKdbS835iAQrUC73L2F5WkboIRd63ai/2Yg6I1jzifPFKH2NTK+cfglkIA== dependencies: sax ">=0.6.0" xmlbuilder "~11.0.0" @@ -6396,10 +5171,10 @@ yargs-parser@^20.2.2, yargs-parser@^20.2.3: resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee" integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== -yargs-parser@^21.0.0: - version "21.0.1" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-21.0.1.tgz#0267f286c877a4f0f728fceb6f8a3e4cb95c6e35" - integrity sha512-9BK1jFpLzJROCI5TzwZL/TU4gqjK5xiHV/RfWLOahrjAko/e4DJkRDZQXfvqAsiZzzYhgAzbgz6lg48jcm4GLg== +yargs-parser@^21.1.1: + version "21.1.1" + resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-21.1.1.tgz#9096bceebf990d21bb31fa9516e0ede294a77d35" + integrity sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw== yargs-unparser@2.0.0: version "2.0.0" @@ -6442,17 +5217,17 @@ yargs@^15.0.2: yargs-parser "^18.1.2" yargs@^17.0.0: - version "17.5.1" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.5.1.tgz#e109900cab6fcb7fd44b1d8249166feb0b36e58e" - integrity sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA== + version "17.7.1" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.7.1.tgz#34a77645201d1a8fc5213ace787c220eabbd0967" + integrity sha512-cwiTb08Xuv5fqF4AovYacTFNxk62th7LKJ6BL9IGUpTJrWoU7/7WdQGTP2SjKf1dUNBGzDd28p/Yfs/GI6JrLw== dependencies: - cliui "^7.0.2" + cliui "^8.0.1" escalade "^3.1.1" get-caller-file "^2.0.5" require-directory "^2.1.1" string-width "^4.2.3" y18n "^5.0.5" - yargs-parser "^21.0.0" + yargs-parser "^21.1.1" yn@3.1.1: version "3.1.1" @@ -6463,12 +5238,3 @@ yocto-queue@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== - -zip-stream@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/zip-stream/-/zip-stream-4.1.0.tgz#51dd326571544e36aa3f756430b313576dc8fc79" - integrity sha512-zshzwQW7gG7hjpBlgeQP9RuyPGNxvJdzR8SUM3QhxCnLjWN2E7j3dOvpeDcQoETfHx0urRS7EtmVToql7YpU4A== - dependencies: - archiver-utils "^2.1.0" - compress-commons "^4.1.0" - readable-stream "^3.6.0"