@salesforce/b2c-cli 0.0.8 → 0.2.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/dist/commands/code/activate.d.ts +1 -0
- package/dist/commands/code/delete.d.ts +11 -0
- package/dist/commands/code/delete.js +6 -2
- package/dist/commands/code/delete.js.map +1 -1
- package/dist/commands/code/deploy.d.ts +8 -1
- package/dist/commands/code/deploy.js +10 -4
- package/dist/commands/code/deploy.js.map +1 -1
- package/dist/commands/code/watch.d.ts +5 -0
- package/dist/commands/code/watch.js +4 -1
- package/dist/commands/code/watch.js.map +1 -1
- package/dist/commands/docs/download.d.ts +5 -1
- package/dist/commands/docs/download.js +4 -1
- package/dist/commands/docs/download.js.map +1 -1
- package/dist/commands/docs/read.d.ts +4 -1
- package/dist/commands/docs/read.js +4 -2
- package/dist/commands/docs/read.js.map +1 -1
- package/dist/commands/docs/schema.d.ts +5 -1
- package/dist/commands/docs/schema.js +6 -2
- package/dist/commands/docs/schema.js.map +1 -1
- package/dist/commands/docs/search.d.ts +5 -1
- package/dist/commands/docs/search.js +6 -2
- package/dist/commands/docs/search.js.map +1 -1
- package/dist/commands/ecdn/cache/purge.d.ts +43 -0
- package/dist/commands/ecdn/cache/purge.js +104 -0
- package/dist/commands/ecdn/cache/purge.js.map +1 -0
- package/dist/commands/ecdn/certificates/add.d.ts +44 -0
- package/dist/commands/ecdn/certificates/add.js +109 -0
- package/dist/commands/ecdn/certificates/add.js.map +1 -0
- package/dist/commands/ecdn/certificates/delete.d.ts +41 -0
- package/dist/commands/ecdn/certificates/delete.js +69 -0
- package/dist/commands/ecdn/certificates/delete.js.map +1 -0
- package/dist/commands/ecdn/certificates/list.d.ts +46 -0
- package/dist/commands/ecdn/certificates/list.js +124 -0
- package/dist/commands/ecdn/certificates/list.js.map +1 -0
- package/dist/commands/ecdn/certificates/update.d.ts +45 -0
- package/dist/commands/ecdn/certificates/update.js +104 -0
- package/dist/commands/ecdn/certificates/update.js.map +1 -0
- package/dist/commands/ecdn/certificates/validate.d.ts +40 -0
- package/dist/commands/ecdn/certificates/validate.js +68 -0
- package/dist/commands/ecdn/certificates/validate.js.map +1 -0
- package/dist/commands/ecdn/cipher-suites/get.d.ts +39 -0
- package/dist/commands/ecdn/cipher-suites/get.js +63 -0
- package/dist/commands/ecdn/cipher-suites/get.js.map +1 -0
- package/dist/commands/ecdn/cipher-suites/update.d.ts +41 -0
- package/dist/commands/ecdn/cipher-suites/update.js +81 -0
- package/dist/commands/ecdn/cipher-suites/update.js.map +1 -0
- package/dist/commands/ecdn/logpush/jobs/create.d.ts +45 -0
- package/dist/commands/ecdn/logpush/jobs/create.js +103 -0
- package/dist/commands/ecdn/logpush/jobs/create.js.map +1 -0
- package/dist/commands/ecdn/logpush/jobs/delete.d.ts +39 -0
- package/dist/commands/ecdn/logpush/jobs/delete.js +50 -0
- package/dist/commands/ecdn/logpush/jobs/delete.js.map +1 -0
- package/dist/commands/ecdn/logpush/jobs/get.d.ts +40 -0
- package/dist/commands/ecdn/logpush/jobs/get.js +85 -0
- package/dist/commands/ecdn/logpush/jobs/get.js.map +1 -0
- package/dist/commands/ecdn/logpush/jobs/list.d.ts +43 -0
- package/dist/commands/ecdn/logpush/jobs/list.js +124 -0
- package/dist/commands/ecdn/logpush/jobs/list.js.map +1 -0
- package/dist/commands/ecdn/logpush/jobs/update.d.ts +43 -0
- package/dist/commands/ecdn/logpush/jobs/update.js +94 -0
- package/dist/commands/ecdn/logpush/jobs/update.js.map +1 -0
- package/dist/commands/ecdn/logpush/ownership.d.ts +39 -0
- package/dist/commands/ecdn/logpush/ownership.js +72 -0
- package/dist/commands/ecdn/logpush/ownership.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/create.d.ts +42 -0
- package/dist/commands/ecdn/mrt-rules/create.js +81 -0
- package/dist/commands/ecdn/mrt-rules/create.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/delete.d.ts +39 -0
- package/dist/commands/ecdn/mrt-rules/delete.js +52 -0
- package/dist/commands/ecdn/mrt-rules/delete.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/get.d.ts +39 -0
- package/dist/commands/ecdn/mrt-rules/get.js +89 -0
- package/dist/commands/ecdn/mrt-rules/get.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/rules/delete.d.ts +40 -0
- package/dist/commands/ecdn/mrt-rules/rules/delete.js +57 -0
- package/dist/commands/ecdn/mrt-rules/rules/delete.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/rules/update.d.ts +44 -0
- package/dist/commands/ecdn/mrt-rules/rules/update.js +88 -0
- package/dist/commands/ecdn/mrt-rules/rules/update.js.map +1 -0
- package/dist/commands/ecdn/mrt-rules/update.d.ts +43 -0
- package/dist/commands/ecdn/mrt-rules/update.js +87 -0
- package/dist/commands/ecdn/mrt-rules/update.js.map +1 -0
- package/dist/commands/ecdn/mtls/create.d.ts +41 -0
- package/dist/commands/ecdn/mtls/create.js +84 -0
- package/dist/commands/ecdn/mtls/create.js.map +1 -0
- package/dist/commands/ecdn/mtls/delete.d.ts +38 -0
- package/dist/commands/ecdn/mtls/delete.js +53 -0
- package/dist/commands/ecdn/mtls/delete.js.map +1 -0
- package/dist/commands/ecdn/mtls/get.d.ts +39 -0
- package/dist/commands/ecdn/mtls/get.js +72 -0
- package/dist/commands/ecdn/mtls/get.js.map +1 -0
- package/dist/commands/ecdn/mtls/list.d.ts +42 -0
- package/dist/commands/ecdn/mtls/list.js +118 -0
- package/dist/commands/ecdn/mtls/list.js.map +1 -0
- package/dist/commands/ecdn/origin-headers/delete.d.ts +37 -0
- package/dist/commands/ecdn/origin-headers/delete.js +46 -0
- package/dist/commands/ecdn/origin-headers/delete.js.map +1 -0
- package/dist/commands/ecdn/origin-headers/get.d.ts +39 -0
- package/dist/commands/ecdn/origin-headers/get.js +61 -0
- package/dist/commands/ecdn/origin-headers/get.js.map +1 -0
- package/dist/commands/ecdn/origin-headers/set.d.ts +41 -0
- package/dist/commands/ecdn/origin-headers/set.js +76 -0
- package/dist/commands/ecdn/origin-headers/set.js.map +1 -0
- package/dist/commands/ecdn/page-shield/notifications/create.d.ts +41 -0
- package/dist/commands/ecdn/page-shield/notifications/create.js +84 -0
- package/dist/commands/ecdn/page-shield/notifications/create.js.map +1 -0
- package/dist/commands/ecdn/page-shield/notifications/delete.d.ts +38 -0
- package/dist/commands/ecdn/page-shield/notifications/delete.js +53 -0
- package/dist/commands/ecdn/page-shield/notifications/delete.js.map +1 -0
- package/dist/commands/ecdn/page-shield/notifications/list.d.ts +42 -0
- package/dist/commands/ecdn/page-shield/notifications/list.js +118 -0
- package/dist/commands/ecdn/page-shield/notifications/list.js.map +1 -0
- package/dist/commands/ecdn/page-shield/policies/create.d.ts +44 -0
- package/dist/commands/ecdn/page-shield/policies/create.js +100 -0
- package/dist/commands/ecdn/page-shield/policies/create.js.map +1 -0
- package/dist/commands/ecdn/page-shield/policies/delete.d.ts +39 -0
- package/dist/commands/ecdn/page-shield/policies/delete.js +56 -0
- package/dist/commands/ecdn/page-shield/policies/delete.js.map +1 -0
- package/dist/commands/ecdn/page-shield/policies/get.d.ts +40 -0
- package/dist/commands/ecdn/page-shield/policies/get.js +72 -0
- package/dist/commands/ecdn/page-shield/policies/get.js.map +1 -0
- package/dist/commands/ecdn/page-shield/policies/list.d.ts +43 -0
- package/dist/commands/ecdn/page-shield/policies/list.js +119 -0
- package/dist/commands/ecdn/page-shield/policies/list.js.map +1 -0
- package/dist/commands/ecdn/page-shield/policies/update.d.ts +45 -0
- package/dist/commands/ecdn/page-shield/policies/update.js +110 -0
- package/dist/commands/ecdn/page-shield/policies/update.js.map +1 -0
- package/dist/commands/ecdn/page-shield/scripts/get.d.ts +40 -0
- package/dist/commands/ecdn/page-shield/scripts/get.js +99 -0
- package/dist/commands/ecdn/page-shield/scripts/get.js.map +1 -0
- package/dist/commands/ecdn/page-shield/scripts/list.d.ts +43 -0
- package/dist/commands/ecdn/page-shield/scripts/list.js +124 -0
- package/dist/commands/ecdn/page-shield/scripts/list.js.map +1 -0
- package/dist/commands/ecdn/security/get.d.ts +39 -0
- package/dist/commands/ecdn/security/get.js +69 -0
- package/dist/commands/ecdn/security/get.js.map +1 -0
- package/dist/commands/ecdn/security/update.d.ts +47 -0
- package/dist/commands/ecdn/security/update.js +136 -0
- package/dist/commands/ecdn/security/update.js.map +1 -0
- package/dist/commands/ecdn/speed/get.d.ts +39 -0
- package/dist/commands/ecdn/speed/get.js +64 -0
- package/dist/commands/ecdn/speed/get.js.map +1 -0
- package/dist/commands/ecdn/speed/update.d.ts +46 -0
- package/dist/commands/ecdn/speed/update.js +105 -0
- package/dist/commands/ecdn/speed/update.js.map +1 -0
- package/dist/commands/ecdn/waf/groups/list.d.ts +42 -0
- package/dist/commands/ecdn/waf/groups/list.js +89 -0
- package/dist/commands/ecdn/waf/groups/list.js.map +1 -0
- package/dist/commands/ecdn/waf/groups/update.d.ts +43 -0
- package/dist/commands/ecdn/waf/groups/update.js +84 -0
- package/dist/commands/ecdn/waf/groups/update.js.map +1 -0
- package/dist/commands/ecdn/waf/managed-rules/list.d.ts +44 -0
- package/dist/commands/ecdn/waf/managed-rules/list.js +124 -0
- package/dist/commands/ecdn/waf/managed-rules/list.js.map +1 -0
- package/dist/commands/ecdn/waf/managed-rules/update.d.ts +43 -0
- package/dist/commands/ecdn/waf/managed-rules/update.js +94 -0
- package/dist/commands/ecdn/waf/managed-rules/update.js.map +1 -0
- package/dist/commands/ecdn/waf/migrate.d.ts +40 -0
- package/dist/commands/ecdn/waf/migrate.js +83 -0
- package/dist/commands/ecdn/waf/migrate.js.map +1 -0
- package/dist/commands/ecdn/waf/owasp/get.d.ts +40 -0
- package/dist/commands/ecdn/waf/owasp/get.js +64 -0
- package/dist/commands/ecdn/waf/owasp/get.js.map +1 -0
- package/dist/commands/ecdn/waf/owasp/update.d.ts +42 -0
- package/dist/commands/ecdn/waf/owasp/update.js +79 -0
- package/dist/commands/ecdn/waf/owasp/update.js.map +1 -0
- package/dist/commands/ecdn/waf/rules/get.d.ts +41 -0
- package/dist/commands/ecdn/waf/rules/get.js +68 -0
- package/dist/commands/ecdn/waf/rules/get.js.map +1 -0
- package/dist/commands/ecdn/waf/rules/list.d.ts +45 -0
- package/dist/commands/ecdn/waf/rules/list.js +120 -0
- package/dist/commands/ecdn/waf/rules/list.js.map +1 -0
- package/dist/commands/ecdn/waf/rules/update.d.ts +42 -0
- package/dist/commands/ecdn/waf/rules/update.js +77 -0
- package/dist/commands/ecdn/waf/rules/update.js.map +1 -0
- package/dist/commands/ecdn/waf/rulesets/list.d.ts +43 -0
- package/dist/commands/ecdn/waf/rulesets/list.js +119 -0
- package/dist/commands/ecdn/waf/rulesets/list.js.map +1 -0
- package/dist/commands/ecdn/waf/rulesets/update.d.ts +44 -0
- package/dist/commands/ecdn/waf/rulesets/update.js +101 -0
- package/dist/commands/ecdn/waf/rulesets/update.js.map +1 -0
- package/dist/commands/ecdn/zones/create.d.ts +40 -0
- package/dist/commands/ecdn/zones/create.js +71 -0
- package/dist/commands/ecdn/zones/create.js.map +1 -0
- package/dist/commands/ecdn/zones/list.d.ts +44 -0
- package/dist/commands/ecdn/zones/list.js +112 -0
- package/dist/commands/ecdn/zones/list.js.map +1 -0
- package/dist/commands/job/export.d.ts +5 -1
- package/dist/commands/job/export.js +5 -2
- package/dist/commands/job/export.js.map +1 -1
- package/dist/commands/job/import.d.ts +5 -1
- package/dist/commands/job/import.js +5 -2
- package/dist/commands/job/import.js.map +1 -1
- package/dist/commands/job/run.d.ts +6 -1
- package/dist/commands/job/run.js +6 -2
- package/dist/commands/job/run.js.map +1 -1
- package/dist/commands/job/search.d.ts +5 -1
- package/dist/commands/job/search.js +4 -1
- package/dist/commands/job/search.js.map +1 -1
- package/dist/commands/job/wait.d.ts +5 -1
- package/dist/commands/job/wait.js +4 -1
- package/dist/commands/job/wait.js.map +1 -1
- package/dist/commands/mrt/{push.d.ts → bundle/deploy.d.ts} +24 -6
- package/dist/commands/mrt/{push.js → bundle/deploy.js} +79 -19
- package/dist/commands/mrt/bundle/deploy.js.map +1 -0
- package/dist/commands/mrt/bundle/download.d.ts +40 -0
- package/dist/commands/mrt/bundle/download.js +109 -0
- package/dist/commands/mrt/bundle/download.js.map +1 -0
- package/dist/commands/mrt/bundle/history.d.ts +30 -0
- package/dist/commands/mrt/bundle/history.js +90 -0
- package/dist/commands/mrt/bundle/history.js.map +1 -0
- package/dist/commands/mrt/bundle/list.d.ts +30 -0
- package/dist/commands/mrt/bundle/list.js +79 -0
- package/dist/commands/mrt/bundle/list.js.map +1 -0
- package/dist/commands/mrt/env/access-control/list.d.ts +30 -0
- package/dist/commands/mrt/env/access-control/list.js +83 -0
- package/dist/commands/mrt/env/access-control/list.js.map +1 -0
- package/dist/commands/mrt/env/b2c.d.ts +32 -0
- package/dist/commands/mrt/env/b2c.js +120 -0
- package/dist/commands/mrt/env/b2c.js.map +1 -0
- package/dist/commands/mrt/env/create.d.ts +5 -1
- package/dist/commands/mrt/env/create.js +6 -2
- package/dist/commands/mrt/env/create.js.map +1 -1
- package/dist/commands/mrt/env/delete.d.ts +10 -0
- package/dist/commands/mrt/env/delete.js +6 -2
- package/dist/commands/mrt/env/delete.js.map +1 -1
- package/dist/commands/mrt/env/get.d.ts +28 -0
- package/dist/commands/mrt/env/get.js +98 -0
- package/dist/commands/mrt/env/get.js.map +1 -0
- package/dist/commands/mrt/env/invalidate.d.ts +29 -0
- package/dist/commands/mrt/env/invalidate.js +66 -0
- package/dist/commands/mrt/env/invalidate.js.map +1 -0
- package/dist/commands/mrt/env/list.d.ts +28 -0
- package/dist/commands/mrt/env/list.js +68 -0
- package/dist/commands/mrt/env/list.js.map +1 -0
- package/dist/commands/mrt/env/redirect/clone.d.ts +31 -0
- package/dist/commands/mrt/env/redirect/clone.js +95 -0
- package/dist/commands/mrt/env/redirect/clone.js.map +1 -0
- package/dist/commands/mrt/env/redirect/create.d.ts +33 -0
- package/dist/commands/mrt/env/redirect/create.js +87 -0
- package/dist/commands/mrt/env/redirect/create.js.map +1 -0
- package/dist/commands/mrt/env/redirect/delete.d.ts +34 -0
- package/dist/commands/mrt/env/redirect/delete.js +92 -0
- package/dist/commands/mrt/env/redirect/delete.js.map +1 -0
- package/dist/commands/mrt/env/redirect/list.d.ts +31 -0
- package/dist/commands/mrt/env/redirect/list.js +90 -0
- package/dist/commands/mrt/env/redirect/list.js.map +1 -0
- package/dist/commands/mrt/env/update.d.ts +37 -0
- package/dist/commands/mrt/env/update.js +173 -0
- package/dist/commands/mrt/env/update.js.map +1 -0
- package/dist/commands/mrt/env/var/delete.d.ts +4 -0
- package/dist/commands/mrt/env/var/delete.js +4 -1
- package/dist/commands/mrt/env/var/delete.js.map +1 -1
- package/dist/commands/mrt/env/var/list.d.ts +5 -1
- package/dist/commands/mrt/env/var/list.js +8 -2
- package/dist/commands/mrt/env/var/list.js.map +1 -1
- package/dist/commands/mrt/env/var/set.d.ts +4 -0
- package/dist/commands/mrt/env/var/set.js +4 -1
- package/dist/commands/mrt/env/var/set.js.map +1 -1
- package/dist/commands/mrt/org/b2c.d.ts +31 -0
- package/dist/commands/mrt/org/b2c.js +55 -0
- package/dist/commands/mrt/org/b2c.js.map +1 -0
- package/dist/commands/mrt/org/list.d.ts +30 -0
- package/dist/commands/mrt/org/list.js +70 -0
- package/dist/commands/mrt/org/list.js.map +1 -0
- package/dist/commands/mrt/project/create.d.ts +35 -0
- package/dist/commands/mrt/project/create.js +129 -0
- package/dist/commands/mrt/project/create.js.map +1 -0
- package/dist/commands/mrt/project/delete.d.ts +39 -0
- package/dist/commands/mrt/project/delete.js +81 -0
- package/dist/commands/mrt/project/delete.js.map +1 -0
- package/dist/commands/mrt/project/get.d.ts +31 -0
- package/dist/commands/mrt/project/get.js +79 -0
- package/dist/commands/mrt/project/get.js.map +1 -0
- package/dist/commands/mrt/project/list.d.ts +31 -0
- package/dist/commands/mrt/project/list.js +80 -0
- package/dist/commands/mrt/project/list.js.map +1 -0
- package/dist/commands/mrt/project/member/add.d.ts +32 -0
- package/dist/commands/mrt/project/member/add.js +73 -0
- package/dist/commands/mrt/project/member/add.js.map +1 -0
- package/dist/commands/mrt/project/member/get.d.ts +31 -0
- package/dist/commands/mrt/project/member/get.js +70 -0
- package/dist/commands/mrt/project/member/get.js.map +1 -0
- package/dist/commands/mrt/project/member/list.d.ts +32 -0
- package/dist/commands/mrt/project/member/list.js +82 -0
- package/dist/commands/mrt/project/member/list.js.map +1 -0
- package/dist/commands/mrt/project/member/remove.d.ts +34 -0
- package/dist/commands/mrt/project/member/remove.js +89 -0
- package/dist/commands/mrt/project/member/remove.js.map +1 -0
- package/dist/commands/mrt/project/member/update.d.ts +32 -0
- package/dist/commands/mrt/project/member/update.js +72 -0
- package/dist/commands/mrt/project/member/update.js.map +1 -0
- package/dist/commands/mrt/project/notification/create.d.ts +33 -0
- package/dist/commands/mrt/project/notification/create.js +86 -0
- package/dist/commands/mrt/project/notification/create.js.map +1 -0
- package/dist/commands/mrt/project/notification/delete.d.ts +34 -0
- package/dist/commands/mrt/project/notification/delete.js +88 -0
- package/dist/commands/mrt/project/notification/delete.js.map +1 -0
- package/dist/commands/mrt/project/notification/get.d.ts +31 -0
- package/dist/commands/mrt/project/notification/get.js +86 -0
- package/dist/commands/mrt/project/notification/get.js.map +1 -0
- package/dist/commands/mrt/project/notification/list.d.ts +31 -0
- package/dist/commands/mrt/project/notification/list.js +88 -0
- package/dist/commands/mrt/project/notification/list.js.map +1 -0
- package/dist/commands/mrt/project/notification/update.d.ts +36 -0
- package/dist/commands/mrt/project/notification/update.js +86 -0
- package/dist/commands/mrt/project/notification/update.js.map +1 -0
- package/dist/commands/mrt/project/update.d.ts +34 -0
- package/dist/commands/mrt/project/update.js +123 -0
- package/dist/commands/mrt/project/update.js.map +1 -0
- package/dist/commands/mrt/user/api-key.d.ts +30 -0
- package/dist/commands/mrt/user/api-key.js +63 -0
- package/dist/commands/mrt/user/api-key.js.map +1 -0
- package/dist/commands/mrt/user/email-prefs.d.ts +30 -0
- package/dist/commands/mrt/user/email-prefs.js +83 -0
- package/dist/commands/mrt/user/email-prefs.js.map +1 -0
- package/dist/commands/mrt/user/profile.d.ts +28 -0
- package/dist/commands/mrt/user/profile.js +50 -0
- package/dist/commands/mrt/user/profile.js.map +1 -0
- package/dist/commands/ods/create.d.ts +1 -1
- package/dist/commands/ods/create.js +2 -3
- package/dist/commands/ods/create.js.map +1 -1
- package/dist/commands/ods/delete.js +2 -3
- package/dist/commands/ods/delete.js.map +1 -1
- package/dist/commands/ods/list.d.ts +1 -1
- package/dist/commands/ods/list.js +2 -3
- package/dist/commands/ods/list.js.map +1 -1
- package/dist/commands/ods/restart.d.ts +1 -1
- package/dist/commands/ods/restart.js +2 -3
- package/dist/commands/ods/restart.js.map +1 -1
- package/dist/commands/ods/start.d.ts +1 -1
- package/dist/commands/ods/start.js +2 -3
- package/dist/commands/ods/start.js.map +1 -1
- package/dist/commands/ods/stop.d.ts +1 -1
- package/dist/commands/ods/stop.js +2 -3
- package/dist/commands/ods/stop.js.map +1 -1
- package/dist/commands/scapi/custom/status.js +3 -3
- package/dist/commands/scapi/custom/status.js.map +1 -1
- package/dist/commands/scapi/schemas/get.d.ts +86 -0
- package/dist/commands/scapi/schemas/get.js +317 -0
- package/dist/commands/scapi/schemas/get.js.map +1 -0
- package/dist/commands/scapi/schemas/list.d.ts +48 -0
- package/dist/commands/scapi/schemas/list.js +148 -0
- package/dist/commands/scapi/schemas/list.js.map +1 -0
- package/dist/commands/setup/config.d.ts +45 -0
- package/dist/commands/setup/config.js +174 -0
- package/dist/commands/setup/config.js.map +1 -0
- package/dist/commands/setup/skills.d.ts +40 -0
- package/dist/commands/setup/skills.js +296 -0
- package/dist/commands/setup/skills.js.map +1 -0
- package/dist/commands/sites/list.js +5 -2
- package/dist/commands/sites/list.js.map +1 -1
- package/dist/commands/slas/client/create.d.ts +1 -1
- package/dist/commands/slas/client/create.js +3 -2
- package/dist/commands/slas/client/create.js.map +1 -1
- package/dist/commands/slas/client/delete.d.ts +1 -1
- package/dist/commands/slas/client/delete.js +3 -3
- package/dist/commands/slas/client/delete.js.map +1 -1
- package/dist/commands/slas/client/get.d.ts +1 -1
- package/dist/commands/slas/client/get.js +3 -3
- package/dist/commands/slas/client/get.js.map +1 -1
- package/dist/commands/slas/client/list.d.ts +1 -1
- package/dist/commands/slas/client/list.js +3 -3
- package/dist/commands/slas/client/list.js.map +1 -1
- package/dist/commands/slas/client/update.d.ts +1 -1
- package/dist/commands/slas/client/update.js +6 -5
- package/dist/commands/slas/client/update.js.map +1 -1
- package/dist/commands/webdav/get.d.ts +1 -0
- package/dist/commands/webdav/get.js +1 -1
- package/dist/commands/webdav/get.js.map +1 -1
- package/dist/commands/webdav/put.js +1 -1
- package/dist/commands/webdav/put.js.map +1 -1
- package/dist/commands/webdav/rm.d.ts +1 -0
- package/dist/commands/webdav/rm.js +1 -1
- package/dist/commands/webdav/rm.js.map +1 -1
- package/dist/i18n/locales/en.d.ts +25 -0
- package/dist/i18n/locales/en.js +29 -0
- package/dist/i18n/locales/en.js.map +1 -1
- package/dist/i18n/locales/index.d.ts +25 -0
- package/dist/utils/ecdn/base-command.d.ts +28 -0
- package/dist/utils/ecdn/base-command.js +69 -0
- package/dist/utils/ecdn/base-command.js.map +1 -0
- package/dist/utils/ecdn/index.d.ts +2 -0
- package/dist/utils/ecdn/index.js +8 -0
- package/dist/utils/ecdn/index.js.map +1 -0
- package/dist/utils/ecdn/zone-command.d.ts +42 -0
- package/dist/utils/ecdn/zone-command.js +75 -0
- package/dist/utils/ecdn/zone-command.js.map +1 -0
- package/dist/utils/scapi/schemas.d.ts +22 -0
- package/dist/utils/scapi/schemas.js +47 -0
- package/dist/utils/scapi/schemas.js.map +1 -0
- package/dist/utils/slas/client.d.ts +6 -20
- package/dist/utils/slas/client.js +18 -15
- package/dist/utils/slas/client.js.map +1 -1
- package/oclif.manifest.json +21674 -1924
- package/package.json +126 -8
- package/dist/commands/mrt/push.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purge.js","sourceRoot":"","sources":["../../../../src/commands/ecdn/cache/purge.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import type { CdnZonesComponents } from '@salesforce/b2c-tooling-sdk/clients';
|
|
2
|
+
import { EcdnZoneCommand } from '../../../utils/ecdn/index.js';
|
|
3
|
+
type Certificate = CdnZonesComponents['schemas']['Certificate'];
|
|
4
|
+
/**
|
|
5
|
+
* Response type for the add command.
|
|
6
|
+
*/
|
|
7
|
+
interface AddOutput {
|
|
8
|
+
certificate: Certificate;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Command to add a certificate for a zone.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesAdd extends EcdnZoneCommand<typeof EcdnCertificatesAdd> {
|
|
14
|
+
static description: string;
|
|
15
|
+
static enableJsonFlag: boolean;
|
|
16
|
+
static examples: string[];
|
|
17
|
+
static flags: {
|
|
18
|
+
hostname: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
19
|
+
type: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
20
|
+
'certificate-file': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
21
|
+
'private-key-file': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
22
|
+
'bundle-method': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
23
|
+
zone: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
24
|
+
'client-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
25
|
+
'client-secret': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
26
|
+
scope: import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
27
|
+
'short-code': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
28
|
+
'tenant-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
29
|
+
'auth-methods': import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
30
|
+
'account-manager-host': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
31
|
+
'log-level': import("@oclif/core/interfaces").OptionFlag<"trace" | "debug" | "info" | "warn" | "error" | "silent" | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
32
|
+
debug: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
33
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
34
|
+
lang: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
35
|
+
config: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
36
|
+
instance: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
37
|
+
'working-directory': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
38
|
+
'extra-query': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
39
|
+
'extra-body': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
40
|
+
'extra-headers': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
41
|
+
};
|
|
42
|
+
run(): Promise<AddOutput>;
|
|
43
|
+
}
|
|
44
|
+
export {};
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2025, Salesforce, Inc.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2
|
|
4
|
+
* For full license text, see the license.txt file in the repo root or http://www.apache.org/licenses/LICENSE-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { readFile } from 'node:fs/promises';
|
|
7
|
+
import { Flags } from '@oclif/core';
|
|
8
|
+
import { EcdnZoneCommand, formatApiError } from '../../../utils/ecdn/index.js';
|
|
9
|
+
import { t } from '../../../i18n/index.js';
|
|
10
|
+
/**
|
|
11
|
+
* Command to add a certificate for a zone.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesAdd extends EcdnZoneCommand {
|
|
14
|
+
static description = t('commands.ecdn.certificates.add.description', 'Add a certificate for a zone');
|
|
15
|
+
static enableJsonFlag = true;
|
|
16
|
+
static examples = [
|
|
17
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --hostname example.com --type automatic',
|
|
18
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --hostname example.com --type custom --certificate-file cert.pem --private-key-file key.pem',
|
|
19
|
+
];
|
|
20
|
+
static flags = {
|
|
21
|
+
...EcdnZoneCommand.baseFlags,
|
|
22
|
+
hostname: Flags.string({
|
|
23
|
+
char: 'h',
|
|
24
|
+
description: t('flags.hostname.description', 'Hostname for the certificate'),
|
|
25
|
+
required: true,
|
|
26
|
+
}),
|
|
27
|
+
type: Flags.string({
|
|
28
|
+
description: t('flags.certificateType.description', 'Certificate type (custom or automatic)'),
|
|
29
|
+
options: ['custom', 'automatic'],
|
|
30
|
+
default: 'automatic',
|
|
31
|
+
}),
|
|
32
|
+
'certificate-file': Flags.string({
|
|
33
|
+
description: t('flags.certificateFile.description', 'Path to certificate file (PEM format, required for custom type)'),
|
|
34
|
+
}),
|
|
35
|
+
'private-key-file': Flags.string({
|
|
36
|
+
description: t('flags.privateKeyFile.description', 'Path to private key file (PEM format, required for custom type)'),
|
|
37
|
+
}),
|
|
38
|
+
'bundle-method': Flags.string({
|
|
39
|
+
description: t('flags.bundleMethod.description', 'Bundle method for custom certificate chain verification'),
|
|
40
|
+
}),
|
|
41
|
+
};
|
|
42
|
+
async run() {
|
|
43
|
+
this.requireOAuthCredentials();
|
|
44
|
+
const zoneId = await this.resolveZoneId();
|
|
45
|
+
const hostname = this.flags.hostname;
|
|
46
|
+
const certificateType = this.flags.type;
|
|
47
|
+
const certificateFile = this.flags['certificate-file'];
|
|
48
|
+
const privateKeyFile = this.flags['private-key-file'];
|
|
49
|
+
const bundleMethod = this.flags['bundle-method'];
|
|
50
|
+
// Validate custom certificate requirements
|
|
51
|
+
if (certificateType === 'custom' && (!certificateFile || !privateKeyFile)) {
|
|
52
|
+
this.error(t('commands.ecdn.certificates.add.customRequired', 'Custom certificates require both --certificate-file and --private-key-file'));
|
|
53
|
+
}
|
|
54
|
+
if (!this.jsonEnabled()) {
|
|
55
|
+
this.log(t('commands.ecdn.certificates.add.adding', 'Adding {{type}} certificate for {{hostname}}...', {
|
|
56
|
+
type: certificateType,
|
|
57
|
+
hostname,
|
|
58
|
+
}));
|
|
59
|
+
}
|
|
60
|
+
// Build request body
|
|
61
|
+
const body = {
|
|
62
|
+
hostname,
|
|
63
|
+
certificateType,
|
|
64
|
+
};
|
|
65
|
+
if (certificateType === 'custom' && certificateFile && privateKeyFile) {
|
|
66
|
+
body.certificate = await readFile(certificateFile, 'utf8');
|
|
67
|
+
body.privateKey = await readFile(privateKeyFile, 'utf8');
|
|
68
|
+
}
|
|
69
|
+
if (bundleMethod) {
|
|
70
|
+
body.bundleMethod = bundleMethod;
|
|
71
|
+
}
|
|
72
|
+
const client = this.getCdnZonesRwClient();
|
|
73
|
+
const organizationId = this.getOrganizationId();
|
|
74
|
+
const { data, error } = await client.POST('/organizations/{organizationId}/zones/{zoneId}/certificates', {
|
|
75
|
+
params: {
|
|
76
|
+
path: { organizationId, zoneId },
|
|
77
|
+
},
|
|
78
|
+
body,
|
|
79
|
+
});
|
|
80
|
+
if (error) {
|
|
81
|
+
this.error(t('commands.ecdn.certificates.add.error', 'Failed to add certificate: {{message}}', {
|
|
82
|
+
message: formatApiError(error),
|
|
83
|
+
}));
|
|
84
|
+
}
|
|
85
|
+
const certificate = data?.data;
|
|
86
|
+
if (!certificate) {
|
|
87
|
+
this.error(t('commands.ecdn.certificates.add.noData', 'No certificate data returned from API'));
|
|
88
|
+
}
|
|
89
|
+
const output = { certificate };
|
|
90
|
+
if (this.jsonEnabled()) {
|
|
91
|
+
return output;
|
|
92
|
+
}
|
|
93
|
+
this.log('');
|
|
94
|
+
this.log(t('commands.ecdn.certificates.add.success', 'Certificate added successfully!'));
|
|
95
|
+
this.log('');
|
|
96
|
+
this.log(` Certificate ID: ${certificate.certificateId}`);
|
|
97
|
+
this.log(` Hosts: ${certificate.hosts?.join(', ') || '-'}`);
|
|
98
|
+
this.log(` Status: ${certificate.status}`);
|
|
99
|
+
this.log(` Type: ${certificate.certificateType}`);
|
|
100
|
+
if (certificate.certificateVerificationTXTName) {
|
|
101
|
+
this.log('');
|
|
102
|
+
this.log(' DNS Verification Required:');
|
|
103
|
+
this.log(` TXT Name: ${certificate.certificateVerificationTXTName}`);
|
|
104
|
+
this.log(` TXT Value: ${certificate.certificateVerificationTXTValue || '-'}`);
|
|
105
|
+
}
|
|
106
|
+
return output;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=add.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add.js","sourceRoot":"","sources":["../../../../src/commands/ecdn/certificates/add.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { EcdnZoneCommand } from '../../../utils/ecdn/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Response type for the delete command.
|
|
4
|
+
*/
|
|
5
|
+
interface DeleteOutput {
|
|
6
|
+
success: boolean;
|
|
7
|
+
certificateId: string;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Command to delete a certificate for a zone.
|
|
11
|
+
* WARNING: Deleting a certificate in use can cause site downtime.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesDelete extends EcdnZoneCommand<typeof EcdnCertificatesDelete> {
|
|
14
|
+
static description: string;
|
|
15
|
+
static enableJsonFlag: boolean;
|
|
16
|
+
static examples: string[];
|
|
17
|
+
static flags: {
|
|
18
|
+
'certificate-id': import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
19
|
+
force: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
20
|
+
zone: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
21
|
+
'client-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
22
|
+
'client-secret': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
23
|
+
scope: import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
24
|
+
'short-code': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
25
|
+
'tenant-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
26
|
+
'auth-methods': import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
27
|
+
'account-manager-host': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
28
|
+
'log-level': import("@oclif/core/interfaces").OptionFlag<"trace" | "debug" | "info" | "warn" | "error" | "silent" | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
29
|
+
debug: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
30
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
31
|
+
lang: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
32
|
+
config: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
33
|
+
instance: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
34
|
+
'working-directory': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
35
|
+
'extra-query': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
36
|
+
'extra-body': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
37
|
+
'extra-headers': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
38
|
+
};
|
|
39
|
+
run(): Promise<DeleteOutput>;
|
|
40
|
+
}
|
|
41
|
+
export {};
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2025, Salesforce, Inc.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2
|
|
4
|
+
* For full license text, see the license.txt file in the repo root or http://www.apache.org/licenses/LICENSE-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { Flags } from '@oclif/core';
|
|
7
|
+
import { EcdnZoneCommand, formatApiError } from '../../../utils/ecdn/index.js';
|
|
8
|
+
import { t } from '../../../i18n/index.js';
|
|
9
|
+
/**
|
|
10
|
+
* Command to delete a certificate for a zone.
|
|
11
|
+
* WARNING: Deleting a certificate in use can cause site downtime.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesDelete extends EcdnZoneCommand {
|
|
14
|
+
static description = t('commands.ecdn.certificates.delete.description', 'Delete a certificate from a zone (WARNING: can cause downtime if in use)');
|
|
15
|
+
static enableJsonFlag = true;
|
|
16
|
+
static examples = [
|
|
17
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --certificate-id abc123',
|
|
18
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --certificate-id abc123 --force',
|
|
19
|
+
];
|
|
20
|
+
static flags = {
|
|
21
|
+
...EcdnZoneCommand.baseFlags,
|
|
22
|
+
'certificate-id': Flags.string({
|
|
23
|
+
description: t('flags.certificateId.description', 'Certificate ID to delete'),
|
|
24
|
+
required: true,
|
|
25
|
+
}),
|
|
26
|
+
force: Flags.boolean({
|
|
27
|
+
char: 'f',
|
|
28
|
+
description: t('flags.force.description', 'Skip confirmation prompt'),
|
|
29
|
+
default: false,
|
|
30
|
+
}),
|
|
31
|
+
};
|
|
32
|
+
async run() {
|
|
33
|
+
this.requireOAuthCredentials();
|
|
34
|
+
const zoneId = await this.resolveZoneId();
|
|
35
|
+
const certificateId = this.flags['certificate-id'];
|
|
36
|
+
const force = this.flags.force;
|
|
37
|
+
if (!force && !this.jsonEnabled()) {
|
|
38
|
+
this.warn(t('commands.ecdn.certificates.delete.warning', 'WARNING: Deleting a certificate that is in use can result in downtime!'));
|
|
39
|
+
this.log(t('commands.ecdn.certificates.delete.useForce', 'Use --force to confirm deletion.'));
|
|
40
|
+
return { success: false, certificateId };
|
|
41
|
+
}
|
|
42
|
+
if (!this.jsonEnabled()) {
|
|
43
|
+
this.log(t('commands.ecdn.certificates.delete.deleting', 'Deleting certificate {{id}}...', { id: certificateId }));
|
|
44
|
+
}
|
|
45
|
+
const client = this.getCdnZonesRwClient();
|
|
46
|
+
const organizationId = this.getOrganizationId();
|
|
47
|
+
const { error } = await client.DELETE('/organizations/{organizationId}/zones/{zoneId}/certificates/{certificateId}', {
|
|
48
|
+
params: {
|
|
49
|
+
path: { organizationId, zoneId, certificateId },
|
|
50
|
+
},
|
|
51
|
+
});
|
|
52
|
+
if (error) {
|
|
53
|
+
this.error(t('commands.ecdn.certificates.delete.error', 'Failed to delete certificate: {{message}}', {
|
|
54
|
+
message: formatApiError(error),
|
|
55
|
+
}));
|
|
56
|
+
}
|
|
57
|
+
const output = {
|
|
58
|
+
success: true,
|
|
59
|
+
certificateId,
|
|
60
|
+
};
|
|
61
|
+
if (this.jsonEnabled()) {
|
|
62
|
+
return output;
|
|
63
|
+
}
|
|
64
|
+
this.log('');
|
|
65
|
+
this.log(t('commands.ecdn.certificates.delete.success', 'Certificate deleted successfully.'));
|
|
66
|
+
return output;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=delete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../../src/commands/ecdn/certificates/delete.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,EAAC,KAAK,EAAC,MAAM,aAAa,CAAC;AAClC,OAAO,EAAC,eAAe,EAAE,cAAc,EAAC,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAC,CAAC,EAAC,MAAM,wBAAwB,CAAC;AAUzC;;;GAGG;AACH,MAAM,CAAC,OAAO,OAAO,sBAAuB,SAAQ,eAA8C;IAChG,MAAM,CAAC,WAAW,GAAG,CAAC,CACpB,+CAA+C,EAC/C,0EAA0E,CAC3E,CAAC;IAEF,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC;IAE7B,MAAM,CAAC,QAAQ,GAAG;QAChB,iGAAiG;QACjG,yGAAyG;KAC1G,CAAC;IAEF,MAAM,CAAC,KAAK,GAAG;QACb,GAAG,eAAe,CAAC,SAAS;QAC5B,gBAAgB,EAAE,KAAK,CAAC,MAAM,CAAC;YAC7B,WAAW,EAAE,CAAC,CAAC,iCAAiC,EAAE,0BAA0B,CAAC;YAC7E,QAAQ,EAAE,IAAI;SACf,CAAC;QACF,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC;YACnB,IAAI,EAAE,GAAG;YACT,WAAW,EAAE,CAAC,CAAC,yBAAyB,EAAE,0BAA0B,CAAC;YACrE,OAAO,EAAE,KAAK;SACf,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAE/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAC1C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QACnD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;QAE/B,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CACP,CAAC,CACC,2CAA2C,EAC3C,wEAAwE,CACzE,CACF,CAAC;YACF,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,4CAA4C,EAAE,kCAAkC,CAAC,CAAC,CAAC;YAC9F,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,aAAa,EAAC,CAAC;QACzC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,4CAA4C,EAAE,gCAAgC,EAAE,EAAC,EAAE,EAAE,aAAa,EAAC,CAAC,CAAC,CAAC;QACnH,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC1C,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEhD,MAAM,EAAC,KAAK,EAAC,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,6EAA6E,EAAE;YACjH,MAAM,EAAE;gBACN,IAAI,EAAE,EAAC,cAAc,EAAE,MAAM,EAAE,aAAa,EAAC;aAC9C;SACF,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,KAAK,CACR,CAAC,CAAC,yCAAyC,EAAE,2CAA2C,EAAE;gBACxF,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC;aAC/B,CAAC,CACH,CAAC;QACJ,CAAC;QAED,MAAM,MAAM,GAAiB;YAC3B,OAAO,EAAE,IAAI;YACb,aAAa;SACd,CAAC;QAEF,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACvB,OAAO,MAAM,CAAC;QAChB,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACb,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,2CAA2C,EAAE,mCAAmC,CAAC,CAAC,CAAC;QAE9F,OAAO,MAAM,CAAC;IAChB,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import type { CdnZonesComponents } from '@salesforce/b2c-tooling-sdk/clients';
|
|
2
|
+
import { EcdnZoneCommand } from '../../../utils/ecdn/index.js';
|
|
3
|
+
type Certificate = CdnZonesComponents['schemas']['Certificate'];
|
|
4
|
+
/**
|
|
5
|
+
* Response type for the list command.
|
|
6
|
+
*/
|
|
7
|
+
interface ListOutput {
|
|
8
|
+
certificates: Certificate[];
|
|
9
|
+
total: number;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Command to list certificates for a zone.
|
|
13
|
+
*/
|
|
14
|
+
export default class EcdnCertificatesList extends EcdnZoneCommand<typeof EcdnCertificatesList> {
|
|
15
|
+
static description: string;
|
|
16
|
+
static enableJsonFlag: boolean;
|
|
17
|
+
static examples: string[];
|
|
18
|
+
static flags: {
|
|
19
|
+
columns: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
20
|
+
extended: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
21
|
+
zone: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
22
|
+
'client-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
23
|
+
'client-secret': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
24
|
+
scope: import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
25
|
+
'short-code': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
26
|
+
'tenant-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
27
|
+
'auth-methods': import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
28
|
+
'account-manager-host': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
29
|
+
'log-level': import("@oclif/core/interfaces").OptionFlag<"trace" | "debug" | "info" | "warn" | "error" | "silent" | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
30
|
+
debug: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
31
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
32
|
+
lang: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
33
|
+
config: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
34
|
+
instance: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
35
|
+
'working-directory': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
36
|
+
'extra-query': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
37
|
+
'extra-body': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
38
|
+
'extra-headers': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
39
|
+
};
|
|
40
|
+
run(): Promise<ListOutput>;
|
|
41
|
+
/**
|
|
42
|
+
* Determines which columns to display based on flags.
|
|
43
|
+
*/
|
|
44
|
+
private getSelectedColumns;
|
|
45
|
+
}
|
|
46
|
+
export {};
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2025, Salesforce, Inc.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2
|
|
4
|
+
* For full license text, see the license.txt file in the repo root or http://www.apache.org/licenses/LICENSE-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { Flags } from '@oclif/core';
|
|
7
|
+
import { TableRenderer } from '@salesforce/b2c-tooling-sdk/cli';
|
|
8
|
+
import { EcdnZoneCommand, formatApiError } from '../../../utils/ecdn/index.js';
|
|
9
|
+
import { t } from '../../../i18n/index.js';
|
|
10
|
+
const COLUMNS = {
|
|
11
|
+
certificateId: {
|
|
12
|
+
header: 'Certificate ID',
|
|
13
|
+
get: (c) => c.certificateId || '-',
|
|
14
|
+
extended: true,
|
|
15
|
+
},
|
|
16
|
+
hosts: {
|
|
17
|
+
header: 'Hosts',
|
|
18
|
+
get: (c) => c.hosts?.join(', ') || '-',
|
|
19
|
+
},
|
|
20
|
+
status: {
|
|
21
|
+
header: 'Status',
|
|
22
|
+
get: (c) => c.status || '-',
|
|
23
|
+
},
|
|
24
|
+
certificateType: {
|
|
25
|
+
header: 'Type',
|
|
26
|
+
get: (c) => c.certificateType || '-',
|
|
27
|
+
},
|
|
28
|
+
expiresOn: {
|
|
29
|
+
header: 'Expires',
|
|
30
|
+
get: (c) => (c.expiresOn ? new Date(c.expiresOn).toLocaleDateString() : '-'),
|
|
31
|
+
extended: true,
|
|
32
|
+
},
|
|
33
|
+
issuer: {
|
|
34
|
+
header: 'Issuer',
|
|
35
|
+
get: (c) => c.issuer || '-',
|
|
36
|
+
extended: true,
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
/** Default columns shown without --extended */
|
|
40
|
+
const DEFAULT_COLUMNS = ['hosts', 'status', 'certificateType'];
|
|
41
|
+
const tableRenderer = new TableRenderer(COLUMNS);
|
|
42
|
+
/**
|
|
43
|
+
* Command to list certificates for a zone.
|
|
44
|
+
*/
|
|
45
|
+
export default class EcdnCertificatesList extends EcdnZoneCommand {
|
|
46
|
+
static description = t('commands.ecdn.certificates.list.description', 'List certificates for a zone');
|
|
47
|
+
static enableJsonFlag = true;
|
|
48
|
+
static examples = [
|
|
49
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone',
|
|
50
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --extended',
|
|
51
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --json',
|
|
52
|
+
];
|
|
53
|
+
static flags = {
|
|
54
|
+
...EcdnZoneCommand.baseFlags,
|
|
55
|
+
columns: Flags.string({
|
|
56
|
+
char: 'c',
|
|
57
|
+
description: `Columns to display (comma-separated). Available: ${Object.keys(COLUMNS).join(', ')}`,
|
|
58
|
+
}),
|
|
59
|
+
extended: Flags.boolean({
|
|
60
|
+
char: 'x',
|
|
61
|
+
description: t('flags.extended.description', 'Show all columns including extended fields'),
|
|
62
|
+
default: false,
|
|
63
|
+
}),
|
|
64
|
+
};
|
|
65
|
+
async run() {
|
|
66
|
+
this.requireOAuthCredentials();
|
|
67
|
+
const zoneId = await this.resolveZoneId();
|
|
68
|
+
if (!this.jsonEnabled()) {
|
|
69
|
+
this.log(t('commands.ecdn.certificates.list.fetching', 'Fetching certificates...'));
|
|
70
|
+
}
|
|
71
|
+
const client = this.getCdnZonesClient();
|
|
72
|
+
const organizationId = this.getOrganizationId();
|
|
73
|
+
const { data, error } = await client.GET('/organizations/{organizationId}/zones/{zoneId}/certificates', {
|
|
74
|
+
params: {
|
|
75
|
+
path: { organizationId, zoneId },
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
if (error) {
|
|
79
|
+
this.error(t('commands.ecdn.certificates.list.error', 'Failed to fetch certificates: {{message}}', {
|
|
80
|
+
message: formatApiError(error),
|
|
81
|
+
}));
|
|
82
|
+
}
|
|
83
|
+
const certificates = data?.data ?? [];
|
|
84
|
+
const output = {
|
|
85
|
+
certificates,
|
|
86
|
+
total: certificates.length,
|
|
87
|
+
};
|
|
88
|
+
if (this.jsonEnabled()) {
|
|
89
|
+
return output;
|
|
90
|
+
}
|
|
91
|
+
if (certificates.length === 0) {
|
|
92
|
+
this.log(t('commands.ecdn.certificates.list.noCertificates', 'No certificates found.'));
|
|
93
|
+
return output;
|
|
94
|
+
}
|
|
95
|
+
this.log(t('commands.ecdn.certificates.list.count', 'Found {{count}} certificate(s):', {
|
|
96
|
+
count: certificates.length,
|
|
97
|
+
}));
|
|
98
|
+
this.log('');
|
|
99
|
+
const columns = this.getSelectedColumns();
|
|
100
|
+
tableRenderer.render(certificates, columns);
|
|
101
|
+
return output;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Determines which columns to display based on flags.
|
|
105
|
+
*/
|
|
106
|
+
getSelectedColumns() {
|
|
107
|
+
const columnsFlag = this.flags.columns;
|
|
108
|
+
const extended = this.flags.extended;
|
|
109
|
+
if (columnsFlag) {
|
|
110
|
+
const requested = columnsFlag.split(',').map((c) => c.trim());
|
|
111
|
+
const valid = tableRenderer.validateColumnKeys(requested);
|
|
112
|
+
if (valid.length === 0) {
|
|
113
|
+
this.warn(`No valid columns specified. Available: ${tableRenderer.getColumnKeys().join(', ')}`);
|
|
114
|
+
return DEFAULT_COLUMNS;
|
|
115
|
+
}
|
|
116
|
+
return valid;
|
|
117
|
+
}
|
|
118
|
+
if (extended) {
|
|
119
|
+
return tableRenderer.getColumnKeys();
|
|
120
|
+
}
|
|
121
|
+
return DEFAULT_COLUMNS;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../../src/commands/ecdn/certificates/list.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { CdnZonesComponents } from '@salesforce/b2c-tooling-sdk/clients';
|
|
2
|
+
import { EcdnZoneCommand } from '../../../utils/ecdn/index.js';
|
|
3
|
+
type Certificate = CdnZonesComponents['schemas']['Certificate'];
|
|
4
|
+
/**
|
|
5
|
+
* Response type for the update command.
|
|
6
|
+
*/
|
|
7
|
+
interface UpdateOutput {
|
|
8
|
+
certificate: Certificate;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Command to update a certificate for a zone.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesUpdate extends EcdnZoneCommand<typeof EcdnCertificatesUpdate> {
|
|
14
|
+
static description: string;
|
|
15
|
+
static enableJsonFlag: boolean;
|
|
16
|
+
static examples: string[];
|
|
17
|
+
static flags: {
|
|
18
|
+
'certificate-id': import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
19
|
+
hostname: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
20
|
+
type: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
21
|
+
'certificate-file': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
22
|
+
'private-key-file': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
23
|
+
'bundle-method': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
24
|
+
zone: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
|
|
25
|
+
'client-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
26
|
+
'client-secret': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
27
|
+
scope: import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
28
|
+
'short-code': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
29
|
+
'tenant-id': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
30
|
+
'auth-methods': import("@oclif/core/interfaces").OptionFlag<string[] | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
31
|
+
'account-manager-host': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
32
|
+
'log-level': import("@oclif/core/interfaces").OptionFlag<"trace" | "debug" | "info" | "warn" | "error" | "silent" | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
33
|
+
debug: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
34
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
35
|
+
lang: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
36
|
+
config: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
37
|
+
instance: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
38
|
+
'working-directory': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
39
|
+
'extra-query': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
40
|
+
'extra-body': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
41
|
+
'extra-headers': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
42
|
+
};
|
|
43
|
+
run(): Promise<UpdateOutput>;
|
|
44
|
+
}
|
|
45
|
+
export {};
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2025, Salesforce, Inc.
|
|
3
|
+
* SPDX-License-Identifier: Apache-2
|
|
4
|
+
* For full license text, see the license.txt file in the repo root or http://www.apache.org/licenses/LICENSE-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { readFile } from 'node:fs/promises';
|
|
7
|
+
import { Flags } from '@oclif/core';
|
|
8
|
+
import { EcdnZoneCommand, formatApiError } from '../../../utils/ecdn/index.js';
|
|
9
|
+
import { t } from '../../../i18n/index.js';
|
|
10
|
+
/**
|
|
11
|
+
* Command to update a certificate for a zone.
|
|
12
|
+
*/
|
|
13
|
+
export default class EcdnCertificatesUpdate extends EcdnZoneCommand {
|
|
14
|
+
static description = t('commands.ecdn.certificates.update.description', 'Update a certificate for a zone');
|
|
15
|
+
static enableJsonFlag = true;
|
|
16
|
+
static examples = [
|
|
17
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --certificate-id abc123 --hostname example.com',
|
|
18
|
+
'<%= config.bin %> <%= command.id %> --tenant-id zzxy_prd --zone my-zone --certificate-id abc123 --certificate-file cert.pem --private-key-file key.pem',
|
|
19
|
+
];
|
|
20
|
+
static flags = {
|
|
21
|
+
...EcdnZoneCommand.baseFlags,
|
|
22
|
+
'certificate-id': Flags.string({
|
|
23
|
+
description: t('flags.certificateId.description', 'Certificate ID to update'),
|
|
24
|
+
required: true,
|
|
25
|
+
}),
|
|
26
|
+
hostname: Flags.string({
|
|
27
|
+
char: 'h',
|
|
28
|
+
description: t('flags.hostname.description', 'Hostname for the certificate'),
|
|
29
|
+
}),
|
|
30
|
+
type: Flags.string({
|
|
31
|
+
description: t('flags.certificateType.description', 'Certificate type (custom or automatic)'),
|
|
32
|
+
options: ['custom', 'automatic'],
|
|
33
|
+
}),
|
|
34
|
+
'certificate-file': Flags.string({
|
|
35
|
+
description: t('flags.certificateFile.description', 'Path to certificate file (PEM format, required for custom type)'),
|
|
36
|
+
}),
|
|
37
|
+
'private-key-file': Flags.string({
|
|
38
|
+
description: t('flags.privateKeyFile.description', 'Path to private key file (PEM format, required for custom type)'),
|
|
39
|
+
}),
|
|
40
|
+
'bundle-method': Flags.string({
|
|
41
|
+
description: t('flags.bundleMethod.description', 'Bundle method for custom certificate chain verification'),
|
|
42
|
+
}),
|
|
43
|
+
};
|
|
44
|
+
async run() {
|
|
45
|
+
this.requireOAuthCredentials();
|
|
46
|
+
const zoneId = await this.resolveZoneId();
|
|
47
|
+
const certificateId = this.flags['certificate-id'];
|
|
48
|
+
const hostname = this.flags.hostname;
|
|
49
|
+
const certificateType = this.flags.type;
|
|
50
|
+
const certificateFile = this.flags['certificate-file'];
|
|
51
|
+
const privateKeyFile = this.flags['private-key-file'];
|
|
52
|
+
const bundleMethod = this.flags['bundle-method'];
|
|
53
|
+
if (!this.jsonEnabled()) {
|
|
54
|
+
this.log(t('commands.ecdn.certificates.update.updating', 'Updating certificate {{id}}...', { id: certificateId }));
|
|
55
|
+
}
|
|
56
|
+
// Build request body - hostname is required by the API
|
|
57
|
+
if (!hostname) {
|
|
58
|
+
this.error(t('commands.ecdn.certificates.update.hostnameRequired', 'Hostname is required for certificate update'));
|
|
59
|
+
}
|
|
60
|
+
const body = {
|
|
61
|
+
hostname,
|
|
62
|
+
};
|
|
63
|
+
if (certificateType) {
|
|
64
|
+
body.certificateType = certificateType;
|
|
65
|
+
}
|
|
66
|
+
if (certificateFile && privateKeyFile) {
|
|
67
|
+
body.certificate = await readFile(certificateFile, 'utf8');
|
|
68
|
+
body.privateKey = await readFile(privateKeyFile, 'utf8');
|
|
69
|
+
}
|
|
70
|
+
if (bundleMethod) {
|
|
71
|
+
body.bundleMethod = bundleMethod;
|
|
72
|
+
}
|
|
73
|
+
const client = this.getCdnZonesRwClient();
|
|
74
|
+
const organizationId = this.getOrganizationId();
|
|
75
|
+
const { data, error } = await client.PATCH('/organizations/{organizationId}/zones/{zoneId}/certificates/{certificateId}', {
|
|
76
|
+
params: {
|
|
77
|
+
path: { organizationId, zoneId, certificateId },
|
|
78
|
+
},
|
|
79
|
+
body,
|
|
80
|
+
});
|
|
81
|
+
if (error) {
|
|
82
|
+
this.error(t('commands.ecdn.certificates.update.error', 'Failed to update certificate: {{message}}', {
|
|
83
|
+
message: formatApiError(error),
|
|
84
|
+
}));
|
|
85
|
+
}
|
|
86
|
+
const certificate = data?.data;
|
|
87
|
+
if (!certificate) {
|
|
88
|
+
this.error(t('commands.ecdn.certificates.update.noData', 'No certificate data returned from API'));
|
|
89
|
+
}
|
|
90
|
+
const output = { certificate };
|
|
91
|
+
if (this.jsonEnabled()) {
|
|
92
|
+
return output;
|
|
93
|
+
}
|
|
94
|
+
this.log('');
|
|
95
|
+
this.log(t('commands.ecdn.certificates.update.success', 'Certificate updated successfully!'));
|
|
96
|
+
this.log('');
|
|
97
|
+
this.log(` Certificate ID: ${certificate.certificateId}`);
|
|
98
|
+
this.log(` Hosts: ${certificate.hosts?.join(', ') || '-'}`);
|
|
99
|
+
this.log(` Status: ${certificate.status}`);
|
|
100
|
+
this.log(` Type: ${certificate.certificateType}`);
|
|
101
|
+
return output;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=update.js.map
|