@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,235 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: handling-sf-data
|
|
3
|
+
description: "Salesforce data operations with 130-point scoring. Use this skill to create, update, delete, bulk import/export, generate test data, and clean up org records using sf CLI and anonymous Apex. TRIGGER when: user creates test data, performs bulk import/export, uses sf data CLI commands, needs data factory patterns for Apex tests, or needs to seed/clean records in a Salesforce org. DO NOT TRIGGER when: SOQL query writing only (use querying-soql), Apex test execution (use running-apex-tests), or metadata deployment (use deploying-metadata)."
|
|
4
|
+
license: MIT
|
|
5
|
+
metadata:
|
|
6
|
+
version: "1.1"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Salesforce Data Operations Expert (handling-sf-data)
|
|
10
|
+
|
|
11
|
+
Use this skill when the user needs **Salesforce data work**: record CRUD, bulk import/export, test data generation, cleanup scripts, or data factory patterns for validating Apex, Flow, or integration behavior.
|
|
12
|
+
|
|
13
|
+
## When This Skill Owns the Task
|
|
14
|
+
|
|
15
|
+
Use `handling-sf-data` when the work involves:
|
|
16
|
+
- `sf data` CLI commands
|
|
17
|
+
- record creation, update, delete, upsert, export, or tree import/export
|
|
18
|
+
- realistic test data generation
|
|
19
|
+
- bulk data operations and cleanup
|
|
20
|
+
- Apex anonymous scripts for data seeding / rollback
|
|
21
|
+
|
|
22
|
+
Delegate elsewhere when the user is:
|
|
23
|
+
- writing SOQL only → [querying-soql](../querying-soql/SKILL.md)
|
|
24
|
+
- running or repairing Apex tests → [running-apex-tests](../running-apex-tests/SKILL.md)
|
|
25
|
+
- deploying metadata first → [deploying-metadata](../deploying-metadata/SKILL.md)
|
|
26
|
+
- creating or modifying custom objects / fields → [generating-custom-object](../generating-custom-object/SKILL.md) or [generating-custom-field](../generating-custom-field/SKILL.md)
|
|
27
|
+
|
|
28
|
+
---
|
|
29
|
+
|
|
30
|
+
## Important Mode Decision
|
|
31
|
+
|
|
32
|
+
Confirm which mode the user wants:
|
|
33
|
+
|
|
34
|
+
| Mode | Use when |
|
|
35
|
+
|---|---|
|
|
36
|
+
| Script generation | they want reusable `.apex`, CSV, or JSON assets without touching an org yet |
|
|
37
|
+
| Remote execution | they want records created / changed in a real org now |
|
|
38
|
+
|
|
39
|
+
Do not assume remote execution if the user may only want scripts.
|
|
40
|
+
|
|
41
|
+
---
|
|
42
|
+
|
|
43
|
+
## Required Context to Gather First
|
|
44
|
+
|
|
45
|
+
Ask for or infer:
|
|
46
|
+
- target object(s)
|
|
47
|
+
- org alias, if remote execution is required
|
|
48
|
+
- operation type: query, create, update, delete, upsert, import, export, cleanup
|
|
49
|
+
- expected volume
|
|
50
|
+
- whether this is test data, migration data, or one-off troubleshooting data
|
|
51
|
+
- any parent-child relationships that must exist first
|
|
52
|
+
|
|
53
|
+
---
|
|
54
|
+
|
|
55
|
+
## Core Operating Rules
|
|
56
|
+
|
|
57
|
+
- `handling-sf-data` acts on **remote org data** unless the user explicitly wants local script generation.
|
|
58
|
+
- Objects and fields must already exist before data creation.
|
|
59
|
+
- For automation testing, prefer **251+ records** when bulk behavior matters.
|
|
60
|
+
- Plan cleanup before creating large or noisy datasets — untracked records accumulate across runs and pollute org state.
|
|
61
|
+
- Use synthetic, non-identifying data in test records — real PII creates compliance risk and cannot be safely removed after bulk import.
|
|
62
|
+
- Prefer **CLI-first** for straightforward CRUD; use anonymous Apex when the operation truly needs server-side orchestration.
|
|
63
|
+
|
|
64
|
+
If metadata is missing, stop and hand off to:
|
|
65
|
+
- [generating-custom-object](../generating-custom-object/SKILL.md) or [generating-custom-field](../generating-custom-field/SKILL.md) to create the missing schema, then [deploying-metadata](../deploying-metadata/SKILL.md) to deploy it before retrying the data operation
|
|
66
|
+
|
|
67
|
+
---
|
|
68
|
+
|
|
69
|
+
## Recommended Workflow
|
|
70
|
+
|
|
71
|
+
### 1. Verify prerequisites
|
|
72
|
+
Confirm object / field availability, org auth, and required parent records.
|
|
73
|
+
|
|
74
|
+
### 2. Run describe-first pre-flight validation when schema is uncertain
|
|
75
|
+
Before creating or updating records, use object describe data to validate:
|
|
76
|
+
- required fields
|
|
77
|
+
- createable vs non-createable fields
|
|
78
|
+
- picklist values
|
|
79
|
+
- relationship fields and parent requirements
|
|
80
|
+
|
|
81
|
+
See [references/sf-cli-data-commands.md](references/sf-cli-data-commands.md) for the `sf sobject describe` command and jq filter patterns for inspecting fields, picklist values, and createable constraints.
|
|
82
|
+
|
|
83
|
+
### 3. Choose the smallest correct mechanism
|
|
84
|
+
| Need | Default approach |
|
|
85
|
+
|---|---|
|
|
86
|
+
| small one-off CRUD | `sf data` single-record commands |
|
|
87
|
+
| large import/export | Bulk API 2.0 via `sf data ... bulk` |
|
|
88
|
+
| parent-child seed set | tree import/export |
|
|
89
|
+
| reusable test dataset | factory / anonymous Apex script |
|
|
90
|
+
| reversible experiment | cleanup script or savepoint-based approach |
|
|
91
|
+
|
|
92
|
+
### 4. Execute or generate assets
|
|
93
|
+
Use the built-in templates under `assets/` when they fit:
|
|
94
|
+
- `assets/factories/`
|
|
95
|
+
- `assets/bulk/`
|
|
96
|
+
- `assets/cleanup/`
|
|
97
|
+
- `assets/soql/`
|
|
98
|
+
- `assets/csv/`
|
|
99
|
+
- `assets/json/`
|
|
100
|
+
|
|
101
|
+
### 5. Verify results
|
|
102
|
+
Check counts, relationships, and record IDs after creation or update.
|
|
103
|
+
|
|
104
|
+
### 6. Apply a bounded retry strategy
|
|
105
|
+
If creation fails:
|
|
106
|
+
1. try the primary CLI shape once
|
|
107
|
+
2. retry once with corrected parameters
|
|
108
|
+
3. re-run describe / validate assumptions
|
|
109
|
+
4. pivot to a different mechanism or provide a manual workaround
|
|
110
|
+
|
|
111
|
+
Do **not** repeat the same failing command indefinitely.
|
|
112
|
+
|
|
113
|
+
### 7. Leave cleanup guidance
|
|
114
|
+
Provide exact cleanup commands or rollback assets whenever data was created.
|
|
115
|
+
|
|
116
|
+
---
|
|
117
|
+
|
|
118
|
+
## High-Signal Rules
|
|
119
|
+
|
|
120
|
+
### Bulk safety
|
|
121
|
+
- use bulk operations for large volumes
|
|
122
|
+
- test automation-sensitive behavior with 251+ records where appropriate
|
|
123
|
+
- avoid one-record-at-a-time patterns for bulk scenarios
|
|
124
|
+
|
|
125
|
+
### Data integrity
|
|
126
|
+
- include required fields
|
|
127
|
+
- validate picklist values before creation
|
|
128
|
+
- verify parent IDs and relationship integrity
|
|
129
|
+
- account for validation rules and duplicate constraints
|
|
130
|
+
- exclude non-createable fields from input payloads
|
|
131
|
+
|
|
132
|
+
### Cleanup discipline
|
|
133
|
+
Prefer one of:
|
|
134
|
+
- delete-by-ID
|
|
135
|
+
- delete-by-pattern
|
|
136
|
+
- delete-by-created-date window
|
|
137
|
+
- rollback / savepoint patterns for script-based test runs
|
|
138
|
+
|
|
139
|
+
---
|
|
140
|
+
|
|
141
|
+
## Common Failure Patterns
|
|
142
|
+
|
|
143
|
+
| Error | Likely cause | Default fix direction |
|
|
144
|
+
|---|---|---|
|
|
145
|
+
| `INVALID_FIELD` | wrong field API name or FLS issue | verify schema and access |
|
|
146
|
+
| `REQUIRED_FIELD_MISSING` | mandatory field omitted | include required values from describe data |
|
|
147
|
+
| `INVALID_CROSS_REFERENCE_KEY` | bad parent ID | create / verify parent first |
|
|
148
|
+
| `FIELD_CUSTOM_VALIDATION_EXCEPTION` | validation rule blocked the record | use valid test data or adjust setup |
|
|
149
|
+
| invalid picklist value | guessed value instead of describe-backed value | inspect picklist values first |
|
|
150
|
+
| non-writeable field error | field is not createable / updateable | remove it from the payload |
|
|
151
|
+
| bulk limits / timeouts | wrong tool for the volume | switch to bulk / staged import |
|
|
152
|
+
|
|
153
|
+
---
|
|
154
|
+
|
|
155
|
+
## Output Format
|
|
156
|
+
|
|
157
|
+
When finishing, report in this order:
|
|
158
|
+
1. **Operation performed**
|
|
159
|
+
2. **Objects and counts**
|
|
160
|
+
3. **Target org or local artifact path**
|
|
161
|
+
4. **Record IDs / output files**
|
|
162
|
+
5. **Verification result**
|
|
163
|
+
6. **Cleanup instructions**
|
|
164
|
+
|
|
165
|
+
Suggested shape:
|
|
166
|
+
|
|
167
|
+
```text
|
|
168
|
+
Data operation: <create / update / delete / export / seed>
|
|
169
|
+
Objects: <object + counts>
|
|
170
|
+
Target: <org alias or local path>
|
|
171
|
+
Artifacts: <record ids / csv / apex / json files>
|
|
172
|
+
Verification: <passed / partial / failed>
|
|
173
|
+
Cleanup: <exact delete or rollback guidance>
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
---
|
|
177
|
+
|
|
178
|
+
## Cross-Skill Integration
|
|
179
|
+
|
|
180
|
+
| Need | Delegate to | Reason |
|
|
181
|
+
|---|---|---|
|
|
182
|
+
| create missing custom objects | [generating-custom-object](../generating-custom-object/SKILL.md) | schema must exist before data operations |
|
|
183
|
+
| create missing custom fields | [generating-custom-field](../generating-custom-field/SKILL.md) | field-level schema must exist before data creation |
|
|
184
|
+
| run bulk-sensitive Apex validation | [running-apex-tests](../running-apex-tests/SKILL.md) | test execution and coverage |
|
|
185
|
+
| deploy missing schema first | [deploying-metadata](../deploying-metadata/SKILL.md) | metadata readiness |
|
|
186
|
+
| implement production Apex logic consuming the data | [generating-apex](../generating-apex/SKILL.md) | Apex class / trigger authoring |
|
|
187
|
+
| implement Flow logic consuming the data | [generating-flow](../generating-flow/SKILL.md) | Flow authoring and automation |
|
|
188
|
+
|
|
189
|
+
---
|
|
190
|
+
|
|
191
|
+
## Reference Map
|
|
192
|
+
|
|
193
|
+
### Start here
|
|
194
|
+
- [references/sf-cli-data-commands.md](references/sf-cli-data-commands.md)
|
|
195
|
+
- [references/test-data-best-practices.md](references/test-data-best-practices.md)
|
|
196
|
+
- [references/orchestration.md](references/orchestration.md)
|
|
197
|
+
- [references/test-data-patterns.md](references/test-data-patterns.md)
|
|
198
|
+
- [references/test-data-factory-usage.md](references/test-data-factory-usage.md)
|
|
199
|
+
|
|
200
|
+
### Query / bulk / cleanup
|
|
201
|
+
- [references/soql-relationship-guide.md](references/soql-relationship-guide.md)
|
|
202
|
+
- [references/relationship-query-examples.md](references/relationship-query-examples.md)
|
|
203
|
+
- [references/bulk-operations-guide.md](references/bulk-operations-guide.md)
|
|
204
|
+
- [references/cleanup-rollback-guide.md](references/cleanup-rollback-guide.md)
|
|
205
|
+
- [references/cleanup-rollback-example.md](references/cleanup-rollback-example.md)
|
|
206
|
+
|
|
207
|
+
### Examples / limits
|
|
208
|
+
- [references/crud-workflow-example.md](references/crud-workflow-example.md)
|
|
209
|
+
- [references/bulk-testing-example.md](references/bulk-testing-example.md)
|
|
210
|
+
- [references/anonymous-apex-guide.md](references/anonymous-apex-guide.md)
|
|
211
|
+
- [references/governor-limits-reference.md](references/governor-limits-reference.md)
|
|
212
|
+
|
|
213
|
+
### Validation scripts
|
|
214
|
+
- [scripts/soql_validator.py](scripts/soql_validator.py) — validate SOQL queries before execution
|
|
215
|
+
- [scripts/validate_data_operation.py](scripts/validate_data_operation.py) — pre-flight check for data operations (required fields, picklist values, createable fields)
|
|
216
|
+
|
|
217
|
+
### Asset templates
|
|
218
|
+
- `assets/factories/` — Apex test data factory scripts (account, contact, opportunity, lead, user, etc.)
|
|
219
|
+
- `assets/bulk/` — Bulk API 2.0 Apex templates (insert 200, 500, 10000 records; upsert by external ID)
|
|
220
|
+
- `assets/cleanup/` — Cleanup and rollback scripts (delete by name, date, pattern; transaction rollback)
|
|
221
|
+
- `assets/soql/` — SOQL query templates (aggregate, subquery, parent-to-child, child-to-parent, polymorphic)
|
|
222
|
+
- `assets/csv/` — CSV import templates for Account, Contact, Opportunity, custom objects
|
|
223
|
+
- `assets/json/` — JSON tree import templates (account-contact, account-opportunity, full hierarchy)
|
|
224
|
+
|
|
225
|
+
---
|
|
226
|
+
|
|
227
|
+
## Score Guide
|
|
228
|
+
|
|
229
|
+
| Score | Meaning |
|
|
230
|
+
|---|---|
|
|
231
|
+
| 117+ | strong production-safe data workflow |
|
|
232
|
+
| 104–116 | good operation with minor improvements possible |
|
|
233
|
+
| 91–103 | acceptable but review advised |
|
|
234
|
+
| 78–90 | partial / risky patterns present |
|
|
235
|
+
| < 78 | blocked until corrected |
|
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ═══════════════════════════════════════════════════════════════════════════════
|
|
3
|
+
* BULK INSERT 10,000+ RECORDS
|
|
4
|
+
* For Bulk API and large data volume testing
|
|
5
|
+
* ═══════════════════════════════════════════════════════════════════════════════
|
|
6
|
+
*
|
|
7
|
+
* ⚠️ IMPORTANT: This script is designed to be run via sf CLI Bulk API
|
|
8
|
+
* NOT via Anonymous Apex (which has governor limits)
|
|
9
|
+
*
|
|
10
|
+
* PURPOSE:
|
|
11
|
+
* Generate large datasets for:
|
|
12
|
+
* • Bulk API 2.0 testing
|
|
13
|
+
* • Performance testing
|
|
14
|
+
* • Data migration validation
|
|
15
|
+
* • Report/Dashboard testing with realistic volumes
|
|
16
|
+
*
|
|
17
|
+
* APPROACHES:
|
|
18
|
+
* 1. Use sf data import bulk with CSV files (recommended)
|
|
19
|
+
* 2. Use Data Loader for very large datasets
|
|
20
|
+
* 3. Use batch Apex to create in smaller chunks
|
|
21
|
+
*
|
|
22
|
+
* ═══════════════════════════════════════════════════════════════════════════════
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
26
|
+
// APPROACH 1: BATCH APEX FOR LARGE DATA CREATION
|
|
27
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Batch class to create large number of Account records
|
|
31
|
+
* Execute with: Database.executeBatch(new BulkAccountCreator(10000), 200);
|
|
32
|
+
*/
|
|
33
|
+
public class BulkAccountCreator implements Database.Batchable<Integer>, Database.Stateful {
|
|
34
|
+
|
|
35
|
+
private Integer targetCount;
|
|
36
|
+
private Integer createdCount = 0;
|
|
37
|
+
private String namePrefix;
|
|
38
|
+
private List<String> industries;
|
|
39
|
+
private DateTime startTime;
|
|
40
|
+
|
|
41
|
+
public BulkAccountCreator(Integer count) {
|
|
42
|
+
this.targetCount = count;
|
|
43
|
+
this.namePrefix = 'BulkData';
|
|
44
|
+
this.industries = new List<String>{
|
|
45
|
+
'Technology', 'Healthcare', 'Finance', 'Manufacturing',
|
|
46
|
+
'Retail', 'Education', 'Energy', 'Media'
|
|
47
|
+
};
|
|
48
|
+
this.startTime = DateTime.now();
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public Iterable<Integer> start(Database.BatchableContext bc) {
|
|
52
|
+
// Create list of indices to process
|
|
53
|
+
List<Integer> indices = new List<Integer>();
|
|
54
|
+
for (Integer i = 0; i < targetCount; i++) {
|
|
55
|
+
indices.add(i);
|
|
56
|
+
}
|
|
57
|
+
return indices;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
public void execute(Database.BatchableContext bc, List<Integer> indices) {
|
|
61
|
+
List<Account> accounts = new List<Account>();
|
|
62
|
+
|
|
63
|
+
for (Integer i : indices) {
|
|
64
|
+
accounts.add(new Account(
|
|
65
|
+
Name = namePrefix + '_' + String.valueOf(i).leftPad(7, '0'),
|
|
66
|
+
Industry = industries[Math.mod(i, industries.size())],
|
|
67
|
+
Type = Math.mod(i, 3) == 0 ? 'Customer' : 'Prospect',
|
|
68
|
+
AnnualRevenue = 50000 + (Math.mod(i, 1000) * 1000),
|
|
69
|
+
NumberOfEmployees = 10 + Math.mod(i, 1000),
|
|
70
|
+
BillingCity = 'San Francisco',
|
|
71
|
+
BillingState = 'CA',
|
|
72
|
+
BillingCountry = 'USA',
|
|
73
|
+
Description = 'Bulk created record ' + i
|
|
74
|
+
));
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
insert accounts;
|
|
78
|
+
createdCount += accounts.size();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
public void finish(Database.BatchableContext bc) {
|
|
82
|
+
DateTime endTime = DateTime.now();
|
|
83
|
+
Long durationMs = endTime.getTime() - startTime.getTime();
|
|
84
|
+
|
|
85
|
+
System.debug('═══════════════════════════════════════════════════════════════');
|
|
86
|
+
System.debug('BULK CREATION COMPLETE');
|
|
87
|
+
System.debug('═══════════════════════════════════════════════════════════════');
|
|
88
|
+
System.debug('Records Created: ' + createdCount);
|
|
89
|
+
System.debug('Duration: ' + durationMs + 'ms (' + (durationMs / 1000) + ' seconds)');
|
|
90
|
+
System.debug('Rate: ' + (createdCount * 1000 / durationMs) + ' records/second');
|
|
91
|
+
System.debug('═══════════════════════════════════════════════════════════════');
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// Execute with:
|
|
96
|
+
// Database.executeBatch(new BulkAccountCreator(10000), 200);
|
|
97
|
+
|
|
98
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
99
|
+
// APPROACH 2: GENERATE CSV FOR BULK API IMPORT
|
|
100
|
+
// Run this to generate CSV, then use sf data import bulk
|
|
101
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Generate CSV content for bulk import
|
|
105
|
+
* Note: For very large files, generate externally with Python/Node.js
|
|
106
|
+
*/
|
|
107
|
+
public class BulkCsvGenerator {
|
|
108
|
+
|
|
109
|
+
public static String generateAccountCsv(Integer count) {
|
|
110
|
+
List<String> rows = new List<String>();
|
|
111
|
+
|
|
112
|
+
// Header
|
|
113
|
+
rows.add('Name,Industry,Type,AnnualRevenue,NumberOfEmployees,BillingCity,BillingState,BillingCountry,Description');
|
|
114
|
+
|
|
115
|
+
List<String> industries = new List<String>{
|
|
116
|
+
'Technology', 'Healthcare', 'Finance', 'Manufacturing',
|
|
117
|
+
'Retail', 'Education', 'Energy', 'Media'
|
|
118
|
+
};
|
|
119
|
+
List<String> types = new List<String>{'Prospect', 'Customer', 'Partner'};
|
|
120
|
+
|
|
121
|
+
// Data rows
|
|
122
|
+
for (Integer i = 0; i < count; i++) {
|
|
123
|
+
String name = 'BulkImport_' + String.valueOf(i).leftPad(7, '0');
|
|
124
|
+
String industry = industries[Math.mod(i, industries.size())];
|
|
125
|
+
String type = types[Math.mod(i, types.size())];
|
|
126
|
+
Decimal revenue = 50000 + (Math.mod(i, 1000) * 1000);
|
|
127
|
+
Integer employees = 10 + Math.mod(i, 1000);
|
|
128
|
+
|
|
129
|
+
rows.add(String.join(new List<String>{
|
|
130
|
+
name,
|
|
131
|
+
industry,
|
|
132
|
+
type,
|
|
133
|
+
String.valueOf(revenue),
|
|
134
|
+
String.valueOf(employees),
|
|
135
|
+
'San Francisco',
|
|
136
|
+
'CA',
|
|
137
|
+
'USA',
|
|
138
|
+
'Bulk imported record ' + i
|
|
139
|
+
}, ','));
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
return String.join(rows, '\n');
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
// Usage:
|
|
147
|
+
// String csv = BulkCsvGenerator.generateAccountCsv(1000);
|
|
148
|
+
// System.debug(csv);
|
|
149
|
+
// Then save to file and use: sf data import bulk --file accounts.csv --sobject Account --target-org myorg
|
|
150
|
+
|
|
151
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
152
|
+
// SF CLI BULK IMPORT COMMANDS
|
|
153
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
154
|
+
|
|
155
|
+
/*
|
|
156
|
+
STEP 1: Create CSV file with headers and data
|
|
157
|
+
|
|
158
|
+
Example accounts.csv:
|
|
159
|
+
Name,Industry,Type,AnnualRevenue,BillingCity,BillingState,BillingCountry
|
|
160
|
+
BulkTest_0000001,Technology,Prospect,100000,San Francisco,CA,USA
|
|
161
|
+
BulkTest_0000002,Healthcare,Customer,150000,San Francisco,CA,USA
|
|
162
|
+
...
|
|
163
|
+
|
|
164
|
+
STEP 2: Import using Bulk API 2.0
|
|
165
|
+
|
|
166
|
+
# Import with wait for completion
|
|
167
|
+
sf data import bulk \
|
|
168
|
+
--file accounts.csv \
|
|
169
|
+
--sobject Account \
|
|
170
|
+
--target-org myorg \
|
|
171
|
+
--wait 30
|
|
172
|
+
|
|
173
|
+
# Import async (returns job ID)
|
|
174
|
+
sf data import bulk \
|
|
175
|
+
--file accounts.csv \
|
|
176
|
+
--sobject Account \
|
|
177
|
+
--target-org myorg
|
|
178
|
+
|
|
179
|
+
# Check job status
|
|
180
|
+
sf data bulk results \
|
|
181
|
+
--job-id 7500000000XXXXX \
|
|
182
|
+
--target-org myorg
|
|
183
|
+
|
|
184
|
+
*/
|
|
185
|
+
|
|
186
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
187
|
+
// PYTHON SCRIPT TO GENERATE LARGE CSV
|
|
188
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
189
|
+
|
|
190
|
+
/*
|
|
191
|
+
Save as generate_bulk_data.py:
|
|
192
|
+
|
|
193
|
+
import csv
|
|
194
|
+
import random
|
|
195
|
+
|
|
196
|
+
industries = ['Technology', 'Healthcare', 'Finance', 'Manufacturing',
|
|
197
|
+
'Retail', 'Education', 'Energy', 'Media']
|
|
198
|
+
types = ['Prospect', 'Customer', 'Partner']
|
|
199
|
+
cities = ['San Francisco', 'New York', 'Chicago', 'Los Angeles', 'Seattle']
|
|
200
|
+
states = ['CA', 'NY', 'IL', 'CA', 'WA']
|
|
201
|
+
|
|
202
|
+
def generate_accounts(count, filename='accounts.csv'):
|
|
203
|
+
with open(filename, 'w', newline='') as f:
|
|
204
|
+
writer = csv.writer(f)
|
|
205
|
+
writer.writerow(['Name', 'Industry', 'Type', 'AnnualRevenue',
|
|
206
|
+
'NumberOfEmployees', 'BillingCity', 'BillingState',
|
|
207
|
+
'BillingCountry', 'Description'])
|
|
208
|
+
|
|
209
|
+
for i in range(count):
|
|
210
|
+
city_idx = i % len(cities)
|
|
211
|
+
writer.writerow([
|
|
212
|
+
f'BulkTest_{i:07d}',
|
|
213
|
+
industries[i % len(industries)],
|
|
214
|
+
types[i % len(types)],
|
|
215
|
+
50000 + (i % 1000) * 1000,
|
|
216
|
+
10 + (i % 500),
|
|
217
|
+
cities[city_idx],
|
|
218
|
+
states[city_idx],
|
|
219
|
+
'USA',
|
|
220
|
+
f'Bulk test record {i}'
|
|
221
|
+
])
|
|
222
|
+
|
|
223
|
+
print(f'Generated {count} records to {filename}')
|
|
224
|
+
|
|
225
|
+
if __name__ == '__main__':
|
|
226
|
+
generate_accounts(10000)
|
|
227
|
+
|
|
228
|
+
Run: python generate_bulk_data.py
|
|
229
|
+
Then: sf data import bulk --file accounts.csv --sobject Account --target-org myorg --wait 30
|
|
230
|
+
|
|
231
|
+
*/
|
|
232
|
+
|
|
233
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
234
|
+
// CLEANUP FOR LARGE DATASETS
|
|
235
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
236
|
+
|
|
237
|
+
/*
|
|
238
|
+
CLEANUP via Bulk API:
|
|
239
|
+
|
|
240
|
+
# Step 1: Export IDs to delete
|
|
241
|
+
sf data query \
|
|
242
|
+
--query "SELECT Id FROM Account WHERE Name LIKE 'BulkTest%' OR Name LIKE 'BulkData%' OR Name LIKE 'BulkImport%'" \
|
|
243
|
+
--target-org myorg \
|
|
244
|
+
--result-format csv \
|
|
245
|
+
> delete-accounts.csv
|
|
246
|
+
|
|
247
|
+
# Step 2: Bulk delete
|
|
248
|
+
sf data delete bulk \
|
|
249
|
+
--file delete-accounts.csv \
|
|
250
|
+
--sobject Account \
|
|
251
|
+
--target-org myorg \
|
|
252
|
+
--wait 30
|
|
253
|
+
|
|
254
|
+
# For hard delete (permanent, requires permission):
|
|
255
|
+
sf data delete bulk \
|
|
256
|
+
--file delete-accounts.csv \
|
|
257
|
+
--sobject Account \
|
|
258
|
+
--target-org myorg \
|
|
259
|
+
--hard-delete \
|
|
260
|
+
--wait 30
|
|
261
|
+
*/
|
|
262
|
+
|
|
263
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
264
|
+
// BATCH APEX CLEANUP
|
|
265
|
+
// ═══════════════════════════════════════════════════════════════════════════════
|
|
266
|
+
|
|
267
|
+
/**
|
|
268
|
+
* Batch class to delete large number of records
|
|
269
|
+
*/
|
|
270
|
+
public class BulkRecordDeleter implements Database.Batchable<SObject> {
|
|
271
|
+
|
|
272
|
+
private String query;
|
|
273
|
+
|
|
274
|
+
public BulkRecordDeleter(String soqlQuery) {
|
|
275
|
+
this.query = soqlQuery;
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
public Database.QueryLocator start(Database.BatchableContext bc) {
|
|
279
|
+
return Database.getQueryLocator(query);
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
public void execute(Database.BatchableContext bc, List<SObject> records) {
|
|
283
|
+
delete records;
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
public void finish(Database.BatchableContext bc) {
|
|
287
|
+
System.debug('Bulk delete complete');
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
// Execute with:
|
|
292
|
+
// String query = 'SELECT Id FROM Account WHERE Name LIKE \'BulkTest%\'';
|
|
293
|
+
// Database.executeBatch(new BulkRecordDeleter(query), 200);
|