@salesforce/afv-skills 1.22.0 → 1.23.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/README.md +0 -39
- package/skills/activating-datacloud/SKILL.md +0 -117
- package/skills/analyzing-omnistudio-dependencies/CREDITS.md +0 -5
- package/skills/analyzing-omnistudio-dependencies/SKILL.md +0 -476
- package/skills/analyzing-omnistudio-dependencies/references/dependency-patterns.md +0 -508
- package/skills/analyzing-omnistudio-dependencies/references/namespace-guide.md +0 -300
- package/skills/applying-cms-brand/SKILL.md +0 -170
- package/skills/applying-slds/SKILL.md +0 -322
- package/skills/applying-slds/checklists.md +0 -83
- package/skills/applying-slds/examples.md +0 -283
- package/skills/applying-slds/guidance/README.md +0 -83
- package/skills/applying-slds/guidance/blueprints-index.md +0 -213
- package/skills/applying-slds/guidance/icons-guidance.md +0 -186
- package/skills/applying-slds/guidance/overviews/borders.md +0 -236
- package/skills/applying-slds/guidance/overviews/color.md +0 -266
- package/skills/applying-slds/guidance/overviews/display-density.md +0 -366
- package/skills/applying-slds/guidance/overviews/icons.md +0 -240
- package/skills/applying-slds/guidance/overviews/illustrations.md +0 -235
- package/skills/applying-slds/guidance/overviews/shadows.md +0 -176
- package/skills/applying-slds/guidance/overviews/spacing.md +0 -216
- package/skills/applying-slds/guidance/overviews/typography.md +0 -323
- package/skills/applying-slds/guidance/overviews/utilities.md +0 -542
- package/skills/applying-slds/guidance/slds-development-guide.md +0 -288
- package/skills/applying-slds/guidance/styling-hooks/borders.md +0 -202
- package/skills/applying-slds/guidance/styling-hooks/color/expressive-palette-hooks.md +0 -153
- package/skills/applying-slds/guidance/styling-hooks/color/index.md +0 -171
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/accent-hooks.md +0 -204
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/feedback-hooks.md +0 -768
- package/skills/applying-slds/guidance/styling-hooks/color/semantic/surface-hooks.md +0 -337
- package/skills/applying-slds/guidance/styling-hooks/color/system-hooks.md +0 -132
- package/skills/applying-slds/guidance/styling-hooks/index.md +0 -327
- package/skills/applying-slds/guidance/styling-hooks/shadows.md +0 -238
- package/skills/applying-slds/guidance/styling-hooks/spacing.md +0 -254
- package/skills/applying-slds/guidance/styling-hooks/typography.md +0 -448
- package/skills/applying-slds/guidance/utilities/alignment.md +0 -119
- package/skills/applying-slds/guidance/utilities/borders.md +0 -131
- package/skills/applying-slds/guidance/utilities/box.md +0 -125
- package/skills/applying-slds/guidance/utilities/color.md +0 -165
- package/skills/applying-slds/guidance/utilities/dark-mode.md +0 -111
- package/skills/applying-slds/guidance/utilities/description-list.md +0 -168
- package/skills/applying-slds/guidance/utilities/floats.md +0 -117
- package/skills/applying-slds/guidance/utilities/grid.md +0 -264
- package/skills/applying-slds/guidance/utilities/horizontal-list.md +0 -110
- package/skills/applying-slds/guidance/utilities/hyphenation.md +0 -84
- package/skills/applying-slds/guidance/utilities/index.md +0 -205
- package/skills/applying-slds/guidance/utilities/interactions.md +0 -89
- package/skills/applying-slds/guidance/utilities/layout.md +0 -109
- package/skills/applying-slds/guidance/utilities/line-clamp.md +0 -131
- package/skills/applying-slds/guidance/utilities/margin.md +0 -155
- package/skills/applying-slds/guidance/utilities/media-object.md +0 -161
- package/skills/applying-slds/guidance/utilities/name-value-list.md +0 -152
- package/skills/applying-slds/guidance/utilities/padding.md +0 -155
- package/skills/applying-slds/guidance/utilities/position.md +0 -177
- package/skills/applying-slds/guidance/utilities/print.md +0 -114
- package/skills/applying-slds/guidance/utilities/scrollable.md +0 -126
- package/skills/applying-slds/guidance/utilities/sizing.md +0 -190
- package/skills/applying-slds/guidance/utilities/themes.md +0 -121
- package/skills/applying-slds/guidance/utilities/truncate.md +0 -127
- package/skills/applying-slds/guidance/utilities/typography.md +0 -166
- package/skills/applying-slds/guidance/utilities/vertical-list.md +0 -166
- package/skills/applying-slds/guidance/utilities/visibility.md +0 -228
- package/skills/applying-slds/metadata/README.md +0 -84
- package/skills/applying-slds/metadata/blueprints/components/accordion.yaml +0 -304
- package/skills/applying-slds/metadata/blueprints/components/activity-timeline.yaml +0 -92
- package/skills/applying-slds/metadata/blueprints/components/alert.yaml +0 -103
- package/skills/applying-slds/metadata/blueprints/components/app-launcher.yaml +0 -94
- package/skills/applying-slds/metadata/blueprints/components/avatar-group.yaml +0 -81
- package/skills/applying-slds/metadata/blueprints/components/avatar.yaml +0 -97
- package/skills/applying-slds/metadata/blueprints/components/badges.yaml +0 -102
- package/skills/applying-slds/metadata/blueprints/components/brand-band.yaml +0 -198
- package/skills/applying-slds/metadata/blueprints/components/breadcrumbs.yaml +0 -95
- package/skills/applying-slds/metadata/blueprints/components/builder-header.yaml +0 -192
- package/skills/applying-slds/metadata/blueprints/components/button-groups.yaml +0 -82
- package/skills/applying-slds/metadata/blueprints/components/button-icons.yaml +0 -295
- package/skills/applying-slds/metadata/blueprints/components/buttons.yaml +0 -230
- package/skills/applying-slds/metadata/blueprints/components/cards.yaml +0 -124
- package/skills/applying-slds/metadata/blueprints/components/carousel.yaml +0 -140
- package/skills/applying-slds/metadata/blueprints/components/chat.yaml +0 -179
- package/skills/applying-slds/metadata/blueprints/components/checkbox-button-group.yaml +0 -192
- package/skills/applying-slds/metadata/blueprints/components/checkbox-button.yaml +0 -204
- package/skills/applying-slds/metadata/blueprints/components/checkbox-toggle.yaml +0 -177
- package/skills/applying-slds/metadata/blueprints/components/checkbox.yaml +0 -108
- package/skills/applying-slds/metadata/blueprints/components/color-picker.yaml +0 -172
- package/skills/applying-slds/metadata/blueprints/components/combobox.yaml +0 -136
- package/skills/applying-slds/metadata/blueprints/components/counter.yaml +0 -147
- package/skills/applying-slds/metadata/blueprints/components/data-tables.yaml +0 -157
- package/skills/applying-slds/metadata/blueprints/components/datepickers.yaml +0 -130
- package/skills/applying-slds/metadata/blueprints/components/datetime-picker.yaml +0 -155
- package/skills/applying-slds/metadata/blueprints/components/docked-composer.yaml +0 -201
- package/skills/applying-slds/metadata/blueprints/components/docked-form-footer.yaml +0 -161
- package/skills/applying-slds/metadata/blueprints/components/docked-utility-bar.yaml +0 -175
- package/skills/applying-slds/metadata/blueprints/components/drop-zone.yaml +0 -115
- package/skills/applying-slds/metadata/blueprints/components/dueling-picklist.yaml +0 -196
- package/skills/applying-slds/metadata/blueprints/components/dynamic-icons.yaml +0 -128
- package/skills/applying-slds/metadata/blueprints/components/dynamic-menu.yaml +0 -141
- package/skills/applying-slds/metadata/blueprints/components/expandable-section.yaml +0 -115
- package/skills/applying-slds/metadata/blueprints/components/expression.yaml +0 -143
- package/skills/applying-slds/metadata/blueprints/components/feeds.yaml +0 -125
- package/skills/applying-slds/metadata/blueprints/components/file-selector.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/files.yaml +0 -119
- package/skills/applying-slds/metadata/blueprints/components/form-element.yaml +0 -145
- package/skills/applying-slds/metadata/blueprints/components/global-header.yaml +0 -120
- package/skills/applying-slds/metadata/blueprints/components/global-navigation.yaml +0 -100
- package/skills/applying-slds/metadata/blueprints/components/icons.yaml +0 -138
- package/skills/applying-slds/metadata/blueprints/components/illustration.yaml +0 -205
- package/skills/applying-slds/metadata/blueprints/components/input.yaml +0 -151
- package/skills/applying-slds/metadata/blueprints/components/list-builder.yaml +0 -127
- package/skills/applying-slds/metadata/blueprints/components/lookups.yaml +0 -132
- package/skills/applying-slds/metadata/blueprints/components/map.yaml +0 -118
- package/skills/applying-slds/metadata/blueprints/components/menus.yaml +0 -134
- package/skills/applying-slds/metadata/blueprints/components/modals.yaml +0 -152
- package/skills/applying-slds/metadata/blueprints/components/notifications.yaml +0 -88
- package/skills/applying-slds/metadata/blueprints/components/page-headers.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/panels.yaml +0 -149
- package/skills/applying-slds/metadata/blueprints/components/path.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/picklist.yaml +0 -125
- package/skills/applying-slds/metadata/blueprints/components/pills.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/popovers.yaml +0 -120
- package/skills/applying-slds/metadata/blueprints/components/progress-bar.yaml +0 -110
- package/skills/applying-slds/metadata/blueprints/components/progress-indicator.yaml +0 -133
- package/skills/applying-slds/metadata/blueprints/components/progress-ring.yaml +0 -102
- package/skills/applying-slds/metadata/blueprints/components/prompt.yaml +0 -126
- package/skills/applying-slds/metadata/blueprints/components/publishers.yaml +0 -178
- package/skills/applying-slds/metadata/blueprints/components/radio-button-group.yaml +0 -172
- package/skills/applying-slds/metadata/blueprints/components/radio-group.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/rich-text-editor.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/scoped-notifications.yaml +0 -188
- package/skills/applying-slds/metadata/blueprints/components/scoped-tabs.yaml +0 -97
- package/skills/applying-slds/metadata/blueprints/components/select.yaml +0 -127
- package/skills/applying-slds/metadata/blueprints/components/setup-assistant.yaml +0 -152
- package/skills/applying-slds/metadata/blueprints/components/slider.yaml +0 -111
- package/skills/applying-slds/metadata/blueprints/components/spinners.yaml +0 -135
- package/skills/applying-slds/metadata/blueprints/components/split-view.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/summary-detail.yaml +0 -103
- package/skills/applying-slds/metadata/blueprints/components/tabs.yaml +0 -138
- package/skills/applying-slds/metadata/blueprints/components/textarea.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/tiles.yaml +0 -108
- package/skills/applying-slds/metadata/blueprints/components/timepicker.yaml +0 -111
- package/skills/applying-slds/metadata/blueprints/components/toast.yaml +0 -154
- package/skills/applying-slds/metadata/blueprints/components/tooltips.yaml +0 -107
- package/skills/applying-slds/metadata/blueprints/components/tree-grid.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/trees.yaml +0 -116
- package/skills/applying-slds/metadata/blueprints/components/trial-bar.yaml +0 -112
- package/skills/applying-slds/metadata/blueprints/components/vertical-navigation.yaml +0 -130
- package/skills/applying-slds/metadata/blueprints/components/vertical-tabs.yaml +0 -140
- package/skills/applying-slds/metadata/blueprints/components/visual-picker.yaml +0 -150
- package/skills/applying-slds/metadata/blueprints/components/welcome-mat.yaml +0 -136
- package/skills/applying-slds/metadata/hooks-index.json +0 -6272
- package/skills/applying-slds/metadata/icon-metadata.json +0 -38466
- package/skills/applying-slds/metadata/utilities-index.json +0 -21912
- package/skills/applying-slds/references/component-selection.md +0 -112
- package/skills/applying-slds/references/icons-decision-guide.md +0 -124
- package/skills/applying-slds/references/styling-decision-guide.md +0 -228
- package/skills/applying-slds/references/utilities-quick-ref.md +0 -125
- package/skills/applying-slds/scripts/search-blueprints.cjs +0 -117
- package/skills/applying-slds/scripts/search-hooks.cjs +0 -139
- package/skills/applying-slds/scripts/search-icons.cjs +0 -174
- package/skills/applying-slds/scripts/search-utilities.cjs +0 -161
- package/skills/building-mobile-apps/SKILL.md +0 -69
- package/skills/building-omnistudio-callable-apex/CREDITS.md +0 -9
- package/skills/building-omnistudio-callable-apex/README.md +0 -80
- package/skills/building-omnistudio-callable-apex/SKILL.md +0 -275
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_openinterface.cls +0 -40
- package/skills/building-omnistudio-callable-apex/assets/pattern_callable_vanilla.cls +0 -32
- package/skills/building-omnistudio-callable-apex/assets/pattern_migration.cls +0 -54
- package/skills/building-omnistudio-callable-apex/assets/pattern_openinterface.cls +0 -45
- package/skills/building-omnistudio-callable-apex/assets/pattern_test_class.cls +0 -65
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallable.cls +0 -115
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/Industries_QuoteByProductCallableTest.cls +0 -189
- package/skills/building-omnistudio-callable-apex/examples/Test_QuoteByProductCallable/TRANSCRIPT.md +0 -115
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallable.cls +0 -74
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomCallableTest.cls +0 -146
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/MyCustomRemoteClass.cls +0 -16
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterface2Conversion/TRANSCRIPT.md +0 -120
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/IndustriesCallableException.cls +0 -7
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallable.cls +0 -73
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomCallableTest.cls +0 -128
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/MyCustomVlocityOpenInterface2.cls +0 -23
- package/skills/building-omnistudio-callable-apex/examples/Test_VlocityOpenInterfaceConversion/TRANSCRIPT.md +0 -75
- package/skills/building-omnistudio-datamapper/CREDITS.md +0 -5
- package/skills/building-omnistudio-datamapper/SKILL.md +0 -269
- package/skills/building-omnistudio-datamapper/assets/completion-summary-template.md +0 -28
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-extract.json +0 -6
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-item.json +0 -12
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-load.json +0 -6
- package/skills/building-omnistudio-datamapper/assets/omni-data-transform-transform.json +0 -6
- package/skills/building-omnistudio-datamapper/references/best-practices.md +0 -277
- package/skills/building-omnistudio-datamapper/references/naming-conventions.md +0 -145
- package/skills/building-omnistudio-flexcard/CREDITS.md +0 -5
- package/skills/building-omnistudio-flexcard/SKILL.md +0 -324
- package/skills/building-omnistudio-flexcard/assets/omni-ui-card.json +0 -10
- package/skills/building-omnistudio-flexcard/references/best-practices.md +0 -291
- package/skills/building-omnistudio-flexcard/references/data-binding-guide.md +0 -311
- package/skills/building-omnistudio-flexcard/references/scoring-rubric.md +0 -66
- package/skills/building-omnistudio-flexcard/scripts/flexcard-commands.sh +0 -24
- package/skills/building-omnistudio-integration-procedure/CREDITS.md +0 -5
- package/skills/building-omnistudio-integration-procedure/SKILL.md +0 -274
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-dr-extract.json +0 -10
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-element-set-values.json +0 -10
- package/skills/building-omnistudio-integration-procedure/assets/omni-process-ip.json +0 -12
- package/skills/building-omnistudio-integration-procedure/assets/scoring-report-format.txt +0 -14
- package/skills/building-omnistudio-integration-procedure/references/best-practices.md +0 -388
- package/skills/building-omnistudio-integration-procedure/references/element-types.md +0 -588
- package/skills/building-omnistudio-integration-procedure/scripts/cli-commands.sh +0 -18
- package/skills/building-omnistudio-omniscript/CREDITS.md +0 -5
- package/skills/building-omnistudio-omniscript/SKILL.md +0 -366
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-step.json +0 -10
- package/skills/building-omnistudio-omniscript/assets/omni-process-element-text-block.json +0 -11
- package/skills/building-omnistudio-omniscript/assets/omni-process-omniscript.json +0 -12
- package/skills/building-omnistudio-omniscript/references/best-practices.md +0 -480
- package/skills/building-omnistudio-omniscript/references/element-types.md +0 -1172
- package/skills/building-omnistudio-omniscript/scripts/check-duplicate-omniscript.sh +0 -13
- package/skills/building-omnistudio-omniscript/scripts/cli-reference.sh +0 -21
- package/skills/building-omnistudio-omniscript/scripts/deploy-omniscript.sh +0 -29
- package/skills/building-sf-integrations/CREDITS.md +0 -5
- package/skills/building-sf-integrations/README.md +0 -95
- package/skills/building-sf-integrations/SKILL.md +0 -191
- package/skills/building-sf-integrations/assets/callouts/callout-retry-handler.cls +0 -167
- package/skills/building-sf-integrations/assets/callouts/http-response-handler.cls +0 -257
- package/skills/building-sf-integrations/assets/callouts/rest-queueable-callout.cls +0 -262
- package/skills/building-sf-integrations/assets/callouts/rest-sync-callout.cls +0 -211
- package/skills/building-sf-integrations/assets/cdc/cdc-handler.cls +0 -246
- package/skills/building-sf-integrations/assets/cdc/cdc-subscriber-trigger.trigger +0 -139
- package/skills/building-sf-integrations/assets/endpoint-security/example.cspTrustedSite-meta.xml +0 -58
- package/skills/building-sf-integrations/assets/endpoint-security/example.remoteSite-meta.xml +0 -39
- package/skills/building-sf-integrations/assets/external-credentials/jwt-external-credential.externalCredential-meta.xml +0 -90
- package/skills/building-sf-integrations/assets/external-credentials/oauth-external-credential.externalCredential-meta.xml +0 -87
- package/skills/building-sf-integrations/assets/external-services/external-service-operations.md +0 -221
- package/skills/building-sf-integrations/assets/external-services/openapi-registration.externalServiceRegistration-meta.xml +0 -193
- package/skills/building-sf-integrations/assets/named-credentials/certificate-auth.namedCredential-meta.xml +0 -62
- package/skills/building-sf-integrations/assets/named-credentials/custom-auth.namedCredential-meta.xml +0 -71
- package/skills/building-sf-integrations/assets/named-credentials/oauth-client-credentials.namedCredential-meta.xml +0 -51
- package/skills/building-sf-integrations/assets/named-credentials/oauth-jwt-bearer.namedCredential-meta.xml +0 -67
- package/skills/building-sf-integrations/assets/platform-events/event-publisher.cls +0 -191
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-action.cls +0 -295
- package/skills/building-sf-integrations/assets/platform-events/event-subscriber-trigger.trigger +0 -108
- package/skills/building-sf-integrations/assets/platform-events/platform-event-definition.object-meta.xml +0 -124
- package/skills/building-sf-integrations/assets/soap/soap-callout-service.cls +0 -186
- package/skills/building-sf-integrations/assets/soap/wsdl2apex-guide.md +0 -213
- package/skills/building-sf-integrations/hooks/scripts/suggest_credential_setup.py +0 -271
- package/skills/building-sf-integrations/hooks/scripts/validate_integration.py +0 -363
- package/skills/building-sf-integrations/references/callout-patterns.md +0 -719
- package/skills/building-sf-integrations/references/cdc-guide.md +0 -288
- package/skills/building-sf-integrations/references/cli-reference.md +0 -94
- package/skills/building-sf-integrations/references/event-driven-architecture-guide.md +0 -266
- package/skills/building-sf-integrations/references/event-patterns.md +0 -838
- package/skills/building-sf-integrations/references/external-services-guide.md +0 -303
- package/skills/building-sf-integrations/references/messaging-api-v2.md +0 -609
- package/skills/building-sf-integrations/references/named-credentials-automation.md +0 -201
- package/skills/building-sf-integrations/references/named-credentials-guide.md +0 -173
- package/skills/building-sf-integrations/references/platform-events-guide.md +0 -288
- package/skills/building-sf-integrations/references/rest-callout-patterns.md +0 -288
- package/skills/building-sf-integrations/references/scoring-rubric.md +0 -59
- package/skills/building-sf-integrations/references/security-best-practices.md +0 -248
- package/skills/building-sf-integrations/scripts/README.md +0 -100
- package/skills/building-sf-integrations/scripts/configure-named-credential.sh +0 -236
- package/skills/building-sf-integrations/scripts/set-api-credential.sh +0 -146
- package/skills/building-sf-integrations/scripts/templates/setup-credentials-with-csp.sh +0 -158
- package/skills/building-ui-bundle-app/SKILL.md +0 -350
- package/skills/building-ui-bundle-frontend/SKILL.md +0 -135
- package/skills/building-ui-bundle-frontend/implementation/component.md +0 -78
- package/skills/building-ui-bundle-frontend/implementation/header-footer.md +0 -132
- package/skills/building-ui-bundle-frontend/implementation/page.md +0 -93
- package/skills/configuring-code-analyzer/SKILL.md +0 -482
- package/skills/configuring-code-analyzer/examples/apex-project-config.yml +0 -41
- package/skills/configuring-code-analyzer/examples/ci-github-actions.yml +0 -96
- package/skills/configuring-code-analyzer/examples/fullstack-project-config.yml +0 -46
- package/skills/configuring-code-analyzer/examples/lwc-project-config.yml +0 -26
- package/skills/configuring-code-analyzer/references/ci-cd-templates.md +0 -648
- package/skills/configuring-code-analyzer/references/config-schema.md +0 -257
- package/skills/configuring-code-analyzer/references/diagnostic-flow.md +0 -70
- package/skills/configuring-code-analyzer/references/engine-prerequisites.md +0 -276
- package/skills/configuring-code-analyzer/references/rule-name-resolution.md +0 -67
- package/skills/configuring-code-analyzer/references/troubleshooting.md +0 -298
- package/skills/configuring-code-analyzer/scripts/check-prerequisites.sh +0 -189
- package/skills/configuring-code-analyzer/scripts/generate-config.sh +0 -143
- package/skills/configuring-code-analyzer/scripts/validate-config.sh +0 -153
- package/skills/configuring-connected-apps/CREDITS.md +0 -3
- package/skills/configuring-connected-apps/README.md +0 -99
- package/skills/configuring-connected-apps/SKILL.md +0 -223
- package/skills/configuring-connected-apps/assets/connected-app-basic.xml +0 -29
- package/skills/configuring-connected-apps/assets/connected-app-canvas.xml +0 -62
- package/skills/configuring-connected-apps/assets/connected-app-jwt.xml +0 -49
- package/skills/configuring-connected-apps/assets/connected-app-oauth.xml +0 -65
- package/skills/configuring-connected-apps/assets/eca-global-oauth.xml +0 -36
- package/skills/configuring-connected-apps/assets/eca-oauth-settings.xml +0 -36
- package/skills/configuring-connected-apps/assets/eca-policies.xml +0 -36
- package/skills/configuring-connected-apps/assets/external-client-app.xml +0 -35
- package/skills/configuring-connected-apps/references/example-usage.md +0 -256
- package/skills/configuring-connected-apps/references/migration-guide.md +0 -328
- package/skills/configuring-connected-apps/references/oauth-flows-reference.md +0 -660
- package/skills/configuring-connected-apps/references/security-checklist.md +0 -209
- package/skills/configuring-connected-apps/references/testing-validation-guide.md +0 -275
- package/skills/connecting-datacloud/CREDITS.md +0 -5
- package/skills/connecting-datacloud/README.md +0 -59
- package/skills/connecting-datacloud/SKILL.md +0 -154
- package/skills/connecting-datacloud/examples/connections/heroku-postgres.json +0 -15
- package/skills/connecting-datacloud/examples/connections/ingest-api-connection.json +0 -5
- package/skills/connecting-datacloud/examples/connections/ingest-api-schema.json +0 -31
- package/skills/connecting-datacloud/examples/connections/redshift.json +0 -16
- package/skills/connecting-datacloud/examples/connections/sharepoint-unstructured.json +0 -20
- package/skills/connecting-datacloud/examples/connections/snowflake-connection.json +0 -42
- package/skills/creating-b2b-commerce-store/SKILL.md +0 -167
- package/skills/creating-b2b-commerce-store/references/store-vs-storefront.md +0 -169
- package/skills/debugging-apex-logs/CREDITS.md +0 -22
- package/skills/debugging-apex-logs/README.md +0 -74
- package/skills/debugging-apex-logs/SKILL.md +0 -171
- package/skills/debugging-apex-logs/assets/benchmarking-template.cls +0 -327
- package/skills/debugging-apex-logs/assets/cpu-heap-optimization.cls +0 -307
- package/skills/debugging-apex-logs/assets/dml-in-loop-fix.cls +0 -219
- package/skills/debugging-apex-logs/assets/null-pointer-fix.cls +0 -252
- package/skills/debugging-apex-logs/assets/soql-in-loop-fix.cls +0 -157
- package/skills/debugging-apex-logs/references/analysis-playbook.md +0 -53
- package/skills/debugging-apex-logs/references/benchmarking-guide.md +0 -287
- package/skills/debugging-apex-logs/references/cli-commands.md +0 -368
- package/skills/debugging-apex-logs/references/common-issues.md +0 -68
- package/skills/debugging-apex-logs/references/debug-log-reference.md +0 -328
- package/skills/debugging-apex-logs/references/log-analysis-tools.md +0 -248
- package/skills/debugging-apex-logs/references/scoring-rubric.md +0 -21
- package/skills/deploying-metadata/CREDITS.md +0 -25
- package/skills/deploying-metadata/README.md +0 -104
- package/skills/deploying-metadata/SKILL.md +0 -213
- package/skills/deploying-metadata/assets/destructiveChanges.xml +0 -143
- package/skills/deploying-metadata/assets/package.xml +0 -121
- package/skills/deploying-metadata/references/agent-deployment-guide.md +0 -628
- package/skills/deploying-metadata/references/deploy.sh +0 -73
- package/skills/deploying-metadata/references/deployment-report-template.md +0 -89
- package/skills/deploying-metadata/references/deployment-workflows.md +0 -395
- package/skills/deploying-metadata/references/orchestration.md +0 -183
- package/skills/deploying-metadata/references/trigger-deployment-safety.md +0 -376
- package/skills/deploying-omnistudio-datapacks/CREDITS.md +0 -5
- package/skills/deploying-omnistudio-datapacks/README.md +0 -88
- package/skills/deploying-omnistudio-datapacks/SKILL.md +0 -173
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/TRANSCRIPT.md +0 -124
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle/deploy-business-internet-plus-bundle.yaml +0 -11
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/TRANSCRIPT.md +0 -142
- package/skills/deploying-omnistudio-datapacks/examples/business-internet-plus-bundle-deploy/deploy-business-internet-plus-bundle.yaml +0 -10
- package/skills/deploying-omnistudio-datapacks/references/job-file-template.md +0 -42
- package/skills/deploying-omnistudio-datapacks/references/troubleshooting-matrix.md +0 -24
- package/skills/deploying-ui-bundle/SKILL.md +0 -79
- package/skills/developing-agentforce/README.md +0 -112
- package/skills/developing-agentforce/SKILL.md +0 -518
- package/skills/developing-agentforce/assets/README-legacy.md +0 -89
- package/skills/developing-agentforce/assets/agent-spec-template.md +0 -90
- package/skills/developing-agentforce/assets/agents/README.md +0 -45
- package/skills/developing-agentforce/assets/agents/hello-world.agent +0 -60
- package/skills/developing-agentforce/assets/agents/multi-subagent.agent +0 -105
- package/skills/developing-agentforce/assets/agents/order-service.agent +0 -272
- package/skills/developing-agentforce/assets/agents/production-faq.agent +0 -101
- package/skills/developing-agentforce/assets/agents/production-faq.bundle-meta.xml +0 -4
- package/skills/developing-agentforce/assets/agents/simple-qa.agent +0 -72
- package/skills/developing-agentforce/assets/agents/verification-gate.agent +0 -280
- package/skills/developing-agentforce/assets/apex/models-api-queueable.cls +0 -225
- package/skills/developing-agentforce/assets/bundle-meta.xml +0 -23
- package/skills/developing-agentforce/assets/components/apex-action.agent +0 -52
- package/skills/developing-agentforce/assets/components/error-handling.agent +0 -58
- package/skills/developing-agentforce/assets/components/escalation-setup.agent +0 -169
- package/skills/developing-agentforce/assets/components/flow-action.agent +0 -66
- package/skills/developing-agentforce/assets/components/n-ary-conditions.agent +0 -110
- package/skills/developing-agentforce/assets/components/subagent-with-actions.agent +0 -40
- package/skills/developing-agentforce/assets/deterministic-routing.agent +0 -166
- package/skills/developing-agentforce/assets/escalation-pattern.agent +0 -209
- package/skills/developing-agentforce/assets/flow-action-lookup.agent +0 -115
- package/skills/developing-agentforce/assets/hub-and-spoke.agent +0 -104
- package/skills/developing-agentforce/assets/invocable-apex-template.cls +0 -187
- package/skills/developing-agentforce/assets/local-info-agent-annotated.agent +0 -355
- package/skills/developing-agentforce/assets/metadata/basic-prompt-template.promptTemplate-meta.xml +0 -109
- package/skills/developing-agentforce/assets/metadata/genai-function-apex.xml +0 -92
- package/skills/developing-agentforce/assets/metadata/genai-function-flow.xml +0 -57
- package/skills/developing-agentforce/assets/metadata/genai-plugin.xml +0 -72
- package/skills/developing-agentforce/assets/metadata/http-callout-flow.flow-meta.xml +0 -348
- package/skills/developing-agentforce/assets/metadata/record-grounded-prompt.promptTemplate-meta.xml +0 -136
- package/skills/developing-agentforce/assets/minimal-starter.agent +0 -42
- package/skills/developing-agentforce/assets/patterns/README.md +0 -254
- package/skills/developing-agentforce/assets/patterns/action-callbacks.agent +0 -178
- package/skills/developing-agentforce/assets/patterns/advanced-input-bindings.agent +0 -141
- package/skills/developing-agentforce/assets/patterns/bidirectional-routing.agent +0 -156
- package/skills/developing-agentforce/assets/patterns/critical-input-collection.agent +0 -244
- package/skills/developing-agentforce/assets/patterns/delegation-routing.agent +0 -89
- package/skills/developing-agentforce/assets/patterns/lifecycle-events.agent +0 -127
- package/skills/developing-agentforce/assets/patterns/llm-controlled-actions.agent +0 -184
- package/skills/developing-agentforce/assets/patterns/multi-step-workflow.agent +0 -282
- package/skills/developing-agentforce/assets/patterns/open-gate-routing.agent +0 -287
- package/skills/developing-agentforce/assets/patterns/procedural-instructions.agent +0 -273
- package/skills/developing-agentforce/assets/patterns/prompt-template-action.agent +0 -188
- package/skills/developing-agentforce/assets/patterns/system-instruction-overrides.agent +0 -293
- package/skills/developing-agentforce/assets/prompt-rag-search.agent +0 -131
- package/skills/developing-agentforce/assets/template-multi-subagent.agent +0 -160
- package/skills/developing-agentforce/assets/template-single-subagent.agent +0 -81
- package/skills/developing-agentforce/assets/verification-gate.agent +0 -208
- package/skills/developing-agentforce/references/action-prompt-templates.md +0 -164
- package/skills/developing-agentforce/references/actions-reference.md +0 -612
- package/skills/developing-agentforce/references/agent-access-guide.md +0 -72
- package/skills/developing-agentforce/references/agent-design-and-spec-creation.md +0 -1010
- package/skills/developing-agentforce/references/agent-metadata-and-lifecycle.md +0 -575
- package/skills/developing-agentforce/references/agent-script-core-language.md +0 -1255
- package/skills/developing-agentforce/references/agent-subagent-map-diagrams.md +0 -323
- package/skills/developing-agentforce/references/agent-user-setup.md +0 -529
- package/skills/developing-agentforce/references/agent-validation-and-debugging.md +0 -805
- package/skills/developing-agentforce/references/architecture-patterns.md +0 -158
- package/skills/developing-agentforce/references/complex-data-types.md +0 -57
- package/skills/developing-agentforce/references/deploy-reference.md +0 -134
- package/skills/developing-agentforce/references/discover-reference.md +0 -102
- package/skills/developing-agentforce/references/examples.md +0 -350
- package/skills/developing-agentforce/references/feature-validity.md +0 -43
- package/skills/developing-agentforce/references/instruction-resolution.md +0 -545
- package/skills/developing-agentforce/references/known-issues.md +0 -353
- package/skills/developing-agentforce/references/minimal-examples.md +0 -67
- package/skills/developing-agentforce/references/production-gotchas.md +0 -300
- package/skills/developing-agentforce/references/safety-review-reference.md +0 -145
- package/skills/developing-agentforce/references/salesforce-cli-for-agents.md +0 -395
- package/skills/developing-agentforce/references/scaffold-reference.md +0 -153
- package/skills/developing-agentforce/references/scoring-rubric.md +0 -24
- package/skills/developing-agentforce/references/version-history.md +0 -23
- package/skills/dx-app-analytics-use/SKILL.md +0 -135
- package/skills/fetching-salesforce-docs/README.md +0 -66
- package/skills/fetching-salesforce-docs/SKILL.md +0 -208
- package/skills/fetching-salesforce-docs/requirements.txt +0 -2
- package/skills/fetching-salesforce-docs/scripts/extract_help_salesforce.py +0 -497
- package/skills/fetching-salesforce-docs/scripts/extract_salesforce_doc.py +0 -357
- package/skills/fetching-salesforce-docs/scripts/runtime_bootstrap.py +0 -58
- package/skills/generating-apex/CREDITS.md +0 -5
- package/skills/generating-apex/SKILL.md +0 -409
- package/skills/generating-apex/assets/abstract.cls +0 -131
- package/skills/generating-apex/assets/batch.cls +0 -124
- package/skills/generating-apex/assets/domain.cls +0 -101
- package/skills/generating-apex/assets/dto.cls +0 -107
- package/skills/generating-apex/assets/exception.cls +0 -50
- package/skills/generating-apex/assets/interface.cls +0 -24
- package/skills/generating-apex/assets/invocable.cls +0 -114
- package/skills/generating-apex/assets/queueable.cls +0 -91
- package/skills/generating-apex/assets/rest-resource.cls +0 -300
- package/skills/generating-apex/assets/schedulable.cls +0 -74
- package/skills/generating-apex/assets/selector.cls +0 -91
- package/skills/generating-apex/assets/service.cls +0 -68
- package/skills/generating-apex/assets/trigger.cls +0 -45
- package/skills/generating-apex/assets/utility.cls +0 -96
- package/skills/generating-apex/references/AccountDeduplicationBatch.cls +0 -147
- package/skills/generating-apex/references/AccountSelector.cls +0 -192
- package/skills/generating-apex/references/AccountService.cls +0 -200
- package/skills/generating-apex-test/CREDITS.md +0 -5
- package/skills/generating-apex-test/SKILL.md +0 -201
- package/skills/generating-apex-test/assets/test-class-template.cls +0 -93
- package/skills/generating-apex-test/assets/test-data-factory-template.cls +0 -111
- package/skills/generating-apex-test/references/assertion-patterns.md +0 -108
- package/skills/generating-apex-test/references/async-testing.md +0 -193
- package/skills/generating-apex-test/references/mocking-patterns.md +0 -220
- package/skills/generating-apex-test/references/test-data-factory.md +0 -75
- package/skills/generating-custom-application/SKILL.md +0 -211
- package/skills/generating-custom-field/SKILL.md +0 -503
- package/skills/generating-custom-lightning-type/SKILL.md +0 -180
- package/skills/generating-custom-lightning-type/assets/primitive-types-and-constraints.md +0 -41
- package/skills/generating-custom-lightning-type/references/widget-rendition.md +0 -124
- package/skills/generating-custom-object/SKILL.md +0 -240
- package/skills/generating-custom-tab/SKILL.md +0 -156
- package/skills/generating-flexipage/SKILL.md +0 -522
- package/skills/generating-flow/SKILL.md +0 -372
- package/skills/generating-lightning-app/SKILL.md +0 -423
- package/skills/generating-list-view/SKILL.md +0 -218
- package/skills/generating-lwc-components/CREDITS.md +0 -5
- package/skills/generating-lwc-components/README.md +0 -126
- package/skills/generating-lwc-components/SKILL.md +0 -190
- package/skills/generating-lwc-components/assets/apex-controller/LwcController.cls +0 -327
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.css +0 -72
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.html +0 -111
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js +0 -163
- package/skills/generating-lwc-components/assets/basic-component/basicComponent.js-meta.xml +0 -137
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.html +0 -111
- package/skills/generating-lwc-components/assets/datatable-component/datatableComponent.js +0 -367
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.css +0 -63
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.html +0 -154
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js +0 -348
- package/skills/generating-lwc-components/assets/flow-screen-component/flowScreenComponent.js-meta.xml +0 -87
- package/skills/generating-lwc-components/assets/form-component/formComponent.html +0 -165
- package/skills/generating-lwc-components/assets/form-component/formComponent.js +0 -275
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.html +0 -100
- package/skills/generating-lwc-components/assets/graphql-component/graphqlComponent.js +0 -336
- package/skills/generating-lwc-components/assets/jest-test/componentName.test.js.example +0 -371
- package/skills/generating-lwc-components/assets/message-channel/RecordSelected.messageChannel-meta.xml +0 -71
- package/skills/generating-lwc-components/assets/message-channel/lmsPublisher.js +0 -103
- package/skills/generating-lwc-components/assets/message-channel/lmsSubscriber.js +0 -181
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.html +0 -85
- package/skills/generating-lwc-components/assets/modal-component/modalComponent.js +0 -199
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.html +0 -55
- package/skills/generating-lwc-components/assets/record-picker/recordPicker.js +0 -199
- package/skills/generating-lwc-components/assets/state-store/store.js +0 -282
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.css +0 -65
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.html +0 -95
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.js-meta.xml +0 -75
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.test.ts.example +0 -301
- package/skills/generating-lwc-components/assets/typescript-component/typescriptComponent.ts +0 -295
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.html +0 -71
- package/skills/generating-lwc-components/assets/workspace-api/workspaceComponent.js +0 -316
- package/skills/generating-lwc-components/hooks/scripts/lwc-lsp-validate.py +0 -295
- package/skills/generating-lwc-components/hooks/scripts/post-tool-validate.py +0 -347
- package/skills/generating-lwc-components/hooks/scripts/slds_data/deprecated_patterns.json +0 -74
- package/skills/generating-lwc-components/hooks/scripts/slds_data/styling_hooks.json +0 -111
- package/skills/generating-lwc-components/hooks/scripts/slds_data/valid_slds_classes.json +0 -127
- package/skills/generating-lwc-components/hooks/scripts/slds_linter_wrapper.py +0 -294
- package/skills/generating-lwc-components/hooks/scripts/slds_rules/__init__.py +0 -22
- package/skills/generating-lwc-components/hooks/scripts/template_validator.py +0 -332
- package/skills/generating-lwc-components/hooks/scripts/validate_slds.py +0 -595
- package/skills/generating-lwc-components/references/accessibility-guide.md +0 -843
- package/skills/generating-lwc-components/references/advanced-features.md +0 -108
- package/skills/generating-lwc-components/references/async-notification-patterns.md +0 -661
- package/skills/generating-lwc-components/references/cli-commands.md +0 -545
- package/skills/generating-lwc-components/references/component-patterns.md +0 -1476
- package/skills/generating-lwc-components/references/flow-integration-guide.md +0 -675
- package/skills/generating-lwc-components/references/jest-testing.md +0 -1011
- package/skills/generating-lwc-components/references/lms-guide.md +0 -860
- package/skills/generating-lwc-components/references/lwc-best-practices.md +0 -1310
- package/skills/generating-lwc-components/references/performance-guide.md +0 -861
- package/skills/generating-lwc-components/references/scoring-and-testing.md +0 -116
- package/skills/generating-lwc-components/references/slds-blueprints.json +0 -14389
- package/skills/generating-lwc-components/references/slds-design-guide.md +0 -166
- package/skills/generating-lwc-components/references/state-management.md +0 -642
- package/skills/generating-lwc-components/references/template-anti-patterns.md +0 -948
- package/skills/generating-lwc-components/references/triangle-pattern.md +0 -365
- package/skills/generating-lwc-components/scripts/local-dev-preview.sh +0 -34
- package/skills/generating-mermaid-diagrams/CREDITS.md +0 -46
- package/skills/generating-mermaid-diagrams/README.md +0 -114
- package/skills/generating-mermaid-diagrams/SKILL.md +0 -217
- package/skills/generating-mermaid-diagrams/assets/agentforce/agent-flow.md +0 -313
- package/skills/generating-mermaid-diagrams/assets/architecture/system-landscape.md +0 -351
- package/skills/generating-mermaid-diagrams/assets/datamodel/b2b-commerce-erd.md +0 -317
- package/skills/generating-mermaid-diagrams/assets/datamodel/campaigns-erd.md +0 -195
- package/skills/generating-mermaid-diagrams/assets/datamodel/consent-erd.md +0 -262
- package/skills/generating-mermaid-diagrams/assets/datamodel/files-erd.md +0 -266
- package/skills/generating-mermaid-diagrams/assets/datamodel/forecasting-erd.md +0 -261
- package/skills/generating-mermaid-diagrams/assets/datamodel/fsl-erd.md +0 -332
- package/skills/generating-mermaid-diagrams/assets/datamodel/party-model-erd.md +0 -237
- package/skills/generating-mermaid-diagrams/assets/datamodel/quote-order-erd.md +0 -277
- package/skills/generating-mermaid-diagrams/assets/datamodel/revenue-cloud-erd.md +0 -343
- package/skills/generating-mermaid-diagrams/assets/datamodel/sales-cloud-erd.md +0 -192
- package/skills/generating-mermaid-diagrams/assets/datamodel/salesforce-erd.md +0 -209
- package/skills/generating-mermaid-diagrams/assets/datamodel/scheduler-erd.md +0 -276
- package/skills/generating-mermaid-diagrams/assets/datamodel/service-cloud-erd.md +0 -217
- package/skills/generating-mermaid-diagrams/assets/datamodel/territory-management-erd.md +0 -241
- package/skills/generating-mermaid-diagrams/assets/integration/api-sequence.md +0 -387
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code-pkce.md +0 -197
- package/skills/generating-mermaid-diagrams/assets/oauth/authorization-code.md +0 -152
- package/skills/generating-mermaid-diagrams/assets/oauth/client-credentials.md +0 -233
- package/skills/generating-mermaid-diagrams/assets/oauth/device-authorization.md +0 -295
- package/skills/generating-mermaid-diagrams/assets/oauth/jwt-bearer.md +0 -256
- package/skills/generating-mermaid-diagrams/assets/oauth/refresh-token.md +0 -281
- package/skills/generating-mermaid-diagrams/assets/oauth/user-agent-social-sign-on.md +0 -281
- package/skills/generating-mermaid-diagrams/assets/role-hierarchy/user-hierarchy.md +0 -322
- package/skills/generating-mermaid-diagrams/references/color-palette.md +0 -464
- package/skills/generating-mermaid-diagrams/references/diagram-conventions.md +0 -313
- package/skills/generating-mermaid-diagrams/references/erd-conventions.md +0 -320
- package/skills/generating-mermaid-diagrams/references/mermaid-reference.md +0 -434
- package/skills/generating-mermaid-diagrams/references/mermaid-styling.md +0 -81
- package/skills/generating-mermaid-diagrams/references/preview-guide.md +0 -46
- package/skills/generating-mermaid-diagrams/references/usage-examples.md +0 -340
- package/skills/generating-mermaid-diagrams/scripts/README.md +0 -160
- package/skills/generating-mermaid-diagrams/scripts/mermaid_preview.py +0 -654
- package/skills/generating-mermaid-diagrams/scripts/query-org-metadata.py +0 -293
- package/skills/generating-permission-set/SKILL.md +0 -189
- package/skills/generating-ui-bundle-custom-app/SKILL.md +0 -93
- package/skills/generating-ui-bundle-custom-app/docs/configure-metadata-custom-application.md +0 -70
- package/skills/generating-ui-bundle-features/SKILL.md +0 -47
- package/skills/generating-ui-bundle-metadata/SKILL.md +0 -153
- package/skills/generating-ui-bundle-metadata/implementation/csp-metadata-format.md +0 -281
- package/skills/generating-ui-bundle-site/SKILL.md +0 -92
- package/skills/generating-ui-bundle-site/docs/configure-metadata-custom-site.md +0 -41
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience-bundle.md +0 -17
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience-config.md +0 -21
- package/skills/generating-ui-bundle-site/docs/configure-metadata-digital-experience.md +0 -40
- package/skills/generating-ui-bundle-site/docs/configure-metadata-network.md +0 -72
- package/skills/generating-ui-bundle-site/docs/update-site-urls.md +0 -100
- package/skills/generating-validation-rule/SKILL.md +0 -74
- package/skills/generating-visual-diagrams/CREDITS.md +0 -80
- package/skills/generating-visual-diagrams/README.md +0 -83
- package/skills/generating-visual-diagrams/SKILL.md +0 -207
- package/skills/generating-visual-diagrams/assets/architecture/integration-flow.md +0 -55
- package/skills/generating-visual-diagrams/assets/erd/core-objects.md +0 -131
- package/skills/generating-visual-diagrams/assets/erd/custom-objects.md +0 -60
- package/skills/generating-visual-diagrams/assets/lwc/dashboard-card.md +0 -45
- package/skills/generating-visual-diagrams/assets/lwc/data-table.md +0 -57
- package/skills/generating-visual-diagrams/assets/lwc/record-form.md +0 -60
- package/skills/generating-visual-diagrams/assets/review/apex-review.md +0 -57
- package/skills/generating-visual-diagrams/assets/review/lwc-review.md +0 -48
- package/skills/generating-visual-diagrams/references/architect-aesthetic-guide.md +0 -257
- package/skills/generating-visual-diagrams/references/examples-index.md +0 -35
- package/skills/generating-visual-diagrams/references/gemini-cli-setup.md +0 -65
- package/skills/generating-visual-diagrams/references/interview-questions.md +0 -529
- package/skills/generating-visual-diagrams/references/iteration-workflow.md +0 -173
- package/skills/generating-visual-diagrams/scripts/check-prerequisites.sh +0 -101
- package/skills/generating-visual-diagrams/scripts/generate_image.py +0 -243
- package/skills/getting-metadata-api-context/README.md +0 -79
- package/skills/getting-metadata-api-context/SKILL.md +0 -466
- package/skills/getting-metadata-api-context/data/metadata_api/AIApplication.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/AIApplicationConfig.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/AIReplyRecommendationsSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AIScoringModelDefinition.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/AIUsecaseDefinition.json +0 -215
- package/skills/getting-metadata-api-context/data/metadata_api/AccountInsightsSettings.json +0 -30
- package/skills/getting-metadata-api-context/data/metadata_api/AccountIntelligenceSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AccountPlanObjMeasCalcDef.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/AccountPlanSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AccountRelationshipShareRule.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/AccountSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingFieldMapping.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingModelConfig.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/AccountingSettings.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/ActionLinkGroupTemplate.json +0 -118
- package/skills/getting-metadata-api-context/data/metadata_api/ActionOverride.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/ActionPlanTemplate.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/ActionableListDefinition.json +0 -114
- package/skills/getting-metadata-api-context/data/metadata_api/ActionsSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatform.json +0 -95
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatformActvAttr.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ActivationPlatformField.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/ActivitiesSettings.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPfrmDataConnectorS3.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPlatformAdncIdentifier.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/ActvPlatformFieldValue.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/AddressSettings.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/AdvAccountForecastSet.json +0 -261
- package/skills/getting-metadata-api-context/data/metadata_api/AffinityScoreDefinition.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/AgentPlatformSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AgentforceForDevelopersSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AiAuthoringBundle.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/AiEvaluationDefinition.json +0 -153
- package/skills/getting-metadata-api-context/data/metadata_api/AiPluginUtteranceDef.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/AllOrNoneHeader.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticSnapshot.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsDashboard.json +0 -369
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsSettings.json +0 -488
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsVisualization.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/AnalyticsWorkspace.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/AnimationRule.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/ApexClass.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/ApexComponent.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/ApexEmailNotifications.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ApexPage.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ApexSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/ApexTestSuite.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ApexTrigger.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/AppAnalyticsSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/AppExperienceSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AppFrameworkTemplateBundle.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/AppMenu.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/AppointmentAssignmentPolicy.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/AppointmentSchedulingPolicy.json +0 -102
- package/skills/getting-metadata-api-context/data/metadata_api/ApprovalProcess.json +0 -234
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType_CustomField.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/ArticleType_Layout.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/AssessmentQuestion.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/AssessmentQuestionSet.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/AssignmentRules.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/AssociationEngineSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/AsyncResult.json +0 -89
- package/skills/getting-metadata-api-context/data/metadata_api/Audience.json +0 -172
- package/skills/getting-metadata-api-context/data/metadata_api/AuraDefinitionBundle.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/AuthProvider.json +0 -169
- package/skills/getting-metadata-api-context/data/metadata_api/AutoResponseRules.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/AutomatedContactsSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/BaseSharingRule.json +0 -24
- package/skills/getting-metadata-api-context/data/metadata_api/BatchCalcJobDefinition.json +0 -849
- package/skills/getting-metadata-api-context/data/metadata_api/BatchProcessJobDefinition.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/BillingSettings.json +0 -152
- package/skills/getting-metadata-api-context/data/metadata_api/BlacklistedConsumer.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/Bot.json +0 -197
- package/skills/getting-metadata-api-context/data/metadata_api/BotBlock.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/BotSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/BotTemplate.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/BotVersion.json +0 -667
- package/skills/getting-metadata-api-context/data/metadata_api/BranchManagementSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/BrandingSet.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/BriefcaseDefinition.json +0 -127
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessHoursSettings.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessProcess.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/BusinessProcessGroup.json +0 -91
- package/skills/getting-metadata-api-context/data/metadata_api/CMSConnectSource.json +0 -197
- package/skills/getting-metadata-api-context/data/metadata_api/CallCenter.json +0 -124
- package/skills/getting-metadata-api-context/data/metadata_api/CallCenterRoutingMap.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/CallCoachingMediaProvider.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/CallOptions.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/CampaignInfluenceModel.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/CampaignSettings.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/CancelDeployResult.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/CareBenefitVerifySettings.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/CareLimitType.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/CareProviderSearchConfig.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/CareRequestConfiguration.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/CareSystemFieldMapping.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/CaseSettings.json +0 -423
- package/skills/getting-metadata-api-context/data/metadata_api/CaseSubjectParticle.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApi.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApiArtifactVersionInfo.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/CatalogedApiVersion.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/Certificate.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/ChannelLayout.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterAnswersSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterEmailsMDSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterExtension.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ChatterSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/ChoiceList.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/ClaimFinancialSettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/ClauseCatgConfiguration.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/CleanDataService.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/CodeBuilderSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CollectionsDashboardSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CommerceSettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/CommunitiesSettings.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/Community.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/CommunityTemplateDefinition.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/CommunityThemeDefinition.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/CompactLayout.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CompanySettings.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ConnectedApp.json +0 -384
- package/skills/getting-metadata-api-context/data/metadata_api/ConnectedAppSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/ContentAsset.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ContentSettings.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/ContentTypeBundle.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/ContextDefinition.json +0 -340
- package/skills/getting-metadata-api-context/data/metadata_api/ContractSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ConvIntelligenceSignalRule.json +0 -106
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationChannelDefinition.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationMessageDefinition.json +0 -380
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationMessageDefinitionTranslation.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationVendorInfo.json +0 -148
- package/skills/getting-metadata-api-context/data/metadata_api/ConversationalIntelligenceSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/CorsWhitelistOrigin.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CriteriaBasedSharingRule.json +0 -206
- package/skills/getting-metadata-api-context/data/metadata_api/CspTrustedSite.json +0 -82
- package/skills/getting-metadata-api-context/data/metadata_api/CurrencySettings.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/CustomAddressFieldSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/CustomApplication.json +0 -453
- package/skills/getting-metadata-api-context/data/metadata_api/CustomApplicationComponent.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/CustomFeedFilter.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/CustomField.json +0 -392
- package/skills/getting-metadata-api-context/data/metadata_api/CustomFieldDisplay.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/CustomHelpMenuSection.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/CustomIndex.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/CustomLabels.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/CustomMetadata.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/CustomNotificationType.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/CustomObject.json +0 -313
- package/skills/getting-metadata-api-context/data/metadata_api/CustomObjectTranslation.json +0 -319
- package/skills/getting-metadata-api-context/data/metadata_api/CustomPageWebLink.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/CustomPermission.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/CustomSite.json +0 -288
- package/skills/getting-metadata-api-context/data/metadata_api/CustomTab.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/CustomValue.json +0 -85
- package/skills/getting-metadata-api-context/data/metadata_api/CustomerDataPlatformSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/Dashboard.json +0 -584
- package/skills/getting-metadata-api-context/data/metadata_api/DataCategoryGroup.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnector.json +0 -230
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnectorIngestApi.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/DataConnectorS3.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/DataDotComSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/DataImportManagementSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/DataKitObjectDependency.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/DataKitObjectTemplate.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/DataObjectBuildOrgTemplate.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/DataObjectSearchIndexConf.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/DataPackageKitDefinition.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/DataPackageKitObject.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/DataSource.json +0 -29
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceBundleDefinition.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceField.json +0 -115
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceObject.json +0 -93
- package/skills/getting-metadata-api-context/data/metadata_api/DataSourceTenant.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/DataSrcDataModelFieldMap.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/DataStreamDefinition.json +0 -105
- package/skills/getting-metadata-api-context/data/metadata_api/DataStreamTemplate.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/DataWeaveResource.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/DebuggingHeader.json +0 -20
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionMatrixDefinition.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionTable.json +0 -211
- package/skills/getting-metadata-api-context/data/metadata_api/DecisionTableDatasetLink.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/DelegateGroup.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/DeleteResult.json +0 -22
- package/skills/getting-metadata-api-context/data/metadata_api/DeployResult.json +0 -253
- package/skills/getting-metadata-api-context/data/metadata_api/DeploymentSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/DescribeMetadataResult.json +0 -31
- package/skills/getting-metadata-api-context/data/metadata_api/DescribeValueTypeResult.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/DevHubSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/DgtAssetMgmtProvider.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/DgtAssetMgmtPrvdLghtCpnt.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle.json +0 -102
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle_Marketing_Workspace_Bundle_and_Folders.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceBundle_Site_Workspace_Bundle_and_Folders.json +0 -541
- package/skills/getting-metadata-api-context/data/metadata_api/DigitalExperienceConfig.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureDefinition.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureDefinitionVersion.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/DisclosureType.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryAIModel.json +0 -263
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryGoal.json +0 -361
- package/skills/getting-metadata-api-context/data/metadata_api/DiscoveryStory.json +0 -98
- package/skills/getting-metadata-api-context/data/metadata_api/Document.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentCategory.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentCategoryDocumentType.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentChecklistSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentGenerationSetting.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/DocumentType.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/DuplicateRule.json +0 -160
- package/skills/getting-metadata-api-context/data/metadata_api/DynamicFormsSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EACSettings.json +0 -112
- package/skills/getting-metadata-api-context/data/metadata_api/EclairGeoData.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinAISettings.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinAgentSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/EinsteinGptSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/EmailAdministrationSettings.json +0 -104
- package/skills/getting-metadata-api-context/data/metadata_api/EmailAuthorizationSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmailIntegrationSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/EmailServicesFunction.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/EmailTemplate.json +0 -116
- package/skills/getting-metadata-api-context/data/metadata_api/EmailTemplateSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceBranding.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceConfig.json +0 -318
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceFieldService.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceFlowConfig.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceLiveAgent.json +0 -141
- package/skills/getting-metadata-api-context/data/metadata_api/EmbeddedServiceMenuSettings.json +0 -165
- package/skills/getting-metadata-api-context/data/metadata_api/EmployeeUserSettings.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/EnablementMeasureDefinition.json +0 -139
- package/skills/getting-metadata-api-context/data/metadata_api/EnablementProgramDefinition.json +0 -241
- package/skills/getting-metadata-api-context/data/metadata_api/EnblProgramTaskSubCategory.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/EncryptionKeySettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/EnhancedNotesSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementProcess.json +0 -147
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementSettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/EntitlementTemplate.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/Error.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/EscalationRules.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/EventDelivery.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/EventRelayConfig.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/EventSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/EventSubscription.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ExperienceBundle.json +0 -387
- package/skills/getting-metadata-api-context/data/metadata_api/ExperienceBundleSettings.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/ExperiencePropertyTypeBundle.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/ExplainabilityMsgTemplate.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetDefinition.json +0 -496
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetMessageToken.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/ExpressionSetObjectAlias.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalAIModel.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalAuthIdentityProvider.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalClientAppSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalClientApplication.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalCredential.json +0 -94
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataConnector.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataSource.json +0 -162
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTranObject.json +0 -191
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTransportFieldTemplate.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalDataTransportObjectTemplate.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalServiceRegistration.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ExternalServicesSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppCanvasSettings.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppConfigurablePolicies.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppGlobalOauthSettings.json +0 -135
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppMobileConfigurablePolicies.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppMobileSettings.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppNotificationSettings.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppOauthConfigurablePolicies.json +0 -153
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppOauthSettings.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppPushConfigurablePolicies.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppPushSettings.json +0 -93
- package/skills/getting-metadata-api-context/data/metadata_api/ExtlClntAppSamlConfigurablePolicies.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterBoolean.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterDate.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FeatureParameterInteger.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/FieldMappingConfig.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/FieldRestrictionRule.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/FieldServiceSettings.json +0 -226
- package/skills/getting-metadata-api-context/data/metadata_api/FieldSet.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/FieldSrcTrgtRelationship.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/FileUploadAndDownloadSecuritySettings.json +0 -53
- package/skills/getting-metadata-api-context/data/metadata_api/FilesConnectSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/FlexiPage.json +0 -355
- package/skills/getting-metadata-api-context/data/metadata_api/Flow.json +0 -2377
- package/skills/getting-metadata-api-context/data/metadata_api/FlowCategory.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/FlowDefinition.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/FlowSettings.json +0 -124
- package/skills/getting-metadata-api-context/data/metadata_api/FlowTest.json +0 -205
- package/skills/getting-metadata-api-context/data/metadata_api/FlowValueMap.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Folder.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/FolderShare.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingFilter.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingFilterCondition.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingObjectListSettings.json +0 -77
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingSettings.json +0 -303
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingSourceDefinition.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingType.json +0 -100
- package/skills/getting-metadata-api-context/data/metadata_api/ForecastingTypeSource.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/FuelType.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/FuelTypeSustnUom.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/FunctionReference.json +0 -31
- package/skills/getting-metadata-api-context/data/metadata_api/FundraisingConfig.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/GatewayProviderPaymentMethodType.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiFunction.json +0 -171
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlanner.json +0 -215
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlannerBundle.json +0 -220
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPlugin.json +0 -87
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPluginInstructionDef.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPromptTemplate.json +0 -183
- package/skills/getting-metadata-api-context/data/metadata_api/GenAiPromptTemplateActv.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GiftEntryGridTemplate.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalPicklist.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalPicklistValue.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalValueSet.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/GlobalValueSetTranslation.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/GoogleAppsSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/Group.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/HighVelocitySalesSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/HistoryRetentionPolicy.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/HomePageComponent.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/HomePageLayout.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/IPAddressRange.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/IdeasSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityProviderSettings.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcDef.json +0 -173
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcDtl.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/IdentityVerificationProcFld.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/IframeWhiteListUrlSettings.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/InboundCertificate.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/InboundNetworkConnection.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/IncidentMgmtSettings.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/Index.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesEinsteinFeatureSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesLoyaltySettings.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesPricingSettings.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesRatingSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesSettings.json +0 -731
- package/skills/getting-metadata-api-context/data/metadata_api/IndustriesUnifiedInventorySettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/InsPlcyLimitConsumptionRule.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/InstalledPackage.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/IntegArtifactDef.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/IntegrationProviderDef.json +0 -155
- package/skills/getting-metadata-api-context/data/metadata_api/InterestTaggingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/InternalDataConnector.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/InvLatePymntRiskCalcSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/InventorySettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/InvocableActionExtension.json +0 -84
- package/skills/getting-metadata-api-context/data/metadata_api/InvocableActionSettings.json +0 -28
- package/skills/getting-metadata-api-context/data/metadata_api/KeywordList.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/KnowledgeSettings.json +0 -280
- package/skills/getting-metadata-api-context/data/metadata_api/LanguageSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Layout.json +0 -659
- package/skills/getting-metadata-api-context/data/metadata_api/LeadConfigSettings.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/LeadConvertSettings.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/LearningItemType.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/Letterhead.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/LightningBolt.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/LightningComponentBundle.json +0 -109
- package/skills/getting-metadata-api-context/data/metadata_api/LightningExperienceSettings.json +0 -191
- package/skills/getting-metadata-api-context/data/metadata_api/LightningExperienceTheme.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/LightningMessageChannel.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/LightningOnboardingConfig.json +0 -62
- package/skills/getting-metadata-api-context/data/metadata_api/LightningTypeBundle.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/ListMetadataQuery.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/ListView.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/LiveAgentSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatAgentConfig.json +0 -188
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatButton.json +0 -188
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatDeployment.json +0 -81
- package/skills/getting-metadata-api-context/data/metadata_api/LiveChatSensitiveDataRule.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/LiveMessageSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/LoyaltyProgramSetup.json +0 -297
- package/skills/getting-metadata-api-context/data/metadata_api/MLDataDefinition.json +0 -146
- package/skills/getting-metadata-api-context/data/metadata_api/MLPredictionDefinition.json +0 -67
- package/skills/getting-metadata-api-context/data/metadata_api/MacroSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MailMergeSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedContentType.json +0 -86
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedEventSubscription.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/ManagedTopics.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/MapAndLocationSettings.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/MarketSegmentDefinition.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/MarketingAppExtension.json +0 -139
- package/skills/getting-metadata-api-context/data/metadata_api/MatchingRule.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/MeetingsSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MessagingChannel.json +0 -278
- package/skills/getting-metadata-api-context/data/metadata_api/MetadataWithContent.json +0 -24
- package/skills/getting-metadata-api-context/data/metadata_api/Metadata_Type_Limits.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/MfgProgramTemplate.json +0 -88
- package/skills/getting-metadata-api-context/data/metadata_api/MfgServiceConsoleSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/MilestoneType.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/MktCalcInsightObjectDef.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/MktDataTranObject.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/MlDomain.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/MobSecurityCertPinConfig.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/MobileApplicationDetail.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSecurityAssignment.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSecurityPolicy.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/MobileSettings.json +0 -121
- package/skills/getting-metadata-api-context/data/metadata_api/ModerationRule.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/MutingPermissionSet.json +0 -33
- package/skills/getting-metadata-api-context/data/metadata_api/MyDomainDiscoverableLogin.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/MyDomainSettings.json +0 -140
- package/skills/getting-metadata-api-context/data/metadata_api/NameSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/NamedCredential.json +0 -205
- package/skills/getting-metadata-api-context/data/metadata_api/NamedFilter.json +0 -89
- package/skills/getting-metadata-api-context/data/metadata_api/NavigationMenu.json +0 -101
- package/skills/getting-metadata-api-context/data/metadata_api/Network.json +0 -606
- package/skills/getting-metadata-api-context/data/metadata_api/NetworkBranding.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/NotificationTypeConfig.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/NotificationsSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/OauthCustomScope.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/OauthOidcSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/OauthTokenExchangeHandler.json +0 -119
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectHierarchyRelationship.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectLinkingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ObjectSourceTargetMap.json +0 -85
- package/skills/getting-metadata-api-context/data/metadata_api/OcrSampleDocument.json +0 -158
- package/skills/getting-metadata-api-context/data/metadata_api/OcrTemplate.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/OmniChannelSettings.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/OmniExtTrackingDef.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/OmniInteractionAccessConfig.json +0 -90
- package/skills/getting-metadata-api-context/data/metadata_api/OmniInteractionConfig.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/OmniScript.json +0 -204
- package/skills/getting-metadata-api-context/data/metadata_api/OmniSupervisorConfig.json +0 -156
- package/skills/getting-metadata-api-context/data/metadata_api/OmniTrackingGroup.json +0 -77
- package/skills/getting-metadata-api-context/data/metadata_api/OnboardingDataObjectGroup.json +0 -131
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunityInsightsSettings.json +0 -30
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunityScoreSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/OpportunitySettings.json +0 -132
- package/skills/getting-metadata-api-context/data/metadata_api/OrchestrationPlanCtxMapping.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/OrderManagementSettings.json +0 -52
- package/skills/getting-metadata-api-context/data/metadata_api/OrderSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/OrgPreferenceSettings.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/OrgSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/OutboundNetworkConnection.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/OwnerSharingRule.json +0 -206
- package/skills/getting-metadata-api-context/data/metadata_api/Package.json +0 -19
- package/skills/getting-metadata-api-context/data/metadata_api/PardotEinsteinSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/PardotSettings.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ParticipantRole.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PartyDataModelSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/PathAssistant.json +0 -74
- package/skills/getting-metadata-api-context/data/metadata_api/PathAssistantSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/PaymentGatewayProvider.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/PaymentsSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSet.json +0 -372
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSetGroup.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/PermissionSetLicenseDefinition.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/PersonAccountOwnerPowerUser.json +0 -38
- package/skills/getting-metadata-api-context/data/metadata_api/Picklist.json +0 -43
- package/skills/getting-metadata-api-context/data/metadata_api/PicklistSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PipelineInspMetricConfig.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformCachePartition.json +0 -79
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEncryptionSettings.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventChannel.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventChannelMember.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventMigration.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PlatformEventSubscriberConfig.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/Portal.json +0 -137
- package/skills/getting-metadata-api-context/data/metadata_api/PortalDelegablePermissionSet.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/PostTemplate.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/PredictionBuilderSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/PresenceDeclineReason.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/PresenceUserConfig.json +0 -122
- package/skills/getting-metadata-api-context/data/metadata_api/PricingActionParameters.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/PricingRecipe.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/PrivacySettings.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/ProcessFlowMigration.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/ProductAttributeSet.json +0 -33
- package/skills/getting-metadata-api-context/data/metadata_api/ProductSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/Profile.json +0 -492
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileActionOverride.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ProfilePasswordPolicy.json +0 -80
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileSearchLayouts.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/ProfileSessionSetting.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/Prompt.json +0 -255
- package/skills/getting-metadata-api-context/data/metadata_api/PublicKeyCertificate.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/PublicKeyCertificateSet.json +0 -65
- package/skills/getting-metadata-api-context/data/metadata_api/Queue.json +0 -123
- package/skills/getting-metadata-api-context/data/metadata_api/QueueRoutingConfig.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/QuickAction.json +0 -175
- package/skills/getting-metadata-api-context/data/metadata_api/QuoteSettings.json +0 -36
- package/skills/getting-metadata-api-context/data/metadata_api/ReadResult.json +0 -16
- package/skills/getting-metadata-api-context/data/metadata_api/RealTimeEventSettings.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/RecommendationStrategy.json +0 -327
- package/skills/getting-metadata-api-context/data/metadata_api/RecordActionDeployment.json +0 -184
- package/skills/getting-metadata-api-context/data/metadata_api/RecordAggregationDefinition.json +0 -148
- package/skills/getting-metadata-api-context/data/metadata_api/RecordAlertCategory.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/RecordPageSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/RecordType.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/RedirectWhitelistUrl.json +0 -26
- package/skills/getting-metadata-api-context/data/metadata_api/ReferencedDashboard.json +0 -55
- package/skills/getting-metadata-api-context/data/metadata_api/RegisteredExternalService.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/RelatedRecordAssocCriteria.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/RelationshipGraphDefinition.json +0 -63
- package/skills/getting-metadata-api-context/data/metadata_api/RemoteSiteSetting.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/Report.json +0 -715
- package/skills/getting-metadata-api-context/data/metadata_api/ReportType.json +0 -118
- package/skills/getting-metadata-api-context/data/metadata_api/RestrictionRule.json +0 -71
- package/skills/getting-metadata-api-context/data/metadata_api/RetailExecutionSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/RetrievalSummaryDefinition.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/RetrieveRequest.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/RetrieveResult.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/Role.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/RoleOrTerritory.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/SalesAgreementSettings.json +0 -180
- package/skills/getting-metadata-api-context/data/metadata_api/SalesWorkQueueSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/SamlSsoConfig.json +0 -128
- package/skills/getting-metadata-api-context/data/metadata_api/SandboxSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/SaveResult.json +0 -22
- package/skills/getting-metadata-api-context/data/metadata_api/SchedulingObjective.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/SchedulingRule.json +0 -66
- package/skills/getting-metadata-api-context/data/metadata_api/SchemaSettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/Scontrol.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/SearchCustomization.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/SearchLayouts.json +0 -64
- package/skills/getting-metadata-api-context/data/metadata_api/SearchOrgWideObjectConfig.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SearchSettings.json +0 -155
- package/skills/getting-metadata-api-context/data/metadata_api/SecuritySettings.json +0 -437
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceAISetupDefinition.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceAISetupField.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceChannel.json +0 -123
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceCloudVoiceSettings.json +0 -83
- package/skills/getting-metadata-api-context/data/metadata_api/ServicePresenceStatus.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceProcess.json +0 -141
- package/skills/getting-metadata-api-context/data/metadata_api/ServiceSetupAssistantSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/SessionHeader.json +0 -17
- package/skills/getting-metadata-api-context/data/metadata_api/SharedTo.json +0 -105
- package/skills/getting-metadata-api-context/data/metadata_api/SharingBaseRule.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/SharingReason.json +0 -34
- package/skills/getting-metadata-api-context/data/metadata_api/SharingRecalculation.json +0 -29
- package/skills/getting-metadata-api-context/data/metadata_api/SharingRules.json +0 -186
- package/skills/getting-metadata-api-context/data/metadata_api/SharingSet.json +0 -78
- package/skills/getting-metadata-api-context/data/metadata_api/SharingSettings.json +0 -92
- package/skills/getting-metadata-api-context/data/metadata_api/SiteDotCom.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/SiteSettings.json +0 -60
- package/skills/getting-metadata-api-context/data/metadata_api/Skill.json +0 -69
- package/skills/getting-metadata-api-context/data/metadata_api/SocialCustomerServiceSettings.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SocialProfileSettings.json +0 -35
- package/skills/getting-metadata-api-context/data/metadata_api/SourceTrackingSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/StageAssignment.json +0 -113
- package/skills/getting-metadata-api-context/data/metadata_api/StageDefinition.json +0 -237
- package/skills/getting-metadata-api-context/data/metadata_api/StandardValueSet.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/StandardValueSetTranslation.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/StaticResource.json +0 -49
- package/skills/getting-metadata-api-context/data/metadata_api/StreamingAppDataConnector.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/SubscriptionManagementSettings.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/SurveySettings.json +0 -44
- package/skills/getting-metadata-api-context/data/metadata_api/SustainabilityUom.json +0 -61
- package/skills/getting-metadata-api-context/data/metadata_api/SustnUomConversion.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogCategory.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogFulfillmentFlow.json +0 -99
- package/skills/getting-metadata-api-context/data/metadata_api/SvcCatalogItemDef.json +0 -202
- package/skills/getting-metadata-api-context/data/metadata_api/SynonymDictionary.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/Tag.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/TagSet.json +0 -47
- package/skills/getting-metadata-api-context/data/metadata_api/Territory.json +0 -39
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2.json +0 -112
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Model.json +0 -41
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Rule.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Settings.json +0 -111
- package/skills/getting-metadata-api-context/data/metadata_api/Territory2Type.json +0 -42
- package/skills/getting-metadata-api-context/data/metadata_api/TimeSheetTemplate.json +0 -75
- package/skills/getting-metadata-api-context/data/metadata_api/TimelineObjectDefinition.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/TopicsForObjects.json +0 -38
- package/skills/getting-metadata-api-context/data/metadata_api/TrailheadSettings.json +0 -40
- package/skills/getting-metadata-api-context/data/metadata_api/TransactionSecurityPolicy.json +0 -127
- package/skills/getting-metadata-api-context/data/metadata_api/Translations.json +0 -976
- package/skills/getting-metadata-api-context/data/metadata_api/TrialOrgSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/UIBundle.json +0 -54
- package/skills/getting-metadata-api-context/data/metadata_api/UIObjectRelationConfig.json +0 -101
- package/skills/getting-metadata-api-context/data/metadata_api/UiFormatSpecificationSet.json +0 -103
- package/skills/getting-metadata-api-context/data/metadata_api/UiPreviewMessageTabDef.json +0 -70
- package/skills/getting-metadata-api-context/data/metadata_api/UpsertResult.json +0 -25
- package/skills/getting-metadata-api-context/data/metadata_api/UserAccessPolicy.json +0 -120
- package/skills/getting-metadata-api-context/data/metadata_api/UserAuthCertificate.json +0 -57
- package/skills/getting-metadata-api-context/data/metadata_api/UserCriteria.json +0 -48
- package/skills/getting-metadata-api-context/data/metadata_api/UserEngagementSettings.json +0 -136
- package/skills/getting-metadata-api-context/data/metadata_api/UserInterfaceSettings.json +0 -96
- package/skills/getting-metadata-api-context/data/metadata_api/UserManagementSettings.json +0 -108
- package/skills/getting-metadata-api-context/data/metadata_api/UserProfileSearchScope.json +0 -8
- package/skills/getting-metadata-api-context/data/metadata_api/UserProvisioningConfig.json +0 -72
- package/skills/getting-metadata-api-context/data/metadata_api/ValidationRule.json +0 -51
- package/skills/getting-metadata-api-context/data/metadata_api/VirtualVisitConfig.json +0 -97
- package/skills/getting-metadata-api-context/data/metadata_api/VoiceSettings.json +0 -68
- package/skills/getting-metadata-api-context/data/metadata_api/WarrantyLifeCycleMgmtSettings.json +0 -32
- package/skills/getting-metadata-api-context/data/metadata_api/WaveAnalyticAssetCollection.json +0 -73
- package/skills/getting-metadata-api-context/data/metadata_api/WaveApplication.json +0 -56
- package/skills/getting-metadata-api-context/data/metadata_api/WaveComponent.json +0 -46
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDashboard.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDataflow.json +0 -45
- package/skills/getting-metadata-api-context/data/metadata_api/WaveDataset.json +0 -50
- package/skills/getting-metadata-api-context/data/metadata_api/WaveLens.json +0 -59
- package/skills/getting-metadata-api-context/data/metadata_api/WaveRecipe.json +0 -58
- package/skills/getting-metadata-api-context/data/metadata_api/WaveTemplateBundle.json +0 -37
- package/skills/getting-metadata-api-context/data/metadata_api/WaveXmd.json +0 -567
- package/skills/getting-metadata-api-context/data/metadata_api/WebLink.json +0 -117
- package/skills/getting-metadata-api-context/data/metadata_api/WebStoreBundle.json +0 -10
- package/skills/getting-metadata-api-context/data/metadata_api/WebStoreTemplate.json +0 -166
- package/skills/getting-metadata-api-context/data/metadata_api/WorkDotComSettings.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/WorkSkillRouting.json +0 -76
- package/skills/getting-metadata-api-context/data/metadata_api/Workflow.json +0 -415
- package/skills/getting-metadata-api-context/data/metadata_api/WorkforceEngagementSettings.json +0 -56
- package/skills/getting-metadata-api-context/examples/README.md +0 -169
- package/skills/getting-metadata-api-context/examples/bash_section_loading.sh +0 -142
- package/skills/getting-metadata-api-context/examples/javascript_section_loading.js +0 -162
- package/skills/getting-metadata-api-context/examples/python_section_loading.py +0 -112
- package/skills/getting-metadata-api-context/references/metadata_index_table.md +0 -654
- package/skills/getting-metadata-api-context/references/usage_guide.md +0 -420
- package/skills/handling-sf-data/CREDITS.md +0 -5
- package/skills/handling-sf-data/README.md +0 -112
- package/skills/handling-sf-data/SKILL.md +0 -234
- package/skills/handling-sf-data/assets/bulk/bulk-insert-10000.apex +0 -293
- package/skills/handling-sf-data/assets/bulk/bulk-insert-200.apex +0 -208
- package/skills/handling-sf-data/assets/bulk/bulk-insert-500.apex +0 -219
- package/skills/handling-sf-data/assets/bulk/bulk-upsert-external-id.apex +0 -324
- package/skills/handling-sf-data/assets/cleanup/delete-by-created-date.apex +0 -319
- package/skills/handling-sf-data/assets/cleanup/delete-by-name.apex +0 -240
- package/skills/handling-sf-data/assets/cleanup/delete-test-data.apex +0 -311
- package/skills/handling-sf-data/assets/cleanup/rollback-transaction.apex +0 -266
- package/skills/handling-sf-data/assets/csv/account-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/contact-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/custom-object-import.csv +0 -11
- package/skills/handling-sf-data/assets/csv/opportunity-import.csv +0 -11
- package/skills/handling-sf-data/assets/factories/account-factory.apex +0 -165
- package/skills/handling-sf-data/assets/factories/case-factory.apex +0 -237
- package/skills/handling-sf-data/assets/factories/contact-factory.apex +0 -168
- package/skills/handling-sf-data/assets/factories/custom-object-factory.apex +0 -260
- package/skills/handling-sf-data/assets/factories/event-factory.apex +0 -275
- package/skills/handling-sf-data/assets/factories/hierarchy-factory.apex +0 -372
- package/skills/handling-sf-data/assets/factories/lead-factory.apex +0 -190
- package/skills/handling-sf-data/assets/factories/opportunity-factory.apex +0 -206
- package/skills/handling-sf-data/assets/factories/task-factory.apex +0 -246
- package/skills/handling-sf-data/assets/factories/user-factory.apex +0 -278
- package/skills/handling-sf-data/assets/json/account-contact-tree.json +0 -130
- package/skills/handling-sf-data/assets/json/account-opportunity-tree.json +0 -110
- package/skills/handling-sf-data/assets/json/full-hierarchy-tree.json +0 -188
- package/skills/handling-sf-data/assets/soql/aggregate.soql +0 -226
- package/skills/handling-sf-data/assets/soql/child-to-parent.soql +0 -162
- package/skills/handling-sf-data/assets/soql/parent-to-child.soql +0 -153
- package/skills/handling-sf-data/assets/soql/polymorphic.soql +0 -198
- package/skills/handling-sf-data/assets/soql/subquery.soql +0 -287
- package/skills/handling-sf-data/references/anonymous-apex-guide.md +0 -98
- package/skills/handling-sf-data/references/bulk-operations-guide.md +0 -94
- package/skills/handling-sf-data/references/bulk-testing-example.md +0 -194
- package/skills/handling-sf-data/references/cleanup-rollback-example.md +0 -322
- package/skills/handling-sf-data/references/cleanup-rollback-guide.md +0 -84
- package/skills/handling-sf-data/references/crud-workflow-example.md +0 -183
- package/skills/handling-sf-data/references/governor-limits-reference.md +0 -74
- package/skills/handling-sf-data/references/orchestration.md +0 -174
- package/skills/handling-sf-data/references/relationship-query-examples.md +0 -249
- package/skills/handling-sf-data/references/sf-cli-data-commands.md +0 -158
- package/skills/handling-sf-data/references/soql-relationship-guide.md +0 -84
- package/skills/handling-sf-data/references/test-data-best-practices.md +0 -104
- package/skills/handling-sf-data/references/test-data-factory-usage.md +0 -290
- package/skills/handling-sf-data/references/test-data-patterns.md +0 -98
- package/skills/handling-sf-data/scripts/soql_validator.py +0 -292
- package/skills/handling-sf-data/scripts/validate_data_operation.py +0 -379
- package/skills/harmonizing-datacloud/CREDITS.md +0 -3
- package/skills/harmonizing-datacloud/README.md +0 -31
- package/skills/harmonizing-datacloud/SKILL.md +0 -116
- package/skills/implementing-ui-bundle-agentforce-conversation-client/SKILL.md +0 -280
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/agent-id-resolution.md +0 -46
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/constraints.md +0 -134
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/examples.md +0 -132
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/style-tokens.md +0 -260
- package/skills/implementing-ui-bundle-agentforce-conversation-client/references/troubleshooting.md +0 -57
- package/skills/implementing-ui-bundle-file-upload/SKILL.md +0 -398
- package/skills/integrating-b2b-commerce-open-code-components/SKILL.md +0 -165
- package/skills/investigating-agentforce-architecture/README.md +0 -156
- package/skills/investigating-agentforce-architecture/SKILL.md +0 -230
- package/skills/investigating-agentforce-architecture/assets/cli/describe_sobject.yaml +0 -16
- package/skills/investigating-agentforce-architecture/assets/cli/describe_tooling_sobject.yaml +0 -17
- package/skills/investigating-agentforce-architecture/assets/cli/list_metadata_genaiprompttemplate.yaml +0 -17
- package/skills/investigating-agentforce-architecture/assets/cli/org_display.yaml +0 -15
- package/skills/investigating-agentforce-architecture/assets/cli/retrieve_genai_plugin.yaml +0 -18
- package/skills/investigating-agentforce-architecture/assets/cli/show_access_token.yaml +0 -27
- package/skills/investigating-agentforce-architecture/assets/mermaid/action_tree.mmd +0 -20
- package/skills/investigating-agentforce-architecture/assets/mermaid/data_flow.mmd +0 -19
- package/skills/investigating-agentforce-architecture/assets/mermaid/dependency_graph.mmd +0 -19
- package/skills/investigating-agentforce-architecture/assets/mermaid/invocation_sequence.mmd +0 -20
- package/skills/investigating-agentforce-architecture/assets/mermaid/planner_state.mmd +0 -18
- package/skills/investigating-agentforce-architecture/assets/soql/apex_class_bodies_by_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/apex_class_bodies_by_names.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/bot_definition_details.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/bot_version_lookup.soql +0 -4
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_by_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_ids_by_names.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/flow_definition_view_by_durable_ids.soql +0 -4
- package/skills/investigating-agentforce-architecture/assets/soql/flow_metadata_by_id.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/functions_by_plugins.soql +0 -5
- package/skills/investigating-agentforce-architecture/assets/soql/planner_attrs_by_parent_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/planner_bundle_functions.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/planner_definition_by_agent_chain.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugin_functions_by_plugin_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugin_instructions_by_plugin_ids.soql +0 -3
- package/skills/investigating-agentforce-architecture/assets/soql/plugins_by_planner.soql +0 -4
- package/skills/investigating-agentforce-architecture/references/architecture_sections.md +0 -243
- package/skills/investigating-agentforce-architecture/references/contract.json +0 -244
- package/skills/investigating-agentforce-architecture/references/soql_fields.md +0 -512
- package/skills/investigating-agentforce-architecture/scripts/_shared/__init__.py +0 -1
- package/skills/investigating-agentforce-architecture/scripts/_shared/fs_guard.py +0 -329
- package/skills/investigating-agentforce-architecture/scripts/_shared/paths.py +0 -110
- package/skills/investigating-agentforce-architecture/scripts/_shared/runtime.py +0 -59
- package/skills/investigating-agentforce-architecture/scripts/_shared/sql.py +0 -10
- package/skills/investigating-agentforce-architecture/scripts/cache_check.py +0 -234
- package/skills/investigating-agentforce-architecture/scripts/config.py +0 -131
- package/skills/investigating-agentforce-architecture/scripts/fetch_soql.py +0 -689
- package/skills/investigating-agentforce-architecture/scripts/finalize.py +0 -295
- package/skills/investigating-agentforce-architecture/scripts/main.py +0 -2835
- package/skills/investigating-agentforce-architecture/scripts/metadata_listing.py +0 -265
- package/skills/investigating-agentforce-architecture/scripts/parallel_retrieve.py +0 -69
- package/skills/investigating-agentforce-architecture/scripts/parse_bundle.py +0 -215
- package/skills/investigating-agentforce-architecture/scripts/parse_wave.py +0 -845
- package/skills/investigating-agentforce-architecture/scripts/probe_channels.py +0 -302
- package/skills/investigating-agentforce-architecture/scripts/render_architecture.py +0 -1043
- package/skills/investigating-agentforce-architecture/scripts/resolve_bot.py +0 -255
- package/skills/investigating-agentforce-architecture/scripts/resolve_invocation_target.py +0 -130
- package/skills/investigating-agentforce-architecture/scripts/rest_client.py +0 -763
- package/skills/investigating-agentforce-architecture/scripts/retrieve_planner.py +0 -13
- package/skills/investigating-agentforce-architecture/scripts/sf_cli.py +0 -242
- package/skills/investigating-agentforce-architecture/scripts/soql_loader.py +0 -253
- package/skills/investigating-agentforce-architecture/scripts/summarize_tree.py +0 -143
- package/skills/investigating-agentforce-architecture/scripts/tests/__init__.py +0 -0
- package/skills/investigating-agentforce-architecture/scripts/tests/_bootstrap.py +0 -23
- package/skills/investigating-agentforce-architecture/scripts/tests/fixtures/__init__.py +0 -0
- package/skills/investigating-agentforce-architecture/scripts/tests/fixtures/genai_payloads.py +0 -400
- package/skills/investigating-agentforce-architecture/scripts/tests/test_cache_check.py +0 -307
- package/skills/investigating-agentforce-architecture/scripts/tests/test_cache_check_main.py +0 -283
- package/skills/investigating-agentforce-architecture/scripts/tests/test_config.py +0 -115
- package/skills/investigating-agentforce-architecture/scripts/tests/test_end_to_end_fixture.py +0 -651
- package/skills/investigating-agentforce-architecture/scripts/tests/test_finalize.py +0 -278
- package/skills/investigating-agentforce-architecture/scripts/tests/test_flow_children_inflation.py +0 -582
- package/skills/investigating-agentforce-architecture/scripts/tests/test_fs_guard.py +0 -113
- package/skills/investigating-agentforce-architecture/scripts/tests/test_iterative_wave_b.py +0 -478
- package/skills/investigating-agentforce-architecture/scripts/tests/test_main_pipeline.py +0 -3359
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parallel_retrieve.py +0 -131
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_bundle.py +0 -400
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave.py +0 -644
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_classifiers.py +0 -224
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_helpers.py +0 -380
- package/skills/investigating-agentforce-architecture/scripts/tests/test_parse_wave_main.py +0 -397
- package/skills/investigating-agentforce-architecture/scripts/tests/test_per_branch_visited.py +0 -244
- package/skills/investigating-agentforce-architecture/scripts/tests/test_probe_channels.py +0 -359
- package/skills/investigating-agentforce-architecture/scripts/tests/test_probe_cli_recipes.py +0 -185
- package/skills/investigating-agentforce-architecture/scripts/tests/test_render_architecture.py +0 -810
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_bot.py +0 -203
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_creds.py +0 -157
- package/skills/investigating-agentforce-architecture/scripts/tests/test_resolve_invocation_target.py +0 -145
- package/skills/investigating-agentforce-architecture/scripts/tests/test_rest_client.py +0 -1253
- package/skills/investigating-agentforce-architecture/scripts/tests/test_runtime_override.py +0 -100
- package/skills/investigating-agentforce-architecture/scripts/tests/test_sf_cli.py +0 -261
- package/skills/investigating-agentforce-architecture/scripts/tests/test_signature_stamping.py +0 -466
- package/skills/investigating-agentforce-architecture/scripts/tests/test_soql_loader.py +0 -501
- package/skills/investigating-agentforce-architecture/scripts/tests/test_summarize_tree.py +0 -241
- package/skills/investigating-agentforce-architecture/scripts/tests/test_write_emit_ctx.py +0 -480
- package/skills/investigating-agentforce-architecture/tools/emit_env.py +0 -157
- package/skills/investigating-agentforce-architecture/tools/emit_result.py +0 -262
- package/skills/investigating-agentforce-architecture/tools/sanitize.py +0 -33
- package/skills/investigating-agentforce-architecture/tools/write_emit_ctx.py +0 -332
- package/skills/investigating-agentforce-d360/README.md +0 -123
- package/skills/investigating-agentforce-d360/SKILL.md +0 -163
- package/skills/investigating-agentforce-d360/assets/dc/app_generation.sql +0 -51
- package/skills/investigating-agentforce-d360/assets/dc/content_category.sql +0 -44
- package/skills/investigating-agentforce-d360/assets/dc/content_quality.sql +0 -41
- package/skills/investigating-agentforce-d360/assets/dc/discover_sessions.sql +0 -36
- package/skills/investigating-agentforce-d360/assets/dc/feedback.sql +0 -47
- package/skills/investigating-agentforce-d360/assets/dc/feedback_details.sql +0 -38
- package/skills/investigating-agentforce-d360/assets/dc/gateway_records.sql +0 -45
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_llm.sql +0 -50
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_metadata.sql +0 -44
- package/skills/investigating-agentforce-d360/assets/dc/gateway_request_tags.sql +0 -42
- package/skills/investigating-agentforce-d360/assets/dc/gateway_requests.sql +0 -89
- package/skills/investigating-agentforce-d360/assets/dc/gateway_responses.sql +0 -43
- package/skills/investigating-agentforce-d360/assets/dc/generations.sql +0 -52
- package/skills/investigating-agentforce-d360/assets/dc/interactions.sql +0 -53
- package/skills/investigating-agentforce-d360/assets/dc/messages.sql +0 -53
- package/skills/investigating-agentforce-d360/assets/dc/messaging_session.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/moment_interactions.sql +0 -34
- package/skills/investigating-agentforce-d360/assets/dc/moments.sql +0 -39
- package/skills/investigating-agentforce-d360/assets/dc/participants.sql +0 -48
- package/skills/investigating-agentforce-d360/assets/dc/sessions.sql +0 -78
- package/skills/investigating-agentforce-d360/assets/dc/steps.sql +0 -64
- package/skills/investigating-agentforce-d360/assets/dc/tag_associations.sql +0 -46
- package/skills/investigating-agentforce-d360/assets/dc/tag_definition_associations.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/tag_definitions.sql +0 -50
- package/skills/investigating-agentforce-d360/assets/dc/tags.sql +0 -37
- package/skills/investigating-agentforce-d360/assets/dc/telemetry_spans.sql +0 -55
- package/skills/investigating-agentforce-d360/references/artifacts.md +0 -50
- package/skills/investigating-agentforce-d360/references/dc_dmo_fields.md +0 -823
- package/skills/investigating-agentforce-d360/references/dc_pipeline_contract.md +0 -608
- package/skills/investigating-agentforce-d360/scripts/_shared/__init__.py +0 -2
- package/skills/investigating-agentforce-d360/scripts/_shared/cli_override.py +0 -98
- package/skills/investigating-agentforce-d360/scripts/_shared/fs_guard.py +0 -334
- package/skills/investigating-agentforce-d360/scripts/_shared/paths.py +0 -155
- package/skills/investigating-agentforce-d360/scripts/_shared/runtime.py +0 -59
- package/skills/investigating-agentforce-d360/scripts/_shared/sql.py +0 -14
- package/skills/investigating-agentforce-d360/scripts/assemble_dc.py +0 -1624
- package/skills/investigating-agentforce-d360/scripts/config.py +0 -45
- package/skills/investigating-agentforce-d360/scripts/dc.py +0 -188
- package/skills/investigating-agentforce-d360/scripts/discover_sessions.py +0 -556
- package/skills/investigating-agentforce-d360/scripts/fetch_dc.py +0 -1045
- package/skills/investigating-agentforce-d360/scripts/render_dc.py +0 -1750
- package/skills/investigating-agentforce-d360/scripts/resolve_session.py +0 -264
- package/skills/investigating-agentforce-d360/scripts/storage.py +0 -92
- package/skills/investigating-agentforce-d360/scripts/tests/__init__.py +0 -0
- package/skills/investigating-agentforce-d360/scripts/tests/_bootstrap.py +0 -15
- package/skills/investigating-agentforce-d360/scripts/tests/fixtures/__init__.py +0 -0
- package/skills/investigating-agentforce-d360/scripts/tests/fixtures/synthetic_session.py +0 -424
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_bootstrap_and_mode.py +0 -115
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_gateway_direct.py +0 -220
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_gateway_direct_integration.py +0 -158
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_helpers.py +0 -287
- package/skills/investigating-agentforce-d360/scripts/tests/test_assemble_dc_integration.py +0 -247
- package/skills/investigating-agentforce-d360/scripts/tests/test_dc_and_resolve_session.py +0 -433
- package/skills/investigating-agentforce-d360/scripts/tests/test_discover_sessions.py +0 -458
- package/skills/investigating-agentforce-d360/scripts/tests/test_discover_sessions_grep_ci.py +0 -193
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_helpers.py +0 -266
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_identity.py +0 -528
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_main.py +0 -251
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_waterfall.py +0 -229
- package/skills/investigating-agentforce-d360/scripts/tests/test_fetch_dc_waterfall_full.py +0 -283
- package/skills/investigating-agentforce-d360/scripts/tests/test_identity_coherence.py +0 -327
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_branches.py +0 -256
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_gateway_direct.py +0 -130
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_helpers.py +0 -291
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_integration.py +0 -220
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_planner_llm_calls.py +0 -284
- package/skills/investigating-agentforce-d360/scripts/tests/test_render_dc_show_prompts_gating.py +0 -215
- package/skills/investigating-agentforce-d360/scripts/tests/test_resolve_from_disk.py +0 -100
- package/skills/investigating-agentforce-d360/scripts/tests/test_resolve_session_main.py +0 -149
- package/skills/investigating-agentforce-d360/scripts/tests/test_runtime_override.py +0 -104
- package/skills/investigating-agentforce-d360/scripts/tests/test_session_shape.py +0 -95
- package/skills/investigating-agentforce-d360/scripts/tests/test_session_shape_dropped_by_stdm.py +0 -85
- package/skills/managing-cdc-enablement/SKILL.md +0 -164
- package/skills/managing-cdc-enablement/assets/PlatformEventChannel-template.xml +0 -5
- package/skills/managing-cdc-enablement/assets/PlatformEventChannelMember-template.xml +0 -11
- package/skills/managing-cdc-enablement/references/deploy-troubleshooting.md +0 -73
- package/skills/managing-cdc-enablement/references/filter-expressions.md +0 -93
- package/skills/managing-managed-event-subscription/SKILL.md +0 -152
- package/skills/managing-managed-event-subscription/assets/managed-event-subscription-template.xml +0 -20
- package/skills/managing-managed-event-subscription/references/delete-guide.md +0 -57
- package/skills/managing-managed-event-subscription/references/topic-name-formats.md +0 -26
- package/skills/managing-managed-event-subscription/references/update-constraints.md +0 -30
- package/skills/modeling-omnistudio-epc-catalog/CREDITS.md +0 -14
- package/skills/modeling-omnistudio-epc-catalog/README.md +0 -89
- package/skills/modeling-omnistudio-epc-catalog/SKILL.md +0 -394
- package/skills/modeling-omnistudio-epc-catalog/assets/attribute-assignment-template.json +0 -402
- package/skills/modeling-omnistudio-epc-catalog/assets/compiled-attribute-overrides-template.json +0 -43
- package/skills/modeling-omnistudio-epc-catalog/assets/completion-block-template.txt +0 -8
- package/skills/modeling-omnistudio-epc-catalog/assets/decomposition-relationships-template.json +0 -233
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_AttributeAssignments.json +0 -514
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_CompiledAttributeOverrides.json +0 -21
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DataPack.json +0 -649
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_DecompositionRelationships.json +0 -200
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ObjectFieldAttributes.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OrchestrationScenarios.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_OverrideDefinitions.json +0 -266
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ParentKeys.json +0 -23
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PriceListEntries.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_ProductChildItems.json +0 -34
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-premium-fttc-simple-offer/Business-Internet-Premium-FTTC_RuleAssignments.json +0 -21
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_AttributeAssignments.json +0 -410
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DataPack.json +0 -535
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ObjectFieldAttributes.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_OrchestrationScenarios.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ParentKeys.json +0 -23
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PriceListEntries.json +0 -220
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/business-internet-pro-vpl-simple-offer/Business-Internet-Pro-VPL_ProductChildItems.json +0 -414
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_AttributeAssignments.json +0 -382
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DataPack.json +0 -565
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ObjectFieldAttributes.json +0 -104
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_OrchestrationScenarios.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ParentKeys.json +0 -13
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PriceListEntries.json +0 -106
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/samsung-galaxy-s22-bundle/Samsung-Galaxy-S22-Bundle_ProductChildItems.json +0 -72
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_AttributeAssignments.json +0 -142
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DataPack.json +0 -377
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_DecompositionRelationships.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ObjectFieldAttributes.json +0 -36
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ParentKeys.json +0 -8
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PriceListEntries.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_PricebookEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/examples/static-ip-simple-offer/Static-IP_ProductChildItems.json +0 -34
- package/skills/modeling-omnistudio-epc-catalog/assets/object-field-attributes-template.json +0 -138
- package/skills/modeling-omnistudio-epc-catalog/assets/orchestration-scenarios-template.json +0 -54
- package/skills/modeling-omnistudio-epc-catalog/assets/override-definitions-template.json +0 -134
- package/skills/modeling-omnistudio-epc-catalog/assets/parent-keys-template.json +0 -29
- package/skills/modeling-omnistudio-epc-catalog/assets/price-list-entries-template.json +0 -158
- package/skills/modeling-omnistudio-epc-catalog/assets/pricebook-entries-template.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/assets/product-child-item-template.json +0 -338
- package/skills/modeling-omnistudio-epc-catalog/assets/product2-offer-template.json +0 -527
- package/skills/modeling-omnistudio-epc-catalog/examples/.gitkeep +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_AttributeAssignments.json +0 -95
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_CompiledAttributeOverrides.json +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DataPack.json +0 -214
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_DecompositionRelationships.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ObjectFieldAttributes.json +0 -98
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OrchestrationScenarios.json +0 -22
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_OverrideDefinitions.json +0 -1
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ParentKeys.json +0 -13
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PriceListEntries.json +0 -35
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_PricebookEntries.json +0 -28
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/Business-Internet-Plus_ProductChildItems.json +0 -110
- package/skills/modeling-omnistudio-epc-catalog/examples/business-internet-plus-bundle/TRANSCRIPT.md +0 -58
- package/skills/modeling-omnistudio-epc-catalog/references/epc-field-guide.md +0 -90
- package/skills/modeling-omnistudio-epc-catalog/references/naming-conventions.md +0 -80
- package/skills/modeling-omnistudio-epc-catalog/references/scoring-model.md +0 -57
- package/skills/modeling-omnistudio-epc-catalog/scripts/cli-validation-commands.sh +0 -19
- package/skills/modeling-omnistudio-epc-catalog/scripts/sample-invocations.sh +0 -18
- package/skills/observing-agentforce/SKILL.md +0 -366
- package/skills/observing-agentforce/apex/AgentforceOptimizeService.cls +0 -1262
- package/skills/observing-agentforce/apex/AgentforceOptimizeService.cls-meta.xml +0 -5
- package/skills/observing-agentforce/references/improve-reference.md +0 -359
- package/skills/observing-agentforce/references/issue-classification.md +0 -220
- package/skills/observing-agentforce/references/reproduce-reference.md +0 -131
- package/skills/observing-agentforce/references/stdm-queries.md +0 -373
- package/skills/observing-agentforce/references/stdm-schema.md +0 -189
- package/skills/orchestrating-datacloud/CREDITS.md +0 -15
- package/skills/orchestrating-datacloud/README.md +0 -127
- package/skills/orchestrating-datacloud/SKILL.md +0 -235
- package/skills/orchestrating-datacloud/UPSTREAM.md +0 -45
- package/skills/orchestrating-datacloud/assets/definitions/activation-target.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/activation.template.json +0 -7
- package/skills/orchestrating-datacloud/assets/definitions/calculated-insight.template.json +0 -7
- package/skills/orchestrating-datacloud/assets/definitions/data-action-target.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/data-action.template.json +0 -5
- package/skills/orchestrating-datacloud/assets/definitions/data-graph.template.json +0 -21
- package/skills/orchestrating-datacloud/assets/definitions/data-stream.template.json +0 -55
- package/skills/orchestrating-datacloud/assets/definitions/dmo.template.json +0 -17
- package/skills/orchestrating-datacloud/assets/definitions/identity-resolution.template.json +0 -30
- package/skills/orchestrating-datacloud/assets/definitions/mapping.template.json +0 -14
- package/skills/orchestrating-datacloud/assets/definitions/relationship.template.json +0 -12
- package/skills/orchestrating-datacloud/assets/definitions/search-index.template.json +0 -9
- package/skills/orchestrating-datacloud/assets/definitions/segment.template.json +0 -16
- package/skills/orchestrating-datacloud/references/feature-readiness.md +0 -157
- package/skills/orchestrating-datacloud/references/plugin-setup.md +0 -138
- package/skills/orchestrating-datacloud/scripts/bootstrap-plugin.sh +0 -53
- package/skills/orchestrating-datacloud/scripts/diagnose-org.mjs +0 -511
- package/skills/orchestrating-datacloud/scripts/generate-manifest.mjs +0 -68
- package/skills/orchestrating-datacloud/scripts/verify-plugin.sh +0 -58
- package/skills/platform-agentexchange-partner-offers-enable/SKILL.md +0 -111
- package/skills/platform-agentexchange-partner-offers-enable/assets/org-pref-template.md +0 -27
- package/skills/platform-agentexchange-partner-offers-enable/examples/org-preference-settings.xml +0 -4
- package/skills/preparing-datacloud/CREDITS.md +0 -7
- package/skills/preparing-datacloud/README.md +0 -51
- package/skills/preparing-datacloud/SKILL.md +0 -190
- package/skills/preparing-datacloud/examples/ingestion-api/.env.example +0 -8
- package/skills/preparing-datacloud/examples/ingestion-api/README.md +0 -48
- package/skills/preparing-datacloud/examples/ingestion-api/send-data.py +0 -144
- package/skills/querying-soql/CREDITS.md +0 -21
- package/skills/querying-soql/README.md +0 -41
- package/skills/querying-soql/SKILL.md +0 -142
- package/skills/querying-soql/assets/aggregate-queries.soql +0 -242
- package/skills/querying-soql/assets/basic-queries.soql +0 -188
- package/skills/querying-soql/assets/bulkified-query-pattern.cls +0 -280
- package/skills/querying-soql/assets/optimization-patterns.soql +0 -259
- package/skills/querying-soql/assets/relationship-queries.soql +0 -203
- package/skills/querying-soql/assets/selector-class.cls +0 -219
- package/skills/querying-soql/references/anti-patterns.md +0 -348
- package/skills/querying-soql/references/cli-commands.md +0 -358
- package/skills/querying-soql/references/field-coverage-rules.md +0 -514
- package/skills/querying-soql/references/query-optimization.md +0 -142
- package/skills/querying-soql/references/selector-patterns.md +0 -479
- package/skills/querying-soql/references/soql-reference.md +0 -227
- package/skills/querying-soql/references/soql-syntax-reference.md +0 -208
- package/skills/querying-soql/scripts/post-tool-validate.py +0 -322
- package/skills/retrieving-datacloud/CREDITS.md +0 -7
- package/skills/retrieving-datacloud/README.md +0 -44
- package/skills/retrieving-datacloud/SKILL.md +0 -119
- package/skills/retrieving-datacloud/examples/search-indexes/hybrid-structured.json +0 -44
- package/skills/retrieving-datacloud/examples/search-indexes/vector-knowledge.json +0 -43
- package/skills/reviewing-lwc-mobile-offline/SKILL.md +0 -167
- package/skills/reviewing-lwc-mobile-offline/references/grounding.md +0 -7
- package/skills/reviewing-lwc-mobile-offline/references/inline-graphql.md +0 -43
- package/skills/reviewing-lwc-mobile-offline/references/komaci-eslint.md +0 -125
- package/skills/reviewing-lwc-mobile-offline/references/lwc-if.md +0 -78
- package/skills/reviewing-lwc-mobile-offline/scripts/komaci.config.mjs +0 -18
- package/skills/reviewing-lwc-mobile-offline/scripts/package.json +0 -10
- package/skills/reviewing-lwc-mobile-offline/scripts/run-komaci.sh +0 -69
- package/skills/running-apex-tests/CREDITS.md +0 -22
- package/skills/running-apex-tests/README.md +0 -94
- package/skills/running-apex-tests/SKILL.md +0 -157
- package/skills/running-apex-tests/assets/basic-test.cls +0 -169
- package/skills/running-apex-tests/assets/bulk-test.cls +0 -255
- package/skills/running-apex-tests/assets/dml-mock.cls +0 -339
- package/skills/running-apex-tests/assets/mock-callout-test.cls +0 -353
- package/skills/running-apex-tests/assets/stub-provider-example.cls +0 -364
- package/skills/running-apex-tests/assets/test-data-factory.cls +0 -328
- package/skills/running-apex-tests/hooks/scripts/parse-test-results.py +0 -364
- package/skills/running-apex-tests/references/cli-commands.md +0 -289
- package/skills/running-apex-tests/references/mocking-patterns.md +0 -500
- package/skills/running-apex-tests/references/performance-optimization.md +0 -283
- package/skills/running-apex-tests/references/test-fix-loop.md +0 -49
- package/skills/running-apex-tests/references/test-patterns.md +0 -154
- package/skills/running-apex-tests/references/testing-best-practices.md +0 -509
- package/skills/running-code-analyzer/SKILL.md +0 -495
- package/skills/running-code-analyzer/examples/README.md +0 -38
- package/skills/running-code-analyzer/examples/basic-scan-output.json +0 -92
- package/skills/running-code-analyzer/examples/command-variations.md +0 -333
- package/skills/running-code-analyzer/examples/fix-application-before-after.md +0 -142
- package/skills/running-code-analyzer/examples/large-scan-output.json +0 -67
- package/skills/running-code-analyzer/examples/security-focused-output.json +0 -95
- package/skills/running-code-analyzer/references/command-examples.md +0 -27
- package/skills/running-code-analyzer/references/engine-reference.md +0 -34
- package/skills/running-code-analyzer/references/error-handling.md +0 -29
- package/skills/running-code-analyzer/references/flag-reference.md +0 -96
- package/skills/running-code-analyzer/references/post-scan-workflows.md +0 -286
- package/skills/running-code-analyzer/references/quick-start.md +0 -28
- package/skills/running-code-analyzer/references/special-behaviors.md +0 -83
- package/skills/running-code-analyzer/references/vendor-file-handling.md +0 -239
- package/skills/running-code-analyzer/scripts/apply-fixes.js +0 -86
- package/skills/running-code-analyzer/scripts/describe-rule.js +0 -382
- package/skills/running-code-analyzer/scripts/discover-fixes.js +0 -34
- package/skills/running-code-analyzer/scripts/filter-violations.js +0 -405
- package/skills/running-code-analyzer/scripts/list-rules.js +0 -260
- package/skills/running-code-analyzer/scripts/parse-results.js +0 -59
- package/skills/running-code-analyzer/scripts/query-results.js +0 -230
- package/skills/running-code-analyzer/scripts/summarize-fixes.js +0 -32
- package/skills/running-code-analyzer/scripts/verify-execution.sh +0 -28
- package/skills/searching-media/SKILL.md +0 -348
- package/skills/segmenting-datacloud/CREDITS.md +0 -3
- package/skills/segmenting-datacloud/README.md +0 -36
- package/skills/segmenting-datacloud/SKILL.md +0 -114
- package/skills/switching-org/SKILL.md +0 -28
- package/skills/testing-agentforce/SKILL.md +0 -333
- package/skills/testing-agentforce/assets/basic-test-spec.yaml +0 -63
- package/skills/testing-agentforce/assets/guardrail-test-spec.yaml +0 -105
- package/skills/testing-agentforce/assets/standard-test-spec.yaml +0 -127
- package/skills/testing-agentforce/references/action-execution.md +0 -241
- package/skills/testing-agentforce/references/batch-testing.md +0 -274
- package/skills/testing-agentforce/references/preview-testing.md +0 -353
- package/skills/testing-agentforce/references/test-report-format.md +0 -160
- package/skills/testing-agentforce/references/troubleshooting.md +0 -73
- package/skills/uplifting-components-to-slds2/SKILL.md +0 -239
- package/skills/uplifting-components-to-slds2/references/color-hooks-decision-guide.md +0 -459
- package/skills/uplifting-components-to-slds2/references/common-patterns.md +0 -87
- package/skills/uplifting-components-to-slds2/references/examples.md +0 -461
- package/skills/uplifting-components-to-slds2/references/migration-checklist.md +0 -67
- package/skills/uplifting-components-to-slds2/references/non-color-hooks-decision-guide.md +0 -333
- package/skills/uplifting-components-to-slds2/references/rule-lwc-token-to-slds-hook.md +0 -135
- package/skills/uplifting-components-to-slds2/references/rule-no-deprecated-tokens-slds1.md +0 -211
- package/skills/uplifting-components-to-slds2/references/rule-no-hardcoded-values.md +0 -160
- package/skills/uplifting-components-to-slds2/references/rule-no-slds-class-overrides.md +0 -126
- package/skills/using-mobile-native-capabilities/SKILL.md +0 -181
- package/skills/using-mobile-native-capabilities/references/app-review.md +0 -68
- package/skills/using-mobile-native-capabilities/references/ar-space-capture.md +0 -125
- package/skills/using-mobile-native-capabilities/references/barcode-scanner.md +0 -219
- package/skills/using-mobile-native-capabilities/references/base-capability.md +0 -22
- package/skills/using-mobile-native-capabilities/references/biometrics.md +0 -90
- package/skills/using-mobile-native-capabilities/references/calendar.md +0 -213
- package/skills/using-mobile-native-capabilities/references/contacts.md +0 -232
- package/skills/using-mobile-native-capabilities/references/document-scanner.md +0 -342
- package/skills/using-mobile-native-capabilities/references/geofencing.md +0 -123
- package/skills/using-mobile-native-capabilities/references/location.md +0 -158
- package/skills/using-mobile-native-capabilities/references/mobile-capabilities.md +0 -30
- package/skills/using-mobile-native-capabilities/references/nfc.md +0 -181
- package/skills/using-mobile-native-capabilities/references/payments.md +0 -95
- package/skills/using-salesforce-archive/SKILL.md +0 -121
- package/skills/using-salesforce-archive/examples/monitor-failed-jobs.md +0 -47
- package/skills/using-salesforce-archive/references/archive-activity-entity.md +0 -59
- package/skills/using-salesforce-archive/references/connect-api-operations.md +0 -157
- package/skills/using-ui-bundle-salesforce-data/SKILL.md +0 -638
- package/skills/using-ui-bundle-salesforce-data/scripts/graphql-search.sh +0 -191
- package/skills/validating-slds/SKILL.md +0 -262
- package/skills/validating-slds/references/quality-checks.md +0 -308
- package/skills/validating-slds/references/report-format.md +0 -302
- package/skills/validating-slds/scripts/analyze-quality.cjs +0 -521
|
@@ -1,1624 +0,0 @@
|
|
|
1
|
-
"""Assemble dc._session_tree.json from fetched DC artifacts.
|
|
2
|
-
|
|
3
|
-
Given `DATA_ROOT/<sid>/dc.*.json` + `dc._session_manifest.json` (produced by
|
|
4
|
-
`scripts/fetch_dc.py`), this module joins the rows in memory and emits:
|
|
5
|
-
|
|
6
|
-
- dc._session_tree.json — session-rooted hierarchical view
|
|
7
|
-
(Interaction → Step → Generation →
|
|
8
|
-
GatewayRequest, with audit rows nested)
|
|
9
|
-
|
|
10
|
-
The human-readable markdown summary is produced by a separate stage,
|
|
11
|
-
`scripts/render_dc.py`, which reads only the tree.
|
|
12
|
-
|
|
13
|
-
Design contract (see references/dc_pipeline_contract.md):
|
|
14
|
-
|
|
15
|
-
- No DMO fetches. Pure in-memory compute over already-fetched artifacts.
|
|
16
|
-
- Driven off `manifest["queries"][*]["name"]` — adding a 25th DMO to
|
|
17
|
-
fetch_dc.py doesn't require changes here (it just won't be placed in
|
|
18
|
-
the tree until the logic is extended).
|
|
19
|
-
- Declared binding chain nests GatewayRequest under LLM_STEP via
|
|
20
|
-
`Step.ssot__GenerationId__c → Generation → GatewayResponse → Request`.
|
|
21
|
-
- Chain-orphan GW calls fall through to a timestamp-window rule
|
|
22
|
-
(tier dominates: ACTION → TOPIC → TRUST_GUARDRAILS → any other;
|
|
23
|
-
innermost Step wins within a tier).
|
|
24
|
-
- PK collisions and parse warnings surface in `counts.*`, not stderr-only.
|
|
25
|
-
|
|
26
|
-
Invocation:
|
|
27
|
-
python3 scripts/assemble_dc.py --session <sid>
|
|
28
|
-
"""
|
|
29
|
-
from __future__ import annotations
|
|
30
|
-
|
|
31
|
-
import argparse
|
|
32
|
-
import functools
|
|
33
|
-
import html
|
|
34
|
-
import json
|
|
35
|
-
import re
|
|
36
|
-
import sys
|
|
37
|
-
from collections import defaultdict
|
|
38
|
-
from dataclasses import dataclass, field
|
|
39
|
-
from datetime import datetime
|
|
40
|
-
from pathlib import Path
|
|
41
|
-
from typing import Any, Dict, Iterable, List, Literal, Optional, Set, Tuple
|
|
42
|
-
|
|
43
|
-
sys.path.insert(0, str(Path(__file__).parent))
|
|
44
|
-
|
|
45
|
-
from config import DATA_ROOT, paths
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
# ---- sentinels + constants -------------------------------------------------
|
|
49
|
-
|
|
50
|
-
_NOT_SET = {"", "NOT_SET", None}
|
|
51
|
-
_INTERNAL_TRACE_RE = re.compile(r'"internalTraceId":"([a-f0-9]+)"') # @rule-suppress starter-sec-002 — re.compile, not eval/exec
|
|
52
|
-
|
|
53
|
-
# Real, non-placeholder agent version. Matches the canonical `^v[0-9]+$`
|
|
54
|
-
# shape that paths.session_dir requires AND excludes the `v0` placeholder
|
|
55
|
-
# stamped by fetch_dc's MyAgent fallback (fetch_dc.py:570-597).
|
|
56
|
-
# Used by `_promote_identity` to decide whether session_identity carries
|
|
57
|
-
# a richer agent_version that should win over a manifest placeholder.
|
|
58
|
-
_REAL_VERSION_RE = re.compile(r'^v[0-9]+$') # @rule-suppress starter-sec-002 — re.compile, not eval/exec
|
|
59
|
-
|
|
60
|
-
# Tier order for timestamp-window fallback. "any other" is an implicit last-resort
|
|
61
|
-
# catch-all covering LLM_STEP (without declared binding), SESSION_END, and any
|
|
62
|
-
# future step types not explicitly listed.
|
|
63
|
-
_TIER_ORDER = ("ACTION_STEP", "TOPIC_STEP", "TRUST_GUARDRAILS_STEP")
|
|
64
|
-
|
|
65
|
-
# Canonical identity-field name → ordered list of `gateway_request_tags.tag__c`
|
|
66
|
-
# values that carry it, tried in order. Agent versions emit different tag
|
|
67
|
-
# names: newer Atlas ReAct agents use `agent_developer_name` /
|
|
68
|
-
# `agent_version_api_name`; legacy MyAgent builds omit the developer
|
|
69
|
-
# name entirely and use the unprefixed `version_api_name`. First non-null
|
|
70
|
-
# value wins. A single-element list means "no fallback known."
|
|
71
|
-
_TAG_KEY_ALIASES: Dict[str, Tuple[str, ...]] = {
|
|
72
|
-
"agent_api_name": ("agent_developer_name",),
|
|
73
|
-
"agent_version": ("agent_version_api_name", "version_api_name"),
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
# ---- typed namespaces ------------------------------------------------------
|
|
78
|
-
#
|
|
79
|
-
# Four frozen dataclasses replace the former dict-bags. frozen=True guards
|
|
80
|
-
# attribute re-assignment, not mutation of the dict values themselves — the
|
|
81
|
-
# producers are responsible for handing in plain dicts (not defaultdicts) so
|
|
82
|
-
# downstream helpers don't rely on auto-creation the type doesn't promise.
|
|
83
|
-
|
|
84
|
-
@dataclass(frozen=True)
|
|
85
|
-
class Indexes:
|
|
86
|
-
interactions_by_id: Dict[str, dict]
|
|
87
|
-
participants_by_id: Dict[str, dict]
|
|
88
|
-
generations_by_id: Dict[str, dict]
|
|
89
|
-
gw_req_by_id: Dict[str, dict]
|
|
90
|
-
gw_resp_by_resp_id: Dict[str, dict]
|
|
91
|
-
feedback_by_id: Dict[str, dict]
|
|
92
|
-
gw_resp_by_req_id: Dict[str, List[dict]]
|
|
93
|
-
steps_by_interaction: Dict[str, List[dict]]
|
|
94
|
-
messages_by_interaction: Dict[str, List[dict]]
|
|
95
|
-
gw_tags_by_parent: Dict[str, List[dict]]
|
|
96
|
-
gw_md_by_parent: Dict[str, List[dict]]
|
|
97
|
-
gw_llm_by_parent: Dict[str, List[dict]]
|
|
98
|
-
quality_by_parent: Dict[str, List[dict]]
|
|
99
|
-
quality_by_id: Dict[str, dict]
|
|
100
|
-
feedback_by_gen: Dict[str, List[dict]]
|
|
101
|
-
feedback_details_by_parent: Dict[str, List[dict]]
|
|
102
|
-
participant_role_by_id: Dict[str, Optional[str]]
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
@dataclass(frozen=True)
|
|
106
|
-
class PolymorphicSplits:
|
|
107
|
-
categories_by_generation: Dict[str, List[dict]]
|
|
108
|
-
categories_by_quality: Dict[str, List[dict]]
|
|
109
|
-
gw_records_by_gw_req: Dict[str, List[dict]]
|
|
110
|
-
gw_records_by_feedback: Dict[str, List[dict]]
|
|
111
|
-
tag_assoc_session: List[dict]
|
|
112
|
-
tag_assoc_by_interaction: Dict[str, List[dict]]
|
|
113
|
-
tag_assoc_by_moment: Dict[str, List[dict]]
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
@dataclass(frozen=True)
|
|
117
|
-
class BindingResults:
|
|
118
|
-
declared_gw_ids: Set[str]
|
|
119
|
-
declared_steps_with_gw: frozenset
|
|
120
|
-
step_id_to_gw_id: Dict[str, Optional[str]]
|
|
121
|
-
declared_collisions: int
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
@dataclass(frozen=True)
|
|
125
|
-
class Catalog:
|
|
126
|
-
agents_observed: List[str]
|
|
127
|
-
tag_definitions: List[dict]
|
|
128
|
-
tag_definition_associations: List[dict]
|
|
129
|
-
tags: List[dict]
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
@dataclass
|
|
133
|
-
class BinderCtx:
|
|
134
|
-
"""Per-interaction scratch state used only by the timestamp-window pass.
|
|
135
|
-
|
|
136
|
-
Kept in a parallel `Dict[iid, BinderCtx]` instead of stashed on the
|
|
137
|
-
interaction view, so binder state can never leak into the emitted tree.
|
|
138
|
-
"""
|
|
139
|
-
start_ts: Optional[datetime]
|
|
140
|
-
end_ts: Optional[datetime]
|
|
141
|
-
steps_with_ts: List[Tuple[dict, Optional[datetime], Optional[datetime]]]
|
|
142
|
-
reserved_step_ids: frozenset
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
# ---- session-dir resolution ----------------------------------------------
|
|
146
|
-
|
|
147
|
-
def _find_session_dir(sid: str) -> Path:
|
|
148
|
-
"""Locate the session dir under the nested layout.
|
|
149
|
-
|
|
150
|
-
Given only a session id, we don't know ``(org, agent, version)`` upfront.
|
|
151
|
-
Strategy:
|
|
152
|
-
|
|
153
|
-
1. Validate ``sid`` against ``paths.SESSION_ID_RE`` at entry. ``sid`` comes
|
|
154
|
-
in via argv / resolve_session and flows directly into path composition
|
|
155
|
-
(``<org>/_sessions/<sid>.link``) and glob patterns; an unvalidated
|
|
156
|
-
value here would undo the traversal guard added in PR #657 BLOCKER-2.
|
|
157
|
-
2. Breadcrumb lookup: ``DATA_ROOT/<org>/_sessions/<sid>.link`` is a plain-
|
|
158
|
-
text relative-path pointer written by ``storage.save``. Iterate all
|
|
159
|
-
orgs, read each ``.link``, resolve against the breadcrumb's parent,
|
|
160
|
-
and **enforce containment** — a tampered or stale breadcrumb whose
|
|
161
|
-
target escapes ``DATA_ROOT`` is skipped (not raised) so a single
|
|
162
|
-
malicious breadcrumb can't DoS the whole resolver. Falls through to
|
|
163
|
-
the glob fallback on any breadcrumb miss.
|
|
164
|
-
3. Glob fallback: ``DATA_ROOT/*/*/<sid>/`` — ``sid`` is now validated at
|
|
165
|
-
entry so the pattern is fixed-depth and cannot glob outside its
|
|
166
|
-
intended 2-level subtree.
|
|
167
|
-
4. Raise ``SystemExit`` with a clear hint to run fetch_dc.py first.
|
|
168
|
-
|
|
169
|
-
Returns the absolute directory path.
|
|
170
|
-
"""
|
|
171
|
-
# Validate first — rejects "../etc", "a/b", "", None, and control chars.
|
|
172
|
-
# ``sid`` from here on is safe to use as a path segment and as the tail
|
|
173
|
-
# of a fixed-depth glob.
|
|
174
|
-
paths.validate_session_id(sid)
|
|
175
|
-
root = paths.DATA_ROOT
|
|
176
|
-
if root.is_dir():
|
|
177
|
-
# Resolve DATA_ROOT once so containment checks don't repeat the walk.
|
|
178
|
-
root_resolved = root.resolve()
|
|
179
|
-
for org_dir in root.iterdir():
|
|
180
|
-
if not org_dir.is_dir():
|
|
181
|
-
continue
|
|
182
|
-
link = org_dir / "_sessions" / f"{sid}.link"
|
|
183
|
-
if link.is_file():
|
|
184
|
-
try:
|
|
185
|
-
rel = link.read_text().strip()
|
|
186
|
-
except OSError:
|
|
187
|
-
continue
|
|
188
|
-
# Resolve relative to the breadcrumb's parent (_sessions/),
|
|
189
|
-
# then enforce that the resolved path stays inside
|
|
190
|
-
# DATA_ROOT. ``.link`` contents are user-writable — a planted
|
|
191
|
-
# breadcrumb with ``../../../../etc/passwd`` must NOT pivot
|
|
192
|
-
# the assembler outside the plugin's data tree.
|
|
193
|
-
target = (link.parent / rel).resolve()
|
|
194
|
-
if not target.is_relative_to(root_resolved):
|
|
195
|
-
# Stale or malicious breadcrumb. Skip — fall through to
|
|
196
|
-
# the glob fallback rather than raising, so one bad
|
|
197
|
-
# breadcrumb in one org doesn't block discovery in
|
|
198
|
-
# another.
|
|
199
|
-
continue
|
|
200
|
-
if target.is_dir():
|
|
201
|
-
return target
|
|
202
|
-
# Glob fallback. ``sid`` is validated; the pattern is fixed-depth.
|
|
203
|
-
matches = list(root.glob(f"*/*/{sid}"))
|
|
204
|
-
if len(matches) == 1:
|
|
205
|
-
return matches[0]
|
|
206
|
-
if len(matches) > 1:
|
|
207
|
-
# Placeholder agent dirs (leading-underscore name like
|
|
208
|
-
# ``<org>/_agent_<botid>__v0/``) mark provisional sessions
|
|
209
|
-
# whose identity wasn't fully resolved at first write. When a
|
|
210
|
-
# real (agent, version) dir also exists for the same session,
|
|
211
|
-
# it's the authoritative home; the placeholder is stale.
|
|
212
|
-
# Prefer the real dir.
|
|
213
|
-
real = [p for p in matches if not p.parent.name.startswith("_")]
|
|
214
|
-
if len(real) == 1:
|
|
215
|
-
return real[0]
|
|
216
|
-
raise SystemExit(
|
|
217
|
-
f"assemble_dc: session {sid} resolves to {len(matches)} dirs "
|
|
218
|
-
f"under {root} — ambiguous. Check for duplicate sessions "
|
|
219
|
-
f"across agents."
|
|
220
|
-
)
|
|
221
|
-
raise SystemExit(
|
|
222
|
-
f"assemble_dc: session dir for {sid} not found under {root}; "
|
|
223
|
-
f"run fetch_dc.py first"
|
|
224
|
-
)
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
# ---- loaders ---------------------------------------------------------------
|
|
228
|
-
|
|
229
|
-
def _load(session_dir: Path, name: str, parse_warnings: List[str]) -> List[dict]:
|
|
230
|
-
"""Load dc.<name>.json from session_dir. Missing → []. Malformed → [] + warning."""
|
|
231
|
-
p = session_dir / f"dc.{name}.json"
|
|
232
|
-
if not p.is_file():
|
|
233
|
-
return []
|
|
234
|
-
try:
|
|
235
|
-
return json.loads(p.read_text())
|
|
236
|
-
except (json.JSONDecodeError, OSError) as e:
|
|
237
|
-
print(f"assemble_dc: WARN dc.{name}.json unreadable: {str(e).splitlines()[0]}",
|
|
238
|
-
file=sys.stderr)
|
|
239
|
-
parse_warnings.append(name)
|
|
240
|
-
return []
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
def _load_manifest(session_dir: Path) -> dict:
|
|
244
|
-
p = session_dir / "dc._session_manifest.json"
|
|
245
|
-
if not p.is_file():
|
|
246
|
-
raise SystemExit(
|
|
247
|
-
f"assemble_dc: manifest not found at {p}; run fetch_dc.py first"
|
|
248
|
-
)
|
|
249
|
-
manifest = json.loads(p.read_text())
|
|
250
|
-
if "queries" not in manifest:
|
|
251
|
-
raise SystemExit("assemble_dc: manifest schema changed — no 'queries' key")
|
|
252
|
-
return manifest
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
def _load_all(sid: str) -> Tuple[dict, Dict[str, List[dict]], List[str], Path]:
|
|
256
|
-
"""Return (manifest, rows_by_name, parse_warnings, session_dir).
|
|
257
|
-
|
|
258
|
-
Iterates manifest["queries"][*]["name"] rather than a hard-coded list —
|
|
259
|
-
a new DMO added to fetch_dc.py is picked up automatically.
|
|
260
|
-
"""
|
|
261
|
-
session_dir = _find_session_dir(sid)
|
|
262
|
-
manifest = _load_manifest(session_dir)
|
|
263
|
-
parse_warnings: List[str] = []
|
|
264
|
-
rows = {
|
|
265
|
-
q["name"]: _load(session_dir, q["name"], parse_warnings)
|
|
266
|
-
for q in manifest["queries"]
|
|
267
|
-
}
|
|
268
|
-
return manifest, rows, parse_warnings, session_dir
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
# ---- small helpers ---------------------------------------------------------
|
|
272
|
-
|
|
273
|
-
def _clean(value: Any) -> Any:
|
|
274
|
-
"""NOT_SET sentinel → None. Other values pass through."""
|
|
275
|
-
return None if value in _NOT_SET else value
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
def _harvest_str(value: Any) -> Optional[str]:
|
|
279
|
-
"""Harvest-layer string normalizer for the session-identity block.
|
|
280
|
-
|
|
281
|
-
Handles three quirks that `_clean` deliberately does not:
|
|
282
|
-
1. **html.unescape** — tag values arrive double-escaped
|
|
283
|
-
(`""0Xx…""`).
|
|
284
|
-
2. **Quote-strip** — after unescape most tag values are wrapped in
|
|
285
|
-
literal `"` characters; strip them.
|
|
286
|
-
3. **`UNSET_VALUE` sentinel** — Data Cloud emits this on a small set
|
|
287
|
-
of optional columns (e.g. `gateway_requests.promptTemplateVersionNo__c`,
|
|
288
|
-
certain `tag_first` values on cold-start sessions). Not observed
|
|
289
|
-
on the columns `_build_session_identity` currently reads, but
|
|
290
|
-
included defensively since the sentinel is part of the DC schema
|
|
291
|
-
contract and a harvest-layer reader should collapse it to None.
|
|
292
|
-
|
|
293
|
-
The binding / index layer uses `_clean()` / `_NOT_SET` which
|
|
294
|
-
intentionally omits these rules — they would be noise there.
|
|
295
|
-
"""
|
|
296
|
-
if value is None:
|
|
297
|
-
return None
|
|
298
|
-
s = html.unescape(str(value)).strip()
|
|
299
|
-
if len(s) >= 2 and s.startswith('"') and s.endswith('"'):
|
|
300
|
-
s = s[1:-1]
|
|
301
|
-
return None if s in ("", "NOT_SET", "UNSET_VALUE") else s
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
def _promote_identity(
|
|
305
|
-
manifest_value: Any,
|
|
306
|
-
session_identity_value: Any,
|
|
307
|
-
*,
|
|
308
|
-
kind: Literal["api_name", "version"],
|
|
309
|
-
) -> Any:
|
|
310
|
-
"""Pick the richer of (manifest, session_identity) for a top-level identity slot.
|
|
311
|
-
|
|
312
|
-
Background. ``fetch_dc._resolve_identity`` walks AGENT-role participant
|
|
313
|
-
rows for ``(api_name, version)``. On agent shapes like MyAgent the
|
|
314
|
-
AGENT rows can leave both fields NOT_SET, so the resolver falls back
|
|
315
|
-
(fetch_dc.py:570-597) to picking ``api_name`` from any participant row
|
|
316
|
-
and stamping ``version="v0"`` as a placeholder satisfying
|
|
317
|
-
``paths.session_dir``'s ``^v[0-9]+$`` shape. The placeholder is enough
|
|
318
|
-
to land the session in a directory, but it's wrong: by wave 5 the
|
|
319
|
-
fetch has materialized ``gateway_request_tags`` rows carrying the real
|
|
320
|
-
``agent_version_api_name`` (e.g. ``v24``), and ``_build_session_identity``
|
|
321
|
-
correctly harvests it onto ``session.identity``. The top-level
|
|
322
|
-
``identity`` block was previously copied verbatim from the manifest,
|
|
323
|
-
so the placeholder leaked downstream while the right value sat
|
|
324
|
-
visible in the same JSON.
|
|
325
|
-
|
|
326
|
-
Policy:
|
|
327
|
-
|
|
328
|
-
- ``kind="version"``: if manifest is the ``"v0"`` placeholder AND
|
|
329
|
-
session_identity carries a non-``v0`` value matching ``^v[0-9]+$``,
|
|
330
|
-
promote. Otherwise keep manifest.
|
|
331
|
-
- ``kind="api_name"``: if manifest is NOT_SET-ish (None / "" / "NOT_SET"
|
|
332
|
-
/ "NOT SET") AND session_identity has a real value, promote.
|
|
333
|
-
Otherwise keep manifest. (Crucially, when session_identity is None
|
|
334
|
-
and manifest has a value, we keep manifest — the strict AGENT-row
|
|
335
|
-
pick is intentional on healthy sessions.)
|
|
336
|
-
- When manifest and session_identity both carry real-but-disagreeing
|
|
337
|
-
values, the manifest wins. The strict AGENT-row pick is the
|
|
338
|
-
authoritative source on a normal session; we only promote in the
|
|
339
|
-
narrow case where the manifest carries a known placeholder /
|
|
340
|
-
NOT_SET sentinel and the harvest layer has something better.
|
|
341
|
-
"""
|
|
342
|
-
if kind == "version":
|
|
343
|
-
if manifest_value != "v0":
|
|
344
|
-
return manifest_value
|
|
345
|
-
if not isinstance(session_identity_value, str):
|
|
346
|
-
return manifest_value
|
|
347
|
-
if session_identity_value == "v0":
|
|
348
|
-
return manifest_value
|
|
349
|
-
if not _REAL_VERSION_RE.match(session_identity_value):
|
|
350
|
-
return manifest_value
|
|
351
|
-
return session_identity_value
|
|
352
|
-
# kind == "api_name"
|
|
353
|
-
if manifest_value not in (None, "", "NOT_SET", "NOT SET"):
|
|
354
|
-
return manifest_value
|
|
355
|
-
if isinstance(session_identity_value, str) and session_identity_value:
|
|
356
|
-
return session_identity_value
|
|
357
|
-
return manifest_value
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
def _reconcile_top_identity(
|
|
361
|
-
manifest: dict, session_identity: dict, org_id_15: Any,
|
|
362
|
-
) -> dict:
|
|
363
|
-
"""Build the top-level ``identity`` block, promoting placeholders.
|
|
364
|
-
|
|
365
|
-
Centralizes the policy in one place so the happy path
|
|
366
|
-
(`_assemble_session`) and the gateway-direct fallback don't drift
|
|
367
|
-
apart. Emits a stderr note when promotion fires so an investigator
|
|
368
|
-
sees the divergence at run time.
|
|
369
|
-
"""
|
|
370
|
-
manifest_api = manifest.get("agent_api_name")
|
|
371
|
-
manifest_ver = manifest.get("agent_version")
|
|
372
|
-
session_api = session_identity.get("agent_api_name")
|
|
373
|
-
session_ver = session_identity.get("agent_version")
|
|
374
|
-
|
|
375
|
-
promoted_api = _promote_identity(manifest_api, session_api, kind="api_name")
|
|
376
|
-
promoted_ver = _promote_identity(manifest_ver, session_ver, kind="version")
|
|
377
|
-
|
|
378
|
-
if promoted_api != manifest_api:
|
|
379
|
-
print(
|
|
380
|
-
f"assemble_dc: identity promoted: agent_api_name "
|
|
381
|
-
f"{manifest_api!r} -> {promoted_api!r} (from session.identity)",
|
|
382
|
-
file=sys.stderr,
|
|
383
|
-
)
|
|
384
|
-
if promoted_ver != manifest_ver:
|
|
385
|
-
print(
|
|
386
|
-
f"assemble_dc: identity promoted: agent_version "
|
|
387
|
-
f"{manifest_ver} -> {promoted_ver} (from session.identity)",
|
|
388
|
-
file=sys.stderr,
|
|
389
|
-
)
|
|
390
|
-
|
|
391
|
-
return {
|
|
392
|
-
"org_id_15": org_id_15,
|
|
393
|
-
"agent_api_name": promoted_api,
|
|
394
|
-
"agent_version": promoted_ver,
|
|
395
|
-
}
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
def _resolve_end_type(session_row: dict, rows: dict) -> Optional[str]:
|
|
399
|
-
"""Resolve the session's terminal outcome with a Session→Step fallback.
|
|
400
|
-
|
|
401
|
-
Session DMO's ``ssot__AiAgentSessionEndType__c`` is authoritative when
|
|
402
|
-
populated, but on Messaging-channel and short E&O sessions it stays
|
|
403
|
-
``NOT_SET`` even after the SESSION_END interaction has materialized.
|
|
404
|
-
The runtime writes the actual outcome (``CLOSED_USER_REQUEST``,
|
|
405
|
-
``USER_ENDED``, ``ESCALATED``, ``TRANSFERRED``, ``TIMEOUT``) onto the
|
|
406
|
-
SESSION_END step's ``ssot__Name__c`` instead. Fall through to that
|
|
407
|
-
step when Session.EndType is missing, so the rendered summary stops
|
|
408
|
-
saying "session end not yet materialized in STDM" for sessions that
|
|
409
|
-
actually completed cleanly.
|
|
410
|
-
"""
|
|
411
|
-
primary = _clean(session_row.get("ssot__AiAgentSessionEndType__c"))
|
|
412
|
-
if primary:
|
|
413
|
-
return primary
|
|
414
|
-
for step in rows.get("steps", []) or ():
|
|
415
|
-
if step.get("ssot__AiAgentInteractionStepType__c") == "SESSION_END":
|
|
416
|
-
name = _clean(step.get("ssot__Name__c"))
|
|
417
|
-
if name:
|
|
418
|
-
return name
|
|
419
|
-
return None
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
def _ts(value: Any) -> Optional[datetime]:
|
|
423
|
-
"""Parse an ISO-8601 timestamp. NOT_SET / non-string → None (unbounded)."""
|
|
424
|
-
if not isinstance(value, str) or value in _NOT_SET:
|
|
425
|
-
return None
|
|
426
|
-
try:
|
|
427
|
-
return datetime.fromisoformat(value.replace("Z", "+00:00"))
|
|
428
|
-
except ValueError:
|
|
429
|
-
return None
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
def _index_unique(rows: Iterable[dict], key: str,
|
|
433
|
-
collisions: List[dict], dmo_label: str) -> Dict[str, dict]:
|
|
434
|
-
"""Build a {key_value: row} dict. On collision: first-write-wins + record."""
|
|
435
|
-
out: Dict[str, dict] = {}
|
|
436
|
-
for r in rows:
|
|
437
|
-
k = r.get(key)
|
|
438
|
-
if k in _NOT_SET:
|
|
439
|
-
continue
|
|
440
|
-
if k in out:
|
|
441
|
-
collisions.append({"dmo": dmo_label, "key": k})
|
|
442
|
-
else:
|
|
443
|
-
out[k] = r
|
|
444
|
-
return out
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
def _groupby(rows: Iterable[dict], key: str) -> Dict[str, List[dict]]:
|
|
448
|
-
out: Dict[str, List[dict]] = defaultdict(list)
|
|
449
|
-
for r in rows:
|
|
450
|
-
k = r.get(key)
|
|
451
|
-
if k not in _NOT_SET:
|
|
452
|
-
out[k].append(r)
|
|
453
|
-
return dict(out)
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
def _extract_trace_id(interaction: dict) -> Optional[str]:
|
|
457
|
-
"""Prefer the primary column; fall back to AttributeText regex."""
|
|
458
|
-
tid = interaction.get("ssot__TelemetryTraceId__c")
|
|
459
|
-
if tid and tid not in _NOT_SET:
|
|
460
|
-
return tid
|
|
461
|
-
attr = interaction.get("ssot__AttributeText__c") or ""
|
|
462
|
-
if not attr:
|
|
463
|
-
return None
|
|
464
|
-
m = _INTERNAL_TRACE_RE.search(html.unescape(attr))
|
|
465
|
-
return m.group(1) if m else None
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
# ---- declared binding chain ------------------------------------------------
|
|
469
|
-
|
|
470
|
-
def _declared_gw_for_step(step: dict,
|
|
471
|
-
generations_by_id: Dict[str, dict],
|
|
472
|
-
gw_resp_by_resp_id: Dict[str, dict],
|
|
473
|
-
gw_req_by_id: Dict[str, dict]) -> Optional[dict]:
|
|
474
|
-
"""Step → Generation → Response → Request. Returns the GatewayRequest row or None."""
|
|
475
|
-
gen_id = step.get("ssot__GenerationId__c")
|
|
476
|
-
if gen_id in _NOT_SET:
|
|
477
|
-
return None
|
|
478
|
-
gen = generations_by_id.get(gen_id)
|
|
479
|
-
if not gen:
|
|
480
|
-
return None
|
|
481
|
-
resp_id = gen.get("generationResponseId__c")
|
|
482
|
-
if resp_id in _NOT_SET:
|
|
483
|
-
return None
|
|
484
|
-
resp = gw_resp_by_resp_id.get(resp_id)
|
|
485
|
-
if not resp:
|
|
486
|
-
return None
|
|
487
|
-
req_id = resp.get("generationRequestId__c")
|
|
488
|
-
if req_id in _NOT_SET:
|
|
489
|
-
return None
|
|
490
|
-
return gw_req_by_id.get(req_id)
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
# ---- timestamp-window fallback --------------------------------------------
|
|
494
|
-
|
|
495
|
-
def _tier(step_type: str) -> int:
|
|
496
|
-
"""Lower is better. 0 = ACTION, 1 = TOPIC, 2 = GUARDRAIL, 3 = any other."""
|
|
497
|
-
try:
|
|
498
|
-
return _TIER_ORDER.index(step_type)
|
|
499
|
-
except ValueError:
|
|
500
|
-
return len(_TIER_ORDER) # "any other"
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
def _window_contains(gw_ts: datetime, start: Optional[datetime],
|
|
504
|
-
end: Optional[datetime]) -> bool:
|
|
505
|
-
"""Closed-closed containment. None end_ts → +∞. Missing start → no match."""
|
|
506
|
-
if start is None:
|
|
507
|
-
return False
|
|
508
|
-
if gw_ts < start:
|
|
509
|
-
return False
|
|
510
|
-
if end is None:
|
|
511
|
-
return True # open-ended upward
|
|
512
|
-
return gw_ts <= end
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
def _bind_ts_window(gw_req: dict,
|
|
516
|
-
steps_with_ts: List[Tuple[dict, datetime, Optional[datetime]]],
|
|
517
|
-
interaction_window: Tuple[Optional[datetime], Optional[datetime]],
|
|
518
|
-
reserved_step_ids: "frozenset[str]") -> Tuple[str, Optional[str]]:
|
|
519
|
-
"""Return (placement, bound_step_id).
|
|
520
|
-
|
|
521
|
-
placement ∈ {"step", "interaction", "unbound"}.
|
|
522
|
-
bound_step_id is set only when placement == "step".
|
|
523
|
-
"""
|
|
524
|
-
gw_ts_raw = gw_req.get("timestamp__c")
|
|
525
|
-
gw_ts = _ts(gw_ts_raw)
|
|
526
|
-
if gw_ts is None:
|
|
527
|
-
return ("unbound", None)
|
|
528
|
-
|
|
529
|
-
# Step candidates: contains gw_ts AND not already declared-bound.
|
|
530
|
-
candidates = [
|
|
531
|
-
(step, start, end)
|
|
532
|
-
for step, start, end in steps_with_ts
|
|
533
|
-
if step["ssot__Id__c"] not in reserved_step_ids
|
|
534
|
-
and _window_contains(gw_ts, start, end)
|
|
535
|
-
]
|
|
536
|
-
if candidates:
|
|
537
|
-
# Best tier → innermost (shortest window) → latest start_ts.
|
|
538
|
-
def sort_key(c):
|
|
539
|
-
step, start, end = c
|
|
540
|
-
tier = _tier(step.get("ssot__AiAgentInteractionStepType__c", ""))
|
|
541
|
-
# Window size; treat None end_ts as "longest" (so nested closed wins).
|
|
542
|
-
if end is None:
|
|
543
|
-
width = float("inf")
|
|
544
|
-
else:
|
|
545
|
-
width = (end - start).total_seconds()
|
|
546
|
-
# Invert latest-start-wins by negating seconds since epoch.
|
|
547
|
-
return (tier, width, -start.timestamp())
|
|
548
|
-
candidates.sort(key=sort_key)
|
|
549
|
-
winner = candidates[0][0]
|
|
550
|
-
return ("step", winner["ssot__Id__c"])
|
|
551
|
-
|
|
552
|
-
# Interaction window.
|
|
553
|
-
i_start, i_end = interaction_window
|
|
554
|
-
if _window_contains(gw_ts, i_start, i_end):
|
|
555
|
-
return ("interaction", None)
|
|
556
|
-
return ("unbound", None)
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
# ---- gateway-request view builder -----------------------------------------
|
|
560
|
-
|
|
561
|
-
def _build_gw_view(gw_req: dict, binding_method: str, *,
|
|
562
|
-
idx: Indexes, dispatch: PolymorphicSplits,
|
|
563
|
-
bound_step_id: Optional[str] = None) -> dict:
|
|
564
|
-
"""Build one GatewayRequest view row.
|
|
565
|
-
|
|
566
|
-
`idx` and `dispatch` are kw-only so `functools.partial(_build_gw_view,
|
|
567
|
-
idx=..., dispatch=...)` bindings don't collide with positional args at
|
|
568
|
-
the 3 call sites (declared / timestamp_window / unbound).
|
|
569
|
-
"""
|
|
570
|
-
gw_id = gw_req["gatewayRequestId__c"]
|
|
571
|
-
responses = idx.gw_resp_by_req_id.get(gw_id, [])
|
|
572
|
-
view: Dict[str, Any] = {
|
|
573
|
-
"binding_method": binding_method,
|
|
574
|
-
"gateway_request_id": gw_id,
|
|
575
|
-
"feature": _clean(gw_req.get("feature__c")),
|
|
576
|
-
"model": _clean(gw_req.get("model__c")),
|
|
577
|
-
"provider": _clean(gw_req.get("provider__c")),
|
|
578
|
-
"prompt_template_dev_name": _clean(gw_req.get("promptTemplateDevName__c")),
|
|
579
|
-
"prompt_tokens": gw_req.get("promptTokens__c"),
|
|
580
|
-
"completion_tokens": gw_req.get("completionTokens__c"),
|
|
581
|
-
"total_tokens": gw_req.get("totalTokens__c"),
|
|
582
|
-
# Carry the raw input prompt through the hierarchical view so the
|
|
583
|
-
# renderer can surface it in the opt-in "Planner LLM calls" section.
|
|
584
|
-
# The 64 KB display cap lives in render_dc, not here — the tree
|
|
585
|
-
# stores the authoritative payload.
|
|
586
|
-
"prompt_text": gw_req.get("prompt__c"),
|
|
587
|
-
"response": responses[0] if responses else None,
|
|
588
|
-
"tags": idx.gw_tags_by_parent.get(gw_id, []),
|
|
589
|
-
"records": dispatch.gw_records_by_gw_req.get(gw_id, []),
|
|
590
|
-
"metadata": idx.gw_md_by_parent.get(gw_id, []),
|
|
591
|
-
"llm": idx.gw_llm_by_parent.get(gw_id, []),
|
|
592
|
-
}
|
|
593
|
-
if bound_step_id is not None:
|
|
594
|
-
view["bound_to_step_id"] = bound_step_id
|
|
595
|
-
return view
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
# ---- main assembly ---------------------------------------------------------
|
|
599
|
-
|
|
600
|
-
def _build_indexes(rows: Dict[str, List[dict]], collisions: List[dict]) -> Indexes:
|
|
601
|
-
"""Build all primary-key dicts and groupby tables. Returns a frozen Indexes."""
|
|
602
|
-
return Indexes(
|
|
603
|
-
interactions_by_id=_index_unique(
|
|
604
|
-
rows.get("interactions", []), "ssot__Id__c", collisions, "interactions_by_id"),
|
|
605
|
-
participants_by_id=_index_unique(
|
|
606
|
-
rows.get("participants", []), "ssot__Id__c", collisions, "participants_by_id"),
|
|
607
|
-
generations_by_id=_index_unique(
|
|
608
|
-
rows.get("generations", []), "generationId__c", collisions, "generations_by_id"),
|
|
609
|
-
gw_req_by_id=_index_unique(
|
|
610
|
-
rows.get("gateway_requests", []), "gatewayRequestId__c", collisions, "gw_req_by_id"),
|
|
611
|
-
gw_resp_by_resp_id=_index_unique(
|
|
612
|
-
rows.get("gateway_responses", []), "generationResponseId__c",
|
|
613
|
-
collisions, "gw_resp_by_resp_id"),
|
|
614
|
-
feedback_by_id=_index_unique(
|
|
615
|
-
rows.get("feedback", []), "feedbackId__c", collisions, "feedback_by_id"),
|
|
616
|
-
gw_resp_by_req_id=_groupby(rows.get("gateway_responses", []), "generationRequestId__c"),
|
|
617
|
-
steps_by_interaction=_groupby(rows.get("steps", []), "ssot__AiAgentInteractionId__c"),
|
|
618
|
-
messages_by_interaction=_groupby(rows.get("messages", []), "ssot__AiAgentInteractionId__c"),
|
|
619
|
-
gw_tags_by_parent=_groupby(rows.get("gateway_request_tags", []), "parent__c"),
|
|
620
|
-
gw_md_by_parent=_groupby(rows.get("gateway_request_metadata", []), "parent__c"),
|
|
621
|
-
gw_llm_by_parent=_groupby(rows.get("gateway_request_llm", []), "parent__c"),
|
|
622
|
-
quality_by_parent=_groupby(rows.get("content_quality", []), "parent__c"),
|
|
623
|
-
quality_by_id={q["id__c"]: q for q in rows.get("content_quality", []) if q.get("id__c")},
|
|
624
|
-
feedback_by_gen=_groupby(rows.get("feedback", []), "generationId__c"),
|
|
625
|
-
feedback_details_by_parent=_groupby(rows.get("feedback_details", []), "parent__c"),
|
|
626
|
-
participant_role_by_id={
|
|
627
|
-
p["ssot__Id__c"]: p.get("ssot__AiAgentSessionParticipantRole__c")
|
|
628
|
-
for p in rows.get("participants", []) if p.get("ssot__Id__c")
|
|
629
|
-
},
|
|
630
|
-
)
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
def _dispatch_polymorphic(rows: Dict[str, List[dict]], idx: Indexes) -> PolymorphicSplits:
|
|
634
|
-
"""Split ContentCategory, GtwyObjRecord, and TagAssociation by polymorphic parent.
|
|
635
|
-
|
|
636
|
-
Producers accumulate into defaultdicts for ergonomics, but the returned
|
|
637
|
-
dataclass stores plain dicts — frozen `Dict[...]` typing can't promise
|
|
638
|
-
auto-creation, so don't let it leak.
|
|
639
|
-
"""
|
|
640
|
-
# ContentCategory: parent is either a generation or a quality row.
|
|
641
|
-
cat_by_gen: Dict[str, List[dict]] = defaultdict(list)
|
|
642
|
-
cat_by_qual: Dict[str, List[dict]] = defaultdict(list)
|
|
643
|
-
for cat in rows.get("content_category", []):
|
|
644
|
-
parent = cat.get("parent__c")
|
|
645
|
-
if parent in _NOT_SET:
|
|
646
|
-
continue
|
|
647
|
-
if parent in idx.generations_by_id:
|
|
648
|
-
cat_by_gen[parent].append(cat)
|
|
649
|
-
elif parent in idx.quality_by_id:
|
|
650
|
-
cat_by_qual[parent].append(cat)
|
|
651
|
-
|
|
652
|
-
# GtwyObjRecord: parent is either a gateway_request or a feedback row.
|
|
653
|
-
rec_by_gw: Dict[str, List[dict]] = defaultdict(list)
|
|
654
|
-
rec_by_fb: Dict[str, List[dict]] = defaultdict(list)
|
|
655
|
-
for rec in rows.get("gateway_records", []):
|
|
656
|
-
parent = rec.get("parent__c")
|
|
657
|
-
if parent in _NOT_SET:
|
|
658
|
-
continue
|
|
659
|
-
if parent in idx.gw_req_by_id:
|
|
660
|
-
rec_by_gw[parent].append(rec)
|
|
661
|
-
elif parent in idx.feedback_by_id:
|
|
662
|
-
rec_by_fb[parent].append(rec)
|
|
663
|
-
|
|
664
|
-
# TagAssociation: exactly one of session/interaction/moment FK is populated.
|
|
665
|
-
ta_session: List[dict] = []
|
|
666
|
-
ta_by_int: Dict[str, List[dict]] = defaultdict(list)
|
|
667
|
-
ta_by_mom: Dict[str, List[dict]] = defaultdict(list)
|
|
668
|
-
for ta in rows.get("tag_associations", []):
|
|
669
|
-
if ta.get("ssot__AiAgentSessionId__c") not in _NOT_SET:
|
|
670
|
-
ta_session.append(ta)
|
|
671
|
-
elif ta.get("ssot__AiAgentInteractionId__c") not in _NOT_SET:
|
|
672
|
-
ta_by_int[ta["ssot__AiAgentInteractionId__c"]].append(ta)
|
|
673
|
-
elif ta.get("ssot__AiAgentMomentId__c") not in _NOT_SET:
|
|
674
|
-
ta_by_mom[ta["ssot__AiAgentMomentId__c"]].append(ta)
|
|
675
|
-
|
|
676
|
-
return PolymorphicSplits(
|
|
677
|
-
categories_by_generation=dict(cat_by_gen),
|
|
678
|
-
categories_by_quality=dict(cat_by_qual),
|
|
679
|
-
gw_records_by_gw_req=dict(rec_by_gw),
|
|
680
|
-
gw_records_by_feedback=dict(rec_by_fb),
|
|
681
|
-
tag_assoc_session=ta_session,
|
|
682
|
-
tag_assoc_by_interaction=dict(ta_by_int),
|
|
683
|
-
tag_assoc_by_moment=dict(ta_by_mom),
|
|
684
|
-
)
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
def _filter_catalog(rows: Dict[str, List[dict]]) -> Catalog:
|
|
688
|
-
"""Filter org-wide tag vocabulary to only what's reachable from session agents."""
|
|
689
|
-
agents = {
|
|
690
|
-
p.get("ssot__AiAgentApiName__c") for p in rows.get("participants", [])
|
|
691
|
-
if p.get("ssot__AiAgentSessionParticipantRole__c") == "AGENT"
|
|
692
|
-
and p.get("ssot__AiAgentApiName__c") not in _NOT_SET
|
|
693
|
-
} | {
|
|
694
|
-
m.get("ssot__AiAgentApiName__c") for m in rows.get("moments", [])
|
|
695
|
-
if m.get("ssot__AiAgentApiName__c") not in _NOT_SET
|
|
696
|
-
}
|
|
697
|
-
# Mirror fetch_dc._resolve_identity's USER-row fallback. On agent shapes
|
|
698
|
-
# like MyAgent, AGENT-role rows leave api_name=NOT_SET while USER
|
|
699
|
-
# rows correctly carry the agent's api_name. Without this fallback, the
|
|
700
|
-
# session lands in a `<api_name>__v0/` directory but `agents_observed`
|
|
701
|
-
# is empty — directory and rendered catalog disagree. Only fires when the
|
|
702
|
-
# primary (AGENT + moments) sources turned up nothing usable; in normal
|
|
703
|
-
# sessions the USER and AGENT rows agree and the union is idempotent.
|
|
704
|
-
if not agents:
|
|
705
|
-
agents = {
|
|
706
|
-
p.get("ssot__AiAgentApiName__c") for p in rows.get("participants", [])
|
|
707
|
-
if p.get("ssot__AiAgentApiName__c") not in _NOT_SET
|
|
708
|
-
}
|
|
709
|
-
agents_observed = sorted(a for a in agents if a)
|
|
710
|
-
relevant_assocs = [
|
|
711
|
-
a for a in rows.get("tag_definition_associations", [])
|
|
712
|
-
if a.get("ssot__AiAgentApiName__c") in agents_observed
|
|
713
|
-
]
|
|
714
|
-
relevant_def_ids = {
|
|
715
|
-
a["ssot__AiAgentTagDefinitionId__c"] for a in relevant_assocs
|
|
716
|
-
if a.get("ssot__AiAgentTagDefinitionId__c") not in _NOT_SET
|
|
717
|
-
}
|
|
718
|
-
return Catalog(
|
|
719
|
-
agents_observed=agents_observed,
|
|
720
|
-
tag_definitions=[d for d in rows.get("tag_definitions", [])
|
|
721
|
-
if d.get("ssot__Id__c") in relevant_def_ids],
|
|
722
|
-
tag_definition_associations=relevant_assocs,
|
|
723
|
-
tags=[t for t in rows.get("tags", [])
|
|
724
|
-
if t.get("ssot__AiAgentTagDefinitionId__c") in relevant_def_ids],
|
|
725
|
-
)
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
def _build_session_identity(rows: Dict[str, List[dict]], manifest: dict) -> dict:
|
|
729
|
-
"""Harvest 18 identity fields from 4 DMOs for the `session.identity` block.
|
|
730
|
-
|
|
731
|
-
All row iteration is preceded by a deterministic sort so repeated runs
|
|
732
|
-
produce byte-identical output regardless of fetch order. `_harvest_str()` is
|
|
733
|
-
the shared normalizer — html.unescape + quote-strip + NOT_SET /
|
|
734
|
-
UNSET_VALUE / empty coercion. See references/dc_pipeline_contract.md
|
|
735
|
-
§2.9a for the field-to-column mapping.
|
|
736
|
-
"""
|
|
737
|
-
# --- gateway_requests: sort by (timestamp__c, gatewayRequestId__c) ---
|
|
738
|
-
gwr_sorted = sorted(
|
|
739
|
-
rows.get("gateway_requests", []),
|
|
740
|
-
key=lambda r: (r.get("timestamp__c") or "",
|
|
741
|
-
r.get("gatewayRequestId__c") or ""),
|
|
742
|
-
)
|
|
743
|
-
|
|
744
|
-
def _first_gwr(key: str) -> Optional[str]:
|
|
745
|
-
for r in gwr_sorted:
|
|
746
|
-
v = _harvest_str(r.get(key))
|
|
747
|
-
if v is not None:
|
|
748
|
-
return v
|
|
749
|
-
return None
|
|
750
|
-
|
|
751
|
-
org_id = _first_gwr("orgId__c")
|
|
752
|
-
platform_user_id = _first_gwr("userId__c")
|
|
753
|
-
planner_id = _first_gwr("plannerId__c")
|
|
754
|
-
bot_version_id = _first_gwr("botVersionId__c")
|
|
755
|
-
app_type = _first_gwr("appType__c")
|
|
756
|
-
|
|
757
|
-
# --- gateway_request_tags: sort by (parent__c, tag__c, tagValue__c) ---
|
|
758
|
-
tags_sorted = sorted(
|
|
759
|
-
rows.get("gateway_request_tags", []),
|
|
760
|
-
key=lambda r: (r.get("parent__c") or "",
|
|
761
|
-
r.get("tag__c") or "",
|
|
762
|
-
r.get("tagValue__c") or ""),
|
|
763
|
-
)
|
|
764
|
-
tag_first: Dict[str, Optional[str]] = {}
|
|
765
|
-
for t in tags_sorted:
|
|
766
|
-
k = t.get("tag__c")
|
|
767
|
-
if not k or k in tag_first:
|
|
768
|
-
continue
|
|
769
|
-
tag_first[k] = _harvest_str(t.get("tagValue__c"))
|
|
770
|
-
|
|
771
|
-
# --- sessions[0] — always exactly one row per session on this path ---
|
|
772
|
-
sessions = rows.get("sessions", [])
|
|
773
|
-
session_row = sessions[0] if sessions else {}
|
|
774
|
-
|
|
775
|
-
# --- participants: first USER-role row by ssot__Id__c ---
|
|
776
|
-
participants_sorted = sorted(
|
|
777
|
-
rows.get("participants", []),
|
|
778
|
-
key=lambda r: r.get("ssot__Id__c") or "",
|
|
779
|
-
)
|
|
780
|
-
messaging_end_user_id = None
|
|
781
|
-
for p in participants_sorted:
|
|
782
|
-
if p.get("ssot__AiAgentSessionParticipantRole__c") == "USER":
|
|
783
|
-
v = _harvest_str(p.get("ssot__ParticipantId__c"))
|
|
784
|
-
if v is not None:
|
|
785
|
-
messaging_end_user_id = v
|
|
786
|
-
break
|
|
787
|
-
|
|
788
|
-
def _aliased(identity_key: str) -> Optional[str]:
|
|
789
|
-
"""Resolve an identity field via its tag-name fallback chain.
|
|
790
|
-
|
|
791
|
-
Parameter name intentionally avoids shadowing `dataclasses.field`.
|
|
792
|
-
"""
|
|
793
|
-
for tag_key in _TAG_KEY_ALIASES[identity_key]:
|
|
794
|
-
v = tag_first.get(tag_key)
|
|
795
|
-
if v is not None:
|
|
796
|
-
return v
|
|
797
|
-
return None
|
|
798
|
-
|
|
799
|
-
# Expose VariableText__c bootstrap variables. Production messaging
|
|
800
|
-
# sessions leave this NOT_SET; Builder Previewer populates it with
|
|
801
|
-
# test-harness keys (__resolved_locale__, __supports_result_display__,
|
|
802
|
-
# etc.). Surfacing this is what makes channel-mode visible in the
|
|
803
|
-
# renderer.
|
|
804
|
-
messaging_session_id = _harvest_str(session_row.get("ssot__RelatedMessagingSessionId__c"))
|
|
805
|
-
voice_call_id = _harvest_str(session_row.get("ssot__RelatedVoiceCallId__c"))
|
|
806
|
-
bootstrap_variables = _parse_bootstrap_variables(
|
|
807
|
-
session_row.get("ssot__VariableText__c")
|
|
808
|
-
)
|
|
809
|
-
|
|
810
|
-
# Derive a `mode` field. ssot__AiAgentChannelType__c is identical for
|
|
811
|
-
# MIAW production and Builder Previewer (`SCRT2 - EmbeddedMessaging`);
|
|
812
|
-
# we have to look at related-id population and bootstrap_variables to
|
|
813
|
-
# tell them apart.
|
|
814
|
-
mode = _derive_mode(messaging_session_id, voice_call_id, bootstrap_variables)
|
|
815
|
-
|
|
816
|
-
# `voice_call_id` + `individual_id` are null on EmbeddedMessaging sessions.
|
|
817
|
-
# They populate on authenticated channels (voice, Experience Cloud with
|
|
818
|
-
# linked Individual). Kept for schema parallelism with messaging_session_id.
|
|
819
|
-
return {
|
|
820
|
-
"org_id": org_id,
|
|
821
|
-
"platform_user_id": platform_user_id,
|
|
822
|
-
"planner_id": planner_id,
|
|
823
|
-
"bot_version_id": bot_version_id,
|
|
824
|
-
"app_type": app_type,
|
|
825
|
-
"bot_id": tag_first.get("bot_id"),
|
|
826
|
-
"bot_name": tag_first.get("bot_name"),
|
|
827
|
-
"agent_api_name": _aliased("agent_api_name"),
|
|
828
|
-
"agent_label": tag_first.get("agent_label"),
|
|
829
|
-
"agent_version": _aliased("agent_version"),
|
|
830
|
-
"agent_type": tag_first.get("agent_type"),
|
|
831
|
-
"planner_name": tag_first.get("planner_name"),
|
|
832
|
-
"planner_type": tag_first.get("planner_type"),
|
|
833
|
-
"configured_model": tag_first.get("configured_model_name"),
|
|
834
|
-
"messaging_session_id": messaging_session_id,
|
|
835
|
-
"messaging_end_user_id": messaging_end_user_id,
|
|
836
|
-
"voice_call_id": voice_call_id,
|
|
837
|
-
"individual_id": _harvest_str(session_row.get("ssot__IndividualId__c")),
|
|
838
|
-
"bootstrap_variables": bootstrap_variables,
|
|
839
|
-
"mode": mode,
|
|
840
|
-
}
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
# Test-harness bootstrap keys that are observed in Builder Previewer sessions
|
|
844
|
-
# but NOT in MIAW production. The presence of any of these in
|
|
845
|
-
# `ssot__VariableText__c` is the strongest at-rest signal that a session was
|
|
846
|
-
# run through the Previewer rather than against a real customer messaging
|
|
847
|
-
# session. Listed here as a frozenset so it's read-only at module level.
|
|
848
|
-
# Builder Previewer adds these keys to ssot__VariableText__c at session
|
|
849
|
-
# bootstrap; MIAW production sessions don't seed them. Used by _derive_mode
|
|
850
|
-
# to distinguish previewer runs from real customer messaging sessions.
|
|
851
|
-
_BUILDER_PREVIEWER_INDICATOR_KEYS: frozenset[str] = frozenset({
|
|
852
|
-
"__resolved_locale__",
|
|
853
|
-
"__locale_instruction__",
|
|
854
|
-
"__supports_result_display__",
|
|
855
|
-
"__show_tool_results_invoked__",
|
|
856
|
-
})
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
def _parse_bootstrap_variables(raw: Any) -> Optional[dict]:
|
|
860
|
-
"""Parse `ssot__VariableText__c` defensively.
|
|
861
|
-
|
|
862
|
-
On real sessions this field can be:
|
|
863
|
-
- missing / None / NOT_SET / UNSET_VALUE → returns None
|
|
864
|
-
- well-formed JSON (Builder Previewer) → returns the dict
|
|
865
|
-
- HTML-entity-encoded JSON (some surfaces emit
|
|
866
|
-
the `"`-escaped form) → unescaped, returns the dict
|
|
867
|
-
- truncated or malformed JSON → returns
|
|
868
|
-
`{"_parse_error": True, "_raw": <first 200 chars>}` so the renderer
|
|
869
|
-
can still flag that a bootstrap exists, just not parseable.
|
|
870
|
-
|
|
871
|
-
Returns None for the empty cases so the caller can treat None as
|
|
872
|
-
"no bootstrap" without distinguishing missing from sentinel.
|
|
873
|
-
"""
|
|
874
|
-
if raw is None:
|
|
875
|
-
return None
|
|
876
|
-
s = html.unescape(str(raw)).strip()
|
|
877
|
-
if not s or s in _NOT_SET or s in ("NOT_SET", "UNSET_VALUE"):
|
|
878
|
-
return None
|
|
879
|
-
try:
|
|
880
|
-
parsed = json.loads(s)
|
|
881
|
-
except (json.JSONDecodeError, ValueError):
|
|
882
|
-
return {"_parse_error": True, "_raw": s[:200]}
|
|
883
|
-
# Defensive: VariableText__c is documented as a JSON object; if a future
|
|
884
|
-
# version emits a JSON array or scalar, surface it under `_raw` rather
|
|
885
|
-
# than letting downstream code crash on `.get()`.
|
|
886
|
-
if not isinstance(parsed, dict):
|
|
887
|
-
return {"_parse_error": True, "_raw": s[:200]}
|
|
888
|
-
return parsed
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
def _derive_mode(
|
|
892
|
-
messaging_session_id: Optional[str],
|
|
893
|
-
voice_call_id: Optional[str],
|
|
894
|
-
bootstrap_variables: Optional[dict],
|
|
895
|
-
) -> str:
|
|
896
|
-
"""Distinguish MIAW production from Builder Previewer from voice.
|
|
897
|
-
|
|
898
|
-
`ssot__AiAgentChannelType__c` is identical (`SCRT2 - EmbeddedMessaging`)
|
|
899
|
-
for MIAW and Builder Previewer — useless for distinguishing them. The
|
|
900
|
-
real signals, in priority order:
|
|
901
|
-
|
|
902
|
-
1. `ssot__RelatedVoiceCallId__c` set ↔ voice channel.
|
|
903
|
-
2. `ssot__RelatedMessagingSessionId__c` set ↔ MIAW production
|
|
904
|
-
(a real MessagingSession record exists).
|
|
905
|
-
3. `RelatedMessagingSessionId__c` NOT_SET AND bootstrap_variables
|
|
906
|
-
contains test-harness keys ↔ Builder Previewer.
|
|
907
|
-
4. None of the above ↔ unknown (e.g. headless API runs, agent script
|
|
908
|
-
previewer cases that don't seed VariableText__c).
|
|
909
|
-
|
|
910
|
-
Return a stable enum string the renderer can match on.
|
|
911
|
-
"""
|
|
912
|
-
if voice_call_id:
|
|
913
|
-
return "voice"
|
|
914
|
-
if messaging_session_id:
|
|
915
|
-
return "production_messaging"
|
|
916
|
-
if isinstance(bootstrap_variables, dict):
|
|
917
|
-
if set(bootstrap_variables) & _BUILDER_PREVIEWER_INDICATOR_KEYS:
|
|
918
|
-
return "builder_previewer"
|
|
919
|
-
return "unknown"
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
def _declared_binding_pass(rows: Dict[str, List[dict]], idx: Indexes) -> BindingResults:
|
|
923
|
-
"""Walk every step; claim GWs reachable via the declared chain.
|
|
924
|
-
|
|
925
|
-
Returns BindingResults(declared_gw_ids, declared_steps_with_gw,
|
|
926
|
-
step_id_to_gw_id, declared_collisions). `declared_steps_with_gw` is a
|
|
927
|
-
frozenset so downstream consumers can't accidentally mutate it.
|
|
928
|
-
`step_id_to_gw_id[step_id]` is the GW id when declared, or None when this
|
|
929
|
-
step's declared GW was already claimed by an earlier step (collision sentinel).
|
|
930
|
-
`declared_collisions` is the aggregate count of collision-sentinel entries.
|
|
931
|
-
"""
|
|
932
|
-
declared_gw_ids: set = set()
|
|
933
|
-
declared_steps_with_gw: set = set()
|
|
934
|
-
step_id_to_gw_id: Dict[str, Optional[str]] = {}
|
|
935
|
-
for step in rows.get("steps", []):
|
|
936
|
-
gw_req = _declared_gw_for_step(
|
|
937
|
-
step, idx.generations_by_id, idx.gw_resp_by_resp_id, idx.gw_req_by_id)
|
|
938
|
-
if gw_req is None:
|
|
939
|
-
continue
|
|
940
|
-
gw_id = gw_req["gatewayRequestId__c"]
|
|
941
|
-
if gw_id in declared_gw_ids:
|
|
942
|
-
# Collision: second+ step reaches a GW already claimed.
|
|
943
|
-
step_id_to_gw_id[step["ssot__Id__c"]] = None
|
|
944
|
-
continue
|
|
945
|
-
declared_gw_ids.add(gw_id)
|
|
946
|
-
declared_steps_with_gw.add(step["ssot__Id__c"])
|
|
947
|
-
step_id_to_gw_id[step["ssot__Id__c"]] = gw_id
|
|
948
|
-
return BindingResults(
|
|
949
|
-
declared_gw_ids=declared_gw_ids,
|
|
950
|
-
declared_steps_with_gw=frozenset(declared_steps_with_gw),
|
|
951
|
-
step_id_to_gw_id=step_id_to_gw_id,
|
|
952
|
-
declared_collisions=sum(1 for v in step_id_to_gw_id.values() if v is None),
|
|
953
|
-
)
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
def _build_step_view(step: dict, idx: Indexes, dispatch: PolymorphicSplits,
|
|
957
|
-
step_id_to_gw_id: Dict[str, Optional[str]],
|
|
958
|
-
build_gw) -> dict:
|
|
959
|
-
"""Emit one Step view, including its Generation and (if declared) GatewayRequest.
|
|
960
|
-
|
|
961
|
-
`build_gw` is a `functools.partial` pre-bound with `idx`/`dispatch`
|
|
962
|
-
(see `assemble()`); call sites only supply `gw_req`, `binding_method`,
|
|
963
|
-
and optionally `bound_step_id`.
|
|
964
|
-
"""
|
|
965
|
-
sid_step = step["ssot__Id__c"]
|
|
966
|
-
gen_id = step.get("ssot__GenerationId__c")
|
|
967
|
-
gen = idx.generations_by_id.get(gen_id) if gen_id not in _NOT_SET else None
|
|
968
|
-
generation_view = _build_generation_view(
|
|
969
|
-
gen, idx.quality_by_parent, dispatch.categories_by_generation,
|
|
970
|
-
dispatch.categories_by_quality, idx.feedback_by_gen,
|
|
971
|
-
idx.feedback_details_by_parent, dispatch.gw_records_by_feedback,
|
|
972
|
-
) if gen is not None else None
|
|
973
|
-
|
|
974
|
-
gw_id = step_id_to_gw_id.get(sid_step)
|
|
975
|
-
gw_view = None
|
|
976
|
-
collision_flag = gw_id is None and sid_step in step_id_to_gw_id
|
|
977
|
-
if gw_id is not None:
|
|
978
|
-
gw_view = build_gw(idx.gw_req_by_id[gw_id], "declared")
|
|
979
|
-
|
|
980
|
-
# Mirror the bound gateway_request's model identifier onto the step
|
|
981
|
-
# itself so renderers can show "LLM_STEP <name> · <model>" without
|
|
982
|
-
# dereferencing the nested gateway view. The mirror is None when no
|
|
983
|
-
# gateway_request is bound (declared chain didn't reach, or the STDM
|
|
984
|
-
# exporter dropped writes — see the `gateway_requests_dropped_by_stdm`
|
|
985
|
-
# session_shape).
|
|
986
|
-
step_model_name = gw_view.get("model") if gw_view else None
|
|
987
|
-
|
|
988
|
-
step_view: Dict[str, Any] = {
|
|
989
|
-
"id": sid_step,
|
|
990
|
-
"type": step.get("ssot__AiAgentInteractionStepType__c"),
|
|
991
|
-
"name": step.get("ssot__Name__c"),
|
|
992
|
-
"start_ts": step.get("ssot__StartTimestamp__c"),
|
|
993
|
-
"end_ts": step.get("ssot__EndTimestamp__c"),
|
|
994
|
-
"error_text": _clean(step.get("ssot__ErrorMessageText__c")),
|
|
995
|
-
"model_name": step_model_name,
|
|
996
|
-
"generation": generation_view,
|
|
997
|
-
"gateway_request": gw_view,
|
|
998
|
-
}
|
|
999
|
-
if collision_flag:
|
|
1000
|
-
step_view["gateway_request_collision"] = True
|
|
1001
|
-
return step_view
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
def _build_message_view(m: dict, participant_role_by_id: Dict[str, str]) -> dict:
|
|
1005
|
-
mtype = m.get("ssot__AiAgentInteractionMessageType__c")
|
|
1006
|
-
pid = m.get("ssot__AiAgentSessionParticipantId__c")
|
|
1007
|
-
role = participant_role_by_id.get(pid)
|
|
1008
|
-
if role is None:
|
|
1009
|
-
role = "USER" if mtype == "Input" else "AGENT" if mtype == "Output" else None
|
|
1010
|
-
return {
|
|
1011
|
-
"message_id": m.get("ssot__Id__c"),
|
|
1012
|
-
"type": mtype,
|
|
1013
|
-
"role": role,
|
|
1014
|
-
"participant_id": pid,
|
|
1015
|
-
"text": m.get("ssot__ContentText__c"),
|
|
1016
|
-
"content_type": m.get("ssot__AiAgentInteractionMsgContentType__c"),
|
|
1017
|
-
"modality": m.get("Modality__c"),
|
|
1018
|
-
"ts": m.get("ssot__MessageSentTimestamp__c"),
|
|
1019
|
-
}
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
def _build_interaction_view(interaction: dict, rows: Dict[str, List[dict]],
|
|
1023
|
-
idx: Indexes, dispatch: PolymorphicSplits,
|
|
1024
|
-
binding: BindingResults,
|
|
1025
|
-
build_gw) -> Tuple[dict, BinderCtx]:
|
|
1026
|
-
"""Emit one Interaction view plus its BinderCtx.
|
|
1027
|
-
|
|
1028
|
-
Returns (view, binder_ctx). Binder scratch state lives in the `BinderCtx`
|
|
1029
|
-
and is keyed externally by `iid`; it never touches the emitted view, so
|
|
1030
|
-
it can't leak into `dc._session_tree.json`. `build_gw` is the
|
|
1031
|
-
`functools.partial` from `assemble()`.
|
|
1032
|
-
"""
|
|
1033
|
-
iid = interaction["ssot__Id__c"]
|
|
1034
|
-
trace_id = _extract_trace_id(interaction)
|
|
1035
|
-
|
|
1036
|
-
steps_sorted = sorted(
|
|
1037
|
-
idx.steps_by_interaction.get(iid, []),
|
|
1038
|
-
key=lambda s: (s.get("ssot__StartTimestamp__c") or "", s.get("ssot__Id__c") or ""))
|
|
1039
|
-
step_views = [_build_step_view(s, idx, dispatch, binding.step_id_to_gw_id, build_gw)
|
|
1040
|
-
for s in steps_sorted]
|
|
1041
|
-
|
|
1042
|
-
# Step windows consumed only by _ts_window_pass via the parallel BinderCtx.
|
|
1043
|
-
steps_with_ts: List[Tuple[dict, Optional[datetime], Optional[datetime]]] = [
|
|
1044
|
-
(s, _ts(s.get("ssot__StartTimestamp__c")), _ts(s.get("ssot__EndTimestamp__c")))
|
|
1045
|
-
for s in steps_sorted if _ts(s.get("ssot__StartTimestamp__c")) is not None
|
|
1046
|
-
]
|
|
1047
|
-
|
|
1048
|
-
messages_sorted = sorted(
|
|
1049
|
-
idx.messages_by_interaction.get(iid, []),
|
|
1050
|
-
key=lambda r: (r.get("ssot__MessageSentTimestamp__c") or "",
|
|
1051
|
-
r.get("ssot__Id__c") or ""))
|
|
1052
|
-
msg_views = [_build_message_view(m, idx.participant_role_by_id)
|
|
1053
|
-
for m in messages_sorted]
|
|
1054
|
-
|
|
1055
|
-
view = {
|
|
1056
|
-
"id": iid,
|
|
1057
|
-
"type": interaction.get("ssot__AiAgentInteractionType__c"),
|
|
1058
|
-
"topic": _clean(interaction.get("ssot__TopicApiName__c")),
|
|
1059
|
-
"trace_id": trace_id,
|
|
1060
|
-
"start_ts": interaction.get("ssot__StartTimestamp__c"),
|
|
1061
|
-
"end_ts": interaction.get("ssot__EndTimestamp__c"),
|
|
1062
|
-
"messages": msg_views,
|
|
1063
|
-
"telemetry_spans": [s for s in rows.get("telemetry_spans", [])
|
|
1064
|
-
if s.get("ssot__TelemetryTrace__c") == trace_id],
|
|
1065
|
-
"steps": step_views,
|
|
1066
|
-
"timestamp_bound_gateway_calls": [], # appended by _ts_window_pass
|
|
1067
|
-
"tag_associations": dispatch.tag_assoc_by_interaction.get(iid, []),
|
|
1068
|
-
}
|
|
1069
|
-
binder_ctx = BinderCtx(
|
|
1070
|
-
start_ts=_ts(interaction.get("ssot__StartTimestamp__c")),
|
|
1071
|
-
end_ts=_ts(interaction.get("ssot__EndTimestamp__c")),
|
|
1072
|
-
steps_with_ts=steps_with_ts,
|
|
1073
|
-
reserved_step_ids=binding.declared_steps_with_gw,
|
|
1074
|
-
)
|
|
1075
|
-
return view, binder_ctx
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
def _ts_window_pass(interactions_view: List[dict],
|
|
1079
|
-
binders: Dict[str, BinderCtx],
|
|
1080
|
-
idx: Indexes,
|
|
1081
|
-
binding: BindingResults,
|
|
1082
|
-
build_gw) -> Tuple[List[dict], dict]:
|
|
1083
|
-
"""Place every chain-orphan GW via timestamp-window, or into unbound[].
|
|
1084
|
-
|
|
1085
|
-
Reads per-interaction binder state from the parallel `binders` dict keyed
|
|
1086
|
-
by `iv["id"]` — never from the view itself. Mutates `interactions_view`
|
|
1087
|
-
in place only to append to `timestamp_bound_gateway_calls[]` (an emission
|
|
1088
|
-
field, pre-initialized to `[]` in `_build_interaction_view`).
|
|
1089
|
-
|
|
1090
|
-
Returns (unbound_gw_calls, gw_binding_counts).
|
|
1091
|
-
"""
|
|
1092
|
-
unbound: List[dict] = []
|
|
1093
|
-
counts = {
|
|
1094
|
-
"declared": len(binding.declared_gw_ids),
|
|
1095
|
-
"timestamp_window": 0,
|
|
1096
|
-
"unbound": 0,
|
|
1097
|
-
"declared_collisions": binding.declared_collisions,
|
|
1098
|
-
}
|
|
1099
|
-
for gw_id, gw_req in idx.gw_req_by_id.items():
|
|
1100
|
-
if gw_id in binding.declared_gw_ids:
|
|
1101
|
-
continue
|
|
1102
|
-
placed = False
|
|
1103
|
-
for iv in interactions_view:
|
|
1104
|
-
bctx = binders[iv["id"]]
|
|
1105
|
-
placement, bound_step_id = _bind_ts_window(
|
|
1106
|
-
gw_req,
|
|
1107
|
-
bctx.steps_with_ts,
|
|
1108
|
-
(bctx.start_ts, bctx.end_ts),
|
|
1109
|
-
bctx.reserved_step_ids,
|
|
1110
|
-
)
|
|
1111
|
-
if placement in ("step", "interaction"):
|
|
1112
|
-
iv["timestamp_bound_gateway_calls"].append(
|
|
1113
|
-
build_gw(gw_req, "timestamp_window", bound_step_id=bound_step_id))
|
|
1114
|
-
counts["timestamp_window"] += 1
|
|
1115
|
-
placed = True
|
|
1116
|
-
break
|
|
1117
|
-
if not placed:
|
|
1118
|
-
unbound.append(build_gw(gw_req, "unbound"))
|
|
1119
|
-
counts["unbound"] += 1
|
|
1120
|
-
|
|
1121
|
-
# Defense in depth: if anyone reintroduces the binder-cache-on-view
|
|
1122
|
-
# pattern in a future edit, this catches it before the tree ever writes.
|
|
1123
|
-
assert not any(k.startswith("_") for iv in interactions_view for k in iv), \
|
|
1124
|
-
"binder scratch state leaked into interaction view — do not stash on the view dict"
|
|
1125
|
-
|
|
1126
|
-
return unbound, counts
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
def _build_moments_view(rows: Dict[str, List[dict]], dispatch: PolymorphicSplits) -> List[dict]:
|
|
1130
|
-
"""session.moments[] with interaction_ids[] back-refs derived from MomentInteraction."""
|
|
1131
|
-
by_moment: Dict[str, List[str]] = defaultdict(list)
|
|
1132
|
-
for mi in rows.get("moment_interactions", []):
|
|
1133
|
-
mid = mi.get("ssot__AiAgentMomentId__c")
|
|
1134
|
-
iid = mi.get("ssot__AiAgentInteractionId__c")
|
|
1135
|
-
if mid not in _NOT_SET and iid not in _NOT_SET:
|
|
1136
|
-
by_moment[mid].append(iid)
|
|
1137
|
-
|
|
1138
|
-
moments_sorted = sorted(
|
|
1139
|
-
rows.get("moments", []),
|
|
1140
|
-
key=lambda r: (r.get("ssot__StartTimestamp__c") or "", r.get("ssot__Id__c") or ""))
|
|
1141
|
-
return [
|
|
1142
|
-
{
|
|
1143
|
-
"moment_id": m.get("ssot__Id__c"),
|
|
1144
|
-
"agent_api_name": _clean(m.get("ssot__AiAgentApiName__c")),
|
|
1145
|
-
"agent_version": _clean(m.get("ssot__AiAgentVersionApiName__c")),
|
|
1146
|
-
"request_summary_text": _clean(m.get("ssot__RequestSummaryText__c")),
|
|
1147
|
-
"response_summary_text": _clean(m.get("ssot__ResponseSummaryText__c")),
|
|
1148
|
-
"interaction_ids": sorted(by_moment.get(m.get("ssot__Id__c"), [])),
|
|
1149
|
-
"start_ts": m.get("ssot__StartTimestamp__c"),
|
|
1150
|
-
"end_ts": m.get("ssot__EndTimestamp__c"),
|
|
1151
|
-
"tag_associations": dispatch.tag_assoc_by_moment.get(m.get("ssot__Id__c"), []),
|
|
1152
|
-
}
|
|
1153
|
-
for m in moments_sorted
|
|
1154
|
-
]
|
|
1155
|
-
|
|
1156
|
-
|
|
1157
|
-
def _build_participants_view(rows: Dict[str, List[dict]]) -> List[dict]:
|
|
1158
|
-
return [
|
|
1159
|
-
{
|
|
1160
|
-
"participant_id": p.get("ssot__Id__c"),
|
|
1161
|
-
"role": p.get("ssot__AiAgentSessionParticipantRole__c"),
|
|
1162
|
-
"agent_api_name": _clean(p.get("ssot__AiAgentApiName__c")),
|
|
1163
|
-
"agent_version": _clean(p.get("ssot__AiAgentVersionApiName__c")),
|
|
1164
|
-
"agent_type": _clean(p.get("ssot__AiAgentType__c")),
|
|
1165
|
-
}
|
|
1166
|
-
for p in sorted(
|
|
1167
|
-
rows.get("participants", []),
|
|
1168
|
-
key=lambda r: (r.get("ssot__StartTimestamp__c") or "", r.get("ssot__Id__c") or ""))
|
|
1169
|
-
]
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
def _build_counts(rows: Dict[str, List[dict]], dispatch: PolymorphicSplits,
|
|
1173
|
-
binding_counts: dict,
|
|
1174
|
-
manifest: dict, collisions: List[dict],
|
|
1175
|
-
parse_warnings: List[str]) -> dict:
|
|
1176
|
-
int_by_type: Dict[str, int] = defaultdict(int)
|
|
1177
|
-
step_by_type: Dict[str, int] = defaultdict(int)
|
|
1178
|
-
for i in rows.get("interactions", []):
|
|
1179
|
-
int_by_type[i.get("ssot__AiAgentInteractionType__c")] += 1
|
|
1180
|
-
for s in rows.get("steps", []):
|
|
1181
|
-
step_by_type[s.get("ssot__AiAgentInteractionStepType__c")] += 1
|
|
1182
|
-
|
|
1183
|
-
return {
|
|
1184
|
-
"interactions_total": len(rows.get("interactions", [])),
|
|
1185
|
-
"interactions_turn": int_by_type.get("TURN", 0),
|
|
1186
|
-
"interactions_session_end": int_by_type.get("SESSION_END", 0),
|
|
1187
|
-
"steps_total": len(rows.get("steps", [])),
|
|
1188
|
-
"steps_by_type": {
|
|
1189
|
-
k: step_by_type.get(k, 0) for k in
|
|
1190
|
-
("LLM_STEP", "ACTION_STEP", "TOPIC_STEP", "TRUST_GUARDRAILS_STEP", "SESSION_END")
|
|
1191
|
-
},
|
|
1192
|
-
"generations": len(rows.get("generations", [])),
|
|
1193
|
-
"gateway_requests": len(rows.get("gateway_requests", [])),
|
|
1194
|
-
"gateway_responses": len(rows.get("gateway_responses", [])),
|
|
1195
|
-
"gateway_metadata": len(rows.get("gateway_request_metadata", [])),
|
|
1196
|
-
"gateway_llm": len(rows.get("gateway_request_llm", [])),
|
|
1197
|
-
"gateway_records_grounded": sum(len(v) for v in dispatch.gw_records_by_gw_req.values()),
|
|
1198
|
-
"gateway_records_feedback": sum(len(v) for v in dispatch.gw_records_by_feedback.values()),
|
|
1199
|
-
"feedback": len(rows.get("feedback", [])),
|
|
1200
|
-
"audit_chain_1to1_ok": (
|
|
1201
|
-
len(rows.get("gateway_requests", [])) == len(rows.get("gateway_responses", []))
|
|
1202
|
-
),
|
|
1203
|
-
"gw_binding": binding_counts,
|
|
1204
|
-
"session_shape": manifest.get("session_shape", "unknown"),
|
|
1205
|
-
"pk_collisions": collisions,
|
|
1206
|
-
"parse_warnings": parse_warnings,
|
|
1207
|
-
}
|
|
1208
|
-
|
|
1209
|
-
|
|
1210
|
-
def assemble(sid: str) -> Tuple[dict, Path]:
|
|
1211
|
-
"""Orchestrate: load → index → dispatch → bind → build views → counts → tree.
|
|
1212
|
-
|
|
1213
|
-
Returns (tree, session_dir). The session_dir is resolved by
|
|
1214
|
-
``_find_session_dir`` (via breadcrumb or glob) and passed back so
|
|
1215
|
-
the caller can write ``dc._session_tree.json`` next to the inputs
|
|
1216
|
-
without re-scanning the disk.
|
|
1217
|
-
"""
|
|
1218
|
-
manifest, rows, parse_warnings, session_dir = _load_all(sid)
|
|
1219
|
-
|
|
1220
|
-
# Short-circuit: session row not found.
|
|
1221
|
-
sessions = rows.get("sessions", [])
|
|
1222
|
-
if not sessions:
|
|
1223
|
-
return _minimal_tree_session_not_found(sid, manifest, parse_warnings), session_dir
|
|
1224
|
-
|
|
1225
|
-
# Short-circuit: STDM Interaction/Step/Message DMOs haven't materialized yet
|
|
1226
|
-
# (gateway_requests present, interactions/steps empty). Render the gateway
|
|
1227
|
-
# chain directly instead of silently emitting an empty tree.
|
|
1228
|
-
if manifest.get("session_shape") == "interactions_not_materialized_yet":
|
|
1229
|
-
return _assemble_gateway_direct(sid, rows, manifest, parse_warnings), session_dir
|
|
1230
|
-
|
|
1231
|
-
collisions: List[dict] = []
|
|
1232
|
-
# Phase 1: independent bags.
|
|
1233
|
-
idx = _build_indexes(rows, collisions)
|
|
1234
|
-
dispatch = _dispatch_polymorphic(rows, idx)
|
|
1235
|
-
catalog = _filter_catalog(rows)
|
|
1236
|
-
# Phase 2: derived bag that depends on idx.
|
|
1237
|
-
binding = _declared_binding_pass(rows, idx)
|
|
1238
|
-
|
|
1239
|
-
# Bind the invariant gw-view args once; call sites supply only the varying ones.
|
|
1240
|
-
build_gw = functools.partial(_build_gw_view, idx=idx, dispatch=dispatch)
|
|
1241
|
-
|
|
1242
|
-
# Build per-Interaction views + parallel binder state (sorted by start_ts).
|
|
1243
|
-
interactions_view: List[dict] = []
|
|
1244
|
-
binders: Dict[str, BinderCtx] = {}
|
|
1245
|
-
for interaction in sorted(
|
|
1246
|
-
rows.get("interactions", []),
|
|
1247
|
-
key=lambda r: (r.get("ssot__StartTimestamp__c") or "",
|
|
1248
|
-
r.get("ssot__Id__c") or "")):
|
|
1249
|
-
view, bctx = _build_interaction_view(interaction, rows, idx, dispatch, binding, build_gw)
|
|
1250
|
-
interactions_view.append(view)
|
|
1251
|
-
binders[view["id"]] = bctx
|
|
1252
|
-
|
|
1253
|
-
# Timestamp-window fallback; mutates interactions_view only via
|
|
1254
|
-
# timestamp_bound_gateway_calls[].append.
|
|
1255
|
-
unbound_gw_calls, gw_binding_counts = _ts_window_pass(
|
|
1256
|
-
interactions_view, binders, idx, binding, build_gw)
|
|
1257
|
-
|
|
1258
|
-
session_row = sessions[0]
|
|
1259
|
-
session_identity = _build_session_identity(rows, manifest)
|
|
1260
|
-
# `org_id_15` is the canonical 15-char slice used by path helpers.
|
|
1261
|
-
# Prefer the manifest-stamped value (resolved in wave 1a of fetch_dc
|
|
1262
|
-
# from sessions[0].ssot__InternalOrganizationId__c); fall back to
|
|
1263
|
-
# slicing session_identity.org_id (the 18-char form from
|
|
1264
|
-
# gateway_requests) when the manifest is missing the field (older
|
|
1265
|
-
# artifacts predate the manifest stamp).
|
|
1266
|
-
org_id_15 = manifest.get("org_id_15")
|
|
1267
|
-
if not org_id_15 and session_identity.get("org_id"):
|
|
1268
|
-
org_id_15 = session_identity["org_id"][:15]
|
|
1269
|
-
session_identity["org_id_15"] = org_id_15
|
|
1270
|
-
|
|
1271
|
-
# Top-level identity block — canonical location for the 3 segments
|
|
1272
|
-
# needed to name the session dir. Richer identity fields live under
|
|
1273
|
-
# `session.identity` as before.
|
|
1274
|
-
# Promote richer values from `session_identity` when the manifest carries
|
|
1275
|
-
# placeholders (notably ``agent_version="v0"`` from the MyAgent
|
|
1276
|
-
# fallback in fetch_dc.py:570-597) — without this, the top-level block
|
|
1277
|
-
# diverges from `session.identity` in the same JSON file.
|
|
1278
|
-
top_identity = _reconcile_top_identity(manifest, session_identity, org_id_15)
|
|
1279
|
-
|
|
1280
|
-
return {
|
|
1281
|
-
"identity": top_identity,
|
|
1282
|
-
"session": {
|
|
1283
|
-
"id": sid,
|
|
1284
|
-
"_schema_version": 1,
|
|
1285
|
-
"org": {
|
|
1286
|
-
"alias": manifest.get("org_alias"),
|
|
1287
|
-
"instance_url": manifest.get("instance_url"),
|
|
1288
|
-
},
|
|
1289
|
-
"identity": session_identity,
|
|
1290
|
-
"start_ts": session_row.get("ssot__StartTimestamp__c"),
|
|
1291
|
-
"end_ts": session_row.get("ssot__EndTimestamp__c"),
|
|
1292
|
-
"end_type": _resolve_end_type(session_row, rows),
|
|
1293
|
-
"channel": _harvest_str(session_row.get("ssot__AiAgentChannelType__c")),
|
|
1294
|
-
"participants": _build_participants_view(rows),
|
|
1295
|
-
"moments": _build_moments_view(rows, dispatch),
|
|
1296
|
-
"interactions": interactions_view,
|
|
1297
|
-
"session_tag_associations": dispatch.tag_assoc_session,
|
|
1298
|
-
"unbound_gateway_calls": unbound_gw_calls,
|
|
1299
|
-
"counts": _build_counts(rows, dispatch, gw_binding_counts,
|
|
1300
|
-
manifest, collisions, parse_warnings),
|
|
1301
|
-
},
|
|
1302
|
-
"catalog": {
|
|
1303
|
-
"agents_observed": catalog.agents_observed,
|
|
1304
|
-
"tag_definitions": catalog.tag_definitions,
|
|
1305
|
-
"tag_definition_associations": catalog.tag_definition_associations,
|
|
1306
|
-
"tags": catalog.tags,
|
|
1307
|
-
},
|
|
1308
|
-
"_doc": (
|
|
1309
|
-
"Assembled from "
|
|
1310
|
-
"DATA_ROOT/<org>/<agent>__<ver>/<sid>/dc.*.json. "
|
|
1311
|
-
"See dc._session_manifest.json for per-query counts and empty reasons. "
|
|
1312
|
-
"Contract: references/dc_pipeline_contract.md."
|
|
1313
|
-
),
|
|
1314
|
-
}, session_dir
|
|
1315
|
-
|
|
1316
|
-
|
|
1317
|
-
def _build_generation_view(gen: dict,
|
|
1318
|
-
quality_by_parent: Dict[str, List[dict]],
|
|
1319
|
-
categories_by_generation: Dict[str, List[dict]],
|
|
1320
|
-
categories_by_quality: Dict[str, List[dict]],
|
|
1321
|
-
feedback_by_gen: Dict[str, List[dict]],
|
|
1322
|
-
feedback_details_by_parent: Dict[str, List[dict]],
|
|
1323
|
-
gw_records_by_feedback: Dict[str, List[dict]]) -> dict:
|
|
1324
|
-
gen_id = gen["generationId__c"]
|
|
1325
|
-
# Quality rows with their TOXICITY sub-categories nested.
|
|
1326
|
-
quality_rows = []
|
|
1327
|
-
for q in quality_by_parent.get(gen_id, []):
|
|
1328
|
-
q_view = dict(q)
|
|
1329
|
-
q_view["_toxicity_subcategories"] = categories_by_quality.get(q.get("id__c"), [])
|
|
1330
|
-
quality_rows.append(q_view)
|
|
1331
|
-
|
|
1332
|
-
# Feedback rows with details + feedback-attachment records nested.
|
|
1333
|
-
feedback_rows = []
|
|
1334
|
-
for fb in feedback_by_gen.get(gen_id, []):
|
|
1335
|
-
fid = fb.get("feedbackId__c")
|
|
1336
|
-
feedback_rows.append({
|
|
1337
|
-
"feedback_id": fid,
|
|
1338
|
-
"feedback": fb.get("feedback__c"),
|
|
1339
|
-
"action": fb.get("action__c"),
|
|
1340
|
-
"details": feedback_details_by_parent.get(fid, []),
|
|
1341
|
-
"records": gw_records_by_feedback.get(fid, []),
|
|
1342
|
-
})
|
|
1343
|
-
|
|
1344
|
-
return {
|
|
1345
|
-
"generation_id": gen_id,
|
|
1346
|
-
"response_id": _clean(gen.get("generationResponseId__c")),
|
|
1347
|
-
"response_text": gen.get("responseText__c"),
|
|
1348
|
-
"masked_response_text": gen.get("maskedResponseText__c"),
|
|
1349
|
-
"response_parameters": gen.get("responseParameters__c"),
|
|
1350
|
-
"feature": _clean(gen.get("feature__c")),
|
|
1351
|
-
"quality": quality_rows,
|
|
1352
|
-
"categories": categories_by_generation.get(gen_id, []),
|
|
1353
|
-
"feedback": feedback_rows,
|
|
1354
|
-
}
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
_STDM_LAG_NOTE = (
|
|
1358
|
-
"Interaction/Step/Message DMOs materialize on a separate cadence from "
|
|
1359
|
-
"Gateway DMOs. For fresh sessions this view reflects the gateway chain "
|
|
1360
|
-
"directly. Re-run in 24–72 hours for the full hierarchical trace."
|
|
1361
|
-
)
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
def _assemble_gateway_direct(sid: str, rows: Dict[str, List[dict]],
|
|
1365
|
-
manifest: dict,
|
|
1366
|
-
parse_warnings: List[str]) -> dict:
|
|
1367
|
-
"""Build a gateway-chain-only tree for sessions whose STDM hierarchy hasn't materialized.
|
|
1368
|
-
|
|
1369
|
-
Mirrors ``_minimal_tree_session_not_found`` in shape, but populates a
|
|
1370
|
-
``session.gateway_chain[]`` harvested directly from ``gateway_requests``
|
|
1371
|
-
joined to ``gateway_request_tags`` / ``gateway_request_metadata`` /
|
|
1372
|
-
``gateway_responses``. ``session.interactions`` is an explicit empty list
|
|
1373
|
-
so consumers that walk it simply no-op.
|
|
1374
|
-
|
|
1375
|
-
The sentinel ``_source = "gateway_direct"`` is consumed by
|
|
1376
|
-
``render_dc._render_gateway_direct``.
|
|
1377
|
-
"""
|
|
1378
|
-
sessions = rows.get("sessions", [])
|
|
1379
|
-
session_row = sessions[0] if sessions else {}
|
|
1380
|
-
|
|
1381
|
-
# Reuse the canonical identity harvester — same tag-alias fallbacks,
|
|
1382
|
-
# same normalization — and apply the same org_id_15 fallback as the
|
|
1383
|
-
# happy path so the top-level identity block is consistent across shapes.
|
|
1384
|
-
session_identity = _build_session_identity(rows, manifest)
|
|
1385
|
-
org_id_15 = manifest.get("org_id_15")
|
|
1386
|
-
if not org_id_15 and session_identity.get("org_id"):
|
|
1387
|
-
org_id_15 = session_identity["org_id"][:15]
|
|
1388
|
-
session_identity["org_id_15"] = org_id_15
|
|
1389
|
-
|
|
1390
|
-
# Same placeholder-promotion policy as the happy path — see
|
|
1391
|
-
# `_reconcile_top_identity` for why we don't trust the manifest blindly.
|
|
1392
|
-
top_identity = _reconcile_top_identity(manifest, session_identity, org_id_15)
|
|
1393
|
-
|
|
1394
|
-
# Group the child DMOs by parent once so the per-request loop stays O(n).
|
|
1395
|
-
tags_by_req: Dict[str, List[dict]] = _groupby(
|
|
1396
|
-
rows.get("gateway_request_tags", []), "parent__c")
|
|
1397
|
-
md_by_req: Dict[str, List[dict]] = _groupby(
|
|
1398
|
-
rows.get("gateway_request_metadata", []), "parent__c")
|
|
1399
|
-
resp_by_req: Dict[str, List[dict]] = _groupby(
|
|
1400
|
-
rows.get("gateway_responses", []), "generationRequestId__c")
|
|
1401
|
-
|
|
1402
|
-
# Deterministic order: sort by (timestamp__c, gatewayRequestId__c) so
|
|
1403
|
-
# repeat runs on the same inputs produce byte-identical output.
|
|
1404
|
-
gw_sorted = sorted(
|
|
1405
|
-
rows.get("gateway_requests", []),
|
|
1406
|
-
key=lambda r: (r.get("timestamp__c") or "",
|
|
1407
|
-
r.get("gatewayRequestId__c") or ""),
|
|
1408
|
-
)
|
|
1409
|
-
|
|
1410
|
-
gateway_chain: List[dict] = []
|
|
1411
|
-
for gw in gw_sorted:
|
|
1412
|
-
gw_id = gw.get("gatewayRequestId__c")
|
|
1413
|
-
# sf__Id (platform row id) isn't harvested by fetch_dc; the logical
|
|
1414
|
-
# PK is gatewayRequestId__c. Keep both keys on the view so readers
|
|
1415
|
-
# can lift either without re-joining.
|
|
1416
|
-
sf_id = gw.get("sf__Id")
|
|
1417
|
-
|
|
1418
|
-
# timestamp: prefer the columns named in the change-request
|
|
1419
|
-
# (requestTimeStamp__c, createdAt__c), then fall back to the
|
|
1420
|
-
# documented column (timestamp__c in references/dc_dmo_fields.md).
|
|
1421
|
-
timestamp = (
|
|
1422
|
-
_clean(gw.get("requestTimeStamp__c"))
|
|
1423
|
-
or _clean(gw.get("createdAt__c"))
|
|
1424
|
-
or _clean(gw.get("timestamp__c"))
|
|
1425
|
-
)
|
|
1426
|
-
|
|
1427
|
-
# Tag-driven fields. Use _harvest_str for html-unescape + quote-strip —
|
|
1428
|
-
# same normalizer _build_session_identity uses on tag values.
|
|
1429
|
-
tag_first: Dict[str, Optional[str]] = {}
|
|
1430
|
-
for t in sorted(
|
|
1431
|
-
tags_by_req.get(gw_id, []),
|
|
1432
|
-
key=lambda r: (r.get("tag__c") or "",
|
|
1433
|
-
r.get("tagValue__c") or "")):
|
|
1434
|
-
k = t.get("tag__c")
|
|
1435
|
-
if not k or k in tag_first:
|
|
1436
|
-
continue
|
|
1437
|
-
tag_first[k] = _harvest_str(t.get("tagValue__c"))
|
|
1438
|
-
|
|
1439
|
-
# Prompt-template name: prefer the direct column on the request;
|
|
1440
|
-
# fall back to the tag alias used by older agent builds.
|
|
1441
|
-
prompt_template_dev_name = (
|
|
1442
|
-
_clean(gw.get("promptTemplateDevName__c"))
|
|
1443
|
-
or tag_first.get("prompt_template_dev_name")
|
|
1444
|
-
)
|
|
1445
|
-
# `feature` likewise prefers the typed column, falls back to tag.
|
|
1446
|
-
feature = _clean(gw.get("feature__c")) or tag_first.get("feature")
|
|
1447
|
-
|
|
1448
|
-
# Response side — take the first by response timestamp. 1:1 invariant
|
|
1449
|
-
# holds on every live session we've observed, but defend against the
|
|
1450
|
-
# in-flight-call edge case by sorting deterministically.
|
|
1451
|
-
responses_sorted = sorted(
|
|
1452
|
-
resp_by_req.get(gw_id, []),
|
|
1453
|
-
key=lambda r: (r.get("timestamp__c") or "",
|
|
1454
|
-
r.get("generationResponseId__c") or ""),
|
|
1455
|
-
)
|
|
1456
|
-
response_view: Optional[dict] = None
|
|
1457
|
-
if responses_sorted:
|
|
1458
|
-
resp = responses_sorted[0]
|
|
1459
|
-
response_view = {
|
|
1460
|
-
"timestamp": _clean(resp.get("timestamp__c")),
|
|
1461
|
-
"finish_reason": _parse_finish_reason_params(resp.get("parameters__c")),
|
|
1462
|
-
}
|
|
1463
|
-
|
|
1464
|
-
gateway_chain.append({
|
|
1465
|
-
"gateway_request_id": gw_id,
|
|
1466
|
-
"sf_id": sf_id,
|
|
1467
|
-
"timestamp": timestamp,
|
|
1468
|
-
"model": _clean(gw.get("model__c")),
|
|
1469
|
-
"provider": _clean(gw.get("provider__c")),
|
|
1470
|
-
"prompt_template_dev_name": prompt_template_dev_name,
|
|
1471
|
-
"feature": feature,
|
|
1472
|
-
"prompt_tokens": gw.get("promptTokens__c"),
|
|
1473
|
-
"completion_tokens": gw.get("completionTokens__c"),
|
|
1474
|
-
"total_tokens": gw.get("totalTokens__c"),
|
|
1475
|
-
# Raw prompt is authoritative on disk (dc.gateway_requests.json);
|
|
1476
|
-
# the 64 KB display cap lives in the render layer, not here.
|
|
1477
|
-
"prompt_text": gw.get("prompt__c"),
|
|
1478
|
-
"metadata": md_by_req.get(gw_id, []),
|
|
1479
|
-
"tags": tags_by_req.get(gw_id, []),
|
|
1480
|
-
"response": response_view,
|
|
1481
|
-
})
|
|
1482
|
-
|
|
1483
|
-
return {
|
|
1484
|
-
"identity": top_identity,
|
|
1485
|
-
"_source": "gateway_direct",
|
|
1486
|
-
"session": {
|
|
1487
|
-
"id": sid,
|
|
1488
|
-
"_schema_version": 1,
|
|
1489
|
-
"org": {
|
|
1490
|
-
"alias": manifest.get("org_alias"),
|
|
1491
|
-
"instance_url": manifest.get("instance_url"),
|
|
1492
|
-
},
|
|
1493
|
-
"identity": session_identity,
|
|
1494
|
-
"start_ts": session_row.get("ssot__StartTimestamp__c"),
|
|
1495
|
-
"end_ts": session_row.get("ssot__EndTimestamp__c"),
|
|
1496
|
-
"end_type": _resolve_end_type(session_row, rows),
|
|
1497
|
-
"channel": _harvest_str(session_row.get("ssot__AiAgentChannelType__c")),
|
|
1498
|
-
"participants": _build_participants_view(rows),
|
|
1499
|
-
# Explicit empty list — downstream consumers walk this and must
|
|
1500
|
-
# no-op safely when STDM hasn't materialized yet.
|
|
1501
|
-
"interactions": [],
|
|
1502
|
-
"gateway_chain": gateway_chain,
|
|
1503
|
-
"_stdm_lag_note": _STDM_LAG_NOTE,
|
|
1504
|
-
"counts": {
|
|
1505
|
-
"session_shape": manifest.get("session_shape",
|
|
1506
|
-
"interactions_not_materialized_yet"),
|
|
1507
|
-
"gateway_requests": len(rows.get("gateway_requests", [])),
|
|
1508
|
-
"gateway_responses": len(rows.get("gateway_responses", [])),
|
|
1509
|
-
"gateway_metadata": len(rows.get("gateway_request_metadata", [])),
|
|
1510
|
-
"gateway_tags": len(rows.get("gateway_request_tags", [])),
|
|
1511
|
-
"interactions_total": 0,
|
|
1512
|
-
"steps_total": 0,
|
|
1513
|
-
"parse_warnings": parse_warnings,
|
|
1514
|
-
},
|
|
1515
|
-
},
|
|
1516
|
-
"_doc": (
|
|
1517
|
-
f"Session {sid}: STDM Interaction/Step/Message DMOs have not "
|
|
1518
|
-
"materialized yet (they lag Gateway DMOs by hours to days). "
|
|
1519
|
-
"Tree carries the gateway chain harvested directly from "
|
|
1520
|
-
"GenAIGatewayRequest + related audit DMOs. Re-run fetch_dc.py "
|
|
1521
|
-
"in 24–72h once the STDM hierarchy has caught up for the full "
|
|
1522
|
-
"hierarchical trace."
|
|
1523
|
-
),
|
|
1524
|
-
}
|
|
1525
|
-
|
|
1526
|
-
|
|
1527
|
-
def _parse_finish_reason_params(parameters: Optional[str]) -> Optional[str]:
|
|
1528
|
-
"""Lift finish_reason out of GatewayResponse.parameters__c.
|
|
1529
|
-
|
|
1530
|
-
The field arrives HTML-escaped and the finish_reason value itself is
|
|
1531
|
-
often wrapped in escaped quotes (e.g. `\\"stop\\"`). Mirrors
|
|
1532
|
-
``render_dc._parse_finish_reason`` but against the gateway-response
|
|
1533
|
-
parameters column rather than Generation.responseParameters__c.
|
|
1534
|
-
"""
|
|
1535
|
-
if not parameters:
|
|
1536
|
-
return None
|
|
1537
|
-
try:
|
|
1538
|
-
decoded = html.unescape(parameters)
|
|
1539
|
-
parsed = json.loads(decoded)
|
|
1540
|
-
except (ValueError, TypeError):
|
|
1541
|
-
return None
|
|
1542
|
-
raw = parsed.get("finish_reason") if isinstance(parsed, dict) else None
|
|
1543
|
-
if not isinstance(raw, str):
|
|
1544
|
-
return None
|
|
1545
|
-
return raw.replace("\\", "").strip('"').strip() or None
|
|
1546
|
-
|
|
1547
|
-
|
|
1548
|
-
def _minimal_tree_session_not_found(sid: str, manifest: dict,
|
|
1549
|
-
parse_warnings: List[str]) -> dict:
|
|
1550
|
-
# Note: deliberately does NOT include `session.identity` — harvest
|
|
1551
|
-
# sources (gateway_requests, gateway_request_tags, sessions[0],
|
|
1552
|
-
# participants) are all empty on this path. Renderer's minimal-tree
|
|
1553
|
-
# branch must handle absent identity. DOES include _schema_version so
|
|
1554
|
-
# the renderer's version check doesn't warn on every not-found session.
|
|
1555
|
-
#
|
|
1556
|
-
# Top-level `identity` still carries the manifest-stamped (org, agent,
|
|
1557
|
-
# version) when available — the session dir already exists under that
|
|
1558
|
-
# identity or the manifest couldn't have been read. Breadcrumb readers
|
|
1559
|
-
# depend on this block being present on EVERY tree, not just
|
|
1560
|
-
# full-populated ones.
|
|
1561
|
-
return {
|
|
1562
|
-
"identity": {
|
|
1563
|
-
"org_id_15": manifest.get("org_id_15"),
|
|
1564
|
-
"agent_api_name": manifest.get("agent_api_name"),
|
|
1565
|
-
"agent_version": manifest.get("agent_version"),
|
|
1566
|
-
},
|
|
1567
|
-
"session": {
|
|
1568
|
-
"id": sid,
|
|
1569
|
-
"_schema_version": 1,
|
|
1570
|
-
"org": {
|
|
1571
|
-
"alias": manifest.get("org_alias"),
|
|
1572
|
-
"instance_url": manifest.get("instance_url"),
|
|
1573
|
-
},
|
|
1574
|
-
"counts": {
|
|
1575
|
-
"session_shape": manifest.get("session_shape", "session_not_found"),
|
|
1576
|
-
"parse_warnings": parse_warnings,
|
|
1577
|
-
},
|
|
1578
|
-
},
|
|
1579
|
-
"_doc": (
|
|
1580
|
-
f"Session {sid} did not resolve in Data Cloud "
|
|
1581
|
-
"(sessions.json returned 0 rows). Check the session id, or wait for "
|
|
1582
|
-
"STDM materialization. No interactions, catalog, or audit rows available."
|
|
1583
|
-
),
|
|
1584
|
-
}
|
|
1585
|
-
|
|
1586
|
-
|
|
1587
|
-
# ---- public entry points --------------------------------------------------
|
|
1588
|
-
|
|
1589
|
-
def main_for_session(sid: str) -> int:
|
|
1590
|
-
"""Called by fetch_dc.py's auto-run hook and by `--session` CLI.
|
|
1591
|
-
|
|
1592
|
-
Writes ``dc._session_tree.json`` into the session dir located by
|
|
1593
|
-
``_find_session_dir`` (via breadcrumb / glob) — the caller does not
|
|
1594
|
-
need to know ``(org, agent, version)`` to invoke the assembler.
|
|
1595
|
-
"""
|
|
1596
|
-
tree, session_dir = assemble(sid)
|
|
1597
|
-
tree_path = session_dir / "dc._session_tree.json"
|
|
1598
|
-
tree_path.write_text(json.dumps(tree, indent=2, sort_keys=True, default=str) + "\n")
|
|
1599
|
-
print(f"assemble_dc: wrote {tree_path}", file=sys.stderr)
|
|
1600
|
-
return 0
|
|
1601
|
-
|
|
1602
|
-
|
|
1603
|
-
def main() -> int:
|
|
1604
|
-
ap = argparse.ArgumentParser(
|
|
1605
|
-
prog="assemble_dc.py",
|
|
1606
|
-
description="Assemble dc._session_tree.json for one session.",
|
|
1607
|
-
)
|
|
1608
|
-
ap.add_argument("--session", required=True,
|
|
1609
|
-
help="AI-agent session UUID or MessagingSession id (0Mw...). "
|
|
1610
|
-
"Messaging ids are resolved from disk "
|
|
1611
|
-
"(DATA_ROOT/*/dc.sessions.json); run fetch_dc.py first "
|
|
1612
|
-
"if the session hasn't been fetched yet.")
|
|
1613
|
-
# Runtime-agnostic path overrides; default to ~/.vibe/...
|
|
1614
|
-
from _shared.cli_override import add_cli_flags, apply_overrides
|
|
1615
|
-
add_cli_flags(ap)
|
|
1616
|
-
args = ap.parse_args()
|
|
1617
|
-
apply_overrides(args, caller_globals=globals())
|
|
1618
|
-
from resolve_session import resolve_disk_or_live
|
|
1619
|
-
sid = resolve_disk_or_live(args.session)
|
|
1620
|
-
return main_for_session(sid)
|
|
1621
|
-
|
|
1622
|
-
|
|
1623
|
-
if __name__ == "__main__":
|
|
1624
|
-
sys.exit(main())
|