Class: PlatformSdk::CanvasApiWrapper::Client
- Inherits:
-
Object
- Object
- PlatformSdk::CanvasApiWrapper::Client
- Defined in:
- lib/platform_sdk/canvas_api/client.rb
Overview
DataPipeline::Client
Constant Summary collapse
- PAGE_SIZE =
10
Instance Attribute Summary collapse
-
#connection ⇒ Object
readonly
Returns the value of attribute connection.
-
#host ⇒ Object
readonly
Returns the value of attribute host.
-
#token ⇒ Object
readonly
Returns the value of attribute token.
Instance Method Summary collapse
- #assignment(course_id:, assignment_id:) ⇒ Object
- #assignments(course_id:, module_id:) ⇒ Object
- #course_modules(course_id:) ⇒ Object
- #course_students(course_id:) ⇒ Object
-
#initialize(domain:, token:) ⇒ Client
constructor
A new instance of Client.
- #module_item(course_id:, module_id:, module_item_id:) ⇒ Object
- #module_items(course_id:, module_id:) ⇒ Object
- #post_complete_quiz_submission(course_id:, quiz_id:, submission_id:, attempt:, validation_token:) ⇒ Hash
- #post_create_quiz_submission(course_id:, quiz_id:, user_id:) ⇒ Object
- #post_discussion_topic_entry(course_id:, topic_id:, user_id:, message:) ⇒ Object
-
#post_mark_module_item_done(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
Nil.
-
#post_mark_module_item_read(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
Nil.
- #quiz(course_id:, quiz_id:) ⇒ Object
- #quiz_submissions(course_id:, quiz_id:, user_id:) ⇒ Array
- #submissions(course_id:, assignment_id:) ⇒ Object
- #update_submission_excused(course_id:, assignment_id:, user_id:) ⇒ Object
- #update_submission_excused_with_comment(course_id:, assignment_id:, user_id:, comment:) ⇒ Object
- #user_module_item(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
- #user_module_items(course_id:, module_id:, user_id:) ⇒ Object
Constructor Details
#initialize(domain:, token:) ⇒ Client
Returns a new instance of Client.
15 16 17 18 19 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 15 def initialize(domain:, token:) @host = "https://#{domain}" @token = token @connection = Faraday.new(url: host, headers: { 'Authorization' => "Bearer #{token}" }) end |
Instance Attribute Details
#connection ⇒ Object (readonly)
Returns the value of attribute connection.
9 10 11 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 9 def connection @connection end |
#host ⇒ Object (readonly)
Returns the value of attribute host.
9 10 11 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 9 def host @host end |
#token ⇒ Object (readonly)
Returns the value of attribute token.
9 10 11 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 9 def token @token end |
Instance Method Details
#assignment(course_id:, assignment_id:) ⇒ Object
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 96 def assignment(course_id:, assignment_id:) uri = "api/v1/courses/#{course_id}/assignments/#{assignment_id}" response = @connection.get(uri) handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting quiz submissions#{}" end end |
#assignments(course_id:, module_id:) ⇒ Object
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 79 def assignments(course_id:, module_id:) response = @connection.get("/api/v1/courses/#{course_id}/modules/#{module_id}/items?per_page=#{PAGE_SIZE}") handle_rate_limiting response if success?(response.status) assignments = paginated_items headers: response.headers, initial_response: response.body assignments.select { |item| item[:type] == 'Assignment' } else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting assignments: #{}" end end |
#course_modules(course_id:) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 23 def course_modules(course_id:) response = @connection.get("/api/v1/courses/#{course_id}/modules") handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting course modules: #{}" end end |
#course_students(course_id:) ⇒ Object
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 211 def course_students(course_id:) uri = "/api/v1/courses/#{course_id}/users?per_page=#{PAGE_SIZE}" params = { 'enrollment_type[]' => 'student' } response = @connection.get(uri, params) handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting course students: #{}" end end |
#module_item(course_id:, module_id:, module_item_id:) ⇒ Object
115 116 117 118 119 120 121 122 123 124 125 126 127 128 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 115 def module_item(course_id:, module_id:, module_item_id:) response = @connection.get("/api/v1/courses/#{course_id}/modules/#{module_id}/items/#{module_item_id}") handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting module item: #{}" end end |
#module_items(course_id:, module_id:) ⇒ Object
41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 41 def module_items(course_id:, module_id:) response = @connection.get("/api/v1/courses/#{course_id}/modules/#{module_id}/items?per_page=#{PAGE_SIZE}") handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting module items: #{}" end end |
#post_complete_quiz_submission(course_id:, quiz_id:, submission_id:, attempt:, validation_token:) ⇒ Hash
286 287 288 289 290 291 292 293 294 295 296 297 298 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 286 def post_complete_quiz_submission(course_id:, quiz_id:, submission_id:, attempt:, validation_token:) uri = "api/v1/courses/#{course_id}/quizzes/#{quiz_id}/submissions/#{submission_id}/complete" response = @connection.post(uri) do |req| req.headers['Content-Type'] = 'application/json' req.body = { attempt:, validation_token: }.to_json end handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else handle_post_response_errors(response, 'Error completing quiz submission') end end |
#post_create_quiz_submission(course_id:, quiz_id:, user_id:) ⇒ Object
269 270 271 272 273 274 275 276 277 278 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 269 def post_create_quiz_submission(course_id:, quiz_id:, user_id:) uri = "api/v1/courses/#{course_id}/quizzes/#{quiz_id}/submissions?as_user_id=#{user_id}" response = @connection.post(uri) handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else handle_post_response_errors(response, 'Error creating quiz submission') end end |
#post_discussion_topic_entry(course_id:, topic_id:, user_id:, message:) ⇒ Object
332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 332 def post_discussion_topic_entry(course_id:, topic_id:, user_id:, message:) uri = "api/v1/courses/#{course_id}/discussion_topics/#{topic_id}/entries?as_user_id=#{user_id}" response = @connection.post(uri) do |req| req.headers['Content-Type'] = 'application/json' req.body = { 'message': .to_s }.to_json end handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors]&.each do |error| << "#{error[:message]} " end raise "Error posting a reply: #{}" end end |
#post_mark_module_item_done(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
Returns nil.
321 322 323 324 325 326 327 328 329 330 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 321 def post_mark_module_item_done(course_id:, module_id:, module_item_id:, user_id:) uri = "api/v1/courses/#{course_id}/modules/#{module_id}/items/#{module_item_id}/done?as_user_id=#{user_id}" response = @connection.post(uri) handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else handle_post_response_errors(response, 'Error marking module item done') end end |
#post_mark_module_item_read(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
Returns nil.
305 306 307 308 309 310 311 312 313 314 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 305 def post_mark_module_item_read(course_id:, module_id:, module_item_id:, user_id:) uri = "api/v1/courses/#{course_id}/modules/#{module_id}/items/#{module_item_id}/mark_read?as_user_id=#{user_id}" response = @connection.post(uri) handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else handle_post_response_errors(response, 'Error marking module items read') end end |
#quiz(course_id:, quiz_id:) ⇒ Object
230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 230 def quiz(course_id:, quiz_id:) uri = "/api/v1/courses/#{course_id}/quizzes/#{quiz_id}" response = @connection.get(uri) handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting quiz: #{}" end end |
#quiz_submissions(course_id:, quiz_id:, user_id:) ⇒ Array
250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 250 def quiz_submissions(course_id:, quiz_id:, user_id:) uri = "api/v1/courses/#{course_id}/quizzes/#{quiz_id}/submissions?user=#{user_id}&per_page=#{PAGE_SIZE}" response = @connection.get(uri) handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting quiz submissions#{}" end end |
#submissions(course_id:, assignment_id:) ⇒ Object
147 148 149 150 151 152 153 154 155 156 157 158 159 160 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 147 def submissions(course_id:, assignment_id:) response = @connection.get("/api/v1/courses/#{course_id}/assignments/#{assignment_id}/submissions/") handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting submissions: #{}" end end |
#update_submission_excused(course_id:, assignment_id:, user_id:) ⇒ Object
162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 162 def update_submission_excused(course_id:, assignment_id:, user_id:) uri = "/api/v1/courses/#{course_id}/assignments/#{assignment_id}/submissions/#{user_id}" response = @connection.put(uri) do |req| req.headers["Content-Type"] = "application/json" req.body = { submission: { excuse: true } }.to_json end handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error update submissions to excused: #{}" end end |
#update_submission_excused_with_comment(course_id:, assignment_id:, user_id:, comment:) ⇒ Object
185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 185 def update_submission_excused_with_comment(course_id:, assignment_id:, user_id:, comment:) uri = "/api/v1/courses/#{course_id}/assignments/#{assignment_id}/submissions/#{user_id}" response = @connection.put(uri) do |req| req.headers['Content-Type'] = 'application/json' req.body = { 'comment': { 'text_comment': comment }, 'submission': { 'excuse': true } }.to_json end if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error update submissions to excused: #{}" end end |
#user_module_item(course_id:, module_id:, module_item_id:, user_id:) ⇒ Object
130 131 132 133 134 135 136 137 138 139 140 141 142 143 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 130 def user_module_item(course_id:, module_id:, module_item_id:, user_id:) response = @connection.get("/api/v1/courses/#{course_id}/modules/#{module_id}/items/#{module_item_id}?as_user_id=#{user_id}") handle_rate_limiting response if success?(response.status) MultiJson.load response.body, symbolize_keys: true else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting module item: #{}" end end |
#user_module_items(course_id:, module_id:, user_id:) ⇒ Object
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/platform_sdk/canvas_api/client.rb', line 60 def user_module_items(course_id:, module_id:, user_id:) uri = "/api/v1/courses/#{course_id}/modules/#{module_id}/items?as_user_id=#{user_id}&per_page=#{PAGE_SIZE}" response = @connection.get(uri) handle_rate_limiting response if success?(response.status) paginated_items headers: response.headers, initial_response: response.body else result = MultiJson.load response.body, symbolize_keys: true = String.new result[:errors].each do |error| << "#{error[:message]} " end raise "Error getting module items: #{}" end end |