File size: 4,606 Bytes
644ca8a
4d95901
57ebff8
b30c308
 
 
2faaefc
66fb743
bf5ebfe
66fb743
4d95901
b30c308
4d95901
81a8f8d
b30c308
66fb743
 
 
 
 
 
 
f9a4052
 
66fb743
 
 
 
 
 
 
d8c6bfd
66fb743
d8c6bfd
 
81a8f8d
66fb743
 
d8c6bfd
 
81a8f8d
66fb743
 
d8c6bfd
66fb743
 
d8c6bfd
66fb743
 
 
f9a4052
0126664
66fb743
d8c6bfd
66fb743
 
 
 
 
b30c308
66fb743
 
 
 
 
 
b30c308
81a8f8d
 
 
 
b30c308
81a8f8d
 
 
66fb743
b30c308
81a8f8d
 
 
57ebff8
81a8f8d
 
66fb743
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
import os
import streamlit as st
from azure.cosmos import CosmosClient, PartitionKey
from azure.storage.blob import BlobServiceClient
from azure.cosmos.exceptions import CosmosResourceNotFoundError
import requests
import glob
from datetime import datetime

# Initialize Azure Clients
COSMOS_CONNECTION_STRING = os.getenv('COSMOS_CONNECTION_STRING')
BLOB_STORAGE_CONNECTION_STRING = os.getenv('BLOB_STORAGE_CONNECTION_STRING')
cosmos_client = CosmosClient.from_connection_string(COSMOS_CONNECTION_STRING)
blob_service = BlobServiceClient.from_connection_string(BLOB_STORAGE_CONNECTION_STRING)

# Function to Delete All Items in a Container
def delete_all_items_in_container(db_name, container_name):
    database_client = cosmos_client.get_database_client(db_name)
    container_client = database_client.get_container_client(container_name)
    
    for item in container_client.read_all_items():
        try:
            partition_key = '/id'
            container_client.delete_item(item=item['id'], partition_key=partition_key)
            st.write(f"Deleted Item: {item['id']}")
        except CosmosResourceNotFoundError:
            st.error(f"Item not found: {item['id']}")


# Display and Manage Cosmos DB Structure
def display_and_manage_cosmos_db():
    st.subheader('Azure Cosmos DB Structure')
    for db_properties in cosmos_client.list_databases():
        db_name = db_properties['id']
        st.markdown(f"#### Database: {db_name}")
        database_client = cosmos_client.get_database_client(db_name)

        for container_properties in database_client.list_containers():
            container_name = container_properties['id']
            st.markdown(f"- **Container**: {container_name}")
            container_client = database_client.get_container_client(container_name)

            for item in container_client.read_all_items():
                item_desc = f"  - Item: `{item['id']}`"
                st.markdown(item_desc)
                if 'file_name' in item:
                    st.image(item['file_name'])
                
                # Update and Delete buttons for each item
                if st.button(f"🗑️ Delete {item['id']}", key=f"delete_{item['id']}"):
                    partition_key = '/id'
                    container_client.delete_item(item=item['id'], partition_key=partition_key)
                    st.success(f"Deleted Item: {item['id']}")

# Insert PNG Images with Unique Identifiers
def insert_png_images_with_unique_ids():
    db_name = st.selectbox("Select Database", [db['id'] for db in cosmos_client.list_databases()])
    container_name = st.selectbox("Select Container", [container['id'] for container in cosmos_client.get_database_client(db_name).list_containers()])
    container_client = cosmos_client.get_database_client(db_name).get_container_client(container_name)

    png_files = glob.glob('*.png')
    for file_name in png_files:
        unique_id = f"{os.path.splitext(file_name)[0]}_{datetime.now().strftime('%Y%m%d%H%M%S')}"
        item_data = {"id": unique_id, "file_name": file_name}
        container_client.create_item(body=item_data)
        st.write(f"Inserted Item: {unique_id}")

# Azure Blob Storage - Upload/Download
st.subheader('Azure Blob Storage - Upload/Download')
blob_container = st.text_input('Blob Container')
blob_file = st.file_uploader('Upload file to Blob')

if blob_file is not None and st.button('Upload to Blob'):
    blob_client = blob_service.get_blob_client(container=blob_container, blob=blob_file.name)
    blob_client.upload_blob(blob_file.getvalue())
    st.success('File uploaded successfully.')

# Azure Functions - Trigger
st.subheader('Azure Functions - Trigger')
function_url = st.text_input('Function URL')

if st.button('Call Azure Function'):
    response = requests.get(function_url)
    st.write('Function Response:', response.text)


# Display Cosmos DB Structure and Manage Items
display_and_manage_cosmos_db()

# Button to Insert PNG Images with Unique Identifiers
if st.button('Insert PNG Images with Unique IDs'):
    insert_png_images_with_unique_ids()

# Button to Delete All Items in a Container
db_name_to_delete = st.selectbox("Select Database to Delete From", [db['id'] for db in cosmos_client.list_databases()])
container_name_to_delete = st.selectbox("Select Container to Delete From", [container['id'] for container in cosmos_client.get_database_client(db_name_to_delete).list_containers()])

if st.button('Delete All Items in Container'):
    delete_all_items_in_container(db_name_to_delete, container_name_to_delete)
    st.success("All items deleted successfully.")