mcp-server-kubernetes 1.6.2 → 2.0.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/README.md +46 -22
- package/dist/config/container-templates.d.ts +2 -2
- package/dist/index.d.ts +314 -736
- package/dist/index.js +93 -200
- package/dist/models/resource-models.d.ts +6 -6
- package/dist/tools/kubectl-apply.d.ts +46 -0
- package/dist/tools/kubectl-apply.js +110 -0
- package/dist/tools/kubectl-context.d.ts +49 -0
- package/dist/tools/kubectl-context.js +233 -0
- package/dist/tools/kubectl-create.d.ts +150 -0
- package/dist/tools/kubectl-create.js +321 -0
- package/dist/tools/kubectl-delete.d.ts +77 -0
- package/dist/tools/kubectl-delete.js +177 -0
- package/dist/tools/kubectl-describe.d.ts +47 -0
- package/dist/tools/kubectl-describe.js +96 -0
- package/dist/tools/kubectl-generic.d.ts +71 -0
- package/dist/tools/kubectl-generic.js +121 -0
- package/dist/tools/kubectl-get.d.ts +72 -0
- package/dist/tools/kubectl-get.js +251 -0
- package/dist/tools/kubectl-list.d.ts +61 -0
- package/dist/tools/kubectl-list.js +189 -0
- package/dist/tools/{get_logs.d.ts → kubectl-logs.d.ts} +35 -19
- package/dist/tools/kubectl-logs.js +312 -0
- package/dist/tools/kubectl-patch.d.ts +57 -0
- package/dist/tools/kubectl-patch.js +128 -0
- package/dist/tools/kubectl-rollout.d.ts +67 -0
- package/dist/tools/kubectl-rollout.js +115 -0
- package/dist/tools/{scale_deployment.d.ts → kubectl-scale.d.ts} +13 -3
- package/dist/tools/kubectl-scale.js +73 -0
- package/package.json +1 -1
- package/dist/tools/create_configmap.d.ts +0 -33
- package/dist/tools/create_configmap.js +0 -66
- package/dist/tools/create_cronjob.d.ts +0 -47
- package/dist/tools/create_cronjob.js +0 -93
- package/dist/tools/create_deployment.d.ts +0 -135
- package/dist/tools/create_deployment.js +0 -162
- package/dist/tools/create_namespace.d.ts +0 -22
- package/dist/tools/create_namespace.js +0 -48
- package/dist/tools/create_pod.d.ts +0 -130
- package/dist/tools/create_pod.js +0 -153
- package/dist/tools/create_service.d.ts +0 -74
- package/dist/tools/create_service.js +0 -102
- package/dist/tools/delete_configmap.d.ts +0 -26
- package/dist/tools/delete_configmap.js +0 -49
- package/dist/tools/delete_cronjob.d.ts +0 -26
- package/dist/tools/delete_cronjob.js +0 -48
- package/dist/tools/delete_deployment.d.ts +0 -31
- package/dist/tools/delete_deployment.js +0 -47
- package/dist/tools/delete_namespace.d.ts +0 -27
- package/dist/tools/delete_namespace.js +0 -44
- package/dist/tools/delete_pod.d.ts +0 -31
- package/dist/tools/delete_pod.js +0 -45
- package/dist/tools/delete_service.d.ts +0 -32
- package/dist/tools/delete_service.js +0 -46
- package/dist/tools/describe_cronjob.d.ts +0 -27
- package/dist/tools/describe_cronjob.js +0 -83
- package/dist/tools/describe_deployment.d.ts +0 -26
- package/dist/tools/describe_deployment.js +0 -40
- package/dist/tools/describe_node.d.ts +0 -22
- package/dist/tools/describe_node.js +0 -84
- package/dist/tools/describe_pod.d.ts +0 -33
- package/dist/tools/describe_pod.js +0 -81
- package/dist/tools/describe_service.d.ts +0 -34
- package/dist/tools/describe_service.js +0 -85
- package/dist/tools/get_configmap.d.ts +0 -27
- package/dist/tools/get_configmap.js +0 -48
- package/dist/tools/get_current_context.d.ts +0 -23
- package/dist/tools/get_current_context.js +0 -55
- package/dist/tools/get_events.d.ts +0 -28
- package/dist/tools/get_events.js +0 -66
- package/dist/tools/get_job_logs.d.ts +0 -40
- package/dist/tools/get_job_logs.js +0 -104
- package/dist/tools/get_logs.js +0 -150
- package/dist/tools/list_contexts.d.ts +0 -23
- package/dist/tools/list_contexts.js +0 -39
- package/dist/tools/list_cronjobs.d.ts +0 -23
- package/dist/tools/list_cronjobs.js +0 -35
- package/dist/tools/list_deployments.d.ts +0 -23
- package/dist/tools/list_deployments.js +0 -30
- package/dist/tools/list_jobs.d.ts +0 -29
- package/dist/tools/list_jobs.js +0 -77
- package/dist/tools/list_nodes.d.ts +0 -15
- package/dist/tools/list_nodes.js +0 -21
- package/dist/tools/list_pods.d.ts +0 -23
- package/dist/tools/list_pods.js +0 -29
- package/dist/tools/list_services.d.ts +0 -23
- package/dist/tools/list_services.js +0 -31
- package/dist/tools/scale_deployment.js +0 -50
- package/dist/tools/set_current_context.d.ts +0 -23
- package/dist/tools/set_current_context.js +0 -35
- package/dist/tools/update_configmap.d.ts +0 -33
- package/dist/tools/update_configmap.js +0 -71
- package/dist/tools/update_deployment.d.ts +0 -113
- package/dist/tools/update_deployment.js +0 -155
- package/dist/tools/update_service.d.ts +0 -72
- package/dist/tools/update_service.js +0 -125
|
@@ -1,125 +0,0 @@
|
|
|
1
|
-
import { McpError, ErrorCode } from "@modelcontextprotocol/sdk/types.js";
|
|
2
|
-
export const updateServiceSchema = {
|
|
3
|
-
name: "update_service",
|
|
4
|
-
description: "Update an existing kubernetes service in cluster",
|
|
5
|
-
inputSchema: {
|
|
6
|
-
type: "object",
|
|
7
|
-
required: ["name", "namespace"],
|
|
8
|
-
properties: {
|
|
9
|
-
name: { type: "string" },
|
|
10
|
-
namespace: { type: "string", default: "default" },
|
|
11
|
-
type: {
|
|
12
|
-
type: "string",
|
|
13
|
-
enum: ["ClusterIP", "NodePort", "LoadBalancer"],
|
|
14
|
-
},
|
|
15
|
-
selector: {
|
|
16
|
-
type: "object",
|
|
17
|
-
additionalProperties: { type: "string" },
|
|
18
|
-
},
|
|
19
|
-
ports: {
|
|
20
|
-
type: "array",
|
|
21
|
-
items: {
|
|
22
|
-
type: "object",
|
|
23
|
-
properties: {
|
|
24
|
-
port: { type: "number" },
|
|
25
|
-
targetPort: { type: "number" },
|
|
26
|
-
protocol: {
|
|
27
|
-
type: "string",
|
|
28
|
-
enum: ["TCP", "UDP"],
|
|
29
|
-
default: "TCP"
|
|
30
|
-
},
|
|
31
|
-
name: { type: "string" },
|
|
32
|
-
nodePort: { type: "number" }
|
|
33
|
-
},
|
|
34
|
-
required: ["port"]
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
},
|
|
38
|
-
},
|
|
39
|
-
};
|
|
40
|
-
export async function updateService(k8sManager, params) {
|
|
41
|
-
// Get existing service
|
|
42
|
-
const { body: existingService } = await k8sManager
|
|
43
|
-
.getCoreApi()
|
|
44
|
-
.readNamespacedService(params.name, params.namespace)
|
|
45
|
-
.catch((error) => {
|
|
46
|
-
console.error("Service read error:", {
|
|
47
|
-
status: error.response?.statusCode,
|
|
48
|
-
message: error.response?.body?.message || error.message,
|
|
49
|
-
details: error.response?.body,
|
|
50
|
-
});
|
|
51
|
-
if (error.response?.statusCode === 404) {
|
|
52
|
-
throw new McpError(ErrorCode.InvalidRequest, `Service '${params.name}' not found in namespace '${params.namespace}'`);
|
|
53
|
-
}
|
|
54
|
-
throw new McpError(ErrorCode.InternalError, `Failed to retrieve service: ${error.response?.body?.message || error.message}`);
|
|
55
|
-
});
|
|
56
|
-
// Process ports if provided
|
|
57
|
-
let servicePorts;
|
|
58
|
-
if (params.ports) {
|
|
59
|
-
servicePorts = params.ports.map((portConfig, index) => {
|
|
60
|
-
const existingPort = existingService.spec?.ports?.[index];
|
|
61
|
-
const name = portConfig.name || (existingPort?.name || `port-${index}`);
|
|
62
|
-
return {
|
|
63
|
-
port: portConfig.port,
|
|
64
|
-
targetPort: portConfig.targetPort !== undefined
|
|
65
|
-
? portConfig.targetPort
|
|
66
|
-
: portConfig.port,
|
|
67
|
-
protocol: portConfig.protocol || "TCP",
|
|
68
|
-
name: name,
|
|
69
|
-
...(existingService.spec?.type === "NodePort" || params.type === "NodePort" ?
|
|
70
|
-
{ nodePort: portConfig.nodePort !== undefined ? portConfig.nodePort : existingPort?.nodePort } : {})
|
|
71
|
-
};
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
const updatedService = {
|
|
75
|
-
...existingService,
|
|
76
|
-
spec: {
|
|
77
|
-
...existingService.spec,
|
|
78
|
-
type: params.type || existingService.spec.type,
|
|
79
|
-
selector: params.selector || existingService.spec.selector,
|
|
80
|
-
ports: servicePorts || existingService.spec.ports,
|
|
81
|
-
clusterIP: existingService.spec.clusterIP,
|
|
82
|
-
},
|
|
83
|
-
};
|
|
84
|
-
try {
|
|
85
|
-
const { body } = await k8sManager
|
|
86
|
-
.getCoreApi()
|
|
87
|
-
.replaceNamespacedService(params.name, params.namespace, updatedService);
|
|
88
|
-
return {
|
|
89
|
-
content: [
|
|
90
|
-
{
|
|
91
|
-
type: "text",
|
|
92
|
-
text: JSON.stringify({
|
|
93
|
-
message: "Service updated successfully",
|
|
94
|
-
service: {
|
|
95
|
-
name: body.metadata?.name,
|
|
96
|
-
namespace: body.metadata?.namespace,
|
|
97
|
-
type: body.spec?.type,
|
|
98
|
-
clusterIP: body.spec?.clusterIP,
|
|
99
|
-
ports: body.spec?.ports,
|
|
100
|
-
},
|
|
101
|
-
}, null, 2),
|
|
102
|
-
},
|
|
103
|
-
],
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
catch (error) {
|
|
107
|
-
console.error("Service update error:", {
|
|
108
|
-
status: error.response?.statusCode,
|
|
109
|
-
message: error.response?.body?.message || error.message,
|
|
110
|
-
details: error.response?.body,
|
|
111
|
-
});
|
|
112
|
-
if (error instanceof McpError)
|
|
113
|
-
throw error;
|
|
114
|
-
// Handle specific Kubernetes API errors
|
|
115
|
-
if (error.response?.body?.message) {
|
|
116
|
-
if (error.response.body.message.includes("field is immutable")) {
|
|
117
|
-
throw new McpError(ErrorCode.InvalidRequest, `Update failed: Attempted to modify immutable field. ${error.response.body.message}`);
|
|
118
|
-
}
|
|
119
|
-
if (error.response.statusCode === 422) {
|
|
120
|
-
throw new McpError(ErrorCode.InvalidRequest, `Invalid service configuration: ${error.response.body.message}`);
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
throw new McpError(ErrorCode.InternalError, `Failed to update service: ${error.response?.body?.message || error.message}`);
|
|
124
|
-
}
|
|
125
|
-
}
|