Azure blob storage supports two ways of authorization for blob access. Either you use the storage account key or a derivate SAS token – or you use AAD RBAC to access blob.
I did a quick test today to check if it would be possible to use a B2B guest to access blob storage. Want to find out more?
Inviting a guest to your storage container
I decided to use an existing storage account for this test. I did create a new container on this storage account, called ‘testb2b’.
data:image/s3,"s3://crabby-images/e8c37/e8c3710aaabc6b9a26b04c8d80bd619bbf40206f" alt=""
The default authorization is still storage account key (or SAS). I switched this to AAD.
data:image/s3,"s3://crabby-images/67c50/67c5034df3732d4d16f8448ddef1ad396c3e6b91" alt=""
And then I went ahead and invited my guest. This guest exists in my own AAD tenant, nillsf.com.
data:image/s3,"s3://crabby-images/72112/72112bf7bf45afe9a102ace047540f9b3e4c1fa2" alt=""
If this is the first time this guest is invited to your directory, he’ll get an invitation. Since Ben doesn’t have email (he is just a demo user for me), I used the invitation URL from the notification for him the accept his invite.
data:image/s3,"s3://crabby-images/53ee8/53ee86235d16a8cdb3aef6380cb45f2b03dabbc4" alt=""
data:image/s3,"s3://crabby-images/10aee/10aee3e27d36fd0020f2e71dfca49b34f3525561" alt=""
And then finally, I uploaded a file to that storage account (still using my own user in the azure portal) so I would have some data to show:
data:image/s3,"s3://crabby-images/2c2fd/2c2fd8edbbadcac1ff410d5d2c014e67c0046cbe" alt=""
Using Storage Explorer to access files using AAD RBAC
To demo the fact that we can connect, I decided to use the Storage Explorer. This is a free tool you can use to connect to Azure storage.
data:image/s3,"s3://crabby-images/1c0fa/1c0fa78a850424e854d2a094b235e0cc755d514d" alt=""
First, I added my ben@nillsf.com to the storage explorer accounts.
data:image/s3,"s3://crabby-images/a2c77/a2c779e9fcfd990d079f00f948e68c1adeec220a" alt=""
After that, I added the resource (the container) via AAD authorization.
data:image/s3,"s3://crabby-images/29606/29606e441a21a41816214aa7dbc216e6df381e46" alt=""
This will ask you for the account to use and the container location. Once you enter that, you can use storage explorer to see the files.
data:image/s3,"s3://crabby-images/0b862/0b86263dcc837730c8b00891fe39189b09c61859" alt=""
And as you can see, I can now see and download my file using storage explorer.
data:image/s3,"s3://crabby-images/77c59/77c592462dde41d0017cb5858c3e68db79f2c74e" alt=""
Conclusion
The goal of this post was to prove that I can invite Azure AD B2B guests to connect to storage accounts using Azure AD authorization. This worked perfectly.