Skip to main content
Glama
Michaelzag
by Michaelzag

delete_rewrite

Remove specific email rewrite rules permanently on Migadu MCP Server. Input requires a list of targets with 'name' (required) and optional 'domain'. This action is irreversible.

Instructions

Delete rewrite rules. DESTRUCTIVE: Cannot be undone. List of dicts with: name (required), domain (optional).

Input Schema

NameRequiredDescriptionDefault
targetsYes

Input Schema (JSON Schema)

{ "properties": { "targets": { "items": { "additionalProperties": true, "type": "object" }, "title": "Targets", "type": "array" } }, "required": [ "targets" ], "type": "object" }

Implementation Reference

  • The main handler function for the 'delete_rewrite' MCP tool. It handles bulk deletion requests by calling the process_delete_rewrite helper.
    @mcp.tool( annotations={ "readOnlyHint": False, "destructiveHint": True, "idempotentHint": True, "openWorldHint": True, }, ) async def delete_rewrite( targets: List[Dict[str, Any]], ctx: Context ) -> Dict[str, Any]: """Delete rewrite rules. DESTRUCTIVE: Cannot be undone. List of dicts with: name (required), domain (optional).""" count = len(list(ensure_iterable(targets))) await log_bulk_operation_start(ctx, "Deleting", count, "rewrite rule") await ctx.warning("๐Ÿ—‘๏ธ DESTRUCTIVE: This operation cannot be undone!") result = await process_delete_rewrite(targets, ctx) await log_bulk_operation_result( ctx, "Rewrite rule deletion", result, "rewrite rule" ) return result
  • Pydantic input schema RewriteDeleteRequest used by bulk_processor_with_schema for validating each delete target.
    class RewriteDeleteRequest(BaseModel): """Request schema for deleting a rewrite rule""" name: str = Field(..., description="Identifier/slug of the rule to delete") domain: Optional[str] = Field(None, description="Domain name")
  • Call to register_rewrite_tools which defines and registers the delete_rewrite tool (along with other rewrite tools) on the MCP server.
    register_rewrite_tools(mcp)
  • Helper function process_delete_rewrite that validates individual items using the schema and calls the service layer to perform the deletion.
    @bulk_processor_with_schema(RewriteDeleteRequest) async def process_delete_rewrite( validated_item: RewriteDeleteRequest, ctx: Context ) -> Dict[str, Any]: """Process a single rewrite rule deletion with Pydantic validation""" # Use validated Pydantic model directly - all validation already done name = validated_item.name domain = validated_item.domain # Get domain if not provided if domain is None: from migadu_mcp.config import get_config config = get_config() domain = config.get_default_domain() if not domain: raise ValueError("No domain provided and MIGADU_DOMAIN not configured") await ctx.warning(f"๐Ÿ—‘๏ธ DESTRUCTIVE: Deleting rewrite rule {name}@{domain}") service = get_service_factory().rewrite_service() await service.delete_rewrite(domain, name) await log_operation_success(ctx, "Deleted rewrite rule", f"{name}@{domain}") return {"deleted": f"{name}@{domain}", "success": True}
  • Service layer implementation that makes the actual Migadu API DELETE request to remove the rewrite rule.
    async def delete_rewrite(self, domain: str, name: str) -> Dict[str, Any]: """Delete a rewrite rule""" return await self.client.request("DELETE", f"/domains/{domain}/rewrites/{name}")

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/Michaelzag/migadu-mcp'

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