create_voice_channel
Create a new voice channel in a Discord server with customizable settings like name, user limit, and bitrate.
Instructions
Create a new voice channel in the specified server.
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| name | Yes | ||
| server_id | No | ||
| category_id | No | ||
| user_limit | No | ||
| bitrate | No | ||
| reason | No |
Implementation Reference
- The handler function that executes the create_voice_channel tool logic, fetching the guild, building kwargs from arguments, and calling guild.create_voice_channel.async def handle_create_voice_channel(discord_client, arguments: Dict[str, Any]) -> List[TextContent]: """Create a voice channel""" guild = await discord_client.fetch_guild(int(arguments["server_id"])) kwargs = { "name": arguments["name"], "reason": "Voice channel created via MCP" } if "category_id" in arguments: category = guild.get_channel(int(arguments["category_id"])) kwargs["category"] = category if "user_limit" in arguments: kwargs["user_limit"] = arguments["user_limit"] if "bitrate" in arguments: kwargs["bitrate"] = arguments["bitrate"] if "position" in arguments: kwargs["position"] = arguments["position"] channel = await guild.create_voice_channel(**kwargs) return [TextContent( type="text", text=f"Created voice channel '{channel.name}' (ID: {channel.id}) in {guild.name}" )]
- The input schema defining parameters for the create_voice_channel tool, including server_id, name, and optional settings like bitrate and user_limit.inputSchema={ "type": "object", "properties": { "server_id": {"type": "string", "description": "Server ID"}, "name": {"type": "string", "description": "Channel name"}, "category_id": {"type": "string", "description": "Optional category ID"}, "user_limit": {"type": "number", "description": "User limit (0 for unlimited)"}, "bitrate": {"type": "number", "description": "Audio bitrate"}, "position": {"type": "number", "description": "Channel position"} }, "required": ["server_id", "name"] }
- src/discord_mcp/integrated_server.py:174-189 (registration)The Tool object registration for create_voice_channel, including name, description, and input schema.Tool( name="create_voice_channel", description="Create a voice channel with custom settings", inputSchema={ "type": "object", "properties": { "server_id": {"type": "string", "description": "Server ID"}, "name": {"type": "string", "description": "Channel name"}, "category_id": {"type": "string", "description": "Optional category ID"}, "user_limit": {"type": "number", "description": "User limit (0 for unlimited)"}, "bitrate": {"type": "number", "description": "Audio bitrate"}, "position": {"type": "number", "description": "Channel position"} }, "required": ["server_id", "name"] } ),
- src/discord_mcp/integrated_server.py:1005-1019 (registration)The dispatch logic in call_tool that routes 'create_voice_channel' to AdvancedToolHandlers.handle_create_voice_channel based on the advanced_tool_names list.advanced_tool_names = [ "edit_server_settings", "create_server_template", "create_channel_category", "create_voice_channel", "create_stage_channel", "create_forum_channel", "create_announcement_channel", "edit_channel", "set_channel_permissions", "create_role", "edit_role", "delete_role", "create_role_hierarchy", "create_emoji", "create_webhook", "send_webhook_message", "ban_member", "kick_member", "timeout_member", "bulk_delete_messages", "create_scheduled_event", "create_invite", "create_thread", "create_automod_rule" ] if name in advanced_tool_names: handler_method = f"handle_{name}" if hasattr(AdvancedToolHandlers, handler_method): return await getattr(AdvancedToolHandlers, handler_method)(discord_client, arguments)