sugarcrb 0.1.4 → 0.1.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/sugarcrb/version.rb +1 -1
- data/lib/sugarcrb.rb +56 -58
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 28c88bf9e8829171b432d71cc1bf0ff43ccd59ab
|
4
|
+
data.tar.gz: f20fef0403de24481eafb2b10450d777ce16a530
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bd5eef173e0f044bda6213d437efab9c6fca3e926f959ea4b51a45dba14f89854b0e4388af2602977e9b8f6560ad07f4e6e8b9a4dd6ffff26f6b9a33b364a192
|
7
|
+
data.tar.gz: 11be8450b19cf68628691b7b36016afc5db86aba1528f20646c5e7e877f62b1c5a43c83ef03f0359ff3f40cece5fd94e87270f31725c9e09a31298092b28adc6
|
data/lib/sugarcrb/version.rb
CHANGED
data/lib/sugarcrb.rb
CHANGED
@@ -2,33 +2,49 @@ require "sugarcrb/version"
|
|
2
2
|
require 'rest-client'
|
3
3
|
|
4
4
|
module Sugarcrb
|
5
|
-
class << self
|
6
5
|
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
6
|
+
def initialize(host, username, password, platform, client_id, client_secret)
|
7
|
+
# Instance variables
|
8
|
+
@host = host
|
9
|
+
@username = username
|
10
|
+
@password = password
|
11
|
+
@platform = platform
|
12
|
+
@client_secret = client_secret
|
13
|
+
@client_id = client_id
|
14
|
+
@access_token = ""
|
15
|
+
@refresh_token = ""
|
16
|
+
end
|
17
|
+
|
18
|
+
attr_accessor :username
|
19
|
+
attr_accessor :access_token
|
20
|
+
attr_accessor :refresh_token
|
18
21
|
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
+
def oauth2_token (refresh = false)
|
23
|
+
data = {
|
24
|
+
"grant_type": "password",
|
25
|
+
"client_id": @client_id,
|
26
|
+
"client_secret": @client_secret,
|
27
|
+
"username": @username,
|
28
|
+
"password": @password,
|
29
|
+
"platform": @platform
|
30
|
+
}
|
31
|
+
response = RestClient.post "#{@host}/rest/v10/oauth2/token", data
|
32
|
+
response_json = JSON.load(response)
|
33
|
+
if (response.code == 200) then
|
34
|
+
@access_token = response_json['access_token']
|
35
|
+
@refresh_token = response_json['refresh_token']
|
36
|
+
end
|
37
|
+
return response
|
38
|
+
end
|
22
39
|
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
}
|
40
|
+
def oauth2_refresh_token
|
41
|
+
data = {
|
42
|
+
"grant_type": "refresh_token",
|
43
|
+
"refresh_token": @refresh_token,
|
44
|
+
"client_id": @client_id,
|
45
|
+
"client_secret": @client_secret,
|
46
|
+
}
|
47
|
+
begin
|
32
48
|
response = RestClient.post "#{@host}/rest/v10/oauth2/token", data
|
33
49
|
response_json = JSON.load(response)
|
34
50
|
if (response.code == 200) then
|
@@ -36,44 +52,26 @@ module Sugarcrb
|
|
36
52
|
@refresh_token = response_json['refresh_token']
|
37
53
|
end
|
38
54
|
return response
|
55
|
+
rescue RestClient::Unauthorized => err
|
56
|
+
return self.oauth2_token
|
39
57
|
end
|
58
|
+
end
|
40
59
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
begin
|
49
|
-
response = RestClient.post "#{@host}/rest/v10/oauth2/token", data
|
50
|
-
response_json = JSON.load(response)
|
51
|
-
if (response.code == 200) then
|
52
|
-
@access_token = response_json['access_token']
|
53
|
-
@refresh_token = response_json['refresh_token']
|
54
|
-
end
|
55
|
-
return response
|
56
|
-
rescue RestClient::Unauthorized => err
|
57
|
-
return self.oauth2_token
|
60
|
+
def call (method, endpoint, data = false, reintents = 0)
|
61
|
+
begin
|
62
|
+
response = case method
|
63
|
+
when "post" then RestClient.post "#{@host}/rest/v10/#{endpoint}", data, headers={"OAuth-Token" => @access_token}
|
64
|
+
when "get" then RestClient.get "#{@host}/rest/v10/#{endpoint}", headers={"OAuth-Token" => @access_token}
|
65
|
+
when "put" then RestClient.put "#{@host}/rest/v10/#{endpoint}", data, headers={"OAuth-Token" => @access_token}
|
66
|
+
when "delete" then RestClient.delete "#{@host}/rest/v10/#{endpoint}", headers={"OAuth-Token" => @access_token}
|
58
67
|
end
|
59
|
-
end
|
60
68
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
when "delete" then RestClient.delete "#{@host}/rest/v10/#{endpoint}", headers={"OAuth-Token" => @access_token}
|
68
|
-
end
|
69
|
-
|
70
|
-
return response
|
71
|
-
rescue RestClient::Unauthorized => err
|
72
|
-
if reintents < 3 then
|
73
|
-
self.oauth2_refresh_token
|
74
|
-
reintents = reintents + 1
|
75
|
-
self.call(method, endpoint, data, reintents)
|
76
|
-
end
|
69
|
+
return response
|
70
|
+
rescue RestClient::Unauthorized => err
|
71
|
+
if reintents < 3 then
|
72
|
+
self.oauth2_refresh_token
|
73
|
+
reintents = reintents + 1
|
74
|
+
self.call(method, endpoint, data, reintents)
|
77
75
|
end
|
78
76
|
end
|
79
77
|
end
|