w3_space_provision
Associates a decentralized storage space with a customer or billing account by linking a space DID to a customer identifier for simplified storage management.
Instructions
Associates a space with a customer/billing account.
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| customerId | Yes | Customer identifier (e.g., email or account DID) to associate the space with. | |
| spaceDid | Yes | The DID of the space to provision. |
Implementation Reference
- src/tool_handlers.ts:727-748 (handler)The handler function that implements the core logic for the w3_space_provision tool. It validates input using the schema, executes the w3cli 'space provision' command, and formats the response.const handleW3SpaceProvision: ToolHandler = async (args) => { const parsed = Schemas.W3SpaceProvisionArgsSchema.safeParse(args); if (!parsed.success) throw new Error( `Invalid arguments for w3_space_provision: ${parsed.error.message}` ); const { customerId, spaceDid } = parsed.data; const { stdout } = await runW3Command( `space provision ${customerId} --space ${spaceDid}` ); return { content: [ { type: "text", text: JSON.stringify({ message: `Space ${spaceDid} provisioned for customer ${customerId}.`, output: stdout.trim(), }), }, ], }; };
- src/schemas.ts:303-315 (schema)Zod schema defining the input arguments for the w3_space_provision tool, including customerId and spaceDid.export const W3SpaceProvisionArgsSchema = z .object({ customerId: z .string() .describe( "Customer identifier (e.g., email or account DID) to associate the space with." ), spaceDid: z .string() .startsWith("did:key:") .describe("The DID of the space to provision."), }) .describe("Associates a space with a customer/billing account.");
- src/tool_handlers.ts:944-980 (registration)The toolHandlers map registers the handleW3SpaceProvision function under the 'w3_space_provision' key, which is used by the MCP server to route CallTool requests.export const toolHandlers: Record<string, ToolHandler> = { w3_login: handleW3Login, w3_space_ls: handleW3SpaceLs, w3_space_use: handleW3SpaceUse, w3_space_create: handleW3SpaceCreate, w3_up: handleW3Up, w3_ls: handleW3Ls, w3_rm: handleW3Rm, w3_open: handleW3Open, w3_space_info: handleW3SpaceInfo, w3_space_add: handleW3SpaceAdd, w3_delegation_create: handleW3DelegationCreate, w3_delegation_ls: handleW3DelegationLs, w3_delegation_revoke: handleW3DelegationRevoke, w3_proof_add: handleW3ProofAdd, w3_proof_ls: handleW3ProofLs, w3_key_create: handleW3KeyCreate, w3_bridge_generate_tokens: handleW3BridgeGenerateTokens, w3_can_blob_add: handleW3CanBlobAdd, w3_can_blob_ls: handleW3CanBlobLs, w3_can_blob_rm: handleW3CanBlobRm, w3_can_index_add: handleW3CanIndexAdd, w3_can_upload_add: handleW3CanUploadAdd, w3_can_upload_ls: handleW3CanUploadLs, w3_can_upload_rm: handleW3CanUploadRm, w3_plan_get: handleW3PlanGet, w3_account_ls: handleW3AccountLs, w3_space_provision: handleW3SpaceProvision, w3_coupon_create: handleW3CouponCreate, w3_usage_report: handleW3UsageReport, w3_can_access_claim: handleW3CanAccessClaim, w3_can_store_add: handleW3CanStoreAdd, w3_can_store_ls: handleW3CanStoreLs, w3_can_store_rm: handleW3CanStoreRm, w3_can_filecoin_info: handleW3CanFilecoinInfo, w3_reset: handleW3Reset, };