Skip to main content
Glama
terrakube-io

Terrakube MCP Server

by terrakube-io

create-workspace

Generate a new workspace in a specified organization with defined Terraform version, name, and optional VCS settings using the Terrakube MCP Server.

Instructions

Creates a new workspace in the specified organization

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
descriptionNoWorkspace description
nameYesWorkspace name
organizationIdYesOrganization ID
terraformVersionYesTerraform version
vcsProviderNoVCS provider (e.g., github, gitlab)
vcsRepoNoVCS repository URL

Implementation Reference

  • The asynchronous handler function that implements the core logic of the 'create-workspace' tool. It sends a POST request to the Terrakube API endpoint to create a new workspace using the provided organizationId, name, description, terraformVersion, vcsProvider, and vcsRepo, then returns the JSON response.
    async ({ organizationId, name, description, terraformVersion, vcsProvider, vcsRepo }) => { const response = await fetch(`${CONFIG.apiUrl}/organization/${organizationId}/workspace`, { method: "POST", headers: { Authorization: `Bearer ${CONFIG.patToken}`, "Content-Type": "application/vnd.api+json" }, body: JSON.stringify({ data: { type: "workspace", attributes: { name, description, terraformVersion, vcsProvider, vcsRepo } } }) }); if (!response.ok) { throw new Error(`Failed to create workspace: ${response.statusText}`); } const data = await response.json(); return { content: [{ type: "text", text: JSON.stringify(data, null, 2) }] }; }
  • Zod input schema defining the parameters for the 'create-workspace' tool: organizationId (required), name (required), description (optional), terraformVersion (required), vcsProvider (optional), vcsRepo (optional).
    { organizationId: z.string().describe("Organization ID"), name: z.string().describe("Workspace name"), description: z.string().optional().describe("Workspace description"), terraformVersion: z.string().describe("Terraform version"), vcsProvider: z.string().optional().describe("VCS provider (e.g., github, gitlab)"), vcsRepo: z.string().optional().describe("VCS repository URL") },
  • The server.tool() registration call for the 'create-workspace' tool within the registerWorkspaceTools function, specifying name, description, input schema, and handler.
    server.tool( "create-workspace", "Creates a new workspace in the specified organization", { organizationId: z.string().describe("Organization ID"), name: z.string().describe("Workspace name"), description: z.string().optional().describe("Workspace description"), terraformVersion: z.string().describe("Terraform version"), vcsProvider: z.string().optional().describe("VCS provider (e.g., github, gitlab)"), vcsRepo: z.string().optional().describe("VCS repository URL") }, async ({ organizationId, name, description, terraformVersion, vcsProvider, vcsRepo }) => { const response = await fetch(`${CONFIG.apiUrl}/organization/${organizationId}/workspace`, { method: "POST", headers: { Authorization: `Bearer ${CONFIG.patToken}`, "Content-Type": "application/vnd.api+json" }, body: JSON.stringify({ data: { type: "workspace", attributes: { name, description, terraformVersion, vcsProvider, vcsRepo } } }) }); if (!response.ok) { throw new Error(`Failed to create workspace: ${response.statusText}`); } const data = await response.json(); return { content: [{ type: "text", text: JSON.stringify(data, null, 2) }] }; } );

Other Tools

Related Tools

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/terrakube-io/mcp-server-terrakube'

If you have feedback or need assistance with the MCP directory API, please join our Discord server