-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathitems.ts
More file actions
224 lines (199 loc) · 5.89 KB
/
items.ts
File metadata and controls
224 lines (199 loc) · 5.89 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
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
// 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 { Page, type PageParams } from '../pagination';
/**
* 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.
*/
export class Items extends APIResource {
/**
* This endpoint is used to create an [Item](/core-concepts#item).
*
* @example
* ```ts
* const item = await client.items.create({
* name: 'API requests',
* });
* ```
*/
create(body: ItemCreateParams, options?: Core.RequestOptions): Core.APIPromise<Item> {
return this._client.post('/items', { body, ...options });
}
/**
* This endpoint can be used to update properties on the Item.
*
* @example
* ```ts
* const item = await client.items.update('item_id');
* ```
*/
update(itemId: string, body: ItemUpdateParams, options?: Core.RequestOptions): Core.APIPromise<Item> {
return this._client.put(`/items/${itemId}`, { body, ...options });
}
/**
* This endpoint returns a list of all Items, ordered in descending order by
* creation time.
*
* @example
* ```ts
* // Automatically fetches more pages as needed.
* for await (const item of client.items.list()) {
* // ...
* }
* ```
*/
list(query?: ItemListParams, options?: Core.RequestOptions): Core.PagePromise<ItemsPage, Item>;
list(options?: Core.RequestOptions): Core.PagePromise<ItemsPage, Item>;
list(
query: ItemListParams | Core.RequestOptions = {},
options?: Core.RequestOptions,
): Core.PagePromise<ItemsPage, Item> {
if (isRequestOptions(query)) {
return this.list({}, query);
}
return this._client.getAPIList('/items', ItemsPage, { query, ...options });
}
/**
* Archive item
*
* @example
* ```ts
* const item = await client.items.archive('item_id');
* ```
*/
archive(itemId: string, options?: Core.RequestOptions): Core.APIPromise<Item> {
return this._client.post(`/items/${itemId}/archive`, options);
}
/**
* This endpoint returns an item identified by its item_id.
*
* @example
* ```ts
* const item = await client.items.fetch('item_id');
* ```
*/
fetch(itemId: string, options?: Core.RequestOptions): Core.APIPromise<Item> {
return this._client.get(`/items/${itemId}`, options);
}
}
export class ItemsPage extends Page<Item> {}
/**
* 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.
*/
export interface Item {
/**
* The Orb-assigned unique identifier for the item.
*/
id: string;
/**
* The time at which the item was created.
*/
created_at: string;
/**
* A list of external connections for this item, used to sync with external
* invoicing and tax systems.
*/
external_connections: Array<Item.ExternalConnection>;
/**
* 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 };
/**
* The name of the item.
*/
name: string;
/**
* The time at which the item was archived. If null, the item is not archived.
*/
archived_at?: string | null;
}
export namespace Item {
/**
* Represents a connection between an Item and an external system for invoicing or
* tax calculation purposes.
*/
export interface ExternalConnection {
/**
* The name of the external system this item is connected to.
*/
external_connection_name:
| 'stripe'
| 'quickbooks'
| 'bill.com'
| 'netsuite'
| 'taxjar'
| 'avalara'
| 'anrok'
| 'numeral'
| 'stripe_tax';
/**
* The identifier of this item in the external system.
*/
external_entity_id: string;
}
}
export interface ItemCreateParams {
/**
* The name of the item.
*/
name: 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 ItemUpdateParams {
external_connections?: Array<ItemUpdateParams.ExternalConnection> | null;
/**
* 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;
name?: string | null;
}
export namespace ItemUpdateParams {
/**
* Represents a connection between an Item and an external system for invoicing or
* tax calculation purposes.
*/
export interface ExternalConnection {
/**
* The name of the external system this item is connected to.
*/
external_connection_name:
| 'stripe'
| 'quickbooks'
| 'bill.com'
| 'netsuite'
| 'taxjar'
| 'avalara'
| 'anrok'
| 'numeral'
| 'stripe_tax';
/**
* The identifier of this item in the external system.
*/
external_entity_id: string;
}
}
export interface ItemListParams extends PageParams {}
Items.ItemsPage = ItemsPage;
export declare namespace Items {
export {
type Item as Item,
ItemsPage as ItemsPage,
type ItemCreateParams as ItemCreateParams,
type ItemUpdateParams as ItemUpdateParams,
type ItemListParams as ItemListParams,
};
}