Class: PowerBI::Tenant
- Inherits:
-
Object
- Object
- PowerBI::Tenant
- Defined in:
- lib/power-bi/tenant.rb
Instance Attribute Summary collapse
-
#capacities ⇒ Object
readonly
Returns the value of attribute capacities.
-
#gateways ⇒ Object
readonly
Returns the value of attribute gateways.
-
#workspaces ⇒ Object
readonly
Returns the value of attribute workspaces.
Instance Method Summary collapse
- #capacity(id) ⇒ Object
- #delete(url, params = {}) ⇒ Object
- #gateway(id) ⇒ Object
- #get(url, params = {}) ⇒ Object
- #get_raw(url, params = {}) ⇒ Object
-
#initialize(token_generator, retries: 5, logger: nil) ⇒ Tenant
constructor
A new instance of Tenant.
- #log(message, level: :info) ⇒ Object
- #patch(url, params = {}) ⇒ Object
- #post(url, params = {}) ⇒ Object
- #post_file(url, file, params = {}) ⇒ Object
- #workspace(id) ⇒ Object
Constructor Details
#initialize(token_generator, retries: 5, logger: nil) ⇒ Tenant
Returns a new instance of Tenant.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/power-bi/tenant.rb', line 5 def initialize(token_generator, retries: 5, logger: nil) @token_generator = token_generator @workspaces = WorkspaceArray.new(self) @gateways = GatewayArray.new(self) @capacities = CapacityArray.new(self) @logger = logger ## WHY RETRIES? ## # It is noticed that once in a while (~0.1% API calls), the Power BI server returns a 500 (internal server error) without apparent reason, just retrying works :-) ################## @retry_options = { max: retries, exceptions: [Errno::ETIMEDOUT, Timeout::Error, Faraday::TimeoutError, Faraday::RetriableResponse, Faraday::ConnectionFailed], methods: [:get, :post, :patch, :delete], retry_statuses: [500], # internal server error interval: 0.2, interval_randomness: 0, backoff_factor: 4, retry_block: -> (env, , retries, exc) { self.log "retrying...!! exception: #{exc.to_s} ---- #{exc.}, request URL: #{env.url}" }, } end |
Instance Attribute Details
#capacities ⇒ Object (readonly)
Returns the value of attribute capacities.
3 4 5 |
# File 'lib/power-bi/tenant.rb', line 3 def capacities @capacities end |
#gateways ⇒ Object (readonly)
Returns the value of attribute gateways.
3 4 5 |
# File 'lib/power-bi/tenant.rb', line 3 def gateways @gateways end |
#workspaces ⇒ Object (readonly)
Returns the value of attribute workspaces.
3 4 5 |
# File 'lib/power-bi/tenant.rb', line 3 def workspaces @workspaces end |
Instance Method Details
#capacity(id) ⇒ Object
41 42 43 |
# File 'lib/power-bi/tenant.rb', line 41 def capacity(id) Capacity.new(self, nil, id) end |
#delete(url, params = {}) ⇒ Object
127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 |
# File 'lib/power-bi/tenant.rb', line 127 def delete(url, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :retry, @retry_options end response = conn.delete(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['Accept'] = 'application/json' req.headers['authorization'] = "Bearer #{token}" yield req if block_given? end log "Calling (DELETE) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" if [400, 401, 404].include? response.status raise NotFoundError end unless [200, 202].include? response.status raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end unless response.body.empty? JSON.parse(response.body, symbolize_names: true) end end |
#gateway(id) ⇒ Object
37 38 39 |
# File 'lib/power-bi/tenant.rb', line 37 def gateway(id) Gateway.new(self, nil, id) end |
#get(url, params = {}) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
# File 'lib/power-bi/tenant.rb', line 45 def get(url, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :retry, @retry_options end response = conn.get(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['Accept'] = 'application/json' req.headers['authorization'] = "Bearer #{token}" yield req if block_given? end if response.status == 400 raise NotFoundError end unless [200, 202].include? response.status raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end log "Calling (GET) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" unless response.body.empty? JSON.parse(response.body, symbolize_names: true) end end |
#get_raw(url, params = {}) ⇒ Object
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 |
# File 'lib/power-bi/tenant.rb', line 68 def get_raw(url, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :retry, @retry_options end response = conn.get(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['authorization'] = "Bearer #{token}" yield req if block_given? end log "Calling (GET - raw) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" unless [200, 202].include? response.status raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end response.body end |
#log(message, level: :info) ⇒ Object
27 28 29 30 31 |
# File 'lib/power-bi/tenant.rb', line 27 def log(, level: :info) if @logger @logger.send(level, ) # hence, the logger needs to implement the 'level' methods end end |
#patch(url, params = {}) ⇒ Object
106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 |
# File 'lib/power-bi/tenant.rb', line 106 def patch(url, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :retry, @retry_options end response = conn.patch(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['Accept'] = 'application/json' req.headers['Content-Type'] = 'application/json' req.headers['authorization'] = "Bearer #{token}" yield req if block_given? end log "Calling (PATCH) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" unless [200, 202].include? response.status raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end unless response.body.empty? JSON.parse(response.body, symbolize_names: true) end end |
#post(url, params = {}) ⇒ Object
85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/power-bi/tenant.rb', line 85 def post(url, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :retry, @retry_options end response = conn.post(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['Accept'] = 'application/json' req.headers['Content-Type'] = 'application/json' req.headers['authorization'] = "Bearer #{token}" yield req if block_given? end log "Calling (POST) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" unless [200, 201, 202].include? response.status raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end unless response.body.empty? JSON.parse(response.body, symbolize_names: true) end end |
#post_file(url, file, params = {}) ⇒ Object
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 |
# File 'lib/power-bi/tenant.rb', line 150 def post_file(url, file, params = {}) t0 = Time.now conn = Faraday.new do |f| f.request :multipart f.request :retry, @retry_options end response = conn.post(PowerBI::BASE_URL + url) do |req| req.params = params req.headers['Accept'] = 'application/json' req.headers['Content-Type'] = 'multipart/form-data' req.headers['authorization'] = "Bearer #{token}" req.body = {value: Faraday::UploadIO.new(file, 'application/octet-stream')} req..timeout = 120 # default is 60 seconds Net::ReadTimeout end log "Calling (POST - file) #{response.env.url.to_s} - took #{((Time.now - t0) * 1000).to_i} ms" if response.status != 202 raise APIError.new("Error calling Power BI API (status #{response.status}): #{response.body}") end JSON.parse(response.body, symbolize_names: true) end |