-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathmetrics.ts
More file actions
189 lines (164 loc) · 5.57 KB
/
metrics.ts
File metadata and controls
189 lines (164 loc) · 5.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { APIResource } from '../resource';
import { isRequestOptions } from '../core';
import * as Core from '../core';
import * as ItemsAPI from './items';
import { Page, type PageParams } from '../pagination';
/**
* The Metric resource represents a calculation of a quantity based on events.
* Metrics are defined by the query that transforms raw usage events into meaningful values for your customers.
*/
export class Metrics extends APIResource {
/**
* This endpoint is used to create a [metric](/core-concepts###metric) using a SQL
* string. See [SQL support](/extensibility/advanced-metrics#sql-support) for a
* description of constructing SQL queries with examples.
*
* @example
* ```ts
* const billableMetric = await client.metrics.create({
* description: 'Sum of bytes downloaded in fast mode',
* item_id: 'item_id',
* name: 'Bytes downloaded',
* sql: "SELECT sum(bytes_downloaded) FROM events WHERE download_speed = 'fast'",
* });
* ```
*/
create(body: MetricCreateParams, options?: Core.RequestOptions): Core.APIPromise<BillableMetric> {
return this._client.post('/metrics', { body, ...options });
}
/**
* This endpoint allows you to update the `metadata` property on a metric. If you
* pass `null` for the metadata value, it will clear any existing metadata for that
* invoice.
*
* @example
* ```ts
* const billableMetric = await client.metrics.update(
* 'metric_id',
* );
* ```
*/
update(
metricId: string,
body: MetricUpdateParams,
options?: Core.RequestOptions,
): Core.APIPromise<BillableMetric> {
return this._client.put(`/metrics/${metricId}`, { body, ...options });
}
/**
* This endpoint is used to fetch [metric](/core-concepts##metric) details given a
* metric identifier. It returns information about the metrics including its name,
* description, and item.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const billableMetric of client.metrics.list()) {
* // ...
* }
* ```
*/
list(
query?: MetricListParams,
options?: Core.RequestOptions,
): Core.PagePromise<BillableMetricsPage, BillableMetric>;
list(options?: Core.RequestOptions): Core.PagePromise<BillableMetricsPage, BillableMetric>;
list(
query: MetricListParams | Core.RequestOptions = {},
options?: Core.RequestOptions,
): Core.PagePromise<BillableMetricsPage, BillableMetric> {
if (isRequestOptions(query)) {
return this.list({}, query);
}
return this._client.getAPIList('/metrics', BillableMetricsPage, { query, ...options });
}
/**
* This endpoint is used to list [metrics](/core-concepts#metric). It returns
* information about the metrics including its name, description, and item.
*
* @example
* ```ts
* const billableMetric = await client.metrics.fetch(
* 'metric_id',
* );
* ```
*/
fetch(metricId: string, options?: Core.RequestOptions): Core.APIPromise<BillableMetric> {
return this._client.get(`/metrics/${metricId}`, options);
}
}
export class BillableMetricsPage extends Page<BillableMetric> {}
/**
* The Metric resource represents a calculation of a quantity based on events.
* Metrics are defined by the query that transforms raw usage events into
* meaningful values for your customers.
*/
export interface BillableMetric {
id: string;
description: string | null;
/**
* The Item resource represents a sellable product or good. Items are associated
* with all line items, billable metrics, and prices and are used for defining
* external sync behavior for invoices and tax calculation purposes.
*/
item: ItemsAPI.Item;
/**
* User specified key-value pairs for the resource. If not present, this defaults
* to an empty dictionary. Individual keys can be removed by setting the value to
* `null`, and the entire metadata mapping can be cleared by setting `metadata` to
* `null`.
*/
metadata: { [key: string]: string };
name: string;
status: 'active' | 'draft' | 'archived';
parameter_definitions?: Array<{ [key: string]: unknown }> | null;
}
export interface MetricCreateParams {
/**
* A description of the metric.
*/
description: string | null;
/**
* The id of the item
*/
item_id: string;
/**
* The name of the metric.
*/
name: string;
/**
* A sql string defining the metric.
*/
sql: string;
/**
* User-specified key/value pairs for the resource. Individual keys can be removed
* by setting the value to `null`, and the entire metadata mapping can be cleared
* by setting `metadata` to `null`.
*/
metadata?: { [key: string]: string | null } | null;
}
export interface MetricUpdateParams {
/**
* User-specified key/value pairs for the resource. Individual keys can be removed
* by setting the value to `null`, and the entire metadata mapping can be cleared
* by setting `metadata` to `null`.
*/
metadata?: { [key: string]: string | null } | null;
}
export interface MetricListParams extends PageParams {
'created_at[gt]'?: string | null;
'created_at[gte]'?: string | null;
'created_at[lt]'?: string | null;
'created_at[lte]'?: string | null;
}
Metrics.BillableMetricsPage = BillableMetricsPage;
export declare namespace Metrics {
export {
type BillableMetric as BillableMetric,
BillableMetricsPage as BillableMetricsPage,
type MetricCreateParams as MetricCreateParams,
type MetricUpdateParams as MetricUpdateParams,
type MetricListParams as MetricListParams,
};
}