canvas-api 1.0 → 1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/lib/canvas-api.rb +66 -30
- metadata +18 -29
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: 95c34739c1dbdc8b69b65bfa291bd1fa318825b4
|
4
|
+
data.tar.gz: ddcdac8157ef3ad82ef6a94d96d5bf668c07937c
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: be00b864dfa100429fe449662aacf43a492b3bf35ad5f64015d11406ba37e1e557c4ad3a9718786aaf95a0a5ee13ae51b6a1c4c72c4eb81903934f34057dbf7a
|
7
|
+
data.tar.gz: 0fdf7e6e0f638a8fd07f43d923b4fd72f85e191bd852e6dab464016dc563b1b8b1513b66ae9e529588582c7af738e81465e6d36fa6ecaa8d7754aa232a29e13f
|
data/lib/canvas-api.rb
CHANGED
@@ -1,9 +1,8 @@
|
|
1
1
|
require 'uri'
|
2
2
|
require 'cgi'
|
3
3
|
require 'net/http'
|
4
|
-
require 'net/http/post/multipart'
|
5
4
|
require 'json'
|
6
|
-
|
5
|
+
require 'typhoeus'
|
7
6
|
|
8
7
|
module Canvas
|
9
8
|
class API
|
@@ -104,25 +103,28 @@ module Canvas
|
|
104
103
|
end
|
105
104
|
|
106
105
|
def retrieve_response(request)
|
107
|
-
request['User-Agent'] = "CanvasAPI Ruby"
|
106
|
+
request.options[:headers]['User-Agent'] = "CanvasAPI Ruby"
|
108
107
|
begin
|
109
|
-
response =
|
108
|
+
response = request.run
|
109
|
+
raise ApiError.new("request timed out") if response.timed_out?
|
110
110
|
rescue Timeout::Error => e
|
111
111
|
raise ApiError.new("request timed out")
|
112
112
|
end
|
113
|
-
raise ApiError.new("unexpected redirect to #{response.
|
113
|
+
raise ApiError.new("unexpected redirect to #{response.headers['Location']}") if response.code.to_s.match(/3\d\d/)
|
114
114
|
json = JSON.parse(response.body) rescue {'error' => 'invalid JSON'}
|
115
115
|
if !json.is_a?(Array)
|
116
116
|
raise ApiError.new(json['error']) if json['error']
|
117
|
+
raise ApiError.new(json['errors']) if json['errors']
|
117
118
|
if !response.code.to_s.match(/2\d\d/)
|
118
119
|
json['message'] ||= "unexpected error"
|
120
|
+
json['status'] ||= response.code.to_s
|
119
121
|
raise ApiError.new("#{json['status']} #{json['message']}")
|
120
122
|
end
|
121
123
|
else
|
122
124
|
json = ResultSet.new(self, json)
|
123
|
-
if response['
|
124
|
-
json.link = response['
|
125
|
-
json.next_endpoint = response['
|
125
|
+
if response.headers['Link']
|
126
|
+
json.link = response.headers['Link']
|
127
|
+
json.next_endpoint = response.headers['Link'].split(/,/).detect{|rel| rel.match(/rel="next"/) }.split(/;/).first.strip[1..-2].sub(/https?:\/\/[^\/]+/, '') rescue nil
|
126
128
|
end
|
127
129
|
end
|
128
130
|
json
|
@@ -130,7 +132,7 @@ module Canvas
|
|
130
132
|
|
131
133
|
# Semi-hack so I can write better specs
|
132
134
|
def get_request(endpoint)
|
133
|
-
|
135
|
+
Typhoeus::Request.new(@uri.to_s, method: :get)
|
134
136
|
end
|
135
137
|
|
136
138
|
def get(endpoint, params=nil)
|
@@ -141,28 +143,29 @@ module Canvas
|
|
141
143
|
|
142
144
|
def delete(endpoint, params={})
|
143
145
|
generate_uri(endpoint, params['query_parameters'] || params[:query_parameters])
|
144
|
-
request =
|
145
|
-
request.
|
146
|
+
request = Typhoeus::Request.new(@uri.to_s, method: :delete)
|
147
|
+
request.options[:body] = clean_params(params)
|
146
148
|
retrieve_response(request)
|
147
149
|
end
|
148
150
|
|
149
151
|
def put(endpoint, params={})
|
150
152
|
generate_uri(endpoint, params['query_parameters'] || params[:query_parameters])
|
151
|
-
request =
|
152
|
-
request.
|
153
|
+
request = Typhoeus::Request.new(@uri.to_s, method: :put)
|
154
|
+
request.options[:body] = clean_params(params)
|
153
155
|
retrieve_response(request)
|
154
156
|
end
|
155
157
|
|
156
158
|
def post(endpoint, params={})
|
157
159
|
generate_uri(endpoint, params['query_parameters'] || params[:query_parameters])
|
158
|
-
request =
|
159
|
-
request.
|
160
|
+
request = Typhoeus::Request.new(@uri.to_s, method: :post)
|
161
|
+
request.options[:body] = params #clean_params(params)
|
160
162
|
retrieve_response(request)
|
161
163
|
end
|
162
164
|
|
163
165
|
def post_multi(endpoint, params={})
|
164
166
|
generate_uri(endpoint, params['query_parameters'] || params[:query_parameters])
|
165
|
-
request =
|
167
|
+
request = Typhoeus::Request.new(@uri.to_s, method: :post)
|
168
|
+
request.options[:body] = clean_params(params)
|
166
169
|
retrieve_response(request)
|
167
170
|
end
|
168
171
|
|
@@ -171,12 +174,12 @@ module Canvas
|
|
171
174
|
return params if params.is_a?(Array)
|
172
175
|
return nil unless params.is_a?(Hash)
|
173
176
|
params.delete(:query_parameters)
|
174
|
-
res =
|
177
|
+
res = PairArray.new
|
175
178
|
params.each do |key, val|
|
176
179
|
if val.is_a?(Array)
|
177
180
|
raise "No support for nested array parameters currently"
|
178
181
|
elsif val.is_a?(Hash)
|
179
|
-
res
|
182
|
+
res.concat clean_params(val, prefix ? (prefix + "[" + key.to_s + "]") : key.to_s)
|
180
183
|
else
|
181
184
|
if prefix
|
182
185
|
res << [prefix + "[" + key.to_s + "]", val.to_s]
|
@@ -194,10 +197,14 @@ module Canvas
|
|
194
197
|
:size => file.size,
|
195
198
|
:name => opts[:name] || opts['name'] || File.basename(file.path),
|
196
199
|
:content_type => opts[:content_type] || opts['content_type'] || "application/octet-stream",
|
197
|
-
:parent_folder_id => opts[:parent_folder_id] || opts['parent_folder_id'],
|
198
|
-
:parent_folder_path => opts[:parent_folder_path] || opts['parent_folder_path'],
|
199
200
|
:on_duplicate => opts[:on_duplicate] || opts['on_duplicate']
|
200
201
|
}
|
202
|
+
if opts[:parent_folder_id] || opts['parent_folder_id']
|
203
|
+
params[:parent_folder_id] = opts[:parent_folder_id] || opts['parent_folder_id']
|
204
|
+
elsif opts[:parent_folder_path] || opts['parent_folder_path']
|
205
|
+
params[:parent_folder_path] = opts[:parent_folder_path] || opts['parent_folder_path']
|
206
|
+
end
|
207
|
+
|
201
208
|
res = post(endpoint, params)
|
202
209
|
if !res['upload_url']
|
203
210
|
raise ApiError.new("Unexpected error: #{res['message'] || 'no upload URL returned'}")
|
@@ -209,17 +216,16 @@ module Canvas
|
|
209
216
|
end
|
210
217
|
|
211
218
|
def multipart_upload(url, upload_params, params, file)
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
http = Net::HTTP.new(uri.host, uri.port)
|
216
|
-
http.use_ssl = uri.scheme == 'https'
|
217
|
-
req = Net::HTTP::Post::Multipart.new(uri.path, @multipart_args)
|
218
|
-
res = http.start do |stream_http|
|
219
|
-
stream_http.request(req)
|
219
|
+
req = Typhoeus::Request.new(url, method: :post)
|
220
|
+
upload_params.each do |k, v|
|
221
|
+
upload_params[k] = v.to_s if v
|
220
222
|
end
|
221
|
-
|
222
|
-
|
223
|
+
upload_params['file'] = file
|
224
|
+
req.options[:body] = upload_params
|
225
|
+
@multi_request = req
|
226
|
+
res = req.run
|
227
|
+
raise ApiError.new("Unexpected error: #{res.body}") if !res.headers['Location']
|
228
|
+
res.headers['Location']
|
223
229
|
end
|
224
230
|
|
225
231
|
def upload_file_from_url(endpoint, opts)
|
@@ -277,4 +283,34 @@ module Canvas
|
|
277
283
|
more
|
278
284
|
end
|
279
285
|
end
|
286
|
+
class PairArray < Array
|
287
|
+
end
|
288
|
+
end
|
289
|
+
|
290
|
+
|
291
|
+
# TODO: this is a hack that digs into the bowels of typhoeus
|
292
|
+
module Ethon
|
293
|
+
class Easy
|
294
|
+
module Queryable
|
295
|
+
def recursively_generate_pairs(h, prefix, pairs)
|
296
|
+
case h
|
297
|
+
when Hash
|
298
|
+
h.each_pair do |k,v|
|
299
|
+
key = prefix.nil? ? k : "#{prefix}[#{k}]"
|
300
|
+
pairs_for(v, key, pairs)
|
301
|
+
end
|
302
|
+
when Canvas::PairArray
|
303
|
+
h.each do |k, v|
|
304
|
+
key = prefix.nil? ? k : "#{prefix}[#{k}]"
|
305
|
+
pairs_for(v, key, pairs)
|
306
|
+
end
|
307
|
+
when Array
|
308
|
+
h.each_with_index do |v, i|
|
309
|
+
key = "#{prefix}[#{i}]"
|
310
|
+
pairs_for(v, key, pairs)
|
311
|
+
end
|
312
|
+
end
|
313
|
+
end
|
314
|
+
end
|
315
|
+
end
|
280
316
|
end
|
metadata
CHANGED
@@ -1,78 +1,69 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: canvas-api
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: '1.
|
5
|
-
prerelease:
|
4
|
+
version: '1.1'
|
6
5
|
platform: ruby
|
7
6
|
authors:
|
8
7
|
- Instructure
|
9
8
|
autorequire:
|
10
9
|
bindir: bin
|
11
10
|
cert_chain: []
|
12
|
-
date: 2014-
|
11
|
+
date: 2014-05-15 00:00:00.000000000 Z
|
13
12
|
dependencies:
|
14
13
|
- !ruby/object:Gem::Dependency
|
15
14
|
name: json
|
16
15
|
requirement: !ruby/object:Gem::Requirement
|
17
|
-
none: false
|
18
16
|
requirements:
|
19
|
-
- -
|
17
|
+
- - ">="
|
20
18
|
- !ruby/object:Gem::Version
|
21
19
|
version: '0'
|
22
20
|
type: :runtime
|
23
21
|
prerelease: false
|
24
22
|
version_requirements: !ruby/object:Gem::Requirement
|
25
|
-
none: false
|
26
23
|
requirements:
|
27
|
-
- -
|
24
|
+
- - ">="
|
28
25
|
- !ruby/object:Gem::Version
|
29
26
|
version: '0'
|
30
27
|
- !ruby/object:Gem::Dependency
|
31
|
-
name:
|
28
|
+
name: typhoeus
|
32
29
|
requirement: !ruby/object:Gem::Requirement
|
33
|
-
none: false
|
34
30
|
requirements:
|
35
|
-
- -
|
31
|
+
- - ">="
|
36
32
|
- !ruby/object:Gem::Version
|
37
33
|
version: '0'
|
38
34
|
type: :runtime
|
39
35
|
prerelease: false
|
40
36
|
version_requirements: !ruby/object:Gem::Requirement
|
41
|
-
none: false
|
42
37
|
requirements:
|
43
|
-
- -
|
38
|
+
- - ">="
|
44
39
|
- !ruby/object:Gem::Version
|
45
40
|
version: '0'
|
46
41
|
- !ruby/object:Gem::Dependency
|
47
42
|
name: rspec
|
48
43
|
requirement: !ruby/object:Gem::Requirement
|
49
|
-
none: false
|
50
44
|
requirements:
|
51
|
-
- -
|
45
|
+
- - ">="
|
52
46
|
- !ruby/object:Gem::Version
|
53
47
|
version: '0'
|
54
48
|
type: :development
|
55
49
|
prerelease: false
|
56
50
|
version_requirements: !ruby/object:Gem::Requirement
|
57
|
-
none: false
|
58
51
|
requirements:
|
59
|
-
- -
|
52
|
+
- - ">="
|
60
53
|
- !ruby/object:Gem::Version
|
61
54
|
version: '0'
|
62
55
|
- !ruby/object:Gem::Dependency
|
63
56
|
name: ruby-debug
|
64
57
|
requirement: !ruby/object:Gem::Requirement
|
65
|
-
none: false
|
66
58
|
requirements:
|
67
|
-
- -
|
59
|
+
- - ">="
|
68
60
|
- !ruby/object:Gem::Version
|
69
61
|
version: '0'
|
70
62
|
type: :development
|
71
63
|
prerelease: false
|
72
64
|
version_requirements: !ruby/object:Gem::Requirement
|
73
|
-
none: false
|
74
65
|
requirements:
|
75
|
-
- -
|
66
|
+
- - ">="
|
76
67
|
- !ruby/object:Gem::Version
|
77
68
|
version: '0'
|
78
69
|
description:
|
@@ -82,33 +73,31 @@ extensions: []
|
|
82
73
|
extra_rdoc_files:
|
83
74
|
- LICENSE
|
84
75
|
files:
|
85
|
-
-
|
76
|
+
- Changelog
|
86
77
|
- LICENSE
|
87
78
|
- README.md
|
88
|
-
-
|
79
|
+
- lib/canvas-api.rb
|
89
80
|
homepage: http://github.com/whitmer/canvas-api
|
90
81
|
licenses: []
|
82
|
+
metadata: {}
|
91
83
|
post_install_message:
|
92
84
|
rdoc_options: []
|
93
85
|
require_paths:
|
94
86
|
- lib
|
95
87
|
required_ruby_version: !ruby/object:Gem::Requirement
|
96
|
-
none: false
|
97
88
|
requirements:
|
98
|
-
- -
|
89
|
+
- - ">="
|
99
90
|
- !ruby/object:Gem::Version
|
100
91
|
version: '0'
|
101
92
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
102
|
-
none: false
|
103
93
|
requirements:
|
104
|
-
- -
|
94
|
+
- - ">="
|
105
95
|
- !ruby/object:Gem::Version
|
106
96
|
version: '0'
|
107
97
|
requirements: []
|
108
98
|
rubyforge_project:
|
109
|
-
rubygems_version:
|
99
|
+
rubygems_version: 2.2.2
|
110
100
|
signing_key:
|
111
|
-
specification_version:
|
101
|
+
specification_version: 4
|
112
102
|
summary: Ruby library for accessing the Canvas API
|
113
103
|
test_files: []
|
114
|
-
has_rdoc:
|