Critical Risk →

bazel_ios_clean

Clean Bazel build outputs. Use expunge to remove the entire output base.

How to control bazel_ios_clean ↓

What bazel_ios_clean does on XcodeBazelMCP

AI agents call bazel_ios_clean to permanently remove resources in XcodeBazelMCP — typically in cleanup and lifecycle workflows. It does its job in a single call, and there is no undo.

Critical Risk

Why bazel_ios_clean needs a policy

The bazel_ios_clean tool, particularly with the expunge option, irreversibly deletes or removes data (build outputs and the entire output base). This matches the Destructive category definition: 'irreversibly deletes or overwrites data, or actions that cannot be undone.' While not as critical as deleting source code, losing build outputs can disrupt workflows and requires rebuilding.

From the tool's definition Tool name includes 'clean' and description explicitly states it 'Clean[s] Bazel build outputs' with option to 'expunge' and 'remove the entire output base.' These are irreversible operations that destroy build artifacts and cached data.

Risk signalsBulk/mass operation — affects multiple targets

Documented attack patterns abuse exactly the kind of access bazel_ios_clean gives an agent:

How to control bazel_ios_clean

PolicyLayer is an MCP gateway — it sits between your AI agents and XcodeBazelMCP, and nothing reaches the server without passing your rules. This is the rule we recommend for bazel_ios_clean:

policy.json
{
  "version": "1",
  "default": "deny",
  "hide": [
    "bazel_ios_clean"
  ]
}

bazel_ios_clean disappears from the agent's tool list entirely, and any attempt to call it is denied. The rest of the server keeps working.

  1. Create a free account and register XcodeBazelMCP — nothing to install.
  2. Add this policy — paste it, or build it visually.
  3. Point your MCP client (Claude, Cursor, anything) at your gateway URL.
RESTRICT THIS TOOL →

Free to start. No card required.

Related tools and policies

Go deeper

Questions about bazel_ios_clean

What does the bazel_ios_clean tool do? +

Clean Bazel build outputs. Use expunge to remove the entire output base. It is categorised as a Destructive tool in the XcodeBazelMCP MCP Server, which means it can permanently delete or destroy data. Block by default and require explicit approval.

How do I enforce a policy on bazel_ios_clean? +

Register the XcodeBazel MCP server in PolicyLayer and add a rule for bazel_ios_clean: allow, deny, rate-limit, or require approval. Point your MCP client at the PolicyLayer proxy URL and the rule is enforced on every call, before it reaches XcodeBazelMCP. Nothing to install.

What risk level is bazel_ios_clean? +

bazel_ios_clean is a Destructive tool with critical risk. Critical-risk tools should be blocked by default and only enabled with explicit human approval.

Can I rate-limit bazel_ios_clean? +

Yes. Add a rate_limit block to the bazel_ios_clean rule in your PolicyLayer policy. For example, setting max: 10 and window: 60 limits the tool to 10 calls per minute. Rate limits are tracked per agent session and reset automatically.

How do I block bazel_ios_clean completely? +

Set action: deny in the PolicyLayer policy for bazel_ios_clean. The AI agent will receive a policy violation error and cannot call the tool. You can also include a reason field to explain why the tool is blocked.

What MCP server provides bazel_ios_clean? +

bazel_ios_clean is provided by the XcodeBazel MCP server (xcodebazelmcp/xcodebazelmcp). PolicyLayer sits as a proxy in front of this server to enforce policies before tool calls reach the server.

Enforce policy on every XcodeBazelMCP tool call.

Start from XcodeBazelMCP, add the rest of your stack, and see everything your agents can call. Then put policy on all of it.

Free to start. No card required.

117 XcodeBazelMCP tools catalogued and risk-classified — across an index of 43,000+ MCP servers.

// GET IN TOUCH

Have a question or want to learn more? Send us a message.

Message sent.

We'll get back to you soon.