2015-09-08 11:44:40 +02:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: users
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# name :string
|
|
|
|
# balance :integer default(0), not null
|
|
|
|
# penning :boolean default(FALSE), not null
|
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
|
|
|
#
|
|
|
|
|
2015-09-08 11:30:11 +02:00
|
|
|
class User < ActiveRecord::Base
|
2015-09-11 14:51:35 +02:00
|
|
|
include FriendlyId
|
|
|
|
friendly_id :name, use: :finders
|
2018-03-13 14:50:50 +01:00
|
|
|
devise :cas_authenticatable
|
2015-09-08 12:11:48 +02:00
|
|
|
has_many :incoming_transactions,
|
|
|
|
class_name: 'Transaction', foreign_key: 'creditor_id'
|
|
|
|
has_many :outgoing_transactions,
|
|
|
|
class_name: 'Transaction', foreign_key: 'debtor_id'
|
2017-01-09 15:46:43 +01:00
|
|
|
has_many :incoming_requests,
|
|
|
|
class_name: 'Request', foreign_key: 'debtor_id'
|
|
|
|
has_many :outgoing_requests,
|
2017-01-14 23:12:45 +01:00
|
|
|
class_name: 'Request', foreign_key: 'creditor_id'
|
2017-01-09 16:22:58 +01:00
|
|
|
has_many :notifications
|
2015-09-08 12:45:11 +02:00
|
|
|
|
2015-09-09 12:49:24 +02:00
|
|
|
has_many :issued_transactions, as: :issuer, class_name: 'Transaction'
|
|
|
|
|
2015-09-08 15:51:23 +02:00
|
|
|
validates :name, presence: true, uniqueness: true
|
|
|
|
|
2018-03-13 14:50:50 +01:00
|
|
|
scope :humans, -> { where.not(id: self.wina) }
|
2015-09-14 17:21:53 +02:00
|
|
|
|
2015-09-08 12:45:11 +02:00
|
|
|
def transactions
|
|
|
|
Transaction.where("creditor_id = ? OR debtor_id = ?", id, id)
|
|
|
|
end
|
2015-09-08 13:34:29 +02:00
|
|
|
|
2015-09-08 13:09:34 +02:00
|
|
|
def calculate_balance!
|
|
|
|
balance = incoming_transactions.sum(:amount) -
|
|
|
|
outgoing_transactions.sum(:amount)
|
|
|
|
self.update_attribute :balance, balance
|
|
|
|
end
|
2015-09-08 13:36:16 +02:00
|
|
|
|
2018-03-13 14:50:50 +01:00
|
|
|
def cas_extra_attributes=(extra_attributes)
|
|
|
|
self.name = extra_attributes['display_name']
|
|
|
|
self.debt_allowed = extra_attributes['permissions'].include? 'HAVE_SCHULDEN'
|
|
|
|
self.penning = extra_attributes['permissions'].include? 'MANAGE_SCHULDEN'
|
2015-09-08 13:34:29 +02:00
|
|
|
end
|
2015-09-08 21:38:29 +02:00
|
|
|
|
2018-03-13 14:50:50 +01:00
|
|
|
def self.wina
|
|
|
|
@@wina ||= find_or_create_by name: 'WiNA', username: :WiNA
|
2015-09-08 21:38:29 +02:00
|
|
|
end
|
2015-09-08 11:30:11 +02:00
|
|
|
end
|