Skip to main content

Azure MCP Agent for secure, compliant resource deployment

Project description

Azure MCP Agent (Custom)

This repository contains a custom MCP server (server.py) exposing tools to:

  1. List active Azure role assignments for the signed-in user.
  2. List Azure resources (subscription-wide or specific resource group).
  3. Deploy resources via Bicep-backed PowerShell scripts (storage account, key vault, Azure OpenAI, AI Search, AI Foundry).

Prerequisites

Python Setup

cd "c:\Users\v-siddjha\OneDrive - MAQ Software\Desktop\agent"
python -m venv .venv
. .venv\Scripts\Activate.ps1
pip install -r requirements.txt

Run MCP Server Directly

python server.py

This starts the MCP process that tools (e.g., GitHub Copilot Agent) can attach to.

Configure GitHub Copilot to Use This MCP Server

In VS Code settings (JSON view), add an MCP server entry. Example:

"github.copilot.mcpServers": {
  "azure-agent": {
    "command": "python",
    "args": [
      "c:/Users/v-siddjha/OneDrive - MAQ Software/Desktop/agent/server.py"
    ],
    "env": {
      "PYTHONUNBUFFERED": "1"
    }
  }
}

Restart VS Code or Copilot Agent session. Copilot should list available tools (azure_login, list_permissions, list_resources, get_resource_parameters, deploy_resource).

Tool Usage (Within Copilot Chat)

  • List permissions:
    • Prompt: Call tool list_permissions (optionally pass user_principal_name or out_file).
  • List resources (all):
    • Prompt: Call tool list_resources.
  • List resources for RG:
    • Prompt: Call tool list_resources {"resource_group_name":"my-rg"}.
  • Discover required params for deployment:
    • Prompt: Call tool get_resource_parameters {"resource_type":"storage-account"}.
  • Deploy a resource (must supply required params):
    • Prompt: Call tool deploy_resource {"resource_type":"storage-account","parameters":{"ResourceGroupName":"my-rg","StorageAccountName":"mystorage123","Location":"eastus","AccessTier":"Hot"}}.

Local Test Harness (Without Copilot)

Run the included script:

python test_agent.py

Uncomment the deployment section and fill real parameter values before testing resource creation.

Adding New Deployment Scripts

  1. Place new deploy-*.ps1 in scripts/.
  2. Add a Bicep template in templates/.
  3. Extend DEPLOYMENT_SCRIPTS in server.py with logical key -> script filename.
  4. Use get_resource_parameters to see inferred required params.

Notes on Parameter Validation

deploy_resource infers required parameters by detecting if (-not $Param) prompts in the script. Ensure each truly required input has that pattern for stricter enforcement.

Common Issues

  • Azure CLI not found: Install CLI and restart shell.
  • Not logged in: Run az login.
  • Missing permissions: Confirm role assignments (e.g., Reader, Contributor) with list_permissions tool output.
  • Deployment failures: Check Bicep template, naming constraints, region availability.

Security Considerations

  • Do not hardcode secrets; use Key Vault deployment then store secrets securely.
  • Validate user-supplied parameters before passing to scripts if exposing externally.

Cleanup

To remove test resources, use Azure Portal or az group delete -n <RGName> --no-wait --yes.


Happy building! Use the Copilot Agent chat to invoke tools interactively.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

azure_sfi_agent_test-1.0.1.tar.gz (26.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

azure_sfi_agent_test-1.0.1-py3-none-any.whl (34.0 kB view details)

Uploaded Python 3

File details

Details for the file azure_sfi_agent_test-1.0.1.tar.gz.

File metadata

  • Download URL: azure_sfi_agent_test-1.0.1.tar.gz
  • Upload date:
  • Size: 26.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for azure_sfi_agent_test-1.0.1.tar.gz
Algorithm Hash digest
SHA256 bf2df9aaeb305c0fd7d78f2381ad2bc23d7417e7ec5812c04156c8e0d9f4b0d6
MD5 649bc7588f8f135584a1c1bf2129d3ef
BLAKE2b-256 51f3985bec46fd34d2c0a85d55e4b11b774a2f1e6e6ad025c8faef460a5fb34f

See more details on using hashes here.

File details

Details for the file azure_sfi_agent_test-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for azure_sfi_agent_test-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 219d569447b99144b2983ef6986f03c611deaaead333683cf5650758ece38ec0
MD5 3ba250dd6175addf6150ee13337e43d1
BLAKE2b-256 c2ead932010814712420fbb024d5200f13a863638e4615d7d0f55f550d0c28ea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page