@dotdo/do 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +400 -0
- package/dist/ai/embeddings.d.ts +129 -0
- package/dist/ai/embeddings.d.ts.map +1 -0
- package/dist/ai/embeddings.js +217 -0
- package/dist/ai/embeddings.js.map +1 -0
- package/dist/ai/gateway.d.ts +139 -0
- package/dist/ai/gateway.d.ts.map +1 -0
- package/dist/ai/gateway.js +179 -0
- package/dist/ai/gateway.js.map +1 -0
- package/dist/ai/image.d.ts +140 -0
- package/dist/ai/image.d.ts.map +1 -0
- package/dist/ai/image.js +199 -0
- package/dist/ai/image.js.map +1 -0
- package/dist/ai/index.d.ts +98 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +223 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/models.d.ts +81 -0
- package/dist/ai/models.d.ts.map +1 -0
- package/dist/ai/models.js +537 -0
- package/dist/ai/models.js.map +1 -0
- package/dist/ai/text.d.ts +176 -0
- package/dist/ai/text.d.ts.map +1 -0
- package/dist/ai/text.js +253 -0
- package/dist/ai/text.js.map +1 -0
- package/dist/ai/voice/agents.d.ts +224 -0
- package/dist/ai/voice/agents.d.ts.map +1 -0
- package/dist/ai/voice/agents.js +375 -0
- package/dist/ai/voice/agents.js.map +1 -0
- package/dist/ai/voice/campaigns.d.ts +307 -0
- package/dist/ai/voice/campaigns.d.ts.map +1 -0
- package/dist/ai/voice/campaigns.js +739 -0
- package/dist/ai/voice/campaigns.js.map +1 -0
- package/dist/ai/voice/index.d.ts +21 -0
- package/dist/ai/voice/index.d.ts.map +1 -0
- package/dist/ai/voice/index.js +42 -0
- package/dist/ai/voice/index.js.map +1 -0
- package/dist/ai/voice/providers.d.ts +283 -0
- package/dist/ai/voice/providers.d.ts.map +1 -0
- package/dist/ai/voice/providers.js +286 -0
- package/dist/ai/voice/providers.js.map +1 -0
- package/dist/ai/voice/sessions.d.ts +294 -0
- package/dist/ai/voice/sessions.d.ts.map +1 -0
- package/dist/ai/voice/sessions.js +531 -0
- package/dist/ai/voice/sessions.js.map +1 -0
- package/dist/ai/voice/tools.d.ts +242 -0
- package/dist/ai/voice/tools.d.ts.map +1 -0
- package/dist/ai/voice/tools.js +370 -0
- package/dist/ai/voice/tools.js.map +1 -0
- package/dist/ai/voice/tts.d.ts +173 -0
- package/dist/ai/voice/tts.d.ts.map +1 -0
- package/dist/ai/voice/tts.js +252 -0
- package/dist/ai/voice/tts.js.map +1 -0
- package/dist/ai/voice/webrtc.d.ts +228 -0
- package/dist/ai/voice/webrtc.d.ts.map +1 -0
- package/dist/ai/voice/webrtc.js +372 -0
- package/dist/ai/voice/webrtc.js.map +1 -0
- package/dist/api/index.d.ts +103 -0
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +191 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/mcp/handlers.d.ts +25 -0
- package/dist/api/mcp/handlers.d.ts.map +1 -0
- package/dist/api/mcp/handlers.js +422 -0
- package/dist/api/mcp/handlers.js.map +1 -0
- package/dist/api/mcp/index.d.ts +113 -0
- package/dist/api/mcp/index.d.ts.map +1 -0
- package/dist/api/mcp/index.js +141 -0
- package/dist/api/mcp/index.js.map +1 -0
- package/dist/api/middleware/auth.d.ts +65 -0
- package/dist/api/middleware/auth.d.ts.map +1 -0
- package/dist/api/middleware/auth.js +271 -0
- package/dist/api/middleware/auth.js.map +1 -0
- package/dist/api/middleware/cors.d.ts +62 -0
- package/dist/api/middleware/cors.d.ts.map +1 -0
- package/dist/api/middleware/cors.js +225 -0
- package/dist/api/middleware/cors.js.map +1 -0
- package/dist/api/middleware/index.d.ts +60 -0
- package/dist/api/middleware/index.d.ts.map +1 -0
- package/dist/api/middleware/index.js +175 -0
- package/dist/api/middleware/index.js.map +1 -0
- package/dist/api/middleware/rateLimit.d.ts +84 -0
- package/dist/api/middleware/rateLimit.d.ts.map +1 -0
- package/dist/api/middleware/rateLimit.js +321 -0
- package/dist/api/middleware/rateLimit.js.map +1 -0
- package/dist/api/routes/ai.d.ts +17 -0
- package/dist/api/routes/ai.d.ts.map +1 -0
- package/dist/api/routes/ai.js +430 -0
- package/dist/api/routes/ai.js.map +1 -0
- package/dist/api/routes/do.d.ts +17 -0
- package/dist/api/routes/do.d.ts.map +1 -0
- package/dist/api/routes/do.js +458 -0
- package/dist/api/routes/do.js.map +1 -0
- package/dist/api/routes/functions.d.ts +111 -0
- package/dist/api/routes/functions.d.ts.map +1 -0
- package/dist/api/routes/functions.js +548 -0
- package/dist/api/routes/functions.js.map +1 -0
- package/dist/api/routes/health.d.ts +16 -0
- package/dist/api/routes/health.d.ts.map +1 -0
- package/dist/api/routes/health.js +163 -0
- package/dist/api/routes/health.js.map +1 -0
- package/dist/api/routes/index.d.ts +41 -0
- package/dist/api/routes/index.d.ts.map +1 -0
- package/dist/api/routes/index.js +275 -0
- package/dist/api/routes/index.js.map +1 -0
- package/dist/api/routes/nouns.d.ts +26 -0
- package/dist/api/routes/nouns.d.ts.map +1 -0
- package/dist/api/routes/nouns.js +456 -0
- package/dist/api/routes/nouns.js.map +1 -0
- package/dist/api/routes/orgs.d.ts +17 -0
- package/dist/api/routes/orgs.d.ts.map +1 -0
- package/dist/api/routes/orgs.js +560 -0
- package/dist/api/routes/orgs.js.map +1 -0
- package/dist/api/routes/relationships.d.ts +30 -0
- package/dist/api/routes/relationships.d.ts.map +1 -0
- package/dist/api/routes/relationships.js +360 -0
- package/dist/api/routes/relationships.js.map +1 -0
- package/dist/api/routes/roles.d.ts +17 -0
- package/dist/api/routes/roles.d.ts.map +1 -0
- package/dist/api/routes/roles.js +721 -0
- package/dist/api/routes/roles.js.map +1 -0
- package/dist/api/routes/things.d.ts +27 -0
- package/dist/api/routes/things.d.ts.map +1 -0
- package/dist/api/routes/things.js +568 -0
- package/dist/api/routes/things.js.map +1 -0
- package/dist/api/routes/users.d.ts +17 -0
- package/dist/api/routes/users.d.ts.map +1 -0
- package/dist/api/routes/users.js +401 -0
- package/dist/api/routes/users.js.map +1 -0
- package/dist/api/routes/verbs.d.ts +31 -0
- package/dist/api/routes/verbs.d.ts.map +1 -0
- package/dist/api/routes/verbs.js +505 -0
- package/dist/api/routes/verbs.js.map +1 -0
- package/dist/api/routes/workflows.d.ts +44 -0
- package/dist/api/routes/workflows.d.ts.map +1 -0
- package/dist/api/routes/workflows.js +521 -0
- package/dist/api/routes/workflows.js.map +1 -0
- package/dist/api/types.d.ts +370 -0
- package/dist/api/types.d.ts.map +1 -0
- package/dist/api/types.js +11 -0
- package/dist/api/types.js.map +1 -0
- package/dist/db/cdc/events.d.ts +201 -0
- package/dist/db/cdc/events.d.ts.map +1 -0
- package/dist/db/cdc/events.js +271 -0
- package/dist/db/cdc/events.js.map +1 -0
- package/dist/db/cdc/index.d.ts +13 -0
- package/dist/db/cdc/index.d.ts.map +1 -0
- package/dist/db/cdc/index.js +16 -0
- package/dist/db/cdc/index.js.map +1 -0
- package/dist/db/cdc/replay.d.ts +388 -0
- package/dist/db/cdc/replay.d.ts.map +1 -0
- package/dist/db/cdc/replay.js +469 -0
- package/dist/db/cdc/replay.js.map +1 -0
- package/dist/db/cdc/storage.d.ts +567 -0
- package/dist/db/cdc/storage.d.ts.map +1 -0
- package/dist/db/cdc/storage.js +856 -0
- package/dist/db/cdc/storage.js.map +1 -0
- package/dist/db/cdc/streaming.d.ts +459 -0
- package/dist/db/cdc/streaming.d.ts.map +1 -0
- package/dist/db/cdc/streaming.js +636 -0
- package/dist/db/cdc/streaming.js.map +1 -0
- package/dist/db/collections/actions.d.ts +440 -0
- package/dist/db/collections/actions.d.ts.map +1 -0
- package/dist/db/collections/actions.js +631 -0
- package/dist/db/collections/actions.js.map +1 -0
- package/dist/db/collections/base.d.ts +342 -0
- package/dist/db/collections/base.d.ts.map +1 -0
- package/dist/db/collections/base.js +510 -0
- package/dist/db/collections/base.js.map +1 -0
- package/dist/db/collections/index.d.ts +50 -0
- package/dist/db/collections/index.d.ts.map +1 -0
- package/dist/db/collections/index.js +48 -0
- package/dist/db/collections/index.js.map +1 -0
- package/dist/db/collections/nouns.d.ts +260 -0
- package/dist/db/collections/nouns.d.ts.map +1 -0
- package/dist/db/collections/nouns.js +273 -0
- package/dist/db/collections/nouns.js.map +1 -0
- package/dist/db/collections/relationships.d.ts +484 -0
- package/dist/db/collections/relationships.d.ts.map +1 -0
- package/dist/db/collections/relationships.js +815 -0
- package/dist/db/collections/relationships.js.map +1 -0
- package/dist/db/collections/things.d.ts +439 -0
- package/dist/db/collections/things.d.ts.map +1 -0
- package/dist/db/collections/things.js +603 -0
- package/dist/db/collections/things.js.map +1 -0
- package/dist/db/collections/verbs.d.ts +308 -0
- package/dist/db/collections/verbs.d.ts.map +1 -0
- package/dist/db/collections/verbs.js +480 -0
- package/dist/db/collections/verbs.js.map +1 -0
- package/dist/db/index.d.ts +14 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +23 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/storage/cold.d.ts +313 -0
- package/dist/db/storage/cold.d.ts.map +1 -0
- package/dist/db/storage/cold.js +319 -0
- package/dist/db/storage/cold.js.map +1 -0
- package/dist/db/storage/hot.d.ts +340 -0
- package/dist/db/storage/hot.d.ts.map +1 -0
- package/dist/db/storage/hot.js +333 -0
- package/dist/db/storage/hot.js.map +1 -0
- package/dist/db/storage/index.d.ts +242 -0
- package/dist/db/storage/index.d.ts.map +1 -0
- package/dist/db/storage/index.js +109 -0
- package/dist/db/storage/index.js.map +1 -0
- package/dist/db/storage/snapshots.d.ts +342 -0
- package/dist/db/storage/snapshots.d.ts.map +1 -0
- package/dist/db/storage/snapshots.js +298 -0
- package/dist/db/storage/snapshots.js.map +1 -0
- package/dist/db/storage/vortex.d.ts +324 -0
- package/dist/db/storage/vortex.d.ts.map +1 -0
- package/dist/db/storage/vortex.js +365 -0
- package/dist/db/storage/vortex.js.map +1 -0
- package/dist/db/storage/warm.d.ts +306 -0
- package/dist/db/storage/warm.d.ts.map +1 -0
- package/dist/db/storage/warm.js +339 -0
- package/dist/db/storage/warm.js.map +1 -0
- package/dist/do/DigitalObject.d.ts +595 -0
- package/dist/do/DigitalObject.d.ts.map +1 -0
- package/dist/do/DigitalObject.js +971 -0
- package/dist/do/DigitalObject.js.map +1 -0
- package/dist/do/business/financial/accounting.d.ts +436 -0
- package/dist/do/business/financial/accounting.d.ts.map +1 -0
- package/dist/do/business/financial/accounting.js +476 -0
- package/dist/do/business/financial/accounting.js.map +1 -0
- package/dist/do/business/financial/index.d.ts +15 -0
- package/dist/do/business/financial/index.d.ts.map +1 -0
- package/dist/do/business/financial/index.js +20 -0
- package/dist/do/business/financial/index.js.map +1 -0
- package/dist/do/business/financial/metrics.d.ts +370 -0
- package/dist/do/business/financial/metrics.d.ts.map +1 -0
- package/dist/do/business/financial/metrics.js +376 -0
- package/dist/do/business/financial/metrics.js.map +1 -0
- package/dist/do/business/financial/payments.d.ts +397 -0
- package/dist/do/business/financial/payments.d.ts.map +1 -0
- package/dist/do/business/financial/payments.js +395 -0
- package/dist/do/business/financial/payments.js.map +1 -0
- package/dist/do/business/financial/reports.d.ts +284 -0
- package/dist/do/business/financial/reports.d.ts.map +1 -0
- package/dist/do/business/financial/reports.js +347 -0
- package/dist/do/business/financial/reports.js.map +1 -0
- package/dist/do/business/financial/stripe.d.ts +254 -0
- package/dist/do/business/financial/stripe.d.ts.map +1 -0
- package/dist/do/business/financial/stripe.js +261 -0
- package/dist/do/business/financial/stripe.js.map +1 -0
- package/dist/do/business/financial/subscriptions.d.ts +402 -0
- package/dist/do/business/financial/subscriptions.d.ts.map +1 -0
- package/dist/do/business/financial/subscriptions.js +349 -0
- package/dist/do/business/financial/subscriptions.js.map +1 -0
- package/dist/do/business/index.d.ts +9 -0
- package/dist/do/business/index.d.ts.map +1 -0
- package/dist/do/business/index.js +10 -0
- package/dist/do/business/index.js.map +1 -0
- package/dist/do/colo/followers.d.ts +194 -0
- package/dist/do/colo/followers.d.ts.map +1 -0
- package/dist/do/colo/followers.js +224 -0
- package/dist/do/colo/followers.js.map +1 -0
- package/dist/do/colo/fork.d.ts +103 -0
- package/dist/do/colo/fork.d.ts.map +1 -0
- package/dist/do/colo/fork.js +143 -0
- package/dist/do/colo/fork.js.map +1 -0
- package/dist/do/colo/index.d.ts +181 -0
- package/dist/do/colo/index.d.ts.map +1 -0
- package/dist/do/colo/index.js +145 -0
- package/dist/do/colo/index.js.map +1 -0
- package/dist/do/colo/info.d.ts +106 -0
- package/dist/do/colo/info.d.ts.map +1 -0
- package/dist/do/colo/info.js +196 -0
- package/dist/do/colo/info.js.map +1 -0
- package/dist/do/colo/migrate.d.ts +161 -0
- package/dist/do/colo/migrate.d.ts.map +1 -0
- package/dist/do/colo/migrate.js +190 -0
- package/dist/do/colo/migrate.js.map +1 -0
- package/dist/do/colo/routing.d.ts +182 -0
- package/dist/do/colo/routing.d.ts.map +1 -0
- package/dist/do/colo/routing.js +254 -0
- package/dist/do/colo/routing.js.map +1 -0
- package/dist/do/domains/dns.d.ts +269 -0
- package/dist/do/domains/dns.d.ts.map +1 -0
- package/dist/do/domains/dns.js +215 -0
- package/dist/do/domains/dns.js.map +1 -0
- package/dist/do/domains/index.d.ts +40 -0
- package/dist/do/domains/index.d.ts.map +1 -0
- package/dist/do/domains/index.js +61 -0
- package/dist/do/domains/index.js.map +1 -0
- package/dist/do/domains/routing.d.ts +263 -0
- package/dist/do/domains/routing.d.ts.map +1 -0
- package/dist/do/domains/routing.js +362 -0
- package/dist/do/domains/routing.js.map +1 -0
- package/dist/do/domains/ssl.d.ts +217 -0
- package/dist/do/domains/ssl.d.ts.map +1 -0
- package/dist/do/domains/ssl.js +231 -0
- package/dist/do/domains/ssl.js.map +1 -0
- package/dist/do/domains/subdomains.d.ts +207 -0
- package/dist/do/domains/subdomains.d.ts.map +1 -0
- package/dist/do/domains/subdomains.js +223 -0
- package/dist/do/domains/subdomains.js.map +1 -0
- package/dist/do/domains/tlds.d.ts +175 -0
- package/dist/do/domains/tlds.d.ts.map +1 -0
- package/dist/do/domains/tlds.js +188 -0
- package/dist/do/domains/tlds.js.map +1 -0
- package/dist/do/domains/validation.d.ts +164 -0
- package/dist/do/domains/validation.d.ts.map +1 -0
- package/dist/do/domains/validation.js +290 -0
- package/dist/do/domains/validation.js.map +1 -0
- package/dist/do/hibernation.d.ts +385 -0
- package/dist/do/hibernation.d.ts.map +1 -0
- package/dist/do/hibernation.js +518 -0
- package/dist/do/hibernation.js.map +1 -0
- package/dist/do/index.d.ts +19 -0
- package/dist/do/index.d.ts.map +1 -0
- package/dist/do/index.js +23 -0
- package/dist/do/index.js.map +1 -0
- package/dist/do/state.d.ts +336 -0
- package/dist/do/state.d.ts.map +1 -0
- package/dist/do/state.js +290 -0
- package/dist/do/state.js.map +1 -0
- package/dist/index.d.ts +44 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +89 -0
- package/dist/index.js.map +1 -0
- package/dist/rpc/client.d.ts +426 -0
- package/dist/rpc/client.d.ts.map +1 -0
- package/dist/rpc/client.js +826 -0
- package/dist/rpc/client.js.map +1 -0
- package/dist/rpc/index.d.ts +19 -0
- package/dist/rpc/index.d.ts.map +1 -0
- package/dist/rpc/index.js +23 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/rpc/methods.d.ts +364 -0
- package/dist/rpc/methods.d.ts.map +1 -0
- package/dist/rpc/methods.js +557 -0
- package/dist/rpc/methods.js.map +1 -0
- package/dist/rpc/protocol.d.ts +310 -0
- package/dist/rpc/protocol.d.ts.map +1 -0
- package/dist/rpc/protocol.js +672 -0
- package/dist/rpc/protocol.js.map +1 -0
- package/dist/rpc/routes.d.ts +332 -0
- package/dist/rpc/routes.d.ts.map +1 -0
- package/dist/rpc/routes.js +633 -0
- package/dist/rpc/routes.js.map +1 -0
- package/dist/rpc/server.d.ts +380 -0
- package/dist/rpc/server.d.ts.map +1 -0
- package/dist/rpc/server.js +850 -0
- package/dist/rpc/server.js.map +1 -0
- package/dist/sdk/auth.d.ts +201 -0
- package/dist/sdk/auth.d.ts.map +1 -0
- package/dist/sdk/auth.js +343 -0
- package/dist/sdk/auth.js.map +1 -0
- package/dist/sdk/client.d.ts +123 -0
- package/dist/sdk/client.d.ts.map +1 -0
- package/dist/sdk/client.js +403 -0
- package/dist/sdk/client.js.map +1 -0
- package/dist/sdk/index.d.ts +123 -0
- package/dist/sdk/index.d.ts.map +1 -0
- package/dist/sdk/index.js +230 -0
- package/dist/sdk/index.js.map +1 -0
- package/dist/sdk/rpc.d.ts +275 -0
- package/dist/sdk/rpc.d.ts.map +1 -0
- package/dist/sdk/rpc.js +249 -0
- package/dist/sdk/rpc.js.map +1 -0
- package/dist/sdk/transport.d.ts +283 -0
- package/dist/sdk/transport.d.ts.map +1 -0
- package/dist/sdk/transport.js +661 -0
- package/dist/sdk/transport.js.map +1 -0
- package/dist/sdk/types.d.ts +265 -0
- package/dist/sdk/types.d.ts.map +1 -0
- package/dist/sdk/types.js +27 -0
- package/dist/sdk/types.js.map +1 -0
- package/dist/types/ai.d.ts +533 -0
- package/dist/types/ai.d.ts.map +1 -0
- package/dist/types/ai.js +18 -0
- package/dist/types/ai.js.map +1 -0
- package/dist/types/app.d.ts +371 -0
- package/dist/types/app.d.ts.map +1 -0
- package/dist/types/app.js +151 -0
- package/dist/types/app.js.map +1 -0
- package/dist/types/business.d.ts +482 -0
- package/dist/types/business.d.ts.map +1 -0
- package/dist/types/business.js +60 -0
- package/dist/types/business.js.map +1 -0
- package/dist/types/cascade.d.ts +323 -0
- package/dist/types/cascade.d.ts.map +1 -0
- package/dist/types/cascade.js +82 -0
- package/dist/types/cascade.js.map +1 -0
- package/dist/types/collections.d.ts +704 -0
- package/dist/types/collections.d.ts.map +1 -0
- package/dist/types/collections.js +23 -0
- package/dist/types/collections.js.map +1 -0
- package/dist/types/colo.d.ts +171 -0
- package/dist/types/colo.d.ts.map +1 -0
- package/dist/types/colo.js +63 -0
- package/dist/types/colo.js.map +1 -0
- package/dist/types/communication.d.ts +595 -0
- package/dist/types/communication.d.ts.map +1 -0
- package/dist/types/communication.js +16 -0
- package/dist/types/communication.js.map +1 -0
- package/dist/types/content.d.ts +286 -0
- package/dist/types/content.d.ts.map +1 -0
- package/dist/types/content.js +8 -0
- package/dist/types/content.js.map +1 -0
- package/dist/types/context.d.ts +407 -0
- package/dist/types/context.d.ts.map +1 -0
- package/dist/types/context.js +36 -0
- package/dist/types/context.js.map +1 -0
- package/dist/types/databases.d.ts +377 -0
- package/dist/types/databases.d.ts.map +1 -0
- package/dist/types/databases.js +14 -0
- package/dist/types/databases.js.map +1 -0
- package/dist/types/domains.d.ts +132 -0
- package/dist/types/domains.d.ts.map +1 -0
- package/dist/types/domains.js +107 -0
- package/dist/types/domains.js.map +1 -0
- package/dist/types/execution.d.ts +381 -0
- package/dist/types/execution.d.ts.map +1 -0
- package/dist/types/execution.js +40 -0
- package/dist/types/execution.js.map +1 -0
- package/dist/types/financial.d.ts +608 -0
- package/dist/types/financial.d.ts.map +1 -0
- package/dist/types/financial.js +12 -0
- package/dist/types/financial.js.map +1 -0
- package/dist/types/functions.d.ts +215 -0
- package/dist/types/functions.d.ts.map +1 -0
- package/dist/types/functions.js +15 -0
- package/dist/types/functions.js.map +1 -0
- package/dist/types/git.d.ts +299 -0
- package/dist/types/git.d.ts.map +1 -0
- package/dist/types/git.js +17 -0
- package/dist/types/git.js.map +1 -0
- package/dist/types/identity.d.ts +141 -0
- package/dist/types/identity.d.ts.map +1 -0
- package/dist/types/identity.js +54 -0
- package/dist/types/identity.js.map +1 -0
- package/dist/types/index.d.ts +40 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +65 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/integrations.d.ts +356 -0
- package/dist/types/integrations.d.ts.map +1 -0
- package/dist/types/integrations.js +19 -0
- package/dist/types/integrations.js.map +1 -0
- package/dist/types/mdxui.d.ts +1955 -0
- package/dist/types/mdxui.d.ts.map +1 -0
- package/dist/types/mdxui.js +751 -0
- package/dist/types/mdxui.js.map +1 -0
- package/dist/types/observability.d.ts +315 -0
- package/dist/types/observability.d.ts.map +1 -0
- package/dist/types/observability.js +13 -0
- package/dist/types/observability.js.map +1 -0
- package/dist/types/rpc.d.ts +339 -0
- package/dist/types/rpc.d.ts.map +1 -0
- package/dist/types/rpc.js +24 -0
- package/dist/types/rpc.js.map +1 -0
- package/dist/types/saas.d.ts +678 -0
- package/dist/types/saas.d.ts.map +1 -0
- package/dist/types/saas.js +59 -0
- package/dist/types/saas.js.map +1 -0
- package/dist/types/service.d.ts +676 -0
- package/dist/types/service.d.ts.map +1 -0
- package/dist/types/service.js +69 -0
- package/dist/types/service.js.map +1 -0
- package/dist/types/site.d.ts +317 -0
- package/dist/types/site.d.ts.map +1 -0
- package/dist/types/site.js +203 -0
- package/dist/types/site.js.map +1 -0
- package/dist/types/startup.d.ts +576 -0
- package/dist/types/startup.d.ts.map +1 -0
- package/dist/types/startup.js +59 -0
- package/dist/types/startup.js.map +1 -0
- package/dist/types/storage.d.ts +276 -0
- package/dist/types/storage.d.ts.map +1 -0
- package/dist/types/storage.js +35 -0
- package/dist/types/storage.js.map +1 -0
- package/dist/types/telephony.d.ts +458 -0
- package/dist/types/telephony.d.ts.map +1 -0
- package/dist/types/telephony.js +19 -0
- package/dist/types/telephony.js.map +1 -0
- package/dist/types/tenant.d.ts +708 -0
- package/dist/types/tenant.d.ts.map +1 -0
- package/dist/types/tenant.js +103 -0
- package/dist/types/tenant.js.map +1 -0
- package/dist/types/voice-ai.d.ts +459 -0
- package/dist/types/voice-ai.d.ts.map +1 -0
- package/dist/types/voice-ai.js +32 -0
- package/dist/types/voice-ai.js.map +1 -0
- package/package.json +143 -0
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MCP (Model Context Protocol) Module
|
|
3
|
+
*
|
|
4
|
+
* Implements the Model Context Protocol for AI tool integration.
|
|
5
|
+
* Allows AI agents (Claude, GPT, etc.) to interact with Digital Objects.
|
|
6
|
+
*
|
|
7
|
+
* MCP Spec: https://modelcontextprotocol.io/
|
|
8
|
+
*/
|
|
9
|
+
import { Hono } from 'hono';
|
|
10
|
+
import { getTools, handleListTools, handleToolCall, handleInitialize } from './handlers';
|
|
11
|
+
// =============================================================================
|
|
12
|
+
// MCP Routes
|
|
13
|
+
// =============================================================================
|
|
14
|
+
/**
|
|
15
|
+
* Create MCP routes
|
|
16
|
+
*/
|
|
17
|
+
export function createMCPRoutes() {
|
|
18
|
+
const router = new Hono();
|
|
19
|
+
/**
|
|
20
|
+
* GET /mcp - MCP server discovery
|
|
21
|
+
*/
|
|
22
|
+
router.get('/mcp', (c) => {
|
|
23
|
+
const url = new URL(c.req.url);
|
|
24
|
+
const info = {
|
|
25
|
+
protocolVersion: '2024-11-05',
|
|
26
|
+
capabilities: {
|
|
27
|
+
tools: { listChanged: false },
|
|
28
|
+
resources: { subscribe: false, listChanged: false },
|
|
29
|
+
prompts: { listChanged: false },
|
|
30
|
+
logging: {},
|
|
31
|
+
},
|
|
32
|
+
serverInfo: {
|
|
33
|
+
name: url.hostname,
|
|
34
|
+
version: '1.0.0',
|
|
35
|
+
},
|
|
36
|
+
};
|
|
37
|
+
return c.json({
|
|
38
|
+
...info,
|
|
39
|
+
endpoints: {
|
|
40
|
+
discovery: `${url.origin}/mcp`,
|
|
41
|
+
tools: `${url.origin}/mcp`,
|
|
42
|
+
rpc: `${url.origin}/rpc`,
|
|
43
|
+
},
|
|
44
|
+
links: {
|
|
45
|
+
self: `${url.origin}/mcp`,
|
|
46
|
+
api: `${url.origin}/.do`,
|
|
47
|
+
docs: 'https://do.md/mcp',
|
|
48
|
+
},
|
|
49
|
+
}, 200, {
|
|
50
|
+
'Access-Control-Allow-Origin': '*',
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
/**
|
|
54
|
+
* POST /mcp - MCP JSON-RPC requests
|
|
55
|
+
*/
|
|
56
|
+
router.post('/mcp', async (c) => {
|
|
57
|
+
const url = new URL(c.req.url);
|
|
58
|
+
try {
|
|
59
|
+
const body = await c.req.json();
|
|
60
|
+
let response;
|
|
61
|
+
switch (body.method) {
|
|
62
|
+
case 'initialize':
|
|
63
|
+
response = handleInitialize(url.hostname, body.id);
|
|
64
|
+
break;
|
|
65
|
+
case 'tools/list':
|
|
66
|
+
response = await handleListTools(body.id);
|
|
67
|
+
break;
|
|
68
|
+
case 'tools/call': {
|
|
69
|
+
const params = body.params;
|
|
70
|
+
response = await handleToolCall(c.env, url.hostname, body.id, params.name, params.arguments || {});
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
default:
|
|
74
|
+
response = {
|
|
75
|
+
jsonrpc: '2.0',
|
|
76
|
+
id: body.id,
|
|
77
|
+
error: {
|
|
78
|
+
code: -32601,
|
|
79
|
+
message: `Method not found: ${body.method}`,
|
|
80
|
+
},
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
return c.json(response, 200, {
|
|
84
|
+
'Access-Control-Allow-Origin': '*',
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
return c.json({
|
|
89
|
+
jsonrpc: '2.0',
|
|
90
|
+
id: null,
|
|
91
|
+
error: {
|
|
92
|
+
code: -32700,
|
|
93
|
+
message: 'Parse error',
|
|
94
|
+
data: error instanceof Error ? error.message : undefined,
|
|
95
|
+
},
|
|
96
|
+
}, 400, {
|
|
97
|
+
'Access-Control-Allow-Origin': '*',
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
/**
|
|
102
|
+
* OPTIONS /mcp - CORS preflight
|
|
103
|
+
*/
|
|
104
|
+
router.options('/mcp', (c) => {
|
|
105
|
+
return new Response(null, {
|
|
106
|
+
status: 204,
|
|
107
|
+
headers: {
|
|
108
|
+
'Access-Control-Allow-Origin': '*',
|
|
109
|
+
'Access-Control-Allow-Methods': 'GET, POST, OPTIONS',
|
|
110
|
+
'Access-Control-Allow-Headers': 'Content-Type, Authorization',
|
|
111
|
+
'Access-Control-Max-Age': '86400',
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
/**
|
|
116
|
+
* GET /mcp/tools - List available tools
|
|
117
|
+
*/
|
|
118
|
+
router.get('/mcp/tools', (c) => {
|
|
119
|
+
const url = new URL(c.req.url);
|
|
120
|
+
const colo = c.req.header('CF-Ray')?.split('-')[1];
|
|
121
|
+
const tools = getTools();
|
|
122
|
+
return c.json({
|
|
123
|
+
api: url.hostname,
|
|
124
|
+
data: { tools },
|
|
125
|
+
links: {
|
|
126
|
+
self: `${url.origin}/mcp/tools`,
|
|
127
|
+
mcp: `${url.origin}/mcp`,
|
|
128
|
+
api: `${url.origin}/.do`,
|
|
129
|
+
},
|
|
130
|
+
colo,
|
|
131
|
+
timestamp: Date.now(),
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
return router;
|
|
135
|
+
}
|
|
136
|
+
// =============================================================================
|
|
137
|
+
// Exports
|
|
138
|
+
// =============================================================================
|
|
139
|
+
export { getTools, handleListTools, handleToolCall, handleInitialize } from './handlers';
|
|
140
|
+
export default createMCPRoutes;
|
|
141
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../api/mcp/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
*
|
|
4
|
+
* Handles JWT-based authentication and authorization.
|
|
5
|
+
* Supports optional auth (for public routes) and required auth.
|
|
6
|
+
*/
|
|
7
|
+
import type { Context, Next } from 'hono';
|
|
8
|
+
import type { Env, DOContext, AuthUser, AuthOptions } from '../types';
|
|
9
|
+
/**
|
|
10
|
+
* Create authentication middleware
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* // Optional auth - sets user if token present
|
|
14
|
+
* app.use('*', createAuthMiddleware())
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* // Required auth - returns 401 if no valid token
|
|
18
|
+
* app.use('/api/*', createAuthMiddleware({ required: true }))
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* // Role-based auth
|
|
22
|
+
* app.use('/admin/*', createAuthMiddleware({ required: true, roles: ['admin'] }))
|
|
23
|
+
*/
|
|
24
|
+
export declare function createAuthMiddleware(options?: AuthOptions): (c: Context<{
|
|
25
|
+
Bindings: Env;
|
|
26
|
+
Variables: DOContext;
|
|
27
|
+
}>, next: Next) => Promise<Response | void>;
|
|
28
|
+
/**
|
|
29
|
+
* Get the authenticated user from context
|
|
30
|
+
*/
|
|
31
|
+
export declare function getUser(c: Context<{
|
|
32
|
+
Variables: DOContext;
|
|
33
|
+
}>): AuthUser | undefined;
|
|
34
|
+
/**
|
|
35
|
+
* Require authentication (throws if not authenticated)
|
|
36
|
+
*/
|
|
37
|
+
export declare function requireUser(c: Context<{
|
|
38
|
+
Variables: DOContext;
|
|
39
|
+
}>): AuthUser;
|
|
40
|
+
/**
|
|
41
|
+
* Check if user has a specific role
|
|
42
|
+
*/
|
|
43
|
+
export declare function hasRole(c: Context<{
|
|
44
|
+
Variables: DOContext;
|
|
45
|
+
}>, role: string): boolean;
|
|
46
|
+
/**
|
|
47
|
+
* Check if user has a specific permission
|
|
48
|
+
*/
|
|
49
|
+
export declare function hasPermission(c: Context<{
|
|
50
|
+
Variables: DOContext;
|
|
51
|
+
}>, permission: string): boolean;
|
|
52
|
+
/**
|
|
53
|
+
* Create API key authentication middleware
|
|
54
|
+
*
|
|
55
|
+
* @example
|
|
56
|
+
* app.use('/api/*', createApiKeyMiddleware({ required: true }))
|
|
57
|
+
*/
|
|
58
|
+
export declare function createApiKeyMiddleware(options?: {
|
|
59
|
+
required?: boolean;
|
|
60
|
+
headerName?: string;
|
|
61
|
+
}): (c: Context<{
|
|
62
|
+
Bindings: Env;
|
|
63
|
+
Variables: DOContext;
|
|
64
|
+
}>, next: Next) => Promise<Response | void>;
|
|
65
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../../api/middleware/auth.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AACzC,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAc,MAAM,UAAU,CAAA;AAqFjF;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,GAAE,WAAgB,IAC9C,GAAG,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,EAAE,MAAM,IAAI,KAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CA6FzG;AAMD;;GAEG;AACH,wBAAgB,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,GAAG,QAAQ,GAAG,SAAS,CAElF;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,OAAO,CAAC;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,GAAG,QAAQ,CAM1E;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAGnF;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,CAAC,EAAE,OAAO,CAAC;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAG/F;AAMD;;;;;GAKG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,GAAE;IAAE,QAAQ,CAAC,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,CAAA;CAAO,IAGhF,GAAG,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,EAAE,MAAM,IAAI,KAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAqDzG"}
|
|
@@ -0,0 +1,271 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
*
|
|
4
|
+
* Handles JWT-based authentication and authorization.
|
|
5
|
+
* Supports optional auth (for public routes) and required auth.
|
|
6
|
+
*/
|
|
7
|
+
// =============================================================================
|
|
8
|
+
// JWT Utilities
|
|
9
|
+
// =============================================================================
|
|
10
|
+
/**
|
|
11
|
+
* Decode a JWT token (without verification for quick parsing)
|
|
12
|
+
*/
|
|
13
|
+
function decodeJWT(token) {
|
|
14
|
+
try {
|
|
15
|
+
const parts = token.split('.');
|
|
16
|
+
if (parts.length !== 3)
|
|
17
|
+
return null;
|
|
18
|
+
const header = JSON.parse(atob(parts[0]));
|
|
19
|
+
const payload = JSON.parse(atob(parts[1]));
|
|
20
|
+
return { header, payload };
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Verify a JWT token
|
|
28
|
+
* In production, this would use proper crypto verification
|
|
29
|
+
*/
|
|
30
|
+
async function verifyJWT(token, secret) {
|
|
31
|
+
const decoded = decodeJWT(token);
|
|
32
|
+
if (!decoded) {
|
|
33
|
+
return { success: false, error: 'Invalid token format' };
|
|
34
|
+
}
|
|
35
|
+
const payload = decoded.payload;
|
|
36
|
+
// Check expiration
|
|
37
|
+
if (payload.exp && typeof payload.exp === 'number') {
|
|
38
|
+
if (Date.now() / 1000 > payload.exp) {
|
|
39
|
+
return { success: false, error: 'Token expired' };
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
// Build user from payload
|
|
43
|
+
const user = {
|
|
44
|
+
id: String(payload.sub || payload.id || 'unknown'),
|
|
45
|
+
email: payload.email,
|
|
46
|
+
orgId: payload.orgId,
|
|
47
|
+
roles: payload.roles || [],
|
|
48
|
+
permissions: payload.permissions || [],
|
|
49
|
+
exp: payload.exp,
|
|
50
|
+
};
|
|
51
|
+
return { success: true, user };
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Extract token from request
|
|
55
|
+
* Checks Authorization header and cookies
|
|
56
|
+
*/
|
|
57
|
+
function extractToken(c) {
|
|
58
|
+
// Check Authorization header
|
|
59
|
+
const authHeader = c.req.header('Authorization');
|
|
60
|
+
if (authHeader?.startsWith('Bearer ')) {
|
|
61
|
+
return authHeader.slice(7);
|
|
62
|
+
}
|
|
63
|
+
// Check cookie
|
|
64
|
+
const cookie = c.req.header('Cookie');
|
|
65
|
+
if (cookie) {
|
|
66
|
+
const match = cookie.match(/auth_token=([^;]+)/);
|
|
67
|
+
if (match)
|
|
68
|
+
return match[1];
|
|
69
|
+
}
|
|
70
|
+
// Check query param (for WebSocket connections)
|
|
71
|
+
const url = new URL(c.req.url);
|
|
72
|
+
const queryToken = url.searchParams.get('token');
|
|
73
|
+
if (queryToken)
|
|
74
|
+
return queryToken;
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
// =============================================================================
|
|
78
|
+
// Auth Middleware Factory
|
|
79
|
+
// =============================================================================
|
|
80
|
+
/**
|
|
81
|
+
* Create authentication middleware
|
|
82
|
+
*
|
|
83
|
+
* @example
|
|
84
|
+
* // Optional auth - sets user if token present
|
|
85
|
+
* app.use('*', createAuthMiddleware())
|
|
86
|
+
*
|
|
87
|
+
* @example
|
|
88
|
+
* // Required auth - returns 401 if no valid token
|
|
89
|
+
* app.use('/api/*', createAuthMiddleware({ required: true }))
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* // Role-based auth
|
|
93
|
+
* app.use('/admin/*', createAuthMiddleware({ required: true, roles: ['admin'] }))
|
|
94
|
+
*/
|
|
95
|
+
export function createAuthMiddleware(options = {}) {
|
|
96
|
+
return async (c, next) => {
|
|
97
|
+
const secret = options.secret || c.env.AUTH_SECRET || 'dev-secret';
|
|
98
|
+
const tokenExtractor = options.extractToken || extractToken;
|
|
99
|
+
// Extract token
|
|
100
|
+
const token = tokenExtractor(c);
|
|
101
|
+
if (!token) {
|
|
102
|
+
if (options.required) {
|
|
103
|
+
return c.json({
|
|
104
|
+
api: new URL(c.req.url).hostname,
|
|
105
|
+
error: {
|
|
106
|
+
code: 'UNAUTHORIZED',
|
|
107
|
+
message: 'Authentication required',
|
|
108
|
+
},
|
|
109
|
+
links: {
|
|
110
|
+
auth: 'https://do.md/auth',
|
|
111
|
+
},
|
|
112
|
+
timestamp: Date.now(),
|
|
113
|
+
}, 401);
|
|
114
|
+
}
|
|
115
|
+
// No token, continue without user
|
|
116
|
+
await next();
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
// Verify token
|
|
120
|
+
const result = await verifyJWT(token, secret);
|
|
121
|
+
if (!result.success) {
|
|
122
|
+
if (options.required) {
|
|
123
|
+
return c.json({
|
|
124
|
+
api: new URL(c.req.url).hostname,
|
|
125
|
+
error: {
|
|
126
|
+
code: 'INVALID_TOKEN',
|
|
127
|
+
message: result.error || 'Invalid authentication token',
|
|
128
|
+
},
|
|
129
|
+
links: {
|
|
130
|
+
auth: 'https://do.md/auth',
|
|
131
|
+
},
|
|
132
|
+
timestamp: Date.now(),
|
|
133
|
+
}, 401);
|
|
134
|
+
}
|
|
135
|
+
// Invalid token but not required, continue without user
|
|
136
|
+
await next();
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
const user = result.user;
|
|
140
|
+
// Check roles if specified
|
|
141
|
+
if (options.roles && options.roles.length > 0) {
|
|
142
|
+
const hasRole = options.roles.some(role => user.roles.includes(role));
|
|
143
|
+
if (!hasRole) {
|
|
144
|
+
return c.json({
|
|
145
|
+
api: new URL(c.req.url).hostname,
|
|
146
|
+
error: {
|
|
147
|
+
code: 'FORBIDDEN',
|
|
148
|
+
message: `Required role: ${options.roles.join(' or ')}`,
|
|
149
|
+
},
|
|
150
|
+
links: {
|
|
151
|
+
self: c.req.url,
|
|
152
|
+
},
|
|
153
|
+
timestamp: Date.now(),
|
|
154
|
+
}, 403);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
// Check permissions if specified
|
|
158
|
+
if (options.permissions && options.permissions.length > 0) {
|
|
159
|
+
const hasPermission = options.permissions.some(perm => user.permissions.includes(perm));
|
|
160
|
+
if (!hasPermission) {
|
|
161
|
+
return c.json({
|
|
162
|
+
api: new URL(c.req.url).hostname,
|
|
163
|
+
error: {
|
|
164
|
+
code: 'FORBIDDEN',
|
|
165
|
+
message: `Required permission: ${options.permissions.join(' or ')}`,
|
|
166
|
+
},
|
|
167
|
+
links: {
|
|
168
|
+
self: c.req.url,
|
|
169
|
+
},
|
|
170
|
+
timestamp: Date.now(),
|
|
171
|
+
}, 403);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
// Set user in context
|
|
175
|
+
c.set('user', user);
|
|
176
|
+
await next();
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
// =============================================================================
|
|
180
|
+
// Helper Functions
|
|
181
|
+
// =============================================================================
|
|
182
|
+
/**
|
|
183
|
+
* Get the authenticated user from context
|
|
184
|
+
*/
|
|
185
|
+
export function getUser(c) {
|
|
186
|
+
return c.get('user');
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Require authentication (throws if not authenticated)
|
|
190
|
+
*/
|
|
191
|
+
export function requireUser(c) {
|
|
192
|
+
const user = c.get('user');
|
|
193
|
+
if (!user) {
|
|
194
|
+
throw new Error('Authentication required');
|
|
195
|
+
}
|
|
196
|
+
return user;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Check if user has a specific role
|
|
200
|
+
*/
|
|
201
|
+
export function hasRole(c, role) {
|
|
202
|
+
const user = c.get('user');
|
|
203
|
+
return user?.roles.includes(role) ?? false;
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Check if user has a specific permission
|
|
207
|
+
*/
|
|
208
|
+
export function hasPermission(c, permission) {
|
|
209
|
+
const user = c.get('user');
|
|
210
|
+
return user?.permissions.includes(permission) ?? false;
|
|
211
|
+
}
|
|
212
|
+
// =============================================================================
|
|
213
|
+
// API Key Auth
|
|
214
|
+
// =============================================================================
|
|
215
|
+
/**
|
|
216
|
+
* Create API key authentication middleware
|
|
217
|
+
*
|
|
218
|
+
* @example
|
|
219
|
+
* app.use('/api/*', createApiKeyMiddleware({ required: true }))
|
|
220
|
+
*/
|
|
221
|
+
export function createApiKeyMiddleware(options = {}) {
|
|
222
|
+
const headerName = options.headerName || 'X-API-Key';
|
|
223
|
+
return async (c, next) => {
|
|
224
|
+
const apiKey = c.req.header(headerName);
|
|
225
|
+
if (!apiKey) {
|
|
226
|
+
if (options.required) {
|
|
227
|
+
return c.json({
|
|
228
|
+
api: new URL(c.req.url).hostname,
|
|
229
|
+
error: {
|
|
230
|
+
code: 'UNAUTHORIZED',
|
|
231
|
+
message: `API key required (${headerName} header)`,
|
|
232
|
+
},
|
|
233
|
+
links: {
|
|
234
|
+
docs: 'https://do.md/api-keys',
|
|
235
|
+
},
|
|
236
|
+
timestamp: Date.now(),
|
|
237
|
+
}, 401);
|
|
238
|
+
}
|
|
239
|
+
await next();
|
|
240
|
+
return;
|
|
241
|
+
}
|
|
242
|
+
// Validate API key against KV store
|
|
243
|
+
// In production, this would check KV for the key
|
|
244
|
+
// For now, accept any key that looks valid
|
|
245
|
+
if (!/^do_[a-zA-Z0-9]{32,}$/.test(apiKey)) {
|
|
246
|
+
if (options.required) {
|
|
247
|
+
return c.json({
|
|
248
|
+
api: new URL(c.req.url).hostname,
|
|
249
|
+
error: {
|
|
250
|
+
code: 'INVALID_API_KEY',
|
|
251
|
+
message: 'Invalid API key format',
|
|
252
|
+
},
|
|
253
|
+
links: {
|
|
254
|
+
docs: 'https://do.md/api-keys',
|
|
255
|
+
},
|
|
256
|
+
timestamp: Date.now(),
|
|
257
|
+
}, 401);
|
|
258
|
+
}
|
|
259
|
+
await next();
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
// Set a basic user for API key auth
|
|
263
|
+
c.set('user', {
|
|
264
|
+
id: `api:${apiKey.slice(0, 16)}`,
|
|
265
|
+
roles: ['api'],
|
|
266
|
+
permissions: ['api:read', 'api:write'],
|
|
267
|
+
});
|
|
268
|
+
await next();
|
|
269
|
+
};
|
|
270
|
+
}
|
|
271
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../api/middleware/auth.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CORS Middleware
|
|
3
|
+
*
|
|
4
|
+
* Handles Cross-Origin Resource Sharing with configurable options.
|
|
5
|
+
* Includes smart defaults for the DO platform.
|
|
6
|
+
*/
|
|
7
|
+
import type { Context, Next } from 'hono';
|
|
8
|
+
import type { Env, DOContext, CORSConfig } from '../types';
|
|
9
|
+
/**
|
|
10
|
+
* Default CORS configuration for DO APIs
|
|
11
|
+
*/
|
|
12
|
+
export declare const DEFAULT_CORS_CONFIG: CORSConfig;
|
|
13
|
+
/**
|
|
14
|
+
* Restrictive CORS for sensitive endpoints
|
|
15
|
+
*/
|
|
16
|
+
export declare const RESTRICTIVE_CORS_CONFIG: CORSConfig;
|
|
17
|
+
/**
|
|
18
|
+
* Create CORS middleware with custom configuration
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* // Use default config
|
|
22
|
+
* app.use('*', createCorsMiddleware())
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* // Custom origins
|
|
26
|
+
* app.use('*', createCorsMiddleware({
|
|
27
|
+
* origin: ['https://app.example.com', 'https://admin.example.com']
|
|
28
|
+
* }))
|
|
29
|
+
*
|
|
30
|
+
* @example
|
|
31
|
+
* // Restrictive config for admin routes
|
|
32
|
+
* app.use('/admin/*', createCorsMiddleware(RESTRICTIVE_CORS_CONFIG))
|
|
33
|
+
*/
|
|
34
|
+
export declare function createCorsMiddleware(config?: CORSConfig): import("hono").MiddlewareHandler;
|
|
35
|
+
/**
|
|
36
|
+
* Create dynamic CORS middleware that checks allowed origins from KV
|
|
37
|
+
*
|
|
38
|
+
* This allows runtime configuration of CORS without redeployment
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* app.use('*', createDynamicCorsMiddleware('cors:allowed-origins'))
|
|
42
|
+
*/
|
|
43
|
+
export declare function createDynamicCorsMiddleware(kvKey?: string): (c: Context<{
|
|
44
|
+
Bindings: Env;
|
|
45
|
+
Variables: DOContext;
|
|
46
|
+
}>, next: Next) => Promise<Response | void>;
|
|
47
|
+
/**
|
|
48
|
+
* Create a dedicated preflight handler for specific routes
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* app.options('/api/*', createPreflightHandler())
|
|
52
|
+
*/
|
|
53
|
+
export declare function createPreflightHandler(config?: CORSConfig): (c: Context) => Response;
|
|
54
|
+
/**
|
|
55
|
+
* Add CORS headers to an existing response
|
|
56
|
+
*/
|
|
57
|
+
export declare function addCorsHeaders(response: Response, origin: string, config?: CORSConfig): Response;
|
|
58
|
+
/**
|
|
59
|
+
* Check if an origin is allowed
|
|
60
|
+
*/
|
|
61
|
+
export declare function isOriginAllowed(origin: string, config?: CORSConfig): boolean;
|
|
62
|
+
//# sourceMappingURL=cors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cors.d.ts","sourceRoot":"","sources":["../../../api/middleware/cors.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAEzC,OAAO,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAM1D;;GAEG;AACH,eAAO,MAAM,mBAAmB,EAAE,UAmBjC,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,uBAAuB,EAAE,UAgBrC,CAAA;AAMD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,GAAE,UAAe,oCAY3D;AAMD;;;;;;;GAOG;AACH,wBAAgB,2BAA2B,CAAC,KAAK,GAAE,MAAsB,IACzD,GAAG,OAAO,CAAC;IAAE,QAAQ,EAAE,GAAG,CAAC;IAAC,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC,EAAE,MAAM,IAAI,KAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CA8CzG;AAMD;;;;;GAKG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,GAAE,UAAgC,IACrE,GAAG,OAAO,cA8BnB;AAMD;;GAEG;AACH,wBAAgB,cAAc,CAC5B,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,EACd,MAAM,GAAE,UAAgC,GACvC,QAAQ,CA4BV;AAED;;GAEG;AACH,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,GAAE,UAAgC,GAAG,OAAO,CAgBjG"}
|