cancel
Showing results for 
Search instead for 
Did you mean: 
Reply

Get drive id for Doc Library selection

Hey all, 

I am using the Excel action 'Create Worksheet' and I would like to make the 'Document Library' property dynamic rather than select it from the dropdown. However it does not accept the Document Library 'Display Name' or Id,  it only seems to accept the 'drive' property.

Does anybody know how to get the 'drive' of a document library? I tried sending an HTTP request to SharePoint but I must have something incorrect.

1 ACCEPTED SOLUTION

Accepted Solutions

UPDATE:
I was able to accomplish this with a work around. 
1) In my HTTP request to SharePoint I used the uri: _api/v2.0/drives

     It then listed all the drives and drive id's on that site

2) Then I used Parse JSON to get the values inside the output Body of the HTTP Request
3)  Then a Filter Array to find the document library I needed (I filtered by name)
4) Then finally I used a Compose with the Id from the Filter array. *Note - Many Ids may be listed from the output so if this helps anyone it is: @{items('Apply_to_each')?['id']} 

And of course I set this as a variable because that was a bit of a ridiculous process to get one id. 
So, a bit nuts, but it works if you are having the trouble with the _api/v2.0/drive/root:/<FileName> uri as I was.

I believe this is all much easier to achieve using the Microsoft Graph api if you are registered
But, I hope this helps anyone with the same issue. 


Thanks for your guidance and help @annajhaveri!

View solution in original post

16 REPLIES 16
annajhaveri
Most Valuable Professional
Most Valuable Professional

@TorreyFalconer  are you also providing the dynamic file name, in the excel actions of Power Automate, we cant simply provide the library and filename as their actual names, we need to fetch the drive id and file id and use it in the Create Worksheet action, please see below steps on how to do it:

 

1. Add 'Send an HTTP request to SharePoint' action to the flow and configure it was follows:

annajhaveri_0-1615557284416.png

Uri should be _api/v2.0/drive/root:/<filename>

here replace <filename> with a variable or the actual file name e.g. book1.xlsx

 

2. Then add Compose action and configure following expression in this compose action

outputs('Send_an_HTTP_request_to_SharePoint')?['body']['Id']

annajhaveri_1-1615557388048.png

 

3. Now again add Compose action and configure following expression in this compose action

outputs('Send_an_HTTP_request_to_SharePoint')?['body']['parentReference']['driveId']

annajhaveri_2-1615557487411.png

 

4. Then in Create Worksheet action configure it as follows, use compose action output in the Document library and file name parameters, as shown in screenshot below

annajhaveri_3-1615557637797.png

 

 

Regards,
Anna Jhaveri

If I have answered your question, please mark the post as Solved to help other users to identify the correct answer
If you like my response, please give it a Thumbs Up.

Thanks! 

I think this will work but I am still getting a 400 error at the moment with my HTTP request Uri. 
It just says that it got an unexpected response from the request. 


I have my Uri input: 

_api/v2.0/drive/root:/book1.xlsx

 I tried it various ways using a variable, the actual file name etc. (I even tried using the doc library name instead) but still get the same error.
Any thoughts?

@TorreyFalconer  could you please let me know following:

 

1. Excel file name in which you want to create the worksheet? 

2. Document library in which file exists

3. Is file added directly under document library or under a folder, if under folder can you share the folder path

 

With these answers i can help you to figure out what will the Uri in your case

Regards,
Anna Jhaveri

If I have answered your question, please mark the post as Solved to help other users to identify the correct answer
If you like my response, please give it a Thumbs Up.

Hey!

 

File Name: 2021-03_PersonCount.xlsx

Document Library: Meeting Attendance 
Not under a folder, directly in the document library!

 

Hope that helps!

UPDATE:
I was able to accomplish this with a work around. 
1) In my HTTP request to SharePoint I used the uri: _api/v2.0/drives

     It then listed all the drives and drive id's on that site

2) Then I used Parse JSON to get the values inside the output Body of the HTTP Request
3)  Then a Filter Array to find the document library I needed (I filtered by name)
4) Then finally I used a Compose with the Id from the Filter array. *Note - Many Ids may be listed from the output so if this helps anyone it is: @{items('Apply_to_each')?['id']} 

