@databricks/sdk-instanceprofiles 0.1.0-dev.3 → 0.1.0-dev.5
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 +28 -0
- package/dist/v2/client.d.ts +3 -3
- package/dist/v2/client.d.ts.map +1 -1
- package/dist/v2/client.js +31 -29
- package/dist/v2/client.js.map +1 -1
- package/dist/v2/transport.d.ts +30 -2
- package/dist/v2/transport.d.ts.map +1 -1
- package/dist/v2/transport.js +33 -16
- package/dist/v2/transport.js.map +1 -1
- package/dist/v2/utils.d.ts.map +1 -1
- package/dist/v2/utils.js +2 -1
- package/dist/v2/utils.js.map +1 -1
- package/package.json +9 -5
- package/src/v2/client.ts +0 -223
- package/src/v2/index.ts +0 -15
- package/src/v2/model.ts +0 -166
- package/src/v2/transport.ts +0 -73
- package/src/v2/utils.ts +0 -156
package/README.md
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
# @databricks/sdk-instanceprofiles
|
|
2
|
+
|
|
3
|
+
> [!WARNING]
|
|
4
|
+
>
|
|
5
|
+
> ## PREVIEW - NOT FOR PRODUCTION USE
|
|
6
|
+
>
|
|
7
|
+
> **This SDK is in preview and is subject to change without notice.**
|
|
8
|
+
>
|
|
9
|
+
> - **Do NOT use in production environments**
|
|
10
|
+
> - **Breaking changes may occur at any time**
|
|
11
|
+
> - **APIs are experimental and unstable**
|
|
12
|
+
> - **Use for development and testing only**
|
|
13
|
+
|
|
14
|
+
## Installation
|
|
15
|
+
|
|
16
|
+
```bash
|
|
17
|
+
npm install @databricks/sdk-instanceprofiles
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
## Usage
|
|
21
|
+
|
|
22
|
+
```typescript
|
|
23
|
+
import {InstanceProfilesClient} from '@databricks/sdk-instanceprofiles/v2';
|
|
24
|
+
|
|
25
|
+
const client = new InstanceProfilesClient({});
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
For a full getting-started guide, see the [root README](../../README.md).
|
package/dist/v2/client.d.ts
CHANGED
|
@@ -2,12 +2,12 @@ import type { CallOptions } from '@databricks/sdk-options/call';
|
|
|
2
2
|
import type { ClientOptions } from '@databricks/sdk-options/client';
|
|
3
3
|
import type { AddInstanceProfileRequest, AddInstanceProfileResponse, EditInstanceProfileRequest, EditInstanceProfileResponse, ListInstanceProfilesRequest, ListInstanceProfilesResponse, RemoveInstanceProfileRequest, RemoveInstanceProfileResponse } from './model';
|
|
4
4
|
export declare class InstanceProfilesClient {
|
|
5
|
-
private readonly
|
|
6
|
-
private readonly workspaceId;
|
|
7
|
-
private readonly httpClient;
|
|
5
|
+
private readonly options;
|
|
8
6
|
private readonly logger;
|
|
9
7
|
private readonly userAgent;
|
|
8
|
+
private config;
|
|
10
9
|
constructor(options: ClientOptions);
|
|
10
|
+
private resolveConfig;
|
|
11
11
|
/**
|
|
12
12
|
* Registers an instance profile in <Databricks>. In the UI, you can then give users the permission
|
|
13
13
|
* to use this instance profile when launching clusters.
|
package/dist/v2/client.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/v2/client.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,8BAA8B,CAAC;AAC9D,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,gCAAgC,CAAC;AAWlE,OAAO,KAAK,EACV,yBAAyB,EACzB,0BAA0B,EAC1B,0BAA0B,EAC1B,2BAA2B,EAC3B,2BAA2B,EAC3B,4BAA4B,EAC5B,4BAA4B,EAC5B,6BAA6B,EAC9B,MAAM,SAAS,CAAC;AAiBjB,qBAAa,sBAAsB;IACjC,OAAO,CAAC,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/v2/client.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,8BAA8B,CAAC;AAC9D,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,gCAAgC,CAAC;AAWlE,OAAO,KAAK,EACV,yBAAyB,EACzB,0BAA0B,EAC1B,0BAA0B,EAC1B,2BAA2B,EAC3B,2BAA2B,EAC3B,4BAA4B,EAC5B,4BAA4B,EAC5B,6BAA6B,EAC9B,MAAM,SAAS,CAAC;AAiBjB,qBAAa,sBAAsB;IACjC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;IACxC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAIhC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IAInC,OAAO,CAAC,MAAM,CAA4C;gBAE9C,OAAO,EAAE,aAAa;IAUlC,OAAO,CAAC,aAAa;IAKrB;;;;;OAKG;IACG,kBAAkB,CACtB,GAAG,EAAE,yBAAyB,EAC9B,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,0BAA0B,CAAC;IA0BtC;;;;;;;;;;;;;OAaG;IACG,mBAAmB,CACvB,GAAG,EAAE,0BAA0B,EAC/B,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,2BAA2B,CAAC;IA6BvC;;;;OAIG;IACG,oBAAoB,CACxB,IAAI,EAAE,2BAA2B,EACjC,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,4BAA4B,CAAC;IA4BxC;;;;;OAKG;IACG,qBAAqB,CACzB,GAAG,EAAE,4BAA4B,EACjC,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,6BAA6B,CAAC;CA4B1C"}
|
package/dist/v2/client.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { VERSION as AUTH_VERSION } from '@databricks/sdk-auth';
|
|
3
3
|
import { createDefault } from '@databricks/sdk-core/clientinfo';
|
|
4
4
|
import { NoOpLogger } from '@databricks/sdk-core/logger';
|
|
5
|
-
import {
|
|
5
|
+
import { resolveClientConfig } from './transport';
|
|
6
6
|
import { buildHttpRequest, executeCall, executeHttpCall, marshalRequest, parseResponse, } from './utils';
|
|
7
7
|
import pkgJson from '../../package.json' with { type: 'json' };
|
|
8
8
|
import { marshalAddInstanceProfileRequestSchema, marshalEditInstanceProfileRequestSchema, marshalRemoveInstanceProfileRequestSchema, unmarshalAddInstanceProfileResponseSchema, unmarshalEditInstanceProfileResponseSchema, unmarshalListInstanceProfilesResponseSchema, unmarshalRemoveInstanceProfileResponseSchema, } from './model';
|
|
@@ -12,30 +12,28 @@ const PACKAGE_SEGMENT = {
|
|
|
12
12
|
value: pkgJson.version,
|
|
13
13
|
};
|
|
14
14
|
export class InstanceProfilesClient {
|
|
15
|
-
|
|
16
|
-
// Workspace ID used to route workspace-level calls on unified hosts (SPOG).
|
|
17
|
-
// When set, workspace-level methods send X-Databricks-Org-Id on every
|
|
18
|
-
// request.
|
|
19
|
-
workspaceId;
|
|
20
|
-
httpClient;
|
|
15
|
+
options;
|
|
21
16
|
logger;
|
|
22
17
|
// User-Agent header value. Composed once at construction from
|
|
23
18
|
// createDefault() merged with this package's identity and the active
|
|
24
19
|
// credential's name.
|
|
25
20
|
userAgent;
|
|
21
|
+
// Memoized configuration. The profile is resolved once, lazily, on the first
|
|
22
|
+
// request, then reused; host, workspaceId/accountId, and credentials are
|
|
23
|
+
// filled from it when not set explicitly on the options.
|
|
24
|
+
config;
|
|
26
25
|
constructor(options) {
|
|
27
|
-
|
|
28
|
-
throw new Error('Host is required.');
|
|
29
|
-
}
|
|
30
|
-
this.host = options.host.replace(/\/$/, '');
|
|
31
|
-
this.workspaceId = options.workspaceId;
|
|
26
|
+
this.options = options;
|
|
32
27
|
this.logger = options.logger ?? new NoOpLogger();
|
|
33
28
|
const info = createDefault()
|
|
34
29
|
.with(PACKAGE_SEGMENT)
|
|
35
30
|
.with({ key: 'sdk-js-auth', value: AUTH_VERSION })
|
|
36
31
|
.with({ key: 'auth', value: options.credentials?.name() ?? 'default' });
|
|
37
32
|
this.userAgent = info.toString();
|
|
38
|
-
|
|
33
|
+
}
|
|
34
|
+
resolveConfig() {
|
|
35
|
+
this.config ??= resolveClientConfig(this.options);
|
|
36
|
+
return this.config;
|
|
39
37
|
}
|
|
40
38
|
/**
|
|
41
39
|
* Registers an instance profile in <Databricks>. In the UI, you can then give users the permission
|
|
@@ -44,19 +42,20 @@ export class InstanceProfilesClient {
|
|
|
44
42
|
* This API is only available to admin users.
|
|
45
43
|
*/
|
|
46
44
|
async addInstanceProfile(req, options) {
|
|
47
|
-
const
|
|
45
|
+
const { host, workspaceId, httpClient } = await this.resolveConfig();
|
|
46
|
+
const url = `${host}/api/2.0/instance-profiles/add`;
|
|
48
47
|
const body = marshalRequest(req, marshalAddInstanceProfileRequestSchema);
|
|
49
48
|
let resp;
|
|
50
49
|
const call = async (callSignal) => {
|
|
51
50
|
const headers = new Headers({ 'Content-Type': 'application/json' });
|
|
52
|
-
if (
|
|
53
|
-
headers.set('X-Databricks-Org-Id',
|
|
51
|
+
if (workspaceId !== undefined) {
|
|
52
|
+
headers.set('X-Databricks-Org-Id', workspaceId);
|
|
54
53
|
}
|
|
55
54
|
headers.set('User-Agent', this.userAgent);
|
|
56
55
|
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
57
56
|
const respBody = await executeHttpCall({
|
|
58
57
|
request: httpReq,
|
|
59
|
-
httpClient
|
|
58
|
+
httpClient,
|
|
60
59
|
logger: this.logger,
|
|
61
60
|
});
|
|
62
61
|
resp = parseResponse(respBody, unmarshalAddInstanceProfileResponseSchema);
|
|
@@ -82,19 +81,20 @@ export class InstanceProfilesClient {
|
|
|
82
81
|
* This API is only available to admin users.
|
|
83
82
|
*/
|
|
84
83
|
async editInstanceProfile(req, options) {
|
|
85
|
-
const
|
|
84
|
+
const { host, workspaceId, httpClient } = await this.resolveConfig();
|
|
85
|
+
const url = `${host}/api/2.0/instance-profiles/edit`;
|
|
86
86
|
const body = marshalRequest(req, marshalEditInstanceProfileRequestSchema);
|
|
87
87
|
let resp;
|
|
88
88
|
const call = async (callSignal) => {
|
|
89
89
|
const headers = new Headers({ 'Content-Type': 'application/json' });
|
|
90
|
-
if (
|
|
91
|
-
headers.set('X-Databricks-Org-Id',
|
|
90
|
+
if (workspaceId !== undefined) {
|
|
91
|
+
headers.set('X-Databricks-Org-Id', workspaceId);
|
|
92
92
|
}
|
|
93
93
|
headers.set('User-Agent', this.userAgent);
|
|
94
94
|
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
95
95
|
const respBody = await executeHttpCall({
|
|
96
96
|
request: httpReq,
|
|
97
|
-
httpClient
|
|
97
|
+
httpClient,
|
|
98
98
|
logger: this.logger,
|
|
99
99
|
});
|
|
100
100
|
resp = parseResponse(respBody, unmarshalEditInstanceProfileResponseSchema);
|
|
@@ -111,18 +111,19 @@ export class InstanceProfilesClient {
|
|
|
111
111
|
* This API is available to all users.
|
|
112
112
|
*/
|
|
113
113
|
async listInstanceProfiles(_req, options) {
|
|
114
|
-
const
|
|
114
|
+
const { host, workspaceId, httpClient } = await this.resolveConfig();
|
|
115
|
+
const url = `${host}/api/2.0/instance-profiles/list`;
|
|
115
116
|
let resp;
|
|
116
117
|
const call = async (callSignal) => {
|
|
117
118
|
const headers = new Headers();
|
|
118
|
-
if (
|
|
119
|
-
headers.set('X-Databricks-Org-Id',
|
|
119
|
+
if (workspaceId !== undefined) {
|
|
120
|
+
headers.set('X-Databricks-Org-Id', workspaceId);
|
|
120
121
|
}
|
|
121
122
|
headers.set('User-Agent', this.userAgent);
|
|
122
123
|
const httpReq = buildHttpRequest('GET', url, headers, callSignal);
|
|
123
124
|
const respBody = await executeHttpCall({
|
|
124
125
|
request: httpReq,
|
|
125
|
-
httpClient
|
|
126
|
+
httpClient,
|
|
126
127
|
logger: this.logger,
|
|
127
128
|
});
|
|
128
129
|
resp = parseResponse(respBody, unmarshalListInstanceProfilesResponseSchema);
|
|
@@ -140,19 +141,20 @@ export class InstanceProfilesClient {
|
|
|
140
141
|
* This API is only accessible to admin users.
|
|
141
142
|
*/
|
|
142
143
|
async removeInstanceProfile(req, options) {
|
|
143
|
-
const
|
|
144
|
+
const { host, workspaceId, httpClient } = await this.resolveConfig();
|
|
145
|
+
const url = `${host}/api/2.0/instance-profiles/remove`;
|
|
144
146
|
const body = marshalRequest(req, marshalRemoveInstanceProfileRequestSchema);
|
|
145
147
|
let resp;
|
|
146
148
|
const call = async (callSignal) => {
|
|
147
149
|
const headers = new Headers({ 'Content-Type': 'application/json' });
|
|
148
|
-
if (
|
|
149
|
-
headers.set('X-Databricks-Org-Id',
|
|
150
|
+
if (workspaceId !== undefined) {
|
|
151
|
+
headers.set('X-Databricks-Org-Id', workspaceId);
|
|
150
152
|
}
|
|
151
153
|
headers.set('User-Agent', this.userAgent);
|
|
152
154
|
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
153
155
|
const respBody = await executeHttpCall({
|
|
154
156
|
request: httpReq,
|
|
155
|
-
httpClient
|
|
157
|
+
httpClient,
|
|
156
158
|
logger: this.logger,
|
|
157
159
|
});
|
|
158
160
|
resp = parseResponse(respBody, unmarshalRemoveInstanceProfileResponseSchema);
|
package/dist/v2/client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/v2/client.ts"],"names":[],"mappings":"AAAA,+EAA+E;AAE/E,OAAO,EAAC,OAAO,IAAI,YAAY,EAAC,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAC,aAAa,EAAC,MAAM,iCAAiC,CAAC;AAE9D,OAAO,EAAC,UAAU,EAAC,MAAM,6BAA6B,CAAC;AAIvD,OAAO,EAAC,
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/v2/client.ts"],"names":[],"mappings":"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"}
|
package/dist/v2/transport.d.ts
CHANGED
|
@@ -1,5 +1,33 @@
|
|
|
1
1
|
import type { HttpClient } from '@databricks/sdk-core/http';
|
|
2
2
|
import type { ClientOptions } from '@databricks/sdk-options/client';
|
|
3
|
-
/**
|
|
4
|
-
|
|
3
|
+
/**
|
|
4
|
+
* The configuration a client needs to issue requests, resolved from
|
|
5
|
+
* {@link ClientOptions} and a configuration profile.
|
|
6
|
+
*/
|
|
7
|
+
export interface ResolvedClientConfig {
|
|
8
|
+
/** Host with any trailing slash removed. */
|
|
9
|
+
host: string;
|
|
10
|
+
/**
|
|
11
|
+
* Default account ID for account-level paths that contain an account_id
|
|
12
|
+
* segment. A request's own accountId still wins.
|
|
13
|
+
*/
|
|
14
|
+
accountId?: string;
|
|
15
|
+
/**
|
|
16
|
+
* Workspace ID used to route workspace-level calls on unified hosts (SPOG).
|
|
17
|
+
*/
|
|
18
|
+
workspaceId?: string;
|
|
19
|
+
/** HTTP client with authentication, and any configured timeout, applied. */
|
|
20
|
+
httpClient: HttpClient;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Resolves {@link ClientOptions} into a {@link ResolvedClientConfig}.
|
|
24
|
+
*
|
|
25
|
+
* A configuration profile is always resolved from the config file and
|
|
26
|
+
* environment variables (per options.profileOptions); it supplies host,
|
|
27
|
+
* accountId, workspaceId, and credentials wherever the caller did not set them
|
|
28
|
+
* explicitly. Explicit options always take precedence.
|
|
29
|
+
*
|
|
30
|
+
* @throws if host is neither provided nor present in the resolved profile.
|
|
31
|
+
*/
|
|
32
|
+
export declare function resolveClientConfig(options: ClientOptions): Promise<ResolvedClientConfig>;
|
|
5
33
|
//# sourceMappingURL=transport.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../src/v2/transport.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,UAAU,EAGX,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../src/v2/transport.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,UAAU,EAGX,MAAM,2BAA2B,CAAC;AAInC,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,gCAAgC,CAAC;AAElE;;;GAGG;AACH,MAAM,WAAW,oBAAoB;IACnC,4CAA4C;IAC5C,IAAI,EAAE,MAAM,CAAC;IAEb;;;OAGG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,4EAA4E;IAC5E,UAAU,EAAE,UAAU,CAAC;CACxB;AAED;;;;;;;;;GASG;AACH,wBAAsB,mBAAmB,CACvC,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,oBAAoB,CAAC,CA4B/B"}
|
package/dist/v2/transport.js
CHANGED
|
@@ -1,24 +1,41 @@
|
|
|
1
1
|
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
2
|
import { defaultCredentials } from '@databricks/sdk-auth/credentials';
|
|
3
3
|
import { newFetchHttpClient } from '@databricks/sdk-core/http';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
4
|
+
import { resolve } from '@databricks/sdk-core/profiles';
|
|
5
|
+
/**
|
|
6
|
+
* Resolves {@link ClientOptions} into a {@link ResolvedClientConfig}.
|
|
7
|
+
*
|
|
8
|
+
* A configuration profile is always resolved from the config file and
|
|
9
|
+
* environment variables (per options.profileOptions); it supplies host,
|
|
10
|
+
* accountId, workspaceId, and credentials wherever the caller did not set them
|
|
11
|
+
* explicitly. Explicit options always take precedence.
|
|
12
|
+
*
|
|
13
|
+
* @throws if host is neither provided nor present in the resolved profile.
|
|
14
|
+
*/
|
|
15
|
+
export async function resolveClientConfig(options) {
|
|
16
|
+
const profile = await resolve(options.profileOptions);
|
|
17
|
+
const host = options.host ?? profile.host;
|
|
18
|
+
if (host === undefined) {
|
|
19
|
+
throw new Error('Host is required.');
|
|
14
20
|
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
21
|
+
// The provided httpClient (or the default fetch client) is the base wire;
|
|
22
|
+
// authentication and the optional timeout are layered on top of it. The
|
|
23
|
+
// default credential chain reuses the profile resolved above so that the
|
|
24
|
+
// same profileOptions govern host and authentication alike.
|
|
25
|
+
const base = options.httpClient ?? newFetchHttpClient();
|
|
26
|
+
const credentials = options.credentials ?? defaultCredentials({ profile });
|
|
27
|
+
let httpClient = new AuthHttpClient(base, credentials);
|
|
28
|
+
if (options.timeout !== undefined) {
|
|
29
|
+
httpClient = new TimeoutHttpClient(httpClient, options.timeout);
|
|
20
30
|
}
|
|
21
|
-
|
|
31
|
+
const accountId = options.accountId ?? profile.accountId;
|
|
32
|
+
const workspaceId = options.workspaceId ?? profile.workspaceId;
|
|
33
|
+
return {
|
|
34
|
+
host: host.replace(/\/$/, ''),
|
|
35
|
+
httpClient,
|
|
36
|
+
...(accountId !== undefined && { accountId }),
|
|
37
|
+
...(workspaceId !== undefined && { workspaceId }),
|
|
38
|
+
};
|
|
22
39
|
}
|
|
23
40
|
/** Wraps an HttpClient and adds authentication headers to requests. */
|
|
24
41
|
class AuthHttpClient {
|
package/dist/v2/transport.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../src/v2/transport.ts"],"names":[],"mappings":"AAAA,+EAA+E;AAG/E,OAAO,EAAC,kBAAkB,EAAC,MAAM,kCAAkC,CAAC;AAMpE,OAAO,EAAC,kBAAkB,EAAC,MAAM,2BAA2B,CAAC;
|
|
1
|
+
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../src/v2/transport.ts"],"names":[],"mappings":"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"}
|
package/dist/v2/utils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/v2/utils.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,UAAU,EACV,WAAW,EAEZ,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,6BAA6B,CAAC;AACxD,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,KAAK,EAAC,CAAC,EAAC,MAAM,KAAK,CAAC;AAO3B,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,OAAO,EAAE,WAAW,CAAC;IAC9B,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB;AAED;;;;GAIG;AACH,wBAAsB,WAAW,CAC/B,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,EAC7C,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,IAAI,CAAC,CASf;AA2BD,wBAAsB,eAAe,CACnC,IAAI,EAAE,eAAe,GACpB,OAAO,CAAC,UAAU,CAAC,CA2BrB;AAED,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,OAAO,EAChB,MAAM,CAAC,EAAE,WAAW,EACpB,IAAI,CAAC,EAAE,MAAM,GAAG,cAAc,CAAC,UAAU,CAAC,GACzC,WAAW,CASb;AAED,wBAAgB,aAAa,CAAC,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/v2/utils.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,UAAU,EACV,WAAW,EAEZ,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,6BAA6B,CAAC;AACxD,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,KAAK,EAAC,CAAC,EAAC,MAAM,KAAK,CAAC;AAO3B,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,OAAO,EAAE,WAAW,CAAC;IAC9B,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB;AAED;;;;GAIG;AACH,wBAAsB,WAAW,CAC/B,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,EAC7C,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,IAAI,CAAC,CASf;AA2BD,wBAAsB,eAAe,CACnC,IAAI,EAAE,eAAe,GACpB,OAAO,CAAC,UAAU,CAAC,CA2BrB;AAED,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,OAAO,EAChB,MAAM,CAAC,EAAE,WAAW,EACpB,IAAI,CAAC,EAAE,MAAM,GAAG,cAAc,CAAC,UAAU,CAAC,GACzC,WAAW,CASb;AAED,wBAAgB,aAAa,CAAC,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAK1E;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC,OAAO,GAAG,MAAM,CAEvE;AAED,wBAAgB,kBAAkB,CAChC,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,OAAO,EACd,MAAM,EAAE,eAAe,GACtB,IAAI,CAuBN"}
|
package/dist/v2/utils.js
CHANGED
|
@@ -79,7 +79,8 @@ export function buildHttpRequest(method, url, headers, signal, body) {
|
|
|
79
79
|
}
|
|
80
80
|
export function parseResponse(body, schema) {
|
|
81
81
|
const text = new TextDecoder().decode(body);
|
|
82
|
-
|
|
82
|
+
// 204 responses return an empty body; treat as `{}`.
|
|
83
|
+
const parsed = text === '' ? {} : jsonBigint.parse(text);
|
|
83
84
|
return schema.parse(parsed);
|
|
84
85
|
}
|
|
85
86
|
export function marshalRequest(data, schema) {
|
package/dist/v2/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/v2/utils.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/v2/utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@databricks/sdk-instanceprofiles",
|
|
3
|
-
"version": "0.1.0-dev.
|
|
3
|
+
"version": "0.1.0-dev.5",
|
|
4
4
|
"description": "",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -12,7 +12,6 @@
|
|
|
12
12
|
},
|
|
13
13
|
"files": [
|
|
14
14
|
"dist",
|
|
15
|
-
"src",
|
|
16
15
|
"LICENSE"
|
|
17
16
|
],
|
|
18
17
|
"scripts": {
|
|
@@ -28,10 +27,15 @@
|
|
|
28
27
|
},
|
|
29
28
|
"author": "Databricks",
|
|
30
29
|
"license": "Apache-2.0",
|
|
30
|
+
"repository": {
|
|
31
|
+
"type": "git",
|
|
32
|
+
"url": "https://github.com/databricks/sdk-js.git",
|
|
33
|
+
"directory": "packages/instanceprofiles"
|
|
34
|
+
},
|
|
31
35
|
"dependencies": {
|
|
32
|
-
"@databricks/sdk-auth": ">=0.1.0-dev.
|
|
33
|
-
"@databricks/sdk-core": ">=0.1.0-dev.
|
|
34
|
-
"@databricks/sdk-options": ">=0.1.0-dev.
|
|
36
|
+
"@databricks/sdk-auth": ">=0.1.0-dev.6 <1.0.0",
|
|
37
|
+
"@databricks/sdk-core": ">=0.1.0-dev.7 <1.0.0",
|
|
38
|
+
"@databricks/sdk-options": ">=0.1.0-dev.6 <1.0.0",
|
|
35
39
|
"@js-temporal/polyfill": "^0.5.0",
|
|
36
40
|
"json-bigint": "^1.0.0",
|
|
37
41
|
"zod": "^4.3.6"
|
package/src/v2/client.ts
DELETED
|
@@ -1,223 +0,0 @@
|
|
|
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
|
-
AddInstanceProfileRequest,
|
|
21
|
-
AddInstanceProfileResponse,
|
|
22
|
-
EditInstanceProfileRequest,
|
|
23
|
-
EditInstanceProfileResponse,
|
|
24
|
-
ListInstanceProfilesRequest,
|
|
25
|
-
ListInstanceProfilesResponse,
|
|
26
|
-
RemoveInstanceProfileRequest,
|
|
27
|
-
RemoveInstanceProfileResponse,
|
|
28
|
-
} from './model';
|
|
29
|
-
import {
|
|
30
|
-
marshalAddInstanceProfileRequestSchema,
|
|
31
|
-
marshalEditInstanceProfileRequestSchema,
|
|
32
|
-
marshalRemoveInstanceProfileRequestSchema,
|
|
33
|
-
unmarshalAddInstanceProfileResponseSchema,
|
|
34
|
-
unmarshalEditInstanceProfileResponseSchema,
|
|
35
|
-
unmarshalListInstanceProfilesResponseSchema,
|
|
36
|
-
unmarshalRemoveInstanceProfileResponseSchema,
|
|
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 InstanceProfilesClient {
|
|
46
|
-
private readonly host: string;
|
|
47
|
-
// Workspace ID used to route workspace-level calls on unified hosts (SPOG).
|
|
48
|
-
// When set, workspace-level methods send X-Databricks-Org-Id on every
|
|
49
|
-
// request.
|
|
50
|
-
private readonly workspaceId: string | undefined;
|
|
51
|
-
private readonly httpClient: HttpClient;
|
|
52
|
-
private readonly logger: Logger;
|
|
53
|
-
// User-Agent header value. Composed once at construction from
|
|
54
|
-
// createDefault() merged with this package's identity and the active
|
|
55
|
-
// credential's name.
|
|
56
|
-
private readonly userAgent: string;
|
|
57
|
-
|
|
58
|
-
constructor(options: ClientOptions) {
|
|
59
|
-
if (options.host === undefined) {
|
|
60
|
-
throw new Error('Host is required.');
|
|
61
|
-
}
|
|
62
|
-
this.host = options.host.replace(/\/$/, '');
|
|
63
|
-
this.workspaceId = options.workspaceId;
|
|
64
|
-
this.logger = options.logger ?? new NoOpLogger();
|
|
65
|
-
const info = createDefault()
|
|
66
|
-
.with(PACKAGE_SEGMENT)
|
|
67
|
-
.with({key: 'sdk-js-auth', value: AUTH_VERSION})
|
|
68
|
-
.with({key: 'auth', value: options.credentials?.name() ?? 'default'});
|
|
69
|
-
this.userAgent = info.toString();
|
|
70
|
-
this.httpClient = newHttpClient(options);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
/**
|
|
74
|
-
* Registers an instance profile in <Databricks>. In the UI, you can then give users the permission
|
|
75
|
-
* to use this instance profile when launching clusters.
|
|
76
|
-
*
|
|
77
|
-
* This API is only available to admin users.
|
|
78
|
-
*/
|
|
79
|
-
async addInstanceProfile(
|
|
80
|
-
req: AddInstanceProfileRequest,
|
|
81
|
-
options?: CallOptions
|
|
82
|
-
): Promise<AddInstanceProfileResponse> {
|
|
83
|
-
const url = `${this.host}/api/2.0/instance-profiles/add`;
|
|
84
|
-
const body = marshalRequest(req, marshalAddInstanceProfileRequestSchema);
|
|
85
|
-
let resp: AddInstanceProfileResponse | undefined;
|
|
86
|
-
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
87
|
-
const headers = new Headers({'Content-Type': 'application/json'});
|
|
88
|
-
if (this.workspaceId !== undefined) {
|
|
89
|
-
headers.set('X-Databricks-Org-Id', this.workspaceId);
|
|
90
|
-
}
|
|
91
|
-
headers.set('User-Agent', this.userAgent);
|
|
92
|
-
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
93
|
-
const respBody = await executeHttpCall({
|
|
94
|
-
request: httpReq,
|
|
95
|
-
httpClient: this.httpClient,
|
|
96
|
-
logger: this.logger,
|
|
97
|
-
});
|
|
98
|
-
resp = parseResponse(respBody, unmarshalAddInstanceProfileResponseSchema);
|
|
99
|
-
};
|
|
100
|
-
await executeCall(call, options);
|
|
101
|
-
if (resp === undefined) {
|
|
102
|
-
throw new Error('operation completed without a result.');
|
|
103
|
-
}
|
|
104
|
-
return resp;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* The only supported field to change is the optional IAM role ARN associated with
|
|
109
|
-
* the instance profile. It is required to specify the IAM role ARN if both of
|
|
110
|
-
* the following are true:
|
|
111
|
-
*
|
|
112
|
-
* * Your role name and instance profile name do not match. The name is the part
|
|
113
|
-
* after the last slash in each ARN.
|
|
114
|
-
* * You want to use the instance profile with [Databricks SQL Serverless](/sql/admin/serverless.html).
|
|
115
|
-
*
|
|
116
|
-
* To understand where these fields are in the AWS console, see
|
|
117
|
-
* [Enable serverless SQL warehouses](/sql/admin/serverless.html).
|
|
118
|
-
*
|
|
119
|
-
* This API is only available to admin users.
|
|
120
|
-
*/
|
|
121
|
-
async editInstanceProfile(
|
|
122
|
-
req: EditInstanceProfileRequest,
|
|
123
|
-
options?: CallOptions
|
|
124
|
-
): Promise<EditInstanceProfileResponse> {
|
|
125
|
-
const url = `${this.host}/api/2.0/instance-profiles/edit`;
|
|
126
|
-
const body = marshalRequest(req, marshalEditInstanceProfileRequestSchema);
|
|
127
|
-
let resp: EditInstanceProfileResponse | undefined;
|
|
128
|
-
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
129
|
-
const headers = new Headers({'Content-Type': 'application/json'});
|
|
130
|
-
if (this.workspaceId !== undefined) {
|
|
131
|
-
headers.set('X-Databricks-Org-Id', this.workspaceId);
|
|
132
|
-
}
|
|
133
|
-
headers.set('User-Agent', this.userAgent);
|
|
134
|
-
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
135
|
-
const respBody = await executeHttpCall({
|
|
136
|
-
request: httpReq,
|
|
137
|
-
httpClient: this.httpClient,
|
|
138
|
-
logger: this.logger,
|
|
139
|
-
});
|
|
140
|
-
resp = parseResponse(
|
|
141
|
-
respBody,
|
|
142
|
-
unmarshalEditInstanceProfileResponseSchema
|
|
143
|
-
);
|
|
144
|
-
};
|
|
145
|
-
await executeCall(call, options);
|
|
146
|
-
if (resp === undefined) {
|
|
147
|
-
throw new Error('operation completed without a result.');
|
|
148
|
-
}
|
|
149
|
-
return resp;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* List the instance profiles that the calling user can use to launch a cluster.
|
|
154
|
-
*
|
|
155
|
-
* This API is available to all users.
|
|
156
|
-
*/
|
|
157
|
-
async listInstanceProfiles(
|
|
158
|
-
_req: ListInstanceProfilesRequest,
|
|
159
|
-
options?: CallOptions
|
|
160
|
-
): Promise<ListInstanceProfilesResponse> {
|
|
161
|
-
const url = `${this.host}/api/2.0/instance-profiles/list`;
|
|
162
|
-
let resp: ListInstanceProfilesResponse | undefined;
|
|
163
|
-
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
164
|
-
const headers = new Headers();
|
|
165
|
-
if (this.workspaceId !== undefined) {
|
|
166
|
-
headers.set('X-Databricks-Org-Id', this.workspaceId);
|
|
167
|
-
}
|
|
168
|
-
headers.set('User-Agent', this.userAgent);
|
|
169
|
-
const httpReq = buildHttpRequest('GET', url, headers, callSignal);
|
|
170
|
-
const respBody = await executeHttpCall({
|
|
171
|
-
request: httpReq,
|
|
172
|
-
httpClient: this.httpClient,
|
|
173
|
-
logger: this.logger,
|
|
174
|
-
});
|
|
175
|
-
resp = parseResponse(
|
|
176
|
-
respBody,
|
|
177
|
-
unmarshalListInstanceProfilesResponseSchema
|
|
178
|
-
);
|
|
179
|
-
};
|
|
180
|
-
await executeCall(call, options);
|
|
181
|
-
if (resp === undefined) {
|
|
182
|
-
throw new Error('operation completed without a result.');
|
|
183
|
-
}
|
|
184
|
-
return resp;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
/**
|
|
188
|
-
* Remove the instance profile with the provided ARN.
|
|
189
|
-
* Existing clusters with this instance profile will continue to function.
|
|
190
|
-
*
|
|
191
|
-
* This API is only accessible to admin users.
|
|
192
|
-
*/
|
|
193
|
-
async removeInstanceProfile(
|
|
194
|
-
req: RemoveInstanceProfileRequest,
|
|
195
|
-
options?: CallOptions
|
|
196
|
-
): Promise<RemoveInstanceProfileResponse> {
|
|
197
|
-
const url = `${this.host}/api/2.0/instance-profiles/remove`;
|
|
198
|
-
const body = marshalRequest(req, marshalRemoveInstanceProfileRequestSchema);
|
|
199
|
-
let resp: RemoveInstanceProfileResponse | undefined;
|
|
200
|
-
const call = async (callSignal?: AbortSignal): Promise<void> => {
|
|
201
|
-
const headers = new Headers({'Content-Type': 'application/json'});
|
|
202
|
-
if (this.workspaceId !== undefined) {
|
|
203
|
-
headers.set('X-Databricks-Org-Id', this.workspaceId);
|
|
204
|
-
}
|
|
205
|
-
headers.set('User-Agent', this.userAgent);
|
|
206
|
-
const httpReq = buildHttpRequest('POST', url, headers, callSignal, body);
|
|
207
|
-
const respBody = await executeHttpCall({
|
|
208
|
-
request: httpReq,
|
|
209
|
-
httpClient: this.httpClient,
|
|
210
|
-
logger: this.logger,
|
|
211
|
-
});
|
|
212
|
-
resp = parseResponse(
|
|
213
|
-
respBody,
|
|
214
|
-
unmarshalRemoveInstanceProfileResponseSchema
|
|
215
|
-
);
|
|
216
|
-
};
|
|
217
|
-
await executeCall(call, options);
|
|
218
|
-
if (resp === undefined) {
|
|
219
|
-
throw new Error('operation completed without a result.');
|
|
220
|
-
}
|
|
221
|
-
return resp;
|
|
222
|
-
}
|
|
223
|
-
}
|
package/src/v2/index.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
-
|
|
3
|
-
export {InstanceProfilesClient} from './client';
|
|
4
|
-
|
|
5
|
-
export type {
|
|
6
|
-
AddInstanceProfileRequest,
|
|
7
|
-
AddInstanceProfileResponse,
|
|
8
|
-
EditInstanceProfileRequest,
|
|
9
|
-
EditInstanceProfileResponse,
|
|
10
|
-
InstanceProfile,
|
|
11
|
-
ListInstanceProfilesRequest,
|
|
12
|
-
ListInstanceProfilesResponse,
|
|
13
|
-
RemoveInstanceProfileRequest,
|
|
14
|
-
RemoveInstanceProfileResponse,
|
|
15
|
-
} from './model';
|
package/src/v2/model.ts
DELETED
|
@@ -1,166 +0,0 @@
|
|
|
1
|
-
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
-
|
|
3
|
-
import {z} from 'zod';
|
|
4
|
-
|
|
5
|
-
export interface AddInstanceProfileRequest {
|
|
6
|
-
/**
|
|
7
|
-
* By default, <Databricks> validates that it has sufficient permissions to launch
|
|
8
|
-
* instances with the instance profile. This validation uses AWS dry-run mode for
|
|
9
|
-
* the RunInstances API. If validation fails with an error message that does not
|
|
10
|
-
* indicate an IAM related permission issue,
|
|
11
|
-
* (e.g. “Your requested instance type is not supported in your requested availability zone”),
|
|
12
|
-
* you can pass this flag to skip the validation and forcibly add the instance profile.
|
|
13
|
-
*/
|
|
14
|
-
skipValidation?: boolean | undefined;
|
|
15
|
-
/** The AWS ARN of the instance profile to register with <Databricks>. This field is required. */
|
|
16
|
-
instanceProfileArn?: string | undefined;
|
|
17
|
-
/**
|
|
18
|
-
* Boolean flag indicating whether the instance profile should only be used in credential
|
|
19
|
-
* passthrough scenarios. If true, it means the instance profile contains an meta IAM role
|
|
20
|
-
* which could assume a wide range of roles. Therefore it should always be used with
|
|
21
|
-
* authorization.
|
|
22
|
-
* This field is optional, the default value is `false`.
|
|
23
|
-
*/
|
|
24
|
-
isMetaInstanceProfile?: boolean | undefined;
|
|
25
|
-
/**
|
|
26
|
-
* The AWS IAM role ARN of the role associated with the instance profile.
|
|
27
|
-
* This field is required if your role name and instance profile name do
|
|
28
|
-
* not match and you want to use the instance profile with
|
|
29
|
-
* [Databricks SQL Serverless](/sql/admin/serverless.html).
|
|
30
|
-
*
|
|
31
|
-
* Otherwise, this field is optional.
|
|
32
|
-
*/
|
|
33
|
-
iamRoleArn?: string | undefined;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
37
|
-
export interface AddInstanceProfileResponse {}
|
|
38
|
-
|
|
39
|
-
export interface EditInstanceProfileRequest {
|
|
40
|
-
/** The AWS ARN of the instance profile to register with <Databricks>. This field is required. */
|
|
41
|
-
instanceProfileArn?: string | undefined;
|
|
42
|
-
/**
|
|
43
|
-
* Boolean flag indicating whether the instance profile should only be used in credential
|
|
44
|
-
* passthrough scenarios. If true, it means the instance profile contains an meta IAM role
|
|
45
|
-
* which could assume a wide range of roles. Therefore it should always be used with
|
|
46
|
-
* authorization.
|
|
47
|
-
* This field is optional, the default value is `false`.
|
|
48
|
-
*/
|
|
49
|
-
isMetaInstanceProfile?: boolean | undefined;
|
|
50
|
-
/**
|
|
51
|
-
* The AWS IAM role ARN of the role associated with the instance profile.
|
|
52
|
-
* This field is required if your role name and instance profile name do
|
|
53
|
-
* not match and you want to use the instance profile with
|
|
54
|
-
* [Databricks SQL Serverless](/sql/admin/serverless.html).
|
|
55
|
-
*
|
|
56
|
-
* Otherwise, this field is optional.
|
|
57
|
-
*/
|
|
58
|
-
iamRoleArn?: string | undefined;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
62
|
-
export interface EditInstanceProfileResponse {}
|
|
63
|
-
|
|
64
|
-
export interface InstanceProfile {
|
|
65
|
-
/** The AWS ARN of the instance profile to register with <Databricks>. This field is required. */
|
|
66
|
-
instanceProfileArn?: string | undefined;
|
|
67
|
-
/**
|
|
68
|
-
* Boolean flag indicating whether the instance profile should only be used in credential
|
|
69
|
-
* passthrough scenarios. If true, it means the instance profile contains an meta IAM role
|
|
70
|
-
* which could assume a wide range of roles. Therefore it should always be used with
|
|
71
|
-
* authorization.
|
|
72
|
-
* This field is optional, the default value is `false`.
|
|
73
|
-
*/
|
|
74
|
-
isMetaInstanceProfile?: boolean | undefined;
|
|
75
|
-
/**
|
|
76
|
-
* The AWS IAM role ARN of the role associated with the instance profile.
|
|
77
|
-
* This field is required if your role name and instance profile name do
|
|
78
|
-
* not match and you want to use the instance profile with
|
|
79
|
-
* [Databricks SQL Serverless](/sql/admin/serverless.html).
|
|
80
|
-
*
|
|
81
|
-
* Otherwise, this field is optional.
|
|
82
|
-
*/
|
|
83
|
-
iamRoleArn?: string | undefined;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
87
|
-
export interface ListInstanceProfilesRequest {}
|
|
88
|
-
|
|
89
|
-
export interface ListInstanceProfilesResponse {
|
|
90
|
-
/** A list of instance profiles that the user can access. */
|
|
91
|
-
instanceProfiles?: InstanceProfile[] | undefined;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
export interface RemoveInstanceProfileRequest {
|
|
95
|
-
/** The ARN of the instance profile to remove. This field is required. */
|
|
96
|
-
instanceProfileArn?: string | undefined;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
100
|
-
export interface RemoveInstanceProfileResponse {}
|
|
101
|
-
|
|
102
|
-
export const unmarshalAddInstanceProfileResponseSchema: z.ZodType<AddInstanceProfileResponse> =
|
|
103
|
-
z.object({});
|
|
104
|
-
|
|
105
|
-
export const unmarshalEditInstanceProfileResponseSchema: z.ZodType<EditInstanceProfileResponse> =
|
|
106
|
-
z.object({});
|
|
107
|
-
|
|
108
|
-
export const unmarshalInstanceProfileSchema: z.ZodType<InstanceProfile> = z
|
|
109
|
-
.object({
|
|
110
|
-
instance_profile_arn: z.string().optional(),
|
|
111
|
-
is_meta_instance_profile: z.boolean().optional(),
|
|
112
|
-
iam_role_arn: z.string().optional(),
|
|
113
|
-
})
|
|
114
|
-
.transform(d => ({
|
|
115
|
-
instanceProfileArn: d.instance_profile_arn,
|
|
116
|
-
isMetaInstanceProfile: d.is_meta_instance_profile,
|
|
117
|
-
iamRoleArn: d.iam_role_arn,
|
|
118
|
-
}));
|
|
119
|
-
|
|
120
|
-
export const unmarshalListInstanceProfilesResponseSchema: z.ZodType<ListInstanceProfilesResponse> =
|
|
121
|
-
z
|
|
122
|
-
.object({
|
|
123
|
-
instance_profiles: z
|
|
124
|
-
.array(z.lazy(() => unmarshalInstanceProfileSchema))
|
|
125
|
-
.optional(),
|
|
126
|
-
})
|
|
127
|
-
.transform(d => ({
|
|
128
|
-
instanceProfiles: d.instance_profiles,
|
|
129
|
-
}));
|
|
130
|
-
|
|
131
|
-
export const unmarshalRemoveInstanceProfileResponseSchema: z.ZodType<RemoveInstanceProfileResponse> =
|
|
132
|
-
z.object({});
|
|
133
|
-
|
|
134
|
-
export const marshalAddInstanceProfileRequestSchema: z.ZodType = z
|
|
135
|
-
.object({
|
|
136
|
-
skipValidation: z.boolean().optional(),
|
|
137
|
-
instanceProfileArn: z.string().optional(),
|
|
138
|
-
isMetaInstanceProfile: z.boolean().optional(),
|
|
139
|
-
iamRoleArn: z.string().optional(),
|
|
140
|
-
})
|
|
141
|
-
.transform(d => ({
|
|
142
|
-
skip_validation: d.skipValidation,
|
|
143
|
-
instance_profile_arn: d.instanceProfileArn,
|
|
144
|
-
is_meta_instance_profile: d.isMetaInstanceProfile,
|
|
145
|
-
iam_role_arn: d.iamRoleArn,
|
|
146
|
-
}));
|
|
147
|
-
|
|
148
|
-
export const marshalEditInstanceProfileRequestSchema: z.ZodType = z
|
|
149
|
-
.object({
|
|
150
|
-
instanceProfileArn: z.string().optional(),
|
|
151
|
-
isMetaInstanceProfile: z.boolean().optional(),
|
|
152
|
-
iamRoleArn: z.string().optional(),
|
|
153
|
-
})
|
|
154
|
-
.transform(d => ({
|
|
155
|
-
instance_profile_arn: d.instanceProfileArn,
|
|
156
|
-
is_meta_instance_profile: d.isMetaInstanceProfile,
|
|
157
|
-
iam_role_arn: d.iamRoleArn,
|
|
158
|
-
}));
|
|
159
|
-
|
|
160
|
-
export const marshalRemoveInstanceProfileRequestSchema: z.ZodType = z
|
|
161
|
-
.object({
|
|
162
|
-
instanceProfileArn: z.string().optional(),
|
|
163
|
-
})
|
|
164
|
-
.transform(d => ({
|
|
165
|
-
instance_profile_arn: d.instanceProfileArn,
|
|
166
|
-
}));
|
package/src/v2/transport.ts
DELETED
|
@@ -1,73 +0,0 @@
|
|
|
1
|
-
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
-
|
|
3
|
-
import type {Credentials} from '@databricks/sdk-auth';
|
|
4
|
-
import {defaultCredentials} from '@databricks/sdk-auth/credentials';
|
|
5
|
-
import type {
|
|
6
|
-
HttpClient,
|
|
7
|
-
HttpRequest,
|
|
8
|
-
HttpResponse,
|
|
9
|
-
} from '@databricks/sdk-core/http';
|
|
10
|
-
import {newFetchHttpClient} from '@databricks/sdk-core/http';
|
|
11
|
-
import type {ClientOptions} from '@databricks/sdk-options/client';
|
|
12
|
-
|
|
13
|
-
/** Creates a new HTTP client with the given options. */
|
|
14
|
-
export function newHttpClient(options?: ClientOptions): HttpClient {
|
|
15
|
-
const opts = options ?? {};
|
|
16
|
-
|
|
17
|
-
// If an HTTP client is provided, use it as-is. Throw if other options are
|
|
18
|
-
// also set, since they would be silently ignored.
|
|
19
|
-
if (opts.httpClient !== undefined) {
|
|
20
|
-
if (opts.credentials !== undefined || opts.timeout !== undefined) {
|
|
21
|
-
throw new Error(
|
|
22
|
-
'httpClient cannot be combined with credentials or timeout'
|
|
23
|
-
);
|
|
24
|
-
}
|
|
25
|
-
return opts.httpClient;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const credentials = opts.credentials ?? defaultCredentials();
|
|
29
|
-
|
|
30
|
-
const base = newFetchHttpClient();
|
|
31
|
-
let client: HttpClient = new AuthHttpClient(base, credentials);
|
|
32
|
-
|
|
33
|
-
if (opts.timeout !== undefined) {
|
|
34
|
-
client = new TimeoutHttpClient(client, opts.timeout);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
return client;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/** Wraps an HttpClient and adds authentication headers to requests. */
|
|
41
|
-
class AuthHttpClient implements HttpClient {
|
|
42
|
-
constructor(
|
|
43
|
-
private readonly base: HttpClient,
|
|
44
|
-
private readonly credentials: Credentials
|
|
45
|
-
) {}
|
|
46
|
-
|
|
47
|
-
async send(request: HttpRequest): Promise<HttpResponse> {
|
|
48
|
-
const authHeaders = await this.credentials.authHeaders();
|
|
49
|
-
// Do not modify the original request.
|
|
50
|
-
const headers = new Headers(request.headers);
|
|
51
|
-
for (const h of authHeaders) {
|
|
52
|
-
headers.set(h.key, h.value);
|
|
53
|
-
}
|
|
54
|
-
return this.base.send({...request, headers});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
/** Wraps an HttpClient and applies a default timeout to requests. */
|
|
59
|
-
class TimeoutHttpClient implements HttpClient {
|
|
60
|
-
constructor(
|
|
61
|
-
private readonly base: HttpClient,
|
|
62
|
-
private readonly timeout: number
|
|
63
|
-
) {}
|
|
64
|
-
|
|
65
|
-
async send(request: HttpRequest): Promise<HttpResponse> {
|
|
66
|
-
const timeoutSignal = AbortSignal.timeout(this.timeout);
|
|
67
|
-
const signal =
|
|
68
|
-
request.signal !== undefined
|
|
69
|
-
? AbortSignal.any([request.signal, timeoutSignal])
|
|
70
|
-
: timeoutSignal;
|
|
71
|
-
return this.base.send({...request, signal});
|
|
72
|
-
}
|
|
73
|
-
}
|
package/src/v2/utils.ts
DELETED
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
// Code generated from API definition by Databricks SDK Generator. DO NOT EDIT.
|
|
2
|
-
|
|
3
|
-
import type {Options} from '@databricks/sdk-core/ops';
|
|
4
|
-
import {execute} from '@databricks/sdk-core/ops';
|
|
5
|
-
import {ApiError} from '@databricks/sdk-core/apierror';
|
|
6
|
-
import type {
|
|
7
|
-
HttpClient,
|
|
8
|
-
HttpRequest,
|
|
9
|
-
HttpResponse,
|
|
10
|
-
} from '@databricks/sdk-core/http';
|
|
11
|
-
import type {Logger} from '@databricks/sdk-core/logger';
|
|
12
|
-
import type {CallOptions} from '@databricks/sdk-options/call';
|
|
13
|
-
import JSONBig from 'json-bigint';
|
|
14
|
-
import type {z} from 'zod';
|
|
15
|
-
|
|
16
|
-
// JSON codec that preserves int64 precision. On the way in, large integer
|
|
17
|
-
// literals come back as bigint instead of being rounded to JS Number. On the
|
|
18
|
-
// way out, bigint values are emitted as raw JSON number digits.
|
|
19
|
-
const jsonBigint = JSONBig({useNativeBigInt: true});
|
|
20
|
-
|
|
21
|
-
export interface HttpCallOptions {
|
|
22
|
-
readonly request: HttpRequest;
|
|
23
|
-
readonly httpClient: HttpClient;
|
|
24
|
-
readonly logger: Logger;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* Translates public CallOptions to the internal Options shape accepted by
|
|
29
|
-
* execute(). Even though the shapes match today, this isolates the public
|
|
30
|
-
* API from the executor's internal type so they can diverge.
|
|
31
|
-
*/
|
|
32
|
-
export async function executeCall(
|
|
33
|
-
call: (signal?: AbortSignal) => Promise<void>,
|
|
34
|
-
options?: CallOptions
|
|
35
|
-
): Promise<void> {
|
|
36
|
-
const opts: Options = {
|
|
37
|
-
...(options?.retrier !== undefined && {retrier: options.retrier}),
|
|
38
|
-
...(options?.rateLimiter !== undefined && {
|
|
39
|
-
rateLimiter: options.rateLimiter,
|
|
40
|
-
}),
|
|
41
|
-
...(options?.timeout !== undefined && {timeout: options.timeout}),
|
|
42
|
-
};
|
|
43
|
-
return execute(options?.signal, call, opts);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
async function readAll(
|
|
47
|
-
body: ReadableStream<Uint8Array> | null
|
|
48
|
-
): Promise<Uint8Array> {
|
|
49
|
-
if (body === null) {
|
|
50
|
-
return new Uint8Array(0);
|
|
51
|
-
}
|
|
52
|
-
const reader = body.getReader();
|
|
53
|
-
const chunks: Uint8Array[] = [];
|
|
54
|
-
for (;;) {
|
|
55
|
-
const {done, value} = await reader.read();
|
|
56
|
-
if (done) {
|
|
57
|
-
break;
|
|
58
|
-
}
|
|
59
|
-
chunks.push(value);
|
|
60
|
-
}
|
|
61
|
-
const totalLength = chunks.reduce((acc, chunk) => acc + chunk.length, 0);
|
|
62
|
-
const result = new Uint8Array(totalLength);
|
|
63
|
-
let offset = 0;
|
|
64
|
-
for (const chunk of chunks) {
|
|
65
|
-
result.set(chunk, offset);
|
|
66
|
-
offset += chunk.length;
|
|
67
|
-
}
|
|
68
|
-
return result;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export async function executeHttpCall(
|
|
72
|
-
opts: HttpCallOptions
|
|
73
|
-
): Promise<Uint8Array> {
|
|
74
|
-
opts.logger.debug('HTTP request', {
|
|
75
|
-
method: opts.request.method,
|
|
76
|
-
url: opts.request.url,
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
let resp: HttpResponse;
|
|
80
|
-
try {
|
|
81
|
-
resp = await opts.httpClient.send(opts.request);
|
|
82
|
-
} catch (e: unknown) {
|
|
83
|
-
opts.logger.debug('HTTP request failed');
|
|
84
|
-
throw e;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
const body = await readAll(resp.body);
|
|
88
|
-
|
|
89
|
-
opts.logger.debug('HTTP response', {
|
|
90
|
-
statusCode: resp.statusCode,
|
|
91
|
-
body: new TextDecoder().decode(body),
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
const apiErr = ApiError.fromHttpError(resp.statusCode, resp.headers, body);
|
|
95
|
-
if (apiErr !== undefined) {
|
|
96
|
-
throw apiErr;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
return body;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
export function buildHttpRequest(
|
|
103
|
-
method: string,
|
|
104
|
-
url: string,
|
|
105
|
-
headers: Headers,
|
|
106
|
-
signal?: AbortSignal,
|
|
107
|
-
body?: string | ReadableStream<Uint8Array>
|
|
108
|
-
): HttpRequest {
|
|
109
|
-
const req: HttpRequest = {url, method, headers};
|
|
110
|
-
if (body !== undefined) {
|
|
111
|
-
req.body = body;
|
|
112
|
-
}
|
|
113
|
-
if (signal !== undefined) {
|
|
114
|
-
req.signal = signal;
|
|
115
|
-
}
|
|
116
|
-
return req;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
export function parseResponse<T>(body: Uint8Array, schema: z.ZodType<T>): T {
|
|
120
|
-
const text = new TextDecoder().decode(body);
|
|
121
|
-
const parsed: unknown = jsonBigint.parse(text);
|
|
122
|
-
return schema.parse(parsed);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
export function marshalRequest(data: unknown, schema: z.ZodType): string {
|
|
126
|
-
return jsonBigint.stringify(schema.parse(data));
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
export function flattenQueryParams(
|
|
130
|
-
prefix: string,
|
|
131
|
-
value: unknown,
|
|
132
|
-
params: URLSearchParams
|
|
133
|
-
): void {
|
|
134
|
-
if (value === null || value === undefined) {
|
|
135
|
-
return;
|
|
136
|
-
}
|
|
137
|
-
if (Array.isArray(value)) {
|
|
138
|
-
// arrays of objects are not yet supported
|
|
139
|
-
for (const item of value) {
|
|
140
|
-
params.append(prefix, String(item));
|
|
141
|
-
}
|
|
142
|
-
} else if (typeof value === 'object') {
|
|
143
|
-
for (const [key, val] of Object.entries(value as Record<string, unknown>)) {
|
|
144
|
-
flattenQueryParams(`${prefix}.${key}`, val, params);
|
|
145
|
-
}
|
|
146
|
-
} else if (
|
|
147
|
-
typeof value === 'string' ||
|
|
148
|
-
typeof value === 'number' ||
|
|
149
|
-
typeof value === 'boolean' ||
|
|
150
|
-
typeof value === 'bigint'
|
|
151
|
-
) {
|
|
152
|
-
params.append(prefix, String(value));
|
|
153
|
-
} else {
|
|
154
|
-
throw new Error(`Unsupported query parameter type: ${typeof value}`);
|
|
155
|
-
}
|
|
156
|
-
}
|