@cubis/foundry 0.3.34 → 0.3.35
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/README.md +56 -11
- package/bin/cubis.js +2809 -965
- package/mcp/.dockerignore +5 -0
- package/mcp/Dockerfile +19 -0
- package/mcp/README.md +550 -11
- package/mcp/config.json +18 -0
- package/mcp/dist/index.d.ts +1 -0
- package/mcp/dist/index.js +1488 -0
- package/mcp/package.json +36 -0
- package/mcp/src/cbxConfig/index.ts +23 -0
- package/mcp/src/cbxConfig/paths.ts +45 -0
- package/mcp/src/cbxConfig/reader.ts +149 -0
- package/mcp/src/cbxConfig/readerWriter.test.ts +147 -0
- package/mcp/src/cbxConfig/serviceConfig.test.ts +42 -0
- package/mcp/src/cbxConfig/serviceConfig.ts +157 -0
- package/mcp/src/cbxConfig/types.ts +44 -0
- package/mcp/src/cbxConfig/writer.ts +90 -0
- package/mcp/src/config/index.test.ts +81 -0
- package/mcp/src/config/index.ts +45 -0
- package/mcp/src/config/schema.ts +55 -0
- package/mcp/src/gateway/catalog.ts +37 -0
- package/mcp/src/gateway/config.ts +247 -0
- package/mcp/src/gateway/manager.ts +255 -0
- package/mcp/src/gateway/types.ts +54 -0
- package/mcp/src/gateway/upstreamClient.ts +80 -0
- package/mcp/src/index.ts +211 -0
- package/mcp/src/server.ts +219 -0
- package/mcp/src/tools/configTools.test.ts +166 -0
- package/mcp/src/tools/future/README.md +21 -0
- package/mcp/src/tools/future/index.ts +8 -0
- package/mcp/src/tools/index.ts +76 -0
- package/mcp/src/tools/mcpGateway.ts +44 -0
- package/mcp/src/tools/postmanGetMode.ts +82 -0
- package/mcp/src/tools/postmanGetStatus.ts +65 -0
- package/mcp/src/tools/postmanModes.ts +28 -0
- package/mcp/src/tools/postmanSetMode.ts +71 -0
- package/mcp/src/tools/skillBrowseCategory.ts +54 -0
- package/mcp/src/tools/skillGet.ts +43 -0
- package/mcp/src/tools/skillListCategories.ts +40 -0
- package/mcp/src/tools/skillSearch.ts +72 -0
- package/mcp/src/tools/skillTools.test.ts +126 -0
- package/mcp/src/tools/stitchGetMode.ts +58 -0
- package/mcp/src/tools/stitchGetStatus.ts +70 -0
- package/mcp/src/tools/stitchSetProfile.ts +82 -0
- package/mcp/src/transports/stdio.ts +9 -0
- package/mcp/src/transports/streamableHttp.ts +43 -0
- package/mcp/src/upstream/passthrough.ts +273 -0
- package/mcp/src/utils/errors.ts +38 -0
- package/mcp/src/utils/logger.ts +63 -0
- package/mcp/src/vault/manifest.test.ts +126 -0
- package/mcp/src/vault/manifest.ts +99 -0
- package/mcp/src/vault/scanner.test.ts +70 -0
- package/mcp/src/vault/scanner.ts +145 -0
- package/mcp/src/vault/types.ts +21 -0
- package/package.json +9 -2
- package/workflows/scripts/generate-powers.mjs +27 -18
- package/workflows/skills/skills_index.json +0 -102
- package/workflows/workflows/agent-environment-setup/manifest.json +0 -24
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/nextjs-react-expert/SKILL.md +1 -1
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/skills_index.json +0 -102
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/nextjs-react-expert/SKILL.md +1 -1
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/skills_index.json +0 -102
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/nextjs-react-expert/SKILL.md +1 -1
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/skills_index.json +0 -102
- package/mcp/catalogs/default.json +0 -14
- package/mcp/powers/atlassian-mcp/POWER.md +0 -91
- package/mcp/powers/atlassian-mcp/SKILL.md +0 -88
- package/mcp/powers/atlassian-mcp/steering/authentication-patterns.md +0 -520
- package/mcp/powers/atlassian-mcp/steering/common-workflows.md +0 -660
- package/mcp/powers/atlassian-mcp/steering/confluence-operations.md +0 -528
- package/mcp/powers/atlassian-mcp/steering/jira-queries.md +0 -421
- package/mcp/powers/atlassian-mcp/steering/mcp-server-setup.md +0 -292
- package/mcp/powers/building-mcp-server-on-cloudflare/POWER.md +0 -261
- package/mcp/powers/building-mcp-server-on-cloudflare/SKILL.md +0 -258
- package/mcp/powers/building-mcp-server-on-cloudflare/steering/examples.md +0 -115
- package/mcp/powers/building-mcp-server-on-cloudflare/steering/oauth-setup.md +0 -338
- package/mcp/powers/building-mcp-server-on-cloudflare/steering/troubleshooting.md +0 -317
- package/mcp/powers/datadog-automation/POWER.md +0 -238
- package/mcp/powers/datadog-automation/SKILL.md +0 -235
- package/mcp/powers/github-automation/POWER.md +0 -230
- package/mcp/powers/github-automation/SKILL.md +0 -227
- package/mcp/powers/mcp-builder/LICENSE.txt +0 -202
- package/mcp/powers/mcp-builder/POWER.md +0 -179
- package/mcp/powers/mcp-builder/SKILL.md +0 -176
- package/mcp/powers/mcp-builder/reference/evaluation.md +0 -602
- package/mcp/powers/mcp-builder/reference/mcp_best_practices.md +0 -915
- package/mcp/powers/mcp-builder/reference/node_mcp_server.md +0 -916
- package/mcp/powers/mcp-builder/reference/python_mcp_server.md +0 -752
- package/mcp/powers/mcp-builder/scripts/connections.py +0 -151
- package/mcp/powers/mcp-builder/scripts/evaluation.py +0 -373
- package/mcp/powers/mcp-builder/scripts/example_evaluation.xml +0 -22
- package/mcp/powers/mcp-builder/scripts/requirements.txt +0 -2
- package/mcp/powers/mcp-developer/POWER.md +0 -88
- package/mcp/powers/mcp-developer/SKILL.md +0 -85
- package/mcp/powers/mcp-developer/steering/protocol.md +0 -244
- package/mcp/powers/mcp-developer/steering/python-sdk.md +0 -367
- package/mcp/powers/mcp-developer/steering/resources.md +0 -554
- package/mcp/powers/mcp-developer/steering/tools.md +0 -480
- package/mcp/powers/mcp-developer/steering/typescript-sdk.md +0 -350
- package/mcp/powers/postman/POWER.md +0 -243
- package/mcp/powers/postman/SKILL.md +0 -240
- package/mcp/powers/postman/flutter-expert/POWER.md +0 -89
- package/mcp/powers/postman/flutter-expert/SKILL.md +0 -77
- package/mcp/powers/postman/flutter-expert/steering/bloc-state.md +0 -259
- package/mcp/powers/postman/flutter-expert/steering/engineering-principles.md +0 -82
- package/mcp/powers/postman/flutter-expert/steering/gorouter-navigation.md +0 -157
- package/mcp/powers/postman/flutter-expert/steering/performance.md +0 -99
- package/mcp/powers/postman/flutter-expert/steering/project-structure.md +0 -77
- package/mcp/powers/postman/flutter-expert/steering/riverpod-state.md +0 -404
- package/mcp/powers/postman/flutter-expert/steering/widget-patterns.md +0 -123
- package/mcp/powers/postman/flutter-security-reviewer/POWER.md +0 -204
- package/mcp/powers/postman/flutter-security-reviewer/SKILL.md +0 -180
- package/mcp/powers/postman/flutter-security-reviewer/steering/log_redaction.md +0 -17
- package/mcp/powers/postman/flutter-security-reviewer/steering/network_hardening.md +0 -13
- package/mcp/powers/postman/flutter-security-reviewer/steering/secret-scanning.md +0 -123
- package/mcp/powers/postman/flutter-security-reviewer/steering/secure_storage_policy.md +0 -16
- package/mcp/powers/postman/flutter-security-reviewer/steering/vulnerability-patterns.md +0 -189
- package/mcp/powers/postman/flutter-security-reviewer/templates/security_review_response.md +0 -31
- package/mcp/powers/postman/flutter-test-master/POWER.md +0 -527
- package/mcp/powers/postman/flutter-test-master/SKILL.md +0 -513
- package/mcp/powers/postman/flutter-test-master/steering/golden-testing.md +0 -444
- package/mcp/powers/postman/flutter-test-master/steering/integration-testing.md +0 -688
- package/mcp/powers/postman/flutter-test-master/steering/property-testing.md +0 -408
- package/mcp/powers/postman/flutter-test-master/steering/riverpod-testing.md +0 -606
- package/mcp/powers/postman/flutter-test-master/steering/test-utilities.md +0 -566
- package/mcp/powers/postman/flutter-test-master/steering/unit-testing.md +0 -511
- package/mcp/powers/postman/flutter-test-master/steering/widget-testing.md +0 -601
- package/mcp/powers/postman/git-commit/POWER.md +0 -47
- package/mcp/powers/postman/git-commit/SKILL.md +0 -46
- package/mcp/powers/postman/gorouter-restoration/POWER.md +0 -227
- package/mcp/powers/postman/gorouter-restoration/SKILL.md +0 -217
- package/mcp/powers/postman/gorouter-restoration/steering/guard_patterns.md +0 -14
- package/mcp/powers/postman/gorouter-restoration/steering/tab_preservation.md +0 -12
- package/mcp/powers/postman/gorouter-restoration/templates/guard_redirect.md +0 -30
- package/mcp/powers/postman/gorouter-restoration/templates/stateful_shell_skeleton.md +0 -40
- package/mcp/powers/postman/mcp.json +0 -11
- package/mcp/powers/postman/microservices-architect/POWER.md +0 -109
- package/mcp/powers/postman/microservices-architect/SKILL.md +0 -93
- package/mcp/powers/postman/microservices-architect/steering/communication.md +0 -499
- package/mcp/powers/postman/microservices-architect/steering/data.md +0 -721
- package/mcp/powers/postman/microservices-architect/steering/decomposition.md +0 -344
- package/mcp/powers/postman/microservices-architect/steering/observability.md +0 -805
- package/mcp/powers/postman/microservices-architect/steering/patterns.md +0 -603
- package/mcp/powers/postman/nestjs-expert/POWER.md +0 -130
- package/mcp/powers/postman/nestjs-expert/SKILL.md +0 -114
- package/mcp/powers/postman/nestjs-expert/steering/authentication.md +0 -461
- package/mcp/powers/postman/nestjs-expert/steering/controllers-routing.md +0 -114
- package/mcp/powers/postman/nestjs-expert/steering/dtos-validation.md +0 -156
- package/mcp/powers/postman/nestjs-expert/steering/migration-from-express.md +0 -1240
- package/mcp/powers/postman/nestjs-expert/steering/secure-sessions.md +0 -56
- package/mcp/powers/postman/nestjs-expert/steering/services-di.md +0 -143
- package/mcp/powers/postman/nestjs-expert/steering/strangler-fig-pattern.md +0 -47
- package/mcp/powers/postman/nestjs-expert/steering/testing-patterns.md +0 -189
- package/mcp/powers/postman/oneup-design/POWER.md +0 -72
- package/mcp/powers/postman/oneup-design/SKILL.md +0 -71
- package/mcp/powers/postman/oneup-design/steering/colors.md +0 -41
- package/mcp/powers/postman/oneup-design/steering/components.md +0 -53
- package/mcp/powers/postman/oneup-design/steering/spacing.md +0 -84
- package/mcp/powers/postman/openapi-docs/POWER.md +0 -78
- package/mcp/powers/postman/openapi-docs/SKILL.md +0 -68
- package/mcp/powers/postman/openapi-docs/steering/crud-templates.md +0 -43
- package/mcp/powers/postman/openapi-docs/steering/framework-express.md +0 -19
- package/mcp/powers/postman/openapi-docs/steering/framework-fastapi.md +0 -20
- package/mcp/powers/postman/openapi-docs/steering/framework-nestjs.md +0 -20
- package/mcp/powers/postman/openapi-docs/steering/framework-raw-openapi.md +0 -14
- package/mcp/powers/postman/openapi-docs/steering/openapi-checklist.md +0 -33
- package/mcp/powers/postman/openapi-docs/steering/stoplight-ui.md +0 -21
- package/mcp/powers/postman/steering/steering.md +0 -26
- package/mcp/powers/sentry-automation/POWER.md +0 -235
- package/mcp/powers/sentry-automation/SKILL.md +0 -232
- package/mcp/skills/atlassian-mcp/SKILL.md +0 -88
- package/mcp/skills/atlassian-mcp/references/authentication-patterns.md +0 -520
- package/mcp/skills/atlassian-mcp/references/common-workflows.md +0 -660
- package/mcp/skills/atlassian-mcp/references/confluence-operations.md +0 -528
- package/mcp/skills/atlassian-mcp/references/jira-queries.md +0 -421
- package/mcp/skills/atlassian-mcp/references/mcp-server-setup.md +0 -292
- package/mcp/skills/building-mcp-server-on-cloudflare/SKILL.md +0 -258
- package/mcp/skills/building-mcp-server-on-cloudflare/references/examples.md +0 -115
- package/mcp/skills/building-mcp-server-on-cloudflare/references/oauth-setup.md +0 -338
- package/mcp/skills/building-mcp-server-on-cloudflare/references/tool-patterns.md +0 -29
- package/mcp/skills/building-mcp-server-on-cloudflare/references/troubleshooting.md +0 -317
- package/mcp/skills/datadog-automation/SKILL.md +0 -235
- package/mcp/skills/github-automation/SKILL.md +0 -227
- package/mcp/skills/mcp-builder/LICENSE.txt +0 -202
- package/mcp/skills/mcp-builder/SKILL.md +0 -176
- package/mcp/skills/mcp-builder/reference/evaluation.md +0 -602
- package/mcp/skills/mcp-builder/reference/mcp_best_practices.md +0 -915
- package/mcp/skills/mcp-builder/reference/node_mcp_server.md +0 -916
- package/mcp/skills/mcp-builder/reference/python_mcp_server.md +0 -752
- package/mcp/skills/mcp-builder/scripts/connections.py +0 -151
- package/mcp/skills/mcp-builder/scripts/evaluation.py +0 -373
- package/mcp/skills/mcp-builder/scripts/example_evaluation.xml +0 -22
- package/mcp/skills/mcp-builder/scripts/requirements.txt +0 -2
- package/mcp/skills/mcp-developer/SKILL.md +0 -85
- package/mcp/skills/mcp-developer/references/protocol.md +0 -244
- package/mcp/skills/mcp-developer/references/python-sdk.md +0 -367
- package/mcp/skills/mcp-developer/references/resources.md +0 -554
- package/mcp/skills/mcp-developer/references/tools.md +0 -480
- package/mcp/skills/mcp-developer/references/typescript-sdk.md +0 -350
- package/mcp/skills/postman/POWER.md +0 -242
- package/mcp/skills/postman/SKILL.md +0 -240
- package/mcp/skills/postman/flutter-expert/POWER.md +0 -89
- package/mcp/skills/postman/flutter-expert/SKILL.md +0 -77
- package/mcp/skills/postman/flutter-expert/references/bloc-state.md +0 -259
- package/mcp/skills/postman/flutter-expert/references/engineering-principles.md +0 -82
- package/mcp/skills/postman/flutter-expert/references/gorouter-navigation.md +0 -157
- package/mcp/skills/postman/flutter-expert/references/performance.md +0 -99
- package/mcp/skills/postman/flutter-expert/references/project-structure.md +0 -77
- package/mcp/skills/postman/flutter-expert/references/riverpod-state.md +0 -404
- package/mcp/skills/postman/flutter-expert/references/widget-patterns.md +0 -123
- package/mcp/skills/postman/flutter-security-reviewer/POWER.md +0 -204
- package/mcp/skills/postman/flutter-security-reviewer/SKILL.md +0 -180
- package/mcp/skills/postman/flutter-security-reviewer/references/log_redaction.md +0 -17
- package/mcp/skills/postman/flutter-security-reviewer/references/network_hardening.md +0 -13
- package/mcp/skills/postman/flutter-security-reviewer/references/secret-scanning.md +0 -123
- package/mcp/skills/postman/flutter-security-reviewer/references/secure_storage_policy.md +0 -16
- package/mcp/skills/postman/flutter-security-reviewer/references/vulnerability-patterns.md +0 -189
- package/mcp/skills/postman/flutter-security-reviewer/templates/security_review_response.md +0 -31
- package/mcp/skills/postman/flutter-test-master/POWER.md +0 -527
- package/mcp/skills/postman/flutter-test-master/SKILL.md +0 -513
- package/mcp/skills/postman/flutter-test-master/references/golden-testing.md +0 -444
- package/mcp/skills/postman/flutter-test-master/references/integration-testing.md +0 -688
- package/mcp/skills/postman/flutter-test-master/references/property-testing.md +0 -408
- package/mcp/skills/postman/flutter-test-master/references/riverpod-testing.md +0 -606
- package/mcp/skills/postman/flutter-test-master/references/test-utilities.md +0 -566
- package/mcp/skills/postman/flutter-test-master/references/unit-testing.md +0 -511
- package/mcp/skills/postman/flutter-test-master/references/widget-testing.md +0 -601
- package/mcp/skills/postman/git-commit/POWER.md +0 -47
- package/mcp/skills/postman/git-commit/SKILL.md +0 -46
- package/mcp/skills/postman/gorouter-restoration/POWER.md +0 -227
- package/mcp/skills/postman/gorouter-restoration/SKILL.md +0 -217
- package/mcp/skills/postman/gorouter-restoration/references/guard_patterns.md +0 -14
- package/mcp/skills/postman/gorouter-restoration/references/tab_preservation.md +0 -12
- package/mcp/skills/postman/gorouter-restoration/templates/guard_redirect.md +0 -30
- package/mcp/skills/postman/gorouter-restoration/templates/stateful_shell_skeleton.md +0 -40
- package/mcp/skills/postman/mcp.json +0 -11
- package/mcp/skills/postman/microservices-architect/POWER.md +0 -109
- package/mcp/skills/postman/microservices-architect/SKILL.md +0 -93
- package/mcp/skills/postman/microservices-architect/references/communication.md +0 -499
- package/mcp/skills/postman/microservices-architect/references/data.md +0 -721
- package/mcp/skills/postman/microservices-architect/references/decomposition.md +0 -344
- package/mcp/skills/postman/microservices-architect/references/observability.md +0 -805
- package/mcp/skills/postman/microservices-architect/references/patterns.md +0 -603
- package/mcp/skills/postman/nestjs-expert/POWER.md +0 -130
- package/mcp/skills/postman/nestjs-expert/SKILL.md +0 -114
- package/mcp/skills/postman/nestjs-expert/references/authentication.md +0 -461
- package/mcp/skills/postman/nestjs-expert/references/controllers-routing.md +0 -114
- package/mcp/skills/postman/nestjs-expert/references/dtos-validation.md +0 -156
- package/mcp/skills/postman/nestjs-expert/references/migration-from-express.md +0 -1240
- package/mcp/skills/postman/nestjs-expert/references/secure-sessions.md +0 -56
- package/mcp/skills/postman/nestjs-expert/references/services-di.md +0 -143
- package/mcp/skills/postman/nestjs-expert/references/strangler-fig-pattern.md +0 -47
- package/mcp/skills/postman/nestjs-expert/references/testing-patterns.md +0 -189
- package/mcp/skills/postman/oneup-design/POWER.md +0 -72
- package/mcp/skills/postman/oneup-design/SKILL.md +0 -71
- package/mcp/skills/postman/oneup-design/references/colors.md +0 -41
- package/mcp/skills/postman/oneup-design/references/components.md +0 -53
- package/mcp/skills/postman/oneup-design/references/spacing.md +0 -84
- package/mcp/skills/postman/openapi-docs/POWER.md +0 -78
- package/mcp/skills/postman/openapi-docs/SKILL.md +0 -68
- package/mcp/skills/postman/openapi-docs/references/crud-templates.md +0 -43
- package/mcp/skills/postman/openapi-docs/references/framework-express.md +0 -19
- package/mcp/skills/postman/openapi-docs/references/framework-fastapi.md +0 -20
- package/mcp/skills/postman/openapi-docs/references/framework-nestjs.md +0 -20
- package/mcp/skills/postman/openapi-docs/references/framework-raw-openapi.md +0 -14
- package/mcp/skills/postman/openapi-docs/references/openapi-checklist.md +0 -33
- package/mcp/skills/postman/openapi-docs/references/stoplight-ui.md +0 -21
- package/mcp/skills/postman/references/steering.md +0 -26
- package/mcp/skills/sentry-automation/SKILL.md +0 -232
- package/workflows/powers/atlassian-mcp/POWER.md +0 -21
- package/workflows/powers/atlassian-mcp/SKILL.md +0 -18
- package/workflows/powers/building-mcp-server-on-cloudflare/POWER.md +0 -21
- package/workflows/powers/building-mcp-server-on-cloudflare/SKILL.md +0 -18
- package/workflows/powers/datadog-automation/POWER.md +0 -21
- package/workflows/powers/datadog-automation/SKILL.md +0 -18
- package/workflows/powers/github-automation/POWER.md +0 -21
- package/workflows/powers/github-automation/SKILL.md +0 -18
- package/workflows/powers/mcp-builder/POWER.md +0 -21
- package/workflows/powers/mcp-builder/SKILL.md +0 -18
- package/workflows/powers/mcp-developer/POWER.md +0 -21
- package/workflows/powers/mcp-developer/SKILL.md +0 -18
- package/workflows/powers/postman/POWER.md +0 -21
- package/workflows/powers/postman/SKILL.md +0 -18
- package/workflows/powers/sentry-automation/POWER.md +0 -21
- package/workflows/powers/sentry-automation/SKILL.md +0 -18
- package/workflows/skills/atlassian-mcp/SKILL.md +0 -18
- package/workflows/skills/building-mcp-server-on-cloudflare/SKILL.md +0 -18
- package/workflows/skills/datadog-automation/SKILL.md +0 -18
- package/workflows/skills/github-automation/SKILL.md +0 -18
- package/workflows/skills/mcp-builder/SKILL.md +0 -18
- package/workflows/skills/mcp-developer/SKILL.md +0 -18
- package/workflows/skills/postman/SKILL.md +0 -18
- package/workflows/skills/sentry-automation/SKILL.md +0 -18
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/SKILL.md +0 -88
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/references/authentication-patterns.md +0 -520
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/references/common-workflows.md +0 -660
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/references/confluence-operations.md +0 -528
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/references/jira-queries.md +0 -421
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/atlassian-mcp/references/mcp-server-setup.md +0 -292
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/building-mcp-server-on-cloudflare/SKILL.md +0 -258
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/building-mcp-server-on-cloudflare/references/examples.md +0 -115
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/building-mcp-server-on-cloudflare/references/oauth-setup.md +0 -338
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/building-mcp-server-on-cloudflare/references/tool-patterns.md +0 -29
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/building-mcp-server-on-cloudflare/references/troubleshooting.md +0 -317
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/datadog-automation/SKILL.md +0 -235
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/github-automation/SKILL.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/LICENSE.txt +0 -202
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/SKILL.md +0 -176
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/reference/evaluation.md +0 -602
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/reference/mcp_best_practices.md +0 -915
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/reference/node_mcp_server.md +0 -916
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/reference/python_mcp_server.md +0 -752
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/scripts/connections.py +0 -151
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/scripts/evaluation.py +0 -373
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/scripts/example_evaluation.xml +0 -22
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-builder/scripts/requirements.txt +0 -2
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/SKILL.md +0 -85
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/references/protocol.md +0 -244
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/references/python-sdk.md +0 -367
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/references/resources.md +0 -554
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/references/tools.md +0 -480
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/mcp-developer/references/typescript-sdk.md +0 -350
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/POWER.md +0 -242
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/SKILL.md +0 -240
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/POWER.md +0 -89
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/SKILL.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/bloc-state.md +0 -259
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/engineering-principles.md +0 -82
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/gorouter-navigation.md +0 -157
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/performance.md +0 -99
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/project-structure.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/riverpod-state.md +0 -404
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-expert/references/widget-patterns.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/POWER.md +0 -204
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/SKILL.md +0 -180
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/references/log_redaction.md +0 -17
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/references/network_hardening.md +0 -13
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/references/secret-scanning.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/references/secure_storage_policy.md +0 -16
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/references/vulnerability-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-security-reviewer/templates/security_review_response.md +0 -31
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/POWER.md +0 -527
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/SKILL.md +0 -513
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/golden-testing.md +0 -444
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/integration-testing.md +0 -688
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/property-testing.md +0 -408
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/riverpod-testing.md +0 -606
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/test-utilities.md +0 -566
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/unit-testing.md +0 -511
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/flutter-test-master/references/widget-testing.md +0 -601
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/git-commit/POWER.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/git-commit/SKILL.md +0 -46
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/POWER.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/SKILL.md +0 -217
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/references/guard_patterns.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/references/tab_preservation.md +0 -12
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/templates/guard_redirect.md +0 -30
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/gorouter-restoration/templates/stateful_shell_skeleton.md +0 -40
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/mcp.json +0 -11
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/POWER.md +0 -109
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/SKILL.md +0 -93
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/references/communication.md +0 -499
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/references/data.md +0 -721
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/references/decomposition.md +0 -344
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/references/observability.md +0 -805
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/microservices-architect/references/patterns.md +0 -603
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/POWER.md +0 -130
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/SKILL.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/authentication.md +0 -461
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/controllers-routing.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/dtos-validation.md +0 -156
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/migration-from-express.md +0 -1240
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/secure-sessions.md +0 -56
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/services-di.md +0 -143
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/strangler-fig-pattern.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/nestjs-expert/references/testing-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/oneup-design/POWER.md +0 -72
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/oneup-design/SKILL.md +0 -71
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/oneup-design/references/colors.md +0 -41
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/oneup-design/references/components.md +0 -53
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/oneup-design/references/spacing.md +0 -84
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/POWER.md +0 -78
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/SKILL.md +0 -68
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/crud-templates.md +0 -43
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/framework-express.md +0 -19
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/framework-fastapi.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/framework-nestjs.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/framework-raw-openapi.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/openapi-checklist.md +0 -33
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/openapi-docs/references/stoplight-ui.md +0 -21
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/postman/references/steering.md +0 -26
- package/workflows/workflows/agent-environment-setup/platforms/copilot/skills/sentry-automation/SKILL.md +0 -232
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/SKILL.md +0 -88
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/references/authentication-patterns.md +0 -520
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/references/common-workflows.md +0 -660
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/references/confluence-operations.md +0 -528
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/references/jira-queries.md +0 -421
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/atlassian-mcp/references/mcp-server-setup.md +0 -292
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/building-mcp-server-on-cloudflare/SKILL.md +0 -258
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/building-mcp-server-on-cloudflare/references/examples.md +0 -115
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/building-mcp-server-on-cloudflare/references/oauth-setup.md +0 -338
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/building-mcp-server-on-cloudflare/references/tool-patterns.md +0 -29
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/building-mcp-server-on-cloudflare/references/troubleshooting.md +0 -317
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/datadog-automation/SKILL.md +0 -235
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/github-automation/SKILL.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/LICENSE.txt +0 -202
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/SKILL.md +0 -176
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/reference/evaluation.md +0 -602
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/reference/mcp_best_practices.md +0 -915
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/reference/node_mcp_server.md +0 -916
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/reference/python_mcp_server.md +0 -752
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/scripts/connections.py +0 -151
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/scripts/evaluation.py +0 -373
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/scripts/example_evaluation.xml +0 -22
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-builder/scripts/requirements.txt +0 -2
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/SKILL.md +0 -85
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/references/protocol.md +0 -244
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/references/python-sdk.md +0 -367
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/references/resources.md +0 -554
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/references/tools.md +0 -480
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/mcp-developer/references/typescript-sdk.md +0 -350
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/POWER.md +0 -242
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/SKILL.md +0 -240
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/POWER.md +0 -89
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/SKILL.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/bloc-state.md +0 -259
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/engineering-principles.md +0 -82
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/gorouter-navigation.md +0 -157
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/performance.md +0 -99
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/project-structure.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/riverpod-state.md +0 -404
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-expert/references/widget-patterns.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/POWER.md +0 -204
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/SKILL.md +0 -180
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/references/log_redaction.md +0 -17
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/references/network_hardening.md +0 -13
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/references/secret-scanning.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/references/secure_storage_policy.md +0 -16
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/references/vulnerability-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-security-reviewer/templates/security_review_response.md +0 -31
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/POWER.md +0 -527
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/SKILL.md +0 -513
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/golden-testing.md +0 -444
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/integration-testing.md +0 -688
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/property-testing.md +0 -408
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/riverpod-testing.md +0 -606
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/test-utilities.md +0 -566
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/unit-testing.md +0 -511
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/flutter-test-master/references/widget-testing.md +0 -601
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/git-commit/POWER.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/git-commit/SKILL.md +0 -46
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/POWER.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/SKILL.md +0 -217
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/references/guard_patterns.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/references/tab_preservation.md +0 -12
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/templates/guard_redirect.md +0 -30
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/gorouter-restoration/templates/stateful_shell_skeleton.md +0 -40
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/mcp.json +0 -11
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/POWER.md +0 -109
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/SKILL.md +0 -93
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/references/communication.md +0 -499
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/references/data.md +0 -721
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/references/decomposition.md +0 -344
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/references/observability.md +0 -805
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/microservices-architect/references/patterns.md +0 -603
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/POWER.md +0 -130
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/SKILL.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/authentication.md +0 -461
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/controllers-routing.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/dtos-validation.md +0 -156
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/migration-from-express.md +0 -1240
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/secure-sessions.md +0 -56
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/services-di.md +0 -143
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/strangler-fig-pattern.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/nestjs-expert/references/testing-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/oneup-design/POWER.md +0 -72
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/oneup-design/SKILL.md +0 -71
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/oneup-design/references/colors.md +0 -41
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/oneup-design/references/components.md +0 -53
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/oneup-design/references/spacing.md +0 -84
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/POWER.md +0 -78
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/SKILL.md +0 -68
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/crud-templates.md +0 -43
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/framework-express.md +0 -19
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/framework-fastapi.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/framework-nestjs.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/framework-raw-openapi.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/openapi-checklist.md +0 -33
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/openapi-docs/references/stoplight-ui.md +0 -21
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/postman/references/steering.md +0 -26
- package/workflows/workflows/agent-environment-setup/platforms/cursor/skills/sentry-automation/SKILL.md +0 -232
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/SKILL.md +0 -88
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/references/authentication-patterns.md +0 -520
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/references/common-workflows.md +0 -660
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/references/confluence-operations.md +0 -528
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/references/jira-queries.md +0 -421
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/atlassian-mcp/references/mcp-server-setup.md +0 -292
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/building-mcp-server-on-cloudflare/SKILL.md +0 -258
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/building-mcp-server-on-cloudflare/references/examples.md +0 -115
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/building-mcp-server-on-cloudflare/references/oauth-setup.md +0 -338
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/building-mcp-server-on-cloudflare/references/tool-patterns.md +0 -29
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/building-mcp-server-on-cloudflare/references/troubleshooting.md +0 -317
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/datadog-automation/SKILL.md +0 -235
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/github-automation/SKILL.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/LICENSE.txt +0 -202
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/SKILL.md +0 -176
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/reference/evaluation.md +0 -602
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/reference/mcp_best_practices.md +0 -915
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/reference/node_mcp_server.md +0 -916
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/reference/python_mcp_server.md +0 -752
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/scripts/connections.py +0 -151
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/scripts/evaluation.py +0 -373
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/scripts/example_evaluation.xml +0 -22
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-builder/scripts/requirements.txt +0 -2
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/SKILL.md +0 -85
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/references/protocol.md +0 -244
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/references/python-sdk.md +0 -367
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/references/resources.md +0 -554
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/references/tools.md +0 -480
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/mcp-developer/references/typescript-sdk.md +0 -350
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/POWER.md +0 -242
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/SKILL.md +0 -240
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/POWER.md +0 -89
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/SKILL.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/bloc-state.md +0 -259
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/engineering-principles.md +0 -82
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/gorouter-navigation.md +0 -157
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/performance.md +0 -99
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/project-structure.md +0 -77
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/riverpod-state.md +0 -404
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-expert/references/widget-patterns.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/POWER.md +0 -204
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/SKILL.md +0 -180
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/references/log_redaction.md +0 -17
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/references/network_hardening.md +0 -13
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/references/secret-scanning.md +0 -123
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/references/secure_storage_policy.md +0 -16
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/references/vulnerability-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-security-reviewer/templates/security_review_response.md +0 -31
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/POWER.md +0 -527
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/SKILL.md +0 -513
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/golden-testing.md +0 -444
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/integration-testing.md +0 -688
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/property-testing.md +0 -408
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/riverpod-testing.md +0 -606
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/test-utilities.md +0 -566
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/unit-testing.md +0 -511
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/flutter-test-master/references/widget-testing.md +0 -601
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/git-commit/POWER.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/git-commit/SKILL.md +0 -46
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/POWER.md +0 -227
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/SKILL.md +0 -217
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/references/guard_patterns.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/references/tab_preservation.md +0 -12
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/templates/guard_redirect.md +0 -30
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/gorouter-restoration/templates/stateful_shell_skeleton.md +0 -40
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/mcp.json +0 -11
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/POWER.md +0 -109
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/SKILL.md +0 -93
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/references/communication.md +0 -499
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/references/data.md +0 -721
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/references/decomposition.md +0 -344
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/references/observability.md +0 -805
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/microservices-architect/references/patterns.md +0 -603
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/POWER.md +0 -130
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/SKILL.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/authentication.md +0 -461
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/controllers-routing.md +0 -114
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/dtos-validation.md +0 -156
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/migration-from-express.md +0 -1240
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/secure-sessions.md +0 -56
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/services-di.md +0 -143
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/strangler-fig-pattern.md +0 -47
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/nestjs-expert/references/testing-patterns.md +0 -189
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/oneup-design/POWER.md +0 -72
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/oneup-design/SKILL.md +0 -71
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/oneup-design/references/colors.md +0 -41
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/oneup-design/references/components.md +0 -53
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/oneup-design/references/spacing.md +0 -84
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/POWER.md +0 -78
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/SKILL.md +0 -68
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/crud-templates.md +0 -43
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/framework-express.md +0 -19
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/framework-fastapi.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/framework-nestjs.md +0 -20
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/framework-raw-openapi.md +0 -14
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/openapi-checklist.md +0 -33
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/openapi-docs/references/stoplight-ui.md +0 -21
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/postman/references/steering.md +0 -26
- package/workflows/workflows/agent-environment-setup/platforms/windsurf/skills/sentry-automation/SKILL.md +0 -232
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cubis Foundry MCP Server – cbxConfig writer.
|
|
3
|
+
*
|
|
4
|
+
* Atomic writes: write to temp file, then rename.
|
|
5
|
+
* Mutates only the target field (e.g., postman.mcpUrl or stitch.activeProfileName).
|
|
6
|
+
* Never exposes or logs apiKey.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
readFileSync,
|
|
11
|
+
writeFileSync,
|
|
12
|
+
renameSync,
|
|
13
|
+
mkdirSync,
|
|
14
|
+
existsSync,
|
|
15
|
+
} from "node:fs";
|
|
16
|
+
import path from "node:path";
|
|
17
|
+
import { parse as parseJsonc } from "jsonc-parser";
|
|
18
|
+
import { resolveConfigPath } from "./paths.js";
|
|
19
|
+
import type { CbxConfig, ConfigScope } from "./types.js";
|
|
20
|
+
import { logger } from "../utils/logger.js";
|
|
21
|
+
import { configNotFound } from "../utils/errors.js";
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Set a nested field in cbx_config.json atomically.
|
|
25
|
+
*
|
|
26
|
+
* @param fieldPath - dot-separated path, e.g. "postman.mcpUrl"
|
|
27
|
+
* @param value - the value to set
|
|
28
|
+
* @param scope - config scope to write to
|
|
29
|
+
* @param workspaceRoot - workspace root for project scope
|
|
30
|
+
*/
|
|
31
|
+
export function writeConfigField(
|
|
32
|
+
fieldPath: string,
|
|
33
|
+
value: unknown,
|
|
34
|
+
scope?: ConfigScope | "auto",
|
|
35
|
+
workspaceRoot?: string,
|
|
36
|
+
): { writtenPath: string; scope: ConfigScope } {
|
|
37
|
+
const resolved = resolveConfigPath(scope, workspaceRoot);
|
|
38
|
+
const configPath = resolved.path;
|
|
39
|
+
|
|
40
|
+
// Read existing config or start fresh
|
|
41
|
+
let config: CbxConfig = {};
|
|
42
|
+
if (existsSync(configPath)) {
|
|
43
|
+
try {
|
|
44
|
+
const raw = readFileSync(configPath, "utf8");
|
|
45
|
+
config = parseJsonc(raw) as CbxConfig;
|
|
46
|
+
} catch {
|
|
47
|
+
logger.warn(
|
|
48
|
+
`Cannot parse existing config at ${configPath}, creating new`,
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// Set the nested field
|
|
54
|
+
const parts = fieldPath.split(".");
|
|
55
|
+
let current: Record<string, unknown> = config;
|
|
56
|
+
for (let i = 0; i < parts.length - 1; i++) {
|
|
57
|
+
const key = parts[i];
|
|
58
|
+
if (typeof current[key] !== "object" || current[key] === null) {
|
|
59
|
+
current[key] = {};
|
|
60
|
+
}
|
|
61
|
+
current = current[key] as Record<string, unknown>;
|
|
62
|
+
}
|
|
63
|
+
current[parts[parts.length - 1]] = value;
|
|
64
|
+
|
|
65
|
+
// Atomic write: temp file + rename
|
|
66
|
+
const dir = path.dirname(configPath);
|
|
67
|
+
if (!existsSync(dir)) {
|
|
68
|
+
mkdirSync(dir, { recursive: true });
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const tmpPath = `${configPath}.tmp.${Date.now()}`;
|
|
72
|
+
writeFileSync(tmpPath, JSON.stringify(config, null, 2) + "\n", "utf8");
|
|
73
|
+
renameSync(tmpPath, configPath);
|
|
74
|
+
|
|
75
|
+
logger.debug(`Config field "${fieldPath}" written to ${configPath}`);
|
|
76
|
+
return { writtenPath: configPath, scope: resolved.scope };
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* Verify a config file exists at the resolved path, or throw the exact error message.
|
|
81
|
+
*/
|
|
82
|
+
export function ensureConfigExists(
|
|
83
|
+
scope?: ConfigScope | "auto",
|
|
84
|
+
workspaceRoot?: string,
|
|
85
|
+
): void {
|
|
86
|
+
const resolved = resolveConfigPath(scope, workspaceRoot);
|
|
87
|
+
if (!existsSync(resolved.path)) {
|
|
88
|
+
configNotFound();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { afterEach, describe, expect, it } from "vitest";
|
|
2
|
+
import { mkdtempSync, rmSync, writeFileSync } from "node:fs";
|
|
3
|
+
import os from "node:os";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import { loadServerConfig } from "./index.js";
|
|
6
|
+
import { rejectCredentialFields } from "./schema.js";
|
|
7
|
+
|
|
8
|
+
const tempDirs: string[] = [];
|
|
9
|
+
|
|
10
|
+
function createTempDir(prefix: string): string {
|
|
11
|
+
const dir = mkdtempSync(path.join(os.tmpdir(), prefix));
|
|
12
|
+
tempDirs.push(dir);
|
|
13
|
+
return dir;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
afterEach(() => {
|
|
17
|
+
while (tempDirs.length > 0) {
|
|
18
|
+
const dir = tempDirs.pop();
|
|
19
|
+
if (dir) {
|
|
20
|
+
rmSync(dir, { recursive: true, force: true });
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
describe("config loading", () => {
|
|
26
|
+
it("loads an explicit config file and applies schema defaults", () => {
|
|
27
|
+
const dir = createTempDir("mcp-config-");
|
|
28
|
+
const configPath = path.join(dir, "config.json");
|
|
29
|
+
|
|
30
|
+
writeFileSync(
|
|
31
|
+
configPath,
|
|
32
|
+
JSON.stringify({
|
|
33
|
+
server: { name: "cubis-foundry-mcp", version: "0.1.0" },
|
|
34
|
+
vault: { roots: ["../workflows/skills"] },
|
|
35
|
+
transport: { default: "stdio" },
|
|
36
|
+
}),
|
|
37
|
+
"utf8",
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
const config = loadServerConfig(configPath);
|
|
41
|
+
expect(config.server.name).toBe("cubis-foundry-mcp");
|
|
42
|
+
expect(config.vault.summaryMaxLength).toBe(200);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it("throws for a missing config file", () => {
|
|
46
|
+
expect(() => loadServerConfig("/definitely/missing/config.json")).toThrow(
|
|
47
|
+
"Cannot read server config",
|
|
48
|
+
);
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it("throws for an invalid config shape", () => {
|
|
52
|
+
const dir = createTempDir("mcp-config-invalid-");
|
|
53
|
+
const configPath = path.join(dir, "config.json");
|
|
54
|
+
writeFileSync(configPath, JSON.stringify({ transport: {} }), "utf8");
|
|
55
|
+
|
|
56
|
+
expect(() => loadServerConfig(configPath)).toThrow("Invalid server config");
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
describe("credential field rejection", () => {
|
|
61
|
+
it("rejects forbidden credential keys anywhere in config", () => {
|
|
62
|
+
expect(() =>
|
|
63
|
+
rejectCredentialFields({
|
|
64
|
+
stitch: {
|
|
65
|
+
profiles: {
|
|
66
|
+
production: { apiKey: "secret" },
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
}),
|
|
70
|
+
).toThrow('must not contain credential field "apiKey"');
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it("allows safe non-secret config fields", () => {
|
|
74
|
+
expect(() =>
|
|
75
|
+
rejectCredentialFields({
|
|
76
|
+
server: { name: "ok", version: "1.0.0" },
|
|
77
|
+
vault: { roots: ["../workflows/skills"] },
|
|
78
|
+
}),
|
|
79
|
+
).not.toThrow();
|
|
80
|
+
});
|
|
81
|
+
});
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cubis Foundry MCP Server – config loader.
|
|
3
|
+
*
|
|
4
|
+
* Reads and validates config.json at startup.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { readFileSync } from "node:fs";
|
|
8
|
+
import path from "node:path";
|
|
9
|
+
import { fileURLToPath } from "node:url";
|
|
10
|
+
import {
|
|
11
|
+
ServerConfigSchema,
|
|
12
|
+
rejectCredentialFields,
|
|
13
|
+
type ServerConfig,
|
|
14
|
+
} from "./schema.js";
|
|
15
|
+
import { logger } from "../utils/logger.js";
|
|
16
|
+
|
|
17
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
18
|
+
const PKG_ROOT =
|
|
19
|
+
path.basename(__dirname) === "config"
|
|
20
|
+
? path.resolve(__dirname, "../..")
|
|
21
|
+
: path.resolve(__dirname, "..");
|
|
22
|
+
const DEFAULT_CONFIG_PATH = path.resolve(PKG_ROOT, "config.json");
|
|
23
|
+
|
|
24
|
+
export function loadServerConfig(configPath?: string): ServerConfig {
|
|
25
|
+
const resolved = configPath ?? DEFAULT_CONFIG_PATH;
|
|
26
|
+
logger.debug(`Loading server config from ${resolved}`);
|
|
27
|
+
|
|
28
|
+
let raw: string;
|
|
29
|
+
try {
|
|
30
|
+
raw = readFileSync(resolved, "utf8");
|
|
31
|
+
} catch {
|
|
32
|
+
throw new Error(`Cannot read server config: ${resolved}`);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const parsed = JSON.parse(raw) as Record<string, unknown>;
|
|
36
|
+
|
|
37
|
+
// Security gate: reject credential fields
|
|
38
|
+
rejectCredentialFields(parsed);
|
|
39
|
+
|
|
40
|
+
const result = ServerConfigSchema.safeParse(parsed);
|
|
41
|
+
if (!result.success) {
|
|
42
|
+
throw new Error(`Invalid server config: ${result.error.message}`);
|
|
43
|
+
}
|
|
44
|
+
return result.data;
|
|
45
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cubis Foundry MCP Server – config schema (Zod v4 via zod/v4 import path).
|
|
3
|
+
*
|
|
4
|
+
* Validates the server's own config.json. Rejects credential fields.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { z } from "zod";
|
|
8
|
+
|
|
9
|
+
export const ServerConfigSchema = z.object({
|
|
10
|
+
server: z.object({
|
|
11
|
+
name: z.string(),
|
|
12
|
+
version: z.string(),
|
|
13
|
+
description: z.string().optional(),
|
|
14
|
+
}),
|
|
15
|
+
vault: z.object({
|
|
16
|
+
roots: z.array(z.string()).min(1),
|
|
17
|
+
summaryMaxLength: z.number().int().positive().default(200),
|
|
18
|
+
}),
|
|
19
|
+
transport: z.object({
|
|
20
|
+
default: z.enum(["stdio", "streamable-http"]).default("stdio"),
|
|
21
|
+
http: z
|
|
22
|
+
.object({
|
|
23
|
+
port: z.number().int().positive().default(3100),
|
|
24
|
+
host: z.string().default("127.0.0.1"),
|
|
25
|
+
})
|
|
26
|
+
.optional(),
|
|
27
|
+
}),
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
export type ServerConfig = z.infer<typeof ServerConfigSchema>;
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Keys that must NEVER appear in the server config (security gate).
|
|
34
|
+
* These belong in cbx_config.json, not here.
|
|
35
|
+
*/
|
|
36
|
+
const FORBIDDEN_KEYS = [
|
|
37
|
+
"apiKey",
|
|
38
|
+
"api_key",
|
|
39
|
+
"secret",
|
|
40
|
+
"token",
|
|
41
|
+
"password",
|
|
42
|
+
"credential",
|
|
43
|
+
];
|
|
44
|
+
|
|
45
|
+
export function rejectCredentialFields(raw: Record<string, unknown>): void {
|
|
46
|
+
const json = JSON.stringify(raw);
|
|
47
|
+
for (const key of FORBIDDEN_KEYS) {
|
|
48
|
+
if (json.includes(`"${key}"`)) {
|
|
49
|
+
throw new Error(
|
|
50
|
+
`Server config.json must not contain credential field "${key}". ` +
|
|
51
|
+
`Store credentials in cbx_config.json instead.`,
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cubis Foundry MCP Server – non-secret upstream tool catalog persistence.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { mkdirSync, writeFileSync } from "node:fs";
|
|
6
|
+
import os from "node:os";
|
|
7
|
+
import path from "node:path";
|
|
8
|
+
import type { ConfigScope } from "../cbxConfig/types.js";
|
|
9
|
+
import type { CatalogPayload, UpstreamProvider } from "./types.js";
|
|
10
|
+
|
|
11
|
+
export function resolveCatalogDir(
|
|
12
|
+
scope: ConfigScope | null,
|
|
13
|
+
configPath: string | null,
|
|
14
|
+
): string {
|
|
15
|
+
if (scope === "project" && configPath) {
|
|
16
|
+
return path.join(path.dirname(configPath), ".cbx", "mcp", "catalog");
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
return path.join(os.homedir(), ".cbx", "mcp", "catalog");
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export function catalogFilePath(
|
|
23
|
+
catalogDir: string,
|
|
24
|
+
provider: UpstreamProvider,
|
|
25
|
+
): string {
|
|
26
|
+
return path.join(catalogDir, `${provider}.tools.json`);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function persistCatalog(
|
|
30
|
+
catalogDir: string,
|
|
31
|
+
payload: CatalogPayload,
|
|
32
|
+
): string {
|
|
33
|
+
mkdirSync(catalogDir, { recursive: true });
|
|
34
|
+
const filePath = catalogFilePath(catalogDir, payload.provider);
|
|
35
|
+
writeFileSync(filePath, JSON.stringify(payload, null, 2) + "\n", "utf8");
|
|
36
|
+
return filePath;
|
|
37
|
+
}
|
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cubis Foundry MCP Server – upstream gateway config resolution.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { readEffectiveConfig } from "../cbxConfig/index.js";
|
|
6
|
+
import type {
|
|
7
|
+
ConfigScope,
|
|
8
|
+
ServiceProfile,
|
|
9
|
+
PostmanConfig,
|
|
10
|
+
StitchConfig,
|
|
11
|
+
} from "../cbxConfig/types.js";
|
|
12
|
+
import type { UpstreamConfig, UpstreamProvider } from "./types.js";
|
|
13
|
+
|
|
14
|
+
const STITCH_DEFAULT_MCP_URL = "https://stitch.googleapis.com/mcp";
|
|
15
|
+
|
|
16
|
+
interface ResolvedGatewayConfig {
|
|
17
|
+
scope: ConfigScope | null;
|
|
18
|
+
configPath: string | null;
|
|
19
|
+
providers: Record<UpstreamProvider, UpstreamConfig>;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
interface NamedProfile {
|
|
23
|
+
name: string;
|
|
24
|
+
profile: ServiceProfile;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function isNonEmptyString(value: unknown): value is string {
|
|
28
|
+
return typeof value === "string" && value.trim().length > 0;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function firstString(...values: Array<unknown>): string | null {
|
|
32
|
+
for (const value of values) {
|
|
33
|
+
if (isNonEmptyString(value)) {
|
|
34
|
+
return value.trim();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function normalizeProfiles(
|
|
41
|
+
profiles?: ServiceProfile[] | Record<string, ServiceProfile>,
|
|
42
|
+
): NamedProfile[] {
|
|
43
|
+
if (!profiles) {
|
|
44
|
+
return [];
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
if (Array.isArray(profiles)) {
|
|
48
|
+
return profiles
|
|
49
|
+
.map((profile, index) => ({
|
|
50
|
+
name: firstString(profile.name) ?? `profile_${index + 1}`,
|
|
51
|
+
profile,
|
|
52
|
+
}))
|
|
53
|
+
.filter((entry) => !!entry.profile);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return Object.entries(profiles).map(([name, profile]) => ({
|
|
57
|
+
name,
|
|
58
|
+
profile,
|
|
59
|
+
}));
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function selectActiveProfile(
|
|
63
|
+
profiles: NamedProfile[],
|
|
64
|
+
activeProfileName?: string,
|
|
65
|
+
): NamedProfile | null {
|
|
66
|
+
if (profiles.length === 0) {
|
|
67
|
+
return null;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const active = firstString(activeProfileName);
|
|
71
|
+
if (active) {
|
|
72
|
+
const hit = profiles.find((profile) => profile.name === active);
|
|
73
|
+
if (hit) {
|
|
74
|
+
return hit;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
return profiles[0];
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
function buildPostmanConfig(
|
|
82
|
+
postman: PostmanConfig | undefined,
|
|
83
|
+
scope: ConfigScope | null,
|
|
84
|
+
configPath: string | null,
|
|
85
|
+
): UpstreamConfig {
|
|
86
|
+
const warnings: string[] = [];
|
|
87
|
+
const profiles = normalizeProfiles(postman?.profiles);
|
|
88
|
+
const active = selectActiveProfile(profiles, postman?.activeProfileName);
|
|
89
|
+
|
|
90
|
+
const mcpUrl = firstString(postman?.mcpUrl, active?.profile.mcpUrl, active?.profile.url);
|
|
91
|
+
if (!mcpUrl) {
|
|
92
|
+
warnings.push("Postman MCP URL is not configured (postman.mcpUrl).");
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const authEnvVar = firstString(
|
|
96
|
+
active?.profile.tokenEnvVar,
|
|
97
|
+
active?.profile.apiKeyEnvVar,
|
|
98
|
+
postman?.tokenEnvVar,
|
|
99
|
+
postman?.apiKeyEnvVar,
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
const rawApiKeySet = !!firstString(active?.profile.apiKey);
|
|
103
|
+
if (rawApiKeySet) {
|
|
104
|
+
warnings.push("Postman profile apiKey is ignored; configure apiKeyEnvVar/tokenEnvVar alias instead.");
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if (!authEnvVar) {
|
|
108
|
+
warnings.push("Postman auth env var alias is missing (active profile apiKeyEnvVar/tokenEnvVar).");
|
|
109
|
+
return {
|
|
110
|
+
provider: "postman",
|
|
111
|
+
mcpUrl,
|
|
112
|
+
authHeader: null,
|
|
113
|
+
authEnvVar: null,
|
|
114
|
+
scope,
|
|
115
|
+
configPath,
|
|
116
|
+
warnings,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
const token = process.env[authEnvVar];
|
|
121
|
+
if (!isNonEmptyString(token)) {
|
|
122
|
+
warnings.push(`Postman auth env var \"${authEnvVar}\" is not set.`);
|
|
123
|
+
return {
|
|
124
|
+
provider: "postman",
|
|
125
|
+
mcpUrl,
|
|
126
|
+
authHeader: null,
|
|
127
|
+
authEnvVar,
|
|
128
|
+
scope,
|
|
129
|
+
configPath,
|
|
130
|
+
warnings,
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
return {
|
|
135
|
+
provider: "postman",
|
|
136
|
+
mcpUrl,
|
|
137
|
+
authHeader: { Authorization: `Bearer ${token}` },
|
|
138
|
+
authEnvVar,
|
|
139
|
+
scope,
|
|
140
|
+
configPath,
|
|
141
|
+
warnings,
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
function buildStitchConfig(
|
|
146
|
+
stitch: StitchConfig | undefined,
|
|
147
|
+
scope: ConfigScope | null,
|
|
148
|
+
configPath: string | null,
|
|
149
|
+
): UpstreamConfig {
|
|
150
|
+
const warnings: string[] = [];
|
|
151
|
+
const profiles = normalizeProfiles(stitch?.profiles);
|
|
152
|
+
const active = selectActiveProfile(profiles, stitch?.activeProfileName);
|
|
153
|
+
|
|
154
|
+
const mcpUrl =
|
|
155
|
+
firstString(stitch?.mcpUrl, active?.profile.mcpUrl, active?.profile.url) ??
|
|
156
|
+
STITCH_DEFAULT_MCP_URL;
|
|
157
|
+
|
|
158
|
+
const authEnvVar = firstString(active?.profile.apiKeyEnvVar, stitch?.apiKeyEnvVar);
|
|
159
|
+
|
|
160
|
+
const rawApiKeySet = !!firstString(active?.profile.apiKey);
|
|
161
|
+
if (rawApiKeySet) {
|
|
162
|
+
warnings.push("Stitch profile apiKey is ignored; configure apiKeyEnvVar alias instead.");
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
if (!authEnvVar) {
|
|
166
|
+
warnings.push("Stitch auth env var alias is missing (active profile apiKeyEnvVar).");
|
|
167
|
+
return {
|
|
168
|
+
provider: "stitch",
|
|
169
|
+
mcpUrl,
|
|
170
|
+
authHeader: null,
|
|
171
|
+
authEnvVar: null,
|
|
172
|
+
scope,
|
|
173
|
+
configPath,
|
|
174
|
+
warnings,
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
const apiKey = process.env[authEnvVar];
|
|
179
|
+
if (!isNonEmptyString(apiKey)) {
|
|
180
|
+
warnings.push(`Stitch auth env var \"${authEnvVar}\" is not set.`);
|
|
181
|
+
return {
|
|
182
|
+
provider: "stitch",
|
|
183
|
+
mcpUrl,
|
|
184
|
+
authHeader: null,
|
|
185
|
+
authEnvVar,
|
|
186
|
+
scope,
|
|
187
|
+
configPath,
|
|
188
|
+
warnings,
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
return {
|
|
193
|
+
provider: "stitch",
|
|
194
|
+
mcpUrl,
|
|
195
|
+
authHeader: { "X-Goog-Api-Key": apiKey },
|
|
196
|
+
authEnvVar,
|
|
197
|
+
scope,
|
|
198
|
+
configPath,
|
|
199
|
+
warnings,
|
|
200
|
+
};
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
export function resolveGatewayConfig(
|
|
204
|
+
scope: ConfigScope | "auto" = "auto",
|
|
205
|
+
): ResolvedGatewayConfig {
|
|
206
|
+
const effective = readEffectiveConfig(scope);
|
|
207
|
+
|
|
208
|
+
if (!effective) {
|
|
209
|
+
const warning =
|
|
210
|
+
"cbx_config.json not found. Configure Postman/Stitch profiles to enable upstream passthrough.";
|
|
211
|
+
return {
|
|
212
|
+
scope: null,
|
|
213
|
+
configPath: null,
|
|
214
|
+
providers: {
|
|
215
|
+
postman: {
|
|
216
|
+
provider: "postman",
|
|
217
|
+
mcpUrl: null,
|
|
218
|
+
authHeader: null,
|
|
219
|
+
authEnvVar: null,
|
|
220
|
+
scope: null,
|
|
221
|
+
configPath: null,
|
|
222
|
+
warnings: [warning],
|
|
223
|
+
},
|
|
224
|
+
stitch: {
|
|
225
|
+
provider: "stitch",
|
|
226
|
+
mcpUrl: STITCH_DEFAULT_MCP_URL,
|
|
227
|
+
authHeader: null,
|
|
228
|
+
authEnvVar: null,
|
|
229
|
+
scope: null,
|
|
230
|
+
configPath: null,
|
|
231
|
+
warnings: [warning],
|
|
232
|
+
},
|
|
233
|
+
},
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
return {
|
|
238
|
+
scope: effective.scope,
|
|
239
|
+
configPath: effective.path,
|
|
240
|
+
providers: {
|
|
241
|
+
postman: buildPostmanConfig(effective.config.postman, effective.scope, effective.path),
|
|
242
|
+
stitch: buildStitchConfig(effective.config.stitch, effective.scope, effective.path),
|
|
243
|
+
},
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
export { STITCH_DEFAULT_MCP_URL };
|