@undefineds.co/xpod 0.1.0-local.202602081751
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/LICENSE +22 -0
- package/README.md +146 -0
- package/components/components.jsonld +72 -0
- package/components/context.jsonld +1635 -0
- package/config/bun.json +90 -0
- package/config/cli.json +260 -0
- package/config/cloud.json +469 -0
- package/config/extensions.local.initializer.json +23 -0
- package/config/local.json +261 -0
- package/config/logging/configurable.json +18 -0
- package/config/main.json +200 -0
- package/config/main.vanilla.json +6 -0
- package/config/resolver.json +347 -0
- package/config/search.json +66 -0
- package/config/seed.dev.json +29 -0
- package/config/seeds/admin.example.json +11 -0
- package/config/seeds/test.json +11 -0
- package/config/terminal.json +22 -0
- package/config/vector.json +35 -0
- package/config/xpod.base.json +155 -0
- package/config/xpod.cluster.json +419 -0
- package/config/xpod.json +233 -0
- package/dist/agents/AgentExecutorFactory.d.ts +67 -0
- package/dist/agents/AgentExecutorFactory.js +193 -0
- package/dist/agents/AgentExecutorFactory.js.map +1 -0
- package/dist/agents/AgentManager.d.ts +114 -0
- package/dist/agents/AgentManager.js +289 -0
- package/dist/agents/AgentManager.js.map +1 -0
- package/dist/agents/BaseAgentExecutor.d.ts +67 -0
- package/dist/agents/BaseAgentExecutor.js +101 -0
- package/dist/agents/BaseAgentExecutor.js.map +1 -0
- package/dist/agents/ClaudeExecutor.d.ts +63 -0
- package/dist/agents/ClaudeExecutor.js +335 -0
- package/dist/agents/ClaudeExecutor.js.map +1 -0
- package/dist/agents/CodeBuddyExecutor.d.ts +54 -0
- package/dist/agents/CodeBuddyExecutor.js +273 -0
- package/dist/agents/CodeBuddyExecutor.js.map +1 -0
- package/dist/agents/IndexAgent.d.ts +70 -0
- package/dist/agents/IndexAgent.js +417 -0
- package/dist/agents/IndexAgent.js.map +1 -0
- package/dist/agents/index.d.ts +22 -0
- package/dist/agents/index.js +48 -0
- package/dist/agents/index.js.map +1 -0
- package/dist/agents/schema/agent-config.d.ts +58 -0
- package/dist/agents/schema/agent-config.js +74 -0
- package/dist/agents/schema/agent-config.js.map +1 -0
- package/dist/agents/schema/tables.d.ts +46 -0
- package/dist/agents/schema/tables.js +64 -0
- package/dist/agents/schema/tables.js.map +1 -0
- package/dist/agents/types.d.ts +266 -0
- package/dist/agents/types.js +9 -0
- package/dist/agents/types.js.map +1 -0
- package/dist/ai/index.d.ts +5 -0
- package/dist/ai/index.js +22 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/schema/config.d.ts +27 -0
- package/dist/ai/schema/config.js +36 -0
- package/dist/ai/schema/config.js.map +1 -0
- package/dist/ai/schema/index.d.ts +8 -0
- package/dist/ai/schema/index.js +27 -0
- package/dist/ai/schema/index.js.map +1 -0
- package/dist/ai/schema/model.d.ts +40 -0
- package/dist/ai/schema/model.js +60 -0
- package/dist/ai/schema/model.js.map +1 -0
- package/dist/ai/schema/provider.d.ts +21 -0
- package/dist/ai/schema/provider.js +30 -0
- package/dist/ai/schema/provider.js.map +1 -0
- package/dist/ai/schema/types.d.ts +52 -0
- package/dist/ai/schema/types.js +62 -0
- package/dist/ai/schema/types.js.map +1 -0
- package/dist/ai/schema/vector-store.d.ts +53 -0
- package/dist/ai/schema/vector-store.js +65 -0
- package/dist/ai/schema/vector-store.js.map +1 -0
- package/dist/ai/service/CredentialReader.d.ts +7 -0
- package/dist/ai/service/CredentialReader.js +10 -0
- package/dist/ai/service/CredentialReader.js.map +1 -0
- package/dist/ai/service/CredentialReaderImpl.d.ts +6 -0
- package/dist/ai/service/CredentialReaderImpl.js +55 -0
- package/dist/ai/service/CredentialReaderImpl.js.map +1 -0
- package/dist/ai/service/EmbeddingService.d.ts +8 -0
- package/dist/ai/service/EmbeddingService.js +10 -0
- package/dist/ai/service/EmbeddingService.js.map +1 -0
- package/dist/ai/service/EmbeddingServiceImpl.d.ts +11 -0
- package/dist/ai/service/EmbeddingServiceImpl.js +73 -0
- package/dist/ai/service/EmbeddingServiceImpl.js.map +1 -0
- package/dist/ai/service/ProviderRegistry.d.ts +26 -0
- package/dist/ai/service/ProviderRegistry.js +10 -0
- package/dist/ai/service/ProviderRegistry.js.map +1 -0
- package/dist/ai/service/ProviderRegistryImpl.d.ts +14 -0
- package/dist/ai/service/ProviderRegistryImpl.js +112 -0
- package/dist/ai/service/ProviderRegistryImpl.js.map +1 -0
- package/dist/ai/service/index.d.ts +10 -0
- package/dist/ai/service/index.js +29 -0
- package/dist/ai/service/index.js.map +1 -0
- package/dist/ai/service/types.d.ts +12 -0
- package/dist/ai/service/types.js +6 -0
- package/dist/ai/service/types.js.map +1 -0
- package/dist/api/ApiServer.d.ts +77 -0
- package/dist/api/ApiServer.js +191 -0
- package/dist/api/ApiServer.js.map +1 -0
- package/dist/api/auth/AuthContext.d.ts +41 -0
- package/dist/api/auth/AuthContext.js +44 -0
- package/dist/api/auth/AuthContext.js.map +1 -0
- package/dist/api/auth/Authenticator.d.ts +23 -0
- package/dist/api/auth/Authenticator.js +3 -0
- package/dist/api/auth/Authenticator.js.map +1 -0
- package/dist/api/auth/ClientCredentialsAuthenticator.d.ts +56 -0
- package/dist/api/auth/ClientCredentialsAuthenticator.js +191 -0
- package/dist/api/auth/ClientCredentialsAuthenticator.js.map +1 -0
- package/dist/api/auth/MultiAuthenticator.d.ts +15 -0
- package/dist/api/auth/MultiAuthenticator.js +36 -0
- package/dist/api/auth/MultiAuthenticator.js.map +1 -0
- package/dist/api/auth/NodeTokenAuthenticator.d.ts +21 -0
- package/dist/api/auth/NodeTokenAuthenticator.js +124 -0
- package/dist/api/auth/NodeTokenAuthenticator.js.map +1 -0
- package/dist/api/auth/SolidTokenAuthenticator.d.ts +27 -0
- package/dist/api/auth/SolidTokenAuthenticator.js +144 -0
- package/dist/api/auth/SolidTokenAuthenticator.js.map +1 -0
- package/dist/api/auth/index.d.ts +5 -0
- package/dist/api/auth/index.js +23 -0
- package/dist/api/auth/index.js.map +1 -0
- package/dist/api/chatkit/ai-provider.d.ts +44 -0
- package/dist/api/chatkit/ai-provider.js +157 -0
- package/dist/api/chatkit/ai-provider.js.map +1 -0
- package/dist/api/chatkit/index.d.ts +11 -0
- package/dist/api/chatkit/index.js +44 -0
- package/dist/api/chatkit/index.js.map +1 -0
- package/dist/api/chatkit/pod-store.d.ts +154 -0
- package/dist/api/chatkit/pod-store.js +794 -0
- package/dist/api/chatkit/pod-store.js.map +1 -0
- package/dist/api/chatkit/schema.d.ts +139 -0
- package/dist/api/chatkit/schema.js +168 -0
- package/dist/api/chatkit/schema.js.map +1 -0
- package/dist/api/chatkit/service.d.ts +143 -0
- package/dist/api/chatkit/service.js +442 -0
- package/dist/api/chatkit/service.js.map +1 -0
- package/dist/api/chatkit/store.d.ts +63 -0
- package/dist/api/chatkit/store.js +178 -0
- package/dist/api/chatkit/store.js.map +1 -0
- package/dist/api/chatkit/types.d.ts +461 -0
- package/dist/api/chatkit/types.js +50 -0
- package/dist/api/chatkit/types.js.map +1 -0
- package/dist/api/container/cloud.d.ts +12 -0
- package/dist/api/container/cloud.js +97 -0
- package/dist/api/container/cloud.js.map +1 -0
- package/dist/api/container/common.d.ts +11 -0
- package/dist/api/container/common.js +82 -0
- package/dist/api/container/common.js.map +1 -0
- package/dist/api/container/index.d.ts +16 -0
- package/dist/api/container/index.js +90 -0
- package/dist/api/container/index.js.map +1 -0
- package/dist/api/container/local.d.ts +13 -0
- package/dist/api/container/local.js +197 -0
- package/dist/api/container/local.js.map +1 -0
- package/dist/api/container/routes.d.ts +11 -0
- package/dist/api/container/routes.js +129 -0
- package/dist/api/container/routes.js.map +1 -0
- package/dist/api/container/types.d.ts +92 -0
- package/dist/api/container/types.js +8 -0
- package/dist/api/container/types.js.map +1 -0
- package/dist/api/handlers/AdminHandler.d.ts +6 -0
- package/dist/api/handlers/AdminHandler.js +330 -0
- package/dist/api/handlers/AdminHandler.js.map +1 -0
- package/dist/api/handlers/ApiKeyHandler.d.ts +15 -0
- package/dist/api/handlers/ApiKeyHandler.js +159 -0
- package/dist/api/handlers/ApiKeyHandler.js.map +1 -0
- package/dist/api/handlers/ChatHandler.d.ts +60 -0
- package/dist/api/handlers/ChatHandler.js +230 -0
- package/dist/api/handlers/ChatHandler.js.map +1 -0
- package/dist/api/handlers/ChatKitHandler.d.ts +18 -0
- package/dist/api/handlers/ChatKitHandler.js +151 -0
- package/dist/api/handlers/ChatKitHandler.js.map +1 -0
- package/dist/api/handlers/DashboardHandler.d.ts +14 -0
- package/dist/api/handlers/DashboardHandler.js +117 -0
- package/dist/api/handlers/DashboardHandler.js.map +1 -0
- package/dist/api/handlers/DdnsHandler.d.ts +19 -0
- package/dist/api/handlers/DdnsHandler.js +306 -0
- package/dist/api/handlers/DdnsHandler.js.map +1 -0
- package/dist/api/handlers/DevHandler.d.ts +18 -0
- package/dist/api/handlers/DevHandler.js +276 -0
- package/dist/api/handlers/DevHandler.js.map +1 -0
- package/dist/api/handlers/NodeHandler.d.ts +16 -0
- package/dist/api/handlers/NodeHandler.js +190 -0
- package/dist/api/handlers/NodeHandler.js.map +1 -0
- package/dist/api/handlers/PodManagementHandler.d.ts +39 -0
- package/dist/api/handlers/PodManagementHandler.js +294 -0
- package/dist/api/handlers/PodManagementHandler.js.map +1 -0
- package/dist/api/handlers/QuotaHandler.d.ts +21 -0
- package/dist/api/handlers/QuotaHandler.js +209 -0
- package/dist/api/handlers/QuotaHandler.js.map +1 -0
- package/dist/api/handlers/SignalHandler.d.ts +13 -0
- package/dist/api/handlers/SignalHandler.js +122 -0
- package/dist/api/handlers/SignalHandler.js.map +1 -0
- package/dist/api/handlers/SubdomainClientHandler.d.ts +24 -0
- package/dist/api/handlers/SubdomainClientHandler.js +169 -0
- package/dist/api/handlers/SubdomainClientHandler.js.map +1 -0
- package/dist/api/handlers/SubdomainHandler.d.ts +17 -0
- package/dist/api/handlers/SubdomainHandler.js +312 -0
- package/dist/api/handlers/SubdomainHandler.js.map +1 -0
- package/dist/api/handlers/VectorHandler.d.ts +15 -0
- package/dist/api/handlers/VectorHandler.js +293 -0
- package/dist/api/handlers/VectorHandler.js.map +1 -0
- package/dist/api/handlers/VectorStoreHandler.d.ts +20 -0
- package/dist/api/handlers/VectorStoreHandler.js +348 -0
- package/dist/api/handlers/VectorStoreHandler.js.map +1 -0
- package/dist/api/handlers/VectorStoreWebhookHandler.d.ts +74 -0
- package/dist/api/handlers/VectorStoreWebhookHandler.js +121 -0
- package/dist/api/handlers/VectorStoreWebhookHandler.js.map +1 -0
- package/dist/api/handlers/WebIdProfileHandler.d.ts +14 -0
- package/dist/api/handlers/WebIdProfileHandler.js +204 -0
- package/dist/api/handlers/WebIdProfileHandler.js.map +1 -0
- package/dist/api/handlers/index.d.ts +11 -0
- package/dist/api/handlers/index.js +28 -0
- package/dist/api/handlers/index.js.map +1 -0
- package/dist/api/index.d.ts +12 -0
- package/dist/api/index.js +29 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/main.d.ts +14 -0
- package/dist/api/main.js +106 -0
- package/dist/api/main.js.map +1 -0
- package/dist/api/middleware/AuthMiddleware.d.ts +35 -0
- package/dist/api/middleware/AuthMiddleware.js +51 -0
- package/dist/api/middleware/AuthMiddleware.js.map +1 -0
- package/dist/api/middleware/index.d.ts +1 -0
- package/dist/api/middleware/index.js +18 -0
- package/dist/api/middleware/index.js.map +1 -0
- package/dist/api/models/model-provider.schema.d.ts +12 -0
- package/dist/api/models/model-provider.schema.js +21 -0
- package/dist/api/models/model-provider.schema.js.map +1 -0
- package/dist/api/models/namespaces.d.ts +9 -0
- package/dist/api/models/namespaces.js +34 -0
- package/dist/api/models/namespaces.js.map +1 -0
- package/dist/api/service/InternalPodService.d.ts +19 -0
- package/dist/api/service/InternalPodService.js +82 -0
- package/dist/api/service/InternalPodService.js.map +1 -0
- package/dist/api/service/VectorService.d.ts +156 -0
- package/dist/api/service/VectorService.js +202 -0
- package/dist/api/service/VectorService.js.map +1 -0
- package/dist/api/service/VectorStoreService.d.ts +262 -0
- package/dist/api/service/VectorStoreService.js +985 -0
- package/dist/api/service/VectorStoreService.js.map +1 -0
- package/dist/api/service/VercelChatService.d.ts +28 -0
- package/dist/api/service/VercelChatService.js +289 -0
- package/dist/api/service/VercelChatService.js.map +1 -0
- package/dist/api/store/DrizzleClientCredentialsStore.d.ts +56 -0
- package/dist/api/store/DrizzleClientCredentialsStore.js +145 -0
- package/dist/api/store/DrizzleClientCredentialsStore.js.map +1 -0
- package/dist/api/store/index.d.ts +1 -0
- package/dist/api/store/index.js +18 -0
- package/dist/api/store/index.js.map +1 -0
- package/dist/components/components.jsonld +88 -0
- package/dist/components/context.jsonld +1962 -0
- package/dist/credential/index.d.ts +1 -0
- package/dist/credential/index.js +18 -0
- package/dist/credential/index.js.map +1 -0
- package/dist/credential/schema/index.d.ts +2 -0
- package/dist/credential/schema/index.js +19 -0
- package/dist/credential/schema/index.js.map +1 -0
- package/dist/credential/schema/tables.d.ts +31 -0
- package/dist/credential/schema/tables.js +42 -0
- package/dist/credential/schema/tables.js.map +1 -0
- package/dist/credential/schema/types.d.ts +20 -0
- package/dist/credential/schema/types.js +26 -0
- package/dist/credential/schema/types.js.map +1 -0
- package/dist/dns/DnsProvider.d.ts +46 -0
- package/dist/dns/DnsProvider.js +3 -0
- package/dist/dns/DnsProvider.js.map +1 -0
- package/dist/dns/DnsProvider.jsonld +161 -0
- package/dist/dns/cloudflare/CloudflareDnsProvider.d.ts +51 -0
- package/dist/dns/cloudflare/CloudflareDnsProvider.js +227 -0
- package/dist/dns/cloudflare/CloudflareDnsProvider.js.map +1 -0
- package/dist/dns/cloudflare/index.d.ts +1 -0
- package/dist/dns/cloudflare/index.js +18 -0
- package/dist/dns/cloudflare/index.js.map +1 -0
- package/dist/dns/tencent/TencentDnsProvider.d.ts +42 -0
- package/dist/dns/tencent/TencentDnsProvider.js +221 -0
- package/dist/dns/tencent/TencentDnsProvider.js.map +1 -0
- package/dist/dns/tencent/TencentDnsProvider.jsonld +239 -0
- package/dist/document/Chunker.d.ts +64 -0
- package/dist/document/Chunker.js +8 -0
- package/dist/document/Chunker.js.map +1 -0
- package/dist/document/DocumentParser.d.ts +58 -0
- package/dist/document/DocumentParser.js +8 -0
- package/dist/document/DocumentParser.js.map +1 -0
- package/dist/document/HeadingChunker.d.ts +34 -0
- package/dist/document/HeadingChunker.js +182 -0
- package/dist/document/HeadingChunker.js.map +1 -0
- package/dist/document/JinaDocumentParser.d.ts +40 -0
- package/dist/document/JinaDocumentParser.js +129 -0
- package/dist/document/JinaDocumentParser.js.map +1 -0
- package/dist/document/index.d.ts +7 -0
- package/dist/document/index.js +26 -0
- package/dist/document/index.js.map +1 -0
- package/dist/edge/DdnsManager.d.ts +53 -0
- package/dist/edge/DdnsManager.js +153 -0
- package/dist/edge/DdnsManager.js.map +1 -0
- package/dist/edge/Dns01CertificateProvisioner.d.ts +27 -0
- package/dist/edge/Dns01CertificateProvisioner.js +160 -0
- package/dist/edge/Dns01CertificateProvisioner.js.map +1 -0
- package/dist/edge/Dns01CertificateProvisioner.jsonld +148 -0
- package/dist/edge/EdgeNodeAgent.d.ts +56 -0
- package/dist/edge/EdgeNodeAgent.js +230 -0
- package/dist/edge/EdgeNodeAgent.js.map +1 -0
- package/dist/edge/EdgeNodeAgent.jsonld +89 -0
- package/dist/edge/EdgeNodeAgentInitializer.d.ts +25 -0
- package/dist/edge/EdgeNodeAgentInitializer.js +64 -0
- package/dist/edge/EdgeNodeAgentInitializer.js.map +1 -0
- package/dist/edge/EdgeNodeCapabilityDetector.d.ts +98 -0
- package/dist/edge/EdgeNodeCapabilityDetector.js +425 -0
- package/dist/edge/EdgeNodeCapabilityDetector.js.map +1 -0
- package/dist/edge/EdgeNodeCertificateProvisioner.d.ts +3 -0
- package/dist/edge/EdgeNodeCertificateProvisioner.js +3 -0
- package/dist/edge/EdgeNodeCertificateProvisioner.js.map +1 -0
- package/dist/edge/EdgeNodeCertificateProvisioner.jsonld +21 -0
- package/dist/edge/EdgeNodeDnsCoordinator.d.ts +38 -0
- package/dist/edge/EdgeNodeDnsCoordinator.js +201 -0
- package/dist/edge/EdgeNodeDnsCoordinator.js.map +1 -0
- package/dist/edge/EdgeNodeDnsCoordinator.jsonld +212 -0
- package/dist/edge/EdgeNodeHealthProbeService.d.ts +25 -0
- package/dist/edge/EdgeNodeHealthProbeService.js +208 -0
- package/dist/edge/EdgeNodeHealthProbeService.js.map +1 -0
- package/dist/edge/EdgeNodeHealthProbeService.jsonld +176 -0
- package/dist/edge/EdgeNodeModeDetector.d.ts +50 -0
- package/dist/edge/EdgeNodeModeDetector.js +194 -0
- package/dist/edge/EdgeNodeModeDetector.js.map +1 -0
- package/dist/edge/EdgeNodeModeDetector.jsonld +114 -0
- package/dist/edge/EdgeNodeTunnelManager.d.ts +23 -0
- package/dist/edge/EdgeNodeTunnelManager.js +99 -0
- package/dist/edge/EdgeNodeTunnelManager.js.map +1 -0
- package/dist/edge/EdgeNodeTunnelManager.jsonld +128 -0
- package/dist/edge/FrpTunnelManager.d.ts +30 -0
- package/dist/edge/FrpTunnelManager.js +151 -0
- package/dist/edge/FrpTunnelManager.js.map +1 -0
- package/dist/edge/FrpTunnelManager.jsonld +192 -0
- package/dist/edge/LocalNetworkManager.d.ts +41 -0
- package/dist/edge/LocalNetworkManager.js +115 -0
- package/dist/edge/LocalNetworkManager.js.map +1 -0
- package/dist/edge/acme/AcmeCertificateManager.d.ts +65 -0
- package/dist/edge/acme/AcmeCertificateManager.js +233 -0
- package/dist/edge/acme/AcmeCertificateManager.js.map +1 -0
- package/dist/edge/acme/AcmeCertificateManager.jsonld +373 -0
- package/dist/edge/acme/ClusterCertificateManager.d.ts +40 -0
- package/dist/edge/acme/ClusterCertificateManager.js +184 -0
- package/dist/edge/acme/ClusterCertificateManager.js.map +1 -0
- package/dist/edge/acme/DnsChallengeClient.d.ts +15 -0
- package/dist/edge/acme/DnsChallengeClient.js +40 -0
- package/dist/edge/acme/DnsChallengeClient.js.map +1 -0
- package/dist/edge/acme/utils.d.ts +4 -0
- package/dist/edge/acme/utils.js +17 -0
- package/dist/edge/acme/utils.js.map +1 -0
- package/dist/edge/frp/FrpRelay.d.ts +11 -0
- package/dist/edge/frp/FrpRelay.js +29 -0
- package/dist/edge/frp/FrpRelay.js.map +1 -0
- package/dist/edge/frp/FrpcProcessManager.d.ts +51 -0
- package/dist/edge/frp/FrpcProcessManager.js +174 -0
- package/dist/edge/frp/FrpcProcessManager.js.map +1 -0
- package/dist/edge/interfaces/EdgeNodeTunnelManager.d.ts +6 -0
- package/dist/edge/interfaces/EdgeNodeTunnelManager.js +3 -0
- package/dist/edge/interfaces/EdgeNodeTunnelManager.js.map +1 -0
- package/dist/edge/interfaces/EdgeNodeTunnelManager.jsonld +21 -0
- package/dist/embedding/CredentialReader.d.ts +7 -0
- package/dist/embedding/CredentialReader.js +10 -0
- package/dist/embedding/CredentialReader.js.map +1 -0
- package/dist/embedding/CredentialReader.jsonld +22 -0
- package/dist/embedding/CredentialReaderImpl.d.ts +6 -0
- package/dist/embedding/CredentialReaderImpl.js +55 -0
- package/dist/embedding/CredentialReaderImpl.js.map +1 -0
- package/dist/embedding/CredentialReaderImpl.jsonld +31 -0
- package/dist/embedding/EmbeddingService.d.ts +8 -0
- package/dist/embedding/EmbeddingService.js +10 -0
- package/dist/embedding/EmbeddingService.js.map +1 -0
- package/dist/embedding/EmbeddingService.jsonld +26 -0
- package/dist/embedding/EmbeddingServiceImpl.d.ts +11 -0
- package/dist/embedding/EmbeddingServiceImpl.js +73 -0
- package/dist/embedding/EmbeddingServiceImpl.js.map +1 -0
- package/dist/embedding/EmbeddingServiceImpl.jsonld +53 -0
- package/dist/embedding/ProviderRegistry.d.ts +26 -0
- package/dist/embedding/ProviderRegistry.js +10 -0
- package/dist/embedding/ProviderRegistry.js.map +1 -0
- package/dist/embedding/ProviderRegistry.jsonld +30 -0
- package/dist/embedding/ProviderRegistryImpl.d.ts +14 -0
- package/dist/embedding/ProviderRegistryImpl.js +112 -0
- package/dist/embedding/ProviderRegistryImpl.js.map +1 -0
- package/dist/embedding/ProviderRegistryImpl.jsonld +40 -0
- package/dist/embedding/index.d.ts +5 -0
- package/dist/embedding/index.js +22 -0
- package/dist/embedding/index.js.map +1 -0
- package/dist/embedding/schema/index.d.ts +1 -0
- package/dist/embedding/schema/index.js +18 -0
- package/dist/embedding/schema/index.js.map +1 -0
- package/dist/embedding/schema/tables.d.ts +70 -0
- package/dist/embedding/schema/tables.js +102 -0
- package/dist/embedding/schema/tables.js.map +1 -0
- package/dist/embedding/types.d.ts +12 -0
- package/dist/embedding/types.js +6 -0
- package/dist/embedding/types.js.map +1 -0
- package/dist/gateway/port-finder.d.ts +4 -0
- package/dist/gateway/port-finder.js +15 -0
- package/dist/gateway/port-finder.js.map +1 -0
- package/dist/gateway/proxy.d.ts +22 -0
- package/dist/gateway/proxy.js +149 -0
- package/dist/gateway/proxy.js.map +1 -0
- package/dist/gateway/supervisor.d.ts +2 -0
- package/dist/gateway/supervisor.js +7 -0
- package/dist/gateway/supervisor.js.map +1 -0
- package/dist/gateway/types.d.ts +1 -0
- package/dist/gateway/types.js +3 -0
- package/dist/gateway/types.js.map +1 -0
- package/dist/http/AppStaticAssetHandler.d.ts +8 -0
- package/dist/http/AppStaticAssetHandler.js +27 -0
- package/dist/http/AppStaticAssetHandler.js.map +1 -0
- package/dist/http/AppStaticAssetHandler.jsonld +26 -0
- package/dist/http/ClusterIngressRouter.d.ts +93 -0
- package/dist/http/ClusterIngressRouter.js +355 -0
- package/dist/http/ClusterIngressRouter.js.map +1 -0
- package/dist/http/ClusterIngressRouter.jsonld +227 -0
- package/dist/http/ClusterWebSocketConfigurator.d.ts +59 -0
- package/dist/http/ClusterWebSocketConfigurator.js +226 -0
- package/dist/http/ClusterWebSocketConfigurator.js.map +1 -0
- package/dist/http/ClusterWebSocketConfigurator.jsonld +145 -0
- package/dist/http/EdgeNodeDirectDebugHttpHandler.d.ts +25 -0
- package/dist/http/EdgeNodeDirectDebugHttpHandler.js +126 -0
- package/dist/http/EdgeNodeDirectDebugHttpHandler.js.map +1 -0
- package/dist/http/EdgeNodeDirectDebugHttpHandler.jsonld +151 -0
- package/dist/http/EdgeNodeProxyHttpHandler.d.ts +28 -0
- package/dist/http/EdgeNodeProxyHttpHandler.js +190 -0
- package/dist/http/EdgeNodeProxyHttpHandler.js.map +1 -0
- package/dist/http/EdgeNodeProxyHttpHandler.jsonld +162 -0
- package/dist/http/PodRoutingHttpHandler.d.ts +64 -0
- package/dist/http/PodRoutingHttpHandler.js +233 -0
- package/dist/http/PodRoutingHttpHandler.js.map +1 -0
- package/dist/http/PodRoutingHttpHandler.jsonld +171 -0
- package/dist/http/RequestIdHttpHandler.d.ts +15 -0
- package/dist/http/RequestIdHttpHandler.js +59 -0
- package/dist/http/RequestIdHttpHandler.js.map +1 -0
- package/dist/http/RouterHttpHandler.d.ts +21 -0
- package/dist/http/RouterHttpHandler.js +49 -0
- package/dist/http/RouterHttpHandler.js.map +1 -0
- package/dist/http/RouterHttpHandler.jsonld +80 -0
- package/dist/http/RouterHttpRoute.d.ts +6 -0
- package/dist/http/RouterHttpRoute.js +11 -0
- package/dist/http/RouterHttpRoute.js.map +1 -0
- package/dist/http/RouterHttpRoute.jsonld +48 -0
- package/dist/http/SignalInterceptHttpHandler.d.ts +24 -0
- package/dist/http/SignalInterceptHttpHandler.js +47 -0
- package/dist/http/SignalInterceptHttpHandler.js.map +1 -0
- package/dist/http/SignalInterceptHttpHandler.jsonld +103 -0
- package/dist/http/SubgraphSparqlHttpHandler.d.ts +70 -0
- package/dist/http/SubgraphSparqlHttpHandler.js +640 -0
- package/dist/http/SubgraphSparqlHttpHandler.js.map +1 -0
- package/dist/http/SubgraphSparqlHttpHandler.jsonld +363 -0
- package/dist/http/TracingHandler.d.ts +19 -0
- package/dist/http/TracingHandler.js +60 -0
- package/dist/http/TracingHandler.js.map +1 -0
- package/dist/http/TracingHandler.jsonld +37 -0
- package/dist/http/admin/EdgeNodeAdminHttpHandler.d.ts +45 -0
- package/dist/http/admin/EdgeNodeAdminHttpHandler.js +292 -0
- package/dist/http/admin/EdgeNodeAdminHttpHandler.js.map +1 -0
- package/dist/http/admin/EdgeNodeCertificateHttpHandler.d.ts +33 -0
- package/dist/http/admin/EdgeNodeCertificateHttpHandler.js +172 -0
- package/dist/http/admin/EdgeNodeCertificateHttpHandler.js.map +1 -0
- package/dist/http/admin/EdgeNodeCertificateHttpHandler.jsonld +182 -0
- package/dist/http/admin/EdgeNodeSignalHttpHandler.d.ts +71 -0
- package/dist/http/admin/EdgeNodeSignalHttpHandler.js +674 -0
- package/dist/http/admin/EdgeNodeSignalHttpHandler.js.map +1 -0
- package/dist/http/admin/EdgeNodeSignalHttpHandler.jsonld +406 -0
- package/dist/http/cluster/PodMigrationHttpHandler.d.ts +52 -0
- package/dist/http/cluster/PodMigrationHttpHandler.js +208 -0
- package/dist/http/cluster/PodMigrationHttpHandler.js.map +1 -0
- package/dist/http/cluster/PodMigrationHttpHandler.jsonld +169 -0
- package/dist/http/quota/QuotaAdminHttpHandler.d.ts +34 -0
- package/dist/http/quota/QuotaAdminHttpHandler.js +241 -0
- package/dist/http/quota/QuotaAdminHttpHandler.js.map +1 -0
- package/dist/http/quota/QuotaAdminHttpHandler.jsonld +171 -0
- package/dist/http/search/SearchHttpHandler.d.ts +59 -0
- package/dist/http/search/SearchHttpHandler.js +312 -0
- package/dist/http/search/SearchHttpHandler.js.map +1 -0
- package/dist/http/search/index.d.ts +1 -0
- package/dist/http/search/index.js +18 -0
- package/dist/http/search/index.js.map +1 -0
- package/dist/http/terminal/TerminalHttpHandler.d.ts +45 -0
- package/dist/http/terminal/TerminalHttpHandler.js +306 -0
- package/dist/http/terminal/TerminalHttpHandler.js.map +1 -0
- package/dist/http/terminal/TerminalHttpHandler.jsonld +232 -0
- package/dist/http/terminal/index.d.ts +1 -0
- package/dist/http/terminal/index.js +18 -0
- package/dist/http/terminal/index.js.map +1 -0
- package/dist/http/vector/VectorHttpHandler.d.ts +42 -0
- package/dist/http/vector/VectorHttpHandler.js +301 -0
- package/dist/http/vector/VectorHttpHandler.js.map +1 -0
- package/dist/http/vector/VectorHttpHandler.jsonld +157 -0
- package/dist/http/vector/index.d.ts +1 -0
- package/dist/http/vector/index.js +18 -0
- package/dist/http/vector/index.js.map +1 -0
- package/dist/ice/IceServerProvider.d.ts +85 -0
- package/dist/ice/IceServerProvider.js +122 -0
- package/dist/ice/IceServerProvider.js.map +1 -0
- package/dist/ice/index.d.ts +8 -0
- package/dist/ice/index.js +25 -0
- package/dist/ice/index.js.map +1 -0
- package/dist/identity/CenterNodeRegistrationService.d.ts +102 -0
- package/dist/identity/CenterNodeRegistrationService.js +266 -0
- package/dist/identity/CenterNodeRegistrationService.js.map +1 -0
- package/dist/identity/CenterNodeRegistrationService.jsonld +251 -0
- package/dist/identity/ReactAppViewHandler.d.ts +31 -0
- package/dist/identity/ReactAppViewHandler.js +79 -0
- package/dist/identity/ReactAppViewHandler.js.map +1 -0
- package/dist/identity/ReactAppViewHandler.jsonld +99 -0
- package/dist/identity/drizzle/AccountRepository.d.ts +31 -0
- package/dist/identity/drizzle/AccountRepository.js +130 -0
- package/dist/identity/drizzle/AccountRepository.js.map +1 -0
- package/dist/identity/drizzle/AccountRoleRepository.d.ts +23 -0
- package/dist/identity/drizzle/AccountRoleRepository.js +233 -0
- package/dist/identity/drizzle/AccountRoleRepository.js.map +1 -0
- package/dist/identity/drizzle/DdnsRepository.d.ts +87 -0
- package/dist/identity/drizzle/DdnsRepository.js +284 -0
- package/dist/identity/drizzle/DdnsRepository.js.map +1 -0
- package/dist/identity/drizzle/DrizzleIndexedStorage.d.ts +26 -0
- package/dist/identity/drizzle/DrizzleIndexedStorage.js +159 -0
- package/dist/identity/drizzle/DrizzleIndexedStorage.js.map +1 -0
- package/dist/identity/drizzle/DrizzleIndexedStorage.jsonld +130 -0
- package/dist/identity/drizzle/EdgeNodeRepository.d.ts +155 -0
- package/dist/identity/drizzle/EdgeNodeRepository.js +555 -0
- package/dist/identity/drizzle/EdgeNodeRepository.js.map +1 -0
- package/dist/identity/drizzle/PodLookupRepository.d.ts +59 -0
- package/dist/identity/drizzle/PodLookupRepository.js +153 -0
- package/dist/identity/drizzle/PodLookupRepository.js.map +1 -0
- package/dist/identity/drizzle/WebIdProfileRepository.d.ts +58 -0
- package/dist/identity/drizzle/WebIdProfileRepository.js +157 -0
- package/dist/identity/drizzle/WebIdProfileRepository.js.map +1 -0
- package/dist/identity/drizzle/db.d.ts +60 -0
- package/dist/identity/drizzle/db.js +269 -0
- package/dist/identity/drizzle/db.js.map +1 -0
- package/dist/identity/drizzle/schema.d.ts +1 -0
- package/dist/identity/drizzle/schema.js +20 -0
- package/dist/identity/drizzle/schema.js.map +1 -0
- package/dist/identity/drizzle/schema.pg.d.ts +20 -0
- package/dist/identity/drizzle/schema.pg.js +103 -0
- package/dist/identity/drizzle/schema.pg.js.map +1 -0
- package/dist/identity/drizzle/schema.sqlite.d.ts +872 -0
- package/dist/identity/drizzle/schema.sqlite.js +100 -0
- package/dist/identity/drizzle/schema.sqlite.js.map +1 -0
- package/dist/identity/oidc/AutoDetectIdentityProviderHandler.d.ts +43 -0
- package/dist/identity/oidc/AutoDetectIdentityProviderHandler.js +92 -0
- package/dist/identity/oidc/AutoDetectIdentityProviderHandler.js.map +1 -0
- package/dist/identity/oidc/AutoDetectIdentityProviderHandler.jsonld +122 -0
- package/dist/identity/oidc/AutoDetectOidcHandler.d.ts +55 -0
- package/dist/identity/oidc/AutoDetectOidcHandler.js +137 -0
- package/dist/identity/oidc/AutoDetectOidcHandler.js.map +1 -0
- package/dist/identity/oidc/AutoDetectOidcHandler.jsonld +138 -0
- package/dist/identity/oidc/DisabledIdentityProviderHandler.d.ts +51 -0
- package/dist/identity/oidc/DisabledIdentityProviderHandler.js +104 -0
- package/dist/identity/oidc/DisabledIdentityProviderHandler.js.map +1 -0
- package/dist/identity/oidc/DisabledIdentityProviderHandler.jsonld +111 -0
- package/dist/identity/oidc/DisabledOidcHandler.d.ts +55 -0
- package/dist/identity/oidc/DisabledOidcHandler.js +132 -0
- package/dist/identity/oidc/DisabledOidcHandler.js.map +1 -0
- package/dist/identity/oidc/DisabledOidcHandler.jsonld +157 -0
- package/dist/index.d.ts +80 -0
- package/dist/index.js +155 -0
- package/dist/index.js.map +1 -0
- package/dist/legacy/DrizzleClientCredentialsStore.d.ts +51 -0
- package/dist/legacy/DrizzleClientCredentialsStore.js +142 -0
- package/dist/legacy/DrizzleClientCredentialsStore.js.map +1 -0
- package/dist/legacy/DrizzleIndexedStorage.d.ts +26 -0
- package/dist/legacy/DrizzleIndexedStorage.js +159 -0
- package/dist/legacy/DrizzleIndexedStorage.js.map +1 -0
- package/dist/legacy/DrizzleQuotaService.d.ts +16 -0
- package/dist/legacy/DrizzleQuotaService.js +37 -0
- package/dist/legacy/DrizzleQuotaService.js.map +1 -0
- package/dist/libs/backends/index.d.ts +6 -0
- package/dist/libs/backends/index.js +31 -0
- package/dist/libs/backends/index.js.map +1 -0
- package/dist/libs/backends/sqlup.d.ts +44 -0
- package/dist/libs/backends/sqlup.js +437 -0
- package/dist/libs/backends/sqlup.js.map +1 -0
- package/dist/logging/ConfigurableLoggerFactory.d.ts +24 -0
- package/dist/logging/ConfigurableLoggerFactory.js +77 -0
- package/dist/logging/ConfigurableLoggerFactory.js.map +1 -0
- package/dist/logging/ConfigurableLoggerFactory.jsonld +169 -0
- package/dist/logging/LogContext.d.ts +5 -0
- package/dist/logging/LogContext.js +6 -0
- package/dist/logging/LogContext.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.js +148 -0
- package/dist/main.js.map +1 -0
- package/dist/network/LocalNetworkDetector.d.ts +65 -0
- package/dist/network/LocalNetworkDetector.js +185 -0
- package/dist/network/LocalNetworkDetector.js.map +1 -0
- package/dist/network/index.d.ts +4 -0
- package/dist/network/index.js +21 -0
- package/dist/network/index.js.map +1 -0
- package/dist/pods/ReservedSuffixIdentifierGenerator.d.ts +13 -0
- package/dist/pods/ReservedSuffixIdentifierGenerator.js +26 -0
- package/dist/pods/ReservedSuffixIdentifierGenerator.js.map +1 -0
- package/dist/pods/ReservedSuffixIdentifierGenerator.jsonld +75 -0
- package/dist/quota/DefaultQuotaService.d.ts +16 -0
- package/dist/quota/DefaultQuotaService.js +37 -0
- package/dist/quota/DefaultQuotaService.js.map +1 -0
- package/dist/quota/DefaultQuotaService.jsonld +85 -0
- package/dist/quota/DrizzleQuotaService.d.ts +16 -0
- package/dist/quota/DrizzleQuotaService.js +37 -0
- package/dist/quota/DrizzleQuotaService.js.map +1 -0
- package/dist/quota/DrizzleQuotaService.jsonld +87 -0
- package/dist/quota/NoopQuotaService.d.ts +7 -0
- package/dist/quota/NoopQuotaService.js +15 -0
- package/dist/quota/NoopQuotaService.js.map +1 -0
- package/dist/quota/NoopQuotaService.jsonld +36 -0
- package/dist/quota/QuotaService.d.ts +6 -0
- package/dist/quota/QuotaService.js +3 -0
- package/dist/quota/QuotaService.js.map +1 -0
- package/dist/quota/QuotaService.jsonld +33 -0
- package/dist/sdk/SignalingClientAdapter.d.ts +38 -0
- package/dist/sdk/SignalingClientAdapter.js +99 -0
- package/dist/sdk/SignalingClientAdapter.js.map +1 -0
- package/dist/sdk/createFetch.d.ts +23 -0
- package/dist/sdk/createFetch.js +258 -0
- package/dist/sdk/createFetch.js.map +1 -0
- package/dist/sdk/index.d.ts +29 -0
- package/dist/sdk/index.js +34 -0
- package/dist/sdk/index.js.map +1 -0
- package/dist/sdk/xpodFetch.d.ts +112 -0
- package/dist/sdk/xpodFetch.js +251 -0
- package/dist/sdk/xpodFetch.js.map +1 -0
- package/dist/service/EdgeNodeCertificateService.d.ts +45 -0
- package/dist/service/EdgeNodeCertificateService.js +164 -0
- package/dist/service/EdgeNodeCertificateService.js.map +1 -0
- package/dist/service/EdgeNodeCertificateService.jsonld +216 -0
- package/dist/service/EdgeNodeHeartbeatService.d.ts +68 -0
- package/dist/service/EdgeNodeHeartbeatService.js +262 -0
- package/dist/service/EdgeNodeHeartbeatService.js.map +1 -0
- package/dist/service/PodMigrationService.d.ts +43 -0
- package/dist/service/PodMigrationService.js +72 -0
- package/dist/service/PodMigrationService.js.map +1 -0
- package/dist/service/PodMigrationService.jsonld +76 -0
- package/dist/signaling/SignalingClient.d.ts +142 -0
- package/dist/signaling/SignalingClient.js +305 -0
- package/dist/signaling/SignalingClient.js.map +1 -0
- package/dist/signaling/SignalingService.d.ts +104 -0
- package/dist/signaling/SignalingService.js +440 -0
- package/dist/signaling/SignalingService.js.map +1 -0
- package/dist/signaling/index.d.ts +11 -0
- package/dist/signaling/index.js +28 -0
- package/dist/signaling/index.js.map +1 -0
- package/dist/signaling/types.d.ts +237 -0
- package/dist/signaling/types.js +18 -0
- package/dist/signaling/types.js.map +1 -0
- package/dist/storage/DrizzleCompat.d.ts +15 -0
- package/dist/storage/DrizzleCompat.js +60 -0
- package/dist/storage/DrizzleCompat.js.map +1 -0
- package/dist/storage/LockingResourceStore.d.ts +8 -0
- package/dist/storage/LockingResourceStore.js +68 -0
- package/dist/storage/LockingResourceStore.js.map +1 -0
- package/dist/storage/MigratableDataAccessor.d.ts +63 -0
- package/dist/storage/MigratableDataAccessor.js +11 -0
- package/dist/storage/MigratableDataAccessor.js.map +1 -0
- package/dist/storage/MigratableDataAccessor.jsonld +60 -0
- package/dist/storage/ObservableResourceStore.d.ts +89 -0
- package/dist/storage/ObservableResourceStore.js +125 -0
- package/dist/storage/ObservableResourceStore.js.map +1 -0
- package/dist/storage/RepresentationPartialConvertingStore.d.ts +22 -0
- package/dist/storage/RepresentationPartialConvertingStore.js +94 -0
- package/dist/storage/RepresentationPartialConvertingStore.js.map +1 -0
- package/dist/storage/RepresentationPartialConvertingStore.jsonld +332 -0
- package/dist/storage/SparqlUpdateResourceStore.d.ts +30 -0
- package/dist/storage/SparqlUpdateResourceStore.js +292 -0
- package/dist/storage/SparqlUpdateResourceStore.js.map +1 -0
- package/dist/storage/SparqlUpdateResourceStore.jsonld +112 -0
- package/dist/storage/SqliteCompat.d.ts +60 -0
- package/dist/storage/SqliteCompat.js +158 -0
- package/dist/storage/SqliteCompat.js.map +1 -0
- package/dist/storage/accessors/MinioDataAccessor.d.ts +127 -0
- package/dist/storage/accessors/MinioDataAccessor.js +249 -0
- package/dist/storage/accessors/MinioDataAccessor.js.map +1 -0
- package/dist/storage/accessors/MinioDataAccessor.jsonld +138 -0
- package/dist/storage/accessors/MixDataAccessor.d.ts +43 -0
- package/dist/storage/accessors/MixDataAccessor.js +130 -0
- package/dist/storage/accessors/MixDataAccessor.js.map +1 -0
- package/dist/storage/accessors/MixDataAccessor.jsonld +101 -0
- package/dist/storage/accessors/QuadstoreSparqlDataAccessor.d.ts +146 -0
- package/dist/storage/accessors/QuadstoreSparqlDataAccessor.js +415 -0
- package/dist/storage/accessors/QuadstoreSparqlDataAccessor.js.map +1 -0
- package/dist/storage/accessors/QuadstoreSparqlDataAccessor.jsonld +180 -0
- package/dist/storage/accessors/QuintStoreSparqlDataAccessor.d.ts +95 -0
- package/dist/storage/accessors/QuintStoreSparqlDataAccessor.js +376 -0
- package/dist/storage/accessors/QuintStoreSparqlDataAccessor.js.map +1 -0
- package/dist/storage/accessors/QuintStoreSparqlDataAccessor.jsonld +168 -0
- package/dist/storage/accessors/TieredMinioDataAccessor.d.ts +150 -0
- package/dist/storage/accessors/TieredMinioDataAccessor.js +582 -0
- package/dist/storage/accessors/TieredMinioDataAccessor.js.map +1 -0
- package/dist/storage/accessors/TieredMinioDataAccessor.jsonld +333 -0
- package/dist/storage/database/PostgresPoolManager.d.ts +56 -0
- package/dist/storage/database/PostgresPoolManager.js +117 -0
- package/dist/storage/database/PostgresPoolManager.js.map +1 -0
- package/dist/storage/keyvalue/PostgresKeyValueStorage.d.ts +34 -0
- package/dist/storage/keyvalue/PostgresKeyValueStorage.js +146 -0
- package/dist/storage/keyvalue/PostgresKeyValueStorage.js.map +1 -0
- package/dist/storage/keyvalue/PostgresKeyValueStorage.jsonld +192 -0
- package/dist/storage/keyvalue/RedisKeyValueStorage.d.ts +30 -0
- package/dist/storage/keyvalue/RedisKeyValueStorage.js +133 -0
- package/dist/storage/keyvalue/RedisKeyValueStorage.js.map +1 -0
- package/dist/storage/keyvalue/RedisKeyValueStorage.jsonld +237 -0
- package/dist/storage/keyvalue/SqliteKeyValueStorage.d.ts +30 -0
- package/dist/storage/keyvalue/SqliteKeyValueStorage.js +164 -0
- package/dist/storage/keyvalue/SqliteKeyValueStorage.js.map +1 -0
- package/dist/storage/keyvalue/SqliteKeyValueStorage.jsonld +167 -0
- package/dist/storage/quint/BaseQuintStore.d.ts +80 -0
- package/dist/storage/quint/BaseQuintStore.js +535 -0
- package/dist/storage/quint/BaseQuintStore.js.map +1 -0
- package/dist/storage/quint/BaseQuintStore.jsonld +175 -0
- package/dist/storage/quint/PgQuintStore.d.ts +61 -0
- package/dist/storage/quint/PgQuintStore.drizzle.d.ts +45 -0
- package/dist/storage/quint/PgQuintStore.drizzle.js +327 -0
- package/dist/storage/quint/PgQuintStore.drizzle.js.map +1 -0
- package/dist/storage/quint/PgQuintStore.js +275 -0
- package/dist/storage/quint/PgQuintStore.js.map +1 -0
- package/dist/storage/quint/PgQuintStore.jsonld +258 -0
- package/dist/storage/quint/SqliteQuintStore.d.ts +55 -0
- package/dist/storage/quint/SqliteQuintStore.js +630 -0
- package/dist/storage/quint/SqliteQuintStore.js.map +1 -0
- package/dist/storage/quint/SqliteQuintStore.jsonld +157 -0
- package/dist/storage/quint/index.d.ts +11 -0
- package/dist/storage/quint/index.js +30 -0
- package/dist/storage/quint/index.js.map +1 -0
- package/dist/storage/quint/schema.d.ts +82 -0
- package/dist/storage/quint/schema.js +33 -0
- package/dist/storage/quint/schema.js.map +1 -0
- package/dist/storage/quint/serialization.d.ts +56 -0
- package/dist/storage/quint/serialization.js +198 -0
- package/dist/storage/quint/serialization.js.map +1 -0
- package/dist/storage/quint/types.d.ts +152 -0
- package/dist/storage/quint/types.js +27 -0
- package/dist/storage/quint/types.js.map +1 -0
- package/dist/storage/quint/types.jsonld +78 -0
- package/dist/storage/quota/PerAccountQuotaStrategy.d.ts +19 -0
- package/dist/storage/quota/PerAccountQuotaStrategy.js +63 -0
- package/dist/storage/quota/PerAccountQuotaStrategy.js.map +1 -0
- package/dist/storage/quota/PerAccountQuotaStrategy.jsonld +113 -0
- package/dist/storage/quota/UsageRepository.d.ts +46 -0
- package/dist/storage/quota/UsageRepository.js +278 -0
- package/dist/storage/quota/UsageRepository.js.map +1 -0
- package/dist/storage/quota/UsageTrackingStore.d.ts +37 -0
- package/dist/storage/quota/UsageTrackingStore.js +355 -0
- package/dist/storage/quota/UsageTrackingStore.js.map +1 -0
- package/dist/storage/quota/UsageTrackingStore.jsonld +193 -0
- package/dist/storage/sparql/AlgebraUtils.d.ts +48 -0
- package/dist/storage/sparql/AlgebraUtils.js +118 -0
- package/dist/storage/sparql/AlgebraUtils.js.map +1 -0
- package/dist/storage/sparql/ComunicaOptimizedEngine.d.ts +59 -0
- package/dist/storage/sparql/ComunicaOptimizedEngine.js +254 -0
- package/dist/storage/sparql/ComunicaOptimizedEngine.js.map +1 -0
- package/dist/storage/sparql/ComunicaQuintEngine.d.ts +134 -0
- package/dist/storage/sparql/ComunicaQuintEngine.js +727 -0
- package/dist/storage/sparql/ComunicaQuintEngine.js.map +1 -0
- package/dist/storage/sparql/ExpressionEvaluator.d.ts +54 -0
- package/dist/storage/sparql/ExpressionEvaluator.js +340 -0
- package/dist/storage/sparql/ExpressionEvaluator.js.map +1 -0
- package/dist/storage/sparql/FilterPushdownExtractor.d.ts +74 -0
- package/dist/storage/sparql/FilterPushdownExtractor.js +409 -0
- package/dist/storage/sparql/FilterPushdownExtractor.js.map +1 -0
- package/dist/storage/sparql/OptimizedQuadstoreEngine.d.ts +65 -0
- package/dist/storage/sparql/OptimizedQuadstoreEngine.js +327 -0
- package/dist/storage/sparql/OptimizedQuadstoreEngine.js.map +1 -0
- package/dist/storage/sparql/OptimizedQuadstoreSource.d.ts +46 -0
- package/dist/storage/sparql/OptimizedQuadstoreSource.js +118 -0
- package/dist/storage/sparql/OptimizedQuadstoreSource.js.map +1 -0
- package/dist/storage/sparql/PatternBuilder.d.ts +41 -0
- package/dist/storage/sparql/PatternBuilder.js +118 -0
- package/dist/storage/sparql/PatternBuilder.js.map +1 -0
- package/dist/storage/sparql/QueryOptimizer.d.ts +125 -0
- package/dist/storage/sparql/QueryOptimizer.js +363 -0
- package/dist/storage/sparql/QueryOptimizer.js.map +1 -0
- package/dist/storage/sparql/QuintEngine.d.ts +92 -0
- package/dist/storage/sparql/QuintEngine.js +150 -0
- package/dist/storage/sparql/QuintEngine.js.map +1 -0
- package/dist/storage/sparql/QuintQuerySource.d.ts +227 -0
- package/dist/storage/sparql/QuintQuerySource.js +918 -0
- package/dist/storage/sparql/QuintQuerySource.js.map +1 -0
- package/dist/storage/sparql/SimpleSparqlExecutor.d.ts +40 -0
- package/dist/storage/sparql/SimpleSparqlExecutor.js +131 -0
- package/dist/storage/sparql/SimpleSparqlExecutor.js.map +1 -0
- package/dist/storage/sparql/SubgraphQueryEngine.d.ts +74 -0
- package/dist/storage/sparql/SubgraphQueryEngine.js +248 -0
- package/dist/storage/sparql/SubgraphQueryEngine.js.map +1 -0
- package/dist/storage/sparql/SubgraphQueryEngine.jsonld +250 -0
- package/dist/storage/vector/PostgresVectorStore.d.ts +46 -0
- package/dist/storage/vector/PostgresVectorStore.js +291 -0
- package/dist/storage/vector/PostgresVectorStore.js.map +1 -0
- package/dist/storage/vector/PostgresVectorStore.jsonld +142 -0
- package/dist/storage/vector/SqliteVectorStore.d.ts +44 -0
- package/dist/storage/vector/SqliteVectorStore.js +282 -0
- package/dist/storage/vector/SqliteVectorStore.js.map +1 -0
- package/dist/storage/vector/SqliteVectorStore.jsonld +137 -0
- package/dist/storage/vector/VectorIndexingListener.d.ts +114 -0
- package/dist/storage/vector/VectorIndexingListener.js +351 -0
- package/dist/storage/vector/VectorIndexingListener.js.map +1 -0
- package/dist/storage/vector/VectorStore.d.ts +42 -0
- package/dist/storage/vector/VectorStore.js +50 -0
- package/dist/storage/vector/VectorStore.js.map +1 -0
- package/dist/storage/vector/VectorStore.jsonld +87 -0
- package/dist/storage/vector/VectorStoreInit.d.ts +28 -0
- package/dist/storage/vector/VectorStoreInit.js +104 -0
- package/dist/storage/vector/VectorStoreInit.js.map +1 -0
- package/dist/storage/vector/index.d.ts +5 -0
- package/dist/storage/vector/index.js +22 -0
- package/dist/storage/vector/index.js.map +1 -0
- package/dist/storage/vector/types.d.ts +39 -0
- package/dist/storage/vector/types.js +8 -0
- package/dist/storage/vector/types.js.map +1 -0
- package/dist/subdomain/SubdomainClient.d.ts +156 -0
- package/dist/subdomain/SubdomainClient.js +220 -0
- package/dist/subdomain/SubdomainClient.js.map +1 -0
- package/dist/subdomain/SubdomainService.d.ts +114 -0
- package/dist/subdomain/SubdomainService.js +212 -0
- package/dist/subdomain/SubdomainService.js.map +1 -0
- package/dist/subdomain/SubdomainService.jsonld +261 -0
- package/dist/subdomain/index.d.ts +2 -0
- package/dist/subdomain/index.js +9 -0
- package/dist/subdomain/index.js.map +1 -0
- package/dist/supervisor/Supervisor.d.ts +20 -0
- package/dist/supervisor/Supervisor.js +174 -0
- package/dist/supervisor/Supervisor.js.map +1 -0
- package/dist/supervisor/index.d.ts +2 -0
- package/dist/supervisor/index.js +6 -0
- package/dist/supervisor/index.js.map +1 -0
- package/dist/supervisor/types.d.ts +19 -0
- package/dist/supervisor/types.js +3 -0
- package/dist/supervisor/types.js.map +1 -0
- package/dist/task/DrizzleTaskQueue.d.ts +60 -0
- package/dist/task/DrizzleTaskQueue.js +171 -0
- package/dist/task/DrizzleTaskQueue.js.map +1 -0
- package/dist/task/TaskExecutor.d.ts +82 -0
- package/dist/task/TaskExecutor.js +198 -0
- package/dist/task/TaskExecutor.js.map +1 -0
- package/dist/task/index.d.ts +10 -0
- package/dist/task/index.js +20 -0
- package/dist/task/index.js.map +1 -0
- package/dist/task/schema.d.ts +53 -0
- package/dist/task/schema.js +71 -0
- package/dist/task/schema.js.map +1 -0
- package/dist/task/types.d.ts +186 -0
- package/dist/task/types.js +12 -0
- package/dist/task/types.js.map +1 -0
- package/dist/terminal/AclPermissionService.d.ts +28 -0
- package/dist/terminal/AclPermissionService.js +141 -0
- package/dist/terminal/AclPermissionService.js.map +1 -0
- package/dist/terminal/BubblewrapSandbox.d.ts +51 -0
- package/dist/terminal/BubblewrapSandbox.js +147 -0
- package/dist/terminal/BubblewrapSandbox.js.map +1 -0
- package/dist/terminal/TerminalSession.d.ts +33 -0
- package/dist/terminal/TerminalSession.js +164 -0
- package/dist/terminal/TerminalSession.js.map +1 -0
- package/dist/terminal/TerminalSessionManager.d.ts +69 -0
- package/dist/terminal/TerminalSessionManager.js +196 -0
- package/dist/terminal/TerminalSessionManager.js.map +1 -0
- package/dist/terminal/index.d.ts +5 -0
- package/dist/terminal/index.js +22 -0
- package/dist/terminal/index.js.map +1 -0
- package/dist/terminal/sandbox/BubblewrapSandbox.d.ts +8 -0
- package/dist/terminal/sandbox/BubblewrapSandbox.js +105 -0
- package/dist/terminal/sandbox/BubblewrapSandbox.js.map +1 -0
- package/dist/terminal/sandbox/MacOSSandbox.d.ts +19 -0
- package/dist/terminal/sandbox/MacOSSandbox.js +120 -0
- package/dist/terminal/sandbox/MacOSSandbox.js.map +1 -0
- package/dist/terminal/sandbox/index.d.ts +29 -0
- package/dist/terminal/sandbox/index.js +113 -0
- package/dist/terminal/sandbox/index.js.map +1 -0
- package/dist/terminal/sandbox/types.d.ts +38 -0
- package/dist/terminal/sandbox/types.js +3 -0
- package/dist/terminal/sandbox/types.js.map +1 -0
- package/dist/terminal/types.d.ts +80 -0
- package/dist/terminal/types.js +16 -0
- package/dist/terminal/types.js.map +1 -0
- package/dist/tunnel/CloudflareTunnelProvider.d.ts +120 -0
- package/dist/tunnel/CloudflareTunnelProvider.js +376 -0
- package/dist/tunnel/CloudflareTunnelProvider.js.map +1 -0
- package/dist/tunnel/CloudflareTunnelProvider.jsonld +204 -0
- package/dist/tunnel/LocalTunnelProvider.d.ts +85 -0
- package/dist/tunnel/LocalTunnelProvider.js +295 -0
- package/dist/tunnel/LocalTunnelProvider.js.map +1 -0
- package/dist/tunnel/LocalTunnelProvider.jsonld +142 -0
- package/dist/tunnel/SakuraFrpTunnelProvider.d.ts +59 -0
- package/dist/tunnel/SakuraFrpTunnelProvider.js +207 -0
- package/dist/tunnel/SakuraFrpTunnelProvider.js.map +1 -0
- package/dist/tunnel/TunnelProvider.d.ts +91 -0
- package/dist/tunnel/TunnelProvider.js +10 -0
- package/dist/tunnel/TunnelProvider.js.map +1 -0
- package/dist/tunnel/TunnelProvider.jsonld +144 -0
- package/dist/tunnel/index.d.ts +3 -0
- package/dist/tunnel/index.js +8 -0
- package/dist/tunnel/index.js.map +1 -0
- package/dist/util/LockContext.d.ts +3 -0
- package/dist/util/LockContext.js +6 -0
- package/dist/util/LockContext.js.map +1 -0
- package/dist/util/ResourceStoreFetch.d.ts +11 -0
- package/dist/util/ResourceStoreFetch.js +147 -0
- package/dist/util/ResourceStoreFetch.js.map +1 -0
- package/dist/util/database/DatabaseMaintenance.d.ts +23 -0
- package/dist/util/database/DatabaseMaintenance.js +82 -0
- package/dist/util/database/DatabaseMaintenance.js.map +1 -0
- package/dist/util/identifiers/ClusterIdentifierStrategy.d.ts +23 -0
- package/dist/util/identifiers/ClusterIdentifierStrategy.js +73 -0
- package/dist/util/identifiers/ClusterIdentifierStrategy.js.map +1 -0
- package/dist/util/identifiers/ClusterIdentifierStrategy.jsonld +90 -0
- package/dist/util/identifiers/MultiDomainIdentifierStrategy.d.ts +40 -0
- package/dist/util/identifiers/MultiDomainIdentifierStrategy.js +73 -0
- package/dist/util/identifiers/MultiDomainIdentifierStrategy.js.map +1 -0
- package/dist/util/identifiers/MultiDomainIdentifierStrategy.jsonld +90 -0
- package/dist/util/identifiers/PathBasedPodIdentifierStrategy.d.ts +78 -0
- package/dist/util/identifiers/PathBasedPodIdentifierStrategy.js +182 -0
- package/dist/util/identifiers/PathBasedPodIdentifierStrategy.js.map +1 -0
- package/dist/util/identifiers/PathBasedPodIdentifierStrategy.jsonld +88 -0
- package/dist/util/identifiers/SubdomainPodIdentifierStrategy.d.ts +68 -0
- package/dist/util/identifiers/SubdomainPodIdentifierStrategy.js +149 -0
- package/dist/util/identifiers/SubdomainPodIdentifierStrategy.js.map +1 -0
- package/dist/util/identifiers/SubdomainPodIdentifierStrategy.jsonld +84 -0
- package/dist/util/locking/DebugRedisLocker.d.ts +8 -0
- package/dist/util/locking/DebugRedisLocker.js +33 -0
- package/dist/util/locking/DebugRedisLocker.js.map +1 -0
- package/dist/util/logger.d.ts +13 -0
- package/dist/util/logger.js +36 -0
- package/dist/util/logger.js.map +1 -0
- package/dist/util/stream/BandwidthThrottleTransform.d.ts +8 -0
- package/dist/util/stream/BandwidthThrottleTransform.js +55 -0
- package/dist/util/stream/BandwidthThrottleTransform.js.map +1 -0
- package/dist/vocab/external.d.ts +216 -0
- package/dist/vocab/external.js +276 -0
- package/dist/vocab/external.js.map +1 -0
- package/dist/vocab/index.d.ts +26 -0
- package/dist/vocab/index.js +46 -0
- package/dist/vocab/index.js.map +1 -0
- package/dist/vocab/udfs.d.ts +184 -0
- package/dist/vocab/udfs.js +217 -0
- package/dist/vocab/udfs.js.map +1 -0
- package/dist/webrtc/WebRTCClient.d.ts +109 -0
- package/dist/webrtc/WebRTCClient.js +344 -0
- package/dist/webrtc/WebRTCClient.js.map +1 -0
- package/dist/webrtc/WebRTCPeerManager.d.ts +112 -0
- package/dist/webrtc/WebRTCPeerManager.js +289 -0
- package/dist/webrtc/WebRTCPeerManager.js.map +1 -0
- package/dist/webrtc/WeriftPeerConnectionFactory.d.ts +13 -0
- package/dist/webrtc/WeriftPeerConnectionFactory.js +255 -0
- package/dist/webrtc/WeriftPeerConnectionFactory.js.map +1 -0
- package/dist/webrtc/index.d.ts +13 -0
- package/dist/webrtc/index.js +30 -0
- package/dist/webrtc/index.js.map +1 -0
- package/dist/webrtc/types.d.ts +169 -0
- package/dist/webrtc/types.js +6 -0
- package/dist/webrtc/types.js.map +1 -0
- package/dist/xpod.single.cjs +826 -0
- package/dist/xpod.single.cjs.map +7 -0
- package/package.json +173 -0
- package/static/app/assets/index.css +1 -0
- package/static/app/assets/main.js +11 -0
- package/static/app/auth.html +21 -0
- package/static/app/index.html +14 -0
- package/static/app/vite.svg +1 -0
- package/static/dashboard/assets/dashboard-G96F8267.js +52 -0
- package/static/dashboard/assets/dashboard-PJyGDppf.css +1 -0
- package/static/dashboard/auth.html +21 -0
- package/static/dashboard/index.html +13 -0
- package/static/dashboard/vite.svg +1 -0
- package/static/landing/index.html +165 -0
- package/templates/identity/index.html.ejs +12 -0
- package/templates/identity/login.html.ejs +49 -0
- package/templates/identity/oidc/consent.html.ejs +103 -0
- package/templates/identity/password/forgot.html.ejs +49 -0
- package/templates/identity/password/login.html.ejs +58 -0
- package/templates/identity/password/register.html.ejs +65 -0
- package/templates/main.html.ejs +1 -0
|
@@ -0,0 +1,640 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SubgraphSparqlHttpHandler = void 0;
|
|
4
|
+
const node_stream_1 = require("node:stream");
|
|
5
|
+
const global_logger_factory_1 = require("global-logger-factory");
|
|
6
|
+
const promises_1 = require("node:stream/promises");
|
|
7
|
+
const community_server_1 = require("@solid/community-server");
|
|
8
|
+
const community_server_2 = require("@solid/community-server");
|
|
9
|
+
const policy_engine_1 = require("@solidlab/policy-engine");
|
|
10
|
+
const n3_1 = require("n3");
|
|
11
|
+
const sparqljs_1 = require("sparqljs");
|
|
12
|
+
const db_1 = require("../identity/drizzle/db");
|
|
13
|
+
const PodLookupRepository_1 = require("../identity/drizzle/PodLookupRepository");
|
|
14
|
+
const UsageRepository_1 = require("../storage/quota/UsageRepository");
|
|
15
|
+
const BandwidthThrottleTransform_1 = require("../util/stream/BandwidthThrottleTransform");
|
|
16
|
+
const ALLOWED_METHODS = ['GET', 'POST', 'OPTIONS'];
|
|
17
|
+
class SubgraphSparqlHttpHandler extends community_server_1.HttpHandler {
|
|
18
|
+
constructor(queryEngine, credentialsExtractor, permissionReader, authorizer, options = {}) {
|
|
19
|
+
super();
|
|
20
|
+
this.logger = (0, global_logger_factory_1.getLoggerFor)(this);
|
|
21
|
+
this.generator = new sparqljs_1.Generator();
|
|
22
|
+
this.engine = queryEngine;
|
|
23
|
+
this.credentialsExtractor = credentialsExtractor;
|
|
24
|
+
this.permissionReader = permissionReader;
|
|
25
|
+
this.authorizer = authorizer;
|
|
26
|
+
this.sidecarPath = options.sidecarPath ?? '/-/sparql';
|
|
27
|
+
this.defaultBandwidthLimit = this.normalizeLimit(options.defaultAccountBandwidthLimitBps);
|
|
28
|
+
// Identity DB is used for pod lookup (to resolve accountId/podId from URL)
|
|
29
|
+
if (options.identityDbUrl) {
|
|
30
|
+
const db = (0, db_1.getIdentityDatabase)(options.identityDbUrl);
|
|
31
|
+
this.podLookup = new PodLookupRepository_1.PodLookupRepository(db);
|
|
32
|
+
}
|
|
33
|
+
// Usage DB can be separate from identity DB (decoupled usage tracking)
|
|
34
|
+
// NOTE: UsageRepository only supports PostgreSQL. SQLite is skipped.
|
|
35
|
+
const usageDbUrl = options.usageDbUrl ?? options.identityDbUrl;
|
|
36
|
+
if (usageDbUrl && !this.isSqliteUrl(usageDbUrl)) {
|
|
37
|
+
const usageDb = (0, db_1.getIdentityDatabase)(usageDbUrl);
|
|
38
|
+
this.usageRepo = new UsageRepository_1.UsageRepository(usageDb);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
async canHandle({ request }) {
|
|
42
|
+
const path = this.parseUrl(request).pathname;
|
|
43
|
+
// Match /-/sparql pattern: /alice/-/sparql or /alice/photos/-/sparql
|
|
44
|
+
if (!path.includes(this.sidecarPath)) {
|
|
45
|
+
throw new community_server_2.NotImplementedHttpError('Request is not targeting a subgraph SPARQL endpoint.');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async handle({ request, response }) {
|
|
49
|
+
const method = (request.method ?? 'GET').toUpperCase();
|
|
50
|
+
if (method === 'OPTIONS') {
|
|
51
|
+
this.writeOptions(response);
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
if (!ALLOWED_METHODS.includes(method)) {
|
|
55
|
+
throw new community_server_2.MethodNotAllowedHttpError(ALLOWED_METHODS);
|
|
56
|
+
}
|
|
57
|
+
try {
|
|
58
|
+
const queryRequest = await this.extractQuery(request, method);
|
|
59
|
+
const context = await this.resolveUsageContext(queryRequest.basePath);
|
|
60
|
+
await this.recordBandwidth(context, queryRequest.ingressBytes, 0);
|
|
61
|
+
const parser = new sparqljs_1.Parser({ baseIRI: queryRequest.baseUrl });
|
|
62
|
+
const parsed = parser.parse(queryRequest.query);
|
|
63
|
+
if (parsed.type === 'update') {
|
|
64
|
+
await this.executeUpdate(queryRequest, parsed, request, response, context);
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
// WORKAROUND: Comunica crashes if ASK query has a LIMIT clause ("Expected bindings but got boolean").
|
|
68
|
+
// ASK results are boolean and cannot be sliced, so LIMIT is semantically redundant but syntactically valid.
|
|
69
|
+
// We strip it here to protect the engine.
|
|
70
|
+
// console.log('Parsed Query Type:', parsed.queryType, 'Limit:', (parsed as any).limit);
|
|
71
|
+
if (parsed.queryType === 'ASK' && parsed.limit !== undefined) {
|
|
72
|
+
this.logger.warn(`Stripping LIMIT from ASK query to prevent Comunica crash. Original limit: ${JSON.stringify(parsed.limit)}`);
|
|
73
|
+
delete parsed.limit;
|
|
74
|
+
queryRequest.query = this.generator.stringify(parsed);
|
|
75
|
+
this.logger.warn(`Sanitized Query: ${queryRequest.query}`);
|
|
76
|
+
}
|
|
77
|
+
const queryType = parsed.queryType ?? 'SELECT';
|
|
78
|
+
switch (queryType) {
|
|
79
|
+
case 'SELECT':
|
|
80
|
+
await this.executeSelect(request, queryRequest, response, context);
|
|
81
|
+
break;
|
|
82
|
+
case 'ASK':
|
|
83
|
+
await this.executeAsk(request, queryRequest, response, context);
|
|
84
|
+
break;
|
|
85
|
+
case 'CONSTRUCT':
|
|
86
|
+
case 'DESCRIBE':
|
|
87
|
+
await this.executeConstruct(request, queryRequest, response, context);
|
|
88
|
+
break;
|
|
89
|
+
default:
|
|
90
|
+
throw new community_server_2.BadRequestHttpError(`Unsupported SPARQL query type: ${queryType}`);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
// Handle HttpErrors with proper status codes
|
|
95
|
+
if (error instanceof community_server_2.HttpError) {
|
|
96
|
+
const errorName = error.name || error.constructor.name || 'HttpError';
|
|
97
|
+
const errorMessage = error.message || 'No message';
|
|
98
|
+
this.logger.error(`SPARQL sidecar error ${error.statusCode} (${this.getRequestId(request)}): ${errorName} - ${errorMessage}`);
|
|
99
|
+
this.sendErrorResponse(response, error.statusCode, errorMessage);
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
// Re-throw unknown errors for CSS error handling
|
|
103
|
+
this.logger.error(`SPARQL sidecar unexpected error (${this.getRequestId(request)}): ${error instanceof Error ? error.message : String(error)}`);
|
|
104
|
+
throw error;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
sendErrorResponse(response, statusCode, message) {
|
|
108
|
+
response.statusCode = statusCode;
|
|
109
|
+
response.setHeader('Content-Type', 'text/plain; charset=utf-8');
|
|
110
|
+
response.end(message);
|
|
111
|
+
}
|
|
112
|
+
async executeSelect(request, { query, basePath, baseUrl }, response, context) {
|
|
113
|
+
await this.authorizeFor(baseUrl, request, [policy_engine_1.PERMISSIONS.Read]);
|
|
114
|
+
let vars = [];
|
|
115
|
+
const results = [];
|
|
116
|
+
const seenVars = new Set();
|
|
117
|
+
try {
|
|
118
|
+
const bindingsStream = await this.engine.queryBindings(query, baseUrl);
|
|
119
|
+
const metadata = typeof bindingsStream.metadata === 'function' ? await bindingsStream.metadata() : undefined;
|
|
120
|
+
vars = metadata?.variables?.map((variable) => variable.value) ?? [];
|
|
121
|
+
for await (const binding of bindingsStream) {
|
|
122
|
+
const row = {};
|
|
123
|
+
for (const [variable, term] of binding) {
|
|
124
|
+
// variable is a Variable object; use .value to get the string name
|
|
125
|
+
const name = typeof variable === 'string' ? variable : variable.value;
|
|
126
|
+
row[name] = this.termToJson(term);
|
|
127
|
+
seenVars.add(name);
|
|
128
|
+
}
|
|
129
|
+
results.push(row);
|
|
130
|
+
}
|
|
131
|
+
// Fallback: if metadata didn't provide vars, extract from bindings
|
|
132
|
+
if (vars.length === 0 && seenVars.size > 0) {
|
|
133
|
+
vars = Array.from(seenVars);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
catch (error) {
|
|
137
|
+
// Comunica throws when projected variables are not assigned (i.e., no results)
|
|
138
|
+
// Return empty results instead of erroring
|
|
139
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
140
|
+
if (message.includes('are used in the projection result, but are not assigned')) {
|
|
141
|
+
this.logger.debug(`Query returned no results: ${message}`);
|
|
142
|
+
// Extract variable names from the error message or query
|
|
143
|
+
const varMatch = message.match(/Variables '([^']+)'/);
|
|
144
|
+
if (varMatch) {
|
|
145
|
+
vars = varMatch[1].split(',').map((v) => v.trim().replace(/^\?/, ''));
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
throw error;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
const payload = {
|
|
153
|
+
head: { vars },
|
|
154
|
+
results: { bindings: results },
|
|
155
|
+
};
|
|
156
|
+
await this.sendPayload(response, JSON.stringify(payload), 'application/sparql-results+json; charset=utf-8', context);
|
|
157
|
+
}
|
|
158
|
+
async executeAsk(request, { query, basePath, baseUrl }, response, context) {
|
|
159
|
+
await this.authorizeFor(baseUrl, request, [policy_engine_1.PERMISSIONS.Read]);
|
|
160
|
+
const result = await this.engine.queryBoolean(query, baseUrl);
|
|
161
|
+
const payload = {
|
|
162
|
+
head: {},
|
|
163
|
+
boolean: result,
|
|
164
|
+
};
|
|
165
|
+
await this.sendPayload(response, JSON.stringify(payload), 'application/sparql-results+json; charset=utf-8', context);
|
|
166
|
+
}
|
|
167
|
+
async executeConstruct(request, { query, basePath, baseUrl }, response, context) {
|
|
168
|
+
await this.authorizeFor(baseUrl, request, [policy_engine_1.PERMISSIONS.Read]);
|
|
169
|
+
const quadStream = await this.engine.queryQuads(query, baseUrl);
|
|
170
|
+
const writer = new n3_1.Writer({ format: 'N-Quads' });
|
|
171
|
+
for await (const quad of quadStream) {
|
|
172
|
+
writer.addQuad(quad);
|
|
173
|
+
}
|
|
174
|
+
const nquads = await new Promise((resolve, reject) => {
|
|
175
|
+
writer.end((error, result) => {
|
|
176
|
+
if (error) {
|
|
177
|
+
reject(error);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
resolve(result);
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
await this.sendPayload(response, nquads, 'application/n-quads; charset=utf-8', context);
|
|
185
|
+
}
|
|
186
|
+
async executeUpdate(queryRequest, parsed, request, response, context) {
|
|
187
|
+
if (queryRequest.method !== 'POST') {
|
|
188
|
+
throw new community_server_2.MethodNotAllowedHttpError(['POST']);
|
|
189
|
+
}
|
|
190
|
+
const { hasInsert, hasDelete } = this.inspectUpdateGraphs(parsed, queryRequest.baseUrl);
|
|
191
|
+
const modes = [];
|
|
192
|
+
if (hasInsert) {
|
|
193
|
+
modes.push(policy_engine_1.PERMISSIONS.Append);
|
|
194
|
+
}
|
|
195
|
+
if (hasDelete) {
|
|
196
|
+
modes.push(policy_engine_1.PERMISSIONS.Delete);
|
|
197
|
+
}
|
|
198
|
+
await this.authorizeFor(queryRequest.baseUrl, request, modes);
|
|
199
|
+
const rewritten = this.rewriteDefaultGraphUpdates(parsed, queryRequest.baseUrl);
|
|
200
|
+
this.logger.verbose(`[SubgraphSPARQL] Rewritten Query: ${rewritten}`);
|
|
201
|
+
await this.engine.queryVoid(rewritten, queryRequest.baseUrl);
|
|
202
|
+
await this.refreshUsage(queryRequest.baseUrl);
|
|
203
|
+
response.statusCode = 204;
|
|
204
|
+
response.setHeader('Cache-Control', 'no-store');
|
|
205
|
+
response.end();
|
|
206
|
+
}
|
|
207
|
+
async sendPayload(response, payload, contentType, context, statusCode = 200) {
|
|
208
|
+
const buffer = typeof payload === 'string' ? Buffer.from(payload, 'utf8') : payload;
|
|
209
|
+
const limit = context ? await this.resolveBandwidthLimit(context) : undefined;
|
|
210
|
+
return this.streamWithLimit(response, buffer, limit, statusCode, contentType);
|
|
211
|
+
}
|
|
212
|
+
async streamWithLimit(response, buffer, limit, statusCode = 200, contentType) {
|
|
213
|
+
if (contentType) {
|
|
214
|
+
response.setHeader('content-type', contentType);
|
|
215
|
+
}
|
|
216
|
+
response.statusCode = statusCode;
|
|
217
|
+
const normalized = this.normalizeLimit(limit);
|
|
218
|
+
let stream = node_stream_1.Readable.from([buffer]);
|
|
219
|
+
if (normalized) {
|
|
220
|
+
stream = stream.pipe((0, BandwidthThrottleTransform_1.createBandwidthThrottleTransform)({ bytesPerSecond: normalized }));
|
|
221
|
+
}
|
|
222
|
+
await (0, promises_1.pipeline)(stream, response);
|
|
223
|
+
}
|
|
224
|
+
async resolveUsageContext(basePath) {
|
|
225
|
+
// Try to look up pod from identity database first
|
|
226
|
+
if (this.podLookup) {
|
|
227
|
+
try {
|
|
228
|
+
const pod = await this.podLookup.findByResourceIdentifier(basePath);
|
|
229
|
+
if (pod) {
|
|
230
|
+
return {
|
|
231
|
+
accountId: pod.accountId,
|
|
232
|
+
podId: pod.podId,
|
|
233
|
+
};
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
catch (error) {
|
|
237
|
+
// Gracefully handle missing tables (e.g., dev mode without identity DB setup)
|
|
238
|
+
this.logger.debug(`Failed to lookup pod for usage context: ${error instanceof Error ? error.message : String(error)}`);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
// Fallback: infer pod from URL path (e.g., /alice/foo → podId=alice)
|
|
242
|
+
// This allows usage tracking without identity database
|
|
243
|
+
if (this.usageRepo) {
|
|
244
|
+
const podId = this.inferPodIdFromPath(basePath);
|
|
245
|
+
if (podId) {
|
|
246
|
+
return {
|
|
247
|
+
accountId: podId, // Use podId as accountId when identity DB not available
|
|
248
|
+
podId,
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
return undefined;
|
|
253
|
+
}
|
|
254
|
+
inferPodIdFromPath(basePath) {
|
|
255
|
+
// Extract first path segment as pod ID: /alice/foo/bar → alice
|
|
256
|
+
const match = basePath.match(/^\/([^/]+)\//);
|
|
257
|
+
if (match && match[1] && !match[1].startsWith('.')) {
|
|
258
|
+
return match[1];
|
|
259
|
+
}
|
|
260
|
+
return undefined;
|
|
261
|
+
}
|
|
262
|
+
async resolveBandwidthLimit(context) {
|
|
263
|
+
if (!this.usageRepo) {
|
|
264
|
+
return this.defaultBandwidthLimit;
|
|
265
|
+
}
|
|
266
|
+
const podRecord = await this.usageRepo.getPodUsage(context.podId);
|
|
267
|
+
if (podRecord && podRecord.bandwidthLimitBps !== undefined) {
|
|
268
|
+
return this.normalizeLimit(podRecord.bandwidthLimitBps);
|
|
269
|
+
}
|
|
270
|
+
const accountRecord = await this.usageRepo.getAccountUsage(context.accountId);
|
|
271
|
+
if (accountRecord && accountRecord.bandwidthLimitBps !== undefined) {
|
|
272
|
+
return this.normalizeLimit(accountRecord.bandwidthLimitBps);
|
|
273
|
+
}
|
|
274
|
+
return this.defaultBandwidthLimit;
|
|
275
|
+
}
|
|
276
|
+
async recordBandwidth(context, ingress, egress) {
|
|
277
|
+
if (!context || !this.usageRepo) {
|
|
278
|
+
return;
|
|
279
|
+
}
|
|
280
|
+
const normalizedIngress = this.normalizeBandwidthDelta(ingress);
|
|
281
|
+
const normalizedEgress = this.normalizeBandwidthDelta(egress);
|
|
282
|
+
if (normalizedIngress === 0 && normalizedEgress === 0) {
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
await this.usageRepo.incrementUsage(context.accountId, context.podId, 0, normalizedIngress, normalizedEgress);
|
|
286
|
+
}
|
|
287
|
+
normalizeLimit(limit) {
|
|
288
|
+
if (limit == null) {
|
|
289
|
+
return null;
|
|
290
|
+
}
|
|
291
|
+
const numeric = Number(limit);
|
|
292
|
+
if (!Number.isFinite(numeric) || numeric <= 0) {
|
|
293
|
+
return null;
|
|
294
|
+
}
|
|
295
|
+
return Math.max(0, Math.trunc(numeric));
|
|
296
|
+
}
|
|
297
|
+
normalizeBandwidthDelta(value) {
|
|
298
|
+
if (!Number.isFinite(value) || value <= 0) {
|
|
299
|
+
return 0;
|
|
300
|
+
}
|
|
301
|
+
return Math.trunc(value);
|
|
302
|
+
}
|
|
303
|
+
async authorizeFor(basePath, request, modes) {
|
|
304
|
+
if (modes.length === 0) {
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
const identifier = { path: basePath };
|
|
308
|
+
const requestedModes = new community_server_2.IdentifierSetMultiMap();
|
|
309
|
+
for (const mode of modes) {
|
|
310
|
+
requestedModes.add(identifier, mode);
|
|
311
|
+
}
|
|
312
|
+
const credentials = await this.credentialsExtractor.handleSafe(request);
|
|
313
|
+
const availablePermissions = await this.permissionReader.handleSafe({ credentials, requestedModes });
|
|
314
|
+
await this.authorizer.handleSafe({ credentials, requestedModes, availablePermissions });
|
|
315
|
+
}
|
|
316
|
+
inspectUpdateGraphs(update, basePath) {
|
|
317
|
+
let hasInsert = false;
|
|
318
|
+
let hasDelete = false;
|
|
319
|
+
for (const operation of update.updates ?? []) {
|
|
320
|
+
if (!this.isInsertDeleteOperation(operation)) {
|
|
321
|
+
throw new community_server_2.BadRequestHttpError('SPARQL update management operations are not supported.');
|
|
322
|
+
}
|
|
323
|
+
if (operation.updateType === 'insert' ||
|
|
324
|
+
(operation.updateType === 'insertdelete' && (operation.insert?.length ?? 0) > 0)) {
|
|
325
|
+
hasInsert = true;
|
|
326
|
+
}
|
|
327
|
+
if (operation.updateType === 'delete' || operation.updateType === 'deletewhere' ||
|
|
328
|
+
(operation.updateType === 'insertdelete' && (operation.delete?.length ?? 0) > 0)) {
|
|
329
|
+
hasDelete = true;
|
|
330
|
+
}
|
|
331
|
+
if (operation.graph) {
|
|
332
|
+
this.assertGraphInScope(operation.graph, basePath);
|
|
333
|
+
}
|
|
334
|
+
if (operation.updateType === 'insert' || operation.updateType === 'insertdelete') {
|
|
335
|
+
this.inspectQuads(operation.insert ?? [], basePath);
|
|
336
|
+
}
|
|
337
|
+
if (operation.updateType === 'delete' || operation.updateType === 'insertdelete' || operation.updateType === 'deletewhere') {
|
|
338
|
+
this.inspectQuads(operation.delete ?? [], basePath);
|
|
339
|
+
}
|
|
340
|
+
if (operation.updateType === 'insertdelete') {
|
|
341
|
+
this.inspectPatterns(operation.where ?? [], basePath);
|
|
342
|
+
if (operation.using) {
|
|
343
|
+
for (const iri of operation.using.default ?? []) {
|
|
344
|
+
this.assertGraphTermInScope(iri, basePath);
|
|
345
|
+
}
|
|
346
|
+
for (const iri of operation.using.named ?? []) {
|
|
347
|
+
this.assertGraphTermInScope(iri, basePath);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
return { hasInsert, hasDelete };
|
|
353
|
+
}
|
|
354
|
+
inspectQuads(quads, basePath) {
|
|
355
|
+
for (const quad of quads) {
|
|
356
|
+
if (quad.type === 'graph') {
|
|
357
|
+
this.assertGraphTermInScope(quad.name, basePath);
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
inspectPatterns(patterns, basePath) {
|
|
362
|
+
for (const pattern of patterns) {
|
|
363
|
+
if (pattern.type === 'graph') {
|
|
364
|
+
this.assertGraphTermInScope(pattern.name, basePath);
|
|
365
|
+
}
|
|
366
|
+
const nested = pattern.patterns;
|
|
367
|
+
if (Array.isArray(nested)) {
|
|
368
|
+
this.inspectPatterns(nested, basePath);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
assertGraphInScope(graph, basePath) {
|
|
373
|
+
if ('default' in graph && graph.default) {
|
|
374
|
+
return;
|
|
375
|
+
}
|
|
376
|
+
if ('name' in graph) {
|
|
377
|
+
const name = graph.name;
|
|
378
|
+
if (name) {
|
|
379
|
+
this.assertGraphTermInScope(name, basePath);
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
else if ('value' in graph) {
|
|
383
|
+
this.assertGraphTermInScope(graph, basePath);
|
|
384
|
+
}
|
|
385
|
+
}
|
|
386
|
+
assertGraphTermInScope(term, basePath) {
|
|
387
|
+
if (!term) {
|
|
388
|
+
return;
|
|
389
|
+
}
|
|
390
|
+
if (term.termType === 'Variable') {
|
|
391
|
+
throw new community_server_2.BadRequestHttpError('Graph IRIs must be explicit when using the /-/sparql update endpoint.');
|
|
392
|
+
}
|
|
393
|
+
if (term.termType === 'NamedNode') {
|
|
394
|
+
// Graph can be either basePath or prefix:basePath (e.g., meta:http://...)
|
|
395
|
+
// Extract the path part after optional prefix (anything before first colon that's not part of http:)
|
|
396
|
+
const graphValue = term.value;
|
|
397
|
+
let pathPart = graphValue;
|
|
398
|
+
// Check if it has a prefix like "meta:" or "acl:" (not "http:" or "https:")
|
|
399
|
+
const prefixMatch = graphValue.match(/^([a-z]+):(?!\/\/)/i);
|
|
400
|
+
if (prefixMatch) {
|
|
401
|
+
pathPart = graphValue.slice(prefixMatch[0].length);
|
|
402
|
+
}
|
|
403
|
+
if (!pathPart.startsWith(basePath)) {
|
|
404
|
+
throw new community_server_2.BadRequestHttpError(`Graph ${term.value} is outside of ${basePath}.`);
|
|
405
|
+
}
|
|
406
|
+
return;
|
|
407
|
+
}
|
|
408
|
+
if (term.default === true) {
|
|
409
|
+
return;
|
|
410
|
+
}
|
|
411
|
+
throw new community_server_2.BadRequestHttpError('Unsupported graph target in SPARQL update.');
|
|
412
|
+
}
|
|
413
|
+
/**
|
|
414
|
+
* Rewrites INSERT/DELETE/INSERT+DELETE that target the default graph (or BGP without GRAPH)
|
|
415
|
+
* so they write to the resource graph (graphIri).
|
|
416
|
+
*/
|
|
417
|
+
rewriteDefaultGraphUpdates(parsed, graphIri) {
|
|
418
|
+
const graphNode = n3_1.DataFactory.namedNode(graphIri);
|
|
419
|
+
const rewritePatterns = (patterns) => {
|
|
420
|
+
if (!patterns)
|
|
421
|
+
return patterns;
|
|
422
|
+
return patterns.map((pattern) => {
|
|
423
|
+
if (pattern.type === 'bgp') {
|
|
424
|
+
return { type: 'graph', name: graphNode, triples: pattern.triples };
|
|
425
|
+
}
|
|
426
|
+
if (pattern.type === 'graph' && pattern.name?.termType === 'DefaultGraph') {
|
|
427
|
+
return { ...pattern, name: graphNode };
|
|
428
|
+
}
|
|
429
|
+
return pattern;
|
|
430
|
+
});
|
|
431
|
+
};
|
|
432
|
+
parsed.updates = parsed.updates.map((op) => {
|
|
433
|
+
if (op.updateType === 'insert' || op.updateType === 'delete' || op.updateType === 'insertdelete') {
|
|
434
|
+
return {
|
|
435
|
+
...op,
|
|
436
|
+
insert: rewritePatterns(op.insert),
|
|
437
|
+
delete: rewritePatterns(op.delete),
|
|
438
|
+
};
|
|
439
|
+
}
|
|
440
|
+
return op;
|
|
441
|
+
});
|
|
442
|
+
return this.generator.stringify(parsed);
|
|
443
|
+
}
|
|
444
|
+
async refreshUsage(basePath) {
|
|
445
|
+
if (!this.usageRepo || !this.podLookup) {
|
|
446
|
+
return;
|
|
447
|
+
}
|
|
448
|
+
const pod = await this.podLookup.findByResourceIdentifier(basePath);
|
|
449
|
+
if (!pod) {
|
|
450
|
+
this.logger.warn(`Skipping quota update for ${basePath}: unable to resolve owning pod.`);
|
|
451
|
+
return;
|
|
452
|
+
}
|
|
453
|
+
const graphs = await this.engine.listGraphs(basePath);
|
|
454
|
+
let totalBytes = 0;
|
|
455
|
+
for (const graph of graphs) {
|
|
456
|
+
totalBytes += await this.computeGraphSize(graph, basePath);
|
|
457
|
+
}
|
|
458
|
+
await this.usageRepo.setPodStorage(pod.accountId, pod.podId, totalBytes);
|
|
459
|
+
}
|
|
460
|
+
async computeGraphSize(graph, basePath) {
|
|
461
|
+
const stream = await this.engine.constructGraph(graph, basePath);
|
|
462
|
+
let bytes = 0;
|
|
463
|
+
try {
|
|
464
|
+
for await (const quad of stream) {
|
|
465
|
+
bytes += SubgraphSparqlHttpHandler.measureQuad(quad);
|
|
466
|
+
}
|
|
467
|
+
}
|
|
468
|
+
finally {
|
|
469
|
+
const close = stream.close;
|
|
470
|
+
if (typeof close === 'function') {
|
|
471
|
+
close();
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
return bytes;
|
|
475
|
+
}
|
|
476
|
+
writeOptions(response) {
|
|
477
|
+
response.statusCode = 204;
|
|
478
|
+
response.setHeader('Allow', ALLOWED_METHODS.join(','));
|
|
479
|
+
response.end();
|
|
480
|
+
}
|
|
481
|
+
async extractQuery(request, method) {
|
|
482
|
+
const url = this.parseUrl(request);
|
|
483
|
+
const path = decodeURIComponent(url.pathname);
|
|
484
|
+
// Sidecar pattern: /alice/-/sparql → basePath = /alice/
|
|
485
|
+
// Or: /alice/photos/-/sparql → basePath = /alice/photos/
|
|
486
|
+
const sidecarIndex = path.indexOf(this.sidecarPath);
|
|
487
|
+
if (sidecarIndex === -1) {
|
|
488
|
+
throw new community_server_2.NotImplementedHttpError('Request is not targeting a subgraph SPARQL endpoint.');
|
|
489
|
+
}
|
|
490
|
+
let basePath = path.slice(0, sidecarIndex);
|
|
491
|
+
// If the base looks like a container (no file extension), normalize with trailing slash.
|
|
492
|
+
const hasExtension = /\.[^/]+$/.test(basePath);
|
|
493
|
+
if (!hasExtension && !basePath.endsWith('/')) {
|
|
494
|
+
basePath = `${basePath}/`;
|
|
495
|
+
}
|
|
496
|
+
let query = null;
|
|
497
|
+
let ingressBytes = 0;
|
|
498
|
+
if (method === 'GET') {
|
|
499
|
+
query = url.searchParams.get('query');
|
|
500
|
+
if (query) {
|
|
501
|
+
ingressBytes += Buffer.byteLength(query, 'utf8');
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
else {
|
|
505
|
+
const contentTypeHeader = request.headers['content-type'] ?? request.headers['Content-Type'];
|
|
506
|
+
const contentType = Array.isArray(contentTypeHeader) ? contentTypeHeader[0] : contentTypeHeader;
|
|
507
|
+
const normalized = contentType?.split(';')[0].trim().toLowerCase();
|
|
508
|
+
if (normalized === 'application/sparql-query' || normalized === 'application/sparql-update') {
|
|
509
|
+
const body = await this.readBody(request);
|
|
510
|
+
ingressBytes += Buffer.byteLength(body, 'utf8');
|
|
511
|
+
query = body.trim();
|
|
512
|
+
}
|
|
513
|
+
else if (normalized === 'application/x-www-form-urlencoded') {
|
|
514
|
+
const body = await this.readBody(request);
|
|
515
|
+
ingressBytes += Buffer.byteLength(body, 'utf8');
|
|
516
|
+
const params = new URLSearchParams(body);
|
|
517
|
+
query = params.get('query') ?? params.get('update');
|
|
518
|
+
}
|
|
519
|
+
else {
|
|
520
|
+
throw new community_server_2.UnsupportedMediaTypeHttpError('Supported content types are application/sparql-query, application/sparql-update, or application/x-www-form-urlencoded.');
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
if (!query || query.trim().length === 0) {
|
|
524
|
+
throw new community_server_2.BadRequestHttpError('A SPARQL query must be supplied through the "query" parameter or request body.');
|
|
525
|
+
}
|
|
526
|
+
const origin = `${url.protocol}//${url.host}`;
|
|
527
|
+
return {
|
|
528
|
+
basePath,
|
|
529
|
+
baseUrl: `${origin}${basePath}`,
|
|
530
|
+
query: query.trim(),
|
|
531
|
+
origin,
|
|
532
|
+
method,
|
|
533
|
+
ingressBytes,
|
|
534
|
+
};
|
|
535
|
+
}
|
|
536
|
+
parseUrl(request) {
|
|
537
|
+
const hostHeader = request.headers.host ?? request.headers.Host ?? 'localhost';
|
|
538
|
+
const protocolHeader = (request.headers['x-forwarded-proto'] ?? request.headers['X-Forwarded-Proto']);
|
|
539
|
+
const protocol = protocolHeader?.split(',')[0]?.trim() ?? 'http';
|
|
540
|
+
const requestUrl = request.url ?? '/';
|
|
541
|
+
return new URL(requestUrl, `${protocol}://${hostHeader}`);
|
|
542
|
+
}
|
|
543
|
+
async readBody(request) {
|
|
544
|
+
return await new Promise((resolve, reject) => {
|
|
545
|
+
let data = '';
|
|
546
|
+
request.setEncoding('utf8');
|
|
547
|
+
request.on('data', (chunk) => {
|
|
548
|
+
data += chunk;
|
|
549
|
+
});
|
|
550
|
+
request.on('end', () => resolve(data));
|
|
551
|
+
request.on('error', reject);
|
|
552
|
+
});
|
|
553
|
+
}
|
|
554
|
+
termToJson(term) {
|
|
555
|
+
switch (term.termType) {
|
|
556
|
+
case 'NamedNode':
|
|
557
|
+
return { type: 'uri', value: term.value };
|
|
558
|
+
case 'BlankNode':
|
|
559
|
+
return { type: 'bnode', value: term.value };
|
|
560
|
+
case 'Literal': {
|
|
561
|
+
const literal = term;
|
|
562
|
+
if (literal.language) {
|
|
563
|
+
return {
|
|
564
|
+
type: 'literal',
|
|
565
|
+
value: literal.value,
|
|
566
|
+
'xml:lang': literal.language,
|
|
567
|
+
};
|
|
568
|
+
}
|
|
569
|
+
const datatype = literal.datatype?.value;
|
|
570
|
+
if (datatype && datatype !== SubgraphSparqlHttpHandler.XSD_STRING) {
|
|
571
|
+
return {
|
|
572
|
+
type: 'literal',
|
|
573
|
+
value: literal.value,
|
|
574
|
+
datatype,
|
|
575
|
+
};
|
|
576
|
+
}
|
|
577
|
+
return { type: 'literal', value: literal.value };
|
|
578
|
+
}
|
|
579
|
+
default:
|
|
580
|
+
return { type: 'literal', value: term.value };
|
|
581
|
+
}
|
|
582
|
+
}
|
|
583
|
+
static measureQuad(quad) {
|
|
584
|
+
const subject = SubgraphSparqlHttpHandler.termToNQuads(quad.subject);
|
|
585
|
+
const predicate = SubgraphSparqlHttpHandler.termToNQuads(quad.predicate);
|
|
586
|
+
const object = SubgraphSparqlHttpHandler.termToNQuads(quad.object);
|
|
587
|
+
const graph = quad.graph.termType === 'DefaultGraph' ? '' : ` ${SubgraphSparqlHttpHandler.termToNQuads(quad.graph)}`;
|
|
588
|
+
const serialized = `${subject} ${predicate} ${object}${graph} .\n`;
|
|
589
|
+
return Buffer.byteLength(serialized, 'utf8');
|
|
590
|
+
}
|
|
591
|
+
static termToNQuads(term) {
|
|
592
|
+
switch (term.termType) {
|
|
593
|
+
case 'NamedNode':
|
|
594
|
+
return `<${term.value}>`;
|
|
595
|
+
case 'BlankNode':
|
|
596
|
+
return `_:${term.value}`;
|
|
597
|
+
case 'Literal':
|
|
598
|
+
return SubgraphSparqlHttpHandler.literalToNQuads(term);
|
|
599
|
+
case 'DefaultGraph':
|
|
600
|
+
return '';
|
|
601
|
+
default:
|
|
602
|
+
return `<${term.value}>`;
|
|
603
|
+
}
|
|
604
|
+
}
|
|
605
|
+
static literalToNQuads(literal) {
|
|
606
|
+
const escaped = SubgraphSparqlHttpHandler.escapeLiteral(literal.value);
|
|
607
|
+
if (literal.language) {
|
|
608
|
+
return `"${escaped}"@${literal.language}`;
|
|
609
|
+
}
|
|
610
|
+
const datatype = literal.datatype?.value;
|
|
611
|
+
if (datatype && datatype !== SubgraphSparqlHttpHandler.XSD_STRING) {
|
|
612
|
+
return `"${escaped}"^^<${datatype}>`;
|
|
613
|
+
}
|
|
614
|
+
return `"${escaped}"`;
|
|
615
|
+
}
|
|
616
|
+
static escapeLiteral(value) {
|
|
617
|
+
return value
|
|
618
|
+
.replace(/\\/g, '\\\\')
|
|
619
|
+
.replace(/"/g, '\\"')
|
|
620
|
+
.replace(/\n/g, '\\n')
|
|
621
|
+
.replace(/\r/g, '\\r')
|
|
622
|
+
.replace(/\t/g, '\\t')
|
|
623
|
+
.replace(/\f/g, '\\f')
|
|
624
|
+
.replace(/\b/g, '\\b');
|
|
625
|
+
}
|
|
626
|
+
isInsertDeleteOperation(operation) {
|
|
627
|
+
return typeof operation.updateType === 'string';
|
|
628
|
+
}
|
|
629
|
+
getRequestId(request) {
|
|
630
|
+
const header = (request.headers['x-request-id'] ?? request.headers['X-Request-Id']);
|
|
631
|
+
return header?.toString() ?? 'no-request-id';
|
|
632
|
+
}
|
|
633
|
+
isSqliteUrl(url) {
|
|
634
|
+
const lower = url.toLowerCase();
|
|
635
|
+
return lower.startsWith('sqlite:') || lower.endsWith('.sqlite') || lower.endsWith('.db');
|
|
636
|
+
}
|
|
637
|
+
}
|
|
638
|
+
exports.SubgraphSparqlHttpHandler = SubgraphSparqlHttpHandler;
|
|
639
|
+
SubgraphSparqlHttpHandler.XSD_STRING = 'http://www.w3.org/2001/XMLSchema#string';
|
|
640
|
+
//# sourceMappingURL=SubgraphSparqlHttpHandler.js.map
|