@openmeter/sdk 1.0.0-alpha.4 → 1.0.0-beta.13
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/README.md +114 -46
- package/dist/clients/client.d.ts +40 -0
- package/dist/clients/client.js +104 -0
- package/dist/clients/event.d.ts +79 -0
- package/dist/clients/event.js +53 -0
- package/dist/clients/meter.d.ts +96 -0
- package/dist/clients/meter.js +64 -0
- package/dist/index.d.ts +11 -22
- package/dist/index.js +8 -25
- package/dist/next.d.ts +15 -0
- package/dist/next.js +46 -0
- package/dist/schemas/openapi.d.ts +406 -0
- package/dist/schemas/openapi.js +5 -0
- package/dist/test/agent.d.ts +2 -0
- package/dist/test/agent.js +184 -0
- package/dist/test/mocks.d.ts +12 -0
- package/dist/test/mocks.js +32 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/index.ts +14 -48
- package/next.ts +76 -0
- package/package.json +56 -55
- package/dist/generated/HttpService.d.ts +0 -14
- package/dist/generated/HttpService.js +0 -27
- package/dist/generated/core/ApiError.d.ts +0 -10
- package/dist/generated/core/ApiError.js +0 -17
- package/dist/generated/core/ApiRequestOptions.d.ts +0 -13
- package/dist/generated/core/ApiRequestOptions.js +0 -2
- package/dist/generated/core/ApiResult.d.ts +0 -7
- package/dist/generated/core/ApiResult.js +0 -2
- package/dist/generated/core/BaseHttpRequest.d.ts +0 -8
- package/dist/generated/core/BaseHttpRequest.js +0 -7
- package/dist/generated/core/CancelablePromise.d.ts +0 -20
- package/dist/generated/core/CancelablePromise.js +0 -93
- package/dist/generated/core/NodeHttpRequest.d.ts +0 -14
- package/dist/generated/core/NodeHttpRequest.js +0 -17
- package/dist/generated/core/OpenAPI.d.ts +0 -16
- package/dist/generated/core/OpenAPI.js +0 -12
- package/dist/generated/core/request.d.ts +0 -34
- package/dist/generated/core/request.js +0 -268
- package/dist/generated/index.d.ts +0 -29
- package/dist/generated/index.js +0 -22
- package/dist/generated/models/Event.d.ts +0 -49
- package/dist/generated/models/Event.js +0 -11
- package/dist/generated/models/IdOrSlug.d.ts +0 -1
- package/dist/generated/models/IdOrSlug.js +0 -2
- package/dist/generated/models/Meter.d.ts +0 -30
- package/dist/generated/models/Meter.js +0 -2
- package/dist/generated/models/MeterAggregation.d.ts +0 -10
- package/dist/generated/models/MeterAggregation.js +0 -12
- package/dist/generated/models/MeterValue.d.ts +0 -10
- package/dist/generated/models/MeterValue.js +0 -2
- package/dist/generated/models/Namespace.d.ts +0 -6
- package/dist/generated/models/Namespace.js +0 -2
- package/dist/generated/models/Problem.d.ts +0 -4
- package/dist/generated/models/Problem.js +0 -2
- package/dist/generated/models/WindowSize.d.ts +0 -5
- package/dist/generated/models/WindowSize.js +0 -7
- package/dist/generated/models/meterIdOrSlug.d.ts +0 -5
- package/dist/generated/models/meterIdOrSlug.js +0 -2
- package/dist/generated/models/namespaceParam.d.ts +0 -4
- package/dist/generated/models/namespaceParam.js +0 -2
- package/dist/generated/schemas/$Event.d.ts +0 -59
- package/dist/generated/schemas/$Event.js +0 -60
- package/dist/generated/schemas/$IdOrSlug.d.ts +0 -13
- package/dist/generated/schemas/$IdOrSlug.js +0 -14
- package/dist/generated/schemas/$Meter.d.ts +0 -44
- package/dist/generated/schemas/$Meter.js +0 -45
- package/dist/generated/schemas/$MeterAggregation.d.ts +0 -3
- package/dist/generated/schemas/$MeterAggregation.js +0 -4
- package/dist/generated/schemas/$MeterValue.d.ts +0 -26
- package/dist/generated/schemas/$MeterValue.js +0 -27
- package/dist/generated/schemas/$Namespace.d.ts +0 -9
- package/dist/generated/schemas/$Namespace.js +0 -10
- package/dist/generated/schemas/$Problem.d.ts +0 -6
- package/dist/generated/schemas/$Problem.js +0 -7
- package/dist/generated/schemas/$WindowSize.d.ts +0 -3
- package/dist/generated/schemas/$WindowSize.js +0 -4
- package/dist/generated/schemas/$meterIdOrSlug.d.ts +0 -4
- package/dist/generated/schemas/$meterIdOrSlug.js +0 -5
- package/dist/generated/schemas/$namespaceParam.d.ts +0 -5
- package/dist/generated/schemas/$namespaceParam.js +0 -6
- package/dist/generated/services/DefaultService.d.ts +0 -16
- package/dist/generated/services/DefaultService.js +0 -22
- package/dist/generated/services/EventsService.d.ts +0 -17
- package/dist/generated/services/EventsService.js +0 -29
- package/dist/generated/services/MetersService.d.ts +0 -75
- package/dist/generated/services/MetersService.js +0 -140
package/dist/index.js
CHANGED
|
@@ -1,29 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export * from './generated/index.js';
|
|
7
|
-
export class OpenMeter extends HttpService {
|
|
8
|
-
request;
|
|
9
|
-
default;
|
|
1
|
+
import { EventsClient } from './clients/event.js';
|
|
2
|
+
import { MetersClient } from './clients/meter.js';
|
|
3
|
+
export { MeterAggregation, WindowSize } from './clients/meter.js';
|
|
4
|
+
export { createOpenAIStreamCallback } from './next.js';
|
|
5
|
+
export class OpenMeter {
|
|
10
6
|
events;
|
|
11
7
|
meters;
|
|
12
|
-
constructor(config
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
VERSION: OpenAPI.VERSION,
|
|
16
|
-
CREDENTIALS: config.credentials ?? OpenAPI.CREDENTIALS,
|
|
17
|
-
WITH_CREDENTIALS: config.withCredentials ?? OpenAPI.WITH_CREDENTIALS,
|
|
18
|
-
TOKEN: config.token,
|
|
19
|
-
USERNAME: config.username,
|
|
20
|
-
PASSWORD: config.password,
|
|
21
|
-
HEADERS: config.headers,
|
|
22
|
-
};
|
|
23
|
-
super(openAPIConfig, HttpRequest);
|
|
24
|
-
this.request = new HttpRequest(openAPIConfig);
|
|
25
|
-
this.default = new DefaultService(this.request);
|
|
26
|
-
this.events = new EventsService(this.request);
|
|
27
|
-
this.meters = new MetersService(this.request);
|
|
8
|
+
constructor(config) {
|
|
9
|
+
this.events = new EventsClient(config);
|
|
10
|
+
this.meters = new MetersClient(config);
|
|
28
11
|
}
|
|
29
12
|
}
|
package/dist/next.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { OpenAIStreamCallbacks } from 'ai';
|
|
2
|
+
import type { TiktokenModel } from 'js-tiktoken';
|
|
3
|
+
type OpenAIUsage = {
|
|
4
|
+
total_tokens: number;
|
|
5
|
+
prompt_tokens: number;
|
|
6
|
+
completion_tokens: number;
|
|
7
|
+
};
|
|
8
|
+
type OpenAIStreamCallbacksWithUsage = OpenAIStreamCallbacks & {
|
|
9
|
+
onUsage?: (usage: OpenAIUsage) => Promise<void> | void;
|
|
10
|
+
};
|
|
11
|
+
export declare function createOpenAIStreamCallback({ model, prompts, }: {
|
|
12
|
+
model: TiktokenModel;
|
|
13
|
+
prompts: string[];
|
|
14
|
+
}, openAIStreamCallbacks: OpenAIStreamCallbacksWithUsage): Promise<OpenAIStreamCallbacks>;
|
|
15
|
+
export {};
|
package/dist/next.js
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
let encodingForModel;
|
|
2
|
+
export async function createOpenAIStreamCallback({ model, prompts, }, openAIStreamCallbacks) {
|
|
3
|
+
// Tiktoken is an optional dependency, so we import it conditionally
|
|
4
|
+
if (!encodingForModel) {
|
|
5
|
+
const { encodingForModel: encodingForModel_ } = await import('js-tiktoken');
|
|
6
|
+
encodingForModel = encodingForModel_;
|
|
7
|
+
}
|
|
8
|
+
const enc = encodingForModel(model);
|
|
9
|
+
let promptTokens = 0;
|
|
10
|
+
let completionTokens = 0;
|
|
11
|
+
const streamCallbacks = {
|
|
12
|
+
...openAIStreamCallbacks,
|
|
13
|
+
async onStart() {
|
|
14
|
+
for (const content of prompts) {
|
|
15
|
+
const tokens = enc.encode(content);
|
|
16
|
+
promptTokens += tokens.length;
|
|
17
|
+
}
|
|
18
|
+
if (typeof openAIStreamCallbacks?.onStart === 'function') {
|
|
19
|
+
return openAIStreamCallbacks.onStart();
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
async onToken(content) {
|
|
23
|
+
// To test tokenizaton see: https://platform.openai.com/tokenizer
|
|
24
|
+
const tokens = enc.encode(content);
|
|
25
|
+
completionTokens += tokens.length;
|
|
26
|
+
if (typeof openAIStreamCallbacks?.onToken === 'function') {
|
|
27
|
+
return openAIStreamCallbacks.onToken(content);
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
async onFinal(completion) {
|
|
31
|
+
// Mimicking OpenAI usage metadata API
|
|
32
|
+
const usage = {
|
|
33
|
+
total_tokens: promptTokens + completionTokens,
|
|
34
|
+
prompt_tokens: promptTokens,
|
|
35
|
+
completion_tokens: completionTokens,
|
|
36
|
+
};
|
|
37
|
+
if (typeof openAIStreamCallbacks?.onUsage === 'function') {
|
|
38
|
+
await openAIStreamCallbacks.onUsage(usage);
|
|
39
|
+
}
|
|
40
|
+
if (typeof openAIStreamCallbacks?.onFinal === 'function') {
|
|
41
|
+
return openAIStreamCallbacks.onFinal(completion);
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
return streamCallbacks;
|
|
46
|
+
}
|
|
@@ -0,0 +1,406 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file was auto-generated by openapi-typescript.
|
|
3
|
+
* Do not make direct changes to the file.
|
|
4
|
+
*/
|
|
5
|
+
export interface paths {
|
|
6
|
+
'/api/v1/events': {
|
|
7
|
+
/** @description Retrieve latest raw events. */
|
|
8
|
+
get: operations['listEvents'];
|
|
9
|
+
/** @description Ingest events */
|
|
10
|
+
post: operations['ingestEvents'];
|
|
11
|
+
};
|
|
12
|
+
'/api/v1/meters': {
|
|
13
|
+
/** @description List meters */
|
|
14
|
+
get: operations['listMeters'];
|
|
15
|
+
/** @description Create meter */
|
|
16
|
+
post: operations['createMeter'];
|
|
17
|
+
};
|
|
18
|
+
'/api/v1/meters/{meterIdOrSlug}': {
|
|
19
|
+
/** @description Get meter by slugs */
|
|
20
|
+
get: operations['getMeter'];
|
|
21
|
+
/** @description Delete meter by slug */
|
|
22
|
+
delete: operations['deleteMeter'];
|
|
23
|
+
};
|
|
24
|
+
'/api/v1/meters/{meterIdOrSlug}/query': {
|
|
25
|
+
/** @description Query meter */
|
|
26
|
+
get: operations['queryMeter'];
|
|
27
|
+
};
|
|
28
|
+
'/api/v1/meters/{meterIdOrSlug}/subjects': {
|
|
29
|
+
/** @description List meter subjects */
|
|
30
|
+
get: operations['listMeterSubjects'];
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export type webhooks = Record<string, never>;
|
|
34
|
+
export interface components {
|
|
35
|
+
schemas: {
|
|
36
|
+
/**
|
|
37
|
+
* @description A Problem Details object (RFC 7807)
|
|
38
|
+
* @example {
|
|
39
|
+
* "type": "urn:problem-type:bad-request",
|
|
40
|
+
* "title": "Bad Request",
|
|
41
|
+
* "status": 400,
|
|
42
|
+
* "detail": "header Content-Type has unexpected value \"application/xml\"",
|
|
43
|
+
* "instance": "urn:request:local/JMOlctsKV8-000001"
|
|
44
|
+
* }
|
|
45
|
+
*/
|
|
46
|
+
Problem: {
|
|
47
|
+
/**
|
|
48
|
+
* Format: uri
|
|
49
|
+
* @description Type contains a URI that identifies the problem type.
|
|
50
|
+
* @example urn:problem-type:bad-request
|
|
51
|
+
*/
|
|
52
|
+
type: string;
|
|
53
|
+
/**
|
|
54
|
+
* @description A a short, human-readable summary of the problem type.
|
|
55
|
+
* @example Bad Request
|
|
56
|
+
*/
|
|
57
|
+
title: string;
|
|
58
|
+
/**
|
|
59
|
+
* Format: int32
|
|
60
|
+
* @description The HTTP status code generated by the origin server for this occurrence of the problem.
|
|
61
|
+
* @example 400
|
|
62
|
+
*/
|
|
63
|
+
status: number;
|
|
64
|
+
/**
|
|
65
|
+
* @description A human-readable explanation specific to this occurrence of the problem.
|
|
66
|
+
* @example header Content-Type has unexpected value \"application/xml\"
|
|
67
|
+
*/
|
|
68
|
+
detail: string;
|
|
69
|
+
/**
|
|
70
|
+
* Format: uri
|
|
71
|
+
* @description A URI reference that identifies the specific occurrence of the problem.
|
|
72
|
+
* @example urn:request:local/JMOlctsKV8-000001
|
|
73
|
+
*/
|
|
74
|
+
instance?: string;
|
|
75
|
+
[key: string]: unknown;
|
|
76
|
+
};
|
|
77
|
+
/** @description CloudEvents Specification JSON Schema */
|
|
78
|
+
Event: {
|
|
79
|
+
/**
|
|
80
|
+
* @description Identifies the event.
|
|
81
|
+
* @example 5c10fade-1c9e-4d6c-8275-c52c36731d3c
|
|
82
|
+
*/
|
|
83
|
+
id: string;
|
|
84
|
+
/**
|
|
85
|
+
* Format: uri-reference
|
|
86
|
+
* @description Identifies the context in which an event happened.
|
|
87
|
+
* @example services/service-0
|
|
88
|
+
*/
|
|
89
|
+
source: string;
|
|
90
|
+
/**
|
|
91
|
+
* @description The version of the CloudEvents specification which the event uses.
|
|
92
|
+
* @example 1.0
|
|
93
|
+
*/
|
|
94
|
+
specversion: string;
|
|
95
|
+
/**
|
|
96
|
+
* @description Describes the type of event related to the originating occurrence.
|
|
97
|
+
* @example api_request
|
|
98
|
+
*/
|
|
99
|
+
type: string;
|
|
100
|
+
/**
|
|
101
|
+
* @description Content type of the data value. Must adhere to RFC 2046 format.
|
|
102
|
+
* @example application/json
|
|
103
|
+
* @enum {string|null}
|
|
104
|
+
*/
|
|
105
|
+
datacontenttype?: 'application/json' | null;
|
|
106
|
+
/**
|
|
107
|
+
* Format: uri
|
|
108
|
+
* @description Identifies the schema that data adheres to.
|
|
109
|
+
*/
|
|
110
|
+
dataschema?: string | null;
|
|
111
|
+
/**
|
|
112
|
+
* @description Describes the subject of the event in the context of the event producer (identified by source).
|
|
113
|
+
* @example customer_id
|
|
114
|
+
*/
|
|
115
|
+
subject: string;
|
|
116
|
+
/**
|
|
117
|
+
* Format: date-time
|
|
118
|
+
* @description Timestamp of when the occurrence happened. Must adhere to RFC 3339.
|
|
119
|
+
* @example 2023-01-01T01:01:01.001Z
|
|
120
|
+
*/
|
|
121
|
+
time?: string | null;
|
|
122
|
+
/**
|
|
123
|
+
* @description The event payload.
|
|
124
|
+
* @example {
|
|
125
|
+
* "duration_ms": "12",
|
|
126
|
+
* "path": "/hello"
|
|
127
|
+
* }
|
|
128
|
+
*/
|
|
129
|
+
data?: {
|
|
130
|
+
[key: string]: unknown;
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
Meter: {
|
|
134
|
+
/**
|
|
135
|
+
* @description A unique identifier for the meter.
|
|
136
|
+
* @example 01G65Z755AFWAKHE12NY0CQ9FH
|
|
137
|
+
*/
|
|
138
|
+
id?: string;
|
|
139
|
+
/**
|
|
140
|
+
* @description A unique identifier for the meter.
|
|
141
|
+
* @example my_meter
|
|
142
|
+
*/
|
|
143
|
+
slug: string;
|
|
144
|
+
/**
|
|
145
|
+
* @description A description of the meter.
|
|
146
|
+
* @example My Meter Description
|
|
147
|
+
*/
|
|
148
|
+
description?: string | null;
|
|
149
|
+
aggregation: components['schemas']['MeterAggregation'];
|
|
150
|
+
/**
|
|
151
|
+
* @description The event type to aggregate.
|
|
152
|
+
* @example api_request
|
|
153
|
+
*/
|
|
154
|
+
eventType: string;
|
|
155
|
+
/**
|
|
156
|
+
* @description JSONPath expression to extract the value from the event data.
|
|
157
|
+
* @example $.duration_ms
|
|
158
|
+
*/
|
|
159
|
+
valueProperty?: string;
|
|
160
|
+
/**
|
|
161
|
+
* @description Named JSONPath expressions to extract the group by values from the event data.
|
|
162
|
+
* @example {
|
|
163
|
+
* "method": "$.method",
|
|
164
|
+
* "path": "$.path"
|
|
165
|
+
* }
|
|
166
|
+
*/
|
|
167
|
+
groupBy?: {
|
|
168
|
+
[key: string]: string;
|
|
169
|
+
};
|
|
170
|
+
windowSize: components['schemas']['WindowSize'];
|
|
171
|
+
};
|
|
172
|
+
/**
|
|
173
|
+
* @description The aggregation type to use for the meter.
|
|
174
|
+
* @enum {string}
|
|
175
|
+
*/
|
|
176
|
+
MeterAggregation: 'SUM' | 'COUNT' | 'AVG' | 'MIN' | 'MAX';
|
|
177
|
+
/** @enum {string} */
|
|
178
|
+
WindowSize: 'MINUTE' | 'HOUR' | 'DAY';
|
|
179
|
+
MeterQueryRow: {
|
|
180
|
+
value: number;
|
|
181
|
+
/** Format: date-time */
|
|
182
|
+
windowStart: string;
|
|
183
|
+
/** Format: date-time */
|
|
184
|
+
windowEnd: string;
|
|
185
|
+
/** @description The subject of the meter value. */
|
|
186
|
+
subject?: string | null;
|
|
187
|
+
groupBy?: {
|
|
188
|
+
[key: string]: string;
|
|
189
|
+
} | null;
|
|
190
|
+
};
|
|
191
|
+
IdOrSlug: string;
|
|
192
|
+
};
|
|
193
|
+
responses: {
|
|
194
|
+
/** @description Bad Request */
|
|
195
|
+
BadRequestProblemResponse: {
|
|
196
|
+
content: {
|
|
197
|
+
'application/problem+json': components['schemas']['Problem'];
|
|
198
|
+
};
|
|
199
|
+
};
|
|
200
|
+
/** @description Method not allowed, feature not supported */
|
|
201
|
+
MethodNotAllowedProblemResponse: {
|
|
202
|
+
content: {
|
|
203
|
+
'application/problem+json': components['schemas']['Problem'];
|
|
204
|
+
};
|
|
205
|
+
};
|
|
206
|
+
/** @description Not Found */
|
|
207
|
+
NotFoundProblemResponse: {
|
|
208
|
+
content: {
|
|
209
|
+
'application/problem+json': components['schemas']['Problem'];
|
|
210
|
+
};
|
|
211
|
+
};
|
|
212
|
+
/** @description Not Implemented */
|
|
213
|
+
NotImplementedProblemResponse: {
|
|
214
|
+
content: {
|
|
215
|
+
'application/problem+json': components['schemas']['Problem'];
|
|
216
|
+
};
|
|
217
|
+
};
|
|
218
|
+
/** @description Unexpected error */
|
|
219
|
+
UnexpectedProblemResponse: {
|
|
220
|
+
content: {
|
|
221
|
+
'application/problem+json': components['schemas']['Problem'];
|
|
222
|
+
};
|
|
223
|
+
};
|
|
224
|
+
};
|
|
225
|
+
parameters: {
|
|
226
|
+
/** @description A unique identifier for the meter. */
|
|
227
|
+
meterIdOrSlug: components['schemas']['IdOrSlug'];
|
|
228
|
+
/**
|
|
229
|
+
* @description Start date-time in RFC 3339 format in UTC timezone.
|
|
230
|
+
* Must be aligned with the window size.
|
|
231
|
+
* Inclusive.
|
|
232
|
+
*/
|
|
233
|
+
queryFrom?: string;
|
|
234
|
+
/**
|
|
235
|
+
* @description End date-time in RFC 3339 format in UTC timezone.
|
|
236
|
+
* Must be aligned with the window size.
|
|
237
|
+
* Inclusive.
|
|
238
|
+
*/
|
|
239
|
+
queryTo?: string;
|
|
240
|
+
/** @description If not specified, a single usage aggregate will be returned for the entirety of the specified period for each subject and group. */
|
|
241
|
+
queryWindowSize?: components['schemas']['WindowSize'];
|
|
242
|
+
querySubject?: string[];
|
|
243
|
+
/** @description If not specified a single aggregate will be returned for each subject and time window. */
|
|
244
|
+
queryGroupBy?: string[];
|
|
245
|
+
};
|
|
246
|
+
requestBodies: never;
|
|
247
|
+
headers: never;
|
|
248
|
+
pathItems: never;
|
|
249
|
+
}
|
|
250
|
+
export type $defs = Record<string, never>;
|
|
251
|
+
export type external = Record<string, never>;
|
|
252
|
+
export interface operations {
|
|
253
|
+
/** @description Retrieve latest raw events. */
|
|
254
|
+
listEvents: {
|
|
255
|
+
parameters: {
|
|
256
|
+
query?: {
|
|
257
|
+
/** @description Number of events to return. */
|
|
258
|
+
limit?: number;
|
|
259
|
+
};
|
|
260
|
+
};
|
|
261
|
+
responses: {
|
|
262
|
+
/** @description Events response */
|
|
263
|
+
200: {
|
|
264
|
+
content: {
|
|
265
|
+
'application/json': components['schemas']['Event'][];
|
|
266
|
+
};
|
|
267
|
+
};
|
|
268
|
+
400: components['responses']['BadRequestProblemResponse'];
|
|
269
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
270
|
+
};
|
|
271
|
+
};
|
|
272
|
+
/** @description Ingest events */
|
|
273
|
+
ingestEvents: {
|
|
274
|
+
requestBody: {
|
|
275
|
+
content: {
|
|
276
|
+
'application/cloudevents+json': components['schemas']['Event'];
|
|
277
|
+
'application/cloudevents-batch+json': components['schemas']['Event'][];
|
|
278
|
+
};
|
|
279
|
+
};
|
|
280
|
+
responses: {
|
|
281
|
+
/** @description OK */
|
|
282
|
+
204: {
|
|
283
|
+
content: never;
|
|
284
|
+
};
|
|
285
|
+
400: components['responses']['BadRequestProblemResponse'];
|
|
286
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
287
|
+
};
|
|
288
|
+
};
|
|
289
|
+
/** @description List meters */
|
|
290
|
+
listMeters: {
|
|
291
|
+
responses: {
|
|
292
|
+
/** @description Meters response */
|
|
293
|
+
200: {
|
|
294
|
+
content: {
|
|
295
|
+
'application/json': components['schemas']['Meter'][];
|
|
296
|
+
};
|
|
297
|
+
};
|
|
298
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
299
|
+
};
|
|
300
|
+
};
|
|
301
|
+
/** @description Create meter */
|
|
302
|
+
createMeter: {
|
|
303
|
+
requestBody: {
|
|
304
|
+
content: {
|
|
305
|
+
'application/json': components['schemas']['Meter'];
|
|
306
|
+
};
|
|
307
|
+
};
|
|
308
|
+
responses: {
|
|
309
|
+
/** @description Created */
|
|
310
|
+
201: {
|
|
311
|
+
content: {
|
|
312
|
+
'application/json': components['schemas']['Meter'];
|
|
313
|
+
};
|
|
314
|
+
};
|
|
315
|
+
400: components['responses']['BadRequestProblemResponse'];
|
|
316
|
+
501: components['responses']['NotImplementedProblemResponse'];
|
|
317
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
318
|
+
};
|
|
319
|
+
};
|
|
320
|
+
/** @description Get meter by slugs */
|
|
321
|
+
getMeter: {
|
|
322
|
+
parameters: {
|
|
323
|
+
path: {
|
|
324
|
+
meterIdOrSlug: components['parameters']['meterIdOrSlug'];
|
|
325
|
+
};
|
|
326
|
+
};
|
|
327
|
+
responses: {
|
|
328
|
+
/** @description OK */
|
|
329
|
+
200: {
|
|
330
|
+
content: {
|
|
331
|
+
'application/json': components['schemas']['Meter'];
|
|
332
|
+
};
|
|
333
|
+
};
|
|
334
|
+
404: components['responses']['NotFoundProblemResponse'];
|
|
335
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
336
|
+
};
|
|
337
|
+
};
|
|
338
|
+
/** @description Delete meter by slug */
|
|
339
|
+
deleteMeter: {
|
|
340
|
+
parameters: {
|
|
341
|
+
path: {
|
|
342
|
+
meterIdOrSlug: components['parameters']['meterIdOrSlug'];
|
|
343
|
+
};
|
|
344
|
+
};
|
|
345
|
+
responses: {
|
|
346
|
+
/** @description No Content */
|
|
347
|
+
204: {
|
|
348
|
+
content: never;
|
|
349
|
+
};
|
|
350
|
+
404: components['responses']['NotFoundProblemResponse'];
|
|
351
|
+
501: components['responses']['NotImplementedProblemResponse'];
|
|
352
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
353
|
+
};
|
|
354
|
+
};
|
|
355
|
+
/** @description Query meter */
|
|
356
|
+
queryMeter: {
|
|
357
|
+
parameters: {
|
|
358
|
+
query?: {
|
|
359
|
+
from?: components['parameters']['queryFrom'];
|
|
360
|
+
to?: components['parameters']['queryTo'];
|
|
361
|
+
windowSize?: components['parameters']['queryWindowSize'];
|
|
362
|
+
subject?: components['parameters']['querySubject'];
|
|
363
|
+
groupBy?: components['parameters']['queryGroupBy'];
|
|
364
|
+
};
|
|
365
|
+
path: {
|
|
366
|
+
meterIdOrSlug: components['parameters']['meterIdOrSlug'];
|
|
367
|
+
};
|
|
368
|
+
};
|
|
369
|
+
responses: {
|
|
370
|
+
/** @description OK */
|
|
371
|
+
200: {
|
|
372
|
+
content: {
|
|
373
|
+
'application/json': {
|
|
374
|
+
/** Format: date-time */
|
|
375
|
+
from?: string;
|
|
376
|
+
/** Format: date-time */
|
|
377
|
+
to?: string;
|
|
378
|
+
windowSize?: components['schemas']['WindowSize'];
|
|
379
|
+
data: components['schemas']['MeterQueryRow'][];
|
|
380
|
+
};
|
|
381
|
+
'text/csv': string;
|
|
382
|
+
};
|
|
383
|
+
};
|
|
384
|
+
400: components['responses']['BadRequestProblemResponse'];
|
|
385
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
386
|
+
};
|
|
387
|
+
};
|
|
388
|
+
/** @description List meter subjects */
|
|
389
|
+
listMeterSubjects: {
|
|
390
|
+
parameters: {
|
|
391
|
+
path: {
|
|
392
|
+
meterIdOrSlug: components['parameters']['meterIdOrSlug'];
|
|
393
|
+
};
|
|
394
|
+
};
|
|
395
|
+
responses: {
|
|
396
|
+
/** @description OK */
|
|
397
|
+
200: {
|
|
398
|
+
content: {
|
|
399
|
+
'application/json': string[];
|
|
400
|
+
};
|
|
401
|
+
};
|
|
402
|
+
400: components['responses']['BadRequestProblemResponse'];
|
|
403
|
+
default: components['responses']['UnexpectedProblemResponse'];
|
|
404
|
+
};
|
|
405
|
+
};
|
|
406
|
+
}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { MockAgent } from 'undici';
|
|
2
|
+
import { mockEvent, mockMeter, mockMeterValue } from './mocks.js';
|
|
3
|
+
export const mockAgent = new MockAgent();
|
|
4
|
+
mockAgent.disableNetConnect();
|
|
5
|
+
const client = mockAgent.get('http://127.0.0.1:8888');
|
|
6
|
+
client
|
|
7
|
+
.intercept({
|
|
8
|
+
path: '/api/v1/events',
|
|
9
|
+
method: 'POST',
|
|
10
|
+
headers: {
|
|
11
|
+
Accept: 'application/json',
|
|
12
|
+
'Content-Type': 'application/cloudevents+json',
|
|
13
|
+
},
|
|
14
|
+
body: JSON.stringify({
|
|
15
|
+
specversion: '1.0',
|
|
16
|
+
id: 'id-1',
|
|
17
|
+
source: 'my-app',
|
|
18
|
+
type: 'my-type',
|
|
19
|
+
subject: 'my-awesome-user-id',
|
|
20
|
+
time: new Date('2023-01-01'),
|
|
21
|
+
data: {
|
|
22
|
+
api_calls: 1,
|
|
23
|
+
},
|
|
24
|
+
}),
|
|
25
|
+
})
|
|
26
|
+
.reply(204);
|
|
27
|
+
client
|
|
28
|
+
.intercept({
|
|
29
|
+
path: `/api/v1/events`,
|
|
30
|
+
method: 'GET',
|
|
31
|
+
headers: {
|
|
32
|
+
Accept: 'application/json',
|
|
33
|
+
},
|
|
34
|
+
})
|
|
35
|
+
.reply(200, [mockEvent], {
|
|
36
|
+
headers: {
|
|
37
|
+
'Content-Type': 'application/json',
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
client
|
|
41
|
+
.intercept({
|
|
42
|
+
path: '/api/v1/events',
|
|
43
|
+
method: 'POST',
|
|
44
|
+
headers: {
|
|
45
|
+
Accept: 'application/json',
|
|
46
|
+
'Content-Type': 'application/cloudevents+json',
|
|
47
|
+
},
|
|
48
|
+
body: JSON.stringify({
|
|
49
|
+
specversion: '1.0',
|
|
50
|
+
id: 'aaf17be7-860c-4519-91d3-00d97da3cc65',
|
|
51
|
+
source: '@openmeter/sdk',
|
|
52
|
+
type: 'my-type',
|
|
53
|
+
subject: 'my-awesome-user-id',
|
|
54
|
+
data: {
|
|
55
|
+
api_calls: 1,
|
|
56
|
+
},
|
|
57
|
+
}),
|
|
58
|
+
})
|
|
59
|
+
.reply(204);
|
|
60
|
+
client
|
|
61
|
+
.intercept({
|
|
62
|
+
path: '/api/v1/meters',
|
|
63
|
+
method: 'GET',
|
|
64
|
+
headers: {
|
|
65
|
+
Accept: 'application/json',
|
|
66
|
+
},
|
|
67
|
+
})
|
|
68
|
+
.reply(200, [mockMeter], {
|
|
69
|
+
headers: {
|
|
70
|
+
'Content-Type': 'application/json',
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
client
|
|
74
|
+
.intercept({
|
|
75
|
+
path: `/api/v1/meters/${mockMeter.slug}`,
|
|
76
|
+
method: 'GET',
|
|
77
|
+
headers: {
|
|
78
|
+
Accept: 'application/json',
|
|
79
|
+
},
|
|
80
|
+
})
|
|
81
|
+
.reply(200, mockMeter, {
|
|
82
|
+
headers: {
|
|
83
|
+
'Content-Type': 'application/json',
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
/** Meter Values */
|
|
87
|
+
client
|
|
88
|
+
.intercept({
|
|
89
|
+
path: `/api/v1/meters/${mockMeter.slug}/values`,
|
|
90
|
+
query: {},
|
|
91
|
+
method: 'GET',
|
|
92
|
+
headers: {
|
|
93
|
+
Accept: 'application/json',
|
|
94
|
+
},
|
|
95
|
+
})
|
|
96
|
+
.reply(200, {
|
|
97
|
+
windowSize: 'HOUR',
|
|
98
|
+
data: [mockMeterValue],
|
|
99
|
+
}, {
|
|
100
|
+
headers: {
|
|
101
|
+
'Content-Type': 'application/json',
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
client
|
|
105
|
+
.intercept({
|
|
106
|
+
path: `/api/v1/meters/${mockMeter.slug}/values`,
|
|
107
|
+
query: {
|
|
108
|
+
subject: 'user-1',
|
|
109
|
+
from: new Date('2021-01-01').toISOString(),
|
|
110
|
+
to: new Date('2021-01-02').toISOString(),
|
|
111
|
+
windowSize: 'HOUR',
|
|
112
|
+
},
|
|
113
|
+
method: 'GET',
|
|
114
|
+
headers: {
|
|
115
|
+
Accept: 'application/json',
|
|
116
|
+
},
|
|
117
|
+
})
|
|
118
|
+
.reply(200, {
|
|
119
|
+
windowSize: 'HOUR',
|
|
120
|
+
data: [mockMeterValue],
|
|
121
|
+
}, {
|
|
122
|
+
headers: {
|
|
123
|
+
'Content-Type': 'application/json',
|
|
124
|
+
},
|
|
125
|
+
});
|
|
126
|
+
/** Meter Query */
|
|
127
|
+
client
|
|
128
|
+
.intercept({
|
|
129
|
+
path: `/api/v1/meters/${mockMeter.slug}/query`,
|
|
130
|
+
query: {},
|
|
131
|
+
method: 'GET',
|
|
132
|
+
headers: {
|
|
133
|
+
Accept: 'application/json',
|
|
134
|
+
},
|
|
135
|
+
})
|
|
136
|
+
.reply(200, {
|
|
137
|
+
from: mockMeterValue.windowStart,
|
|
138
|
+
to: mockMeterValue.windowEnd,
|
|
139
|
+
windowSize: 'HOUR',
|
|
140
|
+
data: [mockMeterValue],
|
|
141
|
+
}, {
|
|
142
|
+
headers: {
|
|
143
|
+
'Content-Type': 'application/json',
|
|
144
|
+
},
|
|
145
|
+
});
|
|
146
|
+
client
|
|
147
|
+
.intercept({
|
|
148
|
+
path: `/api/v1/meters/${mockMeter.slug}/query`,
|
|
149
|
+
query: {
|
|
150
|
+
subject: 'user-1',
|
|
151
|
+
groupBy: 'a,b',
|
|
152
|
+
from: new Date('2021-01-01').toISOString(),
|
|
153
|
+
to: new Date('2021-01-02').toISOString(),
|
|
154
|
+
windowSize: 'HOUR',
|
|
155
|
+
},
|
|
156
|
+
method: 'GET',
|
|
157
|
+
headers: {
|
|
158
|
+
Accept: 'application/json',
|
|
159
|
+
},
|
|
160
|
+
})
|
|
161
|
+
.reply(200, {
|
|
162
|
+
from: mockMeterValue.windowStart,
|
|
163
|
+
to: mockMeterValue.windowEnd,
|
|
164
|
+
windowSize: 'HOUR',
|
|
165
|
+
data: [mockMeterValue],
|
|
166
|
+
}, {
|
|
167
|
+
headers: {
|
|
168
|
+
'Content-Type': 'application/json',
|
|
169
|
+
},
|
|
170
|
+
});
|
|
171
|
+
/** Meter Subjects */
|
|
172
|
+
client
|
|
173
|
+
.intercept({
|
|
174
|
+
path: `/api/v1/meters/${mockMeter.slug}/subjects`,
|
|
175
|
+
method: 'GET',
|
|
176
|
+
headers: {
|
|
177
|
+
Accept: 'application/json',
|
|
178
|
+
},
|
|
179
|
+
})
|
|
180
|
+
.reply(200, [mockMeterValue.subject], {
|
|
181
|
+
headers: {
|
|
182
|
+
'Content-Type': 'application/json',
|
|
183
|
+
},
|
|
184
|
+
});
|