Sha256: c4976956979ad629ac8591b2e86c70cae51a7fdbc4ed24d21de7e30b8b6400b3
Contents?: true
Size: 1.68 KB
Versions: 1
Compression:
Stored size: 1.68 KB
Contents
module AbsorbApi class User < Base include Relations attr_accessor :id, :department_id, :first_name, :middle_name, :last_name, :username, :password, :email_address, :cc_email_addresses, :language_id, :gender, :address, :address2, :city, :province_id, :country_id, :postal_code, :phone, :employee_number, :location, :job_title, :reference_number, :date_hired, :date_terminated, :notes, :custom_fields, :role_ids, :active_status, :is_learner, :is_admin, :is_instructor, :external_id, :supervisor_id, :decimal2, :string1, :decimal1, :string2, :decimal3, :job_title has_many :courses has_many :enrollments, klass: :course_enrollment has_many :certificates has_many :resources def update(attrs) attrs.keys.each { |k| attrs[k.to_s.camelize] = attrs.delete(k) } attrs['Username'] = username response = AbsorbApi.api.put("users/#{id}", attrs) raise ValidationError if response.status == 500 raise RouteNotFound if response.status == 405 self end # gets all associated courses given a collection of users # all calls are called in parallel # users are chunked in groups of 105 to keep typhoeus from bogging down def self.courses_from_collection(users) courses = [] users.each_slice(105) do |user_slice| AbsorbApi.api.in_parallel do user_slice.each do |user| courses << AbsorbApi.api.get("users/#{user.id}/courses") end end end courses.map { |response| response.body.map { |body| Course.new(body) } }.flatten end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
absorb_api-0.1.11 | lib/absorb_api/user.rb |