2018-09-14 01:42:05 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2013-01-22 12:05:01 -05:00
|
|
|
class UsersController < ApplicationController
|
2021-02-15 16:08:59 -05:00
|
|
|
include InternalRedirect
|
2017-05-01 16:46:30 -04:00
|
|
|
include RoutableActions
|
2017-12-07 04:11:41 -05:00
|
|
|
include RendersMemberAccess
|
2020-07-09 11:08:59 -04:00
|
|
|
include RendersProjectsList
|
2017-12-11 09:21:06 -05:00
|
|
|
include ControllerWithCrossProjectAccessCheck
|
2019-09-02 07:12:20 -04:00
|
|
|
include Gitlab::NoteableMetadata
|
2017-12-11 09:21:06 -05:00
|
|
|
|
|
|
|
requires_cross_project_access show: false,
|
|
|
|
groups: false,
|
|
|
|
projects: false,
|
|
|
|
contributed: false,
|
|
|
|
snippets: true,
|
|
|
|
calendar: false,
|
2021-02-15 16:08:59 -05:00
|
|
|
followers: false,
|
|
|
|
following: false,
|
2017-12-11 09:21:06 -05:00
|
|
|
calendar_activities: true
|
2017-05-01 16:46:30 -04:00
|
|
|
|
2015-04-16 08:03:37 -04:00
|
|
|
skip_before_action :authenticate_user!
|
2018-11-28 14:06:02 -05:00
|
|
|
prepend_before_action(only: [:show]) { authenticate_sessionless_user!(:rss) }
|
2021-08-31 17:10:43 -04:00
|
|
|
before_action :user, except: [:exists]
|
2018-07-24 08:46:19 -04:00
|
|
|
before_action :authorize_read_user_profile!,
|
2021-02-15 16:08:59 -05:00
|
|
|
only: [:calendar, :calendar_activities, :groups, :projects, :contributed, :starred, :snippets, :followers, :following]
|
2022-01-06 07:14:04 -05:00
|
|
|
before_action only: [:exists] do
|
2022-03-07 07:16:11 -05:00
|
|
|
check_rate_limit!(:username_exists, scope: request.ip)
|
2022-01-06 07:14:04 -05:00
|
|
|
end
|
2013-06-07 10:31:12 -04:00
|
|
|
|
2022-04-08 20:09:46 -04:00
|
|
|
feature_category :users, [:show, :activity, :groups, :projects, :contributed, :starred,
|
|
|
|
:followers, :following, :calendar, :calendar_activities,
|
2022-06-02 17:09:25 -04:00
|
|
|
:exists, :activity, :follow, :unfollow, :ssh_keys]
|
2022-04-08 20:09:46 -04:00
|
|
|
|
|
|
|
feature_category :snippets, [:snippets]
|
2022-06-02 17:09:25 -04:00
|
|
|
feature_category :source_code_management, [:gpg_keys]
|
2020-10-05 08:08:47 -04:00
|
|
|
|
2022-04-19 11:08:32 -04:00
|
|
|
# TODO: Set higher urgency after resolving https://gitlab.com/gitlab-org/gitlab/-/issues/357914
|
2022-09-28 08:07:50 -04:00
|
|
|
urgency :low, [:show, :calendar_activities, :contributed, :activity, :projects, :groups, :calendar, :snippets]
|
2022-05-20 17:08:53 -04:00
|
|
|
urgency :default, [:followers, :following, :starred]
|
2022-04-22 14:09:22 -04:00
|
|
|
urgency :high, [:exists]
|
2022-04-19 11:08:32 -04:00
|
|
|
|
2013-01-22 12:05:01 -05:00
|
|
|
def show
|
2015-01-29 04:20:17 -05:00
|
|
|
respond_to do |format|
|
|
|
|
format.html
|
2015-03-22 22:41:12 -04:00
|
|
|
|
|
|
|
format.atom do
|
|
|
|
load_events
|
2022-03-17 17:08:35 -04:00
|
|
|
render layout: 'xml'
|
2015-03-22 22:41:12 -04:00
|
|
|
end
|
|
|
|
|
2015-03-22 18:40:26 -04:00
|
|
|
format.json do
|
2020-12-29 07:10:19 -05:00
|
|
|
msg = "This endpoint is deprecated. Use %s instead." % user_activity_path
|
|
|
|
render json: { message: msg }, status: :not_found
|
2015-03-22 18:40:26 -04:00
|
|
|
end
|
2015-01-29 04:20:17 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-12-11 13:09:57 -05:00
|
|
|
# Get all keys of a user(params[:username]) in a text format
|
|
|
|
# Helpful for sysadmins to put in respective servers
|
|
|
|
def ssh_keys
|
2022-06-27 05:09:26 -04:00
|
|
|
keys = user.all_ssh_keys.join("\n")
|
|
|
|
keys << "\n" unless keys.empty?
|
|
|
|
render plain: keys
|
2020-12-11 13:09:57 -05:00
|
|
|
end
|
|
|
|
|
2018-10-04 03:55:37 -04:00
|
|
|
def activity
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { render 'show' }
|
2020-12-01 07:09:17 -05:00
|
|
|
|
|
|
|
format.json do
|
|
|
|
load_events
|
|
|
|
pager_json("events/_events", @events.count, events: @events)
|
|
|
|
end
|
2018-10-04 03:55:37 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-12-16 13:10:10 -05:00
|
|
|
# Get all gpg keys of a user(params[:username]) in a text format
|
|
|
|
def gpg_keys
|
2022-06-27 05:09:26 -04:00
|
|
|
keys = user.gpg_keys.filter_map { |gpg_key| gpg_key.key if gpg_key.verified? }.join("\n")
|
|
|
|
keys << "\n" unless keys.empty?
|
|
|
|
render plain: keys
|
2020-12-16 13:10:10 -05:00
|
|
|
end
|
|
|
|
|
2016-02-24 11:08:00 -05:00
|
|
|
def groups
|
|
|
|
load_groups
|
|
|
|
|
2016-02-29 16:40:57 -05:00
|
|
|
respond_to do |format|
|
2016-03-01 11:22:27 -05:00
|
|
|
format.html { render 'show' }
|
2016-02-29 16:40:57 -05:00
|
|
|
format.json do
|
|
|
|
render json: {
|
|
|
|
html: view_to_html_string("shared/groups/_list", groups: @groups)
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
2016-03-01 11:43:22 -05:00
|
|
|
def projects
|
2016-02-24 11:08:00 -05:00
|
|
|
load_projects
|
|
|
|
|
2019-01-28 14:27:30 -05:00
|
|
|
present_projects(@projects)
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
2016-03-01 11:43:22 -05:00
|
|
|
def contributed
|
2016-02-24 11:08:00 -05:00
|
|
|
load_contributed_projects
|
|
|
|
|
2019-01-28 14:27:30 -05:00
|
|
|
present_projects(@contributed_projects)
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
2019-01-27 05:18:09 -05:00
|
|
|
def starred
|
|
|
|
load_starred_projects
|
|
|
|
|
2019-01-28 14:27:30 -05:00
|
|
|
present_projects(@starred_projects)
|
|
|
|
end
|
|
|
|
|
2021-02-15 16:08:59 -05:00
|
|
|
def followers
|
|
|
|
@user_followers = user.followers.page(params[:page])
|
|
|
|
|
|
|
|
present_users(@user_followers)
|
|
|
|
end
|
|
|
|
|
|
|
|
def following
|
|
|
|
@user_following = user.followees.page(params[:page])
|
|
|
|
|
|
|
|
present_users(@user_following)
|
|
|
|
end
|
|
|
|
|
2019-01-28 14:27:30 -05:00
|
|
|
def present_projects(projects)
|
2019-01-28 13:08:18 -05:00
|
|
|
skip_pagination = Gitlab::Utils.to_boolean(params[:skip_pagination])
|
|
|
|
skip_namespace = Gitlab::Utils.to_boolean(params[:skip_namespace])
|
|
|
|
compact_mode = Gitlab::Utils.to_boolean(params[:compact_mode])
|
|
|
|
|
2019-01-27 05:18:09 -05:00
|
|
|
respond_to do |format|
|
|
|
|
format.html { render 'show' }
|
|
|
|
format.json do
|
2019-01-28 14:27:30 -05:00
|
|
|
pager_json("shared/projects/_list", projects.count, projects: projects, skip_pagination: skip_pagination, skip_namespace: skip_namespace, compact_mode: compact_mode)
|
2019-01-27 05:18:09 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-02 05:37:12 -04:00
|
|
|
def snippets
|
|
|
|
load_snippets
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { render 'show' }
|
|
|
|
format.json do
|
|
|
|
render json: {
|
2017-03-17 11:38:41 -04:00
|
|
|
html: view_to_html_string("snippets/_snippets", collection: @snippets)
|
2016-05-02 05:37:12 -04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-01-29 04:20:17 -05:00
|
|
|
def calendar
|
2017-07-18 18:05:41 -04:00
|
|
|
render json: contributions_calendar.activity_dates
|
2013-01-22 12:05:01 -05:00
|
|
|
end
|
2014-01-27 09:53:59 -05:00
|
|
|
|
2015-03-13 06:39:26 -04:00
|
|
|
def calendar_activities
|
2022-08-09 08:11:57 -04:00
|
|
|
@calendar_date = begin
|
|
|
|
Date.parse(params[:date])
|
|
|
|
rescue StandardError
|
|
|
|
Date.today
|
|
|
|
end
|
2020-09-30 20:10:16 -04:00
|
|
|
@events = contributions_calendar.events_by_date(@calendar_date).map(&:present)
|
2015-03-13 06:39:26 -04:00
|
|
|
|
|
|
|
render 'calendar_activities', layout: false
|
|
|
|
end
|
|
|
|
|
2016-09-09 08:21:00 -04:00
|
|
|
def exists
|
2022-01-26 16:16:58 -05:00
|
|
|
if Gitlab::CurrentSettings.signup_enabled? || current_user
|
|
|
|
render json: { exists: !!Namespace.find_by_path_or_name(params[:username]) }
|
|
|
|
else
|
|
|
|
render json: { error: _('You must be authenticated to access this path.') }, status: :unauthorized
|
|
|
|
end
|
2016-09-09 08:21:00 -04:00
|
|
|
end
|
|
|
|
|
2021-02-15 16:08:59 -05:00
|
|
|
def follow
|
|
|
|
current_user.follow(user)
|
|
|
|
|
|
|
|
redirect_path = referer_path(request) || @user
|
|
|
|
|
|
|
|
redirect_to redirect_path
|
|
|
|
end
|
|
|
|
|
|
|
|
def unfollow
|
|
|
|
current_user.unfollow(user)
|
|
|
|
|
|
|
|
redirect_path = referer_path(request) || @user
|
|
|
|
|
|
|
|
redirect_to redirect_path
|
|
|
|
end
|
|
|
|
|
2015-01-29 04:20:17 -05:00
|
|
|
private
|
2016-03-31 10:36:40 -04:00
|
|
|
|
2016-04-05 17:56:07 -04:00
|
|
|
def user
|
2021-08-19 11:10:29 -04:00
|
|
|
@user ||= find_routable!(User, params[:username], request.fullpath)
|
2015-01-29 04:20:17 -05:00
|
|
|
end
|
2015-02-18 16:28:24 -05:00
|
|
|
|
2020-04-21 11:21:10 -04:00
|
|
|
def personal_projects
|
|
|
|
PersonalProjectsFinder.new(user).execute(current_user)
|
|
|
|
end
|
|
|
|
|
2015-03-22 02:48:08 -04:00
|
|
|
def contributed_projects
|
2016-04-05 17:56:07 -04:00
|
|
|
ContributedProjectsFinder.new(user).execute(current_user)
|
2015-03-22 02:48:08 -04:00
|
|
|
end
|
|
|
|
|
2019-01-27 05:18:09 -05:00
|
|
|
def starred_projects
|
2022-01-27 22:15:57 -05:00
|
|
|
StarredProjectsFinder.new(user, params: finder_params, current_user: current_user).execute
|
2019-01-27 05:18:09 -05:00
|
|
|
end
|
|
|
|
|
2015-03-22 02:48:08 -04:00
|
|
|
def contributions_calendar
|
2016-11-04 10:15:43 -04:00
|
|
|
@contributions_calendar ||= Gitlab::ContributionsCalendar.new(user, current_user)
|
2015-03-22 02:48:08 -04:00
|
|
|
end
|
2015-03-23 12:45:40 -04:00
|
|
|
|
2015-03-22 18:40:26 -04:00
|
|
|
def load_events
|
2021-02-15 16:08:59 -05:00
|
|
|
@events = UserRecentEventsFinder.new(current_user, user, nil, params).execute
|
2017-11-06 11:52:56 -05:00
|
|
|
|
|
|
|
Events::RenderService.new(current_user).execute(@events, atom_request: request.format.atom?)
|
2015-11-18 06:32:35 -05:00
|
|
|
end
|
2015-03-22 18:40:26 -04:00
|
|
|
|
2016-02-24 11:08:00 -05:00
|
|
|
def load_projects
|
2020-04-21 11:21:10 -04:00
|
|
|
@projects = personal_projects
|
2016-03-19 17:37:54 -04:00
|
|
|
.page(params[:page])
|
2018-10-04 03:55:37 -04:00
|
|
|
.per(params[:limit])
|
2017-12-07 04:11:41 -05:00
|
|
|
|
|
|
|
prepare_projects_for_rendering(@projects)
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def load_contributed_projects
|
2016-04-05 17:56:07 -04:00
|
|
|
@contributed_projects = contributed_projects.joined(user)
|
2017-12-07 04:11:41 -05:00
|
|
|
|
|
|
|
prepare_projects_for_rendering(@contributed_projects)
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
2019-01-27 05:18:09 -05:00
|
|
|
def load_starred_projects
|
2019-07-27 02:13:23 -04:00
|
|
|
@starred_projects = starred_projects
|
2019-01-27 05:18:09 -05:00
|
|
|
|
|
|
|
prepare_projects_for_rendering(@starred_projects)
|
|
|
|
end
|
|
|
|
|
2016-02-24 11:08:00 -05:00
|
|
|
def load_groups
|
2016-04-05 17:56:07 -04:00
|
|
|
@groups = JoinedGroupsFinder.new(user).execute(current_user)
|
2017-12-07 04:11:41 -05:00
|
|
|
|
|
|
|
prepare_groups_for_rendering(@groups)
|
2016-02-24 11:08:00 -05:00
|
|
|
end
|
|
|
|
|
2016-05-02 05:37:12 -04:00
|
|
|
def load_snippets
|
2019-09-02 07:12:20 -04:00
|
|
|
@snippets = SnippetsFinder.new(current_user, author: user, scope: params[:scope])
|
|
|
|
.execute
|
|
|
|
.page(params[:page])
|
|
|
|
.inc_author
|
|
|
|
|
|
|
|
@noteable_meta_data = noteable_meta_data(@snippets, 'Snippet')
|
2016-05-02 05:37:12 -04:00
|
|
|
end
|
|
|
|
|
2017-05-18 19:23:05 -04:00
|
|
|
def build_canonical_path(user)
|
2018-04-08 00:35:30 -04:00
|
|
|
url_for(safe_params.merge(username: user.to_param))
|
2017-05-18 19:23:05 -04:00
|
|
|
end
|
2018-07-24 08:46:19 -04:00
|
|
|
|
|
|
|
def authorize_read_user_profile!
|
|
|
|
access_denied! unless can?(current_user, :read_user_profile, user)
|
|
|
|
end
|
2021-02-15 16:08:59 -05:00
|
|
|
|
|
|
|
def present_users(users)
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { render 'show' }
|
|
|
|
format.json do
|
|
|
|
render json: {
|
|
|
|
html: view_to_html_string("shared/users/index", users: users)
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2022-01-27 22:15:57 -05:00
|
|
|
|
|
|
|
def finder_params
|
|
|
|
{
|
|
|
|
# don't display projects pending deletion
|
|
|
|
without_deleted: true,
|
|
|
|
# don't display projects marked for deletion
|
|
|
|
not_aimed_for_deletion: true
|
|
|
|
}
|
|
|
|
end
|
2013-01-22 12:05:01 -05:00
|
|
|
end
|
2019-09-13 09:26:31 -04:00
|
|
|
|
2021-05-11 17:10:21 -04:00
|
|
|
UsersController.prepend_mod_with('UsersController')
|