@openziti/ziti-mcp-server 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/LICENSE +201 -0
- package/README.md +868 -0
- package/dist/auth/client-credentials-flow.d.ts +21 -0
- package/dist/auth/client-credentials-flow.js +63 -0
- package/dist/auth/client-credentials-flow.js.map +1 -0
- package/dist/auth/device-auth-flow.d.ts +47 -0
- package/dist/auth/device-auth-flow.js +291 -0
- package/dist/auth/device-auth-flow.js.map +1 -0
- package/dist/clients/base.d.ts +74 -0
- package/dist/clients/base.js +109 -0
- package/dist/clients/base.js.map +1 -0
- package/dist/clients/claude.d.ts +22 -0
- package/dist/clients/claude.js +40 -0
- package/dist/clients/claude.js.map +1 -0
- package/dist/clients/cursor.d.ts +22 -0
- package/dist/clients/cursor.js +39 -0
- package/dist/clients/cursor.js.map +1 -0
- package/dist/clients/index.d.ts +33 -0
- package/dist/clients/index.js +39 -0
- package/dist/clients/index.js.map +1 -0
- package/dist/clients/types.d.ts +70 -0
- package/dist/clients/types.js +2 -0
- package/dist/clients/types.js.map +1 -0
- package/dist/clients/utils.d.ts +22 -0
- package/dist/clients/utils.js +46 -0
- package/dist/clients/utils.js.map +1 -0
- package/dist/clients/vscode.d.ts +76 -0
- package/dist/clients/vscode.js +159 -0
- package/dist/clients/vscode.js.map +1 -0
- package/dist/clients/windsurf.d.ts +22 -0
- package/dist/clients/windsurf.js +39 -0
- package/dist/clients/windsurf.js.map +1 -0
- package/dist/commands/init.d.ts +45 -0
- package/dist/commands/init.js +133 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/logout.d.ts +12 -0
- package/dist/commands/logout.js +90 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/run.d.ts +15 -0
- package/dist/commands/run.js +94 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/session.d.ts +12 -0
- package/dist/commands/session.js +99 -0
- package/dist/commands/session.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +105 -0
- package/dist/index.js.map +1 -0
- package/dist/server.d.ts +67 -0
- package/dist/server.js +171 -0
- package/dist/server.js.map +1 -0
- package/dist/tools/api-sessions.d.ts +3 -0
- package/dist/tools/api-sessions.js +86 -0
- package/dist/tools/api-sessions.js.map +1 -0
- package/dist/tools/auth-policies.d.ts +3 -0
- package/dist/tools/auth-policies.js +347 -0
- package/dist/tools/auth-policies.js.map +1 -0
- package/dist/tools/authenticators.d.ts +3 -0
- package/dist/tools/authenticators.js +183 -0
- package/dist/tools/authenticators.js.map +1 -0
- package/dist/tools/certificate-authorities.d.ts +3 -0
- package/dist/tools/certificate-authorities.js +288 -0
- package/dist/tools/certificate-authorities.js.map +1 -0
- package/dist/tools/config-types.d.ts +3 -0
- package/dist/tools/config-types.js +194 -0
- package/dist/tools/config-types.js.map +1 -0
- package/dist/tools/configs.d.ts +3 -0
- package/dist/tools/configs.js +203 -0
- package/dist/tools/configs.js.map +1 -0
- package/dist/tools/controller-settings.d.ts +3 -0
- package/dist/tools/controller-settings.js +219 -0
- package/dist/tools/controller-settings.js.map +1 -0
- package/dist/tools/controllers.d.ts +3 -0
- package/dist/tools/controllers.js +89 -0
- package/dist/tools/controllers.js.map +1 -0
- package/dist/tools/edge-router-policies.d.ts +3 -0
- package/dist/tools/edge-router-policies.js +262 -0
- package/dist/tools/edge-router-policies.js.map +1 -0
- package/dist/tools/edge-routers.d.ts +3 -0
- package/dist/tools/edge-routers.js +381 -0
- package/dist/tools/edge-routers.js.map +1 -0
- package/dist/tools/enrollments.d.ts +3 -0
- package/dist/tools/enrollments.js +187 -0
- package/dist/tools/enrollments.js.map +1 -0
- package/dist/tools/external-jwt-signers.d.ts +3 -0
- package/dist/tools/external-jwt-signers.js +242 -0
- package/dist/tools/external-jwt-signers.js.map +1 -0
- package/dist/tools/identities.d.ts +3 -0
- package/dist/tools/identities.js +741 -0
- package/dist/tools/identities.js.map +1 -0
- package/dist/tools/identity-types.d.ts +3 -0
- package/dist/tools/identity-types.js +58 -0
- package/dist/tools/identity-types.js.map +1 -0
- package/dist/tools/index.d.ts +3 -0
- package/dist/tools/index.js +101 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/posture-checks.d.ts +3 -0
- package/dist/tools/posture-checks.js +254 -0
- package/dist/tools/posture-checks.js.map +1 -0
- package/dist/tools/routers.d.ts +3 -0
- package/dist/tools/routers.js +169 -0
- package/dist/tools/routers.js.map +1 -0
- package/dist/tools/service-edge-router-policies.d.ts +3 -0
- package/dist/tools/service-edge-router-policies.js +282 -0
- package/dist/tools/service-edge-router-policies.js.map +1 -0
- package/dist/tools/service-policies.d.ts +3 -0
- package/dist/tools/service-policies.js +311 -0
- package/dist/tools/service-policies.js.map +1 -0
- package/dist/tools/services.d.ts +3 -0
- package/dist/tools/services.js +403 -0
- package/dist/tools/services.js.map +1 -0
- package/dist/tools/sessions.d.ts +3 -0
- package/dist/tools/sessions.js +86 -0
- package/dist/tools/sessions.js.map +1 -0
- package/dist/tools/terminators.d.ts +3 -0
- package/dist/tools/terminators.js +187 -0
- package/dist/tools/terminators.js.map +1 -0
- package/dist/tools/transit-routers.d.ts +3 -0
- package/dist/tools/transit-routers.js +169 -0
- package/dist/tools/transit-routers.js.map +1 -0
- package/dist/utils/analytics.d.ts +75 -0
- package/dist/utils/analytics.js +191 -0
- package/dist/utils/analytics.js.map +1 -0
- package/dist/utils/auth0-client.d.ts +27 -0
- package/dist/utils/auth0-client.js +67 -0
- package/dist/utils/auth0-client.js.map +1 -0
- package/dist/utils/authenticated-client.d.ts +6 -0
- package/dist/utils/authenticated-client.js +55 -0
- package/dist/utils/authenticated-client.js.map +1 -0
- package/dist/utils/config.d.ts +65 -0
- package/dist/utils/config.js +80 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/constants.d.ts +15 -0
- package/dist/utils/constants.js +17 -0
- package/dist/utils/constants.js.map +1 -0
- package/dist/utils/controller-client/client/client.gen.d.ts +2 -0
- package/dist/utils/controller-client/client/client.gen.js +229 -0
- package/dist/utils/controller-client/client/client.gen.js.map +1 -0
- package/dist/utils/controller-client/client/index.d.ts +8 -0
- package/dist/utils/controller-client/client/index.js +7 -0
- package/dist/utils/controller-client/client/index.js.map +1 -0
- package/dist/utils/controller-client/client/types.gen.d.ts +117 -0
- package/dist/utils/controller-client/client/types.gen.js +3 -0
- package/dist/utils/controller-client/client/types.gen.js.map +1 -0
- package/dist/utils/controller-client/client/utils.gen.d.ts +33 -0
- package/dist/utils/controller-client/client/utils.gen.js +232 -0
- package/dist/utils/controller-client/client/utils.gen.js.map +1 -0
- package/dist/utils/controller-client/client.gen.d.ts +12 -0
- package/dist/utils/controller-client/client.gen.js +6 -0
- package/dist/utils/controller-client/client.gen.js.map +1 -0
- package/dist/utils/controller-client/core/auth.gen.d.ts +18 -0
- package/dist/utils/controller-client/core/auth.gen.js +15 -0
- package/dist/utils/controller-client/core/auth.gen.js.map +1 -0
- package/dist/utils/controller-client/core/bodySerializer.gen.d.ts +25 -0
- package/dist/utils/controller-client/core/bodySerializer.gen.js +58 -0
- package/dist/utils/controller-client/core/bodySerializer.gen.js.map +1 -0
- package/dist/utils/controller-client/core/params.gen.d.ts +43 -0
- package/dist/utils/controller-client/core/params.gen.js +101 -0
- package/dist/utils/controller-client/core/params.gen.js.map +1 -0
- package/dist/utils/controller-client/core/pathSerializer.gen.d.ts +33 -0
- package/dist/utils/controller-client/core/pathSerializer.gen.js +115 -0
- package/dist/utils/controller-client/core/pathSerializer.gen.js.map +1 -0
- package/dist/utils/controller-client/core/queryKeySerializer.gen.d.ts +18 -0
- package/dist/utils/controller-client/core/queryKeySerializer.gen.js +100 -0
- package/dist/utils/controller-client/core/queryKeySerializer.gen.js.map +1 -0
- package/dist/utils/controller-client/core/serverSentEvents.gen.d.ts +71 -0
- package/dist/utils/controller-client/core/serverSentEvents.gen.js +136 -0
- package/dist/utils/controller-client/core/serverSentEvents.gen.js.map +1 -0
- package/dist/utils/controller-client/core/types.gen.d.ts +78 -0
- package/dist/utils/controller-client/core/types.gen.js +3 -0
- package/dist/utils/controller-client/core/types.gen.js.map +1 -0
- package/dist/utils/controller-client/core/utils.gen.d.ts +19 -0
- package/dist/utils/controller-client/core/utils.gen.js +88 -0
- package/dist/utils/controller-client/core/utils.gen.js.map +1 -0
- package/dist/utils/controller-client/index.d.ts +2 -0
- package/dist/utils/controller-client/index.js +3 -0
- package/dist/utils/controller-client/index.js.map +1 -0
- package/dist/utils/controller-client/sdk.gen.d.ts +1302 -0
- package/dist/utils/controller-client/sdk.gen.js +4436 -0
- package/dist/utils/controller-client/sdk.gen.js.map +1 -0
- package/dist/utils/controller-client/types.gen.d.ts +9170 -0
- package/dist/utils/controller-client/types.gen.js +3 -0
- package/dist/utils/controller-client/types.gen.js.map +1 -0
- package/dist/utils/glob.d.ts +75 -0
- package/dist/utils/glob.js +110 -0
- package/dist/utils/glob.js.map +1 -0
- package/dist/utils/http-utility.d.ts +5 -0
- package/dist/utils/http-utility.js +68 -0
- package/dist/utils/http-utility.js.map +1 -0
- package/dist/utils/keychain.d.ts +129 -0
- package/dist/utils/keychain.js +193 -0
- package/dist/utils/keychain.js.map +1 -0
- package/dist/utils/logger.d.ts +4 -0
- package/dist/utils/logger.js +28 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/package.d.ts +3 -0
- package/dist/utils/package.js +9 -0
- package/dist/utils/package.js.map +1 -0
- package/dist/utils/scopes.d.ts +12 -0
- package/dist/utils/scopes.js +19 -0
- package/dist/utils/scopes.js.map +1 -0
- package/dist/utils/terminal.d.ts +35 -0
- package/dist/utils/terminal.js +409 -0
- package/dist/utils/terminal.js.map +1 -0
- package/dist/utils/tools.d.ts +63 -0
- package/dist/utils/tools.js +149 -0
- package/dist/utils/tools.js.map +1 -0
- package/dist/utils/types.d.ts +55 -0
- package/dist/utils/types.js +3 -0
- package/dist/utils/types.js.map +1 -0
- package/package.json +89 -0
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
import { createErrorResponse } from '../utils/http-utility.js';
|
|
2
|
+
import { withAuthenticatedClient } from '../utils/authenticated-client.js';
|
|
3
|
+
import { listCas, detailCa, createCa, deleteCa, patchCa, getCaJwt, verifyCa, } from '../utils/controller-client/sdk.gen.js';
|
|
4
|
+
// Define all available Certificate Authority tools
|
|
5
|
+
export const CA_TOOLS = [
|
|
6
|
+
{
|
|
7
|
+
name: 'listCas',
|
|
8
|
+
description: 'List all Certificate Authorities in the Ziti network',
|
|
9
|
+
inputSchema: {
|
|
10
|
+
type: 'object',
|
|
11
|
+
properties: {},
|
|
12
|
+
},
|
|
13
|
+
_meta: {
|
|
14
|
+
requiredScopes: ['read:cas'],
|
|
15
|
+
readOnly: true,
|
|
16
|
+
},
|
|
17
|
+
annotations: {
|
|
18
|
+
title: 'List all Certificate Authorities defined in the Ziti network.',
|
|
19
|
+
readOnlyHint: true,
|
|
20
|
+
destructiveHint: false,
|
|
21
|
+
idempotentHint: true,
|
|
22
|
+
openWorldHint: false,
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
name: 'listCa',
|
|
27
|
+
description: 'Get details about a specific Ziti Certificate Authority',
|
|
28
|
+
inputSchema: {
|
|
29
|
+
type: 'object',
|
|
30
|
+
properties: {
|
|
31
|
+
id: { type: 'string', description: 'ID of the CA to retrieve' },
|
|
32
|
+
},
|
|
33
|
+
required: ['id'],
|
|
34
|
+
},
|
|
35
|
+
_meta: {
|
|
36
|
+
requiredScopes: ['read:cas'],
|
|
37
|
+
readOnly: true,
|
|
38
|
+
},
|
|
39
|
+
annotations: {
|
|
40
|
+
title: 'Get Ziti Certificate Authority Details',
|
|
41
|
+
readOnlyHint: true,
|
|
42
|
+
destructiveHint: false,
|
|
43
|
+
idempotentHint: true,
|
|
44
|
+
openWorldHint: false,
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
name: 'createCa',
|
|
49
|
+
description: 'Create a new Ziti Certificate Authority.',
|
|
50
|
+
inputSchema: {
|
|
51
|
+
type: 'object',
|
|
52
|
+
properties: {
|
|
53
|
+
name: { type: 'string', description: 'Name of the CA to create' },
|
|
54
|
+
certPem: { type: 'string', description: 'The CA certificate in PEM format' },
|
|
55
|
+
isAuthEnabled: {
|
|
56
|
+
type: 'boolean',
|
|
57
|
+
description: 'Whether this CA can be used for authentication',
|
|
58
|
+
default: false,
|
|
59
|
+
},
|
|
60
|
+
isAutoCaEnrollmentEnabled: {
|
|
61
|
+
type: 'boolean',
|
|
62
|
+
description: 'Whether auto CA enrollment is enabled',
|
|
63
|
+
default: false,
|
|
64
|
+
},
|
|
65
|
+
isOttCaEnrollmentEnabled: {
|
|
66
|
+
type: 'boolean',
|
|
67
|
+
description: 'Whether one-time-token CA enrollment is enabled',
|
|
68
|
+
default: false,
|
|
69
|
+
},
|
|
70
|
+
identityRoles: {
|
|
71
|
+
type: 'string',
|
|
72
|
+
description: 'Comma-separated identity roles for auto-enrolled identities',
|
|
73
|
+
},
|
|
74
|
+
identityNameFormat: {
|
|
75
|
+
type: 'string',
|
|
76
|
+
description: 'Format string for naming auto-enrolled identities',
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
required: [
|
|
80
|
+
'name',
|
|
81
|
+
'certPem',
|
|
82
|
+
'isAuthEnabled',
|
|
83
|
+
'isAutoCaEnrollmentEnabled',
|
|
84
|
+
'isOttCaEnrollmentEnabled',
|
|
85
|
+
'identityRoles',
|
|
86
|
+
],
|
|
87
|
+
},
|
|
88
|
+
_meta: {
|
|
89
|
+
requiredScopes: ['write:cas'],
|
|
90
|
+
readOnly: false,
|
|
91
|
+
},
|
|
92
|
+
annotations: {
|
|
93
|
+
title: 'Create a new Certificate Authority in the Ziti network.',
|
|
94
|
+
readOnlyHint: false,
|
|
95
|
+
destructiveHint: false,
|
|
96
|
+
idempotentHint: false,
|
|
97
|
+
openWorldHint: false,
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
name: 'deleteCa',
|
|
102
|
+
description: 'Delete a Ziti Certificate Authority.',
|
|
103
|
+
inputSchema: {
|
|
104
|
+
type: 'object',
|
|
105
|
+
properties: {
|
|
106
|
+
id: { type: 'string', description: 'ID of the CA to delete' },
|
|
107
|
+
},
|
|
108
|
+
required: ['id'],
|
|
109
|
+
},
|
|
110
|
+
_meta: {
|
|
111
|
+
requiredScopes: ['write:cas'],
|
|
112
|
+
readOnly: false,
|
|
113
|
+
},
|
|
114
|
+
annotations: {
|
|
115
|
+
title: 'Delete a Certificate Authority from the Ziti network.',
|
|
116
|
+
readOnlyHint: false,
|
|
117
|
+
destructiveHint: true,
|
|
118
|
+
idempotentHint: false,
|
|
119
|
+
openWorldHint: false,
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
name: 'updateCa',
|
|
124
|
+
description: 'Update an existing Ziti Certificate Authority.',
|
|
125
|
+
inputSchema: {
|
|
126
|
+
type: 'object',
|
|
127
|
+
properties: {
|
|
128
|
+
id: { type: 'string', description: 'ID of the CA to update' },
|
|
129
|
+
name: { type: 'string', description: 'Name to give the CA' },
|
|
130
|
+
isAuthEnabled: {
|
|
131
|
+
type: 'boolean',
|
|
132
|
+
description: 'Whether this CA can be used for authentication',
|
|
133
|
+
},
|
|
134
|
+
isAutoCaEnrollmentEnabled: {
|
|
135
|
+
type: 'boolean',
|
|
136
|
+
description: 'Whether auto CA enrollment is enabled',
|
|
137
|
+
},
|
|
138
|
+
isOttCaEnrollmentEnabled: {
|
|
139
|
+
type: 'boolean',
|
|
140
|
+
description: 'Whether one-time-token CA enrollment is enabled',
|
|
141
|
+
},
|
|
142
|
+
identityRoles: {
|
|
143
|
+
type: 'string',
|
|
144
|
+
description: 'Comma-separated identity roles for auto-enrolled identities',
|
|
145
|
+
},
|
|
146
|
+
identityNameFormat: {
|
|
147
|
+
type: 'string',
|
|
148
|
+
description: 'Format string for naming auto-enrolled identities',
|
|
149
|
+
},
|
|
150
|
+
},
|
|
151
|
+
required: ['id'],
|
|
152
|
+
},
|
|
153
|
+
_meta: {
|
|
154
|
+
requiredScopes: ['write:cas'],
|
|
155
|
+
readOnly: false,
|
|
156
|
+
},
|
|
157
|
+
annotations: {
|
|
158
|
+
title: 'Update an existing Certificate Authority in the Ziti network.',
|
|
159
|
+
readOnlyHint: false,
|
|
160
|
+
destructiveHint: true,
|
|
161
|
+
idempotentHint: true,
|
|
162
|
+
openWorldHint: false,
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
name: 'getCaJwt',
|
|
167
|
+
description: 'Get the JWT for a Certificate Authority, used for enrollment',
|
|
168
|
+
inputSchema: {
|
|
169
|
+
type: 'object',
|
|
170
|
+
properties: {
|
|
171
|
+
id: { type: 'string', description: 'ID of the certificate authority' },
|
|
172
|
+
},
|
|
173
|
+
required: ['id'],
|
|
174
|
+
},
|
|
175
|
+
_meta: {
|
|
176
|
+
requiredScopes: ['read:cas'],
|
|
177
|
+
readOnly: true,
|
|
178
|
+
},
|
|
179
|
+
annotations: {
|
|
180
|
+
title: 'Get JWT for a Certificate Authority.',
|
|
181
|
+
readOnlyHint: true,
|
|
182
|
+
destructiveHint: false,
|
|
183
|
+
idempotentHint: true,
|
|
184
|
+
openWorldHint: false,
|
|
185
|
+
},
|
|
186
|
+
},
|
|
187
|
+
{
|
|
188
|
+
name: 'verifyCa',
|
|
189
|
+
description: 'Verify a Certificate Authority by providing a PEM certificate signed by the CA with the common name matching the CA validation token',
|
|
190
|
+
inputSchema: {
|
|
191
|
+
type: 'object',
|
|
192
|
+
properties: {
|
|
193
|
+
id: { type: 'string', description: 'ID of the certificate authority to verify' },
|
|
194
|
+
certificate: {
|
|
195
|
+
type: 'string',
|
|
196
|
+
description: 'PEM formatted certificate signed by the target CA',
|
|
197
|
+
},
|
|
198
|
+
},
|
|
199
|
+
required: ['id', 'certificate'],
|
|
200
|
+
},
|
|
201
|
+
_meta: {
|
|
202
|
+
requiredScopes: ['write:cas'],
|
|
203
|
+
readOnly: false,
|
|
204
|
+
},
|
|
205
|
+
annotations: {
|
|
206
|
+
title: 'Verify a Certificate Authority.',
|
|
207
|
+
readOnlyHint: false,
|
|
208
|
+
destructiveHint: false,
|
|
209
|
+
idempotentHint: true,
|
|
210
|
+
openWorldHint: false,
|
|
211
|
+
},
|
|
212
|
+
},
|
|
213
|
+
];
|
|
214
|
+
const splitRoles = (roles) => roles.split(',').map((r) => r.trim());
|
|
215
|
+
// Define handlers for each Certificate Authority tool
|
|
216
|
+
export const CA_HANDLERS = {
|
|
217
|
+
listCas: (request, config) => withAuthenticatedClient(request, config, 'list CAs', (client, ztSession) => listCas({ client, headers: { 'zt-session': ztSession } })),
|
|
218
|
+
listCa: (request, config) => {
|
|
219
|
+
const { id } = request.parameters;
|
|
220
|
+
if (!id)
|
|
221
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
222
|
+
return withAuthenticatedClient(request, config, 'get CA', (client, ztSession) => detailCa({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
223
|
+
},
|
|
224
|
+
createCa: (request, config) => {
|
|
225
|
+
const { name, certPem, isAuthEnabled, isAutoCaEnrollmentEnabled, isOttCaEnrollmentEnabled, identityRoles, identityNameFormat, } = request.parameters;
|
|
226
|
+
if (!name)
|
|
227
|
+
return Promise.resolve(createErrorResponse('Error: name is required'));
|
|
228
|
+
if (!certPem)
|
|
229
|
+
return Promise.resolve(createErrorResponse('Error: certPem is required'));
|
|
230
|
+
return withAuthenticatedClient(request, config, 'create CA', (client, ztSession) => createCa({
|
|
231
|
+
body: {
|
|
232
|
+
name,
|
|
233
|
+
certPem,
|
|
234
|
+
isAuthEnabled: isAuthEnabled ?? false,
|
|
235
|
+
isAutoCaEnrollmentEnabled: isAutoCaEnrollmentEnabled ?? false,
|
|
236
|
+
isOttCaEnrollmentEnabled: isOttCaEnrollmentEnabled ?? false,
|
|
237
|
+
identityRoles: identityRoles ? splitRoles(identityRoles) : [],
|
|
238
|
+
identityNameFormat,
|
|
239
|
+
},
|
|
240
|
+
client,
|
|
241
|
+
headers: { 'zt-session': ztSession },
|
|
242
|
+
}));
|
|
243
|
+
},
|
|
244
|
+
deleteCa: (request, config) => {
|
|
245
|
+
const { id } = request.parameters;
|
|
246
|
+
if (!id)
|
|
247
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
248
|
+
return withAuthenticatedClient(request, config, 'delete CA', (client, ztSession) => deleteCa({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
249
|
+
},
|
|
250
|
+
updateCa: (request, config) => {
|
|
251
|
+
const { id, name, isAuthEnabled, isAutoCaEnrollmentEnabled, isOttCaEnrollmentEnabled, identityRoles, identityNameFormat, } = request.parameters;
|
|
252
|
+
if (!id)
|
|
253
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
254
|
+
return withAuthenticatedClient(request, config, 'update CA', (client, ztSession) => patchCa({
|
|
255
|
+
path: { id },
|
|
256
|
+
body: {
|
|
257
|
+
name,
|
|
258
|
+
isAuthEnabled,
|
|
259
|
+
isAutoCaEnrollmentEnabled,
|
|
260
|
+
isOttCaEnrollmentEnabled,
|
|
261
|
+
identityRoles: identityRoles ? splitRoles(identityRoles) : undefined,
|
|
262
|
+
identityNameFormat,
|
|
263
|
+
},
|
|
264
|
+
client,
|
|
265
|
+
headers: { 'zt-session': ztSession },
|
|
266
|
+
}));
|
|
267
|
+
},
|
|
268
|
+
getCaJwt: (request, config) => {
|
|
269
|
+
const { id } = request.parameters;
|
|
270
|
+
if (!id)
|
|
271
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
272
|
+
return withAuthenticatedClient(request, config, 'get ca jwt', (client, ztSession) => getCaJwt({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
273
|
+
},
|
|
274
|
+
verifyCa: (request, config) => {
|
|
275
|
+
const { id, certificate } = request.parameters;
|
|
276
|
+
if (!id)
|
|
277
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
278
|
+
if (!certificate)
|
|
279
|
+
return Promise.resolve(createErrorResponse('Error: certificate is required'));
|
|
280
|
+
return withAuthenticatedClient(request, config, 'verify ca', (client, ztSession) => verifyCa({
|
|
281
|
+
path: { id },
|
|
282
|
+
body: certificate,
|
|
283
|
+
client,
|
|
284
|
+
headers: { 'zt-session': ztSession },
|
|
285
|
+
}));
|
|
286
|
+
},
|
|
287
|
+
};
|
|
288
|
+
//# sourceMappingURL=certificate-authorities.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"certificate-authorities.js","sourceRoot":"","sources":["../../src/tools/certificate-authorities.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { HandlerConfig, HandlerRequest, HandlerResponse, Tool } from '../utils/types.js';
|
|
2
|
+
export declare const CONFIG_TYPE_TOOLS: Tool[];
|
|
3
|
+
export declare const CONFIG_TYPE_HANDLERS: Record<string, (request: HandlerRequest, config: HandlerConfig) => Promise<HandlerResponse>>;
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { createErrorResponse } from '../utils/http-utility.js';
|
|
2
|
+
import { withAuthenticatedClient } from '../utils/authenticated-client.js';
|
|
3
|
+
import { listConfigTypes, detailConfigType, createConfigType, deleteConfigType, patchConfigType, listConfigsForConfigType, } from '../utils/controller-client/sdk.gen.js';
|
|
4
|
+
// Define all available Config Type tools
|
|
5
|
+
export const CONFIG_TYPE_TOOLS = [
|
|
6
|
+
{
|
|
7
|
+
name: 'listConfigTypes',
|
|
8
|
+
description: 'List all Config Types in the Ziti network',
|
|
9
|
+
inputSchema: {
|
|
10
|
+
type: 'object',
|
|
11
|
+
properties: {},
|
|
12
|
+
},
|
|
13
|
+
_meta: {
|
|
14
|
+
requiredScopes: ['read:config-types'],
|
|
15
|
+
readOnly: true,
|
|
16
|
+
},
|
|
17
|
+
annotations: {
|
|
18
|
+
title: 'List all Config Types defined in the Ziti network.',
|
|
19
|
+
readOnlyHint: true,
|
|
20
|
+
destructiveHint: false,
|
|
21
|
+
idempotentHint: true,
|
|
22
|
+
openWorldHint: false,
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
name: 'listConfigType',
|
|
27
|
+
description: 'Get details about a specific Ziti Config Type',
|
|
28
|
+
inputSchema: {
|
|
29
|
+
type: 'object',
|
|
30
|
+
properties: {
|
|
31
|
+
id: { type: 'string', description: 'ID of the config type to retrieve' },
|
|
32
|
+
},
|
|
33
|
+
required: ['id'],
|
|
34
|
+
},
|
|
35
|
+
_meta: {
|
|
36
|
+
requiredScopes: ['read:config-types'],
|
|
37
|
+
readOnly: true,
|
|
38
|
+
},
|
|
39
|
+
annotations: {
|
|
40
|
+
title: 'Get Ziti Config Type Details',
|
|
41
|
+
readOnlyHint: true,
|
|
42
|
+
destructiveHint: false,
|
|
43
|
+
idempotentHint: true,
|
|
44
|
+
openWorldHint: false,
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
name: 'createConfigType',
|
|
49
|
+
description: 'Create a new Ziti Config Type.',
|
|
50
|
+
inputSchema: {
|
|
51
|
+
type: 'object',
|
|
52
|
+
properties: {
|
|
53
|
+
name: { type: 'string', description: 'Name of the config type to create' },
|
|
54
|
+
schema: {
|
|
55
|
+
type: 'object',
|
|
56
|
+
description: 'A JSON schema to enforce configuration against',
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
required: ['name'],
|
|
60
|
+
},
|
|
61
|
+
_meta: {
|
|
62
|
+
requiredScopes: ['write:config-types'],
|
|
63
|
+
readOnly: false,
|
|
64
|
+
},
|
|
65
|
+
annotations: {
|
|
66
|
+
title: 'Create a new Config Type in the Ziti network.',
|
|
67
|
+
readOnlyHint: false,
|
|
68
|
+
destructiveHint: false,
|
|
69
|
+
idempotentHint: false,
|
|
70
|
+
openWorldHint: false,
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
name: 'deleteConfigType',
|
|
75
|
+
description: 'Delete a Ziti Config Type.',
|
|
76
|
+
inputSchema: {
|
|
77
|
+
type: 'object',
|
|
78
|
+
properties: {
|
|
79
|
+
id: { type: 'string', description: 'ID of the config type to delete' },
|
|
80
|
+
},
|
|
81
|
+
required: ['id'],
|
|
82
|
+
},
|
|
83
|
+
_meta: {
|
|
84
|
+
requiredScopes: ['write:config-types'],
|
|
85
|
+
readOnly: false,
|
|
86
|
+
},
|
|
87
|
+
annotations: {
|
|
88
|
+
title: 'Delete a Config Type from the Ziti network.',
|
|
89
|
+
readOnlyHint: false,
|
|
90
|
+
destructiveHint: true,
|
|
91
|
+
idempotentHint: false,
|
|
92
|
+
openWorldHint: false,
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
name: 'updateConfigType',
|
|
97
|
+
description: 'Update an existing Ziti Config Type.',
|
|
98
|
+
inputSchema: {
|
|
99
|
+
type: 'object',
|
|
100
|
+
properties: {
|
|
101
|
+
id: { type: 'string', description: 'ID of the config type to update' },
|
|
102
|
+
name: { type: 'string', description: 'Name to give the config type' },
|
|
103
|
+
schema: {
|
|
104
|
+
type: 'object',
|
|
105
|
+
description: 'A JSON schema to enforce configuration against',
|
|
106
|
+
},
|
|
107
|
+
},
|
|
108
|
+
required: ['id'],
|
|
109
|
+
},
|
|
110
|
+
_meta: {
|
|
111
|
+
requiredScopes: ['write:config-types'],
|
|
112
|
+
readOnly: false,
|
|
113
|
+
},
|
|
114
|
+
annotations: {
|
|
115
|
+
title: 'Update an existing Config Type in the Ziti network.',
|
|
116
|
+
readOnlyHint: false,
|
|
117
|
+
destructiveHint: true,
|
|
118
|
+
idempotentHint: true,
|
|
119
|
+
openWorldHint: false,
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
name: 'listConfigsForConfigType',
|
|
124
|
+
description: 'List all Configs that use a specific Config Type',
|
|
125
|
+
inputSchema: {
|
|
126
|
+
type: 'object',
|
|
127
|
+
properties: {
|
|
128
|
+
id: { type: 'string', description: 'ID of the config type' },
|
|
129
|
+
},
|
|
130
|
+
required: ['id'],
|
|
131
|
+
},
|
|
132
|
+
_meta: {
|
|
133
|
+
requiredScopes: ['read:config-types'],
|
|
134
|
+
readOnly: true,
|
|
135
|
+
},
|
|
136
|
+
annotations: {
|
|
137
|
+
title: 'List Configs for a Config Type.',
|
|
138
|
+
readOnlyHint: true,
|
|
139
|
+
destructiveHint: false,
|
|
140
|
+
idempotentHint: true,
|
|
141
|
+
openWorldHint: false,
|
|
142
|
+
},
|
|
143
|
+
},
|
|
144
|
+
];
|
|
145
|
+
// Define handlers for each Config Type tool
|
|
146
|
+
export const CONFIG_TYPE_HANDLERS = {
|
|
147
|
+
listConfigTypes: (request, config) => withAuthenticatedClient(request, config, 'list config types', (client, ztSession) => listConfigTypes({ client, headers: { 'zt-session': ztSession } })),
|
|
148
|
+
listConfigType: (request, config) => {
|
|
149
|
+
const { id } = request.parameters;
|
|
150
|
+
if (!id)
|
|
151
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
152
|
+
return withAuthenticatedClient(request, config, 'get config type', (client, ztSession) => detailConfigType({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
153
|
+
},
|
|
154
|
+
createConfigType: (request, config) => {
|
|
155
|
+
const { name, schema } = request.parameters;
|
|
156
|
+
if (!name)
|
|
157
|
+
return Promise.resolve(createErrorResponse('Error: name is required'));
|
|
158
|
+
return withAuthenticatedClient(request, config, 'create config type', (client, ztSession) => createConfigType({
|
|
159
|
+
body: {
|
|
160
|
+
name,
|
|
161
|
+
schema,
|
|
162
|
+
},
|
|
163
|
+
client,
|
|
164
|
+
headers: { 'zt-session': ztSession },
|
|
165
|
+
}));
|
|
166
|
+
},
|
|
167
|
+
deleteConfigType: (request, config) => {
|
|
168
|
+
const { id } = request.parameters;
|
|
169
|
+
if (!id)
|
|
170
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
171
|
+
return withAuthenticatedClient(request, config, 'delete config type', (client, ztSession) => deleteConfigType({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
172
|
+
},
|
|
173
|
+
updateConfigType: (request, config) => {
|
|
174
|
+
const { id, name, schema } = request.parameters;
|
|
175
|
+
if (!id)
|
|
176
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
177
|
+
return withAuthenticatedClient(request, config, 'update config type', (client, ztSession) => patchConfigType({
|
|
178
|
+
path: { id },
|
|
179
|
+
body: {
|
|
180
|
+
name,
|
|
181
|
+
schema,
|
|
182
|
+
},
|
|
183
|
+
client,
|
|
184
|
+
headers: { 'zt-session': ztSession },
|
|
185
|
+
}));
|
|
186
|
+
},
|
|
187
|
+
listConfigsForConfigType: (request, config) => {
|
|
188
|
+
const { id } = request.parameters;
|
|
189
|
+
if (!id)
|
|
190
|
+
return Promise.resolve(createErrorResponse('Error: id is required'));
|
|
191
|
+
return withAuthenticatedClient(request, config, 'list configs for config type', (client, ztSession) => listConfigsForConfigType({ path: { id }, client, headers: { 'zt-session': ztSession } }));
|
|
192
|
+
},
|
|
193
|
+
};
|
|
194
|
+
//# sourceMappingURL=config-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config-types.js","sourceRoot":"","sources":["../../src/tools/config-types.ts"],"names":[],"mappings":"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"}
|