@salesforce/afv-skills 1.8.0 → 1.9.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/package.json +1 -1
- package/skills/activating-datacloud/CREDITS.md +5 -0
- package/skills/activating-datacloud/README.md +39 -0
- package/skills/activating-datacloud/SKILL.md +118 -0
- package/skills/analyzing-omnistudio-dependencies/CREDITS.md +5 -0
- package/skills/analyzing-omnistudio-dependencies/SKILL.md +477 -0
- package/skills/analyzing-omnistudio-dependencies/references/dependency-patterns.md +508 -0
- package/skills/analyzing-omnistudio-dependencies/references/namespace-guide.md +300 -0
- package/skills/building-omnistudio-callable-apex/CREDITS.md +9 -0
- package/skills/building-omnistudio-callable-apex/README.md +80 -0
- package/skills/building-omnistudio-callable-apex/SKILL.md +276 -0
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_openinterface.cls +40 -0
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_vanilla.cls +32 -0
- package/skills/building-omnistudio-callable-apex/assets/pattern_migration.cls +54 -0
- package/skills/building-omnistudio-callable-apex/assets/pattern_openinterface.cls +45 -0
- package/skills/building-omnistudio-callable-apex/assets/pattern_test_class.cls +65 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/IndustriesCallableException.cls +7 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallable.cls +115 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallableTest.cls +189 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/TRANSCRIPT.md +115 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/IndustriesCallableException.cls +7 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallable.cls +74 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallableTest.cls +146 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomRemoteClass.cls +16 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/TRANSCRIPT.md +120 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/IndustriesCallableException.cls +7 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallable.cls +73 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallableTest.cls +128 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomVlocityOpenInterface2.cls +23 -0
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/TRANSCRIPT.md +75 -0
- package/skills/building-omnistudio-datamapper/CREDITS.md +5 -0
- package/skills/building-omnistudio-datamapper/SKILL.md +270 -0
- package/skills/building-omnistudio-datamapper/assets/completion-summary-template.md +28 -0
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-extract.json +6 -0
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-item.json +12 -0
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-load.json +6 -0
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-transform.json +6 -0
- package/skills/building-omnistudio-datamapper/references/best-practices.md +277 -0
- package/skills/building-omnistudio-datamapper/references/naming-conventions.md +145 -0
- package/skills/building-omnistudio-flexcard/CREDITS.md +5 -0
- package/skills/building-omnistudio-flexcard/SKILL.md +325 -0
- package/skills/building-omnistudio-flexcard/assets/omni-ui-card.json +10 -0
- package/skills/building-omnistudio-flexcard/references/best-practices.md +291 -0
- package/skills/building-omnistudio-flexcard/references/data-binding-guide.md +311 -0
- package/skills/building-omnistudio-flexcard/references/scoring-rubric.md +66 -0
- package/skills/building-omnistudio-flexcard/scripts/flexcard-commands.sh +24 -0
- package/skills/building-omnistudio-integration-procedure/CREDITS.md +5 -0
- package/skills/building-omnistudio-integration-procedure/SKILL.md +275 -0
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-dr-extract.json +10 -0
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-set-values.json +10 -0
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-ip.json +12 -0
- package/skills/building-omnistudio-integration-procedure/assets/scoring-report-format.txt +14 -0
- package/skills/building-omnistudio-integration-procedure/references/best-practices.md +388 -0
- package/skills/building-omnistudio-integration-procedure/references/element-types.md +588 -0
- package/skills/building-omnistudio-integration-procedure/scripts/cli-commands.sh +18 -0
- package/skills/building-omnistudio-omniscript/CREDITS.md +5 -0
- package/skills/building-omnistudio-omniscript/SKILL.md +367 -0
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-step.json +10 -0
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-text-block.json +11 -0
- package/skills/building-omnistudio-omniscript/assets/omni-process-omniscript.json +12 -0
- package/skills/building-omnistudio-omniscript/references/best-practices.md +480 -0
- package/skills/building-omnistudio-omniscript/references/element-types.md +1172 -0
- package/skills/building-omnistudio-omniscript/scripts/check-duplicate-omniscript.sh +13 -0
- package/skills/building-omnistudio-omniscript/scripts/cli-reference.sh +21 -0
- package/skills/building-omnistudio-omniscript/scripts/deploy-omniscript.sh +29 -0
- package/skills/building-sf-integrations/CREDITS.md +5 -0
- package/skills/building-sf-integrations/README.md +95 -0
- package/skills/building-sf-integrations/SKILL.md +192 -0
- package/skills/building-sf-integrations/assets/callouts/callout-retry-handler.cls +167 -0
- package/skills/building-sf-integrations/assets/callouts/http-response-handler.cls +257 -0
- package/skills/building-sf-integrations/assets/callouts/rest-queueable-callout.cls +262 -0
- package/skills/building-sf-integrations/assets/callouts/rest-sync-callout.cls +211 -0
- package/skills/building-sf-integrations/assets/cdc/cdc-handler.cls +246 -0
- package/skills/building-sf-integrations/assets/cdc/cdc-subscriber-trigger.trigger +139 -0
- package/skills/building-sf-integrations/assets/endpoint-security/example.cspTrustedSite-meta.xml +58 -0
- package/skills/building-sf-integrations/assets/endpoint-security/example.remoteSite-meta.xml +39 -0
- package/skills/building-sf-integrations/assets/external-credentials/jwt-external-credential.externalCredential-meta.xml +90 -0
- package/skills/building-sf-integrations/assets/external-credentials/oauth-external-credential.externalCredential-meta.xml +87 -0
- package/skills/building-sf-integrations/assets/external-services/external-service-operations.md +221 -0
- package/skills/building-sf-integrations/assets/external-services/openapi-registration.externalServiceRegistration-meta.xml +193 -0
- package/skills/building-sf-integrations/assets/named-credentials/certificate-auth.namedCredential-meta.xml +62 -0
- package/skills/building-sf-integrations/assets/named-credentials/custom-auth.namedCredential-meta.xml +71 -0
- package/skills/building-sf-integrations/assets/named-credentials/oauth-client-credentials.namedCredential-meta.xml +51 -0
- package/skills/building-sf-integrations/assets/named-credentials/oauth-jwt-bearer.namedCredential-meta.xml +67 -0
- package/skills/building-sf-integrations/assets/platform-events/event-publisher.cls +191 -0
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-action.cls +295 -0
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-trigger.trigger +108 -0
- package/skills/building-sf-integrations/assets/platform-events/platform-event-definition.object-meta.xml +124 -0
- package/skills/building-sf-integrations/assets/soap/soap-callout-service.cls +186 -0
- package/skills/building-sf-integrations/assets/soap/wsdl2apex-guide.md +213 -0
- package/skills/building-sf-integrations/hooks/scripts/suggest_credential_setup.py +271 -0
- package/skills/building-sf-integrations/hooks/scripts/validate_integration.py +363 -0
- package/skills/building-sf-integrations/references/callout-patterns.md +719 -0
- package/skills/building-sf-integrations/references/cdc-guide.md +288 -0
- package/skills/building-sf-integrations/references/cli-reference.md +94 -0
- package/skills/building-sf-integrations/references/event-driven-architecture-guide.md +266 -0
- package/skills/building-sf-integrations/references/event-patterns.md +838 -0
- package/skills/building-sf-integrations/references/external-services-guide.md +303 -0
- package/skills/building-sf-integrations/references/messaging-api-v2.md +609 -0
- package/skills/building-sf-integrations/references/named-credentials-automation.md +201 -0
- package/skills/building-sf-integrations/references/named-credentials-guide.md +173 -0
- package/skills/building-sf-integrations/references/platform-events-guide.md +288 -0
- package/skills/building-sf-integrations/references/rest-callout-patterns.md +288 -0
- package/skills/building-sf-integrations/references/scoring-rubric.md +59 -0
- package/skills/building-sf-integrations/references/security-best-practices.md +248 -0
- package/skills/building-sf-integrations/scripts/README.md +100 -0
- package/skills/building-sf-integrations/scripts/configure-named-credential.sh +236 -0
- package/skills/building-sf-integrations/scripts/set-api-credential.sh +146 -0
- package/skills/building-sf-integrations/scripts/templates/setup-credentials-with-csp.sh +158 -0
- package/skills/configuring-connected-apps/CREDITS.md +3 -0
- package/skills/configuring-connected-apps/README.md +99 -0
- package/skills/configuring-connected-apps/SKILL.md +224 -0
- package/skills/configuring-connected-apps/assets/connected-app-basic.xml +29 -0
- package/skills/configuring-connected-apps/assets/connected-app-canvas.xml +62 -0
- package/skills/configuring-connected-apps/assets/connected-app-jwt.xml +49 -0
- package/skills/configuring-connected-apps/assets/connected-app-oauth.xml +65 -0
- package/skills/configuring-connected-apps/assets/eca-global-oauth.xml +36 -0
- package/skills/configuring-connected-apps/assets/eca-oauth-settings.xml +36 -0
- package/skills/configuring-connected-apps/assets/eca-policies.xml +36 -0
- package/skills/configuring-connected-apps/assets/external-client-app.xml +35 -0
- package/skills/configuring-connected-apps/references/example-usage.md +256 -0
- package/skills/configuring-connected-apps/references/migration-guide.md +328 -0
- package/skills/configuring-connected-apps/references/oauth-flows-reference.md +660 -0
- package/skills/configuring-connected-apps/references/security-checklist.md +209 -0
- package/skills/configuring-connected-apps/references/testing-validation-guide.md +275 -0
- package/skills/connecting-datacloud/CREDITS.md +5 -0
- package/skills/connecting-datacloud/README.md +59 -0
- package/skills/connecting-datacloud/SKILL.md +155 -0
- package/skills/connecting-datacloud/examples/connections/heroku-postgres.json +15 -0
- package/skills/connecting-datacloud/examples/connections/ingest-api-connection.json +5 -0
- package/skills/connecting-datacloud/examples/connections/ingest-api-schema.json +31 -0
- package/skills/connecting-datacloud/examples/connections/redshift.json +16 -0
- package/skills/connecting-datacloud/examples/connections/sharepoint-unstructured.json +20 -0
- package/skills/connecting-datacloud/examples/connections/snowflake-connection.json +42 -0
- package/skills/debugging-apex-logs/CREDITS.md +22 -0
- package/skills/debugging-apex-logs/README.md +74 -0
- package/skills/debugging-apex-logs/SKILL.md +172 -0
- package/skills/debugging-apex-logs/assets/benchmarking-template.cls +327 -0
- package/skills/debugging-apex-logs/assets/cpu-heap-optimization.cls +307 -0
- package/skills/debugging-apex-logs/assets/dml-in-loop-fix.cls +219 -0
- package/skills/debugging-apex-logs/assets/null-pointer-fix.cls +252 -0
- package/skills/debugging-apex-logs/assets/soql-in-loop-fix.cls +157 -0
- package/skills/debugging-apex-logs/references/analysis-playbook.md +53 -0
- package/skills/debugging-apex-logs/references/benchmarking-guide.md +287 -0
- package/skills/debugging-apex-logs/references/cli-commands.md +368 -0
- package/skills/debugging-apex-logs/references/common-issues.md +68 -0
- package/skills/debugging-apex-logs/references/debug-log-reference.md +328 -0
- package/skills/debugging-apex-logs/references/log-analysis-tools.md +248 -0
- package/skills/debugging-apex-logs/references/scoring-rubric.md +21 -0
- package/skills/deploying-metadata/CREDITS.md +25 -0
- package/skills/deploying-metadata/README.md +104 -0
- package/skills/deploying-metadata/SKILL.md +214 -0
- package/skills/deploying-metadata/assets/destructiveChanges.xml +143 -0
- package/skills/deploying-metadata/assets/package.xml +121 -0
- package/skills/deploying-metadata/references/agent-deployment-guide.md +628 -0
- package/skills/deploying-metadata/references/deploy.sh +73 -0
- package/skills/deploying-metadata/references/deployment-report-template.md +89 -0
- package/skills/deploying-metadata/references/deployment-workflows.md +395 -0
- package/skills/deploying-metadata/references/orchestration.md +183 -0
- package/skills/deploying-metadata/references/trigger-deployment-safety.md +376 -0
- package/skills/deploying-omnistudio-datapacks/CREDITS.md +5 -0
- package/skills/deploying-omnistudio-datapacks/README.md +88 -0
- package/skills/deploying-omnistudio-datapacks/SKILL.md +174 -0
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/TRANSCRIPT.md +124 -0
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/deploy-business-internet-plus-bundle.yaml +11 -0
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/TRANSCRIPT.md +142 -0
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/deploy-business-internet-plus-bundle.yaml +10 -0
- package/skills/deploying-omnistudio-datapacks/references/job-file-template.md +42 -0
- package/skills/deploying-omnistudio-datapacks/references/troubleshooting-matrix.md +24 -0
- package/skills/developing-agentforce/assets/metadata/http-callout-flow.flow-meta.xml +1 -1
- package/skills/developing-agentforce/references/actions-reference.md +8 -8
- package/skills/fetching-salesforce-docs/README.md +66 -0
- package/skills/fetching-salesforce-docs/SKILL.md +209 -0
- package/skills/fetching-salesforce-docs/requirements.txt +2 -0
- package/skills/fetching-salesforce-docs/scripts/extract_help_salesforce.py +497 -0
- package/skills/fetching-salesforce-docs/scripts/extract_salesforce_doc.py +357 -0
- package/skills/fetching-salesforce-docs/scripts/runtime_bootstrap.py +58 -0
- package/skills/generating-apex/CREDITS.md +1 -26
- package/skills/generating-apex-test/CREDITS.md +2 -27
- package/skills/generating-lwc-components/CREDITS.md +5 -0
- package/skills/generating-lwc-components/README.md +126 -0
- package/skills/generating-lwc-components/SKILL.md +191 -0
- package/skills/generating-lwc-components/assets/apex-controller/LwcController.cls +327 -0
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.css +72 -0
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.html +111 -0
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js +163 -0
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js-meta.xml +137 -0
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.html +111 -0
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.js +367 -0
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.css +63 -0
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.html +154 -0
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js +348 -0
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js-meta.xml +87 -0
- package/skills/generating-lwc-components/assets/form-component/formComponent.html +165 -0
- package/skills/generating-lwc-components/assets/form-component/formComponent.js +275 -0
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.html +100 -0
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.js +336 -0
- package/skills/generating-lwc-components/assets/jest-test/componentName.test.js.example +371 -0
- package/skills/generating-lwc-components/assets/message-channel/RecordSelected.messageChannel-meta.xml +71 -0
- package/skills/generating-lwc-components/assets/message-channel/lmsPublisher.js +103 -0
- package/skills/generating-lwc-components/assets/message-channel/lmsSubscriber.js +181 -0
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.html +85 -0
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.js +199 -0
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.html +55 -0
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.js +199 -0
- package/skills/generating-lwc-components/assets/state-store/store.js +282 -0
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.css +65 -0
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.html +95 -0
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.js-meta.xml +75 -0
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.test.ts.example +301 -0
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.ts +295 -0
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.html +71 -0
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.js +316 -0
- package/skills/generating-lwc-components/hooks/scripts/lwc-lsp-validate.py +295 -0
- package/skills/generating-lwc-components/hooks/scripts/post-tool-validate.py +347 -0
- package/skills/generating-lwc-components/hooks/scripts/slds_data/deprecated_patterns.json +74 -0
- package/skills/generating-lwc-components/hooks/scripts/slds_data/styling_hooks.json +111 -0
- package/skills/generating-lwc-components/hooks/scripts/slds_data/valid_slds_classes.json +127 -0
- package/skills/generating-lwc-components/hooks/scripts/slds_linter_wrapper.py +294 -0
- package/skills/generating-lwc-components/hooks/scripts/slds_rules/__init__.py +22 -0
- package/skills/generating-lwc-components/hooks/scripts/template_validator.py +332 -0
- package/skills/generating-lwc-components/hooks/scripts/validate_slds.py +595 -0
- package/skills/generating-lwc-components/references/accessibility-guide.md +843 -0
- package/skills/generating-lwc-components/references/advanced-features.md +108 -0
- package/skills/generating-lwc-components/references/async-notification-patterns.md +661 -0
- package/skills/generating-lwc-components/references/cli-commands.md +545 -0
- package/skills/generating-lwc-components/references/component-patterns.md +1476 -0
- package/skills/generating-lwc-components/references/flow-integration-guide.md +675 -0
- package/skills/generating-lwc-components/references/jest-testing.md +1011 -0
- package/skills/generating-lwc-components/references/lms-guide.md +860 -0
- package/skills/generating-lwc-components/references/lwc-best-practices.md +1310 -0
- package/skills/generating-lwc-components/references/performance-guide.md +861 -0
- package/skills/generating-lwc-components/references/scoring-and-testing.md +116 -0
- package/skills/generating-lwc-components/references/slds-blueprints.json +14389 -0
- package/skills/generating-lwc-components/references/slds-design-guide.md +166 -0
- package/skills/generating-lwc-components/references/state-management.md +642 -0
- package/skills/generating-lwc-components/references/template-anti-patterns.md +948 -0
- package/skills/generating-lwc-components/references/triangle-pattern.md +365 -0
- package/skills/generating-lwc-components/scripts/local-dev-preview.sh +34 -0
- package/skills/generating-mermaid-diagrams/CREDITS.md +46 -0
- package/skills/generating-mermaid-diagrams/README.md +114 -0
- package/skills/generating-mermaid-diagrams/SKILL.md +218 -0
- package/skills/generating-mermaid-diagrams/assets/agentforce/agent-flow.md +313 -0
- package/skills/generating-mermaid-diagrams/assets/architecture/system-landscape.md +351 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/b2b-commerce-erd.md +317 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/campaigns-erd.md +195 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/consent-erd.md +262 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/files-erd.md +266 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/forecasting-erd.md +261 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/fsl-erd.md +332 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/party-model-erd.md +237 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/quote-order-erd.md +277 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/revenue-cloud-erd.md +343 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/sales-cloud-erd.md +192 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/salesforce-erd.md +209 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/scheduler-erd.md +276 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/service-cloud-erd.md +217 -0
- package/skills/generating-mermaid-diagrams/assets/datamodel/territory-management-erd.md +241 -0
- package/skills/generating-mermaid-diagrams/assets/integration/api-sequence.md +387 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code-pkce.md +197 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code.md +152 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/client-credentials.md +233 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/device-authorization.md +295 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/jwt-bearer.md +256 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/refresh-token.md +281 -0
- package/skills/generating-mermaid-diagrams/assets/oauth/user-agent-social-sign-on.md +281 -0
- package/skills/generating-mermaid-diagrams/assets/role-hierarchy/user-hierarchy.md +322 -0
- package/skills/generating-mermaid-diagrams/references/color-palette.md +464 -0
- package/skills/generating-mermaid-diagrams/references/diagram-conventions.md +313 -0
- package/skills/generating-mermaid-diagrams/references/erd-conventions.md +320 -0
- package/skills/generating-mermaid-diagrams/references/mermaid-reference.md +434 -0
- package/skills/generating-mermaid-diagrams/references/mermaid-styling.md +81 -0
- package/skills/generating-mermaid-diagrams/references/preview-guide.md +49 -0
- package/skills/generating-mermaid-diagrams/references/usage-examples.md +340 -0
- package/skills/generating-mermaid-diagrams/scripts/README.md +160 -0
- package/skills/generating-mermaid-diagrams/scripts/mermaid_preview.py +654 -0
- package/skills/generating-mermaid-diagrams/scripts/query-org-metadata.py +293 -0
- package/skills/generating-visual-diagrams/CREDITS.md +80 -0
- package/skills/generating-visual-diagrams/README.md +83 -0
- package/skills/generating-visual-diagrams/SKILL.md +208 -0
- package/skills/generating-visual-diagrams/assets/architecture/integration-flow.md +55 -0
- package/skills/generating-visual-diagrams/assets/erd/core-objects.md +131 -0
- package/skills/generating-visual-diagrams/assets/erd/custom-objects.md +60 -0
- package/skills/generating-visual-diagrams/assets/lwc/dashboard-card.md +45 -0
- package/skills/generating-visual-diagrams/assets/lwc/data-table.md +57 -0
- package/skills/generating-visual-diagrams/assets/lwc/record-form.md +60 -0
- package/skills/generating-visual-diagrams/assets/review/apex-review.md +57 -0
- package/skills/generating-visual-diagrams/assets/review/lwc-review.md +48 -0
- package/skills/generating-visual-diagrams/references/architect-aesthetic-guide.md +257 -0
- package/skills/generating-visual-diagrams/references/examples-index.md +35 -0
- package/skills/generating-visual-diagrams/references/gemini-cli-setup.md +65 -0
- package/skills/generating-visual-diagrams/references/interview-questions.md +529 -0
- package/skills/generating-visual-diagrams/references/iteration-workflow.md +173 -0
- package/skills/generating-visual-diagrams/scripts/check-prerequisites.sh +101 -0
- package/skills/generating-visual-diagrams/scripts/generate_image.py +243 -0
- package/skills/handling-sf-data/CREDITS.md +5 -0
- package/skills/handling-sf-data/README.md +112 -0
- package/skills/handling-sf-data/SKILL.md +235 -0
- package/skills/handling-sf-data/assets/bulk/bulk-insert-10000.apex +293 -0
- package/skills/handling-sf-data/assets/bulk/bulk-insert-200.apex +208 -0
- package/skills/handling-sf-data/assets/bulk/bulk-insert-500.apex +219 -0
- package/skills/handling-sf-data/assets/bulk/bulk-upsert-external-id.apex +324 -0
- package/skills/handling-sf-data/assets/cleanup/delete-by-created-date.apex +319 -0
- package/skills/handling-sf-data/assets/cleanup/delete-by-name.apex +240 -0
- package/skills/handling-sf-data/assets/cleanup/delete-test-data.apex +311 -0
- package/skills/handling-sf-data/assets/cleanup/rollback-transaction.apex +266 -0
- package/skills/handling-sf-data/assets/csv/account-import.csv +11 -0
- package/skills/handling-sf-data/assets/csv/contact-import.csv +11 -0
- package/skills/handling-sf-data/assets/csv/custom-object-import.csv +11 -0
- package/skills/handling-sf-data/assets/csv/opportunity-import.csv +11 -0
- package/skills/handling-sf-data/assets/factories/account-factory.apex +165 -0
- package/skills/handling-sf-data/assets/factories/case-factory.apex +237 -0
- package/skills/handling-sf-data/assets/factories/contact-factory.apex +168 -0
- package/skills/handling-sf-data/assets/factories/custom-object-factory.apex +260 -0
- package/skills/handling-sf-data/assets/factories/event-factory.apex +275 -0
- package/skills/handling-sf-data/assets/factories/hierarchy-factory.apex +372 -0
- package/skills/handling-sf-data/assets/factories/lead-factory.apex +190 -0
- package/skills/handling-sf-data/assets/factories/opportunity-factory.apex +206 -0
- package/skills/handling-sf-data/assets/factories/task-factory.apex +246 -0
- package/skills/handling-sf-data/assets/factories/user-factory.apex +278 -0
- package/skills/handling-sf-data/assets/json/account-contact-tree.json +130 -0
- package/skills/handling-sf-data/assets/json/account-opportunity-tree.json +110 -0
- package/skills/handling-sf-data/assets/json/full-hierarchy-tree.json +188 -0
- package/skills/handling-sf-data/assets/soql/aggregate.soql +226 -0
- package/skills/handling-sf-data/assets/soql/child-to-parent.soql +162 -0
- package/skills/handling-sf-data/assets/soql/parent-to-child.soql +153 -0
- package/skills/handling-sf-data/assets/soql/polymorphic.soql +198 -0
- package/skills/handling-sf-data/assets/soql/subquery.soql +287 -0
- package/skills/handling-sf-data/references/anonymous-apex-guide.md +98 -0
- package/skills/handling-sf-data/references/bulk-operations-guide.md +94 -0
- package/skills/handling-sf-data/references/bulk-testing-example.md +194 -0
- package/skills/handling-sf-data/references/cleanup-rollback-example.md +322 -0
- package/skills/handling-sf-data/references/cleanup-rollback-guide.md +84 -0
- package/skills/handling-sf-data/references/crud-workflow-example.md +183 -0
- package/skills/handling-sf-data/references/governor-limits-reference.md +74 -0
- package/skills/handling-sf-data/references/orchestration.md +174 -0
- package/skills/handling-sf-data/references/relationship-query-examples.md +249 -0
- package/skills/handling-sf-data/references/sf-cli-data-commands.md +158 -0
- package/skills/handling-sf-data/references/soql-relationship-guide.md +84 -0
- package/skills/handling-sf-data/references/test-data-best-practices.md +104 -0
- package/skills/handling-sf-data/references/test-data-factory-usage.md +290 -0
- package/skills/handling-sf-data/references/test-data-patterns.md +98 -0
- package/skills/handling-sf-data/scripts/soql_validator.py +292 -0
- package/skills/handling-sf-data/scripts/validate_data_operation.py +379 -0
- package/skills/harmonizing-datacloud/CREDITS.md +3 -0
- package/skills/harmonizing-datacloud/README.md +31 -0
- package/skills/harmonizing-datacloud/SKILL.md +117 -0
- package/skills/modeling-omnistudio-epc-catalog/CREDITS.md +14 -0
- package/skills/modeling-omnistudio-epc-catalog/README.md +89 -0
- package/skills/modeling-omnistudio-epc-catalog/SKILL.md +395 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/attribute-assignment-template.json +402 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/compiled-attribute-overrides-template.json +43 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/completion-block-template.txt +8 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/decomposition-relationships-template.json +233 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_AttributeAssignments.json +514 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_CompiledAttributeOverrides.json +21 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DataPack.json +649 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DecompositionRelationships.json +200 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ObjectFieldAttributes.json +138 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OrchestrationScenarios.json +54 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OverrideDefinitions.json +266 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ParentKeys.json +23 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PriceListEntries.json +54 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PricebookEntries.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ProductChildItems.json +34 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_RuleAssignments.json +21 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_AttributeAssignments.json +410 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DataPack.json +535 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DecompositionRelationships.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ObjectFieldAttributes.json +138 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_OrchestrationScenarios.json +28 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ParentKeys.json +23 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PriceListEntries.json +220 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PricebookEntries.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ProductChildItems.json +414 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_AttributeAssignments.json +382 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DataPack.json +565 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DecompositionRelationships.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ObjectFieldAttributes.json +104 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_OrchestrationScenarios.json +28 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ParentKeys.json +13 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PriceListEntries.json +106 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PricebookEntries.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ProductChildItems.json +72 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_AttributeAssignments.json +142 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DataPack.json +377 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DecompositionRelationships.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ObjectFieldAttributes.json +36 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ParentKeys.json +8 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PriceListEntries.json +54 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PricebookEntries.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ProductChildItems.json +34 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/object-field-attributes-template.json +138 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/orchestration-scenarios-template.json +54 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/override-definitions-template.json +134 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/parent-keys-template.json +29 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/price-list-entries-template.json +158 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/pricebook-entries-template.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/product-child-item-template.json +338 -0
- package/skills/modeling-omnistudio-epc-catalog/assets/product2-offer-template.json +527 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/.gitkeep +1 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_AttributeAssignments.json +95 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_CompiledAttributeOverrides.json +1 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DataPack.json +214 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DecompositionRelationships.json +28 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ObjectFieldAttributes.json +98 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OrchestrationScenarios.json +22 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OverrideDefinitions.json +1 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ParentKeys.json +13 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PriceListEntries.json +35 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PricebookEntries.json +28 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ProductChildItems.json +110 -0
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/TRANSCRIPT.md +58 -0
- package/skills/modeling-omnistudio-epc-catalog/references/epc-field-guide.md +90 -0
- package/skills/modeling-omnistudio-epc-catalog/references/naming-conventions.md +80 -0
- package/skills/modeling-omnistudio-epc-catalog/references/scoring-model.md +57 -0
- package/skills/modeling-omnistudio-epc-catalog/scripts/cli-validation-commands.sh +19 -0
- package/skills/modeling-omnistudio-epc-catalog/scripts/sample-invocations.sh +18 -0
- package/skills/orchestrating-datacloud/CREDITS.md +15 -0
- package/skills/orchestrating-datacloud/README.md +129 -0
- package/skills/orchestrating-datacloud/SKILL.md +236 -0
- package/skills/orchestrating-datacloud/UPSTREAM.md +45 -0
- package/skills/orchestrating-datacloud/assets/definitions/activation-target.template.json +5 -0
- package/skills/orchestrating-datacloud/assets/definitions/activation.template.json +7 -0
- package/skills/orchestrating-datacloud/assets/definitions/calculated-insight.template.json +7 -0
- package/skills/orchestrating-datacloud/assets/definitions/data-action-target.template.json +5 -0
- package/skills/orchestrating-datacloud/assets/definitions/data-action.template.json +5 -0
- package/skills/orchestrating-datacloud/assets/definitions/data-graph.template.json +21 -0
- package/skills/orchestrating-datacloud/assets/definitions/data-stream.template.json +55 -0
- package/skills/orchestrating-datacloud/assets/definitions/dmo.template.json +17 -0
- package/skills/orchestrating-datacloud/assets/definitions/identity-resolution.template.json +30 -0
- package/skills/orchestrating-datacloud/assets/definitions/mapping.template.json +14 -0
- package/skills/orchestrating-datacloud/assets/definitions/relationship.template.json +12 -0
- package/skills/orchestrating-datacloud/assets/definitions/search-index.template.json +9 -0
- package/skills/orchestrating-datacloud/assets/definitions/segment.template.json +16 -0
- package/skills/orchestrating-datacloud/references/feature-readiness.md +157 -0
- package/skills/orchestrating-datacloud/references/plugin-setup.md +140 -0
- package/skills/orchestrating-datacloud/scripts/bootstrap-plugin.sh +53 -0
- package/skills/orchestrating-datacloud/scripts/diagnose-org.mjs +511 -0
- package/skills/orchestrating-datacloud/scripts/generate-manifest.mjs +68 -0
- package/skills/orchestrating-datacloud/scripts/verify-plugin.sh +58 -0
- package/skills/preparing-datacloud/CREDITS.md +7 -0
- package/skills/preparing-datacloud/README.md +51 -0
- package/skills/preparing-datacloud/SKILL.md +191 -0
- package/skills/preparing-datacloud/examples/ingestion-api/.env.example +8 -0
- package/skills/preparing-datacloud/examples/ingestion-api/README.md +48 -0
- package/skills/preparing-datacloud/examples/ingestion-api/send-data.py +144 -0
- package/skills/querying-soql/CREDITS.md +21 -0
- package/skills/querying-soql/README.md +41 -0
- package/skills/querying-soql/SKILL.md +143 -0
- package/skills/querying-soql/assets/aggregate-queries.soql +242 -0
- package/skills/querying-soql/assets/basic-queries.soql +188 -0
- package/skills/querying-soql/assets/bulkified-query-pattern.cls +280 -0
- package/skills/querying-soql/assets/optimization-patterns.soql +259 -0
- package/skills/querying-soql/assets/relationship-queries.soql +203 -0
- package/skills/querying-soql/assets/selector-class.cls +219 -0
- package/skills/querying-soql/references/anti-patterns.md +348 -0
- package/skills/querying-soql/references/cli-commands.md +358 -0
- package/skills/querying-soql/references/field-coverage-rules.md +514 -0
- package/skills/querying-soql/references/query-optimization.md +142 -0
- package/skills/querying-soql/references/selector-patterns.md +479 -0
- package/skills/querying-soql/references/soql-reference.md +227 -0
- package/skills/querying-soql/references/soql-syntax-reference.md +208 -0
- package/skills/querying-soql/scripts/post-tool-validate.py +322 -0
- package/skills/retrieving-datacloud/CREDITS.md +7 -0
- package/skills/retrieving-datacloud/README.md +44 -0
- package/skills/retrieving-datacloud/SKILL.md +120 -0
- package/skills/retrieving-datacloud/examples/search-indexes/hybrid-structured.json +44 -0
- package/skills/retrieving-datacloud/examples/search-indexes/vector-knowledge.json +43 -0
- package/skills/running-apex-tests/CREDITS.md +22 -0
- package/skills/running-apex-tests/README.md +94 -0
- package/skills/running-apex-tests/SKILL.md +158 -0
- package/skills/running-apex-tests/assets/basic-test.cls +169 -0
- package/skills/running-apex-tests/assets/bulk-test.cls +255 -0
- package/skills/running-apex-tests/assets/dml-mock.cls +339 -0
- package/skills/running-apex-tests/assets/mock-callout-test.cls +353 -0
- package/skills/running-apex-tests/assets/stub-provider-example.cls +364 -0
- package/skills/running-apex-tests/assets/test-data-factory.cls +328 -0
- package/skills/running-apex-tests/hooks/scripts/parse-test-results.py +364 -0
- package/skills/running-apex-tests/references/cli-commands.md +289 -0
- package/skills/running-apex-tests/references/mocking-patterns.md +500 -0
- package/skills/running-apex-tests/references/performance-optimization.md +283 -0
- package/skills/running-apex-tests/references/test-fix-loop.md +49 -0
- package/skills/running-apex-tests/references/test-patterns.md +154 -0
- package/skills/running-apex-tests/references/testing-best-practices.md +509 -0
- package/skills/segmenting-datacloud/CREDITS.md +3 -0
- package/skills/segmenting-datacloud/README.md +36 -0
- package/skills/segmenting-datacloud/SKILL.md +115 -0
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: configuring-connected-apps
|
|
3
|
+
description: "Salesforce Connected Apps and External Client Apps OAuth configuration with 120-point scoring. Use this skill to configure OAuth flows, JWT bearer auth, Connected Apps, and External Client Apps in Salesforce. TRIGGER when: user configures OAuth flows, JWT bearer auth, Connected Apps, ECAs, or touches .connectedApp-meta.xml / .eca-meta.xml files. DO NOT TRIGGER when: configuring Named Credentials for callouts (use building-sf-integrations), reviewing permission policies (use deploying-metadata), or writing Apex token-handling code (use generating-apex)."
|
|
4
|
+
license: MIT
|
|
5
|
+
allowed-tools: Bash Read Write Edit Glob Grep WebFetch AskUserQuestion TodoWrite
|
|
6
|
+
metadata:
|
|
7
|
+
version: "1.1"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# configuring-connected-apps: Salesforce Connected Apps & External Client Apps
|
|
11
|
+
|
|
12
|
+
Use this skill when the user needs **OAuth app configuration** in Salesforce: Connected Apps, External Client Apps (ECAs), JWT bearer setup, PKCE decisions, scope design, or migration from older Connected App patterns to newer ECA patterns.
|
|
13
|
+
|
|
14
|
+
## Scope
|
|
15
|
+
|
|
16
|
+
**In scope:**
|
|
17
|
+
- `.connectedApp-meta.xml` or `.eca-meta.xml` files
|
|
18
|
+
- OAuth flow selection and callback / scope setup
|
|
19
|
+
- JWT bearer auth, device flow, client credentials, or auth-code decisions
|
|
20
|
+
- Connected App vs External Client App architecture choices
|
|
21
|
+
- Consumer key / secret / certificate handling strategy
|
|
22
|
+
|
|
23
|
+
**Out of scope — delegate elsewhere:**
|
|
24
|
+
- Configuring Named Credentials or runtime callouts → [building-sf-integrations](../building-sf-integrations/SKILL.md)
|
|
25
|
+
- Deploying metadata to orgs → [deploying-metadata](../deploying-metadata/SKILL.md)
|
|
26
|
+
- Writing Apex token-handling code → [generating-apex](../generating-apex/SKILL.md)
|
|
27
|
+
|
|
28
|
+
---
|
|
29
|
+
|
|
30
|
+
## First Decision: Connected App or External Client App
|
|
31
|
+
|
|
32
|
+
| If the need is... | Prefer |
|
|
33
|
+
|---|---|
|
|
34
|
+
| simple single-org OAuth app | Connected App |
|
|
35
|
+
| new development with better secret handling | External Client App |
|
|
36
|
+
| multi-org / packaging / stronger operational controls | External Client App |
|
|
37
|
+
| straightforward legacy compatibility | Connected App |
|
|
38
|
+
|
|
39
|
+
Default guidance:
|
|
40
|
+
- Choose **ECA** for new regulated, packageable, or automation-heavy solutions.
|
|
41
|
+
- Choose **Connected App** when simplicity and legacy compatibility matter more.
|
|
42
|
+
- Spring '26 note: creation of new Connected Apps is disabled by default in orgs. For new integrations, prefer External Client Apps unless Connected App compatibility is explicitly required.
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
## Required Inputs
|
|
47
|
+
|
|
48
|
+
Ask for or infer:
|
|
49
|
+
- App type: Connected App or ECA
|
|
50
|
+
- OAuth flow: auth code, PKCE, JWT bearer, device, client credentials
|
|
51
|
+
- Client type: confidential vs public
|
|
52
|
+
- Callback URLs / redirect surfaces
|
|
53
|
+
- Required scopes
|
|
54
|
+
- Distribution model: local org only vs packageable / multi-org
|
|
55
|
+
- Whether certificates or secret rotation are required
|
|
56
|
+
|
|
57
|
+
---
|
|
58
|
+
|
|
59
|
+
## Workflow
|
|
60
|
+
|
|
61
|
+
### 1. Choose the app model
|
|
62
|
+
Decide whether a Connected App or ECA is the better long-term fit using the decision table above.
|
|
63
|
+
|
|
64
|
+
### 2. Choose the OAuth flow
|
|
65
|
+
|
|
66
|
+
| Use case | Default flow |
|
|
67
|
+
|---|---|
|
|
68
|
+
| backend web app | Authorization Code |
|
|
69
|
+
| SPA / mobile / public client | Authorization Code + PKCE |
|
|
70
|
+
| server-to-server / CI/CD | JWT Bearer |
|
|
71
|
+
| device / CLI auth | Device Flow |
|
|
72
|
+
| service account style app | Client Credentials (typically ECA) |
|
|
73
|
+
|
|
74
|
+
### 3. Start from the right template
|
|
75
|
+
Read the appropriate template before generating — do not build from scratch:
|
|
76
|
+
|
|
77
|
+
| Template | Use case |
|
|
78
|
+
|---|---|
|
|
79
|
+
| `assets/connected-app-basic.xml` | Simple API integration, minimal OAuth |
|
|
80
|
+
| `assets/connected-app-oauth.xml` | Web app with full OAuth 2.0 configuration |
|
|
81
|
+
| `assets/connected-app-jwt.xml` | JWT bearer / server-to-server |
|
|
82
|
+
| `assets/connected-app-canvas.xml` | Embedding external apps in Salesforce UI (Canvas) |
|
|
83
|
+
| `assets/external-client-app.xml` | ECA header file — all new ECA builds start here |
|
|
84
|
+
| `assets/eca-global-oauth.xml` | ECA global OAuth settings (scopes, PKCE, rotation) |
|
|
85
|
+
| `assets/eca-oauth-settings.xml` | ECA per-app OAuth settings |
|
|
86
|
+
| `assets/eca-policies.xml` | ECA configurable policies |
|
|
87
|
+
|
|
88
|
+
If you need source-controlled ECA OAuth security metadata, retrieve it from an org first and treat the retrieved file as the schema source of truth:
|
|
89
|
+
```
|
|
90
|
+
sf project retrieve start --metadata ExtlClntAppOauthSecuritySettings:<AppName> --target-org <alias>
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
### 4. Apply security hardening
|
|
94
|
+
Read `references/security-checklist.md` for the full 120-point security checklist. Favor:
|
|
95
|
+
- Least-privilege scopes
|
|
96
|
+
- Explicit callback URLs
|
|
97
|
+
- PKCE for public clients
|
|
98
|
+
- Certificate-based auth where appropriate
|
|
99
|
+
- Rotation-ready secret / key handling
|
|
100
|
+
- IP restrictions when realistic and maintainable
|
|
101
|
+
|
|
102
|
+
### 5. Validate deployment readiness
|
|
103
|
+
Read `references/testing-validation-guide.md` before handoff. Confirm:
|
|
104
|
+
- Metadata file naming is correct (see Gotchas below)
|
|
105
|
+
- Scopes are justified
|
|
106
|
+
- Callback and auth model match the real client type
|
|
107
|
+
- Secrets are not embedded in source
|
|
108
|
+
|
|
109
|
+
### 6. Handle errors
|
|
110
|
+
If deployment fails, check the error output for:
|
|
111
|
+
- `DUPLICATE_VALUE` — a Connected App or ECA with this name already exists; rename or retrieve-then-update instead
|
|
112
|
+
- `INVALID_CROSS_REFERENCE_KEY` — the `externalClientApplication` name in an ECA settings file doesn't match the `.eca-meta.xml` filename exactly
|
|
113
|
+
- `INSUFFICIENT_ACCESS_OR_READONLY` — user lacks the "Manage Connected Apps" permission
|
|
114
|
+
- If any step fails, do not proceed to the next step — surface the error to the user with the specific message above
|
|
115
|
+
|
|
116
|
+
---
|
|
117
|
+
|
|
118
|
+
## Rules / Constraints
|
|
119
|
+
|
|
120
|
+
| Rule | Rationale |
|
|
121
|
+
|---|---|
|
|
122
|
+
| Never commit consumer secrets to source control | Credential exposure risk |
|
|
123
|
+
| Never use `Full` scope by default | Unnecessary privilege; request only what the app needs |
|
|
124
|
+
| Always use PKCE for public clients (mobile, SPA) | Prevents auth code interception |
|
|
125
|
+
| Never use wildcard or overly broad callback URLs | Token interception risk |
|
|
126
|
+
| ECA OAuth security settings must be retrieved from org before editing | File schema is not fully documented; retrieve-first ensures accuracy |
|
|
127
|
+
| Use `<alias>` placeholders in CLI commands, never hardcoded org URLs | Org URLs vary per environment |
|
|
128
|
+
| Detect actual `packageDirectory` from `sfdx-project.json` before writing files | Projects may not use the default `force-app/main/default/` layout |
|
|
129
|
+
|
|
130
|
+
---
|
|
131
|
+
|
|
132
|
+
## Metadata Notes That Matter
|
|
133
|
+
|
|
134
|
+
### Connected App
|
|
135
|
+
Default source location (verify via `sfdx-project.json → packageDirectories`):
|
|
136
|
+
- `<packageDir>/connectedApps/`
|
|
137
|
+
|
|
138
|
+
### External Client App
|
|
139
|
+
ECA metadata spans multiple top-level source directories. Default locations (verify via `sfdx-project.json`):
|
|
140
|
+
|
|
141
|
+
| Directory | Metadata type | File suffix |
|
|
142
|
+
|---|---|---|
|
|
143
|
+
| `<packageDir>/externalClientApps/` | `ExternalClientApplication` | `.eca-meta.xml` |
|
|
144
|
+
| `<packageDir>/extlClntAppGlobalOauthSets/` | `ExtlClntAppGlobalOauthSettings` | `.ecaGlblOauth-meta.xml` |
|
|
145
|
+
| `<packageDir>/extlClntAppOauthSettings/` | `ExtlClntAppOauthSettings` | `.ecaOauth-meta.xml` |
|
|
146
|
+
| `<packageDir>/extlClntAppOauthSecuritySettings/` | `ExtlClntAppOauthSecuritySettings` | `.ecaOauthSecurity-meta.xml` |
|
|
147
|
+
| `<packageDir>/extlClntAppOauthPolicies/` | `ExtlClntAppOauthConfigurablePolicies` | `.ecaOauthPlcy-meta.xml` |
|
|
148
|
+
| `<packageDir>/extlClntAppPolicies/` | `ExtlClntAppConfigurablePolicies` | `.ecaPlcy-meta.xml` |
|
|
149
|
+
|
|
150
|
+
---
|
|
151
|
+
|
|
152
|
+
## Gotchas
|
|
153
|
+
|
|
154
|
+
| Gotcha | Detail |
|
|
155
|
+
|---|---|
|
|
156
|
+
| `.ecaGlblOauth` not `.ecaGlobalOauth` | The global OAuth suffix is abbreviated — using the long form will break deployment |
|
|
157
|
+
| `.ecaPlcy` not `.ecaPolicy` | Same abbreviation pattern — the general policy suffix is short form |
|
|
158
|
+
| `.ecaOauthSecurity` for security settings | Use `.ecaOauthSecurity`, not `.ecaSecurity` |
|
|
159
|
+
| ECA OAuth security settings are retrieve-only | Cannot be created from scratch in source — always retrieve from org first |
|
|
160
|
+
| Spring '26: new Connected Apps disabled by default | New orgs block Connected App creation; use ECA unless explicitly required |
|
|
161
|
+
| Consumer key is generated post-deploy | You cannot set the consumer key in metadata — retrieve it after first deployment |
|
|
162
|
+
|
|
163
|
+
---
|
|
164
|
+
|
|
165
|
+
## Output Expectations
|
|
166
|
+
|
|
167
|
+
When finishing, confirm and report in this order:
|
|
168
|
+
|
|
169
|
+
1. **App type chosen** — Connected App or External Client App
|
|
170
|
+
2. **OAuth flow chosen**
|
|
171
|
+
3. **Files created or updated** — list each metadata file path
|
|
172
|
+
4. **Security decisions** — scopes, PKCE, certs, secrets, IP policy
|
|
173
|
+
5. **Next deployment / testing step**
|
|
174
|
+
|
|
175
|
+
Suggested output shape:
|
|
176
|
+
```
|
|
177
|
+
App: <name>
|
|
178
|
+
Type: Connected App | External Client App
|
|
179
|
+
Flow: <oauth flow>
|
|
180
|
+
Files: <paths>
|
|
181
|
+
Security: <scopes, PKCE, certs, secrets, IP policy>
|
|
182
|
+
Next step: <deploy, retrieve consumer key, or test auth flow>
|
|
183
|
+
Score: <x>/120
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
---
|
|
187
|
+
|
|
188
|
+
## Cross-Skill Integration
|
|
189
|
+
|
|
190
|
+
| Need | Delegate to | Reason |
|
|
191
|
+
|---|---|---|
|
|
192
|
+
| Named Credential / callout runtime config | [building-sf-integrations](../building-sf-integrations/SKILL.md) | runtime integration setup |
|
|
193
|
+
| Deploy app metadata | [deploying-metadata](../deploying-metadata/SKILL.md) | org validation and deployment |
|
|
194
|
+
| Apex token or refresh handling | [generating-apex](../generating-apex/SKILL.md) | implementation logic |
|
|
195
|
+
|
|
196
|
+
---
|
|
197
|
+
|
|
198
|
+
## Score Guide
|
|
199
|
+
|
|
200
|
+
| Score | Meaning |
|
|
201
|
+
|---|---|
|
|
202
|
+
| 80+ | production-ready OAuth app config |
|
|
203
|
+
| 54–79 | workable but needs hardening review |
|
|
204
|
+
| < 54 | block deployment until fixed |
|
|
205
|
+
|
|
206
|
+
---
|
|
207
|
+
|
|
208
|
+
## Reference File Index
|
|
209
|
+
|
|
210
|
+
| File | When to read |
|
|
211
|
+
|---|---|
|
|
212
|
+
| `assets/connected-app-basic.xml` | Step 3 — template for simple Connected App with minimal OAuth |
|
|
213
|
+
| `assets/connected-app-oauth.xml` | Step 3 — template for full OAuth 2.0 Connected App |
|
|
214
|
+
| `assets/connected-app-jwt.xml` | Step 3 — template for JWT bearer / server-to-server Connected App |
|
|
215
|
+
| `assets/connected-app-canvas.xml` | Step 3 — template for Canvas app embedding in Salesforce UI |
|
|
216
|
+
| `assets/external-client-app.xml` | Step 3 — ECA header file template |
|
|
217
|
+
| `assets/eca-global-oauth.xml` | Step 3 — ECA global OAuth settings template (PKCE, rotation, callbacks) |
|
|
218
|
+
| `assets/eca-oauth-settings.xml` | Step 3 — ECA per-app OAuth settings template |
|
|
219
|
+
| `assets/eca-policies.xml` | Step 3 — ECA configurable policies template |
|
|
220
|
+
| `references/oauth-flows-reference.md` | Step 2 — detailed OAuth flow comparison and decision guide |
|
|
221
|
+
| `references/security-checklist.md` | Step 4 — full 120-point security scoring checklist |
|
|
222
|
+
| `references/testing-validation-guide.md` | Step 5 — pre-deployment validation and testing guide |
|
|
223
|
+
| `references/migration-guide.md` | When migrating from Connected App to ECA patterns |
|
|
224
|
+
| `references/example-usage.md` | Full end-to-end examples for common OAuth scenarios |
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: Connected App - Basic
|
|
4
|
+
Use Case: Simple API integration with minimal OAuth configuration
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: Application name (no spaces, alphanumeric + underscore)
|
|
8
|
+
- {{CONTACT_EMAIL}}: Administrator contact email
|
|
9
|
+
- {{DESCRIPTION}}: Brief description of the app's purpose
|
|
10
|
+
- {{CALLBACK_URL}}: OAuth callback URL (must be HTTPS in production)
|
|
11
|
+
-->
|
|
12
|
+
<ConnectedApp xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
13
|
+
<label>{{APP_NAME}}</label>
|
|
14
|
+
<contactEmail>{{CONTACT_EMAIL}}</contactEmail>
|
|
15
|
+
<description>{{DESCRIPTION}}</description>
|
|
16
|
+
|
|
17
|
+
<oauthConfig>
|
|
18
|
+
<callbackUrl>{{CALLBACK_URL}}</callbackUrl>
|
|
19
|
+
<isAdminApproved>false</isAdminApproved>
|
|
20
|
+
<isConsumerSecretOptional>false</isConsumerSecretOptional>
|
|
21
|
+
<scopes>Api</scopes>
|
|
22
|
+
<scopes>RefreshToken</scopes>
|
|
23
|
+
</oauthConfig>
|
|
24
|
+
|
|
25
|
+
<oauthPolicy>
|
|
26
|
+
<ipRelaxation>ENFORCE</ipRelaxation>
|
|
27
|
+
<refreshTokenPolicy>infinite</refreshTokenPolicy>
|
|
28
|
+
</oauthPolicy>
|
|
29
|
+
</ConnectedApp>
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: Connected App - Canvas App
|
|
4
|
+
Use Case: Embedding external applications within Salesforce UI
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: Application name (no spaces, alphanumeric + underscore)
|
|
8
|
+
- {{CONTACT_EMAIL}}: Administrator contact email
|
|
9
|
+
- {{DESCRIPTION}}: Brief description of the app's purpose
|
|
10
|
+
- {{CANVAS_URL}}: URL of your canvas application
|
|
11
|
+
- {{CALLBACK_URL}}: OAuth callback URL (must be HTTPS)
|
|
12
|
+
|
|
13
|
+
Canvas Access Methods:
|
|
14
|
+
- Chatter Feed: Embed in Chatter
|
|
15
|
+
- Chatter Tab: Add to Chatter tab
|
|
16
|
+
- Publisher: Add to publisher actions
|
|
17
|
+
- Visualforce Page: Embed via Visualforce
|
|
18
|
+
- Mobile Card: Show on mobile record pages
|
|
19
|
+
- OpenCTI: Use in Service Cloud CTI
|
|
20
|
+
- LayoutSection: Embed in page layouts
|
|
21
|
+
-->
|
|
22
|
+
<ConnectedApp xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
23
|
+
<label>{{APP_NAME}}</label>
|
|
24
|
+
<contactEmail>{{CONTACT_EMAIL}}</contactEmail>
|
|
25
|
+
<description>{{DESCRIPTION}}</description>
|
|
26
|
+
|
|
27
|
+
<oauthConfig>
|
|
28
|
+
<callbackUrl>{{CALLBACK_URL}}</callbackUrl>
|
|
29
|
+
<isAdminApproved>true</isAdminApproved>
|
|
30
|
+
<isConsumerSecretOptional>false</isConsumerSecretOptional>
|
|
31
|
+
<scopes>Api</scopes>
|
|
32
|
+
<scopes>RefreshToken</scopes>
|
|
33
|
+
</oauthConfig>
|
|
34
|
+
|
|
35
|
+
<oauthPolicy>
|
|
36
|
+
<ipRelaxation>ENFORCE</ipRelaxation>
|
|
37
|
+
<refreshTokenPolicy>infinite</refreshTokenPolicy>
|
|
38
|
+
</oauthPolicy>
|
|
39
|
+
|
|
40
|
+
<!-- Canvas Configuration -->
|
|
41
|
+
<canvasConfig>
|
|
42
|
+
<canvasUrl>{{CANVAS_URL}}</canvasUrl>
|
|
43
|
+
<accessMethod>Get</accessMethod>
|
|
44
|
+
|
|
45
|
+
<!-- Canvas Locations - uncomment as needed -->
|
|
46
|
+
<locations>Chatter</locations>
|
|
47
|
+
<locations>Visualforce</locations>
|
|
48
|
+
<!-- <locations>ChatterFeed</locations> -->
|
|
49
|
+
<!-- <locations>Publisher</locations> -->
|
|
50
|
+
<!-- <locations>MobileNav</locations> -->
|
|
51
|
+
<!-- <locations>OpenCTI</locations> -->
|
|
52
|
+
<!-- <locations>LayoutSection</locations> -->
|
|
53
|
+
|
|
54
|
+
<!-- Canvas Options -->
|
|
55
|
+
<lifecycleClass></lifecycleClass>
|
|
56
|
+
<options>HideHeader</options>
|
|
57
|
+
<options>HideShare</options>
|
|
58
|
+
|
|
59
|
+
<!-- SAML Initiation Method -->
|
|
60
|
+
<samlInitiationMethod>None</samlInitiationMethod>
|
|
61
|
+
</canvasConfig>
|
|
62
|
+
</ConnectedApp>
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: Connected App - JWT Bearer Flow
|
|
4
|
+
Use Case: Server-to-server integration, CI/CD pipelines, headless automation
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: Application name (no spaces, alphanumeric + underscore)
|
|
8
|
+
- {{CONTACT_EMAIL}}: Administrator contact email
|
|
9
|
+
- {{DESCRIPTION}}: Brief description of the app's purpose
|
|
10
|
+
- {{CERTIFICATE_NAME}}: Name of the certificate uploaded to Salesforce
|
|
11
|
+
|
|
12
|
+
Prerequisites:
|
|
13
|
+
1. Create a self-signed certificate or use CA-signed certificate
|
|
14
|
+
2. Upload certificate to Salesforce (Setup > Certificate and Key Management)
|
|
15
|
+
3. Use the certificate name (not file name) in this template
|
|
16
|
+
|
|
17
|
+
Note: No callback URL needed for JWT Bearer flow
|
|
18
|
+
Note: Consumer Secret is optional when using certificate authentication
|
|
19
|
+
-->
|
|
20
|
+
<ConnectedApp xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
21
|
+
<label>{{APP_NAME}}</label>
|
|
22
|
+
<contactEmail>{{CONTACT_EMAIL}}</contactEmail>
|
|
23
|
+
<description>{{DESCRIPTION}} - JWT Bearer Authentication</description>
|
|
24
|
+
|
|
25
|
+
<oauthConfig>
|
|
26
|
+
<!-- JWT Bearer flow doesn't require callback URL, but Salesforce requires one -->
|
|
27
|
+
<callbackUrl>https://localhost/oauth/callback</callbackUrl>
|
|
28
|
+
|
|
29
|
+
<!-- Certificate for JWT signing -->
|
|
30
|
+
<certificate>{{CERTIFICATE_NAME}}</certificate>
|
|
31
|
+
|
|
32
|
+
<isAdminApproved>true</isAdminApproved>
|
|
33
|
+
<isConsumerSecretOptional>true</isConsumerSecretOptional>
|
|
34
|
+
|
|
35
|
+
<!-- API access scope - typically all that's needed for server-to-server -->
|
|
36
|
+
<scopes>Api</scopes>
|
|
37
|
+
<!-- RefreshToken not needed for JWT - each request gets new access token -->
|
|
38
|
+
</oauthConfig>
|
|
39
|
+
|
|
40
|
+
<oauthPolicy>
|
|
41
|
+
<ipRelaxation>ENFORCE</ipRelaxation>
|
|
42
|
+
<refreshTokenPolicy>zero</refreshTokenPolicy>
|
|
43
|
+
</oauthPolicy>
|
|
44
|
+
|
|
45
|
+
<!-- Require connected app to be assigned via permission sets or profiles -->
|
|
46
|
+
<permissionSetLicense>
|
|
47
|
+
<license>Salesforce</license>
|
|
48
|
+
</permissionSetLicense>
|
|
49
|
+
</ConnectedApp>
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: Connected App - Full OAuth
|
|
4
|
+
Use Case: Web application with complete OAuth 2.0 configuration
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: Application name (no spaces, alphanumeric + underscore)
|
|
8
|
+
- {{CONTACT_EMAIL}}: Administrator contact email
|
|
9
|
+
- {{DESCRIPTION}}: Brief description of the app's purpose
|
|
10
|
+
- {{CALLBACK_URL}}: OAuth callback URL (must be HTTPS)
|
|
11
|
+
- {{LOGOUT_URL}}: URL to redirect after logout (optional)
|
|
12
|
+
|
|
13
|
+
OAuth Scopes (uncomment as needed):
|
|
14
|
+
- Api: REST/SOAP API access
|
|
15
|
+
- RefreshToken: Offline access via refresh token
|
|
16
|
+
- Full: Complete access (use sparingly)
|
|
17
|
+
- OpenID: OpenID Connect
|
|
18
|
+
- Web: Web browser access
|
|
19
|
+
- ChatterApi: Chatter REST API
|
|
20
|
+
- CustomPermissions: Custom permission access
|
|
21
|
+
-->
|
|
22
|
+
<ConnectedApp xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
23
|
+
<label>{{APP_NAME}}</label>
|
|
24
|
+
<contactEmail>{{CONTACT_EMAIL}}</contactEmail>
|
|
25
|
+
<description>{{DESCRIPTION}}</description>
|
|
26
|
+
|
|
27
|
+
<oauthConfig>
|
|
28
|
+
<callbackUrl>{{CALLBACK_URL}}</callbackUrl>
|
|
29
|
+
<isAdminApproved>true</isAdminApproved>
|
|
30
|
+
<isConsumerSecretOptional>false</isConsumerSecretOptional>
|
|
31
|
+
<isIntrospectAllTokens>false</isIntrospectAllTokens>
|
|
32
|
+
|
|
33
|
+
<!-- Core API Access -->
|
|
34
|
+
<scopes>Api</scopes>
|
|
35
|
+
<scopes>RefreshToken</scopes>
|
|
36
|
+
|
|
37
|
+
<!-- OpenID Connect (for user identity) -->
|
|
38
|
+
<scopes>OpenID</scopes>
|
|
39
|
+
<scopes>Profile</scopes>
|
|
40
|
+
<scopes>Email</scopes>
|
|
41
|
+
|
|
42
|
+
<!-- Uncomment additional scopes as needed -->
|
|
43
|
+
<!-- <scopes>Web</scopes> -->
|
|
44
|
+
<!-- <scopes>ChatterApi</scopes> -->
|
|
45
|
+
<!-- <scopes>CustomPermissions</scopes> -->
|
|
46
|
+
<!-- <scopes>Wave</scopes> -->
|
|
47
|
+
</oauthConfig>
|
|
48
|
+
|
|
49
|
+
<oauthPolicy>
|
|
50
|
+
<ipRelaxation>ENFORCE</ipRelaxation>
|
|
51
|
+
<refreshTokenPolicy>infinite</refreshTokenPolicy>
|
|
52
|
+
<singleLogoutUrl>{{LOGOUT_URL}}</singleLogoutUrl>
|
|
53
|
+
</oauthPolicy>
|
|
54
|
+
|
|
55
|
+
<!--
|
|
56
|
+
NOTE: refreshTokenValidityPeriod requires specific element ordering per XSD.
|
|
57
|
+
For custom token lifetimes, configure via Setup UI after deployment.
|
|
58
|
+
Using refreshTokenPolicy=infinite is the safest metadata-deployable option.
|
|
59
|
+
-->
|
|
60
|
+
|
|
61
|
+
<!-- Session Policy -->
|
|
62
|
+
<sessionPolicy>
|
|
63
|
+
<sessionTimeout>120</sessionTimeout>
|
|
64
|
+
</sessionPolicy>
|
|
65
|
+
</ConnectedApp>
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: External Client App - Global OAuth Settings
|
|
4
|
+
Use Case: Configure OAuth settings that apply globally to the ECA
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: The ExternalClientApplication API name (must match .eca file)
|
|
8
|
+
- {{LABEL}}: Display label for this global OAuth settings configuration
|
|
9
|
+
- {{CALLBACK_URL}}: OAuth callback URL (must be HTTPS for web, custom scheme for mobile)
|
|
10
|
+
- {{PKCE_REQUIRED}}: true for public clients (mobile, SPA), false for confidential
|
|
11
|
+
- {{SECRET_OPTIONAL}}: true for public clients using PKCE only
|
|
12
|
+
- {{SECRET_FOR_REFRESH}}: true to require secret for refresh token requests
|
|
13
|
+
- {{ROTATE_KEY}}: true to enable consumer key rotation (recommended for production)
|
|
14
|
+
- {{ROTATE_SECRET}}: true to enable consumer secret rotation (recommended for production)
|
|
15
|
+
|
|
16
|
+
Security Recommendations:
|
|
17
|
+
- PKCE: REQUIRED for mobile and SPA applications (public clients)
|
|
18
|
+
- Key/Secret Rotation: Enable for production apps (can be automated via API)
|
|
19
|
+
- Consumer Secret Optional: Only true when using PKCE exclusively
|
|
20
|
+
- Introspect All Tokens: Enable if you need to validate tokens programmatically
|
|
21
|
+
|
|
22
|
+
File Naming: [AppName].ecaGlblOauth-meta.xml
|
|
23
|
+
|
|
24
|
+
NOTE: The file suffix is .ecaGlblOauth (abbreviated), NOT .ecaGlobalOauth
|
|
25
|
+
-->
|
|
26
|
+
<ExtlClntAppGlobalOauthSettings xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
27
|
+
<callbackUrl>{{CALLBACK_URL}}</callbackUrl>
|
|
28
|
+
<externalClientApplication>{{APP_NAME}}</externalClientApplication>
|
|
29
|
+
<isConsumerSecretOptional>{{SECRET_OPTIONAL}}</isConsumerSecretOptional>
|
|
30
|
+
<isIntrospectAllTokens>false</isIntrospectAllTokens>
|
|
31
|
+
<isPkceRequired>{{PKCE_REQUIRED}}</isPkceRequired>
|
|
32
|
+
<isSecretRequiredForRefreshToken>{{SECRET_FOR_REFRESH}}</isSecretRequiredForRefreshToken>
|
|
33
|
+
<label>{{LABEL}}</label>
|
|
34
|
+
<shouldRotateConsumerKey>{{ROTATE_KEY}}</shouldRotateConsumerKey>
|
|
35
|
+
<shouldRotateConsumerSecret>{{ROTATE_SECRET}}</shouldRotateConsumerSecret>
|
|
36
|
+
</ExtlClntAppGlobalOauthSettings>
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: External Client App - Instance OAuth Settings
|
|
4
|
+
Use Case: Configure OAuth scopes for the ECA
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: The ExternalClientApplication API name (must match .eca file)
|
|
8
|
+
- {{LABEL}}: Display label for this OAuth settings configuration
|
|
9
|
+
- {{SCOPES}}: Comma-separated OAuth scopes (e.g., "Api, RefreshToken, OpenID")
|
|
10
|
+
|
|
11
|
+
Common Scope Combinations:
|
|
12
|
+
- API Integration: Api, RefreshToken
|
|
13
|
+
- Web App with Identity: Api, RefreshToken, OpenID, Profile, Email
|
|
14
|
+
- Server-to-Server: Api
|
|
15
|
+
- Mobile App: Api, RefreshToken, OpenID
|
|
16
|
+
|
|
17
|
+
Available Scopes:
|
|
18
|
+
- Api: REST/SOAP API access
|
|
19
|
+
- RefreshToken: Offline access via refresh token
|
|
20
|
+
- OpenID: OpenID Connect (user identity)
|
|
21
|
+
- Profile: User profile information
|
|
22
|
+
- Email: User email address
|
|
23
|
+
- Web: Web browser access
|
|
24
|
+
- ChatterApi: Chatter REST API
|
|
25
|
+
- CustomPermissions: Custom permission access
|
|
26
|
+
|
|
27
|
+
IMPORTANT: OAuth flows (Authorization Code, Client Credentials, etc.) are
|
|
28
|
+
configured via the Admin UI or ExtlClntAppOauthConfigurablePolicies, NOT here.
|
|
29
|
+
|
|
30
|
+
File Naming: [AppName].ecaOauth-meta.xml
|
|
31
|
+
-->
|
|
32
|
+
<ExtlClntAppOauthSettings xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
33
|
+
<commaSeparatedOauthScopes>{{SCOPES}}</commaSeparatedOauthScopes>
|
|
34
|
+
<externalClientApplication>{{APP_NAME}}</externalClientApplication>
|
|
35
|
+
<label>{{LABEL}}</label>
|
|
36
|
+
</ExtlClntAppOauthSettings>
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: External Client App - Configurable Policies
|
|
4
|
+
Use Case: Admin-configurable security policies for the ECA
|
|
5
|
+
|
|
6
|
+
Note: This file is AUTO-GENERATED on first deployment.
|
|
7
|
+
Admins can modify these values in Setup UI or via Metadata API.
|
|
8
|
+
|
|
9
|
+
Replace placeholders:
|
|
10
|
+
- {{IP_RELAXATION}}: IP restriction policy
|
|
11
|
+
- {{REFRESH_TOKEN_POLICY}}: Refresh token lifetime policy
|
|
12
|
+
- {{SESSION_TIMEOUT}}: Session timeout in minutes
|
|
13
|
+
|
|
14
|
+
IP Relaxation Options:
|
|
15
|
+
- ENFORCE: Enforce IP restrictions (recommended)
|
|
16
|
+
- BYPASS: Bypass IP restrictions (use with caution)
|
|
17
|
+
- ENFORCE_ACTIVATED_USERS: Enforce for activated users only
|
|
18
|
+
|
|
19
|
+
Refresh Token Policies:
|
|
20
|
+
- infinite: Tokens never expire
|
|
21
|
+
- zero: No refresh tokens (use with JWT)
|
|
22
|
+
- specific_lifetime: Expire after specified period
|
|
23
|
+
|
|
24
|
+
File Naming: [AppName].ecaPlcy-meta.xml
|
|
25
|
+
-->
|
|
26
|
+
<ExtlClntAppConfigurablePolicies xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
27
|
+
<!-- IP Restriction Policy -->
|
|
28
|
+
<ipRelaxation>{{IP_RELAXATION}}</ipRelaxation>
|
|
29
|
+
|
|
30
|
+
<!-- Refresh Token Lifetime -->
|
|
31
|
+
<refreshTokenPolicy>{{REFRESH_TOKEN_POLICY}}</refreshTokenPolicy>
|
|
32
|
+
<!-- <refreshTokenValidityPeriod>30</refreshTokenValidityPeriod> -->
|
|
33
|
+
|
|
34
|
+
<!-- Session Timeout (minutes) -->
|
|
35
|
+
<sessionTimeout>{{SESSION_TIMEOUT}}</sessionTimeout>
|
|
36
|
+
</ExtlClntAppConfigurablePolicies>
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
+
<!--
|
|
3
|
+
Template: External Client Application - Header File
|
|
4
|
+
Use Case: Modern OAuth app with enhanced security and metadata compliance
|
|
5
|
+
|
|
6
|
+
Replace placeholders:
|
|
7
|
+
- {{APP_NAME}}: Application name (no spaces, alphanumeric + underscore)
|
|
8
|
+
- {{CONTACT_EMAIL}}: Administrator contact email
|
|
9
|
+
- {{DESCRIPTION}}: Brief description of the app's purpose
|
|
10
|
+
- {{ICON_URL}}: URL to app icon (optional)
|
|
11
|
+
- {{LOGO_URL}}: URL to app logo (optional)
|
|
12
|
+
- {{DISTRIBUTION_STATE}}: Local or Packageable
|
|
13
|
+
|
|
14
|
+
Distribution States:
|
|
15
|
+
- Local: Available only in this org
|
|
16
|
+
- Packageable: Can be packaged and distributed via 2GP
|
|
17
|
+
|
|
18
|
+
Common Source Files for ECA:
|
|
19
|
+
1. externalClientApps/[AppName].eca-meta.xml (this file)
|
|
20
|
+
2. extlClntAppGlobalOauthSets/[AppName].ecaGlblOauth-meta.xml (global OAuth settings)
|
|
21
|
+
3. extlClntAppOauthSettings/[AppName].ecaOauth-meta.xml (OAuth scopes / parent link)
|
|
22
|
+
4. extlClntAppOauthSecuritySettings/[AppName].ecaOauthSecurity-meta.xml (optional, retrieve-first)
|
|
23
|
+
5. extlClntAppOauthPolicies/[AppName].ecaOauthPlcy-meta.xml or extlClntAppPolicies/[AppName].ecaPlcy-meta.xml (optional policy metadata)
|
|
24
|
+
|
|
25
|
+
Minimum API Version: 61.0
|
|
26
|
+
-->
|
|
27
|
+
<ExternalClientApplication xmlns="http://soap.sforce.com/2006/04/metadata">
|
|
28
|
+
<contactEmail>{{CONTACT_EMAIL}}</contactEmail>
|
|
29
|
+
<description>{{DESCRIPTION}}</description>
|
|
30
|
+
<distributionState>{{DISTRIBUTION_STATE}}</distributionState>
|
|
31
|
+
<iconUrl>{{ICON_URL}}</iconUrl>
|
|
32
|
+
<isProtected>false</isProtected>
|
|
33
|
+
<label>{{APP_NAME}}</label>
|
|
34
|
+
<logoUrl>{{LOGO_URL}}</logoUrl>
|
|
35
|
+
</ExternalClientApplication>
|