109 lines
2.8 KiB
Ruby
109 lines
2.8 KiB
Ruby
class User
|
|
include SimplyStored::Couch
|
|
include ActiveModel::SerializerSupport
|
|
|
|
property :name
|
|
property :active_list_id
|
|
property :admin, type: :boolean, default: false
|
|
|
|
#FACEBOOK
|
|
property :provider
|
|
property :uid
|
|
property :oauth_token
|
|
property :oauth_expires_at
|
|
property :auth_data
|
|
|
|
devise :database_authenticatable, :recoverable, :rememberable, :trackable, :omniauthable, :omniauth_providers => [:facebook] #, :token_authenticatable , :registerable
|
|
|
|
property :authentication_token
|
|
|
|
has_and_belongs_to_many :lists, storing_keys: false
|
|
has_many :orders
|
|
|
|
validates_uniqueness_of :email
|
|
before_save :ensure_authentication_token
|
|
|
|
has_many :error_logs
|
|
has_many :user_feedbacks
|
|
|
|
view :by_authentication_token, key: :authentication_token
|
|
view :by_email, key: :email
|
|
view :by_facebook, key: [:provider, :uid]
|
|
|
|
def self.find_for_facebook_oauth(auth_data, user)
|
|
user = database.view(self.by_facebook(key: [auth_data.provider, auth_data.uid], limit: 1)).first
|
|
|
|
user || create(
|
|
provider: auth_data.provider,
|
|
uid: auth_data.uid,
|
|
name: auth_data.info.nickname,
|
|
email: auth_data.info.email,
|
|
password: Devise.friendly_token[0,20],
|
|
oauth_token: auth_data.credentials.token,
|
|
oauth_expires_at: auth_data.credentials.expires ? Time.at(auth_data.credentials.expires_at) : nil,
|
|
auth_data: auth_data
|
|
)
|
|
end
|
|
|
|
def facebook_id
|
|
uid
|
|
end
|
|
|
|
def self.from_omniauth(auth)
|
|
#binding.pry
|
|
end
|
|
|
|
def list_is_closed!
|
|
self.active_list_id = nil
|
|
save
|
|
end
|
|
|
|
# This is the user name as it is shown to the supplier
|
|
def supplier_name
|
|
auth_data['info']['name'] rescue I18n.t('user.unknown_supplier_name')
|
|
end
|
|
|
|
# This is the user name as it is shown to other users
|
|
def friends_name
|
|
auth_data['info']['nickname'] rescue ''
|
|
end
|
|
|
|
def has_active_list?
|
|
active_list_id.present?
|
|
end
|
|
|
|
# only used for testing so far
|
|
def active_list
|
|
has_active_list? ? List.find(active_list_id) : nil
|
|
end
|
|
|
|
#####################################
|
|
# Taken from devise 2.2
|
|
#####################################
|
|
|
|
# Generate new authentication token (a.k.a. "single access token").
|
|
def reset_authentication_token
|
|
self.authentication_token = self.class.authentication_token
|
|
end
|
|
|
|
# Generate new authentication token and save the record.
|
|
def reset_authentication_token!
|
|
reset_authentication_token
|
|
save(:validate => false)
|
|
end
|
|
|
|
# Generate authentication token unless already exists.
|
|
def ensure_authentication_token
|
|
reset_authentication_token if authentication_token.blank?
|
|
end
|
|
|
|
# Generate authentication token unless already exists and save the record.
|
|
def ensure_authentication_token!
|
|
reset_authentication_token! if authentication_token.blank?
|
|
end
|
|
|
|
def self.authentication_token
|
|
SecureRandom.hex(24)
|
|
end
|
|
end
|