@rockcarver/frodo-cli 0.18.2-8 → 0.19.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +119 -1
- package/esm/app.js +4 -1
- package/esm/app.js.map +1 -1
- package/esm/cli/FrodoCommand.js +133 -0
- package/esm/cli/FrodoCommand.js.map +1 -0
- package/esm/cli/_template/something-delete.js +9 -15
- package/esm/cli/_template/something-delete.js.map +1 -1
- package/esm/cli/_template/something-describe.js +9 -15
- package/esm/cli/_template/something-describe.js.map +1 -1
- package/esm/cli/_template/something-else-delete.js +9 -15
- package/esm/cli/_template/something-else-delete.js.map +1 -1
- package/esm/cli/_template/something-else-describe.js +9 -15
- package/esm/cli/_template/something-else-describe.js.map +1 -1
- package/esm/cli/_template/something-else-export.js +9 -15
- package/esm/cli/_template/something-else-export.js.map +1 -1
- package/esm/cli/_template/something-else-import.js +9 -15
- package/esm/cli/_template/something-else-import.js.map +1 -1
- package/esm/cli/_template/something-else-list.js +9 -15
- package/esm/cli/_template/something-else-list.js.map +1 -1
- package/esm/cli/_template/something-else.js +8 -8
- package/esm/cli/_template/something-else.js.map +1 -1
- package/esm/cli/_template/something-export.js +9 -15
- package/esm/cli/_template/something-export.js.map +1 -1
- package/esm/cli/_template/something-import.js +9 -15
- package/esm/cli/_template/something-import.js.map +1 -1
- package/esm/cli/_template/something-list.js +9 -15
- package/esm/cli/_template/something-list.js.map +1 -1
- package/esm/cli/_template/something-other-delete.js +9 -15
- package/esm/cli/_template/something-other-delete.js.map +1 -1
- package/esm/cli/_template/something-other-describe.js +9 -15
- package/esm/cli/_template/something-other-describe.js.map +1 -1
- package/esm/cli/_template/something-other-export.js +9 -15
- package/esm/cli/_template/something-other-export.js.map +1 -1
- package/esm/cli/_template/something-other-import.js +9 -15
- package/esm/cli/_template/something-other-import.js.map +1 -1
- package/esm/cli/_template/something-other-list.js +9 -15
- package/esm/cli/_template/something-other-list.js.map +1 -1
- package/esm/cli/_template/something-other.js +8 -8
- package/esm/cli/_template/something-other.js.map +1 -1
- package/esm/cli/_template/something.js +9 -10
- package/esm/cli/_template/something.js.map +1 -1
- package/esm/cli/admin/admin-add-autoid-static-user-mapping.js +8 -15
- package/esm/cli/admin/admin-add-autoid-static-user-mapping.js.map +1 -1
- package/esm/cli/admin/admin-create-oauth2-client-with-admin-privileges.js +9 -15
- package/esm/cli/admin/admin-create-oauth2-client-with-admin-privileges.js.map +1 -1
- package/esm/cli/admin/admin-get-access-token.js +9 -15
- package/esm/cli/admin/admin-get-access-token.js.map +1 -1
- package/esm/cli/admin/admin-grant-oauth2-client-admin-privileges.js +9 -15
- package/esm/cli/admin/admin-grant-oauth2-client-admin-privileges.js.map +1 -1
- package/esm/cli/admin/admin-hide-generic-extension-attributes.js +9 -15
- package/esm/cli/admin/admin-hide-generic-extension-attributes.js.map +1 -1
- package/esm/cli/admin/admin-list-oauth2-clients-with-admin-privileges.js +8 -15
- package/esm/cli/admin/admin-list-oauth2-clients-with-admin-privileges.js.map +1 -1
- package/esm/cli/admin/admin-list-oauth2-clients-with-custom-privileges.js +8 -15
- package/esm/cli/admin/admin-list-oauth2-clients-with-custom-privileges.js.map +1 -1
- package/esm/cli/admin/admin-list-static-user-mappings.js +9 -15
- package/esm/cli/admin/admin-list-static-user-mappings.js.map +1 -1
- package/esm/cli/admin/admin-remove-static-user-mapping.js +8 -15
- package/esm/cli/admin/admin-remove-static-user-mapping.js.map +1 -1
- package/esm/cli/admin/admin-repair-org-model.js +9 -15
- package/esm/cli/admin/admin-repair-org-model.js.map +1 -1
- package/esm/cli/admin/admin-revoke-oauth2-client-admin-privileges.js +9 -15
- package/esm/cli/admin/admin-revoke-oauth2-client-admin-privileges.js.map +1 -1
- package/esm/cli/admin/admin-show-generic-extension-attributes.js +9 -15
- package/esm/cli/admin/admin-show-generic-extension-attributes.js.map +1 -1
- package/esm/cli/admin/admin.js +14 -15
- package/esm/cli/admin/admin.js.map +1 -1
- package/esm/cli/agent/agent-delete.js +8 -15
- package/esm/cli/agent/agent-delete.js.map +1 -1
- package/esm/cli/agent/agent-describe.js +9 -15
- package/esm/cli/agent/agent-describe.js.map +1 -1
- package/esm/cli/agent/agent-export.js +8 -15
- package/esm/cli/agent/agent-export.js.map +1 -1
- package/esm/cli/agent/agent-gateway-delete.js +8 -15
- package/esm/cli/agent/agent-gateway-delete.js.map +1 -1
- package/esm/cli/agent/agent-gateway-describe.js +9 -15
- package/esm/cli/agent/agent-gateway-describe.js.map +1 -1
- package/esm/cli/agent/agent-gateway-export.js +8 -15
- package/esm/cli/agent/agent-gateway-export.js.map +1 -1
- package/esm/cli/agent/agent-gateway-import.js +8 -15
- package/esm/cli/agent/agent-gateway-import.js.map +1 -1
- package/esm/cli/agent/agent-gateway-list.js +9 -15
- package/esm/cli/agent/agent-gateway-list.js.map +1 -1
- package/esm/cli/agent/agent-gateway.js +8 -8
- package/esm/cli/agent/agent-gateway.js.map +1 -1
- package/esm/cli/agent/agent-import.js +8 -15
- package/esm/cli/agent/agent-import.js.map +1 -1
- package/esm/cli/agent/agent-java-delete.js +8 -15
- package/esm/cli/agent/agent-java-delete.js.map +1 -1
- package/esm/cli/agent/agent-java-describe.js +9 -15
- package/esm/cli/agent/agent-java-describe.js.map +1 -1
- package/esm/cli/agent/agent-java-export.js +8 -15
- package/esm/cli/agent/agent-java-export.js.map +1 -1
- package/esm/cli/agent/agent-java-import.js +8 -15
- package/esm/cli/agent/agent-java-import.js.map +1 -1
- package/esm/cli/agent/agent-java-list.js +9 -15
- package/esm/cli/agent/agent-java-list.js.map +1 -1
- package/esm/cli/agent/agent-java.js +8 -8
- package/esm/cli/agent/agent-java.js.map +1 -1
- package/esm/cli/agent/agent-list.js +9 -15
- package/esm/cli/agent/agent-list.js.map +1 -1
- package/esm/cli/agent/agent-web-delete.js +8 -15
- package/esm/cli/agent/agent-web-delete.js.map +1 -1
- package/esm/cli/agent/agent-web-describe.js +9 -15
- package/esm/cli/agent/agent-web-describe.js.map +1 -1
- package/esm/cli/agent/agent-web-export.js +8 -15
- package/esm/cli/agent/agent-web-export.js.map +1 -1
- package/esm/cli/agent/agent-web-import.js +8 -15
- package/esm/cli/agent/agent-web-import.js.map +1 -1
- package/esm/cli/agent/agent-web-list.js +9 -15
- package/esm/cli/agent/agent-web-list.js.map +1 -1
- package/esm/cli/agent/agent-web.js +8 -8
- package/esm/cli/agent/agent-web.js.map +1 -1
- package/esm/cli/agent/agent.js +10 -11
- package/esm/cli/agent/agent.js.map +1 -1
- package/esm/cli/app/app-delete.js +9 -12
- package/esm/cli/app/app-delete.js.map +1 -1
- package/esm/cli/app/app-describe.js +9 -12
- package/esm/cli/app/app-describe.js.map +1 -1
- package/esm/cli/app/app-export.js +28 -34
- package/esm/cli/app/app-export.js.map +1 -1
- package/esm/cli/app/app-import.js +11 -14
- package/esm/cli/app/app-import.js.map +1 -1
- package/esm/cli/app/app-list.js +11 -14
- package/esm/cli/app/app-list.js.map +1 -1
- package/esm/cli/app/app.js +8 -10
- package/esm/cli/app/app.js.map +1 -1
- package/esm/cli/conn/conn-delete.js +5 -5
- package/esm/cli/conn/conn-delete.js.map +1 -1
- package/esm/cli/conn/conn-describe.js +6 -5
- package/esm/cli/conn/conn-describe.js.map +1 -1
- package/esm/cli/conn/conn-list.js +6 -8
- package/esm/cli/conn/conn-list.js.map +1 -1
- package/esm/cli/conn/conn-save.js +72 -0
- package/esm/cli/conn/conn-save.js.map +1 -0
- package/esm/cli/conn/conn.js +10 -8
- package/esm/cli/conn/conn.js.map +1 -1
- package/esm/cli/email/email-template-export.js +29 -39
- package/esm/cli/email/email-template-export.js.map +1 -1
- package/esm/cli/email/email-template-import.js +34 -45
- package/esm/cli/email/email-template-import.js.map +1 -1
- package/esm/cli/email/email-template-list.js +12 -17
- package/esm/cli/email/email-template-list.js.map +1 -1
- package/esm/cli/email/email-template.js +6 -6
- package/esm/cli/email/email-template.js.map +1 -1
- package/esm/cli/email/email.js +2 -2
- package/esm/cli/email/email.js.map +1 -1
- package/esm/cli/esv/esv-apply.js +9 -12
- package/esm/cli/esv/esv-apply.js.map +1 -1
- package/esm/cli/esv/esv-secret-create.js +11 -14
- package/esm/cli/esv/esv-secret-create.js.map +1 -1
- package/esm/cli/esv/esv-secret-delete.js +23 -29
- package/esm/cli/esv/esv-secret-delete.js.map +1 -1
- package/esm/cli/esv/esv-secret-describe.js +11 -14
- package/esm/cli/esv/esv-secret-describe.js.map +1 -1
- package/esm/cli/esv/esv-secret-export.js +9 -12
- package/esm/cli/esv/esv-secret-export.js.map +1 -1
- package/esm/cli/esv/esv-secret-import.js +9 -12
- package/esm/cli/esv/esv-secret-import.js.map +1 -1
- package/esm/cli/esv/esv-secret-list.js +11 -14
- package/esm/cli/esv/esv-secret-list.js.map +1 -1
- package/esm/cli/esv/esv-secret-set.js +11 -14
- package/esm/cli/esv/esv-secret-set.js.map +1 -1
- package/esm/cli/esv/esv-secret-version-activate.js +18 -24
- package/esm/cli/esv/esv-secret-version-activate.js.map +1 -1
- package/esm/cli/esv/esv-secret-version-create.js +11 -14
- package/esm/cli/esv/esv-secret-version-create.js.map +1 -1
- package/esm/cli/esv/esv-secret-version-deactivate.js +18 -24
- package/esm/cli/esv/esv-secret-version-deactivate.js.map +1 -1
- package/esm/cli/esv/esv-secret-version-delete.js +23 -29
- package/esm/cli/esv/esv-secret-version-delete.js.map +1 -1
- package/esm/cli/esv/esv-secret-version-list.js +11 -14
- package/esm/cli/esv/esv-secret-version-list.js.map +1 -1
- package/esm/cli/esv/esv-secret-version.js +8 -8
- package/esm/cli/esv/esv-secret-version.js.map +1 -1
- package/esm/cli/esv/esv-secret.js +11 -11
- package/esm/cli/esv/esv-secret.js.map +1 -1
- package/esm/cli/esv/esv-variable-create.js +10 -14
- package/esm/cli/esv/esv-variable-create.js.map +1 -1
- package/esm/cli/esv/esv-variable-delete.js +23 -29
- package/esm/cli/esv/esv-variable-delete.js.map +1 -1
- package/esm/cli/esv/esv-variable-describe.js +11 -14
- package/esm/cli/esv/esv-variable-describe.js.map +1 -1
- package/esm/cli/esv/esv-variable-export.js +9 -12
- package/esm/cli/esv/esv-variable-export.js.map +1 -1
- package/esm/cli/esv/esv-variable-import.js +9 -12
- package/esm/cli/esv/esv-variable-import.js.map +1 -1
- package/esm/cli/esv/esv-variable-list.js +11 -14
- package/esm/cli/esv/esv-variable-list.js.map +1 -1
- package/esm/cli/esv/esv-variable-set.js +19 -26
- package/esm/cli/esv/esv-variable-set.js.map +1 -1
- package/esm/cli/esv/esv-variable.js +10 -10
- package/esm/cli/esv/esv-variable.js.map +1 -1
- package/esm/cli/esv/esv.js +5 -6
- package/esm/cli/esv/esv.js.map +1 -1
- package/esm/cli/idm/idm-count.js +12 -17
- package/esm/cli/idm/idm-count.js.map +1 -1
- package/esm/cli/idm/idm-export.js +29 -39
- package/esm/cli/idm/idm-export.js.map +1 -1
- package/esm/cli/idm/idm-import.js +29 -39
- package/esm/cli/idm/idm-import.js.map +1 -1
- package/esm/cli/idm/idm-list.js +11 -17
- package/esm/cli/idm/idm-list.js.map +1 -1
- package/esm/cli/idm/idm.js +6 -9
- package/esm/cli/idm/idm.js.map +1 -1
- package/esm/cli/idp/idp-export.js +11 -15
- package/esm/cli/idp/idp-export.js.map +1 -1
- package/esm/cli/idp/idp-import.js +32 -38
- package/esm/cli/idp/idp-import.js.map +1 -1
- package/esm/cli/idp/idp-list.js +9 -13
- package/esm/cli/idp/idp-list.js.map +1 -1
- package/esm/cli/idp/idp.js +5 -6
- package/esm/cli/idp/idp.js.map +1 -1
- package/esm/cli/info/info.js +19 -20
- package/esm/cli/info/info.js.map +1 -1
- package/esm/cli/journey/journey-delete.js +22 -28
- package/esm/cli/journey/journey-delete.js.map +1 -1
- package/esm/cli/journey/journey-describe.js +12 -19
- package/esm/cli/journey/journey-describe.js.map +1 -1
- package/esm/cli/journey/journey-disable.js +20 -26
- package/esm/cli/journey/journey-disable.js.map +1 -1
- package/esm/cli/journey/journey-enable.js +20 -26
- package/esm/cli/journey/journey-enable.js.map +1 -1
- package/esm/cli/journey/journey-export.js +37 -45
- package/esm/cli/journey/journey-export.js.map +1 -1
- package/esm/cli/journey/journey-import.js +44 -52
- package/esm/cli/journey/journey-import.js.map +1 -1
- package/esm/cli/journey/journey-list.js +10 -13
- package/esm/cli/journey/journey-list.js.map +1 -1
- package/esm/cli/journey/journey-prune.js +9 -13
- package/esm/cli/journey/journey-prune.js.map +1 -1
- package/esm/cli/journey/journey.js +10 -11
- package/esm/cli/journey/journey.js.map +1 -1
- package/esm/cli/logging/logs-fetch.js +17 -19
- package/esm/cli/logging/logs-fetch.js.map +1 -1
- package/esm/cli/logging/logs-list.js +19 -25
- package/esm/cli/logging/logs-list.js.map +1 -1
- package/esm/cli/logging/logs-tail.js +17 -19
- package/esm/cli/logging/logs-tail.js.map +1 -1
- package/esm/cli/logging/logs.js +7 -6
- package/esm/cli/logging/logs.js.map +1 -1
- package/esm/cli/realm/realm-add-custom-domain.js +11 -14
- package/esm/cli/realm/realm-add-custom-domain.js.map +1 -1
- package/esm/cli/realm/realm-describe.js +10 -14
- package/esm/cli/realm/realm-describe.js.map +1 -1
- package/esm/cli/realm/realm-list.js +11 -14
- package/esm/cli/realm/realm-list.js.map +1 -1
- package/esm/cli/realm/realm-remove-custom-domain.js +11 -14
- package/esm/cli/realm/realm-remove-custom-domain.js.map +1 -1
- package/esm/cli/realm/realm.js +7 -8
- package/esm/cli/realm/realm.js.map +1 -1
- package/esm/cli/saml/saml-cot-export.js +27 -36
- package/esm/cli/saml/saml-cot-export.js.map +1 -1
- package/esm/cli/saml/saml-cot-import.js +32 -41
- package/esm/cli/saml/saml-cot-import.js.map +1 -1
- package/esm/cli/saml/saml-cot-list.js +10 -16
- package/esm/cli/saml/saml-cot-list.js.map +1 -1
- package/esm/cli/saml/saml-cot.js +6 -6
- package/esm/cli/saml/saml-cot.js.map +1 -1
- package/esm/cli/saml/saml-delete.js +8 -15
- package/esm/cli/saml/saml-delete.js.map +1 -1
- package/esm/cli/saml/saml-describe.js +10 -16
- package/esm/cli/saml/saml-describe.js.map +1 -1
- package/esm/cli/saml/saml-export.js +9 -16
- package/esm/cli/saml/saml-export.js.map +1 -1
- package/esm/cli/saml/saml-import.js +45 -54
- package/esm/cli/saml/saml-import.js.map +1 -1
- package/esm/cli/saml/saml-list.js +11 -17
- package/esm/cli/saml/saml-list.js.map +1 -1
- package/esm/cli/saml/saml-metadata-export.js +21 -30
- package/esm/cli/saml/saml-metadata-export.js.map +1 -1
- package/esm/cli/saml/saml-metadata.js +4 -4
- package/esm/cli/saml/saml-metadata.js.map +1 -1
- package/esm/cli/saml/saml.js +9 -10
- package/esm/cli/saml/saml.js.map +1 -1
- package/esm/cli/script/script-delete.js +9 -12
- package/esm/cli/script/script-delete.js.map +1 -1
- package/esm/cli/script/script-describe.js +9 -12
- package/esm/cli/script/script-describe.js.map +1 -1
- package/esm/cli/script/script-export.js +28 -34
- package/esm/cli/script/script-export.js.map +1 -1
- package/esm/cli/script/script-import.js +10 -13
- package/esm/cli/script/script-import.js.map +1 -1
- package/esm/cli/script/script-list.js +10 -13
- package/esm/cli/script/script-list.js.map +1 -1
- package/esm/cli/script/script.js +7 -8
- package/esm/cli/script/script.js.map +1 -1
- package/esm/cli/service/service-delete.js +10 -16
- package/esm/cli/service/service-delete.js.map +1 -1
- package/esm/cli/service/service-export.js +12 -17
- package/esm/cli/service/service-export.js.map +1 -1
- package/esm/cli/service/service-import.js +12 -18
- package/esm/cli/service/service-import.js.map +1 -1
- package/esm/cli/service/service-list.js +9 -15
- package/esm/cli/service/service-list.js.map +1 -1
- package/esm/cli/service/service.js +6 -7
- package/esm/cli/service/service.js.map +1 -1
- package/esm/cli/theme/theme-delete.js +15 -26
- package/esm/cli/theme/theme-delete.js.map +1 -1
- package/esm/cli/theme/theme-export.js +14 -26
- package/esm/cli/theme/theme-export.js.map +1 -1
- package/esm/cli/theme/theme-import.js +16 -29
- package/esm/cli/theme/theme-import.js.map +1 -1
- package/esm/cli/theme/theme-list.js +12 -20
- package/esm/cli/theme/theme-list.js.map +1 -1
- package/esm/cli/theme/theme.js +6 -7
- package/esm/cli/theme/theme.js.map +1 -1
- package/esm/ops/ConnectionProfileOps.js +30 -0
- package/esm/ops/ConnectionProfileOps.js.map +1 -0
- package/esm/ops/EmailTemplateOps.js +267 -2
- package/esm/ops/EmailTemplateOps.js.map +1 -1
- package/esm/ops/IdmOps.js +317 -0
- package/esm/ops/IdmOps.js.map +1 -0
- package/esm/ops/JourneyOps.js +2 -1
- package/esm/ops/JourneyOps.js.map +1 -1
- package/esm/ops/ServiceOps.js +20 -20
- package/esm/ops/ServiceOps.js.map +1 -1
- package/esm/ops/ThemeOps.js +329 -0
- package/esm/ops/ThemeOps.js.map +1 -1
- package/esm/utils/Console.js +15 -25
- package/esm/utils/Console.js.map +1 -1
- package/esm/utils/ExportImportUtils.js +46 -0
- package/esm/utils/ExportImportUtils.js.map +1 -0
- package/package.json +6 -5
- package/esm/cli/cmd_common.js +0 -79
- package/esm/cli/cmd_common.js.map +0 -1
- package/esm/cli/conn/conn-add.js +0 -37
- package/esm/cli/conn/conn-add.js.map +0 -1
- package/esm/cli/journey/journey-delete.e2e.test_.js.map +0 -1
- package/esm/cli/journey/journey-list.e2e.test_.js.map +0 -1
|
@@ -1,26 +1,23 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
2
3
|
import { Authenticate, Realm, state } from '@rockcarver/frodo-lib';
|
|
3
|
-
import
|
|
4
|
-
import { printMessage } from '../../utils/Console';
|
|
4
|
+
import { verboseMessage } from '../../utils/Console';
|
|
5
5
|
const {
|
|
6
6
|
getTokens
|
|
7
7
|
} = Authenticate;
|
|
8
8
|
const {
|
|
9
9
|
removeCustomDomain
|
|
10
10
|
} = Realm;
|
|
11
|
-
const program = new
|
|
12
|
-
program.description('Remove custom domain (realm DNS alias).').
|
|
11
|
+
const program = new FrodoCommand('frodo realm remove-custom-domain');
|
|
12
|
+
program.description('Remove custom domain (realm DNS alias).').addOption(new Option('-d, --domain <name>', 'Custom DNS domain name.').makeOptionMandatory()).action(
|
|
13
13
|
// implement command logic inside action handler
|
|
14
|
-
async (host, realm, user, password, options) => {
|
|
15
|
-
|
|
16
|
-
state.default.session.setRealm(realm);
|
|
17
|
-
state.default.session.setUsername(user);
|
|
18
|
-
state.default.session.setPassword(password);
|
|
19
|
-
state.default.session.setDeploymentType(options.type);
|
|
20
|
-
state.default.session.setAllowInsecureConnection(options.insecure);
|
|
14
|
+
async (host, realm, user, password, options, command) => {
|
|
15
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
21
16
|
if (await getTokens()) {
|
|
22
|
-
|
|
23
|
-
await removeCustomDomain(state.
|
|
17
|
+
verboseMessage(`Removing custom DNS domain ${options.domain} from realm ${state.getRealm()}...`);
|
|
18
|
+
await removeCustomDomain(state.getRealm(), options.domain);
|
|
19
|
+
} else {
|
|
20
|
+
process.exitCode = 1;
|
|
24
21
|
}
|
|
25
22
|
}
|
|
26
23
|
// end command logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"realm-remove-custom-domain.js","names":["
|
|
1
|
+
{"version":3,"file":"realm-remove-custom-domain.js","names":["FrodoCommand","Option","Authenticate","Realm","state","verboseMessage","getTokens","removeCustomDomain","program","description","addOption","makeOptionMandatory","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","domain","getRealm","process","exitCode","parse"],"sources":["cli/realm/realm-remove-custom-domain.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, Realm, state } from '@rockcarver/frodo-lib';\nimport { verboseMessage } from '../../utils/Console';\n\nconst { getTokens } = Authenticate;\nconst { removeCustomDomain } = Realm;\n\nconst program = new FrodoCommand('frodo realm remove-custom-domain');\n\nprogram\n .description('Remove custom domain (realm DNS alias).')\n .addOption(\n new Option(\n '-d, --domain <name>',\n 'Custom DNS domain name.'\n ).makeOptionMandatory()\n )\n .action(\n // implement command logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n if (await getTokens()) {\n verboseMessage(\n `Removing custom DNS domain ${\n options.domain\n } from realm ${state.getRealm()}...`\n );\n await removeCustomDomain(state.getRealm(), options.domain);\n } else {\n process.exitCode = 1;\n }\n }\n // end command logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,KAAK,EAAEC,KAAK,QAAQ,uBAAuB;AAClE,SAASC,cAAc,QAAQ,qBAAqB;AAEpD,MAAM;EAAEC;AAAU,CAAC,GAAGJ,YAAY;AAClC,MAAM;EAAEK;AAAmB,CAAC,GAAGJ,KAAK;AAEpC,MAAMK,OAAO,GAAG,IAAIR,YAAY,CAAC,kCAAkC,CAAC;AAEpEQ,OAAO,CACJC,WAAW,CAAC,yCAAyC,CAAC,CACtDC,SAAS,CACR,IAAIT,MAAM,CACR,qBAAqB,EACrB,yBAAyB,CAC1B,CAACU,mBAAmB,EAAE,CACxB,CACAC,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD,IAAI,MAAMZ,SAAS,EAAE,EAAE;IACrBD,cAAc,CACX,8BACCY,OAAO,CAACG,MACT,eAAchB,KAAK,CAACiB,QAAQ,EAAG,KAAI,CACrC;IACD,MAAMd,kBAAkB,CAACH,KAAK,CAACiB,QAAQ,EAAE,EAAEJ,OAAO,CAACG,MAAM,CAAC;EAC5D,CAAC,MAAM;IACLE,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHf,OAAO,CAACgB,KAAK,EAAE"}
|
package/esm/cli/realm/realm.js
CHANGED
|
@@ -1,19 +1,18 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoStubCommand } from '../FrodoCommand';
|
|
2
2
|
import path from 'path';
|
|
3
3
|
import { fileURLToPath } from 'url';
|
|
4
4
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
5
5
|
export default function setup() {
|
|
6
|
-
const program = new
|
|
7
|
-
program.command('list', 'List realms.')
|
|
6
|
+
const program = new FrodoStubCommand('realm').description('Manage realms.').executableDir(__dirname);
|
|
7
|
+
program.command('list', 'List realms.');
|
|
8
8
|
program.command('describe', 'Describe realms.')
|
|
9
9
|
// for backwards compatibility
|
|
10
|
-
.alias('details')
|
|
11
|
-
program.command('add-custom-domain', 'Add custom domain (realm DNS alias).')
|
|
12
|
-
program.command('remove-custom-domain', 'Remove custom domain (realm DNS alias).')
|
|
10
|
+
.alias('details');
|
|
11
|
+
program.command('add-custom-domain', 'Add custom domain (realm DNS alias).');
|
|
12
|
+
program.command('remove-custom-domain', 'Remove custom domain (realm DNS alias).');
|
|
13
13
|
|
|
14
|
-
// program.command('delete', 'Delete realms.')
|
|
14
|
+
// program.command('delete', 'Delete realms.');
|
|
15
15
|
|
|
16
|
-
program.showHelpAfterError();
|
|
17
16
|
return program;
|
|
18
17
|
}
|
|
19
18
|
//# sourceMappingURL=realm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"realm.js","names":["
|
|
1
|
+
{"version":3,"file":"realm.js","names":["FrodoStubCommand","path","fileURLToPath","__dirname","dirname","import","meta","url","setup","program","description","executableDir","command","alias"],"sources":["cli/realm/realm.ts"],"sourcesContent":["import { FrodoStubCommand } from '../FrodoCommand';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url));\n\nexport default function setup() {\n const program = new FrodoStubCommand('realm')\n .description('Manage realms.')\n .executableDir(__dirname);\n\n program.command('list', 'List realms.');\n\n program\n .command('describe', 'Describe realms.')\n // for backwards compatibility\n .alias('details');\n\n program.command('add-custom-domain', 'Add custom domain (realm DNS alias).');\n\n program.command(\n 'remove-custom-domain',\n 'Remove custom domain (realm DNS alias).'\n );\n\n // program.command('delete', 'Delete realms.');\n\n return program;\n}\n"],"mappings":"AAAA,SAASA,gBAAgB,QAAQ,iBAAiB;AAClD,OAAOC,IAAI,MAAM,MAAM;AACvB,SAASC,aAAa,QAAQ,KAAK;AAEnC,MAAMC,SAAS,GAAGF,IAAI,CAACG,OAAO,CAACF,aAAa,CAACG,MAAM,CAACC,IAAI,CAACC,GAAG,CAAC,CAAC;AAE9D,eAAe,SAASC,KAAK,GAAG;EAC9B,MAAMC,OAAO,GAAG,IAAIT,gBAAgB,CAAC,OAAO,CAAC,CAC1CU,WAAW,CAAC,gBAAgB,CAAC,CAC7BC,aAAa,CAACR,SAAS,CAAC;EAE3BM,OAAO,CAACG,OAAO,CAAC,MAAM,EAAE,cAAc,CAAC;EAEvCH,OAAO,CACJG,OAAO,CAAC,UAAU,EAAE,kBAAkB;EACvC;EAAA,CACCC,KAAK,CAAC,SAAS,CAAC;EAEnBJ,OAAO,CAACG,OAAO,CAAC,mBAAmB,EAAE,sCAAsC,CAAC;EAE5EH,OAAO,CAACG,OAAO,CACb,sBAAsB,EACtB,yCAAyC,CAC1C;;EAED;;EAEA,OAAOH,OAAO;AAChB"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
2
3
|
import { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';
|
|
3
|
-
import
|
|
4
|
-
import { printMessage } from '../../utils/Console';
|
|
4
|
+
import { printMessage, verboseMessage } from '../../utils/Console';
|
|
5
5
|
const {
|
|
6
6
|
getTokens
|
|
7
7
|
} = Authenticate;
|
|
@@ -10,40 +10,31 @@ const {
|
|
|
10
10
|
exportCirclesOfTrustToFile,
|
|
11
11
|
exportCirclesOfTrustToFiles
|
|
12
12
|
} = CirclesOfTrust;
|
|
13
|
-
const program = new
|
|
14
|
-
program.description('Export SAML circles of trust.').
|
|
13
|
+
const program = new FrodoCommand('frodo saml cot export');
|
|
14
|
+
program.description('Export SAML circles of trust.').addOption(new Option('-i, --cot-id <cot-id>', 'Circle of trust id/name. If specified, -a and -A are ignored.')).addOption(new Option('-f, --file [file]', 'Name of the export file. Ignored with -A. Defaults to <cot-id>.cot.saml.json.')).addOption(new Option('-a, --all', 'Export all the circles of trust in a realm to a single file. Ignored with -i.')).addOption(new Option('-A, --all-separate', 'Export all the circles of trust in a realm as separate files <cot-id>.cot.saml.json. Ignored with -i, and -a.')).action(
|
|
15
15
|
// implement command logic inside action handler
|
|
16
|
-
async (host, realm, user, password, options) => {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
else if (options.allSeparate) {
|
|
39
|
-
printMessage('Exporting all circles of trust to separate files...');
|
|
40
|
-
exportCirclesOfTrustToFiles();
|
|
41
|
-
}
|
|
42
|
-
// unrecognized combination of options or no options
|
|
43
|
-
else {
|
|
44
|
-
printMessage('Unrecognized combination of options or no options...', 'error');
|
|
45
|
-
program.help();
|
|
46
|
-
}
|
|
16
|
+
async (host, realm, user, password, options, command) => {
|
|
17
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
18
|
+
// export by id/name
|
|
19
|
+
if (options.cotId && (await getTokens())) {
|
|
20
|
+
verboseMessage(`Exporting circle of trust "${options.cotId}" from realm "${state.getRealm()}"...`);
|
|
21
|
+
exportCircleOfTrust(options.cotId, options.file);
|
|
22
|
+
}
|
|
23
|
+
// --all -a
|
|
24
|
+
else if (options.all && (await getTokens())) {
|
|
25
|
+
verboseMessage('Exporting all circles of trust to a single file...');
|
|
26
|
+
exportCirclesOfTrustToFile(options.file);
|
|
27
|
+
}
|
|
28
|
+
// --all-separate -A
|
|
29
|
+
else if (options.allSeparate && (await getTokens())) {
|
|
30
|
+
verboseMessage('Exporting all circles of trust to separate files...');
|
|
31
|
+
exportCirclesOfTrustToFiles();
|
|
32
|
+
}
|
|
33
|
+
// unrecognized combination of options or no options
|
|
34
|
+
else {
|
|
35
|
+
printMessage('Unrecognized combination of options or no options...', 'error');
|
|
36
|
+
program.help();
|
|
37
|
+
process.exitCode = 1;
|
|
47
38
|
}
|
|
48
39
|
}
|
|
49
40
|
// end command logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-cot-export.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-cot-export.js","names":["FrodoCommand","Option","Authenticate","CirclesOfTrust","state","printMessage","verboseMessage","getTokens","exportCircleOfTrust","exportCirclesOfTrustToFile","exportCirclesOfTrustToFiles","program","description","addOption","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","cotId","getRealm","file","all","allSeparate","help","process","exitCode","parse"],"sources":["cli/saml/saml-cot-export.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';\nimport { printMessage, verboseMessage } from '../../utils/Console';\n\nconst { getTokens } = Authenticate;\nconst {\n exportCircleOfTrust,\n exportCirclesOfTrustToFile,\n exportCirclesOfTrustToFiles,\n} = CirclesOfTrust;\n\nconst program = new FrodoCommand('frodo saml cot export');\n\nprogram\n .description('Export SAML circles of trust.')\n .addOption(\n new Option(\n '-i, --cot-id <cot-id>',\n 'Circle of trust id/name. If specified, -a and -A are ignored.'\n )\n )\n .addOption(\n new Option(\n '-f, --file [file]',\n 'Name of the export file. Ignored with -A. Defaults to <cot-id>.cot.saml.json.'\n )\n )\n .addOption(\n new Option(\n '-a, --all',\n 'Export all the circles of trust in a realm to a single file. Ignored with -i.'\n )\n )\n .addOption(\n new Option(\n '-A, --all-separate',\n 'Export all the circles of trust in a realm as separate files <cot-id>.cot.saml.json. Ignored with -i, and -a.'\n )\n )\n .action(\n // implement command logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n // export by id/name\n if (options.cotId && (await getTokens())) {\n verboseMessage(\n `Exporting circle of trust \"${\n options.cotId\n }\" from realm \"${state.getRealm()}\"...`\n );\n exportCircleOfTrust(options.cotId, options.file);\n }\n // --all -a\n else if (options.all && (await getTokens())) {\n verboseMessage('Exporting all circles of trust to a single file...');\n exportCirclesOfTrustToFile(options.file);\n }\n // --all-separate -A\n else if (options.allSeparate && (await getTokens())) {\n verboseMessage('Exporting all circles of trust to separate files...');\n exportCirclesOfTrustToFiles();\n }\n // unrecognized combination of options or no options\n else {\n printMessage(\n 'Unrecognized combination of options or no options...',\n 'error'\n );\n program.help();\n process.exitCode = 1;\n }\n }\n // end command logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,cAAc,EAAEC,KAAK,QAAQ,uBAAuB;AAC3E,SAASC,YAAY,EAAEC,cAAc,QAAQ,qBAAqB;AAElE,MAAM;EAAEC;AAAU,CAAC,GAAGL,YAAY;AAClC,MAAM;EACJM,mBAAmB;EACnBC,0BAA0B;EAC1BC;AACF,CAAC,GAAGP,cAAc;AAElB,MAAMQ,OAAO,GAAG,IAAIX,YAAY,CAAC,uBAAuB,CAAC;AAEzDW,OAAO,CACJC,WAAW,CAAC,+BAA+B,CAAC,CAC5CC,SAAS,CACR,IAAIZ,MAAM,CACR,uBAAuB,EACvB,+DAA+D,CAChE,CACF,CACAY,SAAS,CACR,IAAIZ,MAAM,CACR,mBAAmB,EACnB,+EAA+E,CAChF,CACF,CACAY,SAAS,CACR,IAAIZ,MAAM,CACR,WAAW,EACX,+EAA+E,CAChF,CACF,CACAY,SAAS,CACR,IAAIZ,MAAM,CACR,oBAAoB,EACpB,+GAA+G,CAChH,CACF,CACAa,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD;EACA,IAAID,OAAO,CAACG,KAAK,KAAK,MAAMf,SAAS,EAAE,CAAC,EAAE;IACxCD,cAAc,CACX,8BACCa,OAAO,CAACG,KACT,iBAAgBlB,KAAK,CAACmB,QAAQ,EAAG,MAAK,CACxC;IACDf,mBAAmB,CAACW,OAAO,CAACG,KAAK,EAAEH,OAAO,CAACK,IAAI,CAAC;EAClD;EACA;EAAA,KACK,IAAIL,OAAO,CAACM,GAAG,KAAK,MAAMlB,SAAS,EAAE,CAAC,EAAE;IAC3CD,cAAc,CAAC,oDAAoD,CAAC;IACpEG,0BAA0B,CAACU,OAAO,CAACK,IAAI,CAAC;EAC1C;EACA;EAAA,KACK,IAAIL,OAAO,CAACO,WAAW,KAAK,MAAMnB,SAAS,EAAE,CAAC,EAAE;IACnDD,cAAc,CAAC,qDAAqD,CAAC;IACrEI,2BAA2B,EAAE;EAC/B;EACA;EAAA,KACK;IACHL,YAAY,CACV,sDAAsD,EACtD,OAAO,CACR;IACDM,OAAO,CAACgB,IAAI,EAAE;IACdC,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHlB,OAAO,CAACmB,KAAK,EAAE"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
2
3
|
import { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';
|
|
3
|
-
import
|
|
4
|
-
import { printMessage } from '../../utils/Console';
|
|
4
|
+
import { printMessage, verboseMessage } from '../../utils/Console';
|
|
5
5
|
const {
|
|
6
6
|
getTokens
|
|
7
7
|
} = Authenticate;
|
|
@@ -11,45 +11,36 @@ const {
|
|
|
11
11
|
importCirclesOfTrustFromFiles,
|
|
12
12
|
importFirstCircleOfTrust
|
|
13
13
|
} = CirclesOfTrust;
|
|
14
|
-
const program = new
|
|
15
|
-
program.description('Import SAML circles of trust.').
|
|
14
|
+
const program = new FrodoCommand('frodo saml cot import');
|
|
15
|
+
program.description('Import SAML circles of trust.').addOption(new Option('-i, --cot-id <cot-id>', 'Circle of trust id. If specified, only one circle of trust is imported and the options -a and -A are ignored.')).addOption(new Option('-f, --file <file>', 'Name of the file to import the circle(s) of trust from.')).addOption(new Option('-a, --all', 'Import all circles of trust from single file. Ignored with -i.')).addOption(new Option('-A, --all-separate', 'Import all circles of trust from separate files (*.cot.saml.json) in the current directory. Ignored with -i or -a.')).action(
|
|
16
16
|
// implement program logic inside action handler
|
|
17
|
-
async (host, realm, user, password, options) => {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
else if (options.file) {
|
|
45
|
-
printMessage(`Importing first circle of trust from file "${options.file}" into realm "${state.default.session.getRealm()}"...`);
|
|
46
|
-
importFirstCircleOfTrust(options.file);
|
|
47
|
-
}
|
|
48
|
-
// unrecognized combination of options or no options
|
|
49
|
-
else {
|
|
50
|
-
printMessage('Unrecognized combination of options or no options...');
|
|
51
|
-
program.help();
|
|
52
|
-
}
|
|
17
|
+
async (host, realm, user, password, options, command) => {
|
|
18
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
19
|
+
// import by id
|
|
20
|
+
if (options.file && options.cotId && (await getTokens())) {
|
|
21
|
+
verboseMessage(`Importing circle of trust "${options.cotId}" into realm "${state.getRealm()}"...`);
|
|
22
|
+
importCircleOfTrust(options.cotId, options.file);
|
|
23
|
+
}
|
|
24
|
+
// --all -a
|
|
25
|
+
else if (options.all && options.file && (await getTokens())) {
|
|
26
|
+
verboseMessage(`Importing all circles of trust from a single file (${options.file})...`);
|
|
27
|
+
importCirclesOfTrustFromFile(options.file);
|
|
28
|
+
}
|
|
29
|
+
// --all-separate -A
|
|
30
|
+
else if (options.allSeparate && !options.file && (await getTokens())) {
|
|
31
|
+
verboseMessage('Importing all circles of trust from separate files (*.saml.json) in current directory...');
|
|
32
|
+
importCirclesOfTrustFromFiles();
|
|
33
|
+
}
|
|
34
|
+
// import first provider from file
|
|
35
|
+
else if (options.file && (await getTokens())) {
|
|
36
|
+
verboseMessage(`Importing first circle of trust from file "${options.file}" into realm "${state.getRealm()}"...`);
|
|
37
|
+
importFirstCircleOfTrust(options.file);
|
|
38
|
+
}
|
|
39
|
+
// unrecognized combination of options or no options
|
|
40
|
+
else {
|
|
41
|
+
printMessage('Unrecognized combination of options or no options...', 'error');
|
|
42
|
+
program.help();
|
|
43
|
+
process.exitCode = 1;
|
|
53
44
|
}
|
|
54
45
|
}
|
|
55
46
|
// end program logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-cot-import.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-cot-import.js","names":["FrodoCommand","Option","Authenticate","CirclesOfTrust","state","printMessage","verboseMessage","getTokens","importCircleOfTrust","importCirclesOfTrustFromFile","importCirclesOfTrustFromFiles","importFirstCircleOfTrust","program","description","addOption","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","file","cotId","getRealm","all","allSeparate","help","process","exitCode","parse"],"sources":["cli/saml/saml-cot-import.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';\nimport { printMessage, verboseMessage } from '../../utils/Console';\n\nconst { getTokens } = Authenticate;\nconst {\n importCircleOfTrust,\n importCirclesOfTrustFromFile,\n importCirclesOfTrustFromFiles,\n importFirstCircleOfTrust,\n} = CirclesOfTrust;\n\nconst program = new FrodoCommand('frodo saml cot import');\n\nprogram\n .description('Import SAML circles of trust.')\n .addOption(\n new Option(\n '-i, --cot-id <cot-id>',\n 'Circle of trust id. If specified, only one circle of trust is imported and the options -a and -A are ignored.'\n )\n )\n .addOption(\n new Option(\n '-f, --file <file>',\n 'Name of the file to import the circle(s) of trust from.'\n )\n )\n .addOption(\n new Option(\n '-a, --all',\n 'Import all circles of trust from single file. Ignored with -i.'\n )\n )\n .addOption(\n new Option(\n '-A, --all-separate',\n 'Import all circles of trust from separate files (*.cot.saml.json) in the current directory. Ignored with -i or -a.'\n )\n )\n .action(\n // implement program logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n // import by id\n if (options.file && options.cotId && (await getTokens())) {\n verboseMessage(\n `Importing circle of trust \"${\n options.cotId\n }\" into realm \"${state.getRealm()}\"...`\n );\n importCircleOfTrust(options.cotId, options.file);\n }\n // --all -a\n else if (options.all && options.file && (await getTokens())) {\n verboseMessage(\n `Importing all circles of trust from a single file (${options.file})...`\n );\n importCirclesOfTrustFromFile(options.file);\n }\n // --all-separate -A\n else if (options.allSeparate && !options.file && (await getTokens())) {\n verboseMessage(\n 'Importing all circles of trust from separate files (*.saml.json) in current directory...'\n );\n importCirclesOfTrustFromFiles();\n }\n // import first provider from file\n else if (options.file && (await getTokens())) {\n verboseMessage(\n `Importing first circle of trust from file \"${\n options.file\n }\" into realm \"${state.getRealm()}\"...`\n );\n importFirstCircleOfTrust(options.file);\n }\n // unrecognized combination of options or no options\n else {\n printMessage(\n 'Unrecognized combination of options or no options...',\n 'error'\n );\n program.help();\n process.exitCode = 1;\n }\n }\n // end program logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,cAAc,EAAEC,KAAK,QAAQ,uBAAuB;AAC3E,SAASC,YAAY,EAAEC,cAAc,QAAQ,qBAAqB;AAElE,MAAM;EAAEC;AAAU,CAAC,GAAGL,YAAY;AAClC,MAAM;EACJM,mBAAmB;EACnBC,4BAA4B;EAC5BC,6BAA6B;EAC7BC;AACF,CAAC,GAAGR,cAAc;AAElB,MAAMS,OAAO,GAAG,IAAIZ,YAAY,CAAC,uBAAuB,CAAC;AAEzDY,OAAO,CACJC,WAAW,CAAC,+BAA+B,CAAC,CAC5CC,SAAS,CACR,IAAIb,MAAM,CACR,uBAAuB,EACvB,+GAA+G,CAChH,CACF,CACAa,SAAS,CACR,IAAIb,MAAM,CACR,mBAAmB,EACnB,yDAAyD,CAC1D,CACF,CACAa,SAAS,CACR,IAAIb,MAAM,CACR,WAAW,EACX,gEAAgE,CACjE,CACF,CACAa,SAAS,CACR,IAAIb,MAAM,CACR,oBAAoB,EACpB,oHAAoH,CACrH,CACF,CACAc,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD;EACA,IAAID,OAAO,CAACG,IAAI,IAAIH,OAAO,CAACI,KAAK,KAAK,MAAMjB,SAAS,EAAE,CAAC,EAAE;IACxDD,cAAc,CACX,8BACCc,OAAO,CAACI,KACT,iBAAgBpB,KAAK,CAACqB,QAAQ,EAAG,MAAK,CACxC;IACDjB,mBAAmB,CAACY,OAAO,CAACI,KAAK,EAAEJ,OAAO,CAACG,IAAI,CAAC;EAClD;EACA;EAAA,KACK,IAAIH,OAAO,CAACM,GAAG,IAAIN,OAAO,CAACG,IAAI,KAAK,MAAMhB,SAAS,EAAE,CAAC,EAAE;IAC3DD,cAAc,CACX,sDAAqDc,OAAO,CAACG,IAAK,MAAK,CACzE;IACDd,4BAA4B,CAACW,OAAO,CAACG,IAAI,CAAC;EAC5C;EACA;EAAA,KACK,IAAIH,OAAO,CAACO,WAAW,IAAI,CAACP,OAAO,CAACG,IAAI,KAAK,MAAMhB,SAAS,EAAE,CAAC,EAAE;IACpED,cAAc,CACZ,0FAA0F,CAC3F;IACDI,6BAA6B,EAAE;EACjC;EACA;EAAA,KACK,IAAIU,OAAO,CAACG,IAAI,KAAK,MAAMhB,SAAS,EAAE,CAAC,EAAE;IAC5CD,cAAc,CACX,8CACCc,OAAO,CAACG,IACT,iBAAgBnB,KAAK,CAACqB,QAAQ,EAAG,MAAK,CACxC;IACDd,wBAAwB,CAACS,OAAO,CAACG,IAAI,CAAC;EACxC;EACA;EAAA,KACK;IACHlB,YAAY,CACV,sDAAsD,EACtD,OAAO,CACR;IACDO,OAAO,CAACgB,IAAI,EAAE;IACdC,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHlB,OAAO,CAACmB,KAAK,EAAE"}
|
|
@@ -1,29 +1,23 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
2
3
|
import { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';
|
|
3
|
-
import
|
|
4
|
-
import { printMessage } from '../../utils/Console';
|
|
4
|
+
import { verboseMessage } from '../../utils/Console';
|
|
5
5
|
const {
|
|
6
6
|
getTokens
|
|
7
7
|
} = Authenticate;
|
|
8
8
|
const {
|
|
9
9
|
listCirclesOfTrust
|
|
10
10
|
} = CirclesOfTrust;
|
|
11
|
-
const program = new
|
|
12
|
-
program.description('List SAML circles of trust.').
|
|
11
|
+
const program = new FrodoCommand('frodo saml cot list');
|
|
12
|
+
program.description('List SAML circles of trust.').addOption(new Option('-l, --long', 'Long with all fields.').default(false, 'false')).action(
|
|
13
13
|
// implement command logic inside action handler
|
|
14
|
-
async (host, realm, user, password, options) => {
|
|
15
|
-
|
|
16
|
-
state.default.session.setRealm(realm);
|
|
17
|
-
state.default.session.setUsername(user);
|
|
18
|
-
state.default.session.setPassword(password);
|
|
19
|
-
state.default.session.setDeploymentType(options.type);
|
|
20
|
-
state.default.session.setAllowInsecureConnection(options.insecure);
|
|
21
|
-
state.default.session.setVerbose(options.verbose);
|
|
22
|
-
state.default.session.setDebug(options.debug);
|
|
23
|
-
state.default.session.setCurlirize(options.curlirize);
|
|
14
|
+
async (host, realm, user, password, options, command) => {
|
|
15
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
24
16
|
if (await getTokens()) {
|
|
25
|
-
|
|
17
|
+
verboseMessage(`Listing SAML circles of trust in realm "${state.getRealm()}"...`);
|
|
26
18
|
listCirclesOfTrust(options.long);
|
|
19
|
+
} else {
|
|
20
|
+
process.exitCode = 1;
|
|
27
21
|
}
|
|
28
22
|
}
|
|
29
23
|
// end command logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-cot-list.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-cot-list.js","names":["FrodoCommand","Option","Authenticate","CirclesOfTrust","state","verboseMessage","getTokens","listCirclesOfTrust","program","description","addOption","default","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","getRealm","long","process","exitCode","parse"],"sources":["cli/saml/saml-cot-list.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, CirclesOfTrust, state } from '@rockcarver/frodo-lib';\nimport { verboseMessage } from '../../utils/Console';\n\nconst { getTokens } = Authenticate;\nconst { listCirclesOfTrust } = CirclesOfTrust;\n\nconst program = new FrodoCommand('frodo saml cot list');\n\nprogram\n .description('List SAML circles of trust.')\n .addOption(\n new Option('-l, --long', 'Long with all fields.').default(false, 'false')\n )\n .action(\n // implement command logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n if (await getTokens()) {\n verboseMessage(\n `Listing SAML circles of trust in realm \"${state.getRealm()}\"...`\n );\n listCirclesOfTrust(options.long);\n } else {\n process.exitCode = 1;\n }\n }\n // end command logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,cAAc,EAAEC,KAAK,QAAQ,uBAAuB;AAC3E,SAASC,cAAc,QAAQ,qBAAqB;AAEpD,MAAM;EAAEC;AAAU,CAAC,GAAGJ,YAAY;AAClC,MAAM;EAAEK;AAAmB,CAAC,GAAGJ,cAAc;AAE7C,MAAMK,OAAO,GAAG,IAAIR,YAAY,CAAC,qBAAqB,CAAC;AAEvDQ,OAAO,CACJC,WAAW,CAAC,6BAA6B,CAAC,CAC1CC,SAAS,CACR,IAAIT,MAAM,CAAC,YAAY,EAAE,uBAAuB,CAAC,CAACU,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAC1E,CACAC,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD,IAAI,MAAMZ,SAAS,EAAE,EAAE;IACrBD,cAAc,CACX,2CAA0CD,KAAK,CAACgB,QAAQ,EAAG,MAAK,CAClE;IACDb,kBAAkB,CAACU,OAAO,CAACI,IAAI,CAAC;EAClC,CAAC,MAAM;IACLC,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHf,OAAO,CAACgB,KAAK,EAAE"}
|
package/esm/cli/saml/saml-cot.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
const program = new
|
|
3
|
-
program.description('Manage circles of trust.')
|
|
4
|
-
program.command('list', 'List circles of trust.')
|
|
5
|
-
program.command('export', 'Export circles of trust.')
|
|
6
|
-
program.command('import', 'Import circles of trust.')
|
|
1
|
+
import { FrodoStubCommand } from '../FrodoCommand';
|
|
2
|
+
const program = new FrodoStubCommand('frodo saml cot');
|
|
3
|
+
program.description('Manage circles of trust.');
|
|
4
|
+
program.command('list', 'List circles of trust.');
|
|
5
|
+
program.command('export', 'Export circles of trust.');
|
|
6
|
+
program.command('import', 'Import circles of trust.');
|
|
7
7
|
program.parse();
|
|
8
8
|
//# sourceMappingURL=saml-cot.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-cot.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-cot.js","names":["FrodoStubCommand","program","description","command","parse"],"sources":["cli/saml/saml-cot.ts"],"sourcesContent":["import { FrodoStubCommand } from '../FrodoCommand';\n\nconst program = new FrodoStubCommand('frodo saml cot');\n\nprogram.description('Manage circles of trust.');\n\nprogram.command('list', 'List circles of trust.');\n\nprogram.command('export', 'Export circles of trust.');\n\nprogram.command('import', 'Import circles of trust.');\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,gBAAgB,QAAQ,iBAAiB;AAElD,MAAMC,OAAO,GAAG,IAAID,gBAAgB,CAAC,gBAAgB,CAAC;AAEtDC,OAAO,CAACC,WAAW,CAAC,0BAA0B,CAAC;AAE/CD,OAAO,CAACE,OAAO,CAAC,MAAM,EAAE,wBAAwB,CAAC;AAEjDF,OAAO,CAACE,OAAO,CAAC,QAAQ,EAAE,0BAA0B,CAAC;AAErDF,OAAO,CAACE,OAAO,CAAC,QAAQ,EAAE,0BAA0B,CAAC;AAErDF,OAAO,CAACG,KAAK,EAAE"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
3
|
+
import { Authenticate, Saml2 } from '@rockcarver/frodo-lib';
|
|
3
4
|
import { printMessage, verboseMessage } from '../../utils/Console.js';
|
|
4
|
-
import * as common from '../cmd_common.js';
|
|
5
5
|
const {
|
|
6
6
|
getTokens
|
|
7
7
|
} = Authenticate;
|
|
@@ -9,19 +9,11 @@ const {
|
|
|
9
9
|
deleteSaml2Provider,
|
|
10
10
|
deleteSaml2Providers
|
|
11
11
|
} = Saml2;
|
|
12
|
-
const program = new
|
|
13
|
-
program.description('Delete SAML entity providers.').
|
|
12
|
+
const program = new FrodoCommand('frodo saml delete');
|
|
13
|
+
program.description('Delete SAML entity providers.').addOption(new Option('-i, --entity-id <entity-id>', 'Entity id. If specified, -a is ignored.')).addOption(new Option('-a, --all', 'Delete all entity providers. Ignored with -i.')).action(
|
|
14
14
|
// implement command logic inside action handler
|
|
15
|
-
async (host, realm, user, password, options) => {
|
|
16
|
-
|
|
17
|
-
state.default.session.setRealm(realm);
|
|
18
|
-
state.default.session.setUsername(user);
|
|
19
|
-
state.default.session.setPassword(password);
|
|
20
|
-
state.default.session.setDeploymentType(options.type);
|
|
21
|
-
state.default.session.setAllowInsecureConnection(options.insecure);
|
|
22
|
-
state.default.session.setVerbose(options.verbose);
|
|
23
|
-
state.default.session.setDebug(options.debug);
|
|
24
|
-
state.default.session.setCurlirize(options.curlirize);
|
|
15
|
+
async (host, realm, user, password, options, command) => {
|
|
16
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
25
17
|
// -i / --entity-id
|
|
26
18
|
if (options.entityId && (await getTokens())) {
|
|
27
19
|
verboseMessage(`Deleting entity provider '${options.entityId}'...`);
|
|
@@ -36,6 +28,7 @@ async (host, realm, user, password, options) => {
|
|
|
36
28
|
else {
|
|
37
29
|
printMessage('Unrecognized combination of options or no options...', 'error');
|
|
38
30
|
program.help();
|
|
31
|
+
process.exitCode = 1;
|
|
39
32
|
}
|
|
40
33
|
}
|
|
41
34
|
// end command logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-delete.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-delete.js","names":["FrodoCommand","Option","Authenticate","Saml2","printMessage","verboseMessage","getTokens","deleteSaml2Provider","deleteSaml2Providers","program","description","addOption","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","entityId","all","help","process","exitCode","parse"],"sources":["cli/saml/saml-delete.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, Saml2 } from '@rockcarver/frodo-lib';\nimport { printMessage, verboseMessage } from '../../utils/Console.js';\n\nconst { getTokens } = Authenticate;\nconst { deleteSaml2Provider, deleteSaml2Providers } = Saml2;\n\nconst program = new FrodoCommand('frodo saml delete');\n\nprogram\n .description('Delete SAML entity providers.')\n .addOption(\n new Option(\n '-i, --entity-id <entity-id>',\n 'Entity id. If specified, -a is ignored.'\n )\n )\n .addOption(\n new Option('-a, --all', 'Delete all entity providers. Ignored with -i.')\n )\n .action(\n // implement command logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n // -i / --entity-id\n if (options.entityId && (await getTokens())) {\n verboseMessage(`Deleting entity provider '${options.entityId}'...`);\n await deleteSaml2Provider(options.entityId);\n }\n // -a / --all\n else if (options.all && (await getTokens())) {\n verboseMessage(`Deleting all entity providers...`);\n await deleteSaml2Providers();\n }\n // unrecognized combination of options or no options\n else {\n printMessage(\n 'Unrecognized combination of options or no options...',\n 'error'\n );\n program.help();\n process.exitCode = 1;\n }\n }\n // end command logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,KAAK,QAAQ,uBAAuB;AAC3D,SAASC,YAAY,EAAEC,cAAc,QAAQ,wBAAwB;AAErE,MAAM;EAAEC;AAAU,CAAC,GAAGJ,YAAY;AAClC,MAAM;EAAEK,mBAAmB;EAAEC;AAAqB,CAAC,GAAGL,KAAK;AAE3D,MAAMM,OAAO,GAAG,IAAIT,YAAY,CAAC,mBAAmB,CAAC;AAErDS,OAAO,CACJC,WAAW,CAAC,+BAA+B,CAAC,CAC5CC,SAAS,CACR,IAAIV,MAAM,CACR,6BAA6B,EAC7B,yCAAyC,CAC1C,CACF,CACAU,SAAS,CACR,IAAIV,MAAM,CAAC,WAAW,EAAE,+CAA+C,CAAC,CACzE,CACAW,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD;EACA,IAAID,OAAO,CAACG,QAAQ,KAAK,MAAMd,SAAS,EAAE,CAAC,EAAE;IAC3CD,cAAc,CAAE,6BAA4BY,OAAO,CAACG,QAAS,MAAK,CAAC;IACnE,MAAMb,mBAAmB,CAACU,OAAO,CAACG,QAAQ,CAAC;EAC7C;EACA;EAAA,KACK,IAAIH,OAAO,CAACI,GAAG,KAAK,MAAMf,SAAS,EAAE,CAAC,EAAE;IAC3CD,cAAc,CAAE,kCAAiC,CAAC;IAClD,MAAMG,oBAAoB,EAAE;EAC9B;EACA;EAAA,KACK;IACHJ,YAAY,CACV,sDAAsD,EACtD,OAAO,CACR;IACDK,OAAO,CAACa,IAAI,EAAE;IACdC,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHf,OAAO,CAACgB,KAAK,EAAE"}
|
|
@@ -1,27 +1,21 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { FrodoCommand } from '../FrodoCommand';
|
|
2
|
+
import { Option } from 'commander';
|
|
2
3
|
import { Authenticate, state } from '@rockcarver/frodo-lib';
|
|
3
|
-
import
|
|
4
|
-
import { printMessage } from '../../utils/Console';
|
|
4
|
+
import { verboseMessage } from '../../utils/Console';
|
|
5
5
|
import { describeSaml2Provider } from '../../ops/Saml2Ops';
|
|
6
6
|
const {
|
|
7
7
|
getTokens
|
|
8
8
|
} = Authenticate;
|
|
9
|
-
const program = new
|
|
10
|
-
program.description('Describe the configuration of an entity provider.').
|
|
9
|
+
const program = new FrodoCommand('frodo saml describe');
|
|
10
|
+
program.description('Describe the configuration of an entity provider.').addOption(new Option('-i, --entity-id <entity-id>', 'Entity id.')).action(
|
|
11
11
|
// implement command logic inside action handler
|
|
12
|
-
async (host, realm, user, password, options) => {
|
|
13
|
-
|
|
14
|
-
state.default.session.setRealm(realm);
|
|
15
|
-
state.default.session.setUsername(user);
|
|
16
|
-
state.default.session.setPassword(password);
|
|
17
|
-
state.default.session.setDeploymentType(options.type);
|
|
18
|
-
state.default.session.setAllowInsecureConnection(options.insecure);
|
|
19
|
-
state.default.session.setVerbose(options.verbose);
|
|
20
|
-
state.default.session.setDebug(options.debug);
|
|
21
|
-
state.default.session.setCurlirize(options.curlirize);
|
|
12
|
+
async (host, realm, user, password, options, command) => {
|
|
13
|
+
command.handleDefaultArgsAndOpts(host, realm, user, password, options, command);
|
|
22
14
|
if (await getTokens()) {
|
|
23
|
-
|
|
15
|
+
verboseMessage(`Describing SAML entity provider ${options.entityId} in realm "${state.getRealm()}"...`);
|
|
24
16
|
describeSaml2Provider(options.entityId);
|
|
17
|
+
} else {
|
|
18
|
+
process.exitCode = 1;
|
|
25
19
|
}
|
|
26
20
|
}
|
|
27
21
|
// end command logic inside action handler
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"saml-describe.js","names":["
|
|
1
|
+
{"version":3,"file":"saml-describe.js","names":["FrodoCommand","Option","Authenticate","state","verboseMessage","describeSaml2Provider","getTokens","program","description","addOption","action","host","realm","user","password","options","command","handleDefaultArgsAndOpts","entityId","getRealm","process","exitCode","parse"],"sources":["cli/saml/saml-describe.ts"],"sourcesContent":["import { FrodoCommand } from '../FrodoCommand';\nimport { Option } from 'commander';\nimport { Authenticate, state } from '@rockcarver/frodo-lib';\nimport { verboseMessage } from '../../utils/Console';\nimport { describeSaml2Provider } from '../../ops/Saml2Ops';\n\nconst { getTokens } = Authenticate;\n\nconst program = new FrodoCommand('frodo saml describe');\n\nprogram\n .description('Describe the configuration of an entity provider.')\n .addOption(new Option('-i, --entity-id <entity-id>', 'Entity id.'))\n .action(\n // implement command logic inside action handler\n async (host, realm, user, password, options, command) => {\n command.handleDefaultArgsAndOpts(\n host,\n realm,\n user,\n password,\n options,\n command\n );\n if (await getTokens()) {\n verboseMessage(\n `Describing SAML entity provider ${\n options.entityId\n } in realm \"${state.getRealm()}\"...`\n );\n describeSaml2Provider(options.entityId);\n } else {\n process.exitCode = 1;\n }\n }\n // end command logic inside action handler\n );\n\nprogram.parse();\n"],"mappings":"AAAA,SAASA,YAAY,QAAQ,iBAAiB;AAC9C,SAASC,MAAM,QAAQ,WAAW;AAClC,SAASC,YAAY,EAAEC,KAAK,QAAQ,uBAAuB;AAC3D,SAASC,cAAc,QAAQ,qBAAqB;AACpD,SAASC,qBAAqB,QAAQ,oBAAoB;AAE1D,MAAM;EAAEC;AAAU,CAAC,GAAGJ,YAAY;AAElC,MAAMK,OAAO,GAAG,IAAIP,YAAY,CAAC,qBAAqB,CAAC;AAEvDO,OAAO,CACJC,WAAW,CAAC,mDAAmD,CAAC,CAChEC,SAAS,CAAC,IAAIR,MAAM,CAAC,6BAA6B,EAAE,YAAY,CAAC,CAAC,CAClES,MAAM;AACL;AACA,OAAOC,IAAI,EAAEC,KAAK,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,OAAO,KAAK;EACvDA,OAAO,CAACC,wBAAwB,CAC9BN,IAAI,EACJC,KAAK,EACLC,IAAI,EACJC,QAAQ,EACRC,OAAO,EACPC,OAAO,CACR;EACD,IAAI,MAAMV,SAAS,EAAE,EAAE;IACrBF,cAAc,CACX,mCACCW,OAAO,CAACG,QACT,cAAaf,KAAK,CAACgB,QAAQ,EAAG,MAAK,CACrC;IACDd,qBAAqB,CAACU,OAAO,CAACG,QAAQ,CAAC;EACzC,CAAC,MAAM;IACLE,OAAO,CAACC,QAAQ,GAAG,CAAC;EACtB;AACF;AACA;AAAA,CACD;;AAEHd,OAAO,CAACe,KAAK,EAAE"}
|