innowhite_api 1.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README.rdoc +185 -0
- data/Rakefile +14 -0
- data/innowhite.gemspec +32 -0
- data/lib/innowhite.rb +183 -0
- metadata +124 -0
data/README.rdoc
ADDED
@@ -0,0 +1,185 @@
|
|
1
|
+
Getting Started
|
2
|
+
|
3
|
+
Step 1:
|
4
|
+
Install innowhite gem with RubyGems
|
5
|
+
|
6
|
+
gem install innowhite
|
7
|
+
or add this to your Gemfile if you use Bundler:
|
8
|
+
gem "innowhite"
|
9
|
+
|
10
|
+
Step 2:
|
11
|
+
Place the innowhite.yml file in the config directory.
|
12
|
+
This file will be sent to you by email.
|
13
|
+
|
14
|
+
|
15
|
+
In the code :
|
16
|
+
we need to initialize the Innowhite class
|
17
|
+
innowhite = Innowhite.new
|
18
|
+
|
19
|
+
|
20
|
+
Available Command Requests
|
21
|
+
Then we could access the available methods from the instance :
|
22
|
+
|
23
|
+
Create new session :
|
24
|
+
Create new room and get its room url to access it.
|
25
|
+
|
26
|
+
Arguments (as a Hash) :
|
27
|
+
a. :user => the name of the moderator (ex. "John")
|
28
|
+
b. :tags => (optional). Example : (math 101, calculus, integration)
|
29
|
+
c. :desc => (optional) Description of the room. (ex: Definite Integrals by John)
|
30
|
+
|
31
|
+
Request Command :
|
32
|
+
innowhite.create_room({}). Ex : innowhite.create_room({:user => "bainur", :tags => "testing, room testing", :desc => "This is only testing for the room"})
|
33
|
+
|
34
|
+
Return value :
|
35
|
+
a. Room Id
|
36
|
+
b. URL (this URL will be passed to user so that he needs to be redirected to open in new page.)
|
37
|
+
|
38
|
+
|
39
|
+
|
40
|
+
|
41
|
+
Join an existing session
|
42
|
+
Joining the existing room and get its room url to access it.
|
43
|
+
|
44
|
+
Arguments :
|
45
|
+
a. room_id => (mandatory) The room id which want to join.
|
46
|
+
b. username => (mandatory) Username of the user who want to join the room.
|
47
|
+
|
48
|
+
Request Command :
|
49
|
+
innowhite.join_meeting(room_id, username). Ex : innowhite.join_meeting(12345, "bainur")
|
50
|
+
|
51
|
+
Return value :
|
52
|
+
a. URL (this URL will be passed to the user, the user needs to be redirected to open in new page.)
|
53
|
+
|
54
|
+
|
55
|
+
|
56
|
+
|
57
|
+
|
58
|
+
Get the live sessions
|
59
|
+
Get the list of existing sessions.
|
60
|
+
|
61
|
+
Arguments (as a Hash) :
|
62
|
+
a. :tags (optional)
|
63
|
+
b. :user (optional)
|
64
|
+
|
65
|
+
Request Command :
|
66
|
+
innowhite.get_sessions({})
|
67
|
+
|
68
|
+
Return value :
|
69
|
+
a. RoomId
|
70
|
+
b. Room Description
|
71
|
+
c. All tags associated with this room.
|
72
|
+
d. Room Created by.
|
73
|
+
e. Room start time.
|
74
|
+
|
75
|
+
|
76
|
+
|
77
|
+
|
78
|
+
|
79
|
+
Schedule a session :
|
80
|
+
Scheduling new session.
|
81
|
+
|
82
|
+
Arguments (as a Hash) :
|
83
|
+
a. :tags (optional)
|
84
|
+
b. :startTime (format should be in seconds)
|
85
|
+
c. :timeZone (GMT time zone ) (ex : +1, +2)
|
86
|
+
d. :endTime (format should be in seconds)
|
87
|
+
e. :user
|
88
|
+
f. :description
|
89
|
+
|
90
|
+
Request Command :
|
91
|
+
innowhite.schedule_meeting({})
|
92
|
+
|
93
|
+
Return Value :
|
94
|
+
a. True or False
|
95
|
+
|
96
|
+
|
97
|
+
|
98
|
+
|
99
|
+
|
100
|
+
|
101
|
+
|
102
|
+
Get the past sessions
|
103
|
+
Get the list of past sessions.
|
104
|
+
|
105
|
+
Arguments (as a Hash) :
|
106
|
+
a. :tags (optional)
|
107
|
+
b. :user (optional)
|
108
|
+
|
109
|
+
Request Command :
|
110
|
+
innowhite.past_sessions({})
|
111
|
+
|
112
|
+
|
113
|
+
Return Value :
|
114
|
+
a. tags (optional)
|
115
|
+
b. orgName (optional)
|
116
|
+
c. Moderator Name
|
117
|
+
d. Room Description
|
118
|
+
e. Link to play the video.
|
119
|
+
|
120
|
+
|
121
|
+
|
122
|
+
|
123
|
+
Get the scheduled sessions
|
124
|
+
Get the list of scheduled sessions.
|
125
|
+
|
126
|
+
Arguments (as a Hash) :
|
127
|
+
a. :tags (optional)
|
128
|
+
b. :user (optional)
|
129
|
+
|
130
|
+
Request Command :
|
131
|
+
innowhite.get_scheduled_list({})
|
132
|
+
|
133
|
+
Return Value:
|
134
|
+
a. Tags (optional)
|
135
|
+
b. orgName (optional)
|
136
|
+
c. Start time (format should be in seconds)
|
137
|
+
d. Time zone (GMT time zone ) (ex : +1, +2)
|
138
|
+
e. End time (format should be in seconds)
|
139
|
+
f. Room Description
|
140
|
+
g. Moderator name
|
141
|
+
|
142
|
+
|
143
|
+
Cancel scheduled session
|
144
|
+
Cancel the scheduled session.
|
145
|
+
|
146
|
+
Arguments :
|
147
|
+
a. room_id (mandatory)
|
148
|
+
|
149
|
+
Request Command :
|
150
|
+
innowhite.cancel_meeting(room_id)
|
151
|
+
|
152
|
+
Return Value:
|
153
|
+
a. True or False
|
154
|
+
|
155
|
+
|
156
|
+
|
157
|
+
Update a scheduled session :
|
158
|
+
Updating the exist scheduled session.
|
159
|
+
|
160
|
+
Arguments (as a Hash) :
|
161
|
+
a. :room_id (mandatory)
|
162
|
+
b. :startTime (format should be in milliseconds) (optional)
|
163
|
+
c. :timeZone (optional)
|
164
|
+
d. :endTime (format should be in milliseconds) (optional)
|
165
|
+
e. :description (optional)
|
166
|
+
f. :tags (optional)
|
167
|
+
|
168
|
+
Request Command :
|
169
|
+
innowhite.update_schedule({})
|
170
|
+
|
171
|
+
Return Value :
|
172
|
+
a. True or False
|
173
|
+
|
174
|
+
|
175
|
+
|
176
|
+
Get Meeting Play back Recording URL :
|
177
|
+
Returns the video playback URL.
|
178
|
+
|
179
|
+
a. :room_id (mandatory)
|
180
|
+
|
181
|
+
Request Command :
|
182
|
+
innowhite.getRecordingURL({})
|
183
|
+
|
184
|
+
Return Value :
|
185
|
+
a. URL
|
data/Rakefile
ADDED
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
require 'rake'
|
3
|
+
require 'echoe'
|
4
|
+
|
5
|
+
Echoe.new('innowhite', '0.1.0') do |p|
|
6
|
+
p.description = "Innowhite Api"
|
7
|
+
p.url = "http://github.com/bainur/innowhite"
|
8
|
+
p.author = "bainur"
|
9
|
+
p.email = "inoe.bainur@gmail.com"
|
10
|
+
p.ignore_pattern = ["tmp/*", "script/*"]
|
11
|
+
p.development_dependencies = []
|
12
|
+
end
|
13
|
+
|
14
|
+
Dir["#{File.dirname(__FILE__)}/tasks/*.rake"].sort.each { |ext| load ext }
|
data/innowhite.gemspec
ADDED
@@ -0,0 +1,32 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
|
3
|
+
Gem::Specification.new do |s|
|
4
|
+
s.name = %q{innowhite_api}
|
5
|
+
s.version = "1.1.3"
|
6
|
+
|
7
|
+
s.required_rubygems_version = Gem::Requirement.new(">= 1.2") if s.respond_to? :required_rubygems_version=
|
8
|
+
s.authors = [%q{innowhite}]
|
9
|
+
s.date = %q{2011-08-11}
|
10
|
+
s.description = %q{Innowhite Api}
|
11
|
+
s.email = %q{dhiraj.peechara@innowhite.com}
|
12
|
+
s.extra_rdoc_files = [%q{README.rdoc}, %q{lib/innowhite.rb}]
|
13
|
+
s.files = [%q{README.rdoc}, %q{Rakefile}, %q{lib/innowhite.rb}, %q{innowhite.gemspec}]
|
14
|
+
s.homepage = %q{http://github.com/firemonk9/innowhite}
|
15
|
+
s.rdoc_options = [%q{--line-numbers}, %q{--inline-source}, %q{--title}, %q{Innowhite}, %q{--main}, %q{README.rdoc}]
|
16
|
+
s.require_paths = [%q{lib}]
|
17
|
+
s.rubyforge_project = %q{innowhite_api}
|
18
|
+
s.rubygems_version = %q{1.8.6}
|
19
|
+
s.summary = %q{Gem for Innowhite Api}
|
20
|
+
s.add_dependency 'nokogiri', '~> 1.4.4'
|
21
|
+
s.add_dependency 'rest-client', '~> 1.6.7'
|
22
|
+
s.add_development_dependency "rspec", "~> 1.3.4"
|
23
|
+
|
24
|
+
if s.respond_to? :specification_version then
|
25
|
+
s.specification_version = 3
|
26
|
+
|
27
|
+
if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
|
28
|
+
else
|
29
|
+
end
|
30
|
+
else
|
31
|
+
end
|
32
|
+
end
|
data/lib/innowhite.rb
ADDED
@@ -0,0 +1,183 @@
|
|
1
|
+
require 'open-uri'
|
2
|
+
require 'nokogiri'
|
3
|
+
require 'rest-client'
|
4
|
+
|
5
|
+
class Innowhite
|
6
|
+
|
7
|
+
attr_accessor :mod_name, :org_name, :sub, :server_address, :private_key
|
8
|
+
|
9
|
+
def initialize
|
10
|
+
load_settings
|
11
|
+
end
|
12
|
+
|
13
|
+
def create_room(params = {})
|
14
|
+
room_id = get_room_id
|
15
|
+
address = join_room_url(@org_name, room_id, params[:user], true)
|
16
|
+
res = create_room_info(room_id, params[:user], params[:tags], params[:desc], @org_name, address)
|
17
|
+
res.include?("Missing") ? {"errors" => "Failed to fetch, maybe you have entered wrong username / organization name .."} : {"room_id" => room_id, "address" => address}
|
18
|
+
end
|
19
|
+
|
20
|
+
def join_meeting(room_id, user)
|
21
|
+
url = "#{@api_address}exist_session?roomId=#{room_id}"
|
22
|
+
doc = Nokogiri::XML(open(url))
|
23
|
+
doc.text.blank? ? nil : join_room_url(@org_name, room_id, user, false)
|
24
|
+
end
|
25
|
+
|
26
|
+
def get_sessions(params = {})
|
27
|
+
temp = url_generator(params[:parentOrg] || @parent_org, params[:orgName] || @org_name)
|
28
|
+
checksum = generating_checksum(URI.escape(temp))
|
29
|
+
tmp = "#{temp}&user=#{params[:user]}&tags=#{params[:tags]}"
|
30
|
+
url = URI.escape("#{@api_address}list_sessions?#{tmp}&checksum=#{checksum}")
|
31
|
+
JSON::parse(RestClient.get(url, :accept => :json))
|
32
|
+
|
33
|
+
rescue
|
34
|
+
{"errors" => "Error fetching sessions check the organization and private key .."}
|
35
|
+
end
|
36
|
+
|
37
|
+
def schedule_meeting(params = {})
|
38
|
+
room_id = get_room_id
|
39
|
+
address = join_room_url(
|
40
|
+
params[:orgName] || @org_name,
|
41
|
+
room_id,
|
42
|
+
params[:user],
|
43
|
+
true)
|
44
|
+
|
45
|
+
create_schedule(
|
46
|
+
room_id,
|
47
|
+
params[:user],
|
48
|
+
params[:tags],
|
49
|
+
params[:description],
|
50
|
+
params[:parentOrg] || @parent_org,
|
51
|
+
address,
|
52
|
+
params[:startTime],
|
53
|
+
params[:endTime],
|
54
|
+
params[:timeZone]) == "true"
|
55
|
+
end
|
56
|
+
|
57
|
+
def past_sessions(params = {})
|
58
|
+
temp = url_generator(params[:parentOrg] || @parent_org, params[:orgName] || @org_name)
|
59
|
+
checksum = generating_checksum(URI.escape(temp))
|
60
|
+
|
61
|
+
tmp = "#{temp}&user=#{params[:user]}&tags=#{params[:tags]}"
|
62
|
+
url = URI.escape("#{@api_address}past_sessions?#{tmp}&checksum=#{checksum}")
|
63
|
+
JSON::parse(RestClient.get(url, :accept => :json))
|
64
|
+
|
65
|
+
rescue
|
66
|
+
{ "errors" => "Error fetching sessions check the organization and private key .." }
|
67
|
+
end
|
68
|
+
|
69
|
+
def get_scheduled_list(params={})
|
70
|
+
checksum = main_cheksum(params[:parentOrg] || @parent_org, params[:orgName] || @org_name)
|
71
|
+
par = url_generator(params[:parentOrg] || @parent_org, params[:orgName] || @org_name)
|
72
|
+
url = URI.escape("#{@api_address}get_scheduled_sessions?#{par}&checksum=#{checksum}&tags=#{params[:tags]}}")
|
73
|
+
JSON::parse(RestClient.get(url, :accept => :json))
|
74
|
+
end
|
75
|
+
|
76
|
+
def cancel_meeting(room_id)
|
77
|
+
checksum = main_cheksum(@parent_org, @org_name)
|
78
|
+
par = url_generator(@parent_org, @org_name)
|
79
|
+
url = URI.escape("#{@api_address}cancel_meeting?roomId=#{room_id}&#{par}&checksum=#{checksum}")
|
80
|
+
Nokogiri::XML(open(url)).xpath("//success").text == "true"
|
81
|
+
end
|
82
|
+
|
83
|
+
def update_schedule(params = {})
|
84
|
+
checksum = main_cheksum(@parent_org, @org_name)
|
85
|
+
params[:startTime] = params[:startTime].to_i if !params[:startTime].blank? && (params[:startTime].is_a?(DateTime) || params[:startTime].is_a?(Time))
|
86
|
+
params[:endTime] = params[:endTime].to_i if !params[:endTime].blank? && (params[:endTime].is_a?(DateTime) || params[:endTime].is_a?(Time))
|
87
|
+
|
88
|
+
Nokogiri::XML(RestClient.put("#{@api_address}update_schedule",
|
89
|
+
{:roomId => params[:room_id], :tags => params[:tags], :description => params[:description],
|
90
|
+
:parentOrg => @parent_org, :orgName => @org_name,
|
91
|
+
:checksum => checksum, :startTime => params[:startTime],
|
92
|
+
:endTime => params[:endTime], :timeZone => params[:timeZone]
|
93
|
+
}
|
94
|
+
)).xpath("//success").text == "true"
|
95
|
+
end
|
96
|
+
|
97
|
+
def getRecordingURL(room_id)
|
98
|
+
Nokogiri.parse(RestClient.get("#{@server_address}PlayBackServlet?room_id=#{room_id}")).css("webMpath").text.gsub(/.webm$/, "")
|
99
|
+
end
|
100
|
+
|
101
|
+
protected
|
102
|
+
def load_settings
|
103
|
+
settings = YAML.load_file('config/innowhite.yml')# if RAILS_ENV == "development"
|
104
|
+
@server_address = settings["innowhite"]["server_address"]
|
105
|
+
@api_address = settings["innowhite"]["api_address"]
|
106
|
+
@private_key = settings["innowhite"]["private_key"]
|
107
|
+
@parent_org = settings["innowhite"]["organization"]
|
108
|
+
@org_name = @parent_org
|
109
|
+
end
|
110
|
+
|
111
|
+
def create_schedule(room_id, user, tags, desc, parent_org, address, start_time, end_time, time_zone)
|
112
|
+
checksum = generating_checksum(URI.escape(url_generator(parent_org, parent_org)))
|
113
|
+
address = join_room_url(@org_name, room_id, user, true)
|
114
|
+
RestClient.post("#{@api_address}create_schedule_meeting",
|
115
|
+
{:roomId => room_id, :user => user, :tags => tags, :desc => desc, :startTime => start_time,
|
116
|
+
:endTime => end_time, :timeZone => time_zone,
|
117
|
+
:parentOrg => parent_org, :address => address, :orgName => parent_org,
|
118
|
+
:checksum => checksum
|
119
|
+
}
|
120
|
+
)
|
121
|
+
end
|
122
|
+
|
123
|
+
def create_room_info(room_id, user, tags, desc, parent_org, address)
|
124
|
+
checksum = generating_checksum(URI.escape(url_generator(parent_org, parent_org)))
|
125
|
+
|
126
|
+
RestClient.post("#{@api_address}create_room_info",
|
127
|
+
{:roomId => room_id, :user => user, :tags => tags, :desc => desc,
|
128
|
+
:parentOrg => parent_org, :address => address, :orgName => parent_org,
|
129
|
+
:checksum => checksum
|
130
|
+
}
|
131
|
+
)
|
132
|
+
end
|
133
|
+
|
134
|
+
def get_room_id
|
135
|
+
url = create_room_url
|
136
|
+
doc = Nokogiri::XML(open(url))
|
137
|
+
status = doc.xpath('//returnStatus').text.gsub("\n", "") rescue ""
|
138
|
+
|
139
|
+
if status.include?('SUCCESS')
|
140
|
+
doc.xpath('//roomId').text.gsub("\n", "").to_i
|
141
|
+
elsif status.include?('AUTH_FAILED')
|
142
|
+
"AUTH_FAILED"
|
143
|
+
elsif status.include?('EXPIRED')
|
144
|
+
'EXPIRED'
|
145
|
+
elsif status.include?('OUT_OF_SERVICE')
|
146
|
+
'OUT_OF_SERVICE'
|
147
|
+
else
|
148
|
+
"Error With the Server #{url}"
|
149
|
+
end
|
150
|
+
end
|
151
|
+
|
152
|
+
private
|
153
|
+
def main_cheksum(parent_org, org_name)
|
154
|
+
checksum_tmp = url_generator(parent_org, org_name)
|
155
|
+
generating_checksum(URI.escape(checksum_tmp))
|
156
|
+
end
|
157
|
+
|
158
|
+
def generating_checksum(params)
|
159
|
+
Digest::SHA1.hexdigest(params + @private_key)
|
160
|
+
end
|
161
|
+
|
162
|
+
def generate_checksum(parent_org, org_name, user_name)
|
163
|
+
Digest::SHA1.hexdigest(information_url(parent_org, org_name, user_name))
|
164
|
+
end
|
165
|
+
|
166
|
+
def url_generator(parent_org, org_name)
|
167
|
+
"parentOrg=#{parent_org}&orgName=#{org_name}"
|
168
|
+
end
|
169
|
+
|
170
|
+
def join_room_url(org_name, room_id, user, is_teacher)
|
171
|
+
action = "#{@server_address}JoinRoom?"
|
172
|
+
address = "parentOrg=#{@parent_org}&orgName=#{org_name}&roomId=#{room_id}&user=#{user}&roomLeader=#{is_teacher}"
|
173
|
+
"#{action}#{address}&checksum=#{generating_checksum(address)}"
|
174
|
+
end
|
175
|
+
|
176
|
+
def information_url(parent_org, org_name, user_name)
|
177
|
+
"parentOrg=#{parent_org}&orgName=#{org_name}&user=#{user_name}#{@private_key}"
|
178
|
+
end
|
179
|
+
|
180
|
+
def create_room_url
|
181
|
+
"#{@server_address}CreateRoom?parentOrg=#{@parent_org}&orgName=#{@org_name}&user=#{@mod_name}&checksum=#{generate_checksum(@parent_org, @org_name, @mod_name)}"
|
182
|
+
end
|
183
|
+
end
|
metadata
ADDED
@@ -0,0 +1,124 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: innowhite_api
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
hash: 21
|
5
|
+
prerelease:
|
6
|
+
segments:
|
7
|
+
- 1
|
8
|
+
- 1
|
9
|
+
- 3
|
10
|
+
version: 1.1.3
|
11
|
+
platform: ruby
|
12
|
+
authors:
|
13
|
+
- innowhite
|
14
|
+
autorequire:
|
15
|
+
bindir: bin
|
16
|
+
cert_chain: []
|
17
|
+
|
18
|
+
date: 2011-08-11 00:00:00 -05:00
|
19
|
+
default_executable:
|
20
|
+
dependencies:
|
21
|
+
- !ruby/object:Gem::Dependency
|
22
|
+
name: nokogiri
|
23
|
+
prerelease: false
|
24
|
+
requirement: &id001 !ruby/object:Gem::Requirement
|
25
|
+
none: false
|
26
|
+
requirements:
|
27
|
+
- - ~>
|
28
|
+
- !ruby/object:Gem::Version
|
29
|
+
hash: 15
|
30
|
+
segments:
|
31
|
+
- 1
|
32
|
+
- 4
|
33
|
+
- 4
|
34
|
+
version: 1.4.4
|
35
|
+
type: :runtime
|
36
|
+
version_requirements: *id001
|
37
|
+
- !ruby/object:Gem::Dependency
|
38
|
+
name: rest-client
|
39
|
+
prerelease: false
|
40
|
+
requirement: &id002 !ruby/object:Gem::Requirement
|
41
|
+
none: false
|
42
|
+
requirements:
|
43
|
+
- - ~>
|
44
|
+
- !ruby/object:Gem::Version
|
45
|
+
hash: 1
|
46
|
+
segments:
|
47
|
+
- 1
|
48
|
+
- 6
|
49
|
+
- 7
|
50
|
+
version: 1.6.7
|
51
|
+
type: :runtime
|
52
|
+
version_requirements: *id002
|
53
|
+
- !ruby/object:Gem::Dependency
|
54
|
+
name: rspec
|
55
|
+
prerelease: false
|
56
|
+
requirement: &id003 !ruby/object:Gem::Requirement
|
57
|
+
none: false
|
58
|
+
requirements:
|
59
|
+
- - ~>
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
hash: 19
|
62
|
+
segments:
|
63
|
+
- 1
|
64
|
+
- 3
|
65
|
+
- 4
|
66
|
+
version: 1.3.4
|
67
|
+
type: :development
|
68
|
+
version_requirements: *id003
|
69
|
+
description: Innowhite Api
|
70
|
+
email: dhiraj.peechara@innowhite.com
|
71
|
+
executables: []
|
72
|
+
|
73
|
+
extensions: []
|
74
|
+
|
75
|
+
extra_rdoc_files:
|
76
|
+
- README.rdoc
|
77
|
+
- lib/innowhite.rb
|
78
|
+
files:
|
79
|
+
- README.rdoc
|
80
|
+
- Rakefile
|
81
|
+
- lib/innowhite.rb
|
82
|
+
- innowhite.gemspec
|
83
|
+
has_rdoc: true
|
84
|
+
homepage: http://github.com/firemonk9/innowhite
|
85
|
+
licenses: []
|
86
|
+
|
87
|
+
post_install_message:
|
88
|
+
rdoc_options:
|
89
|
+
- --line-numbers
|
90
|
+
- --inline-source
|
91
|
+
- --title
|
92
|
+
- Innowhite
|
93
|
+
- --main
|
94
|
+
- README.rdoc
|
95
|
+
require_paths:
|
96
|
+
- lib
|
97
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
98
|
+
none: false
|
99
|
+
requirements:
|
100
|
+
- - ">="
|
101
|
+
- !ruby/object:Gem::Version
|
102
|
+
hash: 3
|
103
|
+
segments:
|
104
|
+
- 0
|
105
|
+
version: "0"
|
106
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
107
|
+
none: false
|
108
|
+
requirements:
|
109
|
+
- - ">="
|
110
|
+
- !ruby/object:Gem::Version
|
111
|
+
hash: 11
|
112
|
+
segments:
|
113
|
+
- 1
|
114
|
+
- 2
|
115
|
+
version: "1.2"
|
116
|
+
requirements: []
|
117
|
+
|
118
|
+
rubyforge_project: innowhite_api
|
119
|
+
rubygems_version: 1.6.2
|
120
|
+
signing_key:
|
121
|
+
specification_version: 3
|
122
|
+
summary: Gem for Innowhite Api
|
123
|
+
test_files: []
|
124
|
+
|