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