{"ok":true,"data":{"service":"mcp","readyForAgentUiDemo":true,"checks":[{"id":"root-topology-to-mcp","label":"Root graph discovery","status":"degraded","publicSafe":true,"authRequired":false,"evidence":["https://platphormnews.com/api/network/graph","https://mcp.platphormnews.com/api/v1/discovery/sites"]},{"id":"mcp-registry-to-agentui","label":"Tool schema rendering","status":"ready","publicSafe":true,"authRequired":false,"evidence":["tools/list","resources/list","prompts/list"]},{"id":"mcp-to-spec-contract","label":"Contract validation","status":"ready","publicSafe":true,"authRequired":true,"evidence":["openapi.yaml","asyncapi.yaml",".well-known/mcp.json"]},{"id":"mcp-to-sandbox-dry-run","label":"Bounded dry-run","status":"ready","publicSafe":false,"authRequired":true,"evidence":["factory draft tool","handoff envelope","trace context"]},{"id":"mcp-to-evals-gate","label":"Release gate scoring","status":"ready","publicSafe":false,"authRequired":true,"evidence":["eval manifest","public-safe scorecard","release gate state"]}],"requiredFixes":["Run the MCP 2025 initialize, initialized, tools/list, and list_network_sites flow from the client page.","Open AgentUI with the MCP tools/list schema and verify the operator workflow renders without secrets.","Use the protected dry-run buttons only with PLATPHORM_API_KEY stored in the operator environment.","Record downstream confirmation from Spec, Sandbox, and Evals before calling a handoff completed."],"degraded":false,"source":"/api/v1/demo/suite","readiness":{"schemaVersion":"platphorm.demo-readiness.v1","generatedAt":"2026-06-05T22:37:32.808Z","purpose":"Public-safe demo readiness for the Root -> MCP -> AgentUI -> Spec -> Sandbox -> Evals workflow. Handoffs are dry-run envelopes unless a downstream service confirms execution.","protocol":{"version":"2024-11-05","supportedVersions":["2025-06-18","2024-11-05"],"transport":"streamable-http"},"score":94,"classification":"demo ready","counts":{"localCallableTools":140,"resources":16,"prompts":23,"services":6,"activeServices":5,"degradedServices":1,"unavailableServices":0,"handoffs":5,"protectedHandoffs":5},"services":[{"serviceId":"root","name":"PlatPhormNews Root","canonicalUrl":"https://platphormnews.com","purpose":"Root network control plane and topology source.","demoRole":"Publishes the network graph and public policy surfaces MCP uses as topology truth.","ownedEvidence":"Network graph, public manifest, sitemap, trust policy, and route standard.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","llmsIndex","trust","sitemap","robots"],"requiredArtifactKeys":["health","llmsIndex","trust"],"protectedAction":{"label":"Request root graph refresh","capability":"root.network_graph_refresh","endpoint":"https://platphormnews.com/api/network/graph"},"handoffIntent":"Ask the root control plane to refresh or confirm the network graph source used by MCP discovery.","demoNarration":"Start the demo by showing root topology as the source of network truth.","artifacts":[{"key":"health","url":"https://platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.878Z","summary":{"readable":true,"status":"ok","version":"0.0.4"}},{"key":"apiDocs","url":"https://platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.891Z","summary":{"readable":true,"keys":["openapi","info","servers","tags","paths","components"]}},{"key":"openapiJson","url":"https://platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.894Z","summary":{"readable":true,"title":"PlatPhorm News Root API","version":"0.0.4","pathCount":83}},{"key":"openapiYaml","url":"https://platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:32.895Z","summary":{"readable":true,"format":"yaml","pathCount":40}},{"key":"llmsIndex","url":"https://platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:32.990Z","summary":{"readable":true,"service":"PlatPhorm News"}},{"key":"trust","url":"https://platphormnews.com/.well-known/trust.json","status":"unavailable","ok":false,"httpStatus":null,"contentType":null,"bytes":null,"checkedAt":"2026-06-05T22:37:32.994Z","error":"The operation was aborted due to timeout"},{"key":"sitemap","url":"https://platphormnews.com/sitemap.xml","status":"active","ok":true,"httpStatus":200,"contentType":"application/xml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:33.004Z","summary":{"readable":true,"urlCount":57}},{"key":"robots","url":"https://platphormnews.com/robots.txt","status":"active","ok":true,"httpStatus":200,"contentType":"text/plain; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:33.018Z","summary":{"readable":true,"format":"text","length":1661}}],"artifactSummary":{"status":"degraded","checkedAt":"2026-06-05T22:37:34.798Z","active":7,"degraded":0,"unavailable":1,"total":8,"requiredActive":2,"confidence":0.81},"status":"degraded","lastCheckedAt":"2026-06-05T22:37:34.798Z"},{"serviceId":"mcp","name":"MCP","canonicalUrl":"https://mcp.platphormnews.com","purpose":"Canonical capability registry and delegation broker.","demoRole":"Lists tools, resources, prompts, generated drafts, policies, and trace-linked handoff envelopes.","ownedEvidence":"MCP endpoint, tools/list, registry counts, gateway policy, and discovery manifests.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","mcpEndpoint","mcpManifest","llmsIndex","trust"],"requiredArtifactKeys":["health","mcpManifest","llmsIndex","trust"],"protectedAction":{"label":"Run protected MCP delegation","capability":"mcp.protected_delegation","endpoint":"https://mcp.platphormnews.com/api/v1/gateway/call"},"handoffIntent":"Create a trace-linked MCP delegation envelope while preserving public/protected boundaries.","demoNarration":"Use MCP as the hub, not as a replacement for the downstream tools.","artifacts":[{"key":"health","url":"https://mcp.platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.897Z","summary":{"readable":true,"status":"healthy","version":"0.1.0","tools":140,"resources":16,"prompts":23,"redis":"connected","dynamodb":"degraded"}},{"key":"apiDocs","url":"https://mcp.platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.898Z","summary":{"readable":true,"keys":["name","version","description","protocolVersion","supportedProtocolVersions","transport","stats","tools","toolsByCategory","resources","prompts","endpoints"]}},{"key":"openapiJson","url":"https://mcp.platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.899Z","summary":{"readable":true,"title":"PlatPhormNews MCP Gateway API","version":"0.1.0","pathCount":51}},{"key":"openapiYaml","url":"https://mcp.platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:32.900Z","summary":{"readable":true,"format":"yaml","pathCount":52}},{"key":"mcpEndpoint","url":"https://mcp.platphormnews.com/api/mcp","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:34.040Z","summary":{"readable":true,"keys":["name","version","protocol","protocolVersion","supportedProtocolVersions","transport","endpoint","capabilities","security","network","links","connection"]}},{"key":"mcpManifest","url":"https://mcp.platphormnews.com/.well-known/mcp.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:34.118Z","summary":{"readable":true,"name":"platphormnews-mcp","protocolVersion":"2024-11-05","tools":140,"resources":16,"prompts":23}},{"key":"llmsIndex","url":"https://mcp.platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:34.119Z","summary":{"readable":true,"service":"mcp","counts":{"tools":140,"resources":16,"prompts":23,"categories":16,"registeredSites":142,"generatedTools":11,"draftTools":11,"protectedTools":39,"publicTools":101,"degradedTools":11,"integrations":11,"policyPlatforms":12,"mcpClientsSupported":13,"evals":11,"sandboxTests":11,"browserOpsTests":11},"tools":140,"resources":16,"prompts":23}},{"key":"trust","url":"https://mcp.platphormnews.com/.well-known/trust.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:34.147Z","summary":{"readable":true,"keys":["version","serviceVersion","schema","issuer","baseUrl","issuedAt","publicSafeAccessEnabled","productPurpose","counts","auth","publicProtectedBoundary","trustedDomains"]}}],"artifactSummary":{"status":"active","checkedAt":"2026-06-05T22:37:34.285Z","active":8,"degraded":0,"unavailable":0,"total":8,"requiredActive":4,"confidence":1},"status":"active","lastCheckedAt":"2026-06-05T22:37:34.285Z"},{"serviceId":"agentui","name":"AgentUI","canonicalUrl":"https://agentui.platphormnews.com","purpose":"Human-facing workflow orchestration and tool UI renderer.","demoRole":"Renders MCP schemas as operator workflow panels and shows current step state.","ownedEvidence":"Workflow UI, tool form rendering, public workflow templates, and protected action shell.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","mcpManifest","llmsIndex","trust"],"requiredArtifactKeys":["health","llmsIndex","trust"],"protectedAction":{"label":"Open workflow preview","capability":"agentui.workflow_preview","endpoint":"https://agentui.platphormnews.com/api/v1/workflows"},"handoffIntent":"Ask AgentUI to render MCP tool schemas and present a demo workflow without executing protected tools.","demoNarration":"Show the human operator view after MCP discovers the available capabilities.","artifacts":[{"key":"health","url":"https://agentui.platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.901Z","summary":{"readable":true,"status":"healthy","version":"0.1.0"}},{"key":"apiDocs","url":"https://agentui.platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.905Z","summary":{"readable":true,"keys":["ok","data"]}},{"key":"openapiJson","url":"https://agentui.platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:32.906Z","summary":{"readable":true,"title":"PlatPhorm AgentUI","version":"0.1.0","pathCount":124}},{"key":"openapiYaml","url":"https://agentui.platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:32.908Z","summary":{"readable":true,"format":"yaml","pathCount":124}},{"key":"mcpManifest","url":"https://agentui.platphormnews.com/.well-known/mcp.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.044Z","summary":{"readable":true,"name":"agentui"}},{"key":"llmsIndex","url":"https://agentui.platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.068Z","summary":{"readable":true,"service":"agentui"}},{"key":"trust","url":"https://agentui.platphormnews.com/.well-known/trust.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.116Z","summary":{"readable":true,"keys":["service","auth","domainAllowlist","publicAccess","protectedAccess","vercelMetadataPolicy","tracePropagationPolicy","publicAccessSummary","protectedActionSummary","aiPolicy","agentPolicy","xVercelJa4DigestPolicy"]}}],"artifactSummary":{"status":"active","checkedAt":"2026-06-05T22:37:33.236Z","active":7,"degraded":0,"unavailable":0,"total":7,"requiredActive":3,"confidence":1},"status":"active","lastCheckedAt":"2026-06-05T22:37:33.236Z"},{"serviceId":"spec","name":"Spec","canonicalUrl":"https://spec.platphormnews.com","purpose":"Contract truth engine for OpenAPI, AsyncAPI, JSON Schema, MCP, webhook, event, and envelope contracts.","demoRole":"Validates MCP schemas, OpenAPI contracts, AsyncAPI events, and handoff envelopes.","ownedEvidence":"Contract reports, schema checks, OpenAPI/AsyncAPI validation, and spec remediation notes.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","mcpManifest","llmsIndex","trust"],"requiredArtifactKeys":["health","openapiYaml","llmsIndex","trust"],"protectedAction":{"label":"Validate MCP registry contracts","capability":"spec.validate_mcp_registry_contracts","endpoint":"https://spec.platphormnews.com/api/v1/validate"},"handoffIntent":"Send the MCP registry and handoff envelope schema bundle to Spec for contract validation.","demoNarration":"Prove the tool schemas are contract-backed before execution is considered.","artifacts":[{"key":"health","url":"https://spec.platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.236Z","summary":{"readable":true,"status":"healthy","version":"0.1.0"}},{"key":"apiDocs","url":"https://spec.platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.237Z","summary":{"readable":true,"keys":["openapi","info","servers","security","tags","paths","components"]}},{"key":"openapiJson","url":"https://spec.platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.238Z","summary":{"readable":true,"title":"Spec Workbench API","version":"0.1.0","pathCount":132}},{"key":"openapiYaml","url":"https://spec.platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:33.239Z","summary":{"readable":true,"format":"yaml","pathCount":132}},{"key":"mcpManifest","url":"https://spec.platphormnews.com/.well-known/mcp.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.305Z","summary":{"readable":true,"name":"spec-workbench"}},{"key":"llmsIndex","url":"https://spec.platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.306Z","summary":{"readable":true,"service":"spec-workbench","tools":28,"resources":11,"prompts":8}},{"key":"trust","url":"https://spec.platphormnews.com/.well-known/trust.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.329Z","summary":{"readable":true,"keys":["service","baseUrl","auth","publicReadOnlyAccess","protectedActions","trustedDomains","routeStandard","vercelMetadataPolicy","tracePropagationPolicy","dataExposurePolicy","securityContact","policy"]}}],"artifactSummary":{"status":"active","checkedAt":"2026-06-05T22:37:33.536Z","active":7,"degraded":0,"unavailable":0,"total":7,"requiredActive":4,"confidence":1},"status":"active","lastCheckedAt":"2026-06-05T22:37:33.536Z"},{"serviceId":"sandbox","name":"Sandbox","canonicalUrl":"https://sandbox.platphormnews.com","purpose":"Bounded execution and artifact validation.","demoRole":"Receives generated draft tools for dry-run execution and artifact checks.","ownedEvidence":"Dry-run manifests, bounded execution envelopes, logs, and public-safe artifact summaries.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","mcpManifest","llmsIndex","trust"],"requiredArtifactKeys":["health","llmsIndex","trust"],"protectedAction":{"label":"Run bounded dry-run","capability":"sandbox.run_bounded_dry_run","endpoint":"https://sandbox.platphormnews.com/api/v1/runs"},"handoffIntent":"Send a generated draft tool to Sandbox for bounded dry-run validation after auth is satisfied.","demoNarration":"Show that protected execution is delegated, bounded, and never faked by MCP.","artifacts":[{"key":"health","url":"https://sandbox.platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.536Z","summary":{"readable":true}},{"key":"apiDocs","url":"https://sandbox.platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.537Z","summary":{"readable":true,"keys":["openapi","info","servers","components","paths","ok","data"]}},{"key":"openapiJson","url":"https://sandbox.platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.538Z","summary":{"readable":true,"title":"PlatPhorm Sandbox API","version":"2.0.0-phase2","pathCount":76}},{"key":"openapiYaml","url":"https://sandbox.platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:33.539Z","summary":{"readable":true,"format":"yaml","pathCount":76}},{"key":"mcpManifest","url":"https://sandbox.platphormnews.com/.well-known/mcp.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.599Z","summary":{"readable":true,"protocolVersion":"2024-11-05"}},{"key":"llmsIndex","url":"https://sandbox.platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.634Z","summary":{"readable":true,"service":"platphorm-sandbox","tools":102,"resources":35,"prompts":15}},{"key":"trust","url":"https://sandbox.platphormnews.com/.well-known/trust.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.636Z","summary":{"readable":true,"keys":["schema_version","service","baseUrl","policy","auth","publicReadOnlyAccess","protectedActions","localDraftPersistencePolicy","trustedDomainPolicy","routeStandard","vercelMetadataPolicy","tracePropagationPolicy"]}}],"artifactSummary":{"status":"active","checkedAt":"2026-06-05T22:37:33.786Z","active":7,"degraded":0,"unavailable":0,"total":7,"requiredActive":3,"confidence":1},"status":"active","lastCheckedAt":"2026-06-05T22:37:33.786Z"},{"serviceId":"evals","name":"Evals","canonicalUrl":"https://evals.platphormnews.com","purpose":"Scorecards, release gates, and quality decisions.","demoRole":"Scores tool readiness and returns pass/fail/partial gate state for release decisions.","ownedEvidence":"Eval suites, readiness scorecards, release gates, and quality reports.","publicArtifactKeys":["health","apiDocs","openapiJson","openapiYaml","mcpManifest","llmsIndex","trust"],"requiredArtifactKeys":["health","llmsIndex","trust"],"protectedAction":{"label":"Run MCP readiness eval","capability":"evals.run_mcp_readiness_eval","endpoint":"https://evals.platphormnews.com/api/v1/evals/run"},"handoffIntent":"Submit the MCP registry and generated tool evidence package to Evals for scoring after auth is satisfied.","demoNarration":"Close the demo with a release-gate decision instead of a vague success message.","artifacts":[{"key":"health","url":"https://evals.platphormnews.com/api/health","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.786Z","summary":{"readable":true}},{"key":"apiDocs","url":"https://evals.platphormnews.com/api/docs","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.787Z","summary":{"readable":true,"keys":["ok","data"]}},{"key":"openapiJson","url":"https://evals.platphormnews.com/openapi.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.788Z","summary":{"readable":true,"title":"PlatPhorm Evals","version":"0.1.0","pathCount":152}},{"key":"openapiYaml","url":"https://evals.platphormnews.com/openapi.yaml","status":"active","ok":true,"httpStatus":200,"contentType":"application/yaml; charset=utf-8","bytes":0,"checkedAt":"2026-06-05T22:37:33.788Z","summary":{"readable":true,"format":"yaml","pathCount":0}},{"key":"mcpManifest","url":"https://evals.platphormnews.com/.well-known/mcp.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.840Z","summary":{"readable":true,"name":"platphorm-evals"}},{"key":"llmsIndex","url":"https://evals.platphormnews.com/llms-index.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.873Z","summary":{"readable":true,"service":"evals","counts":{"servicesTracked":217,"activeSuites":36,"capabilitiesIndexed":1010,"evalRunsToday":0,"source":"merged","degradedReason":null},"tools":100,"resources":17,"prompts":13}},{"key":"trust","url":"https://evals.platphormnews.com/.well-known/trust.json","status":"active","ok":true,"httpStatus":200,"contentType":"application/json","bytes":0,"checkedAt":"2026-06-05T22:37:33.907Z","summary":{"readable":true,"keys":["schema_version","service","auth","publicAccess","publicReadAccess","protectedActions","trustedDomains","dataExposureBoundaries","policy","provenancePolicy","agentVerificationPolicy"]}}],"artifactSummary":{"status":"active","checkedAt":"2026-06-05T22:37:34.043Z","active":7,"degraded":0,"unavailable":0,"total":7,"requiredActive":3,"confidence":1},"status":"active","lastCheckedAt":"2026-06-05T22:37:34.043Z"}],"workflow":[{"id":"root-topology-to-mcp","order":1,"title":"Root graph discovery","from":"root","to":"mcp","transport":"public_get","status":"degraded","publicSafe":true,"authRequired":false,"downstreamExecutionClaimed":false,"evidence":["https://platphormnews.com/api/network/graph","https://mcp.platphormnews.com/api/v1/discovery/sites"],"operatorCue":"Show that MCP reads the root topology and labels source drift instead of inventing site counts."},{"id":"mcp-registry-to-agentui","order":2,"title":"Tool schema rendering","from":"mcp","to":"agentui","transport":"mcp","status":"ready","publicSafe":true,"authRequired":false,"downstreamExecutionClaimed":false,"evidence":["tools/list","resources/list","prompts/list"],"operatorCue":"Render the selected MCP tool schema in AgentUI before any protected execution."},{"id":"mcp-to-spec-contract","order":3,"title":"Contract validation","from":"mcp","to":"spec","transport":"handoff","status":"ready","publicSafe":true,"authRequired":true,"downstreamExecutionClaimed":false,"evidence":["openapi.yaml","asyncapi.yaml",".well-known/mcp.json"],"operatorCue":"Send a protected dry-run handoff to Spec only when the operator key is present."},{"id":"mcp-to-sandbox-dry-run","order":4,"title":"Bounded dry-run","from":"mcp","to":"sandbox","transport":"handoff","status":"ready","publicSafe":false,"authRequired":true,"downstreamExecutionClaimed":false,"evidence":["factory draft tool","handoff envelope","trace context"],"operatorCue":"Use Sandbox for bounded execution evidence; MCP should not claim execution itself."},{"id":"mcp-to-evals-gate","order":5,"title":"Release gate scoring","from":"mcp","to":"evals","transport":"handoff","status":"ready","publicSafe":false,"authRequired":true,"downstreamExecutionClaimed":false,"evidence":["eval manifest","public-safe scorecard","release gate state"],"operatorCue":"Evals owns the scorecard. MCP records the handoff and waits for confirmed results."}],"handoffs":[{"schemaVersion":"platphorm.handoff.v1","id":"handoff_fa0194cb-ce20-4756-a302-09e37c7c2735","workflowId":"mcp-suite-dry-run","from":"mcp","to":"root","capability":"root.network_graph_refresh","intent":"Ask the root control plane to refresh or confirm the network graph source used by MCP discovery.","transport":"openapi","auth":{"required":true,"satisfied":false,"mode":"none"},"trace":{"traceId":"be16eec0-13cb-43ef-8a04-bc07fd4c7f69","spanId":"6518cd9f692e4eb6","traceUrl":"https://trace.platphormnews.com/traces/be16eec0-13cb-43ef-8a04-bc07fd4c7f69"},"input":{"payload":{"demo":true,"targetUrl":"https://platphormnews.com","protectedEndpoint":"https://platphormnews.com/api/network/graph","publicEvidence":[{"key":"health","url":"https://platphormnews.com/api/health","status":"active","httpStatus":200},{"key":"apiDocs","url":"https://platphormnews.com/api/docs","status":"active","httpStatus":200},{"key":"openapiJson","url":"https://platphormnews.com/openapi.json","status":"active","httpStatus":200},{"key":"openapiYaml","url":"https://platphormnews.com/openapi.yaml","status":"active","httpStatus":200},{"key":"llmsIndex","url":"https://platphormnews.com/llms-index.json","status":"active","httpStatus":200},{"key":"trust","url":"https://platphormnews.com/.well-known/trust.json","status":"unavailable","httpStatus":null},{"key":"sitemap","url":"https://platphormnews.com/sitemap.xml","status":"active","httpStatus":200},{"key":"robots","url":"https://platphormnews.com/robots.txt","status":"active","httpStatus":200}],"downstreamExecutionClaimed":false},"redaction":"public_safe"},"expectedOutput":{"type":"public_safe_evidence_summary","required":true},"status":"protected_required","createdAt":"2026-06-05T22:37:34.798Z","updatedAt":"2026-06-05T22:37:34.798Z","downstreamExecutionClaimed":false,"demoSafe":true},{"schemaVersion":"platphorm.handoff.v1","id":"handoff_712b1df3-6e66-4ddc-9852-3b8b1bd62c4c","workflowId":"mcp-suite-dry-run","from":"mcp","to":"agentui","capability":"agentui.workflow_preview","intent":"Ask AgentUI to render MCP tool schemas and present a demo workflow without executing protected tools.","transport":"mcp","auth":{"required":true,"satisfied":false,"mode":"none"},"trace":{"traceId":"834d75a4-6b79-4a7d-b8c1-23166bdf1ff4","spanId":"fe73ad1578f24075","traceUrl":"https://trace.platphormnews.com/traces/834d75a4-6b79-4a7d-b8c1-23166bdf1ff4"},"input":{"payload":{"demo":true,"targetUrl":"https://agentui.platphormnews.com","protectedEndpoint":"https://agentui.platphormnews.com/api/v1/workflows","publicEvidence":[{"key":"health","url":"https://agentui.platphormnews.com/api/health","status":"active","httpStatus":200},{"key":"apiDocs","url":"https://agentui.platphormnews.com/api/docs","status":"active","httpStatus":200},{"key":"openapiJson","url":"https://agentui.platphormnews.com/openapi.json","status":"active","httpStatus":200},{"key":"openapiYaml","url":"https://agentui.platphormnews.com/openapi.yaml","status":"active","httpStatus":200},{"key":"mcpManifest","url":"https://agentui.platphormnews.com/.well-known/mcp.json","status":"active","httpStatus":200},{"key":"llmsIndex","url":"https://agentui.platphormnews.com/llms-index.json","status":"active","httpStatus":200},{"key":"trust","url":"https://agentui.platphormnews.com/.well-known/trust.json","status":"active","httpStatus":200}],"downstreamExecutionClaimed":false},"redaction":"public_safe"},"expectedOutput":{"type":"public_safe_evidence_summary","required":true},"status":"protected_required","createdAt":"2026-06-05T22:37:34.799Z","updatedAt":"2026-06-05T22:37:34.799Z","downstreamExecutionClaimed":false,"demoSafe":true},{"schemaVersion":"platphorm.handoff.v1","id":"handoff_da9de244-c44c-4fb7-aef9-57e64739dc42","workflowId":"mcp-suite-dry-run","from":"mcp","to":"spec","capability":"spec.validate_mcp_registry_contracts","intent":"Send the MCP registry and handoff envelope schema bundle to Spec for contract validation.","transport":"mcp","auth":{"required":true,"satisfied":false,"mode":"none"},"trace":{"traceId":"44563c73-d61d-479e-be18-90d45e1c6129","spanId":"7960a1f9e4914a0e","traceUrl":"https://trace.platphormnews.com/traces/44563c73-d61d-479e-be18-90d45e1c6129"},"input":{"payload":{"demo":true,"targetUrl":"https://spec.platphormnews.com","protectedEndpoint":"https://spec.platphormnews.com/api/v1/validate","publicEvidence":[{"key":"health","url":"https://spec.platphormnews.com/api/health","status":"active","httpStatus":200},{"key":"apiDocs","url":"https://spec.platphormnews.com/api/docs","status":"active","httpStatus":200},{"key":"openapiJson","url":"https://spec.platphormnews.com/openapi.json","status":"active","httpStatus":200},{"key":"openapiYaml","url":"https://spec.platphormnews.com/openapi.yaml","status":"active","httpStatus":200},{"key":"mcpManifest","url":"https://spec.platphormnews.com/.well-known/mcp.json","status":"active","httpStatus":200},{"key":"llmsIndex","url":"https://spec.platphormnews.com/llms-index.json","status":"active","httpStatus":200},{"key":"trust","url":"https://spec.platphormnews.com/.well-known/trust.json","status":"active","httpStatus":200}],"downstreamExecutionClaimed":false},"redaction":"public_safe"},"expectedOutput":{"type":"public_safe_evidence_summary","required":true},"status":"protected_required","createdAt":"2026-06-05T22:37:34.799Z","updatedAt":"2026-06-05T22:37:34.799Z","downstreamExecutionClaimed":false,"demoSafe":true},{"schemaVersion":"platphorm.handoff.v1","id":"handoff_51a17d63-5cbe-4df1-94c5-29bb274fa97d","workflowId":"mcp-suite-dry-run","from":"mcp","to":"sandbox","capability":"sandbox.run_bounded_dry_run","intent":"Send a generated draft tool to Sandbox for bounded dry-run validation after auth is satisfied.","transport":"mcp","auth":{"required":true,"satisfied":false,"mode":"none"},"trace":{"traceId":"7bdefffe-2bb3-476a-86cf-033c80d39ae5","spanId":"7d2e1aa49d414112","traceUrl":"https://trace.platphormnews.com/traces/7bdefffe-2bb3-476a-86cf-033c80d39ae5"},"input":{"payload":{"demo":true,"targetUrl":"https://sandbox.platphormnews.com","protectedEndpoint":"https://sandbox.platphormnews.com/api/v1/runs","publicEvidence":[{"key":"health","url":"https://sandbox.platphormnews.com/api/health","status":"active","httpStatus":200},{"key":"apiDocs","url":"https://sandbox.platphormnews.com/api/docs","status":"active","httpStatus":200},{"key":"openapiJson","url":"https://sandbox.platphormnews.com/openapi.json","status":"active","httpStatus":200},{"key":"openapiYaml","url":"https://sandbox.platphormnews.com/openapi.yaml","status":"active","httpStatus":200},{"key":"mcpManifest","url":"https://sandbox.platphormnews.com/.well-known/mcp.json","status":"active","httpStatus":200},{"key":"llmsIndex","url":"https://sandbox.platphormnews.com/llms-index.json","status":"active","httpStatus":200},{"key":"trust","url":"https://sandbox.platphormnews.com/.well-known/trust.json","status":"active","httpStatus":200}],"downstreamExecutionClaimed":false},"redaction":"public_safe"},"expectedOutput":{"type":"public_safe_evidence_summary","required":true},"status":"protected_required","createdAt":"2026-06-05T22:37:34.799Z","updatedAt":"2026-06-05T22:37:34.799Z","downstreamExecutionClaimed":false,"demoSafe":true},{"schemaVersion":"platphorm.handoff.v1","id":"handoff_92cfb54e-c4b6-4ed8-9a31-f32a5e669ead","workflowId":"mcp-suite-dry-run","from":"mcp","to":"evals","capability":"evals.run_mcp_readiness_eval","intent":"Submit the MCP registry and generated tool evidence package to Evals for scoring after auth is satisfied.","transport":"mcp","auth":{"required":true,"satisfied":false,"mode":"none"},"trace":{"traceId":"28f53deb-9658-4e5c-9283-a15fcb6c3e00","spanId":"90d5d198b3754e15","traceUrl":"https://trace.platphormnews.com/traces/28f53deb-9658-4e5c-9283-a15fcb6c3e00"},"input":{"payload":{"demo":true,"targetUrl":"https://evals.platphormnews.com","protectedEndpoint":"https://evals.platphormnews.com/api/v1/evals/run","publicEvidence":[{"key":"health","url":"https://evals.platphormnews.com/api/health","status":"active","httpStatus":200},{"key":"apiDocs","url":"https://evals.platphormnews.com/api/docs","status":"active","httpStatus":200},{"key":"openapiJson","url":"https://evals.platphormnews.com/openapi.json","status":"active","httpStatus":200},{"key":"openapiYaml","url":"https://evals.platphormnews.com/openapi.yaml","status":"active","httpStatus":200},{"key":"mcpManifest","url":"https://evals.platphormnews.com/.well-known/mcp.json","status":"active","httpStatus":200},{"key":"llmsIndex","url":"https://evals.platphormnews.com/llms-index.json","status":"active","httpStatus":200},{"key":"trust","url":"https://evals.platphormnews.com/.well-known/trust.json","status":"active","httpStatus":200}],"downstreamExecutionClaimed":false},"redaction":"public_safe"},"expectedOutput":{"type":"public_safe_evidence_summary","required":true},"status":"protected_required","createdAt":"2026-06-05T22:37:34.799Z","updatedAt":"2026-06-05T22:37:34.799Z","downstreamExecutionClaimed":false,"demoSafe":true}],"demoScript":[{"label":"Open demo readiness","command":"curl https://mcp.platphormnews.com/api/v1/demo/suite","protected":false},{"label":"Check MCP metadata","command":"curl https://mcp.platphormnews.com/api/mcp","protected":false},{"label":"Initialize MCP 2025 client","command":"curl -s https://mcp.platphormnews.com/api/mcp -H 'content-type: application/json' -H 'mcp-protocol-version: 2025-06-18' -d '{\"jsonrpc\":\"2.0\",\"id\":1,\"method\":\"initialize\",\"params\":{\"protocolVersion\":\"2025-06-18\",\"capabilities\":{},\"clientInfo\":{\"name\":\"demo\",\"version\":\"1.0.0\"}}}'","protected":false},{"label":"Inspect local callable tools","command":"curl -s https://mcp.platphormnews.com/api/v1/registry/tools","protected":false},{"label":"Preview protected validation handoff","command":"curl -s https://mcp.platphormnews.com/api/v1/factory/validate -H 'content-type: application/json' -H \"X-PlatPhorm-API-Key: $PLATPHORM_API_KEY\" -d '{\"dryRun\":true,\"toolName\":\"inspect_spec_discovery\"}'","protected":true}],"warnings":["PlatPhormNews Root public evidence is degraded; demo can continue, but call it degraded.","Root graph discovery is degraded; do not claim downstream completion."],"nextActions":["Run the MCP 2025 initialize, initialized, tools/list, and list_network_sites flow from the client page.","Open AgentUI with the MCP tools/list schema and verify the operator workflow renders without secrets.","Use the protected dry-run buttons only with PLATPHORM_API_KEY stored in the operator environment.","Record downstream confirmation from Spec, Sandbox, and Evals before calling a handoff completed."]}},"meta":{"generatedAt":"2026-06-05T22:37:34.799Z","traceId":"94349f2c-b5f5-4789-be91-88b591639bfd","degraded":false,"source":"registry"},"warnings":[],"errors":[]}