@apicity/anthropic 0.1.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,108 @@
1
+ // Auto-generated by `pnpm run gen:examples` — do not edit by hand.
2
+ // Source: tests/recordings/<provider>_*/<test>_*/recording.har
3
+ //
4
+ // Each entry is the green-path payload for one endpoint, mined from a real
5
+ // integration-test recording. `attachExamples` walks the provider tree and
6
+ // hangs the matching entry off each endpoint function as `.example`.
7
+ const EXAMPLES = {
8
+ "POST v1.messages": {
9
+ "source": "anthropic/messages-code-review",
10
+ "payload": {
11
+ "model": "claude-sonnet-4-6",
12
+ "max_tokens": 256,
13
+ "system": "You are a senior TypeScript reviewer. Reply with exactly one line in the form: 'BUG: <one-sentence summary>'. No preamble, no code, no Markdown.",
14
+ "messages": [
15
+ {
16
+ "role": "user",
17
+ "content": "Review this:\n```ts\nfunction firstNonEmpty(xs: string[]): string {\n for (let i = 0; i <= xs.length; i++) {\n if (xs[i]) return xs[i];\n }\n return '';\n}\n```"
18
+ },
19
+ {
20
+ "role": "assistant",
21
+ "content": "BUG: The loop condition `i <= xs.length` reads one past the last index, so `xs[xs.length]` is dereferenced as undefined."
22
+ },
23
+ {
24
+ "role": "user",
25
+ "content": "Now review this one the same way:\n```ts\nasync function readA… <truncated 346 chars>"
26
+ }
27
+ ]
28
+ }
29
+ }
30
+ };
31
+ export default EXAMPLES;
32
+ // Walks each "<METHOD> <dotPath>" key onto the provider's tree. Tries the
33
+ // standard `provider.<method>.<dotPath>` shape first, then a few fallbacks
34
+ // to cover providers with non-standard layouts (fal's `.run.` namespace,
35
+ // kie's sub-providers, `free`'s flat root). Returns the same provider for
36
+ // drop-in use as `return attachExamples({ ... });`.
37
+ export function attachExamples(provider) {
38
+ const root = provider;
39
+ const HTTP_KEYS = new Set(["post", "get", "put", "delete", "patch", "head"]);
40
+ for (const [key, example] of Object.entries(EXAMPLES)) {
41
+ const sp = key.indexOf(" ");
42
+ if (sp < 0)
43
+ continue;
44
+ const method = key.slice(0, sp).toLowerCase();
45
+ const segs = key.slice(sp + 1).split(".");
46
+ const candidates = [
47
+ root[method],
48
+ root[method]?.run,
49
+ root,
50
+ ];
51
+ if (segs.length > 1) {
52
+ const sub = root[segs[0]];
53
+ if (sub && typeof sub === "object") {
54
+ const subMethod = sub[method];
55
+ if (subMethod)
56
+ candidates.push({ __nested: subMethod, __segs: segs.slice(1) });
57
+ }
58
+ }
59
+ let attached = false;
60
+ for (const c of candidates) {
61
+ const fn = walkToFn(c, segs);
62
+ if (fn) {
63
+ Object.assign(fn, { example });
64
+ attached = true;
65
+ break;
66
+ }
67
+ }
68
+ if (attached)
69
+ continue;
70
+ for (const k of Object.keys(root)) {
71
+ if (HTTP_KEYS.has(k))
72
+ continue;
73
+ if (!segs.includes(k))
74
+ continue;
75
+ const sub = root[k];
76
+ if (!sub || typeof sub !== "object")
77
+ continue;
78
+ const subMethod = sub[method];
79
+ if (!subMethod)
80
+ continue;
81
+ const fn = walkToFn(subMethod, segs);
82
+ if (fn) {
83
+ Object.assign(fn, { example });
84
+ break;
85
+ }
86
+ }
87
+ }
88
+ return provider;
89
+ }
90
+ function walkToFn(start, segs) {
91
+ if (start && typeof start === "object" && "__nested" in start) {
92
+ const wrapper = start;
93
+ return walkToFn(wrapper.__nested, wrapper.__segs);
94
+ }
95
+ let cur = start;
96
+ for (const seg of segs) {
97
+ if (cur === null || cur === undefined)
98
+ return null;
99
+ const t = typeof cur;
100
+ if (t !== "object" && t !== "function")
101
+ return null;
102
+ cur = cur[seg];
103
+ }
104
+ return typeof cur === "function"
105
+ ? cur
106
+ : null;
107
+ }
108
+ //# sourceMappingURL=example.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"example.js","sourceRoot":"","sources":["../../src/example.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ export { anthropic } from "./anthropic";
2
+ export { AnthropicError } from "./types";
3
+ export { withRetry, withFallback, withRateLimit, createRateLimiter, } from "./middleware";
4
+ export type { RetryOptions, FallbackOptions, RateLimiterOptions, RateLimiter, RateLimitOptions, } from "./middleware";
5
+ export { sseToIterable, parseAnthropicStream } from "./sse";
6
+ export type { SSEEvent } from "./sse";
7
+ export type { AnthropicOptions, AnthropicListParams, AnthropicListResponse, AnthropicCacheControl, AnthropicTextBlock, AnthropicImageSource, AnthropicImageBlock, AnthropicDocumentSource, AnthropicDocumentBlock, AnthropicToolUseBlock, AnthropicToolResultBlock, AnthropicThinkingBlock, AnthropicRedactedThinkingBlock, AnthropicServerToolUseBlock, AnthropicServerToolResultBlock, AnthropicFileBlock, AnthropicContentBlock, AnthropicMessage, AnthropicToolInputSchema, AnthropicCustomTool, AnthropicBashTool, AnthropicTextEditorTool, AnthropicWebSearchTool, AnthropicCodeExecutionTool, AnthropicTool, AnthropicToolChoice, AnthropicThinkingConfig, AnthropicMetadata, AnthropicMessageRequest, AnthropicUsage, AnthropicMessageResponse, AnthropicStreamMessageStart, AnthropicStreamContentBlockStart, AnthropicStreamTextDelta, AnthropicStreamInputJsonDelta, AnthropicStreamThinkingDelta, AnthropicStreamSignatureDelta, AnthropicStreamDelta, AnthropicStreamContentBlockDelta, AnthropicStreamContentBlockStop, AnthropicStreamMessageDelta, AnthropicStreamMessageStop, AnthropicStreamPing, AnthropicStreamError, AnthropicStreamEvent, AnthropicCountTokensRequest, AnthropicCountTokensResponse, AnthropicModelCapabilities, AnthropicModel, AnthropicModelListResponse, AnthropicBatchRequest, AnthropicBatchCreateRequest, AnthropicBatchRequestCounts, AnthropicBatch, AnthropicBatchListResponse, AnthropicBatchResultSuccess, AnthropicBatchResultErrored, AnthropicBatchResultCanceled, AnthropicBatchResultExpired, AnthropicBatchResultType, AnthropicBatchResultEntry, AnthropicBatchDeleteResponse, AnthropicFile, AnthropicFileListResponse, AnthropicFileDeleteResponse, AnthropicFileUploadRequest, AnthropicSkillFile, AnthropicSkill, AnthropicSkillsListParams, AnthropicSkillsListResponse, AnthropicSkillDeleteResponse, AnthropicSkillsCreateRequest, AnthropicSkillVersion, AnthropicSkillVersionsListParams, AnthropicSkillVersionsListResponse, AnthropicSkillVersionDeleteResponse, AnthropicSkillVersionsCreateRequest, AnthropicMessagesMethod, AnthropicCountTokensMethod, AnthropicBatchesMethod, AnthropicModelsNamespace, AnthropicFilesNamespace, AnthropicFilesUploadMethod, AnthropicSkillsCreateMethod, AnthropicSkillVersionsCreateMethod, AnthropicSkillVersionsNamespace, AnthropicSkillsNamespace, AnthropicV1Namespace, AnthropicProvider, } from "./types";
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAGxC,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAGzC,OAAO,EACL,SAAS,EACT,YAAY,EACZ,aAAa,EACb,iBAAiB,GAClB,MAAM,cAAc,CAAC;AACtB,YAAY,EACV,YAAY,EACZ,eAAe,EACf,kBAAkB,EAClB,WAAW,EACX,gBAAgB,GACjB,MAAM,cAAc,CAAC;AAGtB,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAC5D,YAAY,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAGtC,YAAY,EACV,gBAAgB,EAChB,mBAAmB,EACnB,qBAAqB,EACrB,qBAAqB,EACrB,kBAAkB,EAClB,oBAAoB,EACpB,mBAAmB,EACnB,uBAAuB,EACvB,sBAAsB,EACtB,qBAAqB,EACrB,wBAAwB,EACxB,sBAAsB,EACtB,8BAA8B,EAC9B,2BAA2B,EAC3B,8BAA8B,EAC9B,kBAAkB,EAClB,qBAAqB,EACrB,gBAAgB,EAChB,wBAAwB,EACxB,mBAAmB,EACnB,iBAAiB,EACjB,uBAAuB,EACvB,sBAAsB,EACtB,0BAA0B,EAC1B,aAAa,EACb,mBAAmB,EACnB,uBAAuB,EACvB,iBAAiB,EACjB,uBAAuB,EACvB,cAAc,EACd,wBAAwB,EACxB,2BAA2B,EAC3B,gCAAgC,EAChC,wBAAwB,EACxB,6BAA6B,EAC7B,4BAA4B,EAC5B,6BAA6B,EAC7B,oBAAoB,EACpB,gCAAgC,EAChC,+BAA+B,EAC/B,2BAA2B,EAC3B,0BAA0B,EAC1B,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACpB,2BAA2B,EAC3B,4BAA4B,EAC5B,0BAA0B,EAC1B,cAAc,EACd,0BAA0B,EAC1B,qBAAqB,EACrB,2BAA2B,EAC3B,2BAA2B,EAC3B,cAAc,EACd,0BAA0B,EAC1B,2BAA2B,EAC3B,2BAA2B,EAC3B,4BAA4B,EAC5B,2BAA2B,EAC3B,wBAAwB,EACxB,yBAAyB,EACzB,4BAA4B,EAC5B,aAAa,EACb,yBAAyB,EACzB,2BAA2B,EAC3B,0BAA0B,EAC1B,kBAAkB,EAClB,cAAc,EACd,yBAAyB,EACzB,2BAA2B,EAC3B,4BAA4B,EAC5B,4BAA4B,EAC5B,qBAAqB,EACrB,gCAAgC,EAChC,kCAAkC,EAClC,mCAAmC,EACnC,mCAAmC,EACnC,uBAAuB,EACvB,0BAA0B,EAC1B,sBAAsB,EACtB,wBAAwB,EACxB,uBAAuB,EACvB,0BAA0B,EAC1B,2BAA2B,EAC3B,kCAAkC,EAClC,+BAA+B,EAC/B,wBAAwB,EACxB,oBAAoB,EACpB,iBAAiB,GAClB,MAAM,SAAS,CAAC"}
@@ -0,0 +1,9 @@
1
+ // Export main provider function
2
+ export { anthropic } from "./anthropic.js";
3
+ // Export error class
4
+ export { AnthropicError } from "./types.js";
5
+ // Export middleware
6
+ export { withRetry, withFallback, withRateLimit, createRateLimiter, } from "./middleware.js";
7
+ // Export SSE utilities
8
+ export { sseToIterable, parseAnthropicStream } from "./sse.js";
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,qBAAqB;AACrB,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEzC,oBAAoB;AACpB,OAAO,EACL,SAAS,EACT,YAAY,EACZ,aAAa,EACb,iBAAiB,GAClB,MAAM,cAAc,CAAC;AAStB,uBAAuB;AACvB,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC"}
@@ -0,0 +1,34 @@
1
+ export interface RetryOptions {
2
+ retries?: number;
3
+ baseMs?: number;
4
+ factor?: number;
5
+ jitter?: boolean;
6
+ }
7
+ export interface FallbackOptions {
8
+ onFallback?: (error: unknown, index: number) => void;
9
+ }
10
+ export declare function withRetry<TReq, TRes>(fn: (req: TReq, signal?: AbortSignal) => Promise<TRes>, opts?: RetryOptions): (req: TReq, signal?: AbortSignal) => Promise<TRes>;
11
+ export declare function withFallback<TReq, TRes>(fns: Array<(req: TReq, signal?: AbortSignal) => Promise<TRes>>, opts?: FallbackOptions): (req: TReq, signal?: AbortSignal) => Promise<TRes>;
12
+ export interface RateLimiterOptions {
13
+ /** Maximum requests per minute (sliding window). Default: Infinity */
14
+ rpm?: number;
15
+ /** Maximum concurrent in-flight requests. Default: Infinity */
16
+ concurrent?: number;
17
+ /** Maximum time (ms) a request will wait in queue. Default: 60000 */
18
+ maxQueueMs?: number;
19
+ }
20
+ export interface RateLimiter {
21
+ /** Current number of in-flight requests */
22
+ readonly active: number;
23
+ /** Current number of queued requests waiting for a slot */
24
+ readonly queued: number;
25
+ /** Reject all queued requests and clean up timers */
26
+ dispose(): void;
27
+ }
28
+ export interface RateLimitOptions {
29
+ /** Override maxQueueMs for this particular wrapped function */
30
+ maxQueueMs?: number;
31
+ }
32
+ export declare function createRateLimiter(opts?: RateLimiterOptions): RateLimiter;
33
+ export declare function withRateLimit<TReq, TRes>(fn: (req: TReq, signal?: AbortSignal) => Promise<TRes>, limiter: RateLimiter, opts?: RateLimitOptions): (req: TReq, signal?: AbortSignal) => Promise<TRes>;
34
+ //# sourceMappingURL=middleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACtD;AA+BD,wBAAgB,SAAS,CAAC,IAAI,EAAE,IAAI,EAClC,EAAE,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,EACtD,IAAI,GAAE,YAAiB,GACtB,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CA2BpD;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,IAAI,EACrC,GAAG,EAAE,KAAK,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC,EAC9D,IAAI,GAAE,eAAoB,GACzB,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAiBpD;AAED,MAAM,WAAW,kBAAkB;IACjC,sEAAsE;IACtE,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,+DAA+D;IAC/D,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,qEAAqE;IACrE,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,WAAW;IAC1B,2CAA2C;IAC3C,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,2DAA2D;IAC3D,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,qDAAqD;IACrD,OAAO,IAAI,IAAI,CAAC;CACjB;AAED,MAAM,WAAW,gBAAgB;IAC/B,+DAA+D;IAC/D,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAkED,wBAAgB,iBAAiB,CAAC,IAAI,GAAE,kBAAuB,GAAG,WAAW,CAqH5E;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,IAAI,EACtC,EAAE,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,EACtD,OAAO,EAAE,WAAW,EACpB,IAAI,GAAE,gBAAqB,GAC1B,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,CAcpD"}
@@ -0,0 +1,219 @@
1
+ function isTransientError(e) {
2
+ const status = (typeof e === "object" &&
3
+ e !== null &&
4
+ "status" in e &&
5
+ typeof e.status === "number" &&
6
+ e.status) ||
7
+ (typeof e === "object" &&
8
+ e !== null &&
9
+ "statusCode" in e &&
10
+ typeof e.statusCode === "number" &&
11
+ e.statusCode) ||
12
+ (typeof e === "object" &&
13
+ e !== null &&
14
+ "code" in e &&
15
+ typeof e.code === "number" &&
16
+ e.code) ||
17
+ null;
18
+ if (typeof status === "number") {
19
+ return status === 429 || status === 529 || status >= 500;
20
+ }
21
+ return true;
22
+ }
23
+ function sleep(ms) {
24
+ return new Promise((resolve) => setTimeout(resolve, ms));
25
+ }
26
+ export function withRetry(fn, opts = {}) {
27
+ const retries = opts.retries ?? 2;
28
+ const baseMs = opts.baseMs ?? 300;
29
+ const factor = opts.factor ?? 2;
30
+ const jitter = opts.jitter ?? true;
31
+ return async (req, signal) => {
32
+ let attempt = 0;
33
+ while (true) {
34
+ try {
35
+ return await fn(req, signal);
36
+ }
37
+ catch (e) {
38
+ attempt += 1;
39
+ if (attempt > retries || !isTransientError(e) || signal?.aborted) {
40
+ throw e;
41
+ }
42
+ const delay = baseMs * Math.pow(factor, attempt - 1);
43
+ const wait = jitter
44
+ ? Math.floor(delay * (0.8 + Math.random() * 0.4))
45
+ : delay;
46
+ await sleep(wait);
47
+ }
48
+ }
49
+ };
50
+ }
51
+ export function withFallback(fns, opts = {}) {
52
+ if (fns.length === 0) {
53
+ throw new Error("withFallback requires at least one function");
54
+ }
55
+ return async (req, signal) => {
56
+ let lastError;
57
+ for (let i = 0; i < fns.length; i++) {
58
+ try {
59
+ return await fns[i](req, signal);
60
+ }
61
+ catch (e) {
62
+ lastError = e;
63
+ opts.onFallback?.(e, i);
64
+ }
65
+ }
66
+ throw lastError;
67
+ };
68
+ }
69
+ function pruneTimestamps(state, now) {
70
+ const cutoff = now - 60_000;
71
+ while (state.timestamps.length > 0 && state.timestamps[0] <= cutoff) {
72
+ state.timestamps.shift();
73
+ }
74
+ }
75
+ function tryDrain(state) {
76
+ const now = Date.now();
77
+ pruneTimestamps(state, now);
78
+ while (state.queue.length > 0) {
79
+ if (state.timestamps.length >= state.rpm)
80
+ break;
81
+ if (state.activeCount >= state.concurrent)
82
+ break;
83
+ const entry = state.queue.shift();
84
+ clearTimeout(entry.timeoutId);
85
+ if (entry.signal && entry.abortHandler) {
86
+ entry.signal.removeEventListener("abort", entry.abortHandler);
87
+ }
88
+ state.timestamps.push(now);
89
+ state.activeCount++;
90
+ entry.resolve();
91
+ }
92
+ if (state.drainTimerId !== null) {
93
+ clearTimeout(state.drainTimerId);
94
+ state.drainTimerId = null;
95
+ }
96
+ if (state.queue.length > 0 &&
97
+ state.timestamps.length >= state.rpm &&
98
+ state.timestamps.length > 0) {
99
+ const oldestExpiry = state.timestamps[0] + 60_000;
100
+ const delay = Math.max(1, oldestExpiry - now);
101
+ state.drainTimerId = setTimeout(() => {
102
+ state.drainTimerId = null;
103
+ tryDrain(state);
104
+ }, delay);
105
+ }
106
+ }
107
+ export function createRateLimiter(opts = {}) {
108
+ const state = {
109
+ rpm: opts.rpm ?? Infinity,
110
+ concurrent: opts.concurrent ?? Infinity,
111
+ maxQueueMs: opts.maxQueueMs ?? 60_000,
112
+ timestamps: [],
113
+ activeCount: 0,
114
+ queue: [],
115
+ drainTimerId: null,
116
+ disposed: false,
117
+ };
118
+ function acquire(signal, maxQueueMs) {
119
+ if (state.disposed) {
120
+ return Promise.reject(new Error("RateLimiter is disposed"));
121
+ }
122
+ const now = Date.now();
123
+ pruneTimestamps(state, now);
124
+ if (state.timestamps.length < state.rpm &&
125
+ state.activeCount < state.concurrent) {
126
+ state.timestamps.push(now);
127
+ state.activeCount++;
128
+ return Promise.resolve();
129
+ }
130
+ if (signal?.aborted) {
131
+ return Promise.reject(new DOMException("Rate limit queue aborted", "AbortError"));
132
+ }
133
+ const queueTimeout = maxQueueMs ?? state.maxQueueMs;
134
+ return new Promise((resolve, reject) => {
135
+ const entry = {
136
+ resolve,
137
+ reject,
138
+ timeoutId: setTimeout(() => {
139
+ const idx = state.queue.indexOf(entry);
140
+ if (idx !== -1) {
141
+ state.queue.splice(idx, 1);
142
+ if (entry.signal && entry.abortHandler) {
143
+ entry.signal.removeEventListener("abort", entry.abortHandler);
144
+ }
145
+ reject(new Error(`Rate limit queue timeout after ${queueTimeout}ms`));
146
+ }
147
+ }, queueTimeout),
148
+ abortHandler: null,
149
+ signal,
150
+ };
151
+ if (signal) {
152
+ const abortHandler = () => {
153
+ const idx = state.queue.indexOf(entry);
154
+ if (idx !== -1) {
155
+ state.queue.splice(idx, 1);
156
+ clearTimeout(entry.timeoutId);
157
+ reject(new DOMException("Rate limit queue aborted", "AbortError"));
158
+ }
159
+ };
160
+ signal.addEventListener("abort", abortHandler, { once: true });
161
+ entry.abortHandler = abortHandler;
162
+ }
163
+ state.queue.push(entry);
164
+ if (state.timestamps.length >= state.rpm && state.timestamps.length > 0) {
165
+ if (state.drainTimerId === null) {
166
+ const oldestExpiry = state.timestamps[0] + 60_000;
167
+ const delay = Math.max(1, oldestExpiry - now);
168
+ state.drainTimerId = setTimeout(() => {
169
+ state.drainTimerId = null;
170
+ tryDrain(state);
171
+ }, delay);
172
+ }
173
+ }
174
+ });
175
+ }
176
+ function release() {
177
+ state.activeCount--;
178
+ tryDrain(state);
179
+ }
180
+ const limiter = {
181
+ get active() {
182
+ return state.activeCount;
183
+ },
184
+ get queued() {
185
+ return state.queue.length;
186
+ },
187
+ dispose() {
188
+ state.disposed = true;
189
+ if (state.drainTimerId !== null) {
190
+ clearTimeout(state.drainTimerId);
191
+ state.drainTimerId = null;
192
+ }
193
+ for (const entry of state.queue) {
194
+ clearTimeout(entry.timeoutId);
195
+ if (entry.signal && entry.abortHandler) {
196
+ entry.signal.removeEventListener("abort", entry.abortHandler);
197
+ }
198
+ entry.reject(new Error("RateLimiter disposed"));
199
+ }
200
+ state.queue.length = 0;
201
+ },
202
+ _acquire: acquire,
203
+ _release: release,
204
+ };
205
+ return limiter;
206
+ }
207
+ export function withRateLimit(fn, limiter, opts = {}) {
208
+ const internal = limiter;
209
+ return async (req, signal) => {
210
+ await internal._acquire(signal, opts.maxQueueMs);
211
+ try {
212
+ return await fn(req, signal);
213
+ }
214
+ finally {
215
+ internal._release();
216
+ }
217
+ };
218
+ }
219
+ //# sourceMappingURL=middleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { AnthropicStreamEvent } from "./types";
2
+ export interface SSEEvent {
3
+ event: string;
4
+ data: string;
5
+ }
6
+ export declare function sseToIterable(res: Response): AsyncIterable<SSEEvent>;
7
+ export declare function parseAnthropicStream(res: Response): AsyncIterable<AnthropicStreamEvent>;
8
+ //# sourceMappingURL=sse.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sse.d.ts","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAEpD,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,wBAAuB,aAAa,CAAC,GAAG,EAAE,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC,CAsD3E;AAED,wBAAuB,oBAAoB,CACzC,GAAG,EAAE,QAAQ,GACZ,aAAa,CAAC,oBAAoB,CAAC,CASrC"}
@@ -0,0 +1,64 @@
1
+ export async function* sseToIterable(res) {
2
+ if (!res.body)
3
+ return;
4
+ const reader = res.body.getReader();
5
+ const decoder = new TextDecoder();
6
+ let buffer = "";
7
+ while (true) {
8
+ const { value, done } = await reader.read();
9
+ if (done)
10
+ break;
11
+ buffer += decoder.decode(value, { stream: true });
12
+ const parts = buffer.split(/\r?\n\r?\n/);
13
+ for (let i = 0; i < parts.length - 1; i++) {
14
+ const chunk = parts[i];
15
+ const lines = chunk.split(/\r?\n/);
16
+ let event = "message";
17
+ let data = "";
18
+ for (const line of lines) {
19
+ const trimmed = line.trimStart();
20
+ if (trimmed.startsWith("event:")) {
21
+ event = trimmed.slice(6).trim();
22
+ }
23
+ else if (trimmed.startsWith("data:")) {
24
+ data = trimmed.slice(5).trim();
25
+ }
26
+ }
27
+ if (data) {
28
+ yield { event, data };
29
+ }
30
+ }
31
+ buffer = parts[parts.length - 1];
32
+ }
33
+ const trailing = buffer.trim();
34
+ if (trailing.length) {
35
+ const lines = trailing.split(/\r?\n/);
36
+ let event = "message";
37
+ let data = "";
38
+ for (const line of lines) {
39
+ const trimmed = line.trimStart();
40
+ if (trimmed.startsWith("event:")) {
41
+ event = trimmed.slice(6).trim();
42
+ }
43
+ else if (trimmed.startsWith("data:")) {
44
+ data = trimmed.slice(5).trim();
45
+ }
46
+ }
47
+ if (data) {
48
+ yield { event, data };
49
+ }
50
+ }
51
+ }
52
+ export async function* parseAnthropicStream(res) {
53
+ for await (const sse of sseToIterable(res)) {
54
+ if (sse.data === "[DONE]")
55
+ return;
56
+ try {
57
+ yield JSON.parse(sse.data);
58
+ }
59
+ catch {
60
+ // skip malformed events
61
+ }
62
+ }
63
+ }
64
+ //# sourceMappingURL=sse.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,KAAK,SAAS,CAAC,CAAC,aAAa,CAAC,GAAa;IAChD,IAAI,CAAC,GAAG,CAAC,IAAI;QAAE,OAAO;IACtB,MAAM,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;IACpC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;IAClC,IAAI,MAAM,GAAG,EAAE,CAAC;IAEhB,OAAO,IAAI,EAAE,CAAC;QACZ,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;QAC5C,IAAI,IAAI;YAAE,MAAM;QAEhB,MAAM,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAElD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1C,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YACvB,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACnC,IAAI,KAAK,GAAG,SAAS,CAAC;YACtB,IAAI,IAAI,GAAG,EAAE,CAAC;YAEd,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjC,IAAI,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACjC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;gBAClC,CAAC;qBAAM,IAAI,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;oBACvC,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;gBACjC,CAAC;YACH,CAAC;YAED,IAAI,IAAI,EAAE,CAAC;gBACT,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;YACxB,CAAC;QACH,CAAC;QACD,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACnC,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC;IAC/B,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,KAAK,GAAG,SAAS,CAAC;QACtB,IAAI,IAAI,GAAG,EAAE,CAAC;QAEd,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACjC,IAAI,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACjC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAClC,CAAC;iBAAM,IAAI,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;gBACvC,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACjC,CAAC;QACH,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,SAAS,CAAC,CAAC,oBAAoB,CACzC,GAAa;IAEb,IAAI,KAAK,EAAE,MAAM,GAAG,IAAI,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3C,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ;YAAE,OAAO;QAClC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAyB,CAAC;QACrD,CAAC;QAAC,MAAM,CAAC;YACP,wBAAwB;QAC1B,CAAC;IACH,CAAC;AACH,CAAC"}