Azure deployment wrapper
Project description
AzWrap
A Python package that provides a streamlined wrapper for Azure resource management, making it easier to work with Azure services including:
- Azure Storage
- Azure AI Search
- Azure OpenAI
Installation
pip install azwrap
Configuration
AzWrap requires Azure credentials to be set either as environment variables or in a .env file:
AZURE_TENANT_ID=your-tenant-id
AZURE_CLIENT_ID=your-client-id
AZURE_CLIENT_SECRET=your-client-secret
AZURE_SUBSCRIPTION_ID=your-subscription-id
CLI Usage
Once installed, you can use the CLI to manage Azure resources. The CLI is structured around resource types and operations.
General Options
# Get help on CLI usage
azwrap --help
# Change output format (text, json, table)
azwrap --output json <command>
# Enable verbose output
azwrap --verbose <command>
Subscription Management
# List all available subscriptions
azwrap subscription list
# Get details of a specific subscription
azwrap subscription get --subscription-id your-subscription-id
Resource Group Management
# List resource groups in a subscription
azwrap resource-group list
# Create a new resource group
azwrap resource-group create --name my-resource-group --location eastus
# Get details of a specific resource group
azwrap resource-group get --name my-resource-group
Storage Management
# List storage accounts
azwrap storage list
# Create a storage account
azwrap storage create --name mystorageacct --resource-group my-resource-group --location eastus
# List containers in a storage account
azwrap storage containers --name mystorageacct --resource-group my-resource-group
# List blobs in a container
azwrap storage blobs --account mystorageacct --resource-group my-resource-group --container mycontainer
# View folder structure in a container
azwrap storage folder-structure --account mystorageacct --resource-group my-resource-group --container mycontainer
Azure AI Search
# List search services
azwrap search list
# Create a search service
azwrap search create --name mysearchservice --resource-group my-resource-group --location eastus --sku basic
# List indexes in a search service
azwrap index list --search-service mysearchservice --resource-group my-resource-group
# Create an index (with JSON fields definition)
azwrap index create --name myindex --search-service mysearchservice --resource-group my-resource-group --fields '[{"name":"id","type":"SimpleField","key":true,"type_name":"Edm.String"},{"name":"content","type":"SearchableField","type_name":"Edm.String"}]'
# Copy an index
azwrap index copy --source sourceindex --target targetindex --search-service mysearchservice --resource-group my-resource-group
Data Sources and Indexers
# List data sources
azwrap datasource list --search-service mysearchservice --resource-group my-resource-group
# Create a data source connection
azwrap datasource create --name mydatasource --type azureblob --connection-string "DefaultEndpointsProtocol=https;AccountName=myaccount;AccountKey=key;EndpointSuffix=core.windows.net" --container mycontainer --search-service mysearchservice --resource-group my-resource-group
# Create an indexer
azwrap indexer create --name myindexer --data-source mydatasource --target-index myindex --search-service mysearchservice --resource-group my-resource-group
# Run an indexer
azwrap indexer run --name myindexer --search-service mysearchservice --resource-group my-resource-group
# Check indexer status
azwrap indexer status --name myindexer --search-service mysearchservice --resource-group my-resource-group
Skillsets
# List skillsets
azwrap skillset list --search-service mysearchservice --resource-group my-resource-group
# Create a skillset
azwrap skillset create --name myskillset --search-service mysearchservice --resource-group my-resource-group --skills '[{"@odata.type": "#Microsoft.Skills.Text.EntityRecognitionSkill", "name": "entity-recognition", "description": "Extracts entities", "context": "/document", "categories": ["Person", "Location", "Organization"], "defaultLanguageCode": "en", "inputs": [{"name": "text", "source": "/document/content"}], "outputs": [{"name": "persons", "targetName": "people"}, {"name": "locations", "targetName": "places"}, {"name": "organizations", "targetName": "organizations"}]}]'
Azure OpenAI Service
# List OpenAI services
azwrap ai list
# Get details of an OpenAI service
azwrap ai get --name myopenai --resource-group my-resource-group
# List available models
azwrap ai models --name myopenai --resource-group my-resource-group
# List deployments
azwrap ai deployments --name myopenai --resource-group my-resource-group
# Create a deployment
azwrap ai deploy --name gpt35turbo --model gpt-35-turbo --service myopenai --resource-group my-resource-group --capacity 1
# Generate embeddings
azwrap ai embedding --text "This is a sample text" --service myopenai --resource-group my-resource-group --model text-embedding-3-small --api-version 2023-12-01-preview
# Generate chat completion
azwrap ai chat --message "Tell me about Azure" --service myopenai --resource-group my-resource-group --model gpt35turbo --api-version 2023-12-01-preview --system "You are a helpful assistant"
Python API Usage
Identity Management
from azwrap import Identity
# Create an identity with your Azure credentials
identity = Identity(tenant_id, client_id, client_secret)
# Get a list of subscriptions
subscriptions = identity.get_subscriptions()
# Get a specific subscription
subscription = identity.get_subscription(subscription_id)
Resource Management
from azwrap import Subscription, ResourceGroup
# Work with resource groups
resource_group = subscription.get_resource_group(group_name)
# Create a new resource group
new_group = subscription.create_resource_group(group_name, location)
Storage Management
from azwrap import StorageAccount, Container
# Get a storage account
storage_account = resource_group.get_storage_account(account_name)
# Create a new storage account
new_account = resource_group.create_storage_account(account_name, location)
# Work with blob containers
container = storage_account.get_container(container_name)
blobs = container.get_blobs()
Azure AI Search
from azwrap import SearchService, SearchIndex, get_std_vector_search
from azure.search.documents.indexes.models import (
SearchField, SearchFieldDataType, SimpleField, SearchableField
)
# Get a search service
search_service = subscription.get_search_service(service_name)
# Create a new search service
new_service = resource_group.create_search_service(name, location)
# Define fields for an index
fields = [
SimpleField(name="id", type=SearchFieldDataType.String, key=True),
SearchableField(name="content", type=SearchFieldDataType.String, analyzer_name="en.microsoft")
]
# Create a search index
index = search_service.create_or_update_index("my-index", fields)
# Add vector search capability
vector_search = get_std_vector_search()
Azure OpenAI
from azwrap import AIService, OpenAIClient
# Get an OpenAI service
ai_service = resource_group.get_ai_service(service_name)
# Get OpenAI client with Azure credentials
openai_client = ai_service.get_OpenAIClient(api_version="2023-05-15")
# Generate embeddings
embeddings = openai_client.generate_embeddings("Your text here", model="deployment-name")
# Generate chat completions
response = openai_client.generate_chat_completion(
messages=[
{"role": "system", "content": "You are a helpful assistant."},
{"role": "user", "content": "Tell me about Azure."}
],
model="deployment-name",
temperature=0.7,
max_tokens=800
)
Development
To set up the development environment:
# Clone the repository
git clone https://github.com/yourusername/azwrap.git
cd azwrap
# Create a virtual environment
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
# Install dependencies for development
uv sync
# Build the package
python -m build
# Install in development mode
pip install -e .
License
This project is licensed under the MIT License - see the LICENSE file for details.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file azwrap-0.1.2.tar.gz.
File metadata
- Download URL: azwrap-0.1.2.tar.gz
- Upload date:
- Size: 32.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a3e3623905165d2d6012271586b9550e5e9f3336a16600e0a70dbf101928b7bd
|
|
| MD5 |
46f5df1531fb45d5147c85e8e4625cba
|
|
| BLAKE2b-256 |
5e3eb9f613fb25340f4cd130cb28129f434da1988f0d8563a2b5acf3ab76a33f
|
File details
Details for the file azwrap-0.1.2-py3-none-any.whl.
File metadata
- Download URL: azwrap-0.1.2-py3-none-any.whl
- Upload date:
- Size: 28.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8698f72e6974557a113ed038004fd113ddda29b4af9ea02cbdc4178406b549b6
|
|
| MD5 |
26c00deafe597cf0fbbbdc8a40d2428c
|
|
| BLAKE2b-256 |
34175ec30adebff32d521e18fb735783595c553176389e27fe7d14e8d2bfb08f
|