-
Notifications
You must be signed in to change notification settings - Fork 13
/
get-LastDatasetRefreshErrorByLast10Refreshes.pq
89 lines (89 loc) · 3.5 KB
/
get-LastDatasetRefreshErrorByLast10Refreshes.pq
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
let
output =
(generatedToken as text, datasetId as text) =>
let
apiCall =
Json.Document(
Web.Contents(
"https://api.powerbi.com/v1.0/myorg",
[
RelativePath = "admin/datasets/" & datasetId & "/refreshes",
Query = [
#"$top" = "10"
],
Headers = [
#"Content-Type" = "application/json",
Authorization = generatedToken
]
]
)
),
filter =
let
skip =
List.Buffer(
List.Skip(
apiCall[value],
each _[status]? <> "Failed"
)
),
out =
if skip = {} then
[]
else
let
getMaxDate =
List.Accumulate(
skip,
[endTime = #datetime(2000, 1, 1, 0, 0, 0)],
(state, current) =>
if
DateTime.From(state[endTime])
> DateTime.From(current[endTime])
then
state
else
current
)
in
getMaxDate
in
out
in
#table(
type table [
requestId = text,
id = text,
refreshType = text,
startTime = datetime,
endTime = datetime,
status = text
],
List.Transform(
{filter},
each
{
_[requestId]?,
_[id]?,
_[refreshType]?,
_[startTime]?,
_[endTime]?,
_[status]?
}
)
),
documentation = [
Documentation.Name = " get-LastDatasetRefreshErrorByLast10Refreshes.pq ",
Documentation.Description = " Get the newest Error on refresh dataset by last 10 refreshes ",
Documentation.Source = "https://www.jaknapowerbi.cz",
Documentation.Version = " 1.0 ",
Documentation.Author = " Štěpán Rešl "
]
in
Value.ReplaceType(
output,
Value.ReplaceMetadata(
Value.Type(output),
documentation
)
)