tl;dr
Access Azure blob metadata in two steps: obtain a SAS URI, then make an HTTP request — HEAD to read or PUT to write. Accessing index tags isn’t straightforward; secure a SAS URI that permits tag manipulation elsewhere, then return to complete the task.
Scrumptious if not tedious details
Azure blobs are fast and cost efficient. Just ask any Power Platform admin trying to shoehorn storing 250,000 email attachments in Dataverse — mostly self-proclaiming signatures — into the annual budget, and have a box of tissues ready.
To help manage storage classification and search, blobs have very useful additional features like metadata and index tags. See Manage properties and metadata for a blob with .NET and Manage and find Azure Blob data with blob index tags. Short version: metadata are for additional blob properties (e.g. image EXIF data), while tags are effective classification and search mechanism across containers and blobs.
data:image/s3,"s3://crabby-images/69353/693539ae004b3e22dc676c5af4f2c65b218d5ed8" alt="This image shows a user interface from Azure Blob Storage, with a focus on the properties and metadata of a specific blob named "dates-restricted.jpg". The properties section is truncated and not fully visible. In the metadata section, two key-value pairs are visible: "width" with a value of "480" and "height" with a value of "640". Below the metadata, in the blob index tags section, there is another key-value pair visible: "project" with the value "world domination". A red border highlights the metadata and index tags sections."
Metadata
Power Automate can easily manipulate blobs using Azure Blob Storage Connector. One cannot be faulted for thinking a method called “Get Blob Metadata (V2)” would return, uhm, metadata. It does return something that looks like a warped version of blob properties but does not contain the actual metadata.
Luckily, metadata is just an HTTP request away: Get Blob Metadata (REST API) – Azure Storage. All we need is SAS key which we can get using the connector: Create SAS URI by path (V2). Request write privilege when creating SAS key and the metadata can be updated as well.
data:image/s3,"s3://crabby-images/fa7ba/fa7ba35d1691b90e3b98e743f4618088b49526c6" alt="This image depicts a partial screenshot of a Microsoft Power Automate flow, specifically focusing on two steps involved in manipulating metadata for an Azure Blob Storage item. The first step creates SAS URI that is used to build url for read and update requests. Second step is labeled "Get Meta" and shows a configuration with a "HEAD" method, indicating it is set to retrieve metadata. A highlighted URI parameter includes a query component comp=metadata, which is used to specify the operation on the blob's metadata. The sethirdcond step, "Overwrite Meta", has a "PUT" method, signifying an update to the metadata. Here, the same base URI with the comp=metadata parameter is present, and two metadata headers are visible: x-ms-meta-depth with a value of "140", and x-ms-meta-weight with a value of "27.3kg"."
HEAD request returns metadata with the prefix x-ms-meta-
as part of the headers block.
{
"statusCode": 200,
"headers": {
"ETag": "\"0x8DC3CABED4F27DF\"",
"Server": "Windows-Azure-Blob/1.0,Microsoft-HTTPAPI/2.0",
"x-ms-request-id": "dfd94108-b01e-0011-620c-832521000000",
"x-ms-version": "2018-03-28",
"x-ms-meta-width": "670",
"x-ms-meta-height": "370",
"Date": "Sun, 31 Mar 2024 01:38:42 GMT",
"Content-Length": "0",
"Last-Modified": "Tue, 05 Mar 2024 00:33:49 GMT"
}
}
Tags
Tags are a little bit more complicated because permissions for tags are governed separately and connector does accommodate them. You can get appropriate permissions baked into the SAS URI using Azure portal, just make sure to add Tags permissions.
data:image/s3,"s3://crabby-images/b120f/b120fdd0df15140a2ca9b43a1940164d5dcc0510" alt="This image is a screenshot from the Azure Storage user interface, showing the process for generating a Shared Access Signature (SAS) for a blob named "dates-restricted.jpg". The "Generate SAS" tab is selected, indicating the current action. A list of permissions is shown with checkboxes; "Read" and "Tags" permissions are checked, suggesting these are the permissions that will be granted by the SAS. The "Read" permission allows reading the blob's content, while the "Tags" permission relates to accessing or modifying the blob's tags. There are other permissions like Add, Create, Write, Delete, and Permanent delete which remain unchecked. At the bottom, there is an indication that 2 permissions are selected, and there's a field for specifying the start and expiry date/time for the SAS, although the details are not visible in the screenshot."
Generated SAS URI can then be used in Power Automate to access index tags. The only difference from the metadata manipulation besides SAS URI and comp
query parameter is that we append new tag instead of overwriting (involves a bit of xml manipulation; yes, tags use xml structure).
data:image/s3,"s3://crabby-images/fbed8/fbed8468e9cc03d8ff410998d82a663cf56fde60" alt="This image is a screenshot from a Microsoft Power Automate flow, detailing two HTTP request actions designed to interact with Azure Blob Storage index tags. The first action, titled "Get Tags", is configured to perform a GET request, as indicated by the "GET" method. The URI for this request includes a query parameter comp=tags, denoting that the action aims to retrieve the tags associated with a blob. The second action, "Set Tags", is set to use the PUT method, suggesting that it will update or create tags for a blob. It uses a similar URI structure, also including the comp=tags query parameter."
The result:
data:image/s3,"s3://crabby-images/cb21c/cb21c9345f38a2ad85bf369a19546fb1cf77dc47" alt="The image displays a screenshot of an Azure Blob Storage interface after modifications have been made to the metadata and index tags by a Power Automate flow. In the metadata section, there are two key-value pairs with the keys "depth" and "weight" and the corresponding values "140" and "27.3kg"; this section is marked with the word "Replaced", indicating these metadata entries have been updated or replaced. In the blob index tags section, there are two key-value pairs: "project" with the value "world domination" and a newly appended tag "status" with the value "doomed"; this section is labeled "Appended", suggesting that the "status" tag has been added as a result of the flow execution. The overall context implies a successful update and addition of blob properties through the automated process."
Would you rather poke the steps yourself? Download the unmanaged solution which includes a sample flow and connection reference.
Hello, your publication is perfect!!! I was stuck in this type of operation. What type of permission does the web URI have? I tried to update the x-ms-blob-content-disposition and I received :
AuthorizationFailure
This request is not authorized to perform this operation.Thanks for your help
Interesting… Make sure you use
?comp=properties
in the URL. Then, according to https://learn.microsoft.com/rest/api/storageservices/set-blob-properties, you’ll need Write permission on Set Blob Properties operation on object level.But it gets more interesting. You can bake
content-disposition
update into the SAS URL, according to the documentation.Hello George, Thanks for your information. Of course it worked, but by adding ?comp=properties& between the file location and the token of the SAS URL. It works perfectly.