@databricks/sdk-logdelivery 0.0.0-dev → 0.1.0-dev.2
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/LICENSE +203 -0
- package/dist/v1/client.d.ts +39 -0
- package/dist/v1/client.d.ts.map +1 -0
- package/dist/v1/client.js +172 -0
- package/dist/v1/client.js.map +1 -0
- package/dist/v1/index.d.ts +4 -0
- package/dist/v1/index.d.ts.map +1 -0
- package/dist/v1/index.js +4 -0
- package/dist/v1/index.js.map +1 -0
- package/dist/v1/model.d.ts +231 -0
- package/dist/v1/model.d.ts.map +1 -0
- package/dist/v1/model.js +217 -0
- package/dist/v1/model.js.map +1 -0
- package/dist/v1/transport.d.ts +5 -0
- package/dist/v1/transport.d.ts.map +1 -0
- package/dist/v1/transport.js +57 -0
- package/dist/v1/transport.js.map +1 -0
- package/dist/v1/utils.d.ts +21 -0
- package/dist/v1/utils.d.ts.map +1 -0
- package/dist/v1/utils.js +113 -0
- package/dist/v1/utils.js.map +1 -0
- package/package.json +38 -4
- package/src/v1/client.ts +241 -0
- package/src/v1/index.ts +24 -0
- package/src/v1/model.ts +411 -0
- package/src/v1/transport.ts +73 -0
- package/src/v1/utils.ts +156 -0
- package/README.md +0 -1
- package/index.js +0 -1
package/dist/v1/utils.js
ADDED
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
+
import { execute } from '@databricks/sdk-core/ops';
|
|
3
|
+
import { ApiError } from '@databricks/sdk-core/apierror';
|
|
4
|
+
import JSONBig from 'json-bigint';
|
|
5
|
+
// JSON codec that preserves int64 precision. On the way in, large integer
|
|
6
|
+
// literals come back as bigint instead of being rounded to JS Number. On the
|
|
7
|
+
// way out, bigint values are emitted as raw JSON number digits.
|
|
8
|
+
const jsonBigint = JSONBig({ useNativeBigInt: true });
|
|
9
|
+
/**
|
|
10
|
+
* Translates public CallOptions to the internal Options shape accepted by
|
|
11
|
+
* execute(). Even though the shapes match today, this isolates the public
|
|
12
|
+
* API from the executor's internal type so they can diverge.
|
|
13
|
+
*/
|
|
14
|
+
export async function executeCall(call, options) {
|
|
15
|
+
const opts = {
|
|
16
|
+
...(options?.retrier !== undefined && { retrier: options.retrier }),
|
|
17
|
+
...(options?.rateLimiter !== undefined && {
|
|
18
|
+
rateLimiter: options.rateLimiter,
|
|
19
|
+
}),
|
|
20
|
+
...(options?.timeout !== undefined && { timeout: options.timeout }),
|
|
21
|
+
};
|
|
22
|
+
return execute(options?.signal, call, opts);
|
|
23
|
+
}
|
|
24
|
+
async function readAll(body) {
|
|
25
|
+
if (body === null) {
|
|
26
|
+
return new Uint8Array(0);
|
|
27
|
+
}
|
|
28
|
+
const reader = body.getReader();
|
|
29
|
+
const chunks = [];
|
|
30
|
+
for (;;) {
|
|
31
|
+
const { done, value } = await reader.read();
|
|
32
|
+
if (done) {
|
|
33
|
+
break;
|
|
34
|
+
}
|
|
35
|
+
chunks.push(value);
|
|
36
|
+
}
|
|
37
|
+
const totalLength = chunks.reduce((acc, chunk) => acc + chunk.length, 0);
|
|
38
|
+
const result = new Uint8Array(totalLength);
|
|
39
|
+
let offset = 0;
|
|
40
|
+
for (const chunk of chunks) {
|
|
41
|
+
result.set(chunk, offset);
|
|
42
|
+
offset += chunk.length;
|
|
43
|
+
}
|
|
44
|
+
return result;
|
|
45
|
+
}
|
|
46
|
+
export async function executeHttpCall(opts) {
|
|
47
|
+
opts.logger.debug('HTTP request', {
|
|
48
|
+
method: opts.request.method,
|
|
49
|
+
url: opts.request.url,
|
|
50
|
+
});
|
|
51
|
+
let resp;
|
|
52
|
+
try {
|
|
53
|
+
resp = await opts.httpClient.send(opts.request);
|
|
54
|
+
}
|
|
55
|
+
catch (e) {
|
|
56
|
+
opts.logger.debug('HTTP request failed');
|
|
57
|
+
throw e;
|
|
58
|
+
}
|
|
59
|
+
const body = await readAll(resp.body);
|
|
60
|
+
opts.logger.debug('HTTP response', {
|
|
61
|
+
statusCode: resp.statusCode,
|
|
62
|
+
body: new TextDecoder().decode(body),
|
|
63
|
+
});
|
|
64
|
+
const apiErr = ApiError.fromHttpError(resp.statusCode, resp.headers, body);
|
|
65
|
+
if (apiErr !== undefined) {
|
|
66
|
+
throw apiErr;
|
|
67
|
+
}
|
|
68
|
+
return body;
|
|
69
|
+
}
|
|
70
|
+
export function buildHttpRequest(method, url, headers, signal, body) {
|
|
71
|
+
const req = { url, method, headers };
|
|
72
|
+
if (body !== undefined) {
|
|
73
|
+
req.body = body;
|
|
74
|
+
}
|
|
75
|
+
if (signal !== undefined) {
|
|
76
|
+
req.signal = signal;
|
|
77
|
+
}
|
|
78
|
+
return req;
|
|
79
|
+
}
|
|
80
|
+
export function parseResponse(body, schema) {
|
|
81
|
+
const text = new TextDecoder().decode(body);
|
|
82
|
+
const parsed = jsonBigint.parse(text);
|
|
83
|
+
return schema.parse(parsed);
|
|
84
|
+
}
|
|
85
|
+
export function marshalRequest(data, schema) {
|
|
86
|
+
return jsonBigint.stringify(schema.parse(data));
|
|
87
|
+
}
|
|
88
|
+
export function flattenQueryParams(prefix, value, params) {
|
|
89
|
+
if (value === null || value === undefined) {
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
if (Array.isArray(value)) {
|
|
93
|
+
// arrays of objects are not yet supported
|
|
94
|
+
for (const item of value) {
|
|
95
|
+
params.append(prefix, String(item));
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
else if (typeof value === 'object') {
|
|
99
|
+
for (const [key, val] of Object.entries(value)) {
|
|
100
|
+
flattenQueryParams(`${prefix}.${key}`, val, params);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
else if (typeof value === 'string' ||
|
|
104
|
+
typeof value === 'number' ||
|
|
105
|
+
typeof value === 'boolean' ||
|
|
106
|
+
typeof value === 'bigint') {
|
|
107
|
+
params.append(prefix, String(value));
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
throw new Error(`Unsupported query parameter type: ${typeof value}`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/v1/utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,41 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@databricks/sdk-logdelivery",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "
|
|
5
|
-
"
|
|
6
|
-
"
|
|
3
|
+
"version": "0.1.0-dev.2",
|
|
4
|
+
"description": "",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"exports": {
|
|
7
|
+
"./v1": {
|
|
8
|
+
"types": "./dist/v1/index.d.ts",
|
|
9
|
+
"import": "./dist/v1/index.js"
|
|
10
|
+
}
|
|
11
|
+
},
|
|
12
|
+
"files": [
|
|
13
|
+
"dist",
|
|
14
|
+
"src",
|
|
15
|
+
"LICENSE"
|
|
16
|
+
],
|
|
17
|
+
"scripts": {
|
|
18
|
+
"build": "tsc -b",
|
|
19
|
+
"lint": "eslint src --ext .ts",
|
|
20
|
+
"lint:fix": "eslint src --ext .ts --fix",
|
|
21
|
+
"format": "prettier --write \"src/**/*.ts\"",
|
|
22
|
+
"format:check": "prettier --check \"src/**/*.ts\"",
|
|
23
|
+
"typecheck": "tsc --noEmit",
|
|
24
|
+
"clean": "rm -rf dist tsconfig.tsbuildinfo",
|
|
25
|
+
"test": "echo 'no tests'",
|
|
26
|
+
"test:browser": "echo 'no tests'"
|
|
27
|
+
},
|
|
28
|
+
"author": "Databricks",
|
|
29
|
+
"license": "Apache-2.0",
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"@databricks/sdk-auth": ">=0.1.0-dev.3 <1.0.0",
|
|
32
|
+
"@databricks/sdk-core": ">=0.1.0-dev.4 <1.0.0",
|
|
33
|
+
"@databricks/sdk-options": ">=0.1.0-dev.3 <1.0.0",
|
|
34
|
+
"@js-temporal/polyfill": "^0.5.0",
|
|
35
|
+
"json-bigint": "^1.0.0",
|
|
36
|
+
"zod": "^4.3.6"
|
|
37
|
+
},
|
|
38
|
+
"engines": {
|
|
39
|
+
"node": ">=22.0.0"
|
|
40
|
+
}
|
|
7
41
|
}
|
package/src/v1/client.ts
ADDED
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
+
|
|
3
|
+
import {VERSION as AUTH_VERSION} from '@databricks/sdk-auth';
|
|
4
|
+
import {createDefault} from '@databricks/sdk-core/clientinfo';
|
|
5
|
+
import type {Logger} from '@databricks/sdk-core/logger';
|
|
6
|
+
import {NoOpLogger} from '@databricks/sdk-core/logger';
|
|
7
|
+
import type {CallOptions} from '@databricks/sdk-options/call';
|
|
8
|
+
import type {ClientOptions} from '@databricks/sdk-options/client';
|
|
9
|
+
import type {HttpClient} from '@databricks/sdk-core/http';
|
|
10
|
+
import {newHttpClient} from './transport';
|
|
11
|
+
import {
|
|
12
|
+
buildHttpRequest,
|
|
13
|
+
executeCall,
|
|
14
|
+
executeHttpCall,
|
|
15
|
+
marshalRequest,
|
|
16
|
+
parseResponse,
|
|
17
|
+
} from './utils';
|
|
18
|
+
import pkgJson from '../../package.json' with {type: 'json'};
|
|
19
|
+
import type {
|
|
20
|
+
CreateLogDeliveryConfigurationRequest,
|
|
21
|
+
CreateLogDeliveryConfigurationRequest_Response,
|
|
22
|
+
GetLogDeliveryConfigurationRequest,
|
|
23
|
+
GetLogDeliveryConfigurationRequest_Response,
|
|
24
|
+
ListLogDeliveryConfigurationRequest,
|
|
25
|
+
ListLogDeliveryConfigurationRequest_Response,
|
|
26
|
+
LogDeliveryConfiguration,
|
|
27
|
+
UpdateLogDeliveryConfigurationRequest,
|
|
28
|
+
UpdateLogDeliveryConfigurationRequest_Response,
|
|
29
|
+
} from './model';
|
|
30
|
+
import {
|
|
31
|
+
marshalCreateLogDeliveryConfigurationRequestSchema,
|
|
32
|
+
marshalUpdateLogDeliveryConfigurationRequestSchema,
|
|
33
|
+
unmarshalCreateLogDeliveryConfigurationRequest_ResponseSchema,
|
|
34
|
+
unmarshalGetLogDeliveryConfigurationRequest_ResponseSchema,
|
|
35
|
+
unmarshalListLogDeliveryConfigurationRequest_ResponseSchema,
|
|
36
|
+
unmarshalUpdateLogDeliveryConfigurationRequest_ResponseSchema,
|
|
37
|
+
} from './model';
|
|
38
|
+
|
|
39
|
+
// Package identity segment for this client to be used in the User-Agent header.
|
|
40
|
+
const PACKAGE_SEGMENT = {
|
|
41
|
+
key: 'sdk-js-' + pkgJson.name.replace(/^@[^/]+\/sdk-/, ''),
|
|
42
|
+
value: pkgJson.version,
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
export class LogDeliveryClient {
|
|
46
|
+
private readonly host: string;
|
|
47
|
+
// Fallback for endpoints whose path contains {account_id}. If the request
|
|
48
|
+
// already carries an accountId, that value wins.
|
|
49
|
+
private readonly accountId: string | undefined;
|
|
50
|
+
private readonly httpClient: HttpClient;
|
|
51
|
+
private readonly logger: Logger;
|
|
52
|
+
// User-Agent header value. Composed once at construction from
|
|
53
|
+
// createDefault() merged with this package's identity and the active
|
|
54
|
+
// credential's name.
|
|
55
|
+
private readonly userAgent: string;
|
|
56
|
+
|
|
57
|
+
constructor(options: ClientOptions) {
|
|
58
|
+
if (options.host === undefined) {
|
|
59
|
+
throw new Error('Host is required.');
|
|
60
|
+
}
|
|
61
|
+
this.host = options.host.replace(/\/$/, '');
|
|
62
|
+
this.accountId = options.accountId;
|
|
63
|
+
this.logger = options.logger ?? new NoOpLogger();
|
|
64
|
+
const info = createDefault()
|
|
65
|
+
.with(PACKAGE_SEGMENT)
|
|
66
|
+
.with({key: 'sdk-js-auth', value: AUTH_VERSION})
|
|
67
|
+
.with({key: 'auth', value: options.credentials?.name() ?? 'default'});
|
|
68
|
+
this.userAgent = info.toString();
|
|
69
|
+
this.httpClient = newHttpClient(options);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/**
|
|
73
|
+
* Creates a new <Databricks> log delivery configuration to enable delivery of the specified type of logs to your storage location.
|
|
74
|
+
* This requires that you already created a [credential object](:method:Credentials/Create) (which encapsulates a cross-account service IAM role)
|
|
75
|
+
* and a [storage configuration object](:method:Storage/Create) (which encapsulates an S3 bucket).
|
|
76
|
+
*
|
|
77
|
+
* For full details, including the required IAM role policies and bucket policies,
|
|
78
|
+
* see [Deliver and access billable usage logs](https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html)
|
|
79
|
+
* or [Configure audit logging](https://docs.databricks.com/administration-guide/account-settings/audit-logs.html).
|
|
80
|
+
*
|
|
81
|
+
* **Note**: There is a limit on the number of log delivery configurations available per account (each limit applies separately to each log type including billable usage and audit logs).
|
|
82
|
+
* You can create a maximum of two enabled account-level delivery configurations (configurations without a workspace filter) per type.
|
|
83
|
+
* Additionally, you can create two enabled workspace-level delivery configurations per workspace for each log type, which means that the same workspace ID can occur in the workspace filter for no more than two delivery configurations per log type.
|
|
84
|
+
*
|
|
85
|
+
* You cannot delete a log delivery configuration, but you can disable it (see [Enable or disable log delivery configuration](:method:LogDelivery/PatchStatus)).
|
|
86
|
+
*/
|
|
87
|
+
async createLogDeliveryConfiguration(
|
|
88
|
+
req: CreateLogDeliveryConfigurationRequest,
|
|
89
|
+
options?: CallOptions
|
|
90
|
+
): Promise<CreateLogDeliveryConfigurationRequest_Response> {
|
|
91
|
+
const url = `${this.host}/api/2.0/accounts/${req.logDeliveryConfiguration?.accountId ?? this.accountId ?? ''}/log-delivery`;
|
|
92
|
+
const body = marshalRequest(
|
|
93
|
+
req,
|
|
94
|
+
marshalCreateLogDeliveryConfigurationRequestSchema
|
|
95
|
+
);
|
|
96
|
+
let resp: CreateLogDeliveryConfigurationRequest_Response | undefined;
|
|
97
|
+
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
98
|
+
const headers = new Headers({'Content-Type': 'application/json'});
|
|
99
|
+
headers.set('User-Agent', this.userAgent);
|
|
100
|
+
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
101
|
+
const respBody = await executeHttpCall({
|
|
102
|
+
request: httpReq,
|
|
103
|
+
httpClient: this.httpClient,
|
|
104
|
+
logger: this.logger,
|
|
105
|
+
});
|
|
106
|
+
resp = parseResponse(
|
|
107
|
+
respBody,
|
|
108
|
+
unmarshalCreateLogDeliveryConfigurationRequest_ResponseSchema
|
|
109
|
+
);
|
|
110
|
+
};
|
|
111
|
+
await executeCall(call, options);
|
|
112
|
+
if (resp === undefined) {
|
|
113
|
+
throw new Error('operation completed without a result.');
|
|
114
|
+
}
|
|
115
|
+
return resp;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/** Gets a <Databricks> log delivery configuration object for an account, both specified by ID. */
|
|
119
|
+
async getLogDeliveryConfiguration(
|
|
120
|
+
req: GetLogDeliveryConfigurationRequest,
|
|
121
|
+
options?: CallOptions
|
|
122
|
+
): Promise<GetLogDeliveryConfigurationRequest_Response> {
|
|
123
|
+
const url = `${this.host}/api/2.0/accounts/${req.accountId ?? this.accountId ?? ''}/log-delivery/${req.configId ?? ''}`;
|
|
124
|
+
let resp: GetLogDeliveryConfigurationRequest_Response | undefined;
|
|
125
|
+
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
126
|
+
const headers = new Headers();
|
|
127
|
+
headers.set('User-Agent', this.userAgent);
|
|
128
|
+
const httpReq = buildHttpRequest('GET', url, headers, callSignal);
|
|
129
|
+
const respBody = await executeHttpCall({
|
|
130
|
+
request: httpReq,
|
|
131
|
+
httpClient: this.httpClient,
|
|
132
|
+
logger: this.logger,
|
|
133
|
+
});
|
|
134
|
+
resp = parseResponse(
|
|
135
|
+
respBody,
|
|
136
|
+
unmarshalGetLogDeliveryConfigurationRequest_ResponseSchema
|
|
137
|
+
);
|
|
138
|
+
};
|
|
139
|
+
await executeCall(call, options);
|
|
140
|
+
if (resp === undefined) {
|
|
141
|
+
throw new Error('operation completed without a result.');
|
|
142
|
+
}
|
|
143
|
+
return resp;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
/** Gets all <Databricks> log delivery configurations associated with an account specified by ID. */
|
|
147
|
+
async listLogDeliveryConfiguration(
|
|
148
|
+
req: ListLogDeliveryConfigurationRequest,
|
|
149
|
+
options?: CallOptions
|
|
150
|
+
): Promise<ListLogDeliveryConfigurationRequest_Response> {
|
|
151
|
+
const url = `${this.host}/api/2.0/accounts/${req.accountId ?? this.accountId ?? ''}/log-delivery`;
|
|
152
|
+
const params = new URLSearchParams();
|
|
153
|
+
if (req.credentialsId !== undefined) {
|
|
154
|
+
params.append('credentials_id', req.credentialsId);
|
|
155
|
+
}
|
|
156
|
+
if (req.storageConfigurationId !== undefined) {
|
|
157
|
+
params.append('storage_configuration_id', req.storageConfigurationId);
|
|
158
|
+
}
|
|
159
|
+
if (req.status !== undefined) {
|
|
160
|
+
params.append('status', req.status);
|
|
161
|
+
}
|
|
162
|
+
if (req.pageToken !== undefined) {
|
|
163
|
+
params.append('page_token', req.pageToken);
|
|
164
|
+
}
|
|
165
|
+
const query = params.toString();
|
|
166
|
+
const fullUrl = query !== '' ? `${url}?${query}` : url;
|
|
167
|
+
let resp: ListLogDeliveryConfigurationRequest_Response | undefined;
|
|
168
|
+
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
169
|
+
const headers = new Headers();
|
|
170
|
+
headers.set('User-Agent', this.userAgent);
|
|
171
|
+
const httpReq = buildHttpRequest('GET', fullUrl, headers, callSignal);
|
|
172
|
+
const respBody = await executeHttpCall({
|
|
173
|
+
request: httpReq,
|
|
174
|
+
httpClient: this.httpClient,
|
|
175
|
+
logger: this.logger,
|
|
176
|
+
});
|
|
177
|
+
resp = parseResponse(
|
|
178
|
+
respBody,
|
|
179
|
+
unmarshalListLogDeliveryConfigurationRequest_ResponseSchema
|
|
180
|
+
);
|
|
181
|
+
};
|
|
182
|
+
await executeCall(call, options);
|
|
183
|
+
if (resp === undefined) {
|
|
184
|
+
throw new Error('operation completed without a result.');
|
|
185
|
+
}
|
|
186
|
+
return resp;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
async *listLogDeliveryConfigurationIter(
|
|
190
|
+
req: ListLogDeliveryConfigurationRequest,
|
|
191
|
+
options?: CallOptions
|
|
192
|
+
): AsyncGenerator<LogDeliveryConfiguration> {
|
|
193
|
+
const pageReq: ListLogDeliveryConfigurationRequest = {...req};
|
|
194
|
+
for (;;) {
|
|
195
|
+
const resp = await this.listLogDeliveryConfiguration(pageReq, options);
|
|
196
|
+
for (const item of resp.logDeliveryConfigurations ?? []) {
|
|
197
|
+
yield item;
|
|
198
|
+
}
|
|
199
|
+
if (resp.nextPageToken === undefined || resp.nextPageToken === '') {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
pageReq.pageToken = resp.nextPageToken;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
/**
|
|
207
|
+
* Enables or disables a log delivery configuration.
|
|
208
|
+
* Deletion of delivery configurations is not supported, so disable log delivery configurations that are no longer needed.
|
|
209
|
+
* Note that you can't re-enable a delivery configuration if this would violate the delivery configuration limits described under [Create log delivery](:method:LogDelivery/Create).
|
|
210
|
+
*/
|
|
211
|
+
async updateLogDeliveryConfiguration(
|
|
212
|
+
req: UpdateLogDeliveryConfigurationRequest,
|
|
213
|
+
options?: CallOptions
|
|
214
|
+
): Promise<UpdateLogDeliveryConfigurationRequest_Response> {
|
|
215
|
+
const url = `${this.host}/api/2.0/accounts/${req.accountId ?? this.accountId ?? ''}/log-delivery/${req.configId ?? ''}`;
|
|
216
|
+
const body = marshalRequest(
|
|
217
|
+
req,
|
|
218
|
+
marshalUpdateLogDeliveryConfigurationRequestSchema
|
|
219
|
+
);
|
|
220
|
+
let resp: UpdateLogDeliveryConfigurationRequest_Response | undefined;
|
|
221
|
+
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
222
|
+
const headers = new Headers({'Content-Type': 'application/json'});
|
|
223
|
+
headers.set('User-Agent', this.userAgent);
|
|
224
|
+
const httpReq = buildHttpRequest('PATCH', url, headers, callSignal, body);
|
|
225
|
+
const respBody = await executeHttpCall({
|
|
226
|
+
request: httpReq,
|
|
227
|
+
httpClient: this.httpClient,
|
|
228
|
+
logger: this.logger,
|
|
229
|
+
});
|
|
230
|
+
resp = parseResponse(
|
|
231
|
+
respBody,
|
|
232
|
+
unmarshalUpdateLogDeliveryConfigurationRequest_ResponseSchema
|
|
233
|
+
);
|
|
234
|
+
};
|
|
235
|
+
await executeCall(call, options);
|
|
236
|
+
if (resp === undefined) {
|
|
237
|
+
throw new Error('operation completed without a result.');
|
|
238
|
+
}
|
|
239
|
+
return resp;
|
|
240
|
+
}
|
|
241
|
+
}
|
package/src/v1/index.ts
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
+
|
|
3
|
+
export {LogDeliveryClient} from './client';
|
|
4
|
+
|
|
5
|
+
export {
|
|
6
|
+
LogDeliveryConfigStatus,
|
|
7
|
+
LogDeliveryOutputFormat,
|
|
8
|
+
LogDeliveryStatusEnum,
|
|
9
|
+
LogDeliveryType,
|
|
10
|
+
} from './model';
|
|
11
|
+
|
|
12
|
+
export type {
|
|
13
|
+
CreateLogDeliveryConfigurationParams,
|
|
14
|
+
CreateLogDeliveryConfigurationRequest,
|
|
15
|
+
CreateLogDeliveryConfigurationRequest_Response,
|
|
16
|
+
GetLogDeliveryConfigurationRequest,
|
|
17
|
+
GetLogDeliveryConfigurationRequest_Response,
|
|
18
|
+
ListLogDeliveryConfigurationRequest,
|
|
19
|
+
ListLogDeliveryConfigurationRequest_Response,
|
|
20
|
+
LogDeliveryConfiguration,
|
|
21
|
+
LogDeliveryStatus,
|
|
22
|
+
UpdateLogDeliveryConfigurationRequest,
|
|
23
|
+
UpdateLogDeliveryConfigurationRequest_Response,
|
|
24
|
+
} from './model';
|