Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
purple_banana
Frequent Visitor

Adding Timeout to a Web.Contents Dataflow query

I have the following query which works, however the API is very slow, and if I try to increase the date range it times out:

 

Json.Document(Web.Contents("https://<source>/api/v2/",[RelativePath="analytics-stream?startDate="
    & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd")
    &"&code=01"]))
 
I think I should be able to add a timeout argument: e.g. "[Timeout=#duration(0, 0, 30, 0)]" - From research I thought it would go before the end parentheses, however no matter where I put it, the query subsequently fails;
 
Json.Document(Web.Contents("https://<source>/api/v2/",[RelativePath="analytics-stream?startDate=" & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd")
    &"&code=01"],[Timeout=#duration(0, 0, 30, 0)]))
Error: 3 arguments were passed to a function which expects between 1 and 2
 
Json.Document(Web.Contents("https://<source>/api/v2/",[RelativePath="analytics-stream?startDate="
    & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd")
    &"&code=01"]),[Timeout=#duration(0, 0, 30, 0)])
Error: We cannot convert a value of type Record to type Number

Json.Document(Web.Contents("https://<source>/api/v2/",[Timeout=#duration(0, 0, 30, 0)],[RelativePath="analytics-stream?startDate=" & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd")
    &"&code=01"]))
Error: 3 arguments were passed to a function which expects between 1 and 2
 
Please can anyone help with how I should incorperate this argument to this query?
 
Many thanks
1 ACCEPTED SOLUTION
lbendlin
Super User
Super User

Json.Document(Web.Contents("https:///api/v2/",[RelativePath="analytics-stream?startDate=" & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd") &"&code=01",Timeout=#duration(0, 0, 30, 0)]))

View solution in original post

2 REPLIES 2
lbendlin
Super User
Super User

Json.Document(Web.Contents("https:///api/v2/",[RelativePath="analytics-stream?startDate=" & Date.ToText(RangeStart, "yyyy-MM-dd") & "&endDate=" & Date.ToText(RangeEnd, "yyyy-MM-dd") &"&code=01",Timeout=#duration(0, 0, 30, 0)]))

**bleep** I was close 😂

 

Thank you!

Helpful resources

Announcements
PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

Top Solution Authors
Top Kudoed Authors