-
Notifications
You must be signed in to change notification settings - Fork 13
/
get-PipelinesAsAdmin.pq
80 lines (80 loc) · 3.1 KB
/
get-PipelinesAsAdmin.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
let
output =
(generatedToken as text) =>
let
apiCall =
Json.Document(
Web.Contents(
"https://api.powerbi.com/v1.0/myorg",
[
RelativePath = "admin/pipelines",
Query = [
#"$expand" = "stages,users"
],
Headers = [
#"Content-Type" = "application/json",
Authorization = generatedToken
]
]
)
)
in
#table(
type table [
id = text,
displayName = text,
stages = table,
users = table
],
List.Transform(
apiCall[value],
each
{
_[id]?,
_[displayName]?,
Table.AddColumn(
Table.FromRecords(
_[stages]?,
type table [
order,
workspaceId,
workspaceName
],
MissingField.UseNull
),
"Type",
each
if [order] = "0" then
"Development"
else if [order] = "1" then
"Test"
else
"Production"
),
Table.FromRecords(
_[users]?,
type table [
accessRight,
identifier,
principalType
],
MissingField.UseNull
)
}
)
),
documentation = [
Documentation.Name = " get-PipelinesAsAdmin.pq ",
Documentation.Description = " Get pipelines as admin ",
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
)
)