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)
          }]
        };
      }
    );
Install Server

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