And of course I set this as a variable because that was a bit of a ridiculous process to get one id. 
So, a bit nuts, but it works if you are having the trouble with the _api/v2.0/drive/root:/<FileName> uri as I was.

I believe this is all much easier to achieve using the Microsoft Graph api if you are registered
But, I hope this helps anyone with the same issue. 


Thanks for your guidance and help @annajhaveri!

@TorreyFalconer  the reason why below Uri input did not work for is because your document library name is Meeting Attendance , the below Uri works for default Documents library of the site. If not using default documents library then the solution that you provided is correct, which worked for your scenario

_api/v2.0/drive/root:/book1.xlsx

 

Regards,
Anna Jhaveri

If I have answered your question, please mark the post as Solved to help other users to identify the correct answer
If you like my response, please give it a Thumbs Up.

I configured it exactly like that and it did not work. Glad I found a work around though! 

@TorreyFalconer I just meant to explain why it didnt work for your scenario. I hope that makes sense.

Regards,
Anna Jhaveri

If I have answered your question, please mark the post as Solved to help other users to identify the correct answer
If you like my response, please give it a Thumbs Up.

@annajhaveri it did! Thank you very much for the help!

Anonymous
Not applicable

Hi @annajhaveri  / @TorreyFalconer 

I tried both ways:

klee7777_0-1628859270616.png

But both HTTP Get actions failed with "Unexpected response from the service
clientRequestId: 6afea342-387b-4c35-ba2b-28bc1b1837d0
serviceRequestId: d11be59f-a0f6-c000-47d7-b2029fb9b849"

 

So, I couldn't even proceed to the next step. How were you able to pass that action?

What is the syntax if the file is located in a folder and not directly under the document library.  The document library is TestLib and the folder is Output.

I wanted to get the driveitemid from my "When a file is created" SharePoint trigger, and this thread helped me greatly.

 

Maybe my approach will help other travellers to this topic?

 

When using a Data Source Environment Variable, you will have the 'list' ID of your target library. Using the List ID and the "ID" from the Trigger (which is actually the List Item ID), you can use the Graph API to get all the list properties.

 

Graph API documentation tells us that List Items have a relationship with "driveItem", so we can simply expand that property to get both the "driveItem/id" and the "driveItem/parentReference/driveId", which are the two values @annajhaveri pointed out you need for your Excel activity (in my case, I only need the driveItem/id)!

 

Now, I would have thought using SharePoint HTTP request activity would work here, but I am getting an error trying to do anything with _api/v2.0/lists, I am always getting:

{"error":{"code":"itemNotFound","message":"Item not found"}}

But if v2.0 could be used, your SharePoint HTTP request would look like this:

_api/v2.0/lists/{List ID From Data Source Environment Variable}/items/{SharePoint File ID}?expand=driveitem(select=id,parentReference)&select=id,weburl,driveitem

 

To work around this, I am using "Office 365 Groups - Send an HTTP Request" to avoid any authentication overhead using the Graph API (you could also use Azure AD HTTP Request). The GET request URL looks like this:

https://graph.microsoft.com/v1.0/sites/{Site Address}:/lists/{List ID From Data Source Environment Variable}/items/{SharePoint File ID}?expand=driveitem(select=id,parentReference)&select=id,weburl,driveitem

metsshan_0-1653635594401.png

 

You need the {Site Address} to be in the format "contoso.sharepoint.com:/sites/TestSite", which we can get by transforming the Data Source Environment Variable:

@{replace(replace({Site Address Data Source Environment Variable},'https://',''), '.com/', '.com:/')}

 

And, it works!

metsshan_1-1653635999757.png

 

Thank you for the elaborate write-up, @metsshan . However, I suspect that Microsoft made changes to the O365 Groups connector to no longer allow calling that endpoint.

The URI works fine directly in the Graph Explorer (https://developer.microsoft.com/en-us/graph/graph-explorer), but it fails if I call it in a Power Automate flow using the O365 Groups connector as described in your post. The error message it returns is:

URI path is not a valid Graph endpoint, path is neither absolute nor relative or resource/object is not supported for this connector. 

Can anyone else confirm if this approach still works today?

Hi @OliverR-82 , still working as described in my post, no issues from any of my flows which use this daily.

Hey @OliverR-82 , I know this was a few months ago but after a quick test on my end, and a bit of sleuthing I can see that the 'Send and HTTP request' activity has been deprecated and replaced by a V2 activity which only grants access to the /groups endpoint.

 

I don't believe there is a non-premium solution for this request now, and people will need to use 'HTTP Request' or 'HTTP with Microsoft Entra ID'. 

 

EDIT: Or in my case, I replaced with using Custom Connector as I did not like how users were always prompted for a service endpoint when Allowing/creating 'HTTP with Microsoft Entra ID' connections.

Update:
After trying a few things, _api/v2.0/drive no longer works. 
_api/v2.1/drives
is the new endpoint

Helpful resources

Announcements

Community will be READ ONLY July 16th, 5p PDT -July 22nd

Dear Community Members,   We'd like to let you know of an upcoming change to the community platform: starting July 16th, the platform will transition to a READ ONLY mode until July 22nd.   During this period, members will not be able to Kudo, Comment, or Reply to any posts.   On July 22nd, please be on the lookout for a message sent to the email address registered on your community profile. This email is crucial as it will contain your unique code and link to register for the new platform encompassing all of the communities.   What to Expect in the New Community: A more unified experience where all products, including Power Apps, Power Automate, Copilot Studio, and Power Pages, will be accessible from one community.Community Blogs that you can syndicate and link to for automatic updates. We appreciate your understanding and cooperation during this transition. Stay tuned for the exciting new features and a seamless community experience ahead!

Summer of Solutions | Week 4 Results | Winners will be posted on July 24th

We are excited to announce the Summer of Solutions Challenge!    This challenge is kicking off on Monday, June 17th and will run for (4) weeks.  The challenge is open to all Power Platform (Power Apps, Power Automate, Copilot Studio & Power Pages) community members. We invite you to participate in a quest to provide solutions to as many questions as you can. Answers can be provided in all the communities.    Entry Period: This Challenge will consist of four weekly Entry Periods as follows (each an “Entry Period”)   - 12:00 a.m. PT on June 17, 2024 – 11:59 p.m. PT on June 23, 2024 - 12:00 a.m. PT on June 24, 2024 – 11:59 p.m. PT on June 30, 2024 - 12:00 a.m. PT on July 1, 2024 – 11:59 p.m. PT on July 7, 2024 - 12:00 a.m. PT on July 8, 2024 – 11:59 p.m. PT on July 14, 2024   Entries will be eligible for the Entry Period in which they are received and will not carryover to subsequent weekly entry periods.  You must enter into each weekly Entry Period separately.   How to Enter: We invite you to participate in a quest to provide "Accepted Solutions" to as many questions as you can. Answers can be provided in all the communities. Users must provide a solution which can be an “Accepted Solution” in the Forums in all of the communities and there are no limits to the number of “Accepted Solutions” that a member can provide for entries in this challenge, but each entry must be substantially unique and different.    Winner Selection and Prizes: At the end of each week, we will list the top ten (10) Community users which will consist of: 5 Community Members & 5 Super Users and they will advance to the final drawing. We will post each week in the News & Announcements the top 10 Solution providers.  At the end of the challenge, we will add all of the top 10 weekly names and enter them into a random drawing.  Then we will randomly select ten (10) winners (5 Community Members & 5 Super Users) from among all eligible entrants received across all weekly Entry Periods to receive the prize listed below. If a winner declines, we will draw again at random for the next winner.  A user will only be able to win once overall. If they are drawn multiple times, another user will be drawn at random.  Individuals will be contacted before the announcement with the opportunity to claim or deny the prize.  Once all of the winners have been notified, we will post in the News & Announcements of each community with the list of winners.   Each winner will receive one (1) Pass to the Power Platform Conference in Las Vegas, Sep. 18-20, 2024 ($1800 value). NOTE: Prize is for conference attendance only and any other costs such as airfare, lodging, transportation, and food are the sole responsibility of the winner. Tickets are not transferable to any other party or to next year’s event.   ** PLEASE SEE THE ATTACHED RULES for this CHALLENGE**   Week 1 Results: Congratulations to the Week 1 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge.   Community MembersNumber SolutionsSuper UsersNumber Solutions Deenuji 9 @NathanAlvares24  17 @Anil_g  7 @ManishSolanki  13 @eetuRobo  5 @David_MA  10 @VishnuReddy1997  5 @SpongYe  9JhonatanOB19932 (tie) @Nived_Nambiar  8 @maltie  2 (tie)   @PA-Noob  2 (tie)   @LukeMcG  2 (tie)   @tgut03  2 (tie)       Week 2 Results: Congratulations to the Week 2 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge. Week 2: Community MembersSolutionsSuper UsersSolutionsPower Automate  @Deenuji  12@ManishSolanki 19 @Anil_g  10 @NathanAlvares24  17 @VishnuReddy1997  6 @Expiscornovus  10 @Tjan  5 @Nived_Nambiar  10 @eetuRobo  3 @SudeepGhatakNZ 8     Week 3 Results: Congratulations to the Week 3 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge. Week 3:Community MembersSolutionsSuper UsersSolutionsPower Automate Deenuji32ManishSolanki55VishnuReddy199724NathanAlvares2444Anil_g22SudeepGhatakNZ40eetuRobo18Nived_Nambiar28Tjan8David_MA22   Week 4 Results: Congratulations to the Week 4 qualifiers, you are being entered in the random drawing that will take place at the end of the challenge. Week 4:Community MembersSolutionsSuper UsersSolutionsPower Automate Deenuji11FLMike31Sayan11ManishSolanki16VishnuReddy199710creativeopinion14Akshansh-Sharma3SudeepGhatakNZ7claudiovc2CFernandes5 misc2Nived_Nambiar5 Usernametwice232rzaneti5 eetuRobo2   Anil_g2   SharonS2  

Check Out | 2024 Release Wave 2 Plans for Microsoft Dynamics 365 and Microsoft Power Platform

On July 16, 2024, we published the 2024 release wave 2 plans for Microsoft Dynamics 365 and Microsoft Power Platform. These plans are a compilation of the new capabilities planned to be released between October 2024 to March 2025. This release introduces a wealth of new features designed to enhance customer understanding and improve overall user experience, showcasing our dedication to driving digital transformation for our customers and partners.    The upcoming wave is centered around utilizing advanced AI and Microsoft Copilot technologies to enhance user productivity and streamline operations across diverse business applications. These enhancements include intelligent automation, AI-powered insights, and immersive user experiences that are designed to break down barriers between data, insights, and individuals. Watch a summary of the release highlights.    Discover the latest features that empower organizations to operate more efficiently and adaptively. From AI-driven sales insights and customer service enhancements to predictive analytics in supply chain management and autonomous financial processes, the new capabilities enable businesses to proactively address challenges and capitalize on opportunities.    

Updates to Transitions in the Power Platform Communities

We're embarking on a journey to enhance your experience by transitioning to a new community platform. Our team has been diligently working to create a fresh community site, leveraging the very Dynamics 365 and Power Platform tools our community advocates for.  We started this journey with transitioning Copilot Studio forums and blogs in June. The move marks the beginning of a new chapter, and we're eager for you to be a part of it. The rest of the Power Platform product sites will be moving over this summer.   Stay tuned for more updates as we get closer to the launch. We can't wait to welcome you to our new community space, designed with you in mind. Let's connect, learn, and grow together.   Here's to new beginnings and endless possibilities!   If you have any questions, observations or concerns throughout this process please go to https://aka.ms/PPCommSupport.   To stay up to date on the latest details of this migration and other important Community updates subscribe to our News and Announcements forums: Copilot Studio, Power Apps, Power Automate, Power Pages