@lssm/integration.providers-impls 1.41.0 → 1.42.1
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 +21 -0
- package/README.md +4 -1
- package/dist/_virtual/rolldown_runtime.js +36 -1
- package/dist/calendar.d.ts +8 -0
- package/dist/calendar.d.ts.map +1 -0
- package/dist/calendar.js +3 -1
- package/dist/email.d.ts +8 -0
- package/dist/email.d.ts.map +1 -0
- package/dist/email.js +3 -1
- package/dist/embedding.d.ts +8 -0
- package/dist/embedding.d.ts.map +1 -0
- package/dist/embedding.js +3 -1
- package/dist/impls/elevenlabs-voice.d.ts +21 -0
- package/dist/impls/elevenlabs-voice.d.ts.map +1 -0
- package/dist/impls/elevenlabs-voice.js +93 -1
- package/dist/impls/elevenlabs-voice.js.map +1 -0
- package/dist/impls/gcs-storage.d.ts +25 -0
- package/dist/impls/gcs-storage.d.ts.map +1 -0
- package/dist/impls/gcs-storage.js +90 -1
- package/dist/impls/gcs-storage.js.map +1 -0
- package/dist/impls/gmail-inbound.d.ts +27 -0
- package/dist/impls/gmail-inbound.d.ts.map +1 -0
- package/dist/impls/gmail-inbound.js +201 -1
- package/dist/impls/gmail-inbound.js.map +1 -0
- package/dist/impls/gmail-outbound.d.ts +19 -0
- package/dist/impls/gmail-outbound.d.ts.map +1 -0
- package/dist/impls/gmail-outbound.js +105 -5
- package/dist/impls/gmail-outbound.js.map +1 -0
- package/dist/impls/google-calendar.d.ts +24 -0
- package/dist/impls/google-calendar.d.ts.map +1 -0
- package/dist/impls/google-calendar.js +155 -1
- package/dist/impls/google-calendar.js.map +1 -0
- package/dist/impls/index.d.ts +15 -0
- package/dist/impls/index.js +16 -1
- package/dist/impls/mistral-embedding.d.ts +24 -0
- package/dist/impls/mistral-embedding.d.ts.map +1 -0
- package/dist/impls/mistral-embedding.js +42 -1
- package/dist/impls/mistral-embedding.js.map +1 -0
- package/dist/impls/mistral-llm.d.ts +32 -0
- package/dist/impls/mistral-llm.d.ts.map +1 -0
- package/dist/impls/mistral-llm.js +248 -1
- package/dist/impls/mistral-llm.js.map +1 -0
- package/dist/impls/postmark-email.d.ts +20 -0
- package/dist/impls/postmark-email.d.ts.map +1 -0
- package/dist/impls/postmark-email.js +56 -1
- package/dist/impls/postmark-email.js.map +1 -0
- package/dist/impls/powens-client.d.ts +125 -0
- package/dist/impls/powens-client.d.ts.map +1 -0
- package/dist/impls/powens-client.js +172 -1
- package/dist/impls/powens-client.js.map +1 -0
- package/dist/impls/powens-openbanking.d.ts +28 -0
- package/dist/impls/powens-openbanking.d.ts.map +1 -0
- package/dist/impls/powens-openbanking.js +219 -1
- package/dist/impls/powens-openbanking.js.map +1 -0
- package/dist/impls/provider-factory.d.ts +27 -0
- package/dist/impls/provider-factory.d.ts.map +1 -0
- package/dist/impls/provider-factory.js +143 -1
- package/dist/impls/provider-factory.js.map +1 -0
- package/dist/impls/qdrant-vector.d.ts +25 -0
- package/dist/impls/qdrant-vector.d.ts.map +1 -0
- package/dist/impls/qdrant-vector.js +72 -1
- package/dist/impls/qdrant-vector.js.map +1 -0
- package/dist/impls/stripe-payments.d.ts +29 -0
- package/dist/impls/stripe-payments.d.ts.map +1 -0
- package/dist/impls/stripe-payments.js +203 -1
- package/dist/impls/stripe-payments.js.map +1 -0
- package/dist/impls/twilio-sms.d.ts +21 -0
- package/dist/impls/twilio-sms.d.ts.map +1 -0
- package/dist/impls/twilio-sms.js +59 -1
- package/dist/impls/twilio-sms.js.map +1 -0
- package/dist/index.d.ts +44 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +69 -1
- package/dist/index.js.map +1 -0
- package/dist/llm.d.ts +8 -0
- package/dist/llm.d.ts.map +1 -0
- package/dist/llm.js +3 -1
- package/dist/openbanking.d.ts +8 -0
- package/dist/openbanking.d.ts.map +1 -0
- package/dist/openbanking.js +3 -1
- package/dist/payments.d.ts +8 -0
- package/dist/payments.d.ts.map +1 -0
- package/dist/payments.js +3 -1
- package/dist/runtime.d.ts +2 -0
- package/dist/secrets/provider.d.ts +2 -0
- package/dist/secrets/provider.js +3 -1
- package/dist/sms.d.ts +8 -0
- package/dist/sms.d.ts.map +1 -0
- package/dist/sms.js +3 -1
- package/dist/storage.d.ts +8 -0
- package/dist/storage.d.ts.map +1 -0
- package/dist/storage.js +3 -1
- package/dist/vector-store.d.ts +8 -0
- package/dist/vector-store.d.ts.map +1 -0
- package/dist/vector-store.js +3 -1
- package/dist/voice.d.ts +8 -0
- package/dist/voice.d.ts.map +1 -0
- package/dist/voice.js +3 -1
- package/package.json +46 -38
|
@@ -1 +1,143 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { MistralLLMProvider } from "./mistral-llm.js";
|
|
2
|
+
import { MistralEmbeddingProvider } from "./mistral-embedding.js";
|
|
3
|
+
import { QdrantVectorProvider } from "./qdrant-vector.js";
|
|
4
|
+
import { GoogleCloudStorageProvider } from "./gcs-storage.js";
|
|
5
|
+
import { StripePaymentsProvider } from "./stripe-payments.js";
|
|
6
|
+
import { PostmarkEmailProvider } from "./postmark-email.js";
|
|
7
|
+
import { TwilioSmsProvider } from "./twilio-sms.js";
|
|
8
|
+
import { ElevenLabsVoiceProvider } from "./elevenlabs-voice.js";
|
|
9
|
+
import { PowensOpenBankingProvider } from "./powens-openbanking.js";
|
|
10
|
+
import { Buffer } from "node:buffer";
|
|
11
|
+
|
|
12
|
+
//#region src/impls/provider-factory.ts
|
|
13
|
+
const SECRET_CACHE = /* @__PURE__ */ new Map();
|
|
14
|
+
var IntegrationProviderFactory = class {
|
|
15
|
+
async createPaymentsProvider(context) {
|
|
16
|
+
const secrets = await this.loadSecrets(context);
|
|
17
|
+
switch (context.spec.meta.key) {
|
|
18
|
+
case "payments.stripe": return new StripePaymentsProvider({ apiKey: requireSecret(secrets, "apiKey", "Stripe API key is required") });
|
|
19
|
+
default: throw new Error(`Unsupported payments integration: ${context.spec.meta.key}`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async createEmailOutboundProvider(context) {
|
|
23
|
+
const secrets = await this.loadSecrets(context);
|
|
24
|
+
switch (context.spec.meta.key) {
|
|
25
|
+
case "email.postmark": return new PostmarkEmailProvider({
|
|
26
|
+
serverToken: requireSecret(secrets, "serverToken", "Postmark server token is required"),
|
|
27
|
+
defaultFromEmail: context.config.fromEmail,
|
|
28
|
+
messageStream: context.config.messageStream
|
|
29
|
+
});
|
|
30
|
+
default: throw new Error(`Unsupported email integration: ${context.spec.meta.key}`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async createSmsProvider(context) {
|
|
34
|
+
const secrets = await this.loadSecrets(context);
|
|
35
|
+
switch (context.spec.meta.key) {
|
|
36
|
+
case "sms.twilio": return new TwilioSmsProvider({
|
|
37
|
+
accountSid: requireSecret(secrets, "accountSid", "Twilio account SID is required"),
|
|
38
|
+
authToken: requireSecret(secrets, "authToken", "Twilio auth token is required"),
|
|
39
|
+
fromNumber: context.config.fromNumber
|
|
40
|
+
});
|
|
41
|
+
default: throw new Error(`Unsupported SMS integration: ${context.spec.meta.key}`);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
async createVectorStoreProvider(context) {
|
|
45
|
+
const secrets = await this.loadSecrets(context);
|
|
46
|
+
switch (context.spec.meta.key) {
|
|
47
|
+
case "vectordb.qdrant": return new QdrantVectorProvider({
|
|
48
|
+
url: requireConfig(context, "apiUrl", "Qdrant apiUrl config is required"),
|
|
49
|
+
apiKey: secrets.apiKey
|
|
50
|
+
});
|
|
51
|
+
default: throw new Error(`Unsupported vector store integration: ${context.spec.meta.key}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
async createObjectStorageProvider(context) {
|
|
55
|
+
const secrets = await this.loadSecrets(context);
|
|
56
|
+
switch (context.spec.meta.key) {
|
|
57
|
+
case "storage.s3":
|
|
58
|
+
case "storage.gcs": return new GoogleCloudStorageProvider({
|
|
59
|
+
bucket: requireConfig(context, "bucket", "Storage bucket is required"),
|
|
60
|
+
clientOptions: secrets.type === "service_account" ? { credentials: secrets } : void 0
|
|
61
|
+
});
|
|
62
|
+
default: throw new Error(`Unsupported storage integration: ${context.spec.meta.key}`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
async createVoiceProvider(context) {
|
|
66
|
+
const secrets = await this.loadSecrets(context);
|
|
67
|
+
switch (context.spec.meta.key) {
|
|
68
|
+
case "ai-voice.elevenlabs": return new ElevenLabsVoiceProvider({
|
|
69
|
+
apiKey: requireSecret(secrets, "apiKey", "ElevenLabs API key is required"),
|
|
70
|
+
defaultVoiceId: context.config.defaultVoiceId
|
|
71
|
+
});
|
|
72
|
+
default: throw new Error(`Unsupported voice integration: ${context.spec.meta.key}`);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async createLlmProvider(context) {
|
|
76
|
+
const secrets = await this.loadSecrets(context);
|
|
77
|
+
switch (context.spec.meta.key) {
|
|
78
|
+
case "ai-llm.mistral": return new MistralLLMProvider({
|
|
79
|
+
apiKey: requireSecret(secrets, "apiKey", "Mistral API key is required"),
|
|
80
|
+
defaultModel: context.config.model
|
|
81
|
+
});
|
|
82
|
+
default: throw new Error(`Unsupported LLM integration: ${context.spec.meta.key}`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
async createEmbeddingProvider(context) {
|
|
86
|
+
const secrets = await this.loadSecrets(context);
|
|
87
|
+
switch (context.spec.meta.key) {
|
|
88
|
+
case "ai-llm.mistral": return new MistralEmbeddingProvider({
|
|
89
|
+
apiKey: requireSecret(secrets, "apiKey", "Mistral API key is required"),
|
|
90
|
+
defaultModel: context.config.embeddingModel
|
|
91
|
+
});
|
|
92
|
+
default: throw new Error(`Unsupported embeddings integration: ${context.spec.meta.key}`);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
async createOpenBankingProvider(context) {
|
|
96
|
+
const secrets = await this.loadSecrets(context);
|
|
97
|
+
const config = context.config;
|
|
98
|
+
switch (context.spec.meta.key) {
|
|
99
|
+
case "openbanking.powens": {
|
|
100
|
+
const environmentValue = requireConfig(context, "environment", "Powens environment (sandbox | production) must be specified in integration config.");
|
|
101
|
+
if (environmentValue !== "sandbox" && environmentValue !== "production") throw new Error(`Powens environment "${environmentValue}" is invalid. Expected "sandbox" or "production".`);
|
|
102
|
+
return new PowensOpenBankingProvider({
|
|
103
|
+
clientId: requireSecret(secrets, "clientId", "Powens clientId is required"),
|
|
104
|
+
clientSecret: requireSecret(secrets, "clientSecret", "Powens clientSecret is required"),
|
|
105
|
+
apiKey: secrets.apiKey,
|
|
106
|
+
environment: environmentValue,
|
|
107
|
+
baseUrl: config?.baseUrl
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
default: throw new Error(`Unsupported open banking integration: ${context.spec.meta.key}`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
async loadSecrets(context) {
|
|
114
|
+
const cacheKey = context.connection.meta.id;
|
|
115
|
+
if (SECRET_CACHE.has(cacheKey)) return SECRET_CACHE.get(cacheKey) ?? {};
|
|
116
|
+
const value = parseSecret(await context.secretProvider.getSecret(context.secretReference));
|
|
117
|
+
SECRET_CACHE.set(cacheKey, value);
|
|
118
|
+
return value;
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
function parseSecret(secret) {
|
|
122
|
+
const text = Buffer.from(secret.data).toString("utf-8").trim();
|
|
123
|
+
if (!text) return {};
|
|
124
|
+
try {
|
|
125
|
+
return JSON.parse(text);
|
|
126
|
+
} catch {
|
|
127
|
+
return { apiKey: text };
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
function requireSecret(secrets, key, message) {
|
|
131
|
+
const value = secrets[key];
|
|
132
|
+
if (value == null || value === "") throw new Error(message);
|
|
133
|
+
return value;
|
|
134
|
+
}
|
|
135
|
+
function requireConfig(context, key, message) {
|
|
136
|
+
const value = context.config?.[key];
|
|
137
|
+
if (value == null) throw new Error(message);
|
|
138
|
+
return value;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
//#endregion
|
|
142
|
+
export { IntegrationProviderFactory };
|
|
143
|
+
//# sourceMappingURL=provider-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-factory.js","names":[],"sources":["../../src/impls/provider-factory.ts"],"sourcesContent":["import { Buffer } from 'node:buffer';\n\nimport type { IntegrationContext } from '@lssm/integration.runtime/runtime';\nimport type { SecretValue } from '@lssm/integration.runtime/secrets/provider';\nimport { MistralLLMProvider } from './mistral-llm';\nimport { MistralEmbeddingProvider } from './mistral-embedding';\nimport { QdrantVectorProvider } from './qdrant-vector';\nimport { GoogleCloudStorageProvider } from './gcs-storage';\nimport { StripePaymentsProvider } from './stripe-payments';\nimport { PostmarkEmailProvider } from './postmark-email';\nimport { TwilioSmsProvider } from './twilio-sms';\nimport { ElevenLabsVoiceProvider } from './elevenlabs-voice';\nimport type { PaymentsProvider } from '../payments';\nimport type { EmailOutboundProvider } from '../email';\nimport type { SmsProvider } from '../sms';\nimport type { VectorStoreProvider } from '../vector-store';\nimport type { ObjectStorageProvider } from '../storage';\nimport type { VoiceProvider } from '../voice';\nimport type { LLMProvider } from '../llm';\nimport type { EmbeddingProvider } from '../embedding';\nimport type { OpenBankingProvider } from '../openbanking';\nimport { PowensOpenBankingProvider } from './powens-openbanking';\nimport type { PowensEnvironment } from './powens-client';\n\nconst SECRET_CACHE = new Map<string, Record<string, unknown>>();\n\nexport class IntegrationProviderFactory {\n async createPaymentsProvider(\n context: IntegrationContext\n ): Promise<PaymentsProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'payments.stripe':\n return new StripePaymentsProvider({\n apiKey: requireSecret<string>(\n secrets,\n 'apiKey',\n 'Stripe API key is required'\n ),\n });\n default:\n throw new Error(\n `Unsupported payments integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createEmailOutboundProvider(\n context: IntegrationContext\n ): Promise<EmailOutboundProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'email.postmark':\n return new PostmarkEmailProvider({\n serverToken: requireSecret<string>(\n secrets,\n 'serverToken',\n 'Postmark server token is required'\n ),\n defaultFromEmail: (context.config as { fromEmail?: string })\n .fromEmail,\n messageStream: (context.config as { messageStream?: string })\n .messageStream,\n });\n default:\n throw new Error(\n `Unsupported email integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createSmsProvider(context: IntegrationContext): Promise<SmsProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'sms.twilio':\n return new TwilioSmsProvider({\n accountSid: requireSecret<string>(\n secrets,\n 'accountSid',\n 'Twilio account SID is required'\n ),\n authToken: requireSecret<string>(\n secrets,\n 'authToken',\n 'Twilio auth token is required'\n ),\n fromNumber: (context.config as { fromNumber?: string }).fromNumber,\n });\n default:\n throw new Error(\n `Unsupported SMS integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createVectorStoreProvider(\n context: IntegrationContext\n ): Promise<VectorStoreProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'vectordb.qdrant':\n return new QdrantVectorProvider({\n url: requireConfig<string>(\n context,\n 'apiUrl',\n 'Qdrant apiUrl config is required'\n ),\n apiKey: secrets.apiKey as string | undefined,\n });\n default:\n throw new Error(\n `Unsupported vector store integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createObjectStorageProvider(\n context: IntegrationContext\n ): Promise<ObjectStorageProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'storage.s3':\n case 'storage.gcs':\n return new GoogleCloudStorageProvider({\n bucket: requireConfig<string>(\n context,\n 'bucket',\n 'Storage bucket is required'\n ),\n clientOptions:\n secrets.type === 'service_account'\n ? { credentials: secrets as Record<string, unknown> }\n : undefined,\n });\n default:\n throw new Error(\n `Unsupported storage integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createVoiceProvider(\n context: IntegrationContext\n ): Promise<VoiceProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'ai-voice.elevenlabs':\n return new ElevenLabsVoiceProvider({\n apiKey: requireSecret<string>(\n secrets,\n 'apiKey',\n 'ElevenLabs API key is required'\n ),\n defaultVoiceId: (context.config as { defaultVoiceId?: string })\n .defaultVoiceId,\n });\n default:\n throw new Error(\n `Unsupported voice integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createLlmProvider(context: IntegrationContext): Promise<LLMProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'ai-llm.mistral':\n return new MistralLLMProvider({\n apiKey: requireSecret<string>(\n secrets,\n 'apiKey',\n 'Mistral API key is required'\n ),\n defaultModel: (context.config as { model?: string }).model,\n });\n default:\n throw new Error(\n `Unsupported LLM integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createEmbeddingProvider(\n context: IntegrationContext\n ): Promise<EmbeddingProvider> {\n const secrets = await this.loadSecrets(context);\n switch (context.spec.meta.key) {\n case 'ai-llm.mistral':\n return new MistralEmbeddingProvider({\n apiKey: requireSecret<string>(\n secrets,\n 'apiKey',\n 'Mistral API key is required'\n ),\n defaultModel: (context.config as { embeddingModel?: string })\n .embeddingModel,\n });\n default:\n throw new Error(\n `Unsupported embeddings integration: ${context.spec.meta.key}`\n );\n }\n }\n\n async createOpenBankingProvider(\n context: IntegrationContext\n ): Promise<OpenBankingProvider> {\n const secrets = await this.loadSecrets(context);\n const config = context.config as {\n environment?: string;\n baseUrl?: string;\n region?: string;\n pollingIntervalMs?: number;\n };\n\n switch (context.spec.meta.key) {\n case 'openbanking.powens': {\n const environmentValue = requireConfig<string>(\n context,\n 'environment',\n 'Powens environment (sandbox | production) must be specified in integration config.'\n );\n if (\n environmentValue !== 'sandbox' &&\n environmentValue !== 'production'\n ) {\n throw new Error(\n `Powens environment \"${environmentValue}\" is invalid. Expected \"sandbox\" or \"production\".`\n );\n }\n\n return new PowensOpenBankingProvider({\n clientId: requireSecret<string>(\n secrets,\n 'clientId',\n 'Powens clientId is required'\n ),\n clientSecret: requireSecret<string>(\n secrets,\n 'clientSecret',\n 'Powens clientSecret is required'\n ),\n apiKey: secrets.apiKey as string | undefined,\n environment: environmentValue as PowensEnvironment,\n baseUrl: config?.baseUrl as string | undefined,\n });\n }\n default:\n throw new Error(\n `Unsupported open banking integration: ${context.spec.meta.key}`\n );\n }\n }\n\n private async loadSecrets(\n context: IntegrationContext\n ): Promise<Record<string, unknown>> {\n const cacheKey = context.connection.meta.id;\n if (SECRET_CACHE.has(cacheKey)) {\n const cached = SECRET_CACHE.get(cacheKey);\n return cached ?? {};\n }\n const secret = await context.secretProvider.getSecret(\n context.secretReference\n );\n const value = parseSecret(secret);\n SECRET_CACHE.set(cacheKey, value);\n return value;\n }\n}\n\nfunction parseSecret(secret: SecretValue): Record<string, unknown> {\n const text = Buffer.from(secret.data).toString('utf-8').trim();\n if (!text) return {};\n try {\n return JSON.parse(text);\n } catch {\n return { apiKey: text };\n }\n}\n\nfunction requireSecret<T>(\n secrets: Record<string, unknown>,\n key: string,\n message: string\n): T {\n const value = secrets[key];\n if (value == null || value === '') {\n throw new Error(message);\n }\n return value as T;\n}\n\nfunction requireConfig<T>(\n context: IntegrationContext,\n key: string,\n message: string\n): T {\n const config = context.config as Record<string, unknown>;\n const value = config?.[key];\n if (value == null) {\n throw new Error(message);\n }\n return value as T;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { vector_store_d_exports } from "../vector-store.js";
|
|
2
|
+
import { QdrantClient, QdrantClientParams } from "@qdrant/js-client-rest";
|
|
3
|
+
|
|
4
|
+
//#region src/impls/qdrant-vector.d.ts
|
|
5
|
+
interface QdrantVectorProviderOptions {
|
|
6
|
+
url: string;
|
|
7
|
+
apiKey?: string;
|
|
8
|
+
client?: QdrantClient;
|
|
9
|
+
createCollectionIfMissing?: boolean;
|
|
10
|
+
distance?: 'Cosine' | 'Euclid' | 'Dot' | 'Manhattan';
|
|
11
|
+
clientParams?: Omit<QdrantClientParams, 'url' | 'apiKey'>;
|
|
12
|
+
}
|
|
13
|
+
declare class QdrantVectorProvider implements vector_store_d_exports.VectorStoreProvider {
|
|
14
|
+
private readonly client;
|
|
15
|
+
private readonly createCollectionIfMissing;
|
|
16
|
+
private readonly distance;
|
|
17
|
+
constructor(options: QdrantVectorProviderOptions);
|
|
18
|
+
upsert(request: vector_store_d_exports.VectorUpsertRequest): Promise<void>;
|
|
19
|
+
search(query: vector_store_d_exports.VectorSearchQuery): Promise<vector_store_d_exports.VectorSearchResult[]>;
|
|
20
|
+
delete(request: vector_store_d_exports.VectorDeleteRequest): Promise<void>;
|
|
21
|
+
private ensureCollection;
|
|
22
|
+
}
|
|
23
|
+
//#endregion
|
|
24
|
+
export { QdrantVectorProvider, QdrantVectorProviderOptions };
|
|
25
|
+
//# sourceMappingURL=qdrant-vector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"qdrant-vector.d.ts","names":[],"sources":["../../src/impls/qdrant-vector.ts"],"sourcesContent":[],"mappings":";;;;UAUiB,2BAAA;;EAAA,MAAA,CAAA,EAAA,MAAA;EAGN,MAAA,CAAA,EAAA,YAAA;EAGW,yBAAA,CAAA,EAAA,OAAA;EAAL,QAAA,CAAA,EAAA,QAAA,GAAA,QAAA,GAAA,KAAA,GAAA,WAAA;EAAI,YAAA,CAAA,EAAJ,IAAI,CAAC,kBAAD,EAAA,KAAA,GAAA,QAAA,CAAA;AAGrB;AAKuB,cALV,oBAAA,YAAgC,sBAAA,CAAA,mBAKtB,CAAA;EAYC,iBAAA,MAAA;EAAsB,iBAAA,yBAAA;EA4BxB,iBAAA,QAAA;EAA4B,WAAA,CAAA,OAAA,EAxC3B,2BAwC2B;EAAR,MAAA,CAAA,OAAA,EA5BlB,sBAAA,CAAA,mBA4BkB,CAAA,EA5BI,OA4BJ,CAAA,IAAA,CAAA;EAqBlB,MAAA,CAAA,KAAA,EArBF,sBAAA,CAAA,iBAqBE,CAAA,EArBkB,OAqBlB,CArB0B,sBAAA,CAAA,kBAqB1B,EAAA,CAAA;EAAsB,MAAA,CAAA,OAAA,EAAtB,sBAAA,CAAA,mBAAsB,CAAA,EAAA,OAAA,CAAA,IAAA,CAAA;EAlED,QAAA,gBAAA"}
|
|
@@ -1 +1,72 @@
|
|
|
1
|
-
import{QdrantClient
|
|
1
|
+
import { QdrantClient } from "@qdrant/js-client-rest";
|
|
2
|
+
|
|
3
|
+
//#region src/impls/qdrant-vector.ts
|
|
4
|
+
var QdrantVectorProvider = class {
|
|
5
|
+
client;
|
|
6
|
+
createCollectionIfMissing;
|
|
7
|
+
distance;
|
|
8
|
+
constructor(options) {
|
|
9
|
+
this.client = options.client ?? new QdrantClient({
|
|
10
|
+
url: options.url,
|
|
11
|
+
apiKey: options.apiKey,
|
|
12
|
+
...options.clientParams
|
|
13
|
+
});
|
|
14
|
+
this.createCollectionIfMissing = options.createCollectionIfMissing ?? true;
|
|
15
|
+
this.distance = options.distance ?? "Cosine";
|
|
16
|
+
}
|
|
17
|
+
async upsert(request) {
|
|
18
|
+
if (request.documents.length === 0) return;
|
|
19
|
+
const firstDocument = request.documents[0];
|
|
20
|
+
if (!firstDocument) return;
|
|
21
|
+
const vectorSize = firstDocument.vector.length;
|
|
22
|
+
if (this.createCollectionIfMissing) await this.ensureCollection(request.collection, vectorSize);
|
|
23
|
+
const points = request.documents.map((document) => ({
|
|
24
|
+
id: document.id,
|
|
25
|
+
vector: document.vector,
|
|
26
|
+
payload: {
|
|
27
|
+
...document.payload,
|
|
28
|
+
...document.namespace ? { namespace: document.namespace } : {},
|
|
29
|
+
...document.expiresAt ? { expiresAt: document.expiresAt.toISOString() } : {}
|
|
30
|
+
}
|
|
31
|
+
}));
|
|
32
|
+
await this.client.upsert(request.collection, {
|
|
33
|
+
wait: true,
|
|
34
|
+
points
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
async search(query) {
|
|
38
|
+
return (await this.client.search(query.collection, {
|
|
39
|
+
vector: query.vector,
|
|
40
|
+
limit: query.topK,
|
|
41
|
+
filter: query.filter,
|
|
42
|
+
score_threshold: query.scoreThreshold,
|
|
43
|
+
with_payload: true,
|
|
44
|
+
with_vector: false
|
|
45
|
+
})).map((item) => ({
|
|
46
|
+
id: String(item.id),
|
|
47
|
+
score: item.score,
|
|
48
|
+
payload: item.payload ?? void 0,
|
|
49
|
+
namespace: typeof item.payload === "object" && item.payload !== null ? item.payload.namespace : void 0
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
async delete(request) {
|
|
53
|
+
await this.client.delete(request.collection, {
|
|
54
|
+
wait: true,
|
|
55
|
+
points: request.ids
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
async ensureCollection(collectionName, vectorSize) {
|
|
59
|
+
try {
|
|
60
|
+
await this.client.getCollection(collectionName);
|
|
61
|
+
} catch (_error) {
|
|
62
|
+
await this.client.createCollection(collectionName, { vectors: {
|
|
63
|
+
size: vectorSize,
|
|
64
|
+
distance: this.distance
|
|
65
|
+
} });
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
//#endregion
|
|
71
|
+
export { QdrantVectorProvider };
|
|
72
|
+
//# sourceMappingURL=qdrant-vector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"qdrant-vector.js","names":[],"sources":["../../src/impls/qdrant-vector.ts"],"sourcesContent":["import { QdrantClient, type QdrantClientParams } from '@qdrant/js-client-rest';\n\nimport type {\n VectorDeleteRequest,\n VectorSearchQuery,\n VectorSearchResult,\n VectorStoreProvider,\n VectorUpsertRequest,\n} from '../vector-store';\n\nexport interface QdrantVectorProviderOptions {\n url: string;\n apiKey?: string;\n client?: QdrantClient;\n createCollectionIfMissing?: boolean;\n distance?: 'Cosine' | 'Euclid' | 'Dot' | 'Manhattan';\n clientParams?: Omit<QdrantClientParams, 'url' | 'apiKey'>;\n}\n\nexport class QdrantVectorProvider implements VectorStoreProvider {\n private readonly client: QdrantClient;\n private readonly createCollectionIfMissing: boolean;\n private readonly distance: 'Cosine' | 'Euclid' | 'Dot' | 'Manhattan';\n\n constructor(options: QdrantVectorProviderOptions) {\n this.client =\n options.client ??\n new QdrantClient({\n url: options.url,\n apiKey: options.apiKey,\n ...options.clientParams,\n });\n this.createCollectionIfMissing = options.createCollectionIfMissing ?? true;\n this.distance = options.distance ?? 'Cosine';\n }\n\n async upsert(request: VectorUpsertRequest): Promise<void> {\n if (request.documents.length === 0) return;\n const firstDocument = request.documents[0];\n if (!firstDocument) return;\n const vectorSize = firstDocument.vector.length;\n\n if (this.createCollectionIfMissing) {\n await this.ensureCollection(request.collection, vectorSize);\n }\n\n const points = request.documents.map((document) => ({\n id: document.id,\n vector: document.vector,\n payload: {\n ...document.payload,\n ...(document.namespace ? { namespace: document.namespace } : {}),\n ...(document.expiresAt\n ? { expiresAt: document.expiresAt.toISOString() }\n : {}),\n },\n }));\n\n await this.client.upsert(request.collection, {\n wait: true,\n points,\n });\n }\n\n async search(query: VectorSearchQuery): Promise<VectorSearchResult[]> {\n const results = await this.client.search(query.collection, {\n vector: query.vector,\n limit: query.topK,\n filter: query.filter as Record<string, unknown>,\n score_threshold: query.scoreThreshold,\n with_payload: true,\n with_vector: false,\n });\n\n return results.map((item) => ({\n id: String(item.id),\n score: item.score,\n payload: item.payload ?? undefined,\n namespace:\n typeof item.payload === 'object' && item.payload !== null\n ? (item.payload.namespace as string | undefined)\n : undefined,\n }));\n }\n\n async delete(request: VectorDeleteRequest): Promise<void> {\n await this.client.delete(request.collection, {\n wait: true,\n points: request.ids,\n });\n }\n\n private async ensureCollection(\n collectionName: string,\n vectorSize: number\n ): Promise<void> {\n try {\n await this.client.getCollection(collectionName);\n } catch (_error) {\n await this.client.createCollection(collectionName, {\n vectors: {\n size: vectorSize,\n distance: this.distance,\n },\n });\n }\n }\n}\n"],"mappings":";;;AAmBA,IAAa,uBAAb,MAAiE;CAC/D,AAAiB;CACjB,AAAiB;CACjB,AAAiB;CAEjB,YAAY,SAAsC;AAChD,OAAK,SACH,QAAQ,UACR,IAAI,aAAa;GACf,KAAK,QAAQ;GACb,QAAQ,QAAQ;GAChB,GAAG,QAAQ;GACZ,CAAC;AACJ,OAAK,4BAA4B,QAAQ,6BAA6B;AACtE,OAAK,WAAW,QAAQ,YAAY;;CAGtC,MAAM,OAAO,SAA6C;AACxD,MAAI,QAAQ,UAAU,WAAW,EAAG;EACpC,MAAM,gBAAgB,QAAQ,UAAU;AACxC,MAAI,CAAC,cAAe;EACpB,MAAM,aAAa,cAAc,OAAO;AAExC,MAAI,KAAK,0BACP,OAAM,KAAK,iBAAiB,QAAQ,YAAY,WAAW;EAG7D,MAAM,SAAS,QAAQ,UAAU,KAAK,cAAc;GAClD,IAAI,SAAS;GACb,QAAQ,SAAS;GACjB,SAAS;IACP,GAAG,SAAS;IACZ,GAAI,SAAS,YAAY,EAAE,WAAW,SAAS,WAAW,GAAG,EAAE;IAC/D,GAAI,SAAS,YACT,EAAE,WAAW,SAAS,UAAU,aAAa,EAAE,GAC/C,EAAE;IACP;GACF,EAAE;AAEH,QAAM,KAAK,OAAO,OAAO,QAAQ,YAAY;GAC3C,MAAM;GACN;GACD,CAAC;;CAGJ,MAAM,OAAO,OAAyD;AAUpE,UATgB,MAAM,KAAK,OAAO,OAAO,MAAM,YAAY;GACzD,QAAQ,MAAM;GACd,OAAO,MAAM;GACb,QAAQ,MAAM;GACd,iBAAiB,MAAM;GACvB,cAAc;GACd,aAAa;GACd,CAAC,EAEa,KAAK,UAAU;GAC5B,IAAI,OAAO,KAAK,GAAG;GACnB,OAAO,KAAK;GACZ,SAAS,KAAK,WAAW;GACzB,WACE,OAAO,KAAK,YAAY,YAAY,KAAK,YAAY,OAChD,KAAK,QAAQ,YACd;GACP,EAAE;;CAGL,MAAM,OAAO,SAA6C;AACxD,QAAM,KAAK,OAAO,OAAO,QAAQ,YAAY;GAC3C,MAAM;GACN,QAAQ,QAAQ;GACjB,CAAC;;CAGJ,MAAc,iBACZ,gBACA,YACe;AACf,MAAI;AACF,SAAM,KAAK,OAAO,cAAc,eAAe;WACxC,QAAQ;AACf,SAAM,KAAK,OAAO,iBAAiB,gBAAgB,EACjD,SAAS;IACP,MAAM;IACN,UAAU,KAAK;IAChB,EACF,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { payments_d_exports } from "../payments.js";
|
|
2
|
+
import Stripe from "stripe";
|
|
3
|
+
|
|
4
|
+
//#region src/impls/stripe-payments.d.ts
|
|
5
|
+
interface StripePaymentsProviderOptions {
|
|
6
|
+
apiKey: string;
|
|
7
|
+
stripe?: Stripe;
|
|
8
|
+
}
|
|
9
|
+
declare class StripePaymentsProvider implements payments_d_exports.PaymentsProvider {
|
|
10
|
+
private readonly stripe;
|
|
11
|
+
constructor(options: StripePaymentsProviderOptions);
|
|
12
|
+
createCustomer(input: payments_d_exports.CreateCustomerInput): Promise<payments_d_exports.PaymentCustomer>;
|
|
13
|
+
getCustomer(customerId: string): Promise<payments_d_exports.PaymentCustomer | null>;
|
|
14
|
+
createPaymentIntent(input: payments_d_exports.CreatePaymentIntentInput): Promise<payments_d_exports.PaymentIntent>;
|
|
15
|
+
capturePayment(paymentIntentId: string, input?: payments_d_exports.CapturePaymentInput): Promise<payments_d_exports.PaymentIntent>;
|
|
16
|
+
cancelPaymentIntent(paymentIntentId: string): Promise<payments_d_exports.PaymentIntent>;
|
|
17
|
+
refundPayment(input: payments_d_exports.RefundPaymentInput): Promise<payments_d_exports.PaymentRefund>;
|
|
18
|
+
listInvoices(query?: payments_d_exports.ListInvoicesQuery): Promise<payments_d_exports.PaymentInvoice[]>;
|
|
19
|
+
listTransactions(query?: payments_d_exports.ListTransactionsQuery): Promise<payments_d_exports.PaymentTransaction[]>;
|
|
20
|
+
private toCustomer;
|
|
21
|
+
private toPaymentIntent;
|
|
22
|
+
private toInvoice;
|
|
23
|
+
private toMoney;
|
|
24
|
+
private toMetadata;
|
|
25
|
+
private mergeMetadata;
|
|
26
|
+
}
|
|
27
|
+
//#endregion
|
|
28
|
+
export { StripePaymentsProvider, StripePaymentsProviderOptions };
|
|
29
|
+
//# sourceMappingURL=stripe-payments.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stripe-payments.d.ts","names":[],"sources":["../../src/impls/stripe-payments.ts"],"sourcesContent":[],"mappings":";;;;UAkBiB,6BAAA;;EAAA,MAAA,CAAA,EAEN,MAFM;AAOjB;AAGuB,cAHV,sBAAA,YAAkC,kBAAA,CAAA,gBAGxB,CAAA;EAQO,iBAAA,MAAA;EAA8B,WAAA,CAAA,OAAA,EARrC,6BAQqC;EAAR,cAAA,CAAA,KAAA,EAAtB,kBAAA,CAAA,mBAAsB,CAAA,EAAA,OAAA,CAAQ,kBAAA,CAAA,eAAR,CAAA;EAUH,WAAA,CAAA,UAAA,EAAA,MAAA,CAAA,EAAR,OAAQ,CAAA,kBAAA,CAAA,eAAA,GAAA,IAAA,CAAA;EAAR,mBAAA,CAAA,KAAA,EAO9B,kBAAA,CAAA,wBAP8B,CAAA,EAQpC,OARoC,CAQ5B,kBAAA,CAAA,aAR4B,CAAA;EAO9B,cAAA,CAAA,eAAA,EAAA,MAAA,EAAA,KAAA,CAAA,EAmBC,kBAAA,CAAA,mBAnBD,CAAA,EAoBN,OApBM,CAoBE,kBAAA,CAAA,aApBF,CAAA;EACE,mBAAA,CAAA,eAAA,EAAA,MAAA,CAAA,EA2ByC,OA3BzC,CA2BiD,kBAAA,CAAA,aA3BjD,CAAA;EAAR,aAAA,CAAA,KAAA,EAgCwB,kBAAA,CAAA,kBAhCxB,CAAA,EAgC6C,OAhC7C,CAgCqD,kBAAA,CAAA,aAhCrD,CAAA;EAkBO,YAAA,CAAA,KAAA,CAAA,EAuCiB,kBAAA,CAAA,iBAvCjB,CAAA,EAuCqC,OAvCrC,CAuC6C,kBAAA,CAAA,cAvC7C,EAAA,CAAA;EACC,gBAAA,CAAA,KAAA,CAAA,EAsDD,kBAAA,CAAA,qBAtDC,CAAA,EAuDR,OAvDQ,CAuDA,kBAAA,CAAA,kBAvDA,EAAA,CAAA;EAAR,QAAA,UAAA;EAQyD,QAAA,eAAA;EAAR,QAAA,SAAA;EAKzB,QAAA,OAAA;EAA6B,QAAA,UAAA;EAAR,QAAA,aAAA"}
|
|
@@ -1 +1,203 @@
|
|
|
1
|
-
import
|
|
1
|
+
import Stripe from "stripe";
|
|
2
|
+
|
|
3
|
+
//#region src/impls/stripe-payments.ts
|
|
4
|
+
const API_VERSION = "2025-10-29.clover";
|
|
5
|
+
var StripePaymentsProvider = class {
|
|
6
|
+
stripe;
|
|
7
|
+
constructor(options) {
|
|
8
|
+
this.stripe = options.stripe ?? new Stripe(options.apiKey, { apiVersion: API_VERSION });
|
|
9
|
+
}
|
|
10
|
+
async createCustomer(input) {
|
|
11
|
+
const customer = await this.stripe.customers.create({
|
|
12
|
+
email: input.email,
|
|
13
|
+
name: input.name,
|
|
14
|
+
description: input.description,
|
|
15
|
+
metadata: input.metadata
|
|
16
|
+
});
|
|
17
|
+
return this.toCustomer(customer);
|
|
18
|
+
}
|
|
19
|
+
async getCustomer(customerId) {
|
|
20
|
+
const customer = await this.stripe.customers.retrieve(customerId);
|
|
21
|
+
if (customer.deleted) return null;
|
|
22
|
+
return this.toCustomer(customer);
|
|
23
|
+
}
|
|
24
|
+
async createPaymentIntent(input) {
|
|
25
|
+
const intent = await this.stripe.paymentIntents.create({
|
|
26
|
+
amount: input.amount.amount,
|
|
27
|
+
currency: input.amount.currency,
|
|
28
|
+
customer: input.customerId,
|
|
29
|
+
description: input.description,
|
|
30
|
+
capture_method: input.captureMethod ?? "automatic",
|
|
31
|
+
confirmation_method: input.confirmationMethod ?? "automatic",
|
|
32
|
+
automatic_payment_methods: { enabled: true },
|
|
33
|
+
metadata: input.metadata,
|
|
34
|
+
return_url: input.returnUrl,
|
|
35
|
+
statement_descriptor: input.statementDescriptor
|
|
36
|
+
});
|
|
37
|
+
return this.toPaymentIntent(intent);
|
|
38
|
+
}
|
|
39
|
+
async capturePayment(paymentIntentId, input) {
|
|
40
|
+
const intent = await this.stripe.paymentIntents.capture(paymentIntentId, input?.amount ? { amount_to_capture: input.amount.amount } : void 0);
|
|
41
|
+
return this.toPaymentIntent(intent);
|
|
42
|
+
}
|
|
43
|
+
async cancelPaymentIntent(paymentIntentId) {
|
|
44
|
+
const intent = await this.stripe.paymentIntents.cancel(paymentIntentId);
|
|
45
|
+
return this.toPaymentIntent(intent);
|
|
46
|
+
}
|
|
47
|
+
async refundPayment(input) {
|
|
48
|
+
const refund = await this.stripe.refunds.create({
|
|
49
|
+
payment_intent: input.paymentIntentId,
|
|
50
|
+
amount: input.amount?.amount,
|
|
51
|
+
reason: mapRefundReason(input.reason),
|
|
52
|
+
metadata: input.metadata
|
|
53
|
+
});
|
|
54
|
+
const paymentIntentId = typeof refund.payment_intent === "string" ? refund.payment_intent : refund.payment_intent?.id ?? "";
|
|
55
|
+
return {
|
|
56
|
+
id: refund.id,
|
|
57
|
+
paymentIntentId,
|
|
58
|
+
amount: {
|
|
59
|
+
amount: refund.amount ?? 0,
|
|
60
|
+
currency: refund.currency?.toUpperCase() ?? "USD"
|
|
61
|
+
},
|
|
62
|
+
status: mapRefundStatus(refund.status),
|
|
63
|
+
reason: refund.reason ?? void 0,
|
|
64
|
+
metadata: this.toMetadata(refund.metadata),
|
|
65
|
+
createdAt: refund.created ? /* @__PURE__ */ new Date(refund.created * 1e3) : void 0
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
async listInvoices(query) {
|
|
69
|
+
const requestedStatus = query?.status?.[0];
|
|
70
|
+
const stripeStatus = requestedStatus && requestedStatus !== "deleted" ? requestedStatus : void 0;
|
|
71
|
+
return (await this.stripe.invoices.list({
|
|
72
|
+
customer: query?.customerId,
|
|
73
|
+
status: stripeStatus,
|
|
74
|
+
limit: query?.limit,
|
|
75
|
+
starting_after: query?.startingAfter
|
|
76
|
+
})).data.map((invoice) => this.toInvoice(invoice));
|
|
77
|
+
}
|
|
78
|
+
async listTransactions(query) {
|
|
79
|
+
return (await this.stripe.charges.list({
|
|
80
|
+
customer: query?.customerId,
|
|
81
|
+
payment_intent: query?.paymentIntentId,
|
|
82
|
+
limit: query?.limit,
|
|
83
|
+
starting_after: query?.startingAfter
|
|
84
|
+
})).data.map((charge) => ({
|
|
85
|
+
id: charge.id,
|
|
86
|
+
paymentIntentId: typeof charge.payment_intent === "string" ? charge.payment_intent : charge.payment_intent?.id,
|
|
87
|
+
amount: {
|
|
88
|
+
amount: charge.amount,
|
|
89
|
+
currency: charge.currency?.toUpperCase() ?? "USD"
|
|
90
|
+
},
|
|
91
|
+
type: "capture",
|
|
92
|
+
status: mapChargeStatus(charge.status),
|
|
93
|
+
description: charge.description ?? void 0,
|
|
94
|
+
createdAt: /* @__PURE__ */ new Date(charge.created * 1e3),
|
|
95
|
+
metadata: this.mergeMetadata(this.toMetadata(charge.metadata), { balanceTransaction: typeof charge.balance_transaction === "string" ? charge.balance_transaction : void 0 })
|
|
96
|
+
}));
|
|
97
|
+
}
|
|
98
|
+
toCustomer(customer) {
|
|
99
|
+
const metadata = this.toMetadata(customer.metadata);
|
|
100
|
+
const updatedAtValue = metadata?.updatedAt;
|
|
101
|
+
return {
|
|
102
|
+
id: customer.id,
|
|
103
|
+
email: customer.email ?? void 0,
|
|
104
|
+
name: customer.name ?? void 0,
|
|
105
|
+
metadata,
|
|
106
|
+
createdAt: customer.created ? /* @__PURE__ */ new Date(customer.created * 1e3) : void 0,
|
|
107
|
+
updatedAt: updatedAtValue ? new Date(updatedAtValue) : void 0
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
toPaymentIntent(intent) {
|
|
111
|
+
const metadata = this.toMetadata(intent.metadata);
|
|
112
|
+
return {
|
|
113
|
+
id: intent.id,
|
|
114
|
+
amount: this.toMoney(intent.amount_received ?? intent.amount ?? 0, intent.currency),
|
|
115
|
+
status: mapPaymentIntentStatus(intent.status),
|
|
116
|
+
customerId: typeof intent.customer === "string" ? intent.customer : intent.customer?.id,
|
|
117
|
+
description: intent.description ?? void 0,
|
|
118
|
+
clientSecret: intent.client_secret ?? void 0,
|
|
119
|
+
metadata,
|
|
120
|
+
createdAt: /* @__PURE__ */ new Date(intent.created * 1e3),
|
|
121
|
+
updatedAt: intent.canceled_at != null ? /* @__PURE__ */ new Date(intent.canceled_at * 1e3) : /* @__PURE__ */ new Date(intent.created * 1e3)
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
toInvoice(invoice) {
|
|
125
|
+
const metadata = this.toMetadata(invoice.metadata);
|
|
126
|
+
return {
|
|
127
|
+
id: invoice.id,
|
|
128
|
+
number: invoice.number ?? void 0,
|
|
129
|
+
status: invoice.status ?? "draft",
|
|
130
|
+
amountDue: this.toMoney(invoice.amount_due ?? 0, invoice.currency),
|
|
131
|
+
amountPaid: this.toMoney(invoice.amount_paid ?? 0, invoice.currency),
|
|
132
|
+
customerId: typeof invoice.customer === "string" ? invoice.customer : invoice.customer?.id,
|
|
133
|
+
dueDate: invoice.due_date ? /* @__PURE__ */ new Date(invoice.due_date * 1e3) : void 0,
|
|
134
|
+
hostedInvoiceUrl: invoice.hosted_invoice_url ?? void 0,
|
|
135
|
+
metadata,
|
|
136
|
+
createdAt: invoice.created ? /* @__PURE__ */ new Date(invoice.created * 1e3) : void 0,
|
|
137
|
+
updatedAt: invoice.status_transitions?.finalized_at ? /* @__PURE__ */ new Date(invoice.status_transitions.finalized_at * 1e3) : void 0
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
toMoney(amount, currency) {
|
|
141
|
+
return {
|
|
142
|
+
amount,
|
|
143
|
+
currency: currency?.toUpperCase() ?? "USD"
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
toMetadata(metadata) {
|
|
147
|
+
if (!metadata) return void 0;
|
|
148
|
+
const entries = Object.entries(metadata).filter((entry) => typeof entry[1] === "string");
|
|
149
|
+
if (entries.length === 0) return void 0;
|
|
150
|
+
return Object.fromEntries(entries);
|
|
151
|
+
}
|
|
152
|
+
mergeMetadata(base, extras) {
|
|
153
|
+
const filteredExtras = Object.entries(extras).filter((entry) => typeof entry[1] === "string");
|
|
154
|
+
if (!base && filteredExtras.length === 0) return;
|
|
155
|
+
return {
|
|
156
|
+
...base ?? {},
|
|
157
|
+
...Object.fromEntries(filteredExtras)
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
function mapRefundReason(reason) {
|
|
162
|
+
if (!reason) return void 0;
|
|
163
|
+
return [
|
|
164
|
+
"duplicate",
|
|
165
|
+
"fraudulent",
|
|
166
|
+
"requested_by_customer"
|
|
167
|
+
].includes(reason) ? reason : void 0;
|
|
168
|
+
}
|
|
169
|
+
function mapPaymentIntentStatus(status) {
|
|
170
|
+
switch (status) {
|
|
171
|
+
case "requires_payment_method": return "requires_payment_method";
|
|
172
|
+
case "requires_confirmation": return "requires_confirmation";
|
|
173
|
+
case "requires_action":
|
|
174
|
+
case "requires_capture": return "requires_action";
|
|
175
|
+
case "processing": return "processing";
|
|
176
|
+
case "succeeded": return "succeeded";
|
|
177
|
+
case "canceled": return "canceled";
|
|
178
|
+
default: return "requires_payment_method";
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
function mapRefundStatus(status) {
|
|
182
|
+
switch (status) {
|
|
183
|
+
case "pending":
|
|
184
|
+
case "succeeded":
|
|
185
|
+
case "failed":
|
|
186
|
+
case "canceled": return status;
|
|
187
|
+
default: return "pending";
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
function mapChargeStatus(status) {
|
|
191
|
+
switch (status) {
|
|
192
|
+
case "pending":
|
|
193
|
+
case "processing": return "pending";
|
|
194
|
+
case "succeeded": return "succeeded";
|
|
195
|
+
case "failed":
|
|
196
|
+
case "canceled": return "failed";
|
|
197
|
+
default: return "pending";
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
//#endregion
|
|
202
|
+
export { StripePaymentsProvider };
|
|
203
|
+
//# sourceMappingURL=stripe-payments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stripe-payments.js","names":["API_VERSION: Stripe.LatestApiVersion"],"sources":["../../src/impls/stripe-payments.ts"],"sourcesContent":["import Stripe from 'stripe';\n\nimport type {\n CapturePaymentInput,\n CreateCustomerInput,\n CreatePaymentIntentInput,\n ListInvoicesQuery,\n ListTransactionsQuery,\n Money,\n PaymentCustomer,\n PaymentIntent,\n PaymentInvoice,\n PaymentRefund,\n PaymentTransaction,\n PaymentsProvider,\n RefundPaymentInput,\n} from '../payments';\n\nexport interface StripePaymentsProviderOptions {\n apiKey: string;\n stripe?: Stripe;\n}\n\nconst API_VERSION: Stripe.LatestApiVersion = '2025-10-29.clover';\n\nexport class StripePaymentsProvider implements PaymentsProvider {\n private readonly stripe: Stripe;\n\n constructor(options: StripePaymentsProviderOptions) {\n this.stripe =\n options.stripe ??\n new Stripe(options.apiKey, {\n apiVersion: API_VERSION,\n });\n }\n\n async createCustomer(input: CreateCustomerInput): Promise<PaymentCustomer> {\n const customer = await this.stripe.customers.create({\n email: input.email,\n name: input.name,\n description: input.description,\n metadata: input.metadata,\n });\n return this.toCustomer(customer);\n }\n\n async getCustomer(customerId: string): Promise<PaymentCustomer | null> {\n const customer = await this.stripe.customers.retrieve(customerId);\n if (customer.deleted) return null;\n return this.toCustomer(customer);\n }\n\n async createPaymentIntent(\n input: CreatePaymentIntentInput\n ): Promise<PaymentIntent> {\n const intent = await this.stripe.paymentIntents.create({\n amount: input.amount.amount,\n currency: input.amount.currency,\n customer: input.customerId,\n description: input.description,\n capture_method: input.captureMethod ?? 'automatic',\n confirmation_method: input.confirmationMethod ?? 'automatic',\n automatic_payment_methods: { enabled: true },\n metadata: input.metadata,\n return_url: input.returnUrl,\n statement_descriptor: input.statementDescriptor,\n });\n return this.toPaymentIntent(intent);\n }\n\n async capturePayment(\n paymentIntentId: string,\n input?: CapturePaymentInput\n ): Promise<PaymentIntent> {\n const intent = await this.stripe.paymentIntents.capture(\n paymentIntentId,\n input?.amount ? { amount_to_capture: input.amount.amount } : undefined\n );\n return this.toPaymentIntent(intent);\n }\n\n async cancelPaymentIntent(paymentIntentId: string): Promise<PaymentIntent> {\n const intent = await this.stripe.paymentIntents.cancel(paymentIntentId);\n return this.toPaymentIntent(intent);\n }\n\n async refundPayment(input: RefundPaymentInput): Promise<PaymentRefund> {\n const refund = await this.stripe.refunds.create({\n payment_intent: input.paymentIntentId,\n amount: input.amount?.amount,\n reason: mapRefundReason(input.reason),\n metadata: input.metadata,\n });\n const paymentIntentId =\n typeof refund.payment_intent === 'string'\n ? refund.payment_intent\n : (refund.payment_intent?.id ?? '');\n return {\n id: refund.id,\n paymentIntentId,\n amount: {\n amount: refund.amount ?? 0,\n currency: refund.currency?.toUpperCase() ?? 'USD',\n },\n status: mapRefundStatus(refund.status),\n reason: refund.reason ?? undefined,\n metadata: this.toMetadata(refund.metadata),\n createdAt: refund.created ? new Date(refund.created * 1000) : undefined,\n };\n }\n\n async listInvoices(query?: ListInvoicesQuery): Promise<PaymentInvoice[]> {\n const requestedStatus = query?.status?.[0];\n const stripeStatus =\n requestedStatus && requestedStatus !== 'deleted'\n ? requestedStatus\n : undefined;\n const response = await this.stripe.invoices.list({\n customer: query?.customerId,\n status: stripeStatus,\n limit: query?.limit,\n starting_after: query?.startingAfter,\n });\n return response.data.map((invoice) => this.toInvoice(invoice));\n }\n\n async listTransactions(\n query?: ListTransactionsQuery\n ): Promise<PaymentTransaction[]> {\n const response = await this.stripe.charges.list({\n customer: query?.customerId,\n payment_intent: query?.paymentIntentId,\n limit: query?.limit,\n starting_after: query?.startingAfter,\n });\n return response.data.map((charge) => ({\n id: charge.id,\n paymentIntentId:\n typeof charge.payment_intent === 'string'\n ? charge.payment_intent\n : charge.payment_intent?.id,\n amount: {\n amount: charge.amount,\n currency: charge.currency?.toUpperCase() ?? 'USD',\n },\n type: 'capture',\n status: mapChargeStatus(charge.status),\n description: charge.description ?? undefined,\n createdAt: new Date(charge.created * 1000),\n metadata: this.mergeMetadata(this.toMetadata(charge.metadata), {\n balanceTransaction:\n typeof charge.balance_transaction === 'string'\n ? charge.balance_transaction\n : undefined,\n }),\n }));\n }\n\n private toCustomer(customer: Stripe.Customer): PaymentCustomer {\n const metadata = this.toMetadata(customer.metadata);\n const updatedAtValue = metadata?.updatedAt;\n return {\n id: customer.id,\n email: customer.email ?? undefined,\n name: customer.name ?? undefined,\n metadata,\n createdAt: customer.created\n ? new Date(customer.created * 1000)\n : undefined,\n updatedAt: updatedAtValue ? new Date(updatedAtValue) : undefined,\n };\n }\n\n private toPaymentIntent(intent: Stripe.PaymentIntent): PaymentIntent {\n const metadata = this.toMetadata(intent.metadata);\n return {\n id: intent.id,\n amount: this.toMoney(\n intent.amount_received ?? intent.amount ?? 0,\n intent.currency\n ),\n status: mapPaymentIntentStatus(intent.status),\n customerId:\n typeof intent.customer === 'string'\n ? intent.customer\n : intent.customer?.id,\n description: intent.description ?? undefined,\n clientSecret: intent.client_secret ?? undefined,\n metadata,\n createdAt: new Date(intent.created * 1000),\n updatedAt:\n intent.canceled_at != null\n ? new Date(intent.canceled_at * 1000)\n : new Date(intent.created * 1000),\n };\n }\n\n private toInvoice(invoice: Stripe.Invoice): PaymentInvoice {\n const metadata = this.toMetadata(invoice.metadata);\n return {\n id: invoice.id,\n number: invoice.number ?? undefined,\n status: (invoice.status as PaymentInvoice['status']) ?? 'draft',\n amountDue: this.toMoney(invoice.amount_due ?? 0, invoice.currency),\n amountPaid: this.toMoney(invoice.amount_paid ?? 0, invoice.currency),\n customerId:\n typeof invoice.customer === 'string'\n ? invoice.customer\n : invoice.customer?.id,\n dueDate: invoice.due_date ? new Date(invoice.due_date * 1000) : undefined,\n hostedInvoiceUrl: invoice.hosted_invoice_url ?? undefined,\n metadata,\n createdAt: invoice.created ? new Date(invoice.created * 1000) : undefined,\n updatedAt: invoice.status_transitions?.finalized_at\n ? new Date(invoice.status_transitions.finalized_at * 1000)\n : undefined,\n };\n }\n\n private toMoney(amount: number, currency?: string | null): Money {\n return {\n amount,\n currency: currency?.toUpperCase() ?? 'USD',\n };\n }\n\n private toMetadata(\n metadata: Stripe.Metadata | Stripe.Metadata | null | undefined\n ): Record<string, string> | undefined {\n if (!metadata) return undefined;\n const entries = Object.entries(metadata).filter(\n (entry): entry is [string, string] => typeof entry[1] === 'string'\n );\n if (entries.length === 0) return undefined;\n return Object.fromEntries(entries);\n }\n\n private mergeMetadata(\n base: Record<string, string> | undefined,\n extras: Record<string, string | undefined>\n ): Record<string, string> | undefined {\n const filteredExtras = Object.entries(extras).filter(\n (entry): entry is [string, string] => typeof entry[1] === 'string'\n );\n if (!base && filteredExtras.length === 0) {\n return undefined;\n }\n return {\n ...(base ?? {}),\n ...Object.fromEntries(filteredExtras),\n };\n }\n}\n\nfunction mapRefundReason(\n reason?: string\n): Stripe.RefundCreateParams.Reason | undefined {\n if (!reason) return undefined;\n const allowed: Stripe.RefundCreateParams.Reason[] = [\n 'duplicate',\n 'fraudulent',\n 'requested_by_customer',\n ];\n return allowed.includes(reason as Stripe.RefundCreateParams.Reason)\n ? (reason as Stripe.RefundCreateParams.Reason)\n : undefined;\n}\n\nfunction mapPaymentIntentStatus(\n status: string | null | undefined\n): PaymentIntent['status'] {\n switch (status) {\n case 'requires_payment_method':\n return 'requires_payment_method';\n case 'requires_confirmation':\n return 'requires_confirmation';\n case 'requires_action':\n case 'requires_capture':\n return 'requires_action';\n case 'processing':\n return 'processing';\n case 'succeeded':\n return 'succeeded';\n case 'canceled':\n return 'canceled';\n default:\n return 'requires_payment_method';\n }\n}\n\nfunction mapRefundStatus(\n status: string | null | undefined\n): PaymentRefund['status'] {\n switch (status) {\n case 'pending':\n case 'succeeded':\n case 'failed':\n case 'canceled':\n return status;\n default:\n return 'pending';\n }\n}\n\nfunction mapChargeStatus(\n status: string | null | undefined\n): PaymentTransaction['status'] {\n switch (status) {\n case 'pending':\n case 'processing':\n return 'pending';\n case 'succeeded':\n return 'succeeded';\n case 'failed':\n case 'canceled':\n return 'failed';\n default:\n return 'pending';\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { sms_d_exports } from "../sms.js";
|
|
2
|
+
import Twilio from "twilio";
|
|
3
|
+
|
|
4
|
+
//#region src/impls/twilio-sms.d.ts
|
|
5
|
+
type TwilioClient = ReturnType<typeof Twilio>;
|
|
6
|
+
interface TwilioSmsProviderOptions {
|
|
7
|
+
accountSid: string;
|
|
8
|
+
authToken: string;
|
|
9
|
+
fromNumber?: string;
|
|
10
|
+
client?: TwilioClient;
|
|
11
|
+
}
|
|
12
|
+
declare class TwilioSmsProvider implements sms_d_exports.SmsProvider {
|
|
13
|
+
private readonly client;
|
|
14
|
+
private readonly fromNumber?;
|
|
15
|
+
constructor(options: TwilioSmsProviderOptions);
|
|
16
|
+
sendSms(input: sms_d_exports.SendSmsInput): Promise<sms_d_exports.SmsMessage>;
|
|
17
|
+
getDeliveryStatus(messageId: string): Promise<sms_d_exports.SmsDeliveryStatus>;
|
|
18
|
+
}
|
|
19
|
+
//#endregion
|
|
20
|
+
export { TwilioSmsProvider, TwilioSmsProviderOptions };
|
|
21
|
+
//# sourceMappingURL=twilio-sms.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"twilio-sms.d.ts","names":[],"sources":["../../src/impls/twilio-sms.ts"],"sourcesContent":[],"mappings":";;;;KASK,YAAA,GAAe,kBAAkB;UAErB,wBAAA;EAFZ,UAAA,EAAA,MAAY;EAEA,SAAA,EAAA,MAAA;EAOJ,UAAA,CAAA,EAAA,MAAA;EAIU,MAAA,CAAA,EAPZ,YAOY;;AAMuB,cAVjC,iBAAA,YAA6B,aAAA,CAAA,WAUI,CAAA;EAAR,iBAAA,MAAA;EAyBgB,iBAAA,UAAA;EAAR,WAAA,CAAA,OAAA,EA/BvB,wBA+BuB;EAnCJ,OAAA,CAAA,KAAA,EAUnB,aAAA,CAAA,YAVmB,CAAA,EAUJ,OAVI,CAUI,aAAA,CAAA,UAVJ,CAAA;EAAW,iBAAA,CAAA,SAAA,EAAA,MAAA,CAAA,EAmCP,OAnCO,CAmCC,aAAA,CAAA,iBAnCD,CAAA"}
|