@lssm/lib.contracts 0.0.0-canary-20251217052941 → 0.0.0-canary-20251217060433
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/dist/app-config/app-config.feature.d.ts +11 -0
- package/dist/app-config/branding.d.ts +55 -0
- package/dist/app-config/contracts.d.ts +244 -0
- package/dist/app-config/docs/app-config.docblock.d.ts +6 -0
- package/dist/app-config/events.d.ts +122 -0
- package/dist/app-config/index.d.ts +9 -0
- package/dist/app-config/lifecycle-contracts.d.ts +382 -0
- package/dist/app-config/lifecycle.d.ts +27 -0
- package/dist/app-config/runtime.d.ts +114 -0
- package/dist/app-config/spec.d.ts +175 -0
- package/dist/app-config/validation.d.ts +47 -0
- package/dist/capabilities/docs/capabilities.docblock.d.ts +6 -0
- package/dist/capabilities/openbanking.d.ts +9 -0
- package/dist/capabilities.d.ts +48 -0
- package/dist/client/index.d.ts +6 -0
- package/dist/client/react/drivers/rn-reusables.d.ts +22 -0
- package/dist/client/react/drivers/shadcn.d.ts +12 -0
- package/dist/client/react/feature-render.d.ts +19 -0
- package/dist/client/react/form-render.d.ts +91 -0
- package/dist/client/react/index.d.ts +5 -0
- package/dist/contract-registry/index.d.ts +3 -0
- package/dist/contract-registry/schemas.d.ts +124 -0
- package/dist/contract-registry/types.d.ts +46 -0
- package/dist/contracts-adapter-hydration.d.ts +15 -0
- package/dist/contracts-adapter-input.d.ts +10 -0
- package/dist/data-views/docs/data-views.docblock.d.ts +6 -0
- package/dist/data-views/query-generator.d.ts +39 -0
- package/dist/data-views/runtime.d.ts +26 -0
- package/dist/data-views.d.ts +131 -0
- package/dist/docs/PUBLISHING.docblock.d.ts +6 -0
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.d.ts +6 -0
- package/dist/docs/index.d.ts +6 -0
- package/dist/docs/meta.docs.d.ts +6 -0
- package/dist/docs/presentations.d.ts +33 -0
- package/dist/docs/registry.d.ts +24 -0
- package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.d.ts +6 -0
- package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.d.ts +6 -0
- package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.d.ts +6 -0
- package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.d.ts +6 -0
- package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.d.ts +6 -0
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/README.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/create-subscription.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/migrations.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/openapi-export.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/overlays.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/tests.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/themes.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.d.ts +6 -0
- package/dist/docs/tech/lifecycle-stage-system.docblock.d.ts +6 -0
- package/dist/docs/tech/llm/llm-integration.docblock.d.ts +7 -0
- package/dist/docs/tech/mcp-endpoints.docblock.d.ts +6 -0
- package/dist/docs/tech/presentation-runtime.docblock.d.ts +6 -0
- package/dist/docs/tech/schema/README.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/learning-events.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/learning-journeys.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/platform-admin-panel.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/project-access-teams.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/project-routing.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/team-invitations.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/workspace-ops.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/workspaces.docblock.d.ts +6 -0
- package/dist/docs/tech/telemetry-ingest.docblock.d.ts +6 -0
- package/dist/docs/tech/templates/runtime.docblock.d.ts +6 -0
- package/dist/docs/tech/vscode-extension.docblock.d.ts +6 -0
- package/dist/docs/tech/workflows/overview.docblock.d.ts +6 -0
- package/dist/docs/tech-contracts.docs.d.ts +6 -0
- package/dist/docs/types.d.ts +41 -0
- package/dist/events.d.ts +47 -0
- package/dist/experiments/docs/experiments.docblock.d.ts +6 -0
- package/dist/experiments/evaluator.d.ts +37 -0
- package/dist/experiments/spec-resolver.d.ts +16 -0
- package/dist/experiments/spec.d.ts +89 -0
- package/dist/features.d.ts +96 -0
- package/dist/forms/docs/forms.docblock.d.ts +6 -0
- package/dist/forms.d.ts +258 -0
- package/dist/index.d.ts +127 -0
- package/dist/install.d.ts +76 -0
- package/dist/integrations/binding.d.ts +17 -0
- package/dist/integrations/connection.d.ts +51 -0
- package/dist/integrations/contracts.d.ts +435 -0
- package/dist/integrations/docs/integrations.docblock.d.ts +6 -0
- package/dist/integrations/health.d.ts +21 -0
- package/dist/integrations/index.d.ts +34 -0
- package/dist/integrations/openbanking/contracts/accounts.d.ts +287 -0
- package/dist/integrations/openbanking/contracts/balances.d.ts +163 -0
- package/dist/integrations/openbanking/contracts/index.d.ts +10 -0
- package/dist/integrations/openbanking/contracts/transactions.d.ts +211 -0
- package/dist/integrations/openbanking/guards.d.ts +12 -0
- package/dist/integrations/openbanking/models.d.ts +228 -0
- package/dist/integrations/openbanking/openbanking.feature.d.ts +11 -0
- package/dist/integrations/openbanking/telemetry.d.ts +15 -0
- package/dist/integrations/providers/calendar.d.ts +78 -0
- package/dist/integrations/providers/elevenlabs.d.ts +7 -0
- package/dist/integrations/providers/email.d.ts +86 -0
- package/dist/integrations/providers/embedding.d.ts +24 -0
- package/dist/integrations/providers/gcs-storage.d.ts +7 -0
- package/dist/integrations/providers/gmail.d.ts +7 -0
- package/dist/integrations/providers/google-calendar.d.ts +7 -0
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts +20 -0
- package/dist/integrations/providers/impls/gcs-storage.d.ts +24 -0
- package/dist/integrations/providers/impls/gmail-inbound.d.ts +26 -0
- package/dist/integrations/providers/impls/gmail-outbound.d.ts +18 -0
- package/dist/integrations/providers/impls/google-calendar.d.ts +23 -0
- package/dist/integrations/providers/impls/index.d.ts +15 -0
- package/dist/integrations/providers/impls/mistral-embedding.d.ts +23 -0
- package/dist/integrations/providers/impls/mistral-llm.d.ts +31 -0
- package/dist/integrations/providers/impls/postmark-email.d.ts +19 -0
- package/dist/integrations/providers/impls/powens-client.d.ts +124 -0
- package/dist/integrations/providers/impls/powens-openbanking.d.ts +27 -0
- package/dist/integrations/providers/impls/provider-factory.d.ts +26 -0
- package/dist/integrations/providers/impls/qdrant-vector.d.ts +24 -0
- package/dist/integrations/providers/impls/stripe-payments.d.ts +28 -0
- package/dist/integrations/providers/impls/twilio-sms.d.ts +20 -0
- package/dist/integrations/providers/index.d.ts +22 -0
- package/dist/integrations/providers/llm.d.ts +82 -0
- package/dist/integrations/providers/mistral.d.ts +7 -0
- package/dist/integrations/providers/openbanking.d.ts +128 -0
- package/dist/integrations/providers/payments.d.ts +109 -0
- package/dist/integrations/providers/postmark.d.ts +7 -0
- package/dist/integrations/providers/powens.d.ts +7 -0
- package/dist/integrations/providers/qdrant.d.ts +7 -0
- package/dist/integrations/providers/registry.d.ts +11 -0
- package/dist/integrations/providers/sms.d.ts +34 -0
- package/dist/integrations/providers/storage.d.ts +60 -0
- package/dist/integrations/providers/stripe.d.ts +7 -0
- package/dist/integrations/providers/twilio-sms.d.ts +7 -0
- package/dist/integrations/providers/vector-store.d.ts +43 -0
- package/dist/integrations/providers/voice.d.ts +34 -0
- package/dist/integrations/runtime.d.ts +99 -0
- package/dist/integrations/secrets/aws-secret-manager.d.ts +31 -0
- package/dist/integrations/secrets/env-secret-provider.d.ts +31 -0
- package/dist/integrations/secrets/gcp-secret-manager.d.ts +32 -0
- package/dist/integrations/secrets/gcp-secret-manager.js +1 -1
- package/dist/integrations/secrets/index.d.ts +7 -0
- package/dist/integrations/secrets/manager.d.ts +47 -0
- package/dist/integrations/secrets/provider.d.ts +52 -0
- package/dist/integrations/secrets/scaleway-secret-manager.d.ts +38 -0
- package/dist/integrations/spec.d.ts +79 -0
- package/dist/jobs/define-job.d.ts +18 -0
- package/dist/jobs/gcp-cloud-tasks.d.ts +41 -0
- package/dist/jobs/gcp-pubsub.d.ts +25 -0
- package/dist/jobs/handlers/gmail-sync-handler.d.ts +9 -0
- package/dist/jobs/handlers/index.d.ts +9 -0
- package/dist/jobs/handlers/ping-handler.d.ts +10 -0
- package/dist/jobs/handlers/storage-document-handler.d.ts +12 -0
- package/dist/jobs/index.d.ts +3 -0
- package/dist/jobs/memory-queue.d.ts +18 -0
- package/dist/jobs/queue.d.ts +131 -0
- package/dist/jobs/scaleway-sqs-queue.d.ts +30 -0
- package/dist/jsonschema.d.ts +27 -0
- package/dist/knowledge/binding.d.ts +25 -0
- package/dist/knowledge/contracts.d.ts +316 -0
- package/dist/knowledge/docs/knowledge.docblock.d.ts +6 -0
- package/dist/knowledge/index.d.ts +10 -0
- package/dist/knowledge/ingestion/document-processor.d.ts +24 -0
- package/dist/knowledge/ingestion/embedding-service.d.ts +12 -0
- package/dist/knowledge/ingestion/gmail-adapter.d.ts +18 -0
- package/dist/knowledge/ingestion/index.d.ts +6 -0
- package/dist/knowledge/ingestion/storage-adapter.d.ts +15 -0
- package/dist/knowledge/ingestion/vector-indexer.d.ts +18 -0
- package/dist/knowledge/query/index.d.ts +2 -0
- package/dist/knowledge/query/service.d.ts +29 -0
- package/dist/knowledge/runtime.d.ts +32 -0
- package/dist/knowledge/source.d.ts +32 -0
- package/dist/knowledge/spaces/email-threads.d.ts +7 -0
- package/dist/knowledge/spaces/financial-docs.d.ts +7 -0
- package/dist/knowledge/spaces/financial-overview.d.ts +7 -0
- package/dist/knowledge/spaces/index.d.ts +7 -0
- package/dist/knowledge/spaces/product-canon.d.ts +7 -0
- package/dist/knowledge/spaces/support-faq.d.ts +7 -0
- package/dist/knowledge/spaces/uploaded-docs.d.ts +7 -0
- package/dist/knowledge/spec.d.ts +52 -0
- package/dist/llm/exporters.d.ts +67 -0
- package/dist/llm/index.d.ts +4 -0
- package/dist/llm/prompts.d.ts +51 -0
- package/dist/llm/types.d.ts +213 -0
- package/dist/markdown.d.ts +21 -0
- package/dist/migrations.d.ts +52 -0
- package/dist/onboarding-base.d.ts +137 -0
- package/dist/openapi.d.ts +31 -0
- package/dist/openbanking/docs/openbanking.docblock.d.ts +6 -0
- package/dist/ownership.d.ts +75 -0
- package/dist/policy/docs/policy.docblock.d.ts +6 -0
- package/dist/policy/engine.d.ts +39 -0
- package/dist/policy/opa-adapter.d.ts +45 -0
- package/dist/policy/spec.d.ts +114 -0
- package/dist/presentations/docs/presentations-conventions.docblock.d.ts +6 -0
- package/dist/presentations.backcompat.d.ts +7 -0
- package/dist/presentations.d.ts +98 -0
- package/dist/presentations.v2.d.ts +114 -0
- package/dist/prompt.d.ts +60 -0
- package/dist/promptRegistry.d.ts +15 -0
- package/dist/regenerator/adapters.d.ts +19 -0
- package/dist/regenerator/docs/regenerator.docblock.d.ts +6 -0
- package/dist/regenerator/executor.d.ts +70 -0
- package/dist/regenerator/index.d.ts +7 -0
- package/dist/regenerator/service.d.ts +33 -0
- package/dist/regenerator/sinks.d.ts +26 -0
- package/dist/regenerator/types.d.ts +107 -0
- package/dist/regenerator/utils.d.ts +9 -0
- package/dist/registry.d.ts +73 -0
- package/dist/resources.d.ts +64 -0
- package/dist/schema-to-markdown.d.ts +54 -0
- package/dist/server/graphql-pothos.d.ts +27 -0
- package/dist/server/index.d.ts +9 -0
- package/dist/server/mcp/createMcpServer.d.ts +15 -0
- package/dist/server/mcp/mcpTypes.d.ts +29 -0
- package/dist/server/mcp/registerPresentations.d.ts +7 -0
- package/dist/server/mcp/registerPrompts.d.ts +8 -0
- package/dist/server/mcp/registerResources.d.ts +8 -0
- package/dist/server/mcp/registerTools.d.ts +8 -0
- package/dist/server/provider-mcp.d.ts +2 -0
- package/dist/server/rest-elysia.d.ts +40 -0
- package/dist/server/rest-express.d.ts +16 -0
- package/dist/server/rest-generic.d.ts +32 -0
- package/dist/server/rest-next-app.d.ts +35 -0
- package/dist/server/rest-next-mcp.d.ts +11 -0
- package/dist/server/rest-next-pages.d.ts +9 -0
- package/dist/spec.d.ts +195 -0
- package/dist/telemetry/anomaly.d.ts +27 -0
- package/dist/telemetry/docs/telemetry.docblock.d.ts +6 -0
- package/dist/telemetry/index.d.ts +4 -0
- package/dist/telemetry/spec.d.ts +98 -0
- package/dist/telemetry/tracker.d.ts +51 -0
- package/dist/tests/index.d.ts +3 -0
- package/dist/tests/runner.d.ts +43 -0
- package/dist/tests/spec.d.ts +89 -0
- package/dist/themes.d.ts +55 -0
- package/dist/translations/catalog.d.ts +28 -0
- package/dist/translations/tenant.d.ts +15 -0
- package/dist/types/all.d.ts +60 -0
- package/dist/types.d.ts +88 -0
- package/dist/workflow/adapters/db-adapter.d.ts +34 -0
- package/dist/workflow/adapters/file-adapter.d.ts +14 -0
- package/dist/workflow/adapters/index.d.ts +4 -0
- package/dist/workflow/adapters/memory-store.d.ts +18 -0
- package/dist/workflow/expression.d.ts +9 -0
- package/dist/workflow/index.d.ts +10 -0
- package/dist/workflow/runner.d.ts +74 -0
- package/dist/workflow/sla-monitor.d.ts +20 -0
- package/dist/workflow/spec.d.ts +99 -0
- package/dist/workflow/state.d.ts +35 -0
- package/dist/workflow/validation.d.ts +28 -0
- package/package.json +250 -250
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
//#region src/integrations/providers/sms.d.ts
|
|
2
|
+
interface SmsMessage {
|
|
3
|
+
id: string;
|
|
4
|
+
to: string;
|
|
5
|
+
from: string;
|
|
6
|
+
body: string;
|
|
7
|
+
status: 'queued' | 'sending' | 'sent' | 'delivered' | 'undelivered' | 'failed';
|
|
8
|
+
providerMessageId?: string;
|
|
9
|
+
carrier?: string;
|
|
10
|
+
price?: number;
|
|
11
|
+
priceCurrency?: string;
|
|
12
|
+
sentAt?: Date;
|
|
13
|
+
deliveredAt?: Date;
|
|
14
|
+
errorCode?: string;
|
|
15
|
+
errorMessage?: string;
|
|
16
|
+
}
|
|
17
|
+
interface SendSmsInput {
|
|
18
|
+
to: string;
|
|
19
|
+
from?: string;
|
|
20
|
+
body: string;
|
|
21
|
+
metadata?: Record<string, string>;
|
|
22
|
+
}
|
|
23
|
+
interface SmsDeliveryStatus {
|
|
24
|
+
status: SmsMessage['status'];
|
|
25
|
+
errorCode?: string;
|
|
26
|
+
errorMessage?: string;
|
|
27
|
+
updatedAt: Date;
|
|
28
|
+
}
|
|
29
|
+
interface SmsProvider {
|
|
30
|
+
sendSms(input: SendSmsInput): Promise<SmsMessage>;
|
|
31
|
+
getDeliveryStatus(messageId: string): Promise<SmsDeliveryStatus>;
|
|
32
|
+
}
|
|
33
|
+
//#endregion
|
|
34
|
+
export { SendSmsInput, SmsDeliveryStatus, SmsMessage, SmsProvider };
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
//#region src/integrations/providers/storage.d.ts
|
|
2
|
+
interface StorageObjectMetadata {
|
|
3
|
+
bucket: string;
|
|
4
|
+
key: string;
|
|
5
|
+
sizeBytes?: number;
|
|
6
|
+
contentType?: string;
|
|
7
|
+
etag?: string;
|
|
8
|
+
checksum?: string;
|
|
9
|
+
lastModified?: Date;
|
|
10
|
+
metadata?: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
type StorageObjectBody = {
|
|
13
|
+
data: Uint8Array;
|
|
14
|
+
stream?: never;
|
|
15
|
+
} | {
|
|
16
|
+
data?: never;
|
|
17
|
+
stream: AsyncIterable<Uint8Array>;
|
|
18
|
+
};
|
|
19
|
+
type GetObjectResult = StorageObjectMetadata & StorageObjectBody;
|
|
20
|
+
interface PutObjectInput {
|
|
21
|
+
bucket: string;
|
|
22
|
+
key: string;
|
|
23
|
+
data: Uint8Array | ArrayBuffer;
|
|
24
|
+
contentType?: string;
|
|
25
|
+
metadata?: Record<string, string>;
|
|
26
|
+
makePublic?: boolean;
|
|
27
|
+
}
|
|
28
|
+
interface DeleteObjectInput {
|
|
29
|
+
bucket: string;
|
|
30
|
+
key: string;
|
|
31
|
+
}
|
|
32
|
+
interface SignedUrlOptions {
|
|
33
|
+
bucket: string;
|
|
34
|
+
key: string;
|
|
35
|
+
expiresInSeconds: number;
|
|
36
|
+
method?: 'GET' | 'PUT';
|
|
37
|
+
contentType?: string;
|
|
38
|
+
}
|
|
39
|
+
interface ListObjectsQuery {
|
|
40
|
+
bucket: string;
|
|
41
|
+
prefix?: string;
|
|
42
|
+
maxResults?: number;
|
|
43
|
+
pageToken?: string;
|
|
44
|
+
}
|
|
45
|
+
interface ListObjectsResult {
|
|
46
|
+
objects: StorageObjectMetadata[];
|
|
47
|
+
nextPageToken?: string;
|
|
48
|
+
}
|
|
49
|
+
interface ObjectStorageProvider {
|
|
50
|
+
putObject(input: PutObjectInput): Promise<StorageObjectMetadata>;
|
|
51
|
+
getObject(input: DeleteObjectInput): Promise<GetObjectResult | null>;
|
|
52
|
+
deleteObject(input: DeleteObjectInput): Promise<void>;
|
|
53
|
+
generateSignedUrl(options: SignedUrlOptions): Promise<{
|
|
54
|
+
url: string;
|
|
55
|
+
expiresAt: Date;
|
|
56
|
+
}>;
|
|
57
|
+
listObjects(query: ListObjectsQuery): Promise<ListObjectsResult>;
|
|
58
|
+
}
|
|
59
|
+
//#endregion
|
|
60
|
+
export { DeleteObjectInput, GetObjectResult, ListObjectsQuery, ListObjectsResult, ObjectStorageProvider, PutObjectInput, SignedUrlOptions, StorageObjectBody, StorageObjectMetadata };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { IntegrationSpec, IntegrationSpecRegistry } from "../spec.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/providers/stripe.d.ts
|
|
4
|
+
declare const stripeIntegrationSpec: IntegrationSpec;
|
|
5
|
+
declare function registerStripeIntegration(registry: IntegrationSpecRegistry): IntegrationSpecRegistry;
|
|
6
|
+
//#endregion
|
|
7
|
+
export { registerStripeIntegration, stripeIntegrationSpec };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { IntegrationSpec, IntegrationSpecRegistry } from "../spec.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/providers/twilio-sms.d.ts
|
|
4
|
+
declare const twilioSmsIntegrationSpec: IntegrationSpec;
|
|
5
|
+
declare function registerTwilioSmsIntegration(registry: IntegrationSpecRegistry): IntegrationSpecRegistry;
|
|
6
|
+
//#endregion
|
|
7
|
+
export { registerTwilioSmsIntegration, twilioSmsIntegrationSpec };
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { EmbeddingVector } from "./embedding.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/providers/vector-store.d.ts
|
|
4
|
+
interface VectorDocument {
|
|
5
|
+
id: string;
|
|
6
|
+
vector: EmbeddingVector;
|
|
7
|
+
payload?: Record<string, unknown>;
|
|
8
|
+
namespace?: string;
|
|
9
|
+
expiresAt?: Date;
|
|
10
|
+
}
|
|
11
|
+
interface VectorUpsertRequest {
|
|
12
|
+
collection: string;
|
|
13
|
+
documents: VectorDocument[];
|
|
14
|
+
waitForSync?: boolean;
|
|
15
|
+
}
|
|
16
|
+
interface VectorDeleteRequest {
|
|
17
|
+
collection: string;
|
|
18
|
+
ids: string[];
|
|
19
|
+
namespace?: string;
|
|
20
|
+
}
|
|
21
|
+
interface VectorSearchQuery {
|
|
22
|
+
collection: string;
|
|
23
|
+
vector: EmbeddingVector;
|
|
24
|
+
topK: number;
|
|
25
|
+
namespace?: string;
|
|
26
|
+
filter?: Record<string, unknown>;
|
|
27
|
+
scoreThreshold?: number;
|
|
28
|
+
consistent?: boolean;
|
|
29
|
+
}
|
|
30
|
+
interface VectorSearchResult {
|
|
31
|
+
id: string;
|
|
32
|
+
score: number;
|
|
33
|
+
payload?: Record<string, unknown>;
|
|
34
|
+
vector?: EmbeddingVector;
|
|
35
|
+
namespace?: string;
|
|
36
|
+
}
|
|
37
|
+
interface VectorStoreProvider {
|
|
38
|
+
upsert(request: VectorUpsertRequest): Promise<void>;
|
|
39
|
+
search(query: VectorSearchQuery): Promise<VectorSearchResult[]>;
|
|
40
|
+
delete(request: VectorDeleteRequest): Promise<void>;
|
|
41
|
+
}
|
|
42
|
+
//#endregion
|
|
43
|
+
export { VectorDeleteRequest, VectorDocument, VectorSearchQuery, VectorSearchResult, VectorStoreProvider, VectorUpsertRequest };
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
//#region src/integrations/providers/voice.d.ts
|
|
2
|
+
interface Voice {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
language?: string;
|
|
7
|
+
gender?: 'male' | 'female' | 'neutral';
|
|
8
|
+
previewUrl?: string;
|
|
9
|
+
metadata?: Record<string, string>;
|
|
10
|
+
}
|
|
11
|
+
interface VoiceSynthesisInput {
|
|
12
|
+
text: string;
|
|
13
|
+
voiceId?: string;
|
|
14
|
+
language?: string;
|
|
15
|
+
style?: number;
|
|
16
|
+
stability?: number;
|
|
17
|
+
similarityBoost?: number;
|
|
18
|
+
format?: 'mp3' | 'wav' | 'ogg' | 'pcm';
|
|
19
|
+
sampleRateHz?: number;
|
|
20
|
+
metadata?: Record<string, string>;
|
|
21
|
+
}
|
|
22
|
+
interface VoiceSynthesisResult {
|
|
23
|
+
audio: Uint8Array;
|
|
24
|
+
format: string;
|
|
25
|
+
sampleRateHz: number;
|
|
26
|
+
durationSeconds?: number;
|
|
27
|
+
url?: string;
|
|
28
|
+
}
|
|
29
|
+
interface VoiceProvider {
|
|
30
|
+
listVoices(): Promise<Voice[]>;
|
|
31
|
+
synthesize(input: VoiceSynthesisInput): Promise<VoiceSynthesisResult>;
|
|
32
|
+
}
|
|
33
|
+
//#endregion
|
|
34
|
+
export { Voice, VoiceProvider, VoiceSynthesisInput, VoiceSynthesisResult };
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { IntegrationSpec } from "./spec.js";
|
|
2
|
+
import { ConnectionStatus, IntegrationConnection } from "./connection.js";
|
|
3
|
+
import { ResolvedAppConfig, ResolvedIntegration } from "../app-config/runtime.js";
|
|
4
|
+
import { SecretProvider } from "./secrets/provider.js";
|
|
5
|
+
|
|
6
|
+
//#region src/integrations/runtime.d.ts
|
|
7
|
+
interface IntegrationTraceMetadata {
|
|
8
|
+
blueprintName: string;
|
|
9
|
+
blueprintVersion: number;
|
|
10
|
+
configVersion: number;
|
|
11
|
+
}
|
|
12
|
+
interface IntegrationTelemetryEvent {
|
|
13
|
+
tenantId: string;
|
|
14
|
+
appId: string;
|
|
15
|
+
environment?: string;
|
|
16
|
+
slotId?: string;
|
|
17
|
+
integrationKey: string;
|
|
18
|
+
integrationVersion: number;
|
|
19
|
+
connectionId: string;
|
|
20
|
+
status: 'success' | 'error';
|
|
21
|
+
durationMs?: number;
|
|
22
|
+
errorCode?: string;
|
|
23
|
+
errorMessage?: string;
|
|
24
|
+
occurredAt: Date;
|
|
25
|
+
metadata?: Record<string, string | number | boolean>;
|
|
26
|
+
}
|
|
27
|
+
interface IntegrationTelemetryEmitter {
|
|
28
|
+
record(event: IntegrationTelemetryEvent): Promise<void> | void;
|
|
29
|
+
}
|
|
30
|
+
type IntegrationInvocationStatus = 'success' | 'error';
|
|
31
|
+
interface IntegrationContext {
|
|
32
|
+
tenantId: string;
|
|
33
|
+
appId: string;
|
|
34
|
+
environment?: string;
|
|
35
|
+
slotId?: string;
|
|
36
|
+
spec: IntegrationSpec;
|
|
37
|
+
connection: IntegrationConnection;
|
|
38
|
+
secretProvider: SecretProvider;
|
|
39
|
+
secretReference: string;
|
|
40
|
+
trace: IntegrationTraceMetadata;
|
|
41
|
+
config?: Record<string, unknown>;
|
|
42
|
+
}
|
|
43
|
+
interface IntegrationCallContext {
|
|
44
|
+
tenantId: string;
|
|
45
|
+
appId: string;
|
|
46
|
+
environment?: string;
|
|
47
|
+
blueprintName: string;
|
|
48
|
+
blueprintVersion: number;
|
|
49
|
+
configVersion: number;
|
|
50
|
+
slotId: string;
|
|
51
|
+
operation: string;
|
|
52
|
+
}
|
|
53
|
+
interface IntegrationCallError {
|
|
54
|
+
code: string;
|
|
55
|
+
message: string;
|
|
56
|
+
retryable: boolean;
|
|
57
|
+
cause?: unknown;
|
|
58
|
+
}
|
|
59
|
+
interface IntegrationCallResult<T> {
|
|
60
|
+
success: boolean;
|
|
61
|
+
data?: T;
|
|
62
|
+
error?: IntegrationCallError;
|
|
63
|
+
metadata: {
|
|
64
|
+
latencyMs: number;
|
|
65
|
+
connectionId: string;
|
|
66
|
+
ownershipMode: IntegrationConnection['ownershipMode'];
|
|
67
|
+
attempts: number;
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
interface IntegrationCallGuardOptions {
|
|
71
|
+
telemetry?: IntegrationTelemetryEmitter;
|
|
72
|
+
maxAttempts?: number;
|
|
73
|
+
backoffMs?: number;
|
|
74
|
+
shouldRetry?: (error: unknown, attempt: number) => boolean;
|
|
75
|
+
sleep?: (ms: number) => Promise<void>;
|
|
76
|
+
now?: () => Date;
|
|
77
|
+
}
|
|
78
|
+
declare class IntegrationCallGuard {
|
|
79
|
+
private readonly secretProvider;
|
|
80
|
+
private readonly telemetry?;
|
|
81
|
+
private readonly maxAttempts;
|
|
82
|
+
private readonly backoffMs;
|
|
83
|
+
private readonly shouldRetry;
|
|
84
|
+
private readonly sleep;
|
|
85
|
+
private readonly now;
|
|
86
|
+
constructor(secretProvider: SecretProvider, options?: IntegrationCallGuardOptions);
|
|
87
|
+
executeWithGuards<T>(slotId: string, operation: string, input: unknown, resolvedConfig: ResolvedAppConfig, executor: (connection: IntegrationConnection, secrets: Record<string, string>) => Promise<T>): Promise<IntegrationCallResult<T>>;
|
|
88
|
+
private findIntegration;
|
|
89
|
+
private fetchSecrets;
|
|
90
|
+
private parseSecret;
|
|
91
|
+
private emitTelemetry;
|
|
92
|
+
private failure;
|
|
93
|
+
private makeContext;
|
|
94
|
+
private errorCodeFor;
|
|
95
|
+
}
|
|
96
|
+
declare function ensureConnectionReady(integration: ResolvedIntegration): void;
|
|
97
|
+
declare function connectionStatusLabel(status: ConnectionStatus): string;
|
|
98
|
+
//#endregion
|
|
99
|
+
export { IntegrationCallContext, IntegrationCallError, IntegrationCallGuard, IntegrationCallGuardOptions, IntegrationCallResult, IntegrationContext, IntegrationInvocationStatus, IntegrationTelemetryEmitter, IntegrationTelemetryEvent, IntegrationTraceMetadata, connectionStatusLabel, ensureConnectionReady };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { SecretFetchOptions, SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
import { SecretsManagerClient } from "@aws-sdk/client-secrets-manager";
|
|
3
|
+
|
|
4
|
+
//#region src/integrations/secrets/aws-secret-manager.d.ts
|
|
5
|
+
type AwsSecretsManagerClient = Pick<SecretsManagerClient, 'send'>;
|
|
6
|
+
type AwsSecretsManagerClientConfig = ConstructorParameters<typeof SecretsManagerClient>[0];
|
|
7
|
+
interface AwsSecretsManagerProviderOptions {
|
|
8
|
+
region?: string;
|
|
9
|
+
client?: AwsSecretsManagerClient;
|
|
10
|
+
clientConfig?: AwsSecretsManagerClientConfig;
|
|
11
|
+
}
|
|
12
|
+
declare class AwsSecretsManagerProvider implements SecretProvider {
|
|
13
|
+
readonly id = "aws-secrets-manager";
|
|
14
|
+
private readonly explicitRegion?;
|
|
15
|
+
private readonly injectedClient?;
|
|
16
|
+
private readonly clientConfig?;
|
|
17
|
+
private readonly clientsByRegion;
|
|
18
|
+
constructor(options?: AwsSecretsManagerProviderOptions);
|
|
19
|
+
canHandle(reference: SecretReference): boolean;
|
|
20
|
+
getSecret(reference: SecretReference, options?: SecretFetchOptions): Promise<SecretValue>;
|
|
21
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
22
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
23
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
24
|
+
private getClient;
|
|
25
|
+
private parseReference;
|
|
26
|
+
private resolveRegion;
|
|
27
|
+
private buildVersionSelector;
|
|
28
|
+
private buildReference;
|
|
29
|
+
}
|
|
30
|
+
//#endregion
|
|
31
|
+
export { AwsSecretsManagerProvider };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/secrets/env-secret-provider.d.ts
|
|
4
|
+
interface EnvSecretProviderOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Optional map to alias secret references to environment variable names.
|
|
7
|
+
* Useful when referencing secrets from other providers (e.g. gcp://...)
|
|
8
|
+
* while still allowing local overrides.
|
|
9
|
+
*/
|
|
10
|
+
aliases?: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Environment-variable backed secret provider. Read-only by design.
|
|
14
|
+
* Allows overriding other secret providers by deriving environment variable
|
|
15
|
+
* names from secret references (or by using explicit aliases).
|
|
16
|
+
*/
|
|
17
|
+
declare class EnvSecretProvider implements SecretProvider {
|
|
18
|
+
readonly id = "env";
|
|
19
|
+
private readonly aliases;
|
|
20
|
+
constructor(options?: EnvSecretProviderOptions);
|
|
21
|
+
canHandle(reference: SecretReference): boolean;
|
|
22
|
+
getSecret(reference: SecretReference): Promise<SecretValue>;
|
|
23
|
+
setSecret(reference: SecretReference, _payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
24
|
+
rotateSecret(reference: SecretReference, _payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
25
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
26
|
+
private resolveEnvKey;
|
|
27
|
+
private deriveEnvKey;
|
|
28
|
+
private forbiddenError;
|
|
29
|
+
}
|
|
30
|
+
//#endregion
|
|
31
|
+
export { EnvSecretProvider };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
import { SecretManagerServiceClient, protos } from "@google-cloud/secret-manager";
|
|
3
|
+
import { CallOptions } from "google-gax";
|
|
4
|
+
|
|
5
|
+
//#region src/integrations/secrets/gcp-secret-manager.d.ts
|
|
6
|
+
type SecretManagerClient = SecretManagerServiceClient;
|
|
7
|
+
interface GcpSecretManagerProviderOptions {
|
|
8
|
+
projectId?: string;
|
|
9
|
+
client?: SecretManagerClient;
|
|
10
|
+
clientOptions?: ConstructorParameters<typeof SecretManagerServiceClient>[0];
|
|
11
|
+
defaultReplication?: protos.google.cloud.secretmanager.v1.IReplication;
|
|
12
|
+
}
|
|
13
|
+
declare class GcpSecretManagerProvider implements SecretProvider {
|
|
14
|
+
readonly id = "gcp-secret-manager";
|
|
15
|
+
private readonly client;
|
|
16
|
+
private readonly explicitProjectId?;
|
|
17
|
+
private readonly replication;
|
|
18
|
+
constructor(options?: GcpSecretManagerProviderOptions);
|
|
19
|
+
canHandle(reference: SecretReference): boolean;
|
|
20
|
+
getSecret(reference: SecretReference, options?: {
|
|
21
|
+
version?: string;
|
|
22
|
+
}, callOptions?: CallOptions): Promise<SecretValue>;
|
|
23
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
24
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
25
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
26
|
+
private parseReference;
|
|
27
|
+
private buildNames;
|
|
28
|
+
private buildVersionName;
|
|
29
|
+
private ensureSecretExists;
|
|
30
|
+
}
|
|
31
|
+
//#endregion
|
|
32
|
+
export { GcpSecretManagerProvider };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{SecretProviderError as e,normalizeSecretPayload as t,parseSecretUri as n}from"./provider.js";import{SecretManagerServiceClient as r}from"@google-cloud/secret-manager";const
|
|
1
|
+
import{SecretProviderError as e,normalizeSecretPayload as t,parseSecretUri as n}from"./provider.js";import{SecretManagerServiceClient as r,protos as i}from"@google-cloud/secret-manager";const a={automatic:{}};var o=class{id=`gcp-secret-manager`;client;explicitProjectId;replication;constructor(e={}){this.client=e.client??new r(e.clientOptions??{}),this.explicitProjectId=e.projectId,this.replication=e.defaultReplication??a}canHandle(e){try{return n(e).provider===`gcp`}catch{return!1}}async getSecret(t,n,r){let i=this.parseReference(t),a=this.buildVersionName(i,n?.version);try{let[n]=await this.client.accessSecretVersion({name:a},r??{}),i=n.payload;if(!i?.data)throw new e({message:`Secret payload empty for ${a}`,provider:this.id,reference:t,code:`UNKNOWN`});let o=s(n.name??a);return{data:i.data,version:o,metadata:i.dataCrc32c?{crc32c:i.dataCrc32c.toString()}:void 0,retrievedAt:new Date}}catch(e){throw c({error:e,provider:this.id,reference:t,operation:`access`})}}async setSecret(n,r){let i=this.parseReference(n),{secretName:a}=this.buildNames(i),o=t(r);await this.ensureSecretExists(i,r);try{let t=await this.client.addSecretVersion({parent:a,payload:{data:o}});if(!t)throw new e({message:`No version returned when adding secret version for ${a}`,provider:this.id,reference:n,code:`UNKNOWN`});let[r]=t,i=r?.name??`${a}/versions/latest`;return{reference:`gcp://${i}`,version:s(i)??`latest`}}catch(e){throw c({error:e,provider:this.id,reference:n,operation:`addSecretVersion`})}}async rotateSecret(e,t){return this.setSecret(e,t)}async deleteSecret(e){let t=this.parseReference(e),{secretName:n}=this.buildNames(t);try{await this.client.deleteSecret({name:n})}catch(t){throw c({error:t,provider:this.id,reference:e,operation:`delete`})}}parseReference(t){let r=n(t);if(r.provider!==`gcp`)throw new e({message:`Unsupported secret provider: ${r.provider}`,provider:this.id,reference:t,code:`INVALID`});let i=r.path.split(`/`).filter(Boolean);if(i.length<4||i[0]!==`projects`)throw new e({message:`Expected secret reference format gcp://projects/{project}/secrets/{secret}[(/versions/{version})] but received "${r.path}"`,provider:this.id,reference:t,code:`INVALID`});let a=i[1]??this.explicitProjectId;if(!a)throw new e({message:`Unable to resolve project or secret from reference "${r.path}"`,provider:this.id,reference:t,code:`INVALID`});let o=i.indexOf(`secrets`);if(o===-1||o+1>=i.length)throw new e({message:`Unable to resolve project or secret from reference "${r.path}"`,provider:this.id,reference:t,code:`INVALID`});let s=a,c=i[o+1];if(!c)throw new e({message:`Unable to resolve secret ID from reference "${r.path}"`,provider:this.id,reference:t,code:`INVALID`});let l=c,u=i.indexOf(`versions`);return{projectId:s,secretId:l,version:r.extras?.version??(u!==-1&&u+1<i.length?i[u+1]:void 0)}}buildNames(t){let n=t.projectId??this.explicitProjectId;if(!n)throw new e({message:`Project ID must be provided either in reference or provider configuration`,provider:this.id,reference:`gcp://projects//secrets/${t.secretId}`,code:`INVALID`});let r=`projects/${n}`;return{projectParent:r,secretName:`${r}/secrets/${t.secretId}`}}buildVersionName(e,t){let{secretName:n}=this.buildNames(e);return`${n}/versions/${t??e.version??`latest`}`}async ensureSecretExists(e,t){let{secretName:n,projectParent:r}=this.buildNames(e);try{await this.client.getSecret({name:n})}catch(i){let a=c({error:i,provider:this.id,reference:`gcp://${n}`,operation:`getSecret`,suppressThrow:!0});if(!a||a.code!==`NOT_FOUND`)throw a||i;try{await this.client.createSecret({parent:r,secretId:e.secretId,secret:{replication:this.replication,labels:t.labels}})}catch(e){throw c({error:e,provider:this.id,reference:`gcp://${n}`,operation:`createSecret`})}}}};function s(e){let t=e.split(`/`).filter(Boolean),n=t.indexOf(`versions`);if(!(n===-1||n+1>=t.length))return t[n+1]}function c(t){let{error:n,provider:r,reference:i,operation:a,suppressThrow:o}=t;if(n instanceof e)return n;let s=l(n),c=new e({message:n instanceof Error?n.message:`Unknown error during ${a}`,provider:r,reference:i,code:s,cause:n});if(o)return c;throw c}function l(e){if(typeof e!=`object`||!e)return`UNKNOWN`;let t=e.code;return t===5||t===`NOT_FOUND`?`NOT_FOUND`:t===6||t===`ALREADY_EXISTS`?`INVALID`:t===7||t===`PERMISSION_DENIED`||t===403?`FORBIDDEN`:t===3||t===`INVALID_ARGUMENT`?`INVALID`:`UNKNOWN`}export{o as GcpSecretManagerProvider};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ParsedSecretUri, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri } from "./provider.js";
|
|
2
|
+
import { AwsSecretsManagerProvider } from "./aws-secret-manager.js";
|
|
3
|
+
import { EnvSecretProvider } from "./env-secret-provider.js";
|
|
4
|
+
import { GcpSecretManagerProvider } from "./gcp-secret-manager.js";
|
|
5
|
+
import { ScalewaySecretManagerProvider } from "./scaleway-secret-manager.js";
|
|
6
|
+
import { SecretProviderManager, SecretProviderManagerOptions } from "./manager.js";
|
|
7
|
+
export { AwsSecretsManagerProvider, EnvSecretProvider, GcpSecretManagerProvider, ParsedSecretUri, ScalewaySecretManagerProvider, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretProviderManager, SecretProviderManagerOptions, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri };
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/secrets/manager.d.ts
|
|
4
|
+
interface RegisterOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Larger priority values are attempted first. Defaults to 0.
|
|
7
|
+
*/
|
|
8
|
+
priority?: number;
|
|
9
|
+
}
|
|
10
|
+
interface SecretProviderManagerOptions {
|
|
11
|
+
/**
|
|
12
|
+
* Override manager identifier. Defaults to "secret-provider-manager".
|
|
13
|
+
*/
|
|
14
|
+
id?: string;
|
|
15
|
+
/**
|
|
16
|
+
* Providers to pre-register. They are registered in array order with
|
|
17
|
+
* descending priority (first entry wins ties).
|
|
18
|
+
*/
|
|
19
|
+
providers?: {
|
|
20
|
+
provider: SecretProvider;
|
|
21
|
+
priority?: number;
|
|
22
|
+
}[];
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Composite secret provider that delegates to registered providers.
|
|
26
|
+
* Providers are attempted in order of descending priority, respecting the
|
|
27
|
+
* registration order for ties. This enables privileged overrides (e.g.
|
|
28
|
+
* environment variables) while still supporting durable backends like GCP
|
|
29
|
+
* Secret Manager.
|
|
30
|
+
*/
|
|
31
|
+
declare class SecretProviderManager implements SecretProvider {
|
|
32
|
+
readonly id: string;
|
|
33
|
+
private readonly providers;
|
|
34
|
+
private registrationCounter;
|
|
35
|
+
constructor(options?: SecretProviderManagerOptions);
|
|
36
|
+
register(provider: SecretProvider, options?: RegisterOptions): this;
|
|
37
|
+
canHandle(reference: SecretReference): boolean;
|
|
38
|
+
getSecret(reference: SecretReference, options?: SecretFetchOptions): Promise<SecretValue>;
|
|
39
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
40
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
41
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
42
|
+
private delegateToFirst;
|
|
43
|
+
private composeError;
|
|
44
|
+
}
|
|
45
|
+
type SecretFetchOptions = Parameters<SecretProvider['getSecret']>[1];
|
|
46
|
+
//#endregion
|
|
47
|
+
export { SecretProviderManager, SecretProviderManagerOptions };
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//#region src/integrations/secrets/provider.d.ts
|
|
2
|
+
type SecretReference = string;
|
|
3
|
+
interface SecretValue {
|
|
4
|
+
data: Uint8Array;
|
|
5
|
+
version?: string;
|
|
6
|
+
metadata?: Record<string, string>;
|
|
7
|
+
retrievedAt: Date;
|
|
8
|
+
}
|
|
9
|
+
interface SecretFetchOptions {
|
|
10
|
+
version?: string;
|
|
11
|
+
}
|
|
12
|
+
type SecretPayloadEncoding = 'utf-8' | 'base64' | 'binary';
|
|
13
|
+
interface SecretWritePayload {
|
|
14
|
+
data: string | Uint8Array;
|
|
15
|
+
encoding?: SecretPayloadEncoding;
|
|
16
|
+
contentType?: string;
|
|
17
|
+
labels?: Record<string, string>;
|
|
18
|
+
}
|
|
19
|
+
interface SecretRotationResult {
|
|
20
|
+
reference: SecretReference;
|
|
21
|
+
version: string;
|
|
22
|
+
}
|
|
23
|
+
interface SecretProvider {
|
|
24
|
+
readonly id: string;
|
|
25
|
+
canHandle(reference: SecretReference): boolean;
|
|
26
|
+
getSecret(reference: SecretReference, options?: SecretFetchOptions): Promise<SecretValue>;
|
|
27
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
28
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
29
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
30
|
+
}
|
|
31
|
+
interface ParsedSecretUri {
|
|
32
|
+
provider: string;
|
|
33
|
+
path: string;
|
|
34
|
+
extras?: Record<string, string>;
|
|
35
|
+
}
|
|
36
|
+
declare class SecretProviderError extends Error {
|
|
37
|
+
readonly provider: string;
|
|
38
|
+
readonly reference: SecretReference;
|
|
39
|
+
readonly code: 'NOT_FOUND' | 'FORBIDDEN' | 'INVALID' | 'UNKNOWN';
|
|
40
|
+
readonly cause?: unknown;
|
|
41
|
+
constructor(params: {
|
|
42
|
+
message: string;
|
|
43
|
+
provider: string;
|
|
44
|
+
reference: SecretReference;
|
|
45
|
+
code?: SecretProviderError['code'];
|
|
46
|
+
cause?: unknown;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
declare function parseSecretUri(reference: SecretReference): ParsedSecretUri;
|
|
50
|
+
declare function normalizeSecretPayload(payload: SecretWritePayload): Uint8Array;
|
|
51
|
+
//#endregion
|
|
52
|
+
export { ParsedSecretUri, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri };
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { SecretFetchOptions, SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/secrets/scaleway-secret-manager.d.ts
|
|
4
|
+
interface ScalewaySecretManagerProviderOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Scaleway API token (SCW secret key). If omitted, uses env vars.
|
|
7
|
+
* Header: X-Auth-Token
|
|
8
|
+
*/
|
|
9
|
+
token?: string;
|
|
10
|
+
/** Default region when not present in reference (e.g. fr-par). */
|
|
11
|
+
defaultRegion?: string;
|
|
12
|
+
/** Default project id used when creating secrets by name. */
|
|
13
|
+
defaultProjectId?: string;
|
|
14
|
+
/** Override API base url (defaults to https://api.scaleway.com). */
|
|
15
|
+
baseUrl?: string;
|
|
16
|
+
/** Inject fetch for tests. */
|
|
17
|
+
fetch?: typeof fetch;
|
|
18
|
+
}
|
|
19
|
+
declare class ScalewaySecretManagerProvider implements SecretProvider {
|
|
20
|
+
readonly id = "scaleway-secret-manager";
|
|
21
|
+
private readonly token;
|
|
22
|
+
private readonly defaultRegion?;
|
|
23
|
+
private readonly defaultProjectId?;
|
|
24
|
+
private readonly baseUrl;
|
|
25
|
+
private readonly fetchFn;
|
|
26
|
+
constructor(options?: ScalewaySecretManagerProviderOptions);
|
|
27
|
+
canHandle(reference: SecretReference): boolean;
|
|
28
|
+
getSecret(reference: SecretReference, options?: SecretFetchOptions): Promise<SecretValue>;
|
|
29
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
30
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
31
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
32
|
+
private parseReference;
|
|
33
|
+
private createSecret;
|
|
34
|
+
private createSecretVersion;
|
|
35
|
+
private buildReference;
|
|
36
|
+
}
|
|
37
|
+
//#endregion
|
|
38
|
+
export { ScalewaySecretManagerProvider };
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { OwnerShipMeta } from "../ownership.js";
|
|
2
|
+
import { CapabilityRef, CapabilityRequirement } from "../capabilities.js";
|
|
3
|
+
|
|
4
|
+
//#region src/integrations/spec.d.ts
|
|
5
|
+
type IntegrationCategory = 'payments' | 'email' | 'calendar' | 'sms' | 'ai-llm' | 'ai-voice' | 'speech-to-text' | 'vector-db' | 'storage' | 'accounting' | 'crm' | 'helpdesk' | 'open-banking' | 'custom';
|
|
6
|
+
type IntegrationOwnershipMode = 'managed' | 'byok';
|
|
7
|
+
interface IntegrationMeta extends OwnerShipMeta {
|
|
8
|
+
/** Stable provider slug (e.g., "stripe", "openai"). */
|
|
9
|
+
key: string;
|
|
10
|
+
/** Provider version (increment on breaking API changes). */
|
|
11
|
+
version: number;
|
|
12
|
+
category: IntegrationCategory;
|
|
13
|
+
displayName: string;
|
|
14
|
+
}
|
|
15
|
+
interface IntegrationCapabilityMapping {
|
|
16
|
+
/** Which CapabilitySpec this integration provides. */
|
|
17
|
+
provides: CapabilityRef[];
|
|
18
|
+
/** Optional: which capabilities it requires (e.g., storage for caching). */
|
|
19
|
+
requires?: CapabilityRequirement[];
|
|
20
|
+
}
|
|
21
|
+
interface IntegrationConfigSchema {
|
|
22
|
+
/** JSON Schema or SchemaModel defining required config fields. */
|
|
23
|
+
schema: unknown;
|
|
24
|
+
/** Example configuration (for docs/UI). */
|
|
25
|
+
example?: Record<string, unknown>;
|
|
26
|
+
}
|
|
27
|
+
interface IntegrationSecretSchema {
|
|
28
|
+
/** JSON Schema or SchemaModel describing secret fields. */
|
|
29
|
+
schema: unknown;
|
|
30
|
+
/** Redacted example for documentation/UI. */
|
|
31
|
+
example?: Record<string, string>;
|
|
32
|
+
}
|
|
33
|
+
interface IntegrationByokSetup {
|
|
34
|
+
/** Human-readable instructions for tenants configuring BYOK accounts. */
|
|
35
|
+
setupInstructions?: string;
|
|
36
|
+
/** Required scopes/permissions for BYOK accounts. */
|
|
37
|
+
requiredScopes?: string[];
|
|
38
|
+
}
|
|
39
|
+
interface IntegrationHealthCheck {
|
|
40
|
+
/** Endpoint or method to validate connection health. */
|
|
41
|
+
method?: 'ping' | 'list' | 'custom';
|
|
42
|
+
/** Timeout in ms for health check. */
|
|
43
|
+
timeoutMs?: number;
|
|
44
|
+
}
|
|
45
|
+
interface IntegrationSpec {
|
|
46
|
+
meta: IntegrationMeta;
|
|
47
|
+
/** Supported ownership modes for this provider. */
|
|
48
|
+
supportedModes: IntegrationOwnershipMode[];
|
|
49
|
+
/** Which capabilities this integration provides/requires. */
|
|
50
|
+
capabilities: IntegrationCapabilityMapping;
|
|
51
|
+
/** Configuration schema (API keys, endpoints, etc.). */
|
|
52
|
+
configSchema: IntegrationConfigSchema;
|
|
53
|
+
/** Secret schema (API/key material stored via secretRef). */
|
|
54
|
+
secretSchema: IntegrationSecretSchema;
|
|
55
|
+
/** Optional health check configuration. */
|
|
56
|
+
healthCheck?: IntegrationHealthCheck;
|
|
57
|
+
/** Documentation URL. */
|
|
58
|
+
docsUrl?: string;
|
|
59
|
+
/** Rate limits or usage constraints. */
|
|
60
|
+
constraints?: {
|
|
61
|
+
rateLimit?: {
|
|
62
|
+
rpm?: number;
|
|
63
|
+
rph?: number;
|
|
64
|
+
};
|
|
65
|
+
quotas?: Record<string, number>;
|
|
66
|
+
};
|
|
67
|
+
/** Provider-specific metadata for BYOK setup flows. */
|
|
68
|
+
byokSetup?: IntegrationByokSetup;
|
|
69
|
+
}
|
|
70
|
+
declare class IntegrationSpecRegistry {
|
|
71
|
+
private readonly items;
|
|
72
|
+
register(spec: IntegrationSpec): this;
|
|
73
|
+
list(): IntegrationSpec[];
|
|
74
|
+
get(key: string, version?: number): IntegrationSpec | undefined;
|
|
75
|
+
getByCategory(category: IntegrationCategory): IntegrationSpec[];
|
|
76
|
+
}
|
|
77
|
+
declare function makeIntegrationSpecKey(meta: IntegrationMeta): string;
|
|
78
|
+
//#endregion
|
|
79
|
+
export { IntegrationByokSetup, IntegrationCapabilityMapping, IntegrationCategory, IntegrationConfigSchema, IntegrationHealthCheck, IntegrationMeta, IntegrationOwnershipMode, IntegrationSecretSchema, IntegrationSpec, IntegrationSpecRegistry, makeIntegrationSpecKey };
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Job, JobQueue } from "./queue.js";
|
|
2
|
+
import { ZodSchema } from "zod";
|
|
3
|
+
|
|
4
|
+
//#region src/jobs/define-job.d.ts
|
|
5
|
+
interface DefinedJob<TPayload> {
|
|
6
|
+
type: string;
|
|
7
|
+
schema: ZodSchema<TPayload>;
|
|
8
|
+
handler: (payload: TPayload, job: Job<TPayload>) => Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Register a `DefinedJob` on a queue with payload validation.
|
|
12
|
+
*
|
|
13
|
+
* - Parses and validates payload via the job's Zod schema
|
|
14
|
+
* - Invokes the defined handler with the validated payload
|
|
15
|
+
*/
|
|
16
|
+
declare function registerDefinedJob<TPayload>(queue: JobQueue, job: DefinedJob<TPayload>): void;
|
|
17
|
+
//#endregion
|
|
18
|
+
export { DefinedJob, registerDefinedJob };
|