2011-10-09 00:36:38 +03:00
|
|
|
class User < ActiveRecord::Base
|
2012-06-07 15:44:57 +03:00
|
|
|
include Account
|
|
|
|
|
2012-07-06 00:05:31 -07:00
|
|
|
devise :database_authenticatable, :token_authenticatable, :lockable,
|
2012-01-21 20:36:14 +02:00
|
|
|
:recoverable, :rememberable, :trackable, :validatable, :omniauthable
|
2011-10-09 00:36:38 +03:00
|
|
|
|
2012-09-26 23:20:36 -07:00
|
|
|
attr_accessible :email, :password, :password_confirmation, :remember_me, :bio, :name,
|
|
|
|
:skype, :linkedin, :twitter, :dark_scheme, :theme_id, :force_random_password,
|
|
|
|
:extern_uid, :provider, :as => [:default, :admin]
|
2012-09-26 13:20:44 +02:00
|
|
|
attr_accessible :projects_limit, :as => :admin
|
2012-06-26 23:59:08 +02:00
|
|
|
|
|
|
|
attr_accessor :force_random_password
|
2011-10-09 00:36:38 +03:00
|
|
|
|
2012-09-26 23:20:36 -07:00
|
|
|
has_many :keys, dependent: :destroy
|
2012-08-10 18:07:50 -04:00
|
|
|
has_many :projects, through: :users_projects
|
2012-09-26 23:20:36 -07:00
|
|
|
has_many :users_projects, dependent: :destroy
|
|
|
|
has_many :issues, foreign_key: :author_id, dependent: :destroy
|
|
|
|
has_many :notes, foreign_key: :author_id, dependent: :destroy
|
|
|
|
has_many :merge_requests, foreign_key: :author_id, dependent: :destroy
|
2012-08-10 18:07:50 -04:00
|
|
|
has_many :my_own_projects, class_name: "Project", foreign_key: :owner_id
|
2012-09-26 23:20:36 -07:00
|
|
|
has_many :events, class_name: "Event", foreign_key: :author_id, dependent: :destroy
|
|
|
|
has_many :recent_events, class_name: "Event", foreign_key: :author_id, order: "id DESC"
|
|
|
|
has_many :assigned_issues, class_name: "Issue", foreign_key: :assignee_id, dependent: :destroy
|
|
|
|
has_many :assigned_merge_requests, class_name: "MergeRequest", foreign_key: :assignee_id, dependent: :destroy
|
2012-04-24 10:42:30 +03:00
|
|
|
|
2012-08-10 18:07:50 -04:00
|
|
|
validates :bio, length: { within: 0..255 }
|
2012-07-29 16:15:52 +02:00
|
|
|
validates :extern_uid, :allow_blank => true, :uniqueness => {:scope => :provider}
|
2012-09-26 23:20:36 -07:00
|
|
|
validates :projects_limit, presence: true, numericality: {greater_than_or_equal_to: 0}
|
2012-04-16 23:33:03 +03:00
|
|
|
|
2012-08-10 18:07:50 -04:00
|
|
|
scope :not_in_project, lambda { |project| where("id not in (:ids)", ids: project.users.map(&:id) ) }
|
|
|
|
scope :admins, where(admin: true)
|
|
|
|
scope :blocked, where(blocked: true)
|
|
|
|
scope :active, where(blocked: false)
|
2012-04-16 23:33:03 +03:00
|
|
|
|
2012-08-10 18:07:50 -04:00
|
|
|
before_validation :generate_password, on: :create
|
2012-09-26 23:20:36 -07:00
|
|
|
before_save :ensure_authentication_token
|
|
|
|
alias_attribute :private_token, :authentication_token
|
2012-06-24 22:26:13 +02:00
|
|
|
|
|
|
|
def generate_password
|
2012-06-27 00:55:54 +02:00
|
|
|
if self.force_random_password
|
2012-06-24 22:26:13 +02:00
|
|
|
self.password = self.password_confirmation = Devise.friendly_token.first(8)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-04-16 23:33:03 +03:00
|
|
|
def self.filter filter_name
|
|
|
|
case filter_name
|
|
|
|
when "admins"; self.admins
|
|
|
|
when "blocked"; self.blocked
|
|
|
|
when "wop"; self.without_projects
|
|
|
|
else
|
|
|
|
self.active
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.without_projects
|
|
|
|
where('id NOT IN (SELECT DISTINCT(user_id) FROM users_projects)')
|
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
|
2012-08-31 16:44:23 +02:00
|
|
|
def self.create_from_omniauth(auth, ldap = false)
|
2012-09-12 09:23:16 +03:00
|
|
|
gitlab_auth.create_from_omniauth(auth, ldap)
|
2012-08-31 16:44:23 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def self.find_or_new_for_omniauth(auth)
|
2012-09-12 09:23:16 +03:00
|
|
|
gitlab_auth.find_or_new_for_omniauth(auth)
|
|
|
|
end
|
2012-08-31 15:45:50 +02:00
|
|
|
|
2012-09-12 09:23:16 +03:00
|
|
|
def self.find_for_ldap_auth(auth, signed_in_resource = nil)
|
|
|
|
gitlab_auth.find_for_ldap_auth(auth, signed_in_resource)
|
2012-08-31 15:45:50 +02:00
|
|
|
end
|
|
|
|
|
2012-09-12 09:23:16 +03:00
|
|
|
def self.gitlab_auth
|
|
|
|
Gitlab::Auth.new
|
2012-01-28 16:23:17 +03:00
|
|
|
end
|
2012-06-21 19:05:09 +03:00
|
|
|
|
|
|
|
def self.search query
|
2012-08-10 18:07:50 -04:00
|
|
|
where("name like :query or email like :query", query: "%#{query}%")
|
2012-06-21 19:05:09 +03:00
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
2012-09-26 23:20:36 -07:00
|
|
|
|
2011-10-09 00:36:38 +03:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: users
|
|
|
|
#
|
2012-09-26 22:36:31 -07:00
|
|
|
# id :integer not null, primary key
|
2011-10-09 00:36:38 +03:00
|
|
|
# email :string(255) default(""), not null
|
|
|
|
# encrypted_password :string(128) default(""), not null
|
|
|
|
# reset_password_token :string(255)
|
|
|
|
# reset_password_sent_at :datetime
|
|
|
|
# remember_created_at :datetime
|
2012-09-26 22:36:31 -07:00
|
|
|
# sign_in_count :integer default(0)
|
2011-10-09 00:36:38 +03:00
|
|
|
# current_sign_in_at :datetime
|
|
|
|
# last_sign_in_at :datetime
|
|
|
|
# current_sign_in_ip :string(255)
|
|
|
|
# last_sign_in_ip :string(255)
|
2012-06-26 21:23:09 +03:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2011-10-09 00:36:38 +03:00
|
|
|
# name :string(255)
|
2012-09-26 22:36:31 -07:00
|
|
|
# admin :boolean default(FALSE), not null
|
|
|
|
# projects_limit :integer default(10)
|
2011-11-16 16:32:35 +08:00
|
|
|
# skype :string(255) default(""), not null
|
|
|
|
# linkedin :string(255) default(""), not null
|
|
|
|
# twitter :string(255) default(""), not null
|
|
|
|
# authentication_token :string(255)
|
2012-09-26 22:36:31 -07:00
|
|
|
# dark_scheme :boolean default(FALSE), not null
|
|
|
|
# theme_id :integer default(1), not null
|
2012-06-26 21:23:09 +03:00
|
|
|
# bio :string(255)
|
2012-09-26 22:36:31 -07:00
|
|
|
# blocked :boolean default(FALSE), not null
|
|
|
|
# failed_attempts :integer default(0)
|
|
|
|
# locked_at :datetime
|
|
|
|
# extern_uid :string(255)
|
|
|
|
# provider :string(255)
|
2011-10-09 00:36:38 +03:00
|
|
|
#
|