@daocloud-proto/baize 0.1.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.
- package/common/common.pb.ts +42 -0
- package/common/error.pb.ts +10 -0
- package/common/k8s.pb.ts +9 -0
- package/fetch.pb.ts +341 -0
- package/management-api/cluster/v1alpha1/cluster.pb.ts +28 -0
- package/management-api/notebook/v1alpha1/notebook.pb.ts +87 -0
- package/management-api/workspace/v1alpha1/workspace.pb.ts +27 -0
- package/package.json +7 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
/*
|
|
4
|
+
* This file is a generated Typescript file for GRPC Gateway, DO NOT MODIFY
|
|
5
|
+
*/
|
|
6
|
+
export type NoParamsQuery = {
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export type Pagination = {
|
|
10
|
+
total?: number
|
|
11
|
+
page?: number
|
|
12
|
+
pageSize?: number
|
|
13
|
+
sort?: string
|
|
14
|
+
search?: string
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export type Auth = {
|
|
18
|
+
group?: string
|
|
19
|
+
namespaced?: boolean
|
|
20
|
+
meshed?: boolean
|
|
21
|
+
skipAuth?: boolean
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export type Audit = {
|
|
25
|
+
objectNsKey?: string
|
|
26
|
+
objectNameKey?: string
|
|
27
|
+
objectKindName?: string
|
|
28
|
+
objectKindGroup?: string
|
|
29
|
+
objectKindVersion?: string
|
|
30
|
+
objectKindKey?: string
|
|
31
|
+
action?: string
|
|
32
|
+
actionKey?: string
|
|
33
|
+
customObject?: boolean
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export type AuditObject = {
|
|
37
|
+
namespace?: string
|
|
38
|
+
name?: string
|
|
39
|
+
kind?: string
|
|
40
|
+
group?: string
|
|
41
|
+
version?: string
|
|
42
|
+
}
|
package/common/k8s.pb.ts
ADDED
package/fetch.pb.ts
ADDED
|
@@ -0,0 +1,341 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
/*
|
|
4
|
+
* This file is a generated Typescript file for GRPC Gateway, DO NOT MODIFY
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* base64 encoder and decoder
|
|
9
|
+
* Copied and adapted from https://github.com/protobufjs/protobuf.js/blob/master/lib/base64/index.js
|
|
10
|
+
*/
|
|
11
|
+
// Base64 encoding table
|
|
12
|
+
const b64 = new Array(64);
|
|
13
|
+
|
|
14
|
+
// Base64 decoding table
|
|
15
|
+
const s64 = new Array(123);
|
|
16
|
+
|
|
17
|
+
// 65..90, 97..122, 48..57, 43, 47
|
|
18
|
+
for (let i = 0; i < 64;)
|
|
19
|
+
s64[b64[i] = i < 26 ? i + 65 : i < 52 ? i + 71 : i < 62 ? i - 4 : i - 59 | 43] = i++;
|
|
20
|
+
|
|
21
|
+
export function b64Encode(buffer: Uint8Array, start: number, end: number): string {
|
|
22
|
+
let parts: string[] = null;
|
|
23
|
+
const chunk = [];
|
|
24
|
+
let i = 0, // output index
|
|
25
|
+
j = 0, // goto index
|
|
26
|
+
t; // temporary
|
|
27
|
+
while (start < end) {
|
|
28
|
+
const b = buffer[start++];
|
|
29
|
+
switch (j) {
|
|
30
|
+
case 0:
|
|
31
|
+
chunk[i++] = b64[b >> 2];
|
|
32
|
+
t = (b & 3) << 4;
|
|
33
|
+
j = 1;
|
|
34
|
+
break;
|
|
35
|
+
case 1:
|
|
36
|
+
chunk[i++] = b64[t | b >> 4];
|
|
37
|
+
t = (b & 15) << 2;
|
|
38
|
+
j = 2;
|
|
39
|
+
break;
|
|
40
|
+
case 2:
|
|
41
|
+
chunk[i++] = b64[t | b >> 6];
|
|
42
|
+
chunk[i++] = b64[b & 63];
|
|
43
|
+
j = 0;
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
if (i > 8191) {
|
|
47
|
+
(parts || (parts = [])).push(String.fromCharCode.apply(String, chunk));
|
|
48
|
+
i = 0;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (j) {
|
|
52
|
+
chunk[i++] = b64[t];
|
|
53
|
+
chunk[i++] = 61;
|
|
54
|
+
if (j === 1)
|
|
55
|
+
chunk[i++] = 61;
|
|
56
|
+
}
|
|
57
|
+
if (parts) {
|
|
58
|
+
if (i)
|
|
59
|
+
parts.push(String.fromCharCode.apply(String, chunk.slice(0, i)));
|
|
60
|
+
return parts.join("");
|
|
61
|
+
}
|
|
62
|
+
return String.fromCharCode.apply(String, chunk.slice(0, i));
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const invalidEncoding = "invalid encoding";
|
|
66
|
+
|
|
67
|
+
export function b64Decode(s: string): Uint8Array {
|
|
68
|
+
const buffer = [];
|
|
69
|
+
let offset = 0;
|
|
70
|
+
let j = 0, // goto index
|
|
71
|
+
t; // temporary
|
|
72
|
+
for (let i = 0; i < s.length;) {
|
|
73
|
+
let c = s.charCodeAt(i++);
|
|
74
|
+
if (c === 61 && j > 1)
|
|
75
|
+
break;
|
|
76
|
+
if ((c = s64[c]) === undefined)
|
|
77
|
+
throw Error(invalidEncoding);
|
|
78
|
+
switch (j) {
|
|
79
|
+
case 0:
|
|
80
|
+
t = c;
|
|
81
|
+
j = 1;
|
|
82
|
+
break;
|
|
83
|
+
case 1:
|
|
84
|
+
buffer[offset++] = t << 2 | (c & 48) >> 4;
|
|
85
|
+
t = c;
|
|
86
|
+
j = 2;
|
|
87
|
+
break;
|
|
88
|
+
case 2:
|
|
89
|
+
buffer[offset++] = (t & 15) << 4 | (c & 60) >> 2;
|
|
90
|
+
t = c;
|
|
91
|
+
j = 3;
|
|
92
|
+
break;
|
|
93
|
+
case 3:
|
|
94
|
+
buffer[offset++] = (t & 3) << 6 | c;
|
|
95
|
+
j = 0;
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (j === 1)
|
|
100
|
+
throw Error(invalidEncoding);
|
|
101
|
+
return new Uint8Array(buffer);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
function b64Test(s: string): boolean {
|
|
105
|
+
return /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/.test(s);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
export interface InitReq extends RequestInit {
|
|
109
|
+
pathPrefix?: string
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
export function replacer(key: any, value: any): any {
|
|
113
|
+
if(value && value.constructor === Uint8Array) {
|
|
114
|
+
return b64Encode(value, 0, value.length);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
return value;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
export function fetchReq<I, O>(path: string, init?: InitReq): Promise<O> {
|
|
121
|
+
const {pathPrefix, ...req} = init || {}
|
|
122
|
+
|
|
123
|
+
const url = pathPrefix ? `${pathPrefix}${path}` : path
|
|
124
|
+
|
|
125
|
+
return fetch(url, req).then(r => r.json().then((body: O) => {
|
|
126
|
+
if (!r.ok) { throw body; }
|
|
127
|
+
return body;
|
|
128
|
+
})) as Promise<O>
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
// NotifyStreamEntityArrival is a callback that will be called on streaming entity arrival
|
|
132
|
+
export type NotifyStreamEntityArrival<T> = (resp: T) => void
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* fetchStreamingRequest is able to handle grpc-gateway server side streaming call
|
|
136
|
+
* it takes NotifyStreamEntityArrival that lets users respond to entity arrival during the call
|
|
137
|
+
* all entities will be returned as an array after the call finishes.
|
|
138
|
+
**/
|
|
139
|
+
export async function fetchStreamingRequest<S, R>(path: string, callback?: NotifyStreamEntityArrival<R>, init?: InitReq) {
|
|
140
|
+
const {pathPrefix, ...req} = init || {}
|
|
141
|
+
const url = pathPrefix ?`${pathPrefix}${path}` : path
|
|
142
|
+
const result = await fetch(url, req)
|
|
143
|
+
// needs to use the .ok to check the status of HTTP status code
|
|
144
|
+
// http other than 200 will not throw an error, instead the .ok will become false.
|
|
145
|
+
// see https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch#
|
|
146
|
+
if (!result.ok) {
|
|
147
|
+
const resp = await result.json()
|
|
148
|
+
const errMsg = resp.error && resp.error.message ? resp.error.message : ""
|
|
149
|
+
throw new Error(errMsg)
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
if (!result.body) {
|
|
153
|
+
throw new Error("response doesnt have a body")
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
await result.body
|
|
157
|
+
.pipeThrough(new TextDecoderStream())
|
|
158
|
+
.pipeThrough<R>(getNewLineDelimitedJSONDecodingStream<R>())
|
|
159
|
+
.pipeTo(getNotifyEntityArrivalSink((e: R) => {
|
|
160
|
+
if (callback) {
|
|
161
|
+
callback(e)
|
|
162
|
+
}
|
|
163
|
+
}))
|
|
164
|
+
|
|
165
|
+
// wait for the streaming to finish and return the success respond
|
|
166
|
+
return
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* JSONStringStreamController represents the transform controller that's able to transform the incoming
|
|
171
|
+
* new line delimited json content stream into entities and able to push the entity to the down stream
|
|
172
|
+
*/
|
|
173
|
+
interface JSONStringStreamController<T> extends TransformStreamDefaultController {
|
|
174
|
+
buf?: string
|
|
175
|
+
pos?: number
|
|
176
|
+
enqueue: (s: T) => void
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
/**
|
|
180
|
+
* getNewLineDelimitedJSONDecodingStream returns a TransformStream that's able to handle new line delimited json stream content into parsed entities
|
|
181
|
+
*/
|
|
182
|
+
function getNewLineDelimitedJSONDecodingStream<T>(): TransformStream<string, T> {
|
|
183
|
+
return new TransformStream({
|
|
184
|
+
start(controller: JSONStringStreamController<T>) {
|
|
185
|
+
controller.buf = ''
|
|
186
|
+
controller.pos = 0
|
|
187
|
+
},
|
|
188
|
+
|
|
189
|
+
transform(chunk: string, controller: JSONStringStreamController<T>) {
|
|
190
|
+
if (controller.buf === undefined) {
|
|
191
|
+
controller.buf = ''
|
|
192
|
+
}
|
|
193
|
+
if (controller.pos === undefined) {
|
|
194
|
+
controller.pos = 0
|
|
195
|
+
}
|
|
196
|
+
controller.buf += chunk
|
|
197
|
+
while (controller.pos < controller.buf.length) {
|
|
198
|
+
if (controller.buf[controller.pos] === '\n') {
|
|
199
|
+
const line = controller.buf.substring(0, controller.pos)
|
|
200
|
+
const response = JSON.parse(line)
|
|
201
|
+
controller.enqueue(response.result)
|
|
202
|
+
controller.buf = controller.buf.substring(controller.pos + 1)
|
|
203
|
+
controller.pos = 0
|
|
204
|
+
} else {
|
|
205
|
+
++controller.pos
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
})
|
|
210
|
+
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
/**
|
|
214
|
+
* getNotifyEntityArrivalSink takes the NotifyStreamEntityArrival callback and return
|
|
215
|
+
* a sink that will call the callback on entity arrival
|
|
216
|
+
* @param notifyCallback
|
|
217
|
+
*/
|
|
218
|
+
function getNotifyEntityArrivalSink<T>(notifyCallback: NotifyStreamEntityArrival<T>) {
|
|
219
|
+
return new WritableStream<T>({
|
|
220
|
+
write(entity: T) {
|
|
221
|
+
notifyCallback(entity)
|
|
222
|
+
}
|
|
223
|
+
})
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
type Primitive = string | boolean | number;
|
|
227
|
+
type RequestPayload = Record<string, unknown>;
|
|
228
|
+
type FlattenedRequestPayload = Record<string, Primitive | Array<Primitive>>;
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* Checks if given value is a plain object
|
|
232
|
+
* Logic copied and adapted from below source:
|
|
233
|
+
* https://github.com/char0n/ramda-adjunct/blob/master/src/isPlainObj.js
|
|
234
|
+
* @param {unknown} value
|
|
235
|
+
* @return {boolean}
|
|
236
|
+
*/
|
|
237
|
+
function isPlainObject(value: unknown): boolean {
|
|
238
|
+
const isObject =
|
|
239
|
+
Object.prototype.toString.call(value).slice(8, -1) === "Object";
|
|
240
|
+
const isObjLike = value !== null && isObject;
|
|
241
|
+
|
|
242
|
+
if (!isObjLike || !isObject) {
|
|
243
|
+
return false;
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
const proto = Object.getPrototypeOf(value);
|
|
247
|
+
|
|
248
|
+
const hasObjectConstructor =
|
|
249
|
+
typeof proto === "object" &&
|
|
250
|
+
proto.constructor === Object.prototype.constructor;
|
|
251
|
+
|
|
252
|
+
return hasObjectConstructor;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
/**
|
|
256
|
+
* Checks if given value is of a primitive type
|
|
257
|
+
* @param {unknown} value
|
|
258
|
+
* @return {boolean}
|
|
259
|
+
*/
|
|
260
|
+
function isPrimitive(value: unknown): boolean {
|
|
261
|
+
return ["string", "number", "boolean"].some(t => typeof value === t);
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
/**
|
|
265
|
+
* Checks if given primitive is zero-value
|
|
266
|
+
* @param {Primitive} value
|
|
267
|
+
* @return {boolean}
|
|
268
|
+
*/
|
|
269
|
+
function isZeroValuePrimitive(value: Primitive): boolean {
|
|
270
|
+
return value === false || value === 0 || value === "";
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
/**
|
|
274
|
+
* Flattens a deeply nested request payload and returns an object
|
|
275
|
+
* with only primitive values and non-empty array of primitive values
|
|
276
|
+
* as per https://github.com/googleapis/googleapis/blob/master/google/api/http.proto
|
|
277
|
+
* @param {RequestPayload} requestPayload
|
|
278
|
+
* @param {String} path
|
|
279
|
+
* @return {FlattenedRequestPayload>}
|
|
280
|
+
*/
|
|
281
|
+
function flattenRequestPayload<T extends RequestPayload>(
|
|
282
|
+
requestPayload: T,
|
|
283
|
+
path: string = ""
|
|
284
|
+
): FlattenedRequestPayload {
|
|
285
|
+
return Object.keys(requestPayload).reduce(
|
|
286
|
+
(acc: T, key: string): T => {
|
|
287
|
+
const value = requestPayload[key];
|
|
288
|
+
const newPath = path ? [path, key].join(".") : key;
|
|
289
|
+
|
|
290
|
+
const isNonEmptyPrimitiveArray =
|
|
291
|
+
Array.isArray(value) &&
|
|
292
|
+
value.every(v => isPrimitive(v)) &&
|
|
293
|
+
value.length > 0;
|
|
294
|
+
|
|
295
|
+
const isNonZeroValuePrimitive =
|
|
296
|
+
isPrimitive(value) && !isZeroValuePrimitive(value as Primitive);
|
|
297
|
+
|
|
298
|
+
let objectToMerge = {};
|
|
299
|
+
|
|
300
|
+
if (isPlainObject(value)) {
|
|
301
|
+
objectToMerge = flattenRequestPayload(value as RequestPayload, newPath);
|
|
302
|
+
} else if (isNonZeroValuePrimitive || isNonEmptyPrimitiveArray) {
|
|
303
|
+
objectToMerge = { [newPath]: value };
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
return { ...acc, ...objectToMerge };
|
|
307
|
+
},
|
|
308
|
+
{} as T
|
|
309
|
+
) as FlattenedRequestPayload;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* Renders a deeply nested request payload into a string of URL search
|
|
314
|
+
* parameters by first flattening the request payload and then removing keys
|
|
315
|
+
* which are already present in the URL path.
|
|
316
|
+
* @param {RequestPayload} requestPayload
|
|
317
|
+
* @param {string[]} urlPathParams
|
|
318
|
+
* @return {string}
|
|
319
|
+
*/
|
|
320
|
+
export function renderURLSearchParams<T extends RequestPayload>(
|
|
321
|
+
requestPayload: T,
|
|
322
|
+
urlPathParams: string[] = []
|
|
323
|
+
): string {
|
|
324
|
+
const flattenedRequestPayload = flattenRequestPayload(requestPayload);
|
|
325
|
+
|
|
326
|
+
const urlSearchParams = Object.keys(flattenedRequestPayload).reduce(
|
|
327
|
+
(acc: string[][], key: string): string[][] => {
|
|
328
|
+
// key should not be present in the url path as a parameter
|
|
329
|
+
const value = flattenedRequestPayload[key];
|
|
330
|
+
if (urlPathParams.find(f => f === key)) {
|
|
331
|
+
return acc;
|
|
332
|
+
}
|
|
333
|
+
return Array.isArray(value)
|
|
334
|
+
? [...acc, ...value.map(m => [key, m.toString()])]
|
|
335
|
+
: (acc = [...acc, [key, value.toString()]]);
|
|
336
|
+
},
|
|
337
|
+
[] as string[][]
|
|
338
|
+
);
|
|
339
|
+
|
|
340
|
+
return new URLSearchParams(urlSearchParams).toString();
|
|
341
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
/*
|
|
4
|
+
* This file is a generated Typescript file for GRPC Gateway, DO NOT MODIFY
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import * as BaizeCommonCommon from "../../../common/common.pb"
|
|
8
|
+
import * as fm from "../../../fetch.pb"
|
|
9
|
+
export type AICluster = {
|
|
10
|
+
name?: string
|
|
11
|
+
withAiSuite?: boolean
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export type ListAIClustersRequest = {
|
|
15
|
+
workspace?: number
|
|
16
|
+
page?: BaizeCommonCommon.Pagination
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export type ListAIClustersResponse = {
|
|
20
|
+
items?: AICluster[]
|
|
21
|
+
page?: BaizeCommonCommon.Pagination
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export class ClusterService {
|
|
25
|
+
static ListClusters(req: ListAIClustersRequest, initReq?: fm.InitReq): Promise<ListAIClustersResponse> {
|
|
26
|
+
return fm.fetchReq<ListAIClustersRequest, ListAIClustersResponse>(`/apis/baize.io/v1alpha1/workspaces/${req["workspace"]}/clusters?${fm.renderURLSearchParams(req, ["workspace"])}`, {...initReq, method: "GET"})
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
/*
|
|
4
|
+
* This file is a generated Typescript file for GRPC Gateway, DO NOT MODIFY
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import * as BaizeCommonCommon from "../../../common/common.pb"
|
|
8
|
+
import * as BaizeCommonK8s from "../../../common/k8s.pb"
|
|
9
|
+
import * as fm from "../../../fetch.pb"
|
|
10
|
+
|
|
11
|
+
export enum NotebookType {
|
|
12
|
+
TYPE_UNSPECIFIED = "TYPE_UNSPECIFIED",
|
|
13
|
+
JUPYTER = "JUPYTER",
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export enum NotebookStatusPhase {
|
|
17
|
+
PHASE_UNSPECIFIED = "PHASE_UNSPECIFIED",
|
|
18
|
+
PENDING = "PENDING",
|
|
19
|
+
RUNNING = "RUNNING",
|
|
20
|
+
STOPPED = "STOPPED",
|
|
21
|
+
FAILED = "FAILED",
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export type ListNotebooksRequest = {
|
|
25
|
+
workspace?: number
|
|
26
|
+
cluster?: string
|
|
27
|
+
namespace?: string
|
|
28
|
+
page?: BaizeCommonCommon.Pagination
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export type NotebookConfig = {
|
|
32
|
+
resources?: BaizeCommonK8s.Resources
|
|
33
|
+
image?: string
|
|
34
|
+
token?: string
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export type NotebookStatus = {
|
|
38
|
+
phase?: NotebookStatusPhase
|
|
39
|
+
message?: string
|
|
40
|
+
accessUrl?: string
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export type Notebook = {
|
|
44
|
+
workspace?: number
|
|
45
|
+
cluster?: string
|
|
46
|
+
namespace?: string
|
|
47
|
+
name?: string
|
|
48
|
+
type?: NotebookType
|
|
49
|
+
config?: NotebookConfig
|
|
50
|
+
status?: NotebookStatus
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export type ListNotebooksResponse = {
|
|
54
|
+
items?: Notebook[]
|
|
55
|
+
page?: BaizeCommonCommon.Pagination
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export type SingleNotebookRequest = {
|
|
59
|
+
workspace?: number
|
|
60
|
+
cluster?: string
|
|
61
|
+
namespace?: string
|
|
62
|
+
name?: string
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export type CreateNotebookRequest = {
|
|
66
|
+
workspace?: number
|
|
67
|
+
cluster?: string
|
|
68
|
+
namespace?: string
|
|
69
|
+
name?: string
|
|
70
|
+
type?: NotebookType
|
|
71
|
+
config?: NotebookConfig
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export class NotebookService {
|
|
75
|
+
static ListNotebooks(req: ListNotebooksRequest, initReq?: fm.InitReq): Promise<ListNotebooksResponse> {
|
|
76
|
+
return fm.fetchReq<ListNotebooksRequest, ListNotebooksResponse>(`/apis/baize.io/v1alpha1/workspaces/${req["workspace"]}/notebooks?${fm.renderURLSearchParams(req, ["workspace"])}`, {...initReq, method: "GET"})
|
|
77
|
+
}
|
|
78
|
+
static GetNotebook(req: SingleNotebookRequest, initReq?: fm.InitReq): Promise<Notebook> {
|
|
79
|
+
return fm.fetchReq<SingleNotebookRequest, Notebook>(`/apis/baize.io/v1alpha1/workspaces/${req["workspace"]}/clusters/${req["cluster"]}/namespaces/${req["namespace"]}/notebooks/${req["name"]}?${fm.renderURLSearchParams(req, ["workspace", "cluster", "namespace", "name"])}`, {...initReq, method: "GET"})
|
|
80
|
+
}
|
|
81
|
+
static CreateNotebook(req: SingleNotebookRequest, initReq?: fm.InitReq): Promise<Notebook> {
|
|
82
|
+
return fm.fetchReq<SingleNotebookRequest, Notebook>(`/apis/baize.io/v1alpha1/workspaces/${req["workspace"]}/clusters/${req["cluster"]}/namespaces/${req["namespace"]}/notebooks`, {...initReq, method: "POST", body: JSON.stringify(req, fm.replacer)})
|
|
83
|
+
}
|
|
84
|
+
static DeleteNotebook(req: SingleNotebookRequest, initReq?: fm.InitReq): Promise<Notebook> {
|
|
85
|
+
return fm.fetchReq<SingleNotebookRequest, Notebook>(`/apis/baize.io/v1alpha1/workspaces/${req["workspace"]}/clusters/${req["cluster"]}/namespaces/${req["namespace"]}/notebooks/${req["name"]}`, {...initReq, method: "DELETE", body: JSON.stringify(req, fm.replacer)})
|
|
86
|
+
}
|
|
87
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
// @ts-nocheck
|
|
3
|
+
/*
|
|
4
|
+
* This file is a generated Typescript file for GRPC Gateway, DO NOT MODIFY
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import * as BaizeCommonCommon from "../../../common/common.pb"
|
|
8
|
+
import * as fm from "../../../fetch.pb"
|
|
9
|
+
export type ListWorkspaceRequest = {
|
|
10
|
+
page?: BaizeCommonCommon.Pagination
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export type Workspace = {
|
|
14
|
+
workspaceId?: number
|
|
15
|
+
alias?: string
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export type ListWorkspacesResponse = {
|
|
19
|
+
items?: Workspace[]
|
|
20
|
+
page?: BaizeCommonCommon.Pagination
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export class WorkspaceService {
|
|
24
|
+
static ListWorkspaces(req: ListWorkspaceRequest, initReq?: fm.InitReq): Promise<ListWorkspacesResponse> {
|
|
25
|
+
return fm.fetchReq<ListWorkspaceRequest, ListWorkspacesResponse>(`/apis/baize.io/v1alpha1/workspaces?${fm.renderURLSearchParams(req, [])}`, {...initReq, method: "GET"})
|
|
26
|
+
}
|
|
27
|
+
}
|