@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,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* AlgebraUtils - SPARQL algebra tree traversal utilities
|
|
4
|
+
*
|
|
5
|
+
* Provides helper functions for working with SPARQL algebra trees:
|
|
6
|
+
* - Variable extraction
|
|
7
|
+
* - Term extraction from expressions
|
|
8
|
+
* - Literal value extraction
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.extractVariable = extractVariable;
|
|
12
|
+
exports.extractStrVariable = extractStrVariable;
|
|
13
|
+
exports.extractLiteralValue = extractLiteralValue;
|
|
14
|
+
exports.extractLiteral = extractLiteral;
|
|
15
|
+
exports.extractTerm = extractTerm;
|
|
16
|
+
exports.extractVariables = extractVariables;
|
|
17
|
+
exports.isVariableInPattern = isVariableInPattern;
|
|
18
|
+
exports.getVariablePosition = getVariablePosition;
|
|
19
|
+
/**
|
|
20
|
+
* Extract variable name from an expression
|
|
21
|
+
* Returns the variable name (without ?) if it's a variable, null otherwise
|
|
22
|
+
*/
|
|
23
|
+
function extractVariable(expr) {
|
|
24
|
+
if (expr.expressionType === 'term' && expr.term.termType === 'Variable') {
|
|
25
|
+
return expr.term.value;
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Extract variable name from STR(?var) expression
|
|
31
|
+
* Handles both direct variable and STR() wrapped variable
|
|
32
|
+
*/
|
|
33
|
+
function extractStrVariable(expr) {
|
|
34
|
+
// Direct variable
|
|
35
|
+
const direct = extractVariable(expr);
|
|
36
|
+
if (direct)
|
|
37
|
+
return direct;
|
|
38
|
+
// STR(?var)
|
|
39
|
+
if (expr.expressionType === 'operator') {
|
|
40
|
+
const opExpr = expr;
|
|
41
|
+
if (opExpr.operator === 'str' && opExpr.args.length === 1) {
|
|
42
|
+
return extractVariable(opExpr.args[0]);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Extract literal value from an expression
|
|
49
|
+
* Returns the string value if it's a literal, null otherwise
|
|
50
|
+
*/
|
|
51
|
+
function extractLiteralValue(expr) {
|
|
52
|
+
if (expr.expressionType === 'term' && expr.term.termType === 'Literal') {
|
|
53
|
+
return expr.term.value;
|
|
54
|
+
}
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Extract literal with datatype from an expression
|
|
59
|
+
*/
|
|
60
|
+
function extractLiteral(expr) {
|
|
61
|
+
if (expr.expressionType === 'term' && expr.term.termType === 'Literal') {
|
|
62
|
+
const lit = expr.term;
|
|
63
|
+
return {
|
|
64
|
+
value: lit.value,
|
|
65
|
+
datatype: lit.datatype?.value
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Extract a term from an expression
|
|
72
|
+
*/
|
|
73
|
+
function extractTerm(expr) {
|
|
74
|
+
if (expr.expressionType === 'term') {
|
|
75
|
+
return expr.term;
|
|
76
|
+
}
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Extract all variables from a pattern
|
|
81
|
+
*/
|
|
82
|
+
function extractVariables(pattern) {
|
|
83
|
+
const vars = [];
|
|
84
|
+
const seen = new Set();
|
|
85
|
+
for (const pos of ['subject', 'predicate', 'object', 'graph']) {
|
|
86
|
+
const term = pattern[pos];
|
|
87
|
+
if (term && term.termType === 'Variable' && !seen.has(term.value)) {
|
|
88
|
+
seen.add(term.value);
|
|
89
|
+
vars.push(term);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return vars;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Check if a variable is used in a pattern position
|
|
96
|
+
*/
|
|
97
|
+
function isVariableInPattern(varName, pattern) {
|
|
98
|
+
for (const pos of ['subject', 'predicate', 'object', 'graph']) {
|
|
99
|
+
const term = pattern[pos];
|
|
100
|
+
if (term && term.termType === 'Variable' && term.value === varName) {
|
|
101
|
+
return true;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Get the position of a variable in a pattern
|
|
108
|
+
*/
|
|
109
|
+
function getVariablePosition(varName, pattern) {
|
|
110
|
+
for (const pos of ['subject', 'predicate', 'object', 'graph']) {
|
|
111
|
+
const term = pattern[pos];
|
|
112
|
+
if (term && term.termType === 'Variable' && term.value === varName) {
|
|
113
|
+
return pos;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=AlgebraUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AlgebraUtils.js","sourceRoot":"","sources":["../../../src/storage/sparql/AlgebraUtils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * AlgebraUtils - SPARQL algebra tree traversal utilities\n * \n * Provides helper functions for working with SPARQL algebra trees:\n * - Variable extraction\n * - Term extraction from expressions\n * - Literal value extraction\n */\n\nimport type { Term, Variable } from '@rdfjs/types';\nimport type { Algebra } from 'sparqlalgebrajs';\n\n/**\n * Extract variable name from an expression\n * Returns the variable name (without ?) if it's a variable, null otherwise\n */\nexport function extractVariable(expr: Algebra.Expression): string | null {\n if (expr.expressionType === 'term' && expr.term.termType === 'Variable') {\n return expr.term.value;\n }\n return null;\n}\n\n/**\n * Extract variable name from STR(?var) expression\n * Handles both direct variable and STR() wrapped variable\n */\nexport function extractStrVariable(expr: Algebra.Expression): string | null {\n // Direct variable\n const direct = extractVariable(expr);\n if (direct) return direct;\n \n // STR(?var)\n if (expr.expressionType === 'operator') {\n const opExpr = expr as Algebra.OperatorExpression;\n if (opExpr.operator === 'str' && opExpr.args.length === 1) {\n return extractVariable(opExpr.args[0]);\n }\n }\n return null;\n}\n\n/**\n * Extract literal value from an expression\n * Returns the string value if it's a literal, null otherwise\n */\nexport function extractLiteralValue(expr: Algebra.Expression): string | null {\n if (expr.expressionType === 'term' && expr.term.termType === 'Literal') {\n return expr.term.value;\n }\n return null;\n}\n\n/**\n * Extract literal with datatype from an expression\n */\nexport function extractLiteral(expr: Algebra.Expression): { value: string; datatype?: string } | null {\n if (expr.expressionType === 'term' && expr.term.termType === 'Literal') {\n const lit = expr.term as any;\n return {\n value: lit.value,\n datatype: lit.datatype?.value\n };\n }\n return null;\n}\n\n/**\n * Extract a term from an expression\n */\nexport function extractTerm(expr: Algebra.Expression): Term | null {\n if (expr.expressionType === 'term') {\n return expr.term;\n }\n return null;\n}\n\n/**\n * Extract all variables from a pattern\n */\nexport function extractVariables(pattern: Algebra.Pattern): Variable[] {\n const vars: Variable[] = [];\n const seen = new Set<string>();\n \n for (const pos of ['subject', 'predicate', 'object', 'graph'] as const) {\n const term = pattern[pos];\n if (term && term.termType === 'Variable' && !seen.has(term.value)) {\n seen.add(term.value);\n vars.push(term);\n }\n }\n \n return vars;\n}\n\n/**\n * Check if a variable is used in a pattern position\n */\nexport function isVariableInPattern(varName: string, pattern: Algebra.Pattern): boolean {\n for (const pos of ['subject', 'predicate', 'object', 'graph'] as const) {\n const term = pattern[pos];\n if (term && term.termType === 'Variable' && term.value === varName) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * Get the position of a variable in a pattern\n */\nexport function getVariablePosition(varName: string, pattern: Algebra.Pattern): 'subject' | 'predicate' | 'object' | 'graph' | null {\n for (const pos of ['subject', 'predicate', 'object', 'graph'] as const) {\n const term = pattern[pos];\n if (term && term.termType === 'Variable' && term.value === varName) {\n return pos;\n }\n }\n return null;\n}\n"]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ComunicaOptimizedEngine - 基于 Comunica 的优化查询引擎
|
|
3
|
+
*
|
|
4
|
+
* 通过自定义 Source 实现查询下推优化:
|
|
5
|
+
* 1. 在查询执行前分析 SPARQL,提取 LIMIT/ORDER BY 等优化参数
|
|
6
|
+
* 2. 将参数存储在 Engine 实例上
|
|
7
|
+
* 3. 自定义 Source 在 match() 时读取这些参数并传给 quadstore
|
|
8
|
+
*/
|
|
9
|
+
import type { Quad } from '@rdfjs/types';
|
|
10
|
+
import type { Bindings, ResultStream } from '@rdfjs/types';
|
|
11
|
+
import { Quadstore } from 'quadstore';
|
|
12
|
+
export interface ComunicaOptimizedEngineOptions {
|
|
13
|
+
debug?: boolean;
|
|
14
|
+
}
|
|
15
|
+
export interface QueryContext {
|
|
16
|
+
sources?: unknown[];
|
|
17
|
+
baseIRI?: string;
|
|
18
|
+
[key: string]: unknown;
|
|
19
|
+
}
|
|
20
|
+
export declare class ComunicaOptimizedEngine {
|
|
21
|
+
private readonly store;
|
|
22
|
+
private readonly source;
|
|
23
|
+
private readonly engine;
|
|
24
|
+
private readonly debug;
|
|
25
|
+
private currentOptimizeParams;
|
|
26
|
+
constructor(store: Quadstore, options?: ComunicaOptimizedEngineOptions);
|
|
27
|
+
/**
|
|
28
|
+
* 执行 SELECT 查询
|
|
29
|
+
*/
|
|
30
|
+
queryBindings(query: string, context?: QueryContext): Promise<ResultStream<Bindings>>;
|
|
31
|
+
/**
|
|
32
|
+
* 执行 ASK 查询
|
|
33
|
+
*/
|
|
34
|
+
queryBoolean(query: string, context?: QueryContext): Promise<boolean>;
|
|
35
|
+
/**
|
|
36
|
+
* 执行 CONSTRUCT/DESCRIBE 查询
|
|
37
|
+
*/
|
|
38
|
+
queryQuads(query: string, context?: QueryContext): Promise<ResultStream<Quad>>;
|
|
39
|
+
/**
|
|
40
|
+
* 执行 UPDATE 查询
|
|
41
|
+
*/
|
|
42
|
+
queryVoid(query: string, context?: QueryContext): Promise<void>;
|
|
43
|
+
/**
|
|
44
|
+
* 分析查询,提取优化参数
|
|
45
|
+
*/
|
|
46
|
+
private analyzeQuery;
|
|
47
|
+
/**
|
|
48
|
+
* 从 Algebra 提取优化参数
|
|
49
|
+
*
|
|
50
|
+
* 只提取可以安全下推的参数:
|
|
51
|
+
* - LIMIT(对于单 BGP 查询可以直接下推)
|
|
52
|
+
* - ORDER BY(简单变量排序)
|
|
53
|
+
*/
|
|
54
|
+
private extractOptimizeParams;
|
|
55
|
+
/**
|
|
56
|
+
* 将 SPARQL 变量名映射到 quadstore 的 TermName
|
|
57
|
+
*/
|
|
58
|
+
private variableToTermName;
|
|
59
|
+
}
|
|
@@ -0,0 +1,254 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ComunicaOptimizedEngine - 基于 Comunica 的优化查询引擎
|
|
4
|
+
*
|
|
5
|
+
* 通过自定义 Source 实现查询下推优化:
|
|
6
|
+
* 1. 在查询执行前分析 SPARQL,提取 LIMIT/ORDER BY 等优化参数
|
|
7
|
+
* 2. 将参数存储在 Engine 实例上
|
|
8
|
+
* 3. 自定义 Source 在 match() 时读取这些参数并传给 quadstore
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.ComunicaOptimizedEngine = void 0;
|
|
12
|
+
const query_sparql_rdfjs_1 = require("@comunica/query-sparql-rdfjs");
|
|
13
|
+
const sparqlalgebrajs_1 = require("sparqlalgebrajs");
|
|
14
|
+
const asynciterator_1 = require("asynciterator");
|
|
15
|
+
/**
|
|
16
|
+
* 自定义 RDF/JS Source,通过闭包访问优化参数
|
|
17
|
+
*/
|
|
18
|
+
class OptimizedSource {
|
|
19
|
+
constructor(store, getParams, debug) {
|
|
20
|
+
this.store = store;
|
|
21
|
+
this.getParams = getParams;
|
|
22
|
+
this.debug = debug;
|
|
23
|
+
}
|
|
24
|
+
match(subject, predicate, object, graph) {
|
|
25
|
+
// 构建 quadstore pattern
|
|
26
|
+
const pattern = {};
|
|
27
|
+
if (subject && subject.termType !== 'Variable') {
|
|
28
|
+
pattern.subject = subject;
|
|
29
|
+
}
|
|
30
|
+
if (predicate && predicate.termType !== 'Variable') {
|
|
31
|
+
pattern.predicate = predicate;
|
|
32
|
+
}
|
|
33
|
+
if (object && object.termType !== 'Variable') {
|
|
34
|
+
pattern.object = object;
|
|
35
|
+
}
|
|
36
|
+
if (graph && graph.termType !== 'Variable' && graph.termType !== 'DefaultGraph') {
|
|
37
|
+
pattern.graph = graph;
|
|
38
|
+
}
|
|
39
|
+
// 获取优化参数
|
|
40
|
+
const params = this.getParams();
|
|
41
|
+
const opts = {};
|
|
42
|
+
if (params) {
|
|
43
|
+
if (params.limit !== undefined) {
|
|
44
|
+
// 如果有 offset,需要多获取一些
|
|
45
|
+
opts.limit = params.limit + (params.offset ?? 0);
|
|
46
|
+
}
|
|
47
|
+
if (params.order !== undefined) {
|
|
48
|
+
opts.order = params.order;
|
|
49
|
+
}
|
|
50
|
+
if (params.reverse !== undefined) {
|
|
51
|
+
opts.reverse = params.reverse;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (this.debug) {
|
|
55
|
+
console.log(`[OptimizedSource] match() called`);
|
|
56
|
+
console.log(` pattern: ${JSON.stringify(pattern)}`);
|
|
57
|
+
console.log(` opts: ${JSON.stringify(opts)}`);
|
|
58
|
+
}
|
|
59
|
+
// 使用 wrap 函数将 Promise<Array> 转换为 AsyncIterator
|
|
60
|
+
// wrap 会正确处理空数组的情况
|
|
61
|
+
const promiseIterator = (0, asynciterator_1.wrap)(this.store.get(pattern, opts).then(result => result.items));
|
|
62
|
+
return promiseIterator;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
class ComunicaOptimizedEngine {
|
|
66
|
+
constructor(store, options) {
|
|
67
|
+
// 当前查询的优化参数(通过闭包共享给 Source)
|
|
68
|
+
this.currentOptimizeParams = null;
|
|
69
|
+
this.store = store;
|
|
70
|
+
this.debug = options?.debug ?? false;
|
|
71
|
+
// 创建 Source,通过闭包访问 currentOptimizeParams
|
|
72
|
+
this.source = new OptimizedSource(store, () => this.currentOptimizeParams, this.debug);
|
|
73
|
+
this.engine = new query_sparql_rdfjs_1.QueryEngine();
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* 执行 SELECT 查询
|
|
77
|
+
*/
|
|
78
|
+
async queryBindings(query, context) {
|
|
79
|
+
// 分析查询,设置优化参数
|
|
80
|
+
this.currentOptimizeParams = this.analyzeQuery(query);
|
|
81
|
+
if (this.debug && this.currentOptimizeParams) {
|
|
82
|
+
console.log(`[ComunicaOptimizedEngine] Optimization params:`, this.currentOptimizeParams);
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
return await this.engine.queryBindings(query, {
|
|
86
|
+
sources: [this.source],
|
|
87
|
+
...context,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
finally {
|
|
91
|
+
// 查询完成后清除参数
|
|
92
|
+
this.currentOptimizeParams = null;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* 执行 ASK 查询
|
|
97
|
+
*/
|
|
98
|
+
async queryBoolean(query, context) {
|
|
99
|
+
this.currentOptimizeParams = this.analyzeQuery(query);
|
|
100
|
+
// 对于 ASK,设置 limit=1 优化
|
|
101
|
+
if (!this.currentOptimizeParams) {
|
|
102
|
+
this.currentOptimizeParams = { limit: 1 };
|
|
103
|
+
}
|
|
104
|
+
else if (this.currentOptimizeParams.limit === undefined) {
|
|
105
|
+
this.currentOptimizeParams.limit = 1;
|
|
106
|
+
}
|
|
107
|
+
try {
|
|
108
|
+
return await this.engine.queryBoolean(query, {
|
|
109
|
+
sources: [this.source],
|
|
110
|
+
...context,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
finally {
|
|
114
|
+
this.currentOptimizeParams = null;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* 执行 CONSTRUCT/DESCRIBE 查询
|
|
119
|
+
*/
|
|
120
|
+
async queryQuads(query, context) {
|
|
121
|
+
this.currentOptimizeParams = this.analyzeQuery(query);
|
|
122
|
+
try {
|
|
123
|
+
return await this.engine.queryQuads(query, {
|
|
124
|
+
sources: [this.source],
|
|
125
|
+
...context,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
finally {
|
|
129
|
+
this.currentOptimizeParams = null;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* 执行 UPDATE 查询
|
|
134
|
+
*/
|
|
135
|
+
async queryVoid(query, context) {
|
|
136
|
+
// UPDATE 不需要优化
|
|
137
|
+
return this.engine.queryVoid(query, {
|
|
138
|
+
sources: [this.source],
|
|
139
|
+
...context,
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* 分析查询,提取优化参数
|
|
144
|
+
*/
|
|
145
|
+
analyzeQuery(query) {
|
|
146
|
+
try {
|
|
147
|
+
const algebra = (0, sparqlalgebrajs_1.translate)(query, { quads: true });
|
|
148
|
+
return this.extractOptimizeParams(algebra);
|
|
149
|
+
}
|
|
150
|
+
catch (error) {
|
|
151
|
+
if (this.debug) {
|
|
152
|
+
console.log(`[ComunicaOptimizedEngine] Failed to analyze query:`, error);
|
|
153
|
+
}
|
|
154
|
+
return null;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* 从 Algebra 提取优化参数
|
|
159
|
+
*
|
|
160
|
+
* 只提取可以安全下推的参数:
|
|
161
|
+
* - LIMIT(对于单 BGP 查询可以直接下推)
|
|
162
|
+
* - ORDER BY(简单变量排序)
|
|
163
|
+
*/
|
|
164
|
+
extractOptimizeParams(algebra) {
|
|
165
|
+
let limit;
|
|
166
|
+
let offset;
|
|
167
|
+
let order;
|
|
168
|
+
let reverse;
|
|
169
|
+
let currentOp = algebra;
|
|
170
|
+
let canPushLimit = true; // 是否可以下推 LIMIT
|
|
171
|
+
while (currentOp) {
|
|
172
|
+
switch (currentOp.type) {
|
|
173
|
+
case 'slice': {
|
|
174
|
+
const slice = currentOp;
|
|
175
|
+
if (slice.length !== undefined) {
|
|
176
|
+
limit = slice.length;
|
|
177
|
+
}
|
|
178
|
+
if (slice.start !== undefined) {
|
|
179
|
+
offset = slice.start;
|
|
180
|
+
}
|
|
181
|
+
currentOp = slice.input;
|
|
182
|
+
break;
|
|
183
|
+
}
|
|
184
|
+
case 'orderby': {
|
|
185
|
+
const orderBy = currentOp;
|
|
186
|
+
if (orderBy.expressions.length === 1) {
|
|
187
|
+
const expr = orderBy.expressions[0];
|
|
188
|
+
if (expr.expression.expressionType === 'term' &&
|
|
189
|
+
expr.expression.term.termType === 'Variable') {
|
|
190
|
+
const varName = expr.expression.term.value;
|
|
191
|
+
const termName = this.variableToTermName(varName);
|
|
192
|
+
if (termName) {
|
|
193
|
+
order = [termName];
|
|
194
|
+
reverse = !expr.ascending;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
currentOp = orderBy.input;
|
|
199
|
+
break;
|
|
200
|
+
}
|
|
201
|
+
case 'project':
|
|
202
|
+
case 'distinct':
|
|
203
|
+
case 'reduced': {
|
|
204
|
+
currentOp = currentOp.input;
|
|
205
|
+
break;
|
|
206
|
+
}
|
|
207
|
+
case 'bgp': {
|
|
208
|
+
const bgp = currentOp;
|
|
209
|
+
if (bgp.patterns.length === 1) {
|
|
210
|
+
// 单个 triple pattern,可以完全下推
|
|
211
|
+
return { limit, offset, order, reverse };
|
|
212
|
+
}
|
|
213
|
+
// 多个 patterns 需要 JOIN,只能下推到每个 pattern
|
|
214
|
+
// 但 LIMIT 不能直接下推(会影响 JOIN 结果)
|
|
215
|
+
canPushLimit = false;
|
|
216
|
+
return canPushLimit ? { limit, offset, order, reverse } : null;
|
|
217
|
+
}
|
|
218
|
+
case 'join':
|
|
219
|
+
case 'leftjoin':
|
|
220
|
+
case 'union':
|
|
221
|
+
case 'minus':
|
|
222
|
+
// 复杂操作,不能直接下推 LIMIT
|
|
223
|
+
canPushLimit = false;
|
|
224
|
+
return null;
|
|
225
|
+
case 'filter':
|
|
226
|
+
case 'extend':
|
|
227
|
+
case 'group':
|
|
228
|
+
// 这些操作不支持优化
|
|
229
|
+
return null;
|
|
230
|
+
default:
|
|
231
|
+
return null;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
return null;
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* 将 SPARQL 变量名映射到 quadstore 的 TermName
|
|
238
|
+
*/
|
|
239
|
+
variableToTermName(varName) {
|
|
240
|
+
const mapping = {
|
|
241
|
+
's': 'subject',
|
|
242
|
+
'subject': 'subject',
|
|
243
|
+
'p': 'predicate',
|
|
244
|
+
'predicate': 'predicate',
|
|
245
|
+
'o': 'object',
|
|
246
|
+
'object': 'object',
|
|
247
|
+
'g': 'graph',
|
|
248
|
+
'graph': 'graph',
|
|
249
|
+
};
|
|
250
|
+
return mapping[varName.toLowerCase()] ?? null;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
exports.ComunicaOptimizedEngine = ComunicaOptimizedEngine;
|
|
254
|
+
//# sourceMappingURL=ComunicaOptimizedEngine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ComunicaOptimizedEngine.js","sourceRoot":"","sources":["../../../src/storage/sparql/ComunicaOptimizedEngine.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ComunicaOptimizedEngine - 基于 Comunica 的优化查询引擎\n * \n * 通过自定义 Source 实现查询下推优化:\n * 1. 在查询执行前分析 SPARQL,提取 LIMIT/ORDER BY 等优化参数\n * 2. 将参数存储在 Engine 实例上\n * 3. 自定义 Source 在 match() 时读取这些参数并传给 quadstore\n */\n\nimport type { Quad, Term } from '@rdfjs/types';\nimport type { Bindings, ResultStream } from '@rdfjs/types';\nimport type * as RDF from '@rdfjs/types';\nimport { QueryEngine } from '@comunica/query-sparql-rdfjs';\nimport { Quadstore, type TermName, type GetOpts, type Pattern } from 'quadstore';\nimport { translate, type Algebra } from 'sparqlalgebrajs';\nimport { wrap, AsyncIterator } from 'asynciterator';\n\nexport interface ComunicaOptimizedEngineOptions {\n debug?: boolean;\n}\n\nexport interface QueryContext {\n sources?: unknown[];\n baseIRI?: string;\n [key: string]: unknown;\n}\n\ninterface OptimizeParams {\n limit?: number;\n offset?: number;\n order?: TermName[];\n reverse?: boolean;\n}\n\n/**\n * 自定义 RDF/JS Source,通过闭包访问优化参数\n */\nclass OptimizedSource implements RDF.Source {\n constructor(\n private readonly store: Quadstore,\n private readonly getParams: () => OptimizeParams | null,\n private readonly debug: boolean\n ) {}\n\n match(\n subject?: Term | null,\n predicate?: Term | null,\n object?: Term | null,\n graph?: Term | null\n ): RDF.Stream {\n // 构建 quadstore pattern\n const pattern: Pattern = {};\n if (subject && subject.termType !== 'Variable') {\n pattern.subject = subject as any;\n }\n if (predicate && predicate.termType !== 'Variable') {\n pattern.predicate = predicate as any;\n }\n if (object && object.termType !== 'Variable') {\n pattern.object = object as any;\n }\n if (graph && graph.termType !== 'Variable' && graph.termType !== 'DefaultGraph') {\n pattern.graph = graph as any;\n }\n\n // 获取优化参数\n const params = this.getParams();\n const opts: GetOpts = {};\n \n if (params) {\n if (params.limit !== undefined) {\n // 如果有 offset,需要多获取一些\n opts.limit = params.limit + (params.offset ?? 0);\n }\n if (params.order !== undefined) {\n opts.order = params.order;\n }\n if (params.reverse !== undefined) {\n opts.reverse = params.reverse;\n }\n }\n\n if (this.debug) {\n console.log(`[OptimizedSource] match() called`);\n console.log(` pattern: ${JSON.stringify(pattern)}`);\n console.log(` opts: ${JSON.stringify(opts)}`);\n }\n\n // 使用 wrap 函数将 Promise<Array> 转换为 AsyncIterator\n // wrap 会正确处理空数组的情况\n const promiseIterator = wrap(\n this.store.get(pattern, opts).then(result => result.items)\n );\n\n return promiseIterator as any;\n }\n}\n\nexport class ComunicaOptimizedEngine {\n private readonly store: Quadstore;\n private readonly source: OptimizedSource;\n private readonly engine: QueryEngine;\n private readonly debug: boolean;\n \n // 当前查询的优化参数(通过闭包共享给 Source)\n private currentOptimizeParams: OptimizeParams | null = null;\n\n constructor(store: Quadstore, options?: ComunicaOptimizedEngineOptions) {\n this.store = store;\n this.debug = options?.debug ?? false;\n \n // 创建 Source,通过闭包访问 currentOptimizeParams\n this.source = new OptimizedSource(\n store,\n () => this.currentOptimizeParams,\n this.debug\n );\n \n this.engine = new QueryEngine();\n }\n\n /**\n * 执行 SELECT 查询\n */\n async queryBindings(query: string, context?: QueryContext): Promise<ResultStream<Bindings>> {\n // 分析查询,设置优化参数\n this.currentOptimizeParams = this.analyzeQuery(query);\n \n if (this.debug && this.currentOptimizeParams) {\n console.log(`[ComunicaOptimizedEngine] Optimization params:`, this.currentOptimizeParams);\n }\n\n try {\n return await this.engine.queryBindings(query, {\n sources: [this.source],\n ...context,\n } as any);\n } finally {\n // 查询完成后清除参数\n this.currentOptimizeParams = null;\n }\n }\n\n /**\n * 执行 ASK 查询\n */\n async queryBoolean(query: string, context?: QueryContext): Promise<boolean> {\n this.currentOptimizeParams = this.analyzeQuery(query);\n // 对于 ASK,设置 limit=1 优化\n if (!this.currentOptimizeParams) {\n this.currentOptimizeParams = { limit: 1 };\n } else if (this.currentOptimizeParams.limit === undefined) {\n this.currentOptimizeParams.limit = 1;\n }\n \n try {\n return await this.engine.queryBoolean(query, {\n sources: [this.source],\n ...context,\n } as any);\n } finally {\n this.currentOptimizeParams = null;\n }\n }\n\n /**\n * 执行 CONSTRUCT/DESCRIBE 查询\n */\n async queryQuads(query: string, context?: QueryContext): Promise<ResultStream<Quad>> {\n this.currentOptimizeParams = this.analyzeQuery(query);\n \n try {\n return await this.engine.queryQuads(query, {\n sources: [this.source],\n ...context,\n } as any);\n } finally {\n this.currentOptimizeParams = null;\n }\n }\n\n /**\n * 执行 UPDATE 查询\n */\n async queryVoid(query: string, context?: QueryContext): Promise<void> {\n // UPDATE 不需要优化\n return this.engine.queryVoid(query, {\n sources: [this.source],\n ...context,\n } as any);\n }\n\n /**\n * 分析查询,提取优化参数\n */\n private analyzeQuery(query: string): OptimizeParams | null {\n try {\n const algebra = translate(query, { quads: true });\n return this.extractOptimizeParams(algebra);\n } catch (error) {\n if (this.debug) {\n console.log(`[ComunicaOptimizedEngine] Failed to analyze query:`, error);\n }\n return null;\n }\n }\n\n /**\n * 从 Algebra 提取优化参数\n * \n * 只提取可以安全下推的参数:\n * - LIMIT(对于单 BGP 查询可以直接下推)\n * - ORDER BY(简单变量排序)\n */\n private extractOptimizeParams(algebra: Algebra.Operation): OptimizeParams | null {\n let limit: number | undefined;\n let offset: number | undefined;\n let order: TermName[] | undefined;\n let reverse: boolean | undefined;\n let currentOp = algebra;\n let canPushLimit = true; // 是否可以下推 LIMIT\n\n while (currentOp) {\n switch (currentOp.type) {\n case 'slice': {\n const slice = currentOp as Algebra.Slice;\n if (slice.length !== undefined) {\n limit = slice.length;\n }\n if (slice.start !== undefined) {\n offset = slice.start;\n }\n currentOp = slice.input;\n break;\n }\n \n case 'orderby': {\n const orderBy = currentOp as Algebra.OrderBy;\n if (orderBy.expressions.length === 1) {\n const expr = orderBy.expressions[0];\n if (expr.expression.expressionType === 'term' && \n expr.expression.term.termType === 'Variable') {\n const varName = expr.expression.term.value;\n const termName = this.variableToTermName(varName);\n if (termName) {\n order = [termName];\n reverse = !expr.ascending;\n }\n }\n }\n currentOp = orderBy.input;\n break;\n }\n\n case 'project':\n case 'distinct':\n case 'reduced': {\n currentOp = (currentOp as any).input;\n break;\n }\n\n case 'bgp': {\n const bgp = currentOp as Algebra.Bgp;\n if (bgp.patterns.length === 1) {\n // 单个 triple pattern,可以完全下推\n return { limit, offset, order, reverse };\n }\n // 多个 patterns 需要 JOIN,只能下推到每个 pattern\n // 但 LIMIT 不能直接下推(会影响 JOIN 结果)\n canPushLimit = false;\n return canPushLimit ? { limit, offset, order, reverse } : null;\n }\n\n case 'join':\n case 'leftjoin':\n case 'union':\n case 'minus':\n // 复杂操作,不能直接下推 LIMIT\n canPushLimit = false;\n return null;\n\n case 'filter':\n case 'extend':\n case 'group':\n // 这些操作不支持优化\n return null;\n\n default:\n return null;\n }\n }\n\n return null;\n }\n\n /**\n * 将 SPARQL 变量名映射到 quadstore 的 TermName\n */\n private variableToTermName(varName: string): TermName | null {\n const mapping: Record<string, TermName> = {\n 's': 'subject',\n 'subject': 'subject',\n 'p': 'predicate',\n 'predicate': 'predicate',\n 'o': 'object',\n 'object': 'object',\n 'g': 'graph',\n 'graph': 'graph',\n };\n return mapping[varName.toLowerCase()] ?? null;\n }\n}\n"]}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ComunicaQuintEngine - Comunica SPARQL engine backed by QuintStore
|
|
3
|
+
*
|
|
4
|
+
* Features:
|
|
5
|
+
* 1. Query pushdown optimization (LIMIT/ORDER BY)
|
|
6
|
+
* 2. FILTER pushdown via IQuerySource interface
|
|
7
|
+
* 3. External filters for security boundaries (ACL)
|
|
8
|
+
* 4. OPTIONAL optimization via QueryOptimizer
|
|
9
|
+
*
|
|
10
|
+
* Architecture:
|
|
11
|
+
* - Uses QuintQuerySource (IQuerySource) for proper FILTER pushdown
|
|
12
|
+
* - Uses QueryOptimizer for OPTIONAL and Compound Query optimization
|
|
13
|
+
* - Comunica pushes FILTER operations down to sources that declare support
|
|
14
|
+
* - QuintQuerySource extracts filters from algebra and applies them to QuintStore
|
|
15
|
+
*/
|
|
16
|
+
import type { Quad, Bindings, ResultStream } from '@rdfjs/types';
|
|
17
|
+
import { type Algebra } from 'sparqlalgebrajs';
|
|
18
|
+
import type { QuintStore, TermOperators } from '../quint/types';
|
|
19
|
+
export interface ComunicaQuintEngineOptions {
|
|
20
|
+
debug?: boolean;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Security/ACL filters passed from upstream
|
|
24
|
+
* These are applied unconditionally to restrict query scope
|
|
25
|
+
*/
|
|
26
|
+
export interface SecurityFilters {
|
|
27
|
+
subject?: TermOperators;
|
|
28
|
+
predicate?: TermOperators;
|
|
29
|
+
object?: TermOperators;
|
|
30
|
+
graph?: TermOperators;
|
|
31
|
+
}
|
|
32
|
+
export interface QueryContext {
|
|
33
|
+
sources?: unknown[];
|
|
34
|
+
baseIRI?: string;
|
|
35
|
+
/** Security filters for access control */
|
|
36
|
+
filters?: SecurityFilters;
|
|
37
|
+
[key: string]: unknown;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Query analysis result (stateless)
|
|
41
|
+
*/
|
|
42
|
+
export interface QueryAnalysis {
|
|
43
|
+
hasFilter: boolean;
|
|
44
|
+
filterTypes: string[];
|
|
45
|
+
pushdownable: string[];
|
|
46
|
+
nonPushdownable: string[];
|
|
47
|
+
estimatedPushdownRate: number;
|
|
48
|
+
}
|
|
49
|
+
export declare class ComunicaQuintEngine {
|
|
50
|
+
private readonly store;
|
|
51
|
+
private readonly rdfStore;
|
|
52
|
+
private readonly querySource;
|
|
53
|
+
private readonly queryOptimizer;
|
|
54
|
+
private readonly simpleExecutor;
|
|
55
|
+
private readonly engine;
|
|
56
|
+
private readonly debug;
|
|
57
|
+
private bindingsFactory;
|
|
58
|
+
private currentOptimizeParams;
|
|
59
|
+
private currentSecurityFilters;
|
|
60
|
+
private currentFilterExpressions;
|
|
61
|
+
constructor(store: QuintStore, options?: ComunicaQuintEngineOptions);
|
|
62
|
+
/**
|
|
63
|
+
* Analyze a query's pushdown potential (stateless)
|
|
64
|
+
* Returns analysis of what can/cannot be pushed down without executing the query
|
|
65
|
+
*/
|
|
66
|
+
analyzeQuery(query: string): QueryAnalysis;
|
|
67
|
+
/**
|
|
68
|
+
* Analyze algebra tree for pushdown potential
|
|
69
|
+
*/
|
|
70
|
+
private analyzeAlgebra;
|
|
71
|
+
/**
|
|
72
|
+
* Walk algebra tree and collect filter info
|
|
73
|
+
*/
|
|
74
|
+
private walkAlgebra;
|
|
75
|
+
/**
|
|
76
|
+
* Analyze a filter expression
|
|
77
|
+
*/
|
|
78
|
+
private analyzeExpression;
|
|
79
|
+
/**
|
|
80
|
+
* Execute SELECT query
|
|
81
|
+
* Uses IQuerySource for proper FILTER pushdown
|
|
82
|
+
*
|
|
83
|
+
* OPTIONAL 优化:
|
|
84
|
+
* 如果查询包含多个 OPTIONAL 且只是获取属性(不参与过滤),
|
|
85
|
+
* 则先执行核心条件获取 subjects,再批量获取属性
|
|
86
|
+
*/
|
|
87
|
+
queryBindings(query: string, context?: QueryContext): Promise<ResultStream<Bindings>>;
|
|
88
|
+
/**
|
|
89
|
+
* 执行核心查询(不含 OPTIONAL)
|
|
90
|
+
*/
|
|
91
|
+
private executeCoreQuery;
|
|
92
|
+
/**
|
|
93
|
+
* Extract FILTER expressions from query and store them for later pushdown
|
|
94
|
+
* Maps variable names to their filter expressions
|
|
95
|
+
*/
|
|
96
|
+
private extractAndStoreFilters;
|
|
97
|
+
/**
|
|
98
|
+
* Recursively collect FILTER expressions and their variable bindings
|
|
99
|
+
*/
|
|
100
|
+
private collectFilterExpressions;
|
|
101
|
+
/**
|
|
102
|
+
* Get variable names from an expression
|
|
103
|
+
*/
|
|
104
|
+
private getExpressionVariables;
|
|
105
|
+
/**
|
|
106
|
+
* Get the current filter expression for a variable (used by QuintQuerySource)
|
|
107
|
+
*/
|
|
108
|
+
getFilterExpressionForVariable(varName: string): Algebra.Expression | undefined;
|
|
109
|
+
/**
|
|
110
|
+
* Execute ASK query
|
|
111
|
+
*/
|
|
112
|
+
queryBoolean(query: string, context?: QueryContext): Promise<boolean>;
|
|
113
|
+
/**
|
|
114
|
+
* Execute CONSTRUCT/DESCRIBE query
|
|
115
|
+
*/
|
|
116
|
+
queryQuads(query: string, context?: QueryContext): Promise<ResultStream<Quad>>;
|
|
117
|
+
/**
|
|
118
|
+
* Execute UPDATE query (INSERT/DELETE)
|
|
119
|
+
* Uses RDF.Store interface since UPDATE doesn't need FILTER pushdown
|
|
120
|
+
*/
|
|
121
|
+
queryVoid(query: string, context?: QueryContext): Promise<void>;
|
|
122
|
+
/**
|
|
123
|
+
* Extract optimization params from SPARQL query
|
|
124
|
+
*/
|
|
125
|
+
private extractOptimizeParams;
|
|
126
|
+
/**
|
|
127
|
+
* Extract optimization params from SPARQL algebra
|
|
128
|
+
*/
|
|
129
|
+
private extractOptimizeParamsFromAlgebra;
|
|
130
|
+
/**
|
|
131
|
+
* Map SPARQL variable name to TermName
|
|
132
|
+
*/
|
|
133
|
+
private variableToTermName;
|
|
134
|
+
}
|