-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpower_bi.rb
80 lines (62 loc) · 2.72 KB
/
power_bi.rb
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
# frozen_string_literal: true
# Module for PowerBI reports
module PowerBi
require 'uri'
require 'net/http'
require 'json'
def get_access_token
url = URI('https://login.windows.net/common/oauth2/token')
request = Net::HTTP::Post.new(url)
request['cache-control'] = 'no-cache'
request.body = "grant_type=password&
scope=openid&
username=" + ENV['USERNAME_POWERBI'] + "&
password=" + ENV['PASSWORD_POWERBI'] + "&
client_id=" + ENV['CLIENT_ID_POWERBI'] + "&
resource=https%3A%2F%2Fanalysis.windows.net%2Fpowerbi%2Fapi&
undefined="
response = Net::HTTP.start(url.host, url.port,
use_ssl: url.scheme == 'https') { |http| http.request request }
eval(response.body)[:access_token]
end
def get_reports_by_group_id(group_id, token)
url = URI('https://api.powerbi.com/v1.0/myorg/groups/' + group_id + '/reports')
request = Net::HTTP::Get.new(url)
request['Authorization'] = 'Bearer ' + token
request['cache-control'] = 'no-cache'
response = Net::HTTP.start(url.host, url.port,
use_ssl: url.scheme == 'https') { |http| http.request request }
reports = eval(response.body)[:value]
reports_data = []
reports.each do |report|
next unless report[:name] != 'Report Usage Metrics Report'
report_info = { name: report[:name],
group_id: group_id,
report_id: report[:id],
embed_url: report[:embedUrl] }
reports_data.append(report_info)
end
reports_data.sort_by { |element| element[:name] }
end
def get_token_access_reports(group_id, report_id, token)
url = URI('https://api.powerbi.com/v1.0/myorg/groups/' + group_id + '/reports/' + report_id + '/GenerateToken')
request = Net::HTTP::Post.new(url)
request['Content-Type'] = 'application/x-www-form-urlencoded'
request['Authorization'] = 'Bearer ' + token
request['cache-control'] = 'no-cache'
request.body = 'accessLevel=view&undefined='
response = Net::HTTP.start(url.host, url.port,
use_ssl: url.scheme == 'https') { |http| http.request request }
eval(response.body)[:token]
end
def get_report_by_id(report_id, token)
url = URI('ttps://api.powerbi.com/v1.0/myorg/reports/' + report_id)
request = Net::HTTP::Get.new(url)
request['Authorization'] = 'Bearer ' + token
request['cache-control'] = 'no-cache'
response = Net::HTTP.start(url.host, url.port,
use_ssl: url.scheme == 'https') { |http| http.request request }
report = eval(response.body)[:value]
report
end
end