@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,270 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: building-omnistudio-datamapper
|
|
3
|
+
description: "OmniStudio Data Mapper (formerly DataRaptor) creation and validation with 100-point scoring. Use when building Extract, Transform, Load, or Turbo Extract Data Mappers, mapping Salesforce object fields, or reviewing existing Data Mapper configurations. TRIGGER when: user creates Data Mappers, configures field mappings, works with OmniDataTransform metadata, or asks about DataRaptor/Data Mapper patterns. DO NOT TRIGGER when: building Integration Procedures (use building-omnistudio-integration-procedure), authoring OmniScripts (use building-omnistudio-omniscript), or analyzing cross-component dependencies (use analyzing-omnistudio-dependencies)."
|
|
4
|
+
license: MIT
|
|
5
|
+
metadata:
|
|
6
|
+
version: "1.0"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# building-omnistudio-datamapper: OmniStudio Data Mapper Creation and Validation
|
|
10
|
+
|
|
11
|
+
Expert OmniStudio Data Mapper developer specializing in Extract, Transform, Load, and Turbo Extract configurations. Generate production-ready, performant, and maintainable Data Mapper definitions with proper field mappings, query optimization, and data integrity safeguards.
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Scope
|
|
16
|
+
|
|
17
|
+
- **In scope**: Creating and validating OmniStudio Data Mapper configurations (Extract, Transform, Load, Turbo Extract); field mapping design; query optimization; FLS (Field-Level Security) validation; deployment via deploying-metadata skill
|
|
18
|
+
- **Out of scope**: Building Integration Procedures (use `building-omnistudio-integration-procedure`), authoring OmniScripts (use `building-omnistudio-omniscript`), designing FlexCards (use `building-omnistudio-flexcard`), analyzing cross-component dependencies (use `analyzing-omnistudio-dependencies`)
|
|
19
|
+
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
## Core Responsibilities
|
|
23
|
+
|
|
24
|
+
1. **Generation**: Create Data Mapper configurations (Extract, Transform, Load, Turbo Extract) from requirements
|
|
25
|
+
2. **Field Mapping**: Design object-to-output field mappings with proper type handling, lookup resolution, and null safety
|
|
26
|
+
3. **Dependency Tracking**: Identify related OmniStudio components (Integration Procedures, OmniScripts, FlexCards) that consume or feed Data Mappers
|
|
27
|
+
4. **Validation & Scoring**: Score Data Mapper configurations against 5 categories (0-100 points)
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
## CRITICAL: Orchestration Order
|
|
32
|
+
|
|
33
|
+
**analyzing-omnistudio-dependencies -> building-omnistudio-datamapper -> building-omnistudio-integration-procedure -> building-omnistudio-omniscript -> building-omnistudio-flexcard** (you are here: building-omnistudio-datamapper)
|
|
34
|
+
|
|
35
|
+
Data Mappers are the data access layer of the OmniStudio stack. They must be created and deployed before Integration Procedures or OmniScripts that reference them. Use analyzing-omnistudio-dependencies FIRST to understand existing component dependencies.
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## Key Insights
|
|
40
|
+
|
|
41
|
+
| Insight | Details |
|
|
42
|
+
|---------|---------|
|
|
43
|
+
| **Extract vs Turbo Extract** | Extract uses standard SOQL with relationship queries. Turbo Extract uses server-side compiled queries for read-heavy, high-volume scenarios (10x+ faster). Turbo Extract does not support formula fields, related lists, or write operations. |
|
|
44
|
+
| **Transform is in-memory** | Transform Data Mappers operate entirely in memory with no DML or SOQL. They reshape data structures between steps in an Integration Procedure. Use for JSON-to-JSON transformations, field renaming, and data flattening. |
|
|
45
|
+
| **Load = DML** | Load Data Mappers perform insert, update, upsert, or delete operations. They require proper FLS checks and error handling. Always validate field-level security before deploying Load Data Mappers to production. |
|
|
46
|
+
| **OmniDataTransform metadata** | Data Mappers are stored as OmniDataTransform and OmniDataTransformItem records. Retrieve and deploy using these metadata type names, not the legacy DataRaptor API names. |
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## Workflow (5-Phase Pattern)
|
|
51
|
+
|
|
52
|
+
### Phase 1: Requirements Gathering
|
|
53
|
+
|
|
54
|
+
**Ask the user** to gather:
|
|
55
|
+
- Data Mapper type (Extract, Transform, Load, Turbo Extract)
|
|
56
|
+
- Target Salesforce object(s) and fields
|
|
57
|
+
- Target org alias
|
|
58
|
+
- Consuming component (Integration Procedure, OmniScript, or FlexCard name)
|
|
59
|
+
- Data volume expectations (record counts, frequency)
|
|
60
|
+
|
|
61
|
+
**Then**:
|
|
62
|
+
1. Check existing Data Mappers: `Glob: **/OmniDataTransform*`
|
|
63
|
+
2. Check existing OmniStudio metadata: `Glob: **/omnistudio/**`
|
|
64
|
+
3. Create a task list
|
|
65
|
+
|
|
66
|
+
---
|
|
67
|
+
|
|
68
|
+
### Phase 2: Design & Type Selection
|
|
69
|
+
|
|
70
|
+
| Type | Use Case | Naming Prefix | Supports DML | Supports SOQL |
|
|
71
|
+
|------|----------|---------------|--------------|---------------|
|
|
72
|
+
| **Extract** | Read data from one or more objects with relationship queries | `DR_Extract_` | No | Yes |
|
|
73
|
+
| **Turbo Extract** | High-volume read-only queries, server-side compiled | `DR_TurboExtract_` | No | Yes (compiled) |
|
|
74
|
+
| **Transform** | In-memory data reshaping between procedure steps | `DR_Transform_` | No | No |
|
|
75
|
+
| **Load** | Write data (insert, update, upsert, delete) | `DR_Load_` | Yes | No |
|
|
76
|
+
|
|
77
|
+
**Naming Format**: `[Prefix][Object]_[Purpose]` using PascalCase
|
|
78
|
+
|
|
79
|
+
**Examples**:
|
|
80
|
+
- `DR_Extract_Account_Details` -- Extract Account with related Contacts
|
|
81
|
+
- `DR_TurboExtract_Case_List` -- High-volume Case list for FlexCard
|
|
82
|
+
- `DR_Transform_Lead_Flatten` -- Flatten nested Lead data structure
|
|
83
|
+
- `DR_Load_Opportunity_Create` -- Insert Opportunity records
|
|
84
|
+
|
|
85
|
+
---
|
|
86
|
+
|
|
87
|
+
### Phase 3: Generation & Validation
|
|
88
|
+
|
|
89
|
+
**For Generation**:
|
|
90
|
+
1. Read `assets/omni-data-transform-extract.json` (Extract), `assets/omni-data-transform-transform.json` (Transform), or `assets/omni-data-transform-load.json` (Load) for the OmniDataTransform record template
|
|
91
|
+
2. Read `assets/omni-data-transform-item.json` for each field mapping (OmniDataTransformItem) template
|
|
92
|
+
3. Configure query filters, sort order, and limits for Extract types
|
|
93
|
+
4. Set up lookup mappings and default values for Load types
|
|
94
|
+
5. Validate field-level security for all mapped fields
|
|
95
|
+
|
|
96
|
+
**For Review**:
|
|
97
|
+
1. Read existing Data Mapper configuration
|
|
98
|
+
2. Run validation against best practices
|
|
99
|
+
3. Generate improvement report with specific fixes
|
|
100
|
+
|
|
101
|
+
**Run Validation**: Read `assets/completion-summary-template.md` for the scoring output format and thresholds.
|
|
102
|
+
|
|
103
|
+
---
|
|
104
|
+
|
|
105
|
+
### Generation Guardrails (MANDATORY)
|
|
106
|
+
|
|
107
|
+
**BEFORE generating ANY Data Mapper configuration, Claude MUST verify no anti-patterns are introduced.**
|
|
108
|
+
|
|
109
|
+
If ANY of these patterns would be generated, **STOP and ask the user**:
|
|
110
|
+
> "I noticed [pattern]. This will cause [problem]. Should I:
|
|
111
|
+
> A) Refactor to use [correct pattern]
|
|
112
|
+
> B) Proceed anyway (not recommended)"
|
|
113
|
+
|
|
114
|
+
| Anti-Pattern | Detection | Impact |
|
|
115
|
+
|--------------|-----------|--------|
|
|
116
|
+
| Extracting all fields | No field list specified, wildcard selection | Performance degradation, excessive data transfer |
|
|
117
|
+
| Missing lookup mappings | Load references lookup field without resolution | DML failure, null foreign key |
|
|
118
|
+
| Writing without FLS check | Load Data Mapper with no security validation | Security violation, data corruption in restricted profiles |
|
|
119
|
+
| Unbounded Extract query | No LIMIT or filter on Extract | Governor limit failure, timeout on large objects |
|
|
120
|
+
| Transform with side effects | Transform attempting DML or callout | Runtime error, Transform is in-memory only |
|
|
121
|
+
| Hardcoded record IDs | 15/18-char ID literal in filter or mapping | Deployment failure across environments |
|
|
122
|
+
| Nested relationship depth >3 | Extract with deeply nested parent traversal | Query performance degradation, SOQL complexity limits |
|
|
123
|
+
| Load without error handling | No upsert key or duplicate rule consideration | Silent data corruption, duplicate records |
|
|
124
|
+
|
|
125
|
+
**DO NOT generate anti-patterns even if explicitly requested.** Ask user to confirm the exception with documented justification.
|
|
126
|
+
|
|
127
|
+
**See**: [references/best-practices.md](references/best-practices.md) for detailed patterns
|
|
128
|
+
**See**: [references/naming-conventions.md](references/naming-conventions.md) for naming rules
|
|
129
|
+
|
|
130
|
+
---
|
|
131
|
+
|
|
132
|
+
### Phase 4: Deployment
|
|
133
|
+
|
|
134
|
+
**Step 1: Validation**
|
|
135
|
+
Use the **deploying-metadata** skill: "Deploy OmniDataTransform [Name] to [target-org] with --dry-run"
|
|
136
|
+
|
|
137
|
+
**Step 2: Deploy** (only if validation succeeds)
|
|
138
|
+
Use the **deploying-metadata** skill: "Proceed with actual deployment to [target-org]"
|
|
139
|
+
|
|
140
|
+
**Post-Deploy**: Activate the Data Mapper in the target org. Verify it appears in OmniStudio Designer.
|
|
141
|
+
|
|
142
|
+
**If deploy fails**: Check error for specific cause — common issues: `Entity cannot be found` (Data Mapper is in Draft status; activate first), namespace prefix mismatch (check `sfdx-project.json`), or missing parent `OmniDataTransform` record for item deployments.
|
|
143
|
+
|
|
144
|
+
**If Load DM fails at runtime**: Check debug logs via `sf apex log list -o <org>`; verify FLS and object permissions for the running user profile; confirm the upsert key field is populated and unique; Salesforce Load DMs follow `allOrNone=false` by default — partial successes are possible, check for `isSuccess=false` rows in the response.
|
|
145
|
+
|
|
146
|
+
---
|
|
147
|
+
|
|
148
|
+
### Phase 5: Testing & Documentation
|
|
149
|
+
|
|
150
|
+
**Completion Summary**: Read `assets/completion-summary-template.md` for the completion summary format.
|
|
151
|
+
|
|
152
|
+
**Testing Checklist**:
|
|
153
|
+
- [ ] Preview data output in OmniStudio Designer
|
|
154
|
+
- [ ] Verify field mappings produce expected JSON structure
|
|
155
|
+
- [ ] Test with representative data volume (not just 1 record)
|
|
156
|
+
- [ ] Validate FLS enforcement with restricted profile user
|
|
157
|
+
- [ ] Confirm consuming Integration Procedure/OmniScript receives correct data shape
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## Best Practices (100-Point Scoring)
|
|
162
|
+
|
|
163
|
+
| Category | Points | Key Rules |
|
|
164
|
+
|----------|--------|-----------|
|
|
165
|
+
| **Design & Naming** | 20 | Correct type selection; naming follows `DR_[Type]_[Object]_[Purpose]` convention; single responsibility per Data Mapper |
|
|
166
|
+
| **Field Mapping** | 25 | Explicit field list (no wildcards); correct input/output paths; proper type conversions; null-safe default values |
|
|
167
|
+
| **Data Integrity** | 25 | FLS validation on all fields; lookup resolution for Load types; upsert keys defined; duplicate handling configured |
|
|
168
|
+
| **Performance** | 15 | Bounded queries with LIMIT/filters; Turbo Extract for read-heavy scenarios; minimal relationship depth; indexed filter fields |
|
|
169
|
+
| **Documentation** | 15 | Description on OmniDataTransform record; field mapping rationale documented; consuming components identified |
|
|
170
|
+
|
|
171
|
+
**Thresholds**: ✅ 90+ (Deploy) | ⚠️ 67-89 (Review) | ❌ <67 (Block - fix required)
|
|
172
|
+
|
|
173
|
+
---
|
|
174
|
+
|
|
175
|
+
## CLI Commands
|
|
176
|
+
|
|
177
|
+
### Query Existing Data Mappers
|
|
178
|
+
|
|
179
|
+
```bash
|
|
180
|
+
sf data query -q "SELECT Id,Name,Type FROM OmniDataTransform LIMIT 200" -o <org>
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
### Query Data Mapper Field Mappings
|
|
184
|
+
|
|
185
|
+
```bash
|
|
186
|
+
sf data query -q "SELECT Id,Name,InputObjectName,OutputObjectName,LookupObjectName FROM OmniDataTransformItem WHERE OmniDataTransformationId='<id>' LIMIT 200" -o <org>
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
### Retrieve Data Mapper Metadata
|
|
190
|
+
|
|
191
|
+
```bash
|
|
192
|
+
sf project retrieve start -m OmniDataTransform:<Name> -o <org>
|
|
193
|
+
```
|
|
194
|
+
|
|
195
|
+
### Deploy Data Mapper Metadata
|
|
196
|
+
|
|
197
|
+
```bash
|
|
198
|
+
sf project deploy start -m OmniDataTransform:<Name> -o <org>
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
---
|
|
202
|
+
|
|
203
|
+
## Output Expectations
|
|
204
|
+
|
|
205
|
+
Deliverables produced by this skill:
|
|
206
|
+
|
|
207
|
+
- **OmniDataTransform record** — main Data Mapper record built from `assets/omni-data-transform-*.json` template
|
|
208
|
+
- **OmniDataTransformItem records** — one per mapped field, built from `assets/omni-data-transform-item.json` template
|
|
209
|
+
- **Validation score report** — 100-point score across 5 categories (format in `assets/completion-summary-template.md`)
|
|
210
|
+
- **Deployment confirmation** — Data Mapper activated and visible in OmniStudio Designer
|
|
211
|
+
|
|
212
|
+
---
|
|
213
|
+
|
|
214
|
+
## Cross-Skill Integration
|
|
215
|
+
|
|
216
|
+
| From Skill | To building-omnistudio-datamapper | When |
|
|
217
|
+
|------------|------------------|------|
|
|
218
|
+
| analyzing-omnistudio-dependencies | -> building-omnistudio-datamapper | "Analyze dependencies before creating Data Mapper" |
|
|
219
|
+
| generating-custom-object / generating-custom-field | -> building-omnistudio-datamapper | "Describe target object fields before mapping" |
|
|
220
|
+
| querying-soql | -> building-omnistudio-datamapper | "Validate Extract query logic" |
|
|
221
|
+
|
|
222
|
+
| From building-omnistudio-datamapper | To Skill | When |
|
|
223
|
+
|--------------------|----------|------|
|
|
224
|
+
| building-omnistudio-datamapper | -> building-omnistudio-integration-procedure | "Create Integration Procedure that calls this Data Mapper" |
|
|
225
|
+
| building-omnistudio-datamapper | -> deploying-metadata | "Deploy Data Mapper to target org" |
|
|
226
|
+
| building-omnistudio-datamapper | -> building-omnistudio-omniscript | "Wire Data Mapper output into OmniScript" |
|
|
227
|
+
| building-omnistudio-datamapper | -> building-omnistudio-flexcard | "Display Data Mapper Extract results in FlexCard" |
|
|
228
|
+
|
|
229
|
+
---
|
|
230
|
+
|
|
231
|
+
## Gotchas
|
|
232
|
+
|
|
233
|
+
| Issue | Resolution |
|
|
234
|
+
|-------|-----------|
|
|
235
|
+
| Large data volume (>10K records) | Use Turbo Extract; add pagination via Integration Procedure; warn about heap limits |
|
|
236
|
+
| Polymorphic lookup fields | Specify the concrete object type in the mapping; test each type separately |
|
|
237
|
+
| Formula fields in Extract | Standard Extract supports formula fields; Turbo Extract does not — fall back to standard Extract |
|
|
238
|
+
| Cross-object Load (master-detail) | Insert parent records first, then child records in a separate Load step; use Integration Procedure to orchestrate sequence |
|
|
239
|
+
| Namespace-prefixed fields | Include namespace prefix in field paths (e.g., `ns__Field__c`); verify prefix matches target org |
|
|
240
|
+
| Multi-currency orgs | Map CurrencyIsoCode explicitly; do not rely on default currency assumption |
|
|
241
|
+
| RecordType-dependent mappings | Filter by RecordType in Extract; set RecordTypeId in Load; document which RecordTypes are supported |
|
|
242
|
+
| Draft Data Mapper not retrievable | `sf project retrieve start -m OmniDataTransform:<Name>` only works for active DMs; activate before retrieving |
|
|
243
|
+
| Foreign key field name wrong | The parent lookup on `OmniDataTransformItem` is `OmniDataTransformationId` (full word "Transformation"), not `OmniDataTransformId` |
|
|
244
|
+
|
|
245
|
+
---
|
|
246
|
+
|
|
247
|
+
## Notes
|
|
248
|
+
|
|
249
|
+
- **Metadata Type**: OmniDataTransform (not DataRaptor — legacy name deprecated)
|
|
250
|
+
- **API Version**: Requires OmniStudio managed package or Industries Cloud
|
|
251
|
+
- **Scoring**: Block deployment if score < 67; read `assets/completion-summary-template.md` for score format
|
|
252
|
+
- **Turbo Extract Limitations**: No formula fields, no related lists, no aggregate queries, no polymorphic fields
|
|
253
|
+
- **Activation**: Data Mappers must be activated after deployment to be callable from Integration Procedures (see Gotchas for draft retrieval behavior)
|
|
254
|
+
- **Creating via Data API**: Use `sf api request rest --method POST --body @file.json` to create OmniDataTransform and OmniDataTransformItem records. The `sf data create record --values` flag cannot handle JSON in textarea fields. Write the JSON body to a temp file first.
|
|
255
|
+
|
|
256
|
+
---
|
|
257
|
+
|
|
258
|
+
## Reference File Index
|
|
259
|
+
|
|
260
|
+
| File | When to Read |
|
|
261
|
+
|------|-------------|
|
|
262
|
+
| `assets/omni-data-transform-extract.json` | Phase 3 Generation — template for Extract type OmniDataTransform records |
|
|
263
|
+
| `assets/omni-data-transform-transform.json` | Phase 3 Generation — template for Transform type OmniDataTransform records |
|
|
264
|
+
| `assets/omni-data-transform-load.json` | Phase 3 Generation — template for Load type OmniDataTransform records |
|
|
265
|
+
| `assets/omni-data-transform-item.json` | Phase 3 Generation — template for each OmniDataTransformItem field mapping |
|
|
266
|
+
| `assets/completion-summary-template.md` | Phase 3 & 5 — scoring output format and completion summary template |
|
|
267
|
+
| `references/best-practices.md` | Phase 3 Guardrails — detailed patterns for field mapping, query optimization, null handling, and performance |
|
|
268
|
+
| `references/naming-conventions.md` | Phase 2 Design — full naming rules for all Data Mapper types and field mapping conventions |
|
|
269
|
+
|
|
270
|
+
---
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# Data Mapper Completion Templates
|
|
2
|
+
|
|
3
|
+
Use these templates in Phase 3 (scoring output) and Phase 5 (completion summary).
|
|
4
|
+
|
|
5
|
+
## Scoring Output (Phase 3)
|
|
6
|
+
|
|
7
|
+
```
|
|
8
|
+
Score: XX/100 Rating
|
|
9
|
+
|- Design & Naming: XX/20
|
|
10
|
+
|- Field Mapping: XX/25
|
|
11
|
+
|- Data Integrity: XX/25
|
|
12
|
+
|- Performance: XX/15
|
|
13
|
+
|- Documentation: XX/15
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
**Thresholds**: ✅ 90+ (Deploy) | ⚠️ 67-89 (Review) | ❌ <67 (Block — fix required)
|
|
17
|
+
|
|
18
|
+
## Completion Summary (Phase 5)
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
Data Mapper Complete: [Name]
|
|
22
|
+
Type: [Extract|Transform|Load|Turbo Extract]
|
|
23
|
+
Target Object(s): [Object1, Object2]
|
|
24
|
+
Field Count: [N mapped fields]
|
|
25
|
+
Validation: PASSED (Score: XX/100)
|
|
26
|
+
|
|
27
|
+
Next Steps: Test in Integration Procedure, verify data output, monitor performance
|
|
28
|
+
```
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
{
|
|
2
|
+
"OmniDataTransformationId": "{{ParentTransformId}}",
|
|
3
|
+
"Name": "{{FieldName}}",
|
|
4
|
+
"InputObjectName": "{{SalesforceObjectApiName}}",
|
|
5
|
+
"InputFieldName": "{{SalesforceFieldApiName}}",
|
|
6
|
+
"OutputObjectName": "{{OutputNodeName}}",
|
|
7
|
+
"OutputFieldName": "{{OutputFieldName}}",
|
|
8
|
+
"OmniDataTransformItemOrder": 1,
|
|
9
|
+
"FilterDataType": "String",
|
|
10
|
+
"FilterOperator": "",
|
|
11
|
+
"FilterValue": ""
|
|
12
|
+
}
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
<!-- Parent: building-omnistudio-datamapper/SKILL.md -->
|
|
2
|
+
|
|
3
|
+
# Data Mapper Best Practices
|
|
4
|
+
|
|
5
|
+
## When to Use Each Type
|
|
6
|
+
|
|
7
|
+
### Extract
|
|
8
|
+
|
|
9
|
+
Use Extract when:
|
|
10
|
+
- Reading data from one or more related Salesforce objects
|
|
11
|
+
- You need relationship queries (parent-to-child or child-to-parent)
|
|
12
|
+
- Formula fields are required in the output
|
|
13
|
+
- Data volume is moderate (under 10K records per execution)
|
|
14
|
+
- You need aggregate functions or complex filter logic
|
|
15
|
+
|
|
16
|
+
Do NOT use Extract when:
|
|
17
|
+
- Read volume exceeds 10K records consistently -- use Turbo Extract
|
|
18
|
+
- No SOQL is needed (data reshaping only) -- use Transform
|
|
19
|
+
- You are writing data -- use Load
|
|
20
|
+
|
|
21
|
+
### Turbo Extract
|
|
22
|
+
|
|
23
|
+
Use Turbo Extract when:
|
|
24
|
+
- Read-heavy scenarios with high volume (10K+ records)
|
|
25
|
+
- Query is straightforward with indexed filter fields
|
|
26
|
+
- Formula fields are not required
|
|
27
|
+
- No related list (child-to-parent) queries are needed
|
|
28
|
+
- Performance is the primary concern (10x+ faster than standard Extract)
|
|
29
|
+
|
|
30
|
+
Do NOT use Turbo Extract when:
|
|
31
|
+
- Formula fields are needed in output
|
|
32
|
+
- Related list queries are required
|
|
33
|
+
- Aggregate queries (COUNT, SUM) are needed
|
|
34
|
+
- Polymorphic lookup fields are involved
|
|
35
|
+
|
|
36
|
+
### Transform
|
|
37
|
+
|
|
38
|
+
Use Transform when:
|
|
39
|
+
- Reshaping JSON structures between Integration Procedure steps
|
|
40
|
+
- Renaming fields from one schema to another
|
|
41
|
+
- Flattening nested data structures
|
|
42
|
+
- Filtering or merging in-memory datasets
|
|
43
|
+
- No database interaction is needed
|
|
44
|
+
|
|
45
|
+
Do NOT use Transform when:
|
|
46
|
+
- Reading from or writing to Salesforce objects -- use Extract or Load
|
|
47
|
+
- Data needs to be persisted -- use Load
|
|
48
|
+
|
|
49
|
+
### Load
|
|
50
|
+
|
|
51
|
+
Use Load when:
|
|
52
|
+
- Inserting, updating, upserting, or deleting Salesforce records
|
|
53
|
+
- Writing data collected from OmniScript input or external sources
|
|
54
|
+
- Synchronizing data from Integration Procedure callout responses
|
|
55
|
+
|
|
56
|
+
Do NOT use Load when:
|
|
57
|
+
- Reading data -- use Extract or Turbo Extract
|
|
58
|
+
- Reshaping data without persistence -- use Transform
|
|
59
|
+
|
|
60
|
+
---
|
|
61
|
+
|
|
62
|
+
## Field Mapping Patterns
|
|
63
|
+
|
|
64
|
+
### Explicit Field Selection
|
|
65
|
+
|
|
66
|
+
Always specify fields explicitly. Never rely on wildcard or "all fields" selection.
|
|
67
|
+
|
|
68
|
+
```
|
|
69
|
+
Good: Account.Name, Account.Industry, Account.BillingCity
|
|
70
|
+
Bad: Account.* (extracts all fields, wastes bandwidth and heap)
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
### Input/Output Path Structure
|
|
74
|
+
|
|
75
|
+
Data Mapper fields use dot-notation paths for input and output:
|
|
76
|
+
|
|
77
|
+
```
|
|
78
|
+
Input Path: AccountData.Name
|
|
79
|
+
Output Path: Account.Name
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
For nested structures:
|
|
83
|
+
|
|
84
|
+
```
|
|
85
|
+
Input Path: Response.data.accounts[0].name
|
|
86
|
+
Output Path: AccountList.Name
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### Type Conversion Handling
|
|
90
|
+
|
|
91
|
+
Map fields with compatible types. Common conversions:
|
|
92
|
+
|
|
93
|
+
| Source Type | Target Type | Notes |
|
|
94
|
+
|-------------|-------------|-------|
|
|
95
|
+
| String | Date | Requires ISO 8601 format (YYYY-MM-DD) |
|
|
96
|
+
| String | Number | Ensure source contains numeric values only |
|
|
97
|
+
| Boolean | String | Maps to "true"/"false" string literals |
|
|
98
|
+
| DateTime | Date | Truncates time component |
|
|
99
|
+
| Picklist | String | Maps selected value as string |
|
|
100
|
+
|
|
101
|
+
### Lookup Resolution for Load
|
|
102
|
+
|
|
103
|
+
When loading records with lookup relationships:
|
|
104
|
+
|
|
105
|
+
1. Define a lookup mapping that resolves the external key to a Salesforce ID
|
|
106
|
+
2. Specify the lookup object and match field (e.g., `Account.Name` to resolve `AccountId`)
|
|
107
|
+
3. Handle cases where the lookup returns no match (set default or fail gracefully)
|
|
108
|
+
|
|
109
|
+
```
|
|
110
|
+
Field: AccountId
|
|
111
|
+
Lookup Object: Account
|
|
112
|
+
Match Field: Name
|
|
113
|
+
Input Path: InputData.AccountName
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
---
|
|
117
|
+
|
|
118
|
+
## Query Sequence Optimization
|
|
119
|
+
|
|
120
|
+
### Filter Field Indexing
|
|
121
|
+
|
|
122
|
+
For Extract and Turbo Extract, filter on indexed fields whenever possible:
|
|
123
|
+
|
|
124
|
+
- `Id` (always indexed)
|
|
125
|
+
- `Name` (indexed on standard objects)
|
|
126
|
+
- `CreatedDate` (indexed)
|
|
127
|
+
- `SystemModstamp` (indexed)
|
|
128
|
+
- Custom fields marked as External ID or Unique
|
|
129
|
+
- Custom Index fields (request from admin if needed)
|
|
130
|
+
|
|
131
|
+
### Filter Order
|
|
132
|
+
|
|
133
|
+
Place the most selective filter first to reduce the result set early:
|
|
134
|
+
|
|
135
|
+
```
|
|
136
|
+
Good: WHERE Id = :recordId AND Status = 'Active'
|
|
137
|
+
Bad: WHERE Status = 'Active' AND Id = :recordId
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
### Relationship Query Depth
|
|
141
|
+
|
|
142
|
+
Limit relationship traversal to 2 levels for performance:
|
|
143
|
+
|
|
144
|
+
```
|
|
145
|
+
Good: Account.Owner.Name (1 level)
|
|
146
|
+
Bad: Account.Parent.Parent.Parent.Owner.Name (3+ levels)
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
### Limit and Offset
|
|
150
|
+
|
|
151
|
+
Always set a LIMIT on Extract queries unless the consuming component guarantees a bounded input:
|
|
152
|
+
|
|
153
|
+
```
|
|
154
|
+
LIMIT 200 -- Standard batch size
|
|
155
|
+
LIMIT 2000 -- Maximum for most UI scenarios
|
|
156
|
+
LIMIT 10000 -- Absolute maximum, use only with pagination
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## Null Handling and Type Conversion
|
|
162
|
+
|
|
163
|
+
### Default Values
|
|
164
|
+
|
|
165
|
+
Set default values for fields that may be null to prevent downstream errors:
|
|
166
|
+
|
|
167
|
+
| Field Type | Recommended Default | Rationale |
|
|
168
|
+
|------------|-------------------|-----------|
|
|
169
|
+
| String | `""` (empty string) | Prevents null reference in concatenation |
|
|
170
|
+
| Number | `0` | Prevents null arithmetic errors |
|
|
171
|
+
| Boolean | `false` | Prevents null conditional evaluation |
|
|
172
|
+
| Date | (no default) | Leave null; do not fabricate dates |
|
|
173
|
+
| Lookup | (no default) | Leave null; handle in consuming component |
|
|
174
|
+
|
|
175
|
+
### Null-Safe Mapping
|
|
176
|
+
|
|
177
|
+
When mapping fields that may be null:
|
|
178
|
+
|
|
179
|
+
1. Set `isNullable: true` on the OmniDataTransformItem
|
|
180
|
+
2. Configure a default value where business logic requires one
|
|
181
|
+
3. Document which fields are expected to be null in certain scenarios
|
|
182
|
+
4. Test with records that have null values in mapped fields
|
|
183
|
+
|
|
184
|
+
---
|
|
185
|
+
|
|
186
|
+
## Relationship Queries
|
|
187
|
+
|
|
188
|
+
### Parent-to-Child (Subquery)
|
|
189
|
+
|
|
190
|
+
Extract supports parent-to-child relationship queries:
|
|
191
|
+
|
|
192
|
+
```
|
|
193
|
+
Object: Account
|
|
194
|
+
Fields: Name, Industry
|
|
195
|
+
Child Relationship: Contacts (Contact)
|
|
196
|
+
Child Fields: FirstName, LastName, Email
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
Output structure:
|
|
200
|
+
|
|
201
|
+
```json
|
|
202
|
+
{
|
|
203
|
+
"Name": "Acme Corp",
|
|
204
|
+
"Industry": "Technology",
|
|
205
|
+
"Contacts": [
|
|
206
|
+
{ "FirstName": "Jane", "LastName": "Doe", "Email": "jane@acme.com" }
|
|
207
|
+
]
|
|
208
|
+
}
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
### Child-to-Parent (Lookup Traversal)
|
|
212
|
+
|
|
213
|
+
Extract supports child-to-parent traversal via dot notation:
|
|
214
|
+
|
|
215
|
+
```
|
|
216
|
+
Object: Contact
|
|
217
|
+
Fields: FirstName, LastName, Account.Name, Account.Industry
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
Output structure:
|
|
221
|
+
|
|
222
|
+
```json
|
|
223
|
+
{
|
|
224
|
+
"FirstName": "Jane",
|
|
225
|
+
"LastName": "Doe",
|
|
226
|
+
"AccountName": "Acme Corp",
|
|
227
|
+
"AccountIndustry": "Technology"
|
|
228
|
+
}
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
### Turbo Extract Limitations
|
|
232
|
+
|
|
233
|
+
Turbo Extract does NOT support:
|
|
234
|
+
- Child-to-parent relationship queries (subqueries)
|
|
235
|
+
- Formula fields
|
|
236
|
+
- Aggregate functions
|
|
237
|
+
- Polymorphic lookups (e.g., `WhoId` on Task)
|
|
238
|
+
|
|
239
|
+
---
|
|
240
|
+
|
|
241
|
+
## Performance with Large Data Volumes
|
|
242
|
+
|
|
243
|
+
### Batch Size Recommendations
|
|
244
|
+
|
|
245
|
+
| Record Count | Recommended Approach |
|
|
246
|
+
|--------------|---------------------|
|
|
247
|
+
| 1-200 | Standard Extract, single call |
|
|
248
|
+
| 200-2000 | Turbo Extract, single call |
|
|
249
|
+
| 2000-10000 | Turbo Extract with pagination via Integration Procedure |
|
|
250
|
+
| 10000+ | Batch processing: scheduled Integration Procedure with chunked Turbo Extract calls |
|
|
251
|
+
|
|
252
|
+
### Heap Size Management
|
|
253
|
+
|
|
254
|
+
Each Data Mapper execution contributes to the Apex heap limit (6 MB synchronous, 12 MB async):
|
|
255
|
+
|
|
256
|
+
- Map only the fields you need (reduces JSON payload size)
|
|
257
|
+
- Use Turbo Extract for large result sets (server-side processing reduces heap usage)
|
|
258
|
+
- Paginate results when total data exceeds 2 MB
|
|
259
|
+
|
|
260
|
+
### Caching Strategy
|
|
261
|
+
|
|
262
|
+
For data that changes infrequently:
|
|
263
|
+
|
|
264
|
+
- Enable Platform Cache in the consuming Integration Procedure
|
|
265
|
+
- Set appropriate TTL (Time To Live) based on data change frequency
|
|
266
|
+
- Cache at the org partition level for shared reference data
|
|
267
|
+
- Cache at the session partition level for user-specific data
|
|
268
|
+
|
|
269
|
+
### Monitoring
|
|
270
|
+
|
|
271
|
+
Track Data Mapper performance using:
|
|
272
|
+
|
|
273
|
+
```bash
|
|
274
|
+
sf data query -q "SELECT Id,Name,Type,LastModifiedDate FROM OmniDataTransform WHERE IsActive=true ORDER BY LastModifiedDate DESC" -o <org>
|
|
275
|
+
```
|
|
276
|
+
|
|
277
|
+
Review execution logs in OmniStudio Designer > Data Mapper > Preview to identify slow queries and excessive field counts.
|