2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module ProjectsHelper
2020-03-13 15:44:24 +05:30
def project_incident_management_setting
@project_incident_management_setting || = @project . incident_management_setting ||
@project . build_incident_management_setting
end
2015-04-26 12:48:37 +05:30
def link_to_project ( project )
2019-02-15 15:39:39 +05:30
link_to namespace_project_path ( namespace_id : project . namespace , id : project ) , title : h ( project . name ) do
2014-09-02 18:07:02 +05:30
title = content_tag ( :span , project . name , class : 'project-name' )
if project . namespace
namespace = content_tag ( :span , " #{ project . namespace . human_name } / " , class : 'namespace-name' )
title = namespace + title
end
title
end
end
2016-04-02 18:10:28 +05:30
def link_to_member_avatar ( author , opts = { } )
2018-03-17 18:26:18 +05:30
default_opts = { size : 16 , lazy_load : false }
2016-04-02 18:10:28 +05:30
opts = default_opts . merge ( opts )
2018-03-17 18:26:18 +05:30
classes = %W[ avatar avatar-inline s #{ opts [ :size ] } ]
classes << opts [ :avatar_class ] if opts [ :avatar_class ]
2018-03-27 19:54:05 +05:30
avatar = avatar_icon_for_user ( author , opts [ :size ] )
2018-03-17 18:26:18 +05:30
src = opts [ :lazy_load ] ? nil : avatar
image_tag ( src , width : opts [ :size ] , class : classes , alt : '' , " data-src " = > avatar )
end
def author_content_tag ( author , opts = { } )
default_opts = { author_class : 'author' , tooltip : false , by_username : false }
opts = default_opts . merge ( opts )
has_tooltip = ! opts [ :by_username ] && opts [ :tooltip ]
username = opts [ :by_username ] ? author . to_reference : author . name
name_tag_options = { class : [ opts [ :author_class ] ] }
if has_tooltip
name_tag_options [ :title ] = author . to_reference
name_tag_options [ :data ] = { placement : 'top' }
name_tag_options [ :class ] << 'has-tooltip'
end
2018-06-27 16:04:02 +05:30
# NOTE: ActionView::Helpers::TagHelper#content_tag HTML escapes username
content_tag ( :span , username , name_tag_options )
2016-04-02 18:10:28 +05:30
end
2016-06-02 11:05:42 +05:30
def link_to_member ( project , author , opts = { } , & block )
2018-03-17 18:26:18 +05:30
default_opts = { avatar : true , name : true , title : " :name " }
2014-09-02 18:07:02 +05:30
opts = default_opts . merge ( opts )
2019-02-15 15:39:39 +05:30
data_attrs = {
user_id : author . id ,
username : author . username ,
name : author . name
}
2014-09-02 18:07:02 +05:30
return " (deleted) " unless author
2018-12-05 23:21:45 +05:30
author_html = [ ]
2014-09-02 18:07:02 +05:30
# Build avatar image tag
2018-03-17 18:26:18 +05:30
author_html << link_to_member_avatar ( author , opts ) if opts [ :avatar ]
2014-09-02 18:07:02 +05:30
# Build name span tag
2018-03-17 18:26:18 +05:30
author_html << author_content_tag ( author , opts ) if opts [ :name ]
2016-06-02 11:05:42 +05:30
author_html << capture ( & block ) if block
2014-09-02 18:07:02 +05:30
2018-12-05 23:21:45 +05:30
author_html = author_html . join . html_safe
2014-09-02 18:07:02 +05:30
if opts [ :name ]
2019-02-15 15:39:39 +05:30
link_to ( author_html , user_path ( author ) , class : " author-link js-user-link #{ " #{ opts [ :extra_class ] } " if opts [ :extra_class ] } #{ " #{ opts [ :mobile_classes ] } " if opts [ :mobile_classes ] } " , data : data_attrs ) . html_safe
2014-09-02 18:07:02 +05:30
else
2015-12-23 02:04:40 +05:30
title = opts [ :title ] . sub ( " :name " , sanitize ( author . name ) )
2019-12-21 20:55:43 +05:30
link_to ( author_html , user_path ( author ) , class : " author-link has-tooltip " , title : title , data : { container : 'body' , qa_selector : 'assignee_link' } ) . html_safe
2014-09-02 18:07:02 +05:30
end
end
2017-08-17 22:00:37 +05:30
def project_title ( project )
2015-09-25 12:07:36 +05:30
namespace_link =
if project . group
2018-03-17 18:26:18 +05:30
group_title ( project . group , nil , nil )
2015-09-25 12:07:36 +05:30
else
owner = project . namespace . owner
link_to ( simple_sanitize ( owner . name ) , user_path ( owner ) )
2014-09-02 18:07:02 +05:30
end
2015-09-25 12:07:36 +05:30
2018-03-17 18:26:18 +05:30
project_link = link_to project_path ( project ) do
2018-12-05 23:21:45 +05:30
icon = project_icon ( project , alt : project . name , class : 'avatar-tile' , width : 15 , height : 15 ) if project . avatar_url && ! Rails . env . test?
[ icon , content_tag ( " span " , simple_sanitize ( project . name ) , class : " breadcrumb-item-text js-breadcrumb-item-text " ) ] . join . html_safe
2017-09-10 17:25:29 +05:30
end
2016-04-02 18:10:28 +05:30
2018-03-17 18:26:18 +05:30
namespace_link = breadcrumb_list_item ( namespace_link ) unless project . group
project_link = breadcrumb_list_item project_link
2015-09-25 12:07:36 +05:30
2018-03-17 18:26:18 +05:30
" #{ namespace_link } #{ project_link } " . html_safe
2014-09-02 18:07:02 +05:30
end
def remove_project_message ( project )
2018-03-27 19:54:05 +05:30
_ ( " You are going to remove %{project_full_name}. Removed project CANNOT be restored! Are you ABSOLUTELY sure? " ) %
{ project_full_name : project . full_name }
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
def transfer_project_message ( project )
2018-03-27 19:54:05 +05:30
_ ( " You are going to transfer %{project_full_name} to another owner. Are you ABSOLUTELY sure? " ) %
{ project_full_name : project . full_name }
2015-04-26 12:48:37 +05:30
end
2019-12-04 20:38:33 +05:30
def remove_fork_project_description_message ( project )
source = visible_fork_source ( project )
2018-03-17 18:26:18 +05:30
2019-12-04 20:38:33 +05:30
if source
2020-01-01 13:55:28 +05:30
msg = _ ( 'This will remove the fork relationship between this project and %{fork_source}.' ) %
2019-12-04 20:38:33 +05:30
{ fork_source : link_to ( source . full_name , project_path ( source ) ) }
2020-01-01 13:55:28 +05:30
msg . html_safe
2018-03-17 18:26:18 +05:30
else
2019-12-04 20:38:33 +05:30
_ ( 'This will remove the fork relationship between this project and other projects in the fork network.' )
2018-03-17 18:26:18 +05:30
end
2015-11-26 14:37:03 +05:30
end
2019-12-04 20:38:33 +05:30
def remove_fork_project_warning_message ( project )
_ ( " You are going to remove the fork relationship from %{project_full_name}. Are you ABSOLUTELY sure? " ) %
{ project_full_name : project . full_name }
end
def visible_fork_source ( project )
project . fork_source if project . fork_source && can? ( current_user , :read_project , project . fork_source )
end
2014-09-02 18:07:02 +05:30
def project_nav_tabs
@nav_tabs || = get_project_nav_tabs ( @project , current_user )
end
2017-09-10 17:25:29 +05:30
def project_search_tabs? ( tab )
abilities = Array ( search_tab_ability_map [ tab ] )
abilities . any? { | ability | can? ( current_user , ability , @project ) }
end
2014-09-02 18:07:02 +05:30
def project_nav_tab? ( name )
project_nav_tabs . include? name
end
2015-04-26 12:48:37 +05:30
def project_for_deploy_key ( deploy_key )
2017-08-17 22:00:37 +05:30
if deploy_key . has_access_to? ( @project )
2015-04-26 12:48:37 +05:30
@project
else
2017-08-17 22:00:37 +05:30
deploy_key . projects . find do | project |
can? ( current_user , :read_project , project )
end
2015-04-26 12:48:37 +05:30
end
end
2015-09-11 14:41:01 +05:30
def can_change_visibility_level? ( project , current_user )
return false unless can? ( current_user , :change_visibility_level , project )
2018-03-17 18:26:18 +05:30
if project . fork_source
project . fork_source . visibility_level > Gitlab :: VisibilityLevel :: PRIVATE
2015-09-11 14:41:01 +05:30
else
true
end
end
2019-10-12 21:52:04 +05:30
def can_disable_emails? ( project , current_user )
return false if project . group & . emails_disabled?
2019-12-21 20:55:43 +05:30
can? ( current_user , :set_emails_disabled , project )
2019-10-12 21:52:04 +05:30
end
2016-09-13 17:45:13 +05:30
def last_push_event
2018-03-17 18:26:18 +05:30
current_user & . recent_push ( @project )
2016-09-13 17:45:13 +05:30
end
2017-08-17 22:00:37 +05:30
def link_to_autodeploy_doc
2019-12-21 20:55:43 +05:30
link_to _ ( 'About auto deploy' ) , help_page_path ( 'autodevops/index.md#auto-deploy' ) , target : '_blank'
2017-08-17 22:00:37 +05:30
end
def autodeploy_flash_notice ( branch_name )
2017-09-10 17:25:29 +05:30
translation = _ ( " Branch <strong>%{branch_name}</strong> was created. To set up auto deploy, choose a GitLab CI Yaml template and commit your changes. %{link_to_autodeploy_doc} " ) %
{ branch_name : truncate ( sanitize ( branch_name ) ) , link_to_autodeploy_doc : link_to_autodeploy_doc }
translation . html_safe
2017-08-17 22:00:37 +05:30
end
2019-07-07 11:18:12 +05:30
def project_list_cache_key ( project , pipeline_status : true )
2017-09-10 17:25:29 +05:30
key = [
project . route . cache_key ,
project . cache_key ,
2018-11-08 19:23:39 +05:30
project . last_activity_date ,
2017-09-10 17:25:29 +05:30
controller . controller_name ,
controller . action_name ,
2018-03-17 18:26:18 +05:30
Gitlab :: CurrentSettings . cache_key ,
2018-03-27 19:54:05 +05:30
" cross-project: #{ can? ( current_user , :read_cross_project ) } " ,
2018-11-08 19:23:39 +05:30
max_project_member_access_cache_key ( project ) ,
2019-07-07 11:18:12 +05:30
pipeline_status ,
2020-01-01 13:55:28 +05:30
Gitlab :: I18n . locale ,
2018-11-08 19:23:39 +05:30
'v2.6'
2017-09-10 17:25:29 +05:30
]
2019-07-07 11:18:12 +05:30
key << pipeline_status_cache_key ( project . pipeline_status ) if pipeline_status && project . pipeline_status . has_status?
2017-08-17 22:00:37 +05:30
key
end
def load_pipeline_status ( projects )
2017-09-10 17:25:29 +05:30
Gitlab :: Cache :: Ci :: ProjectPipelineStatus
. load_in_batch_for_projects ( projects )
end
def show_no_ssh_key_message?
2018-11-20 20:47:30 +05:30
Gitlab :: CurrentSettings . user_show_add_ssh_key_message? &&
cookies [ :hide_no_ssh_message ] . blank? &&
! current_user . hide_no_ssh_key &&
current_user . require_ssh_key?
2017-09-10 17:25:29 +05:30
end
def show_no_password_message?
cookies [ :hide_no_password_message ] . blank? && ! current_user . hide_no_password &&
2018-03-17 18:26:18 +05:30
current_user . require_extra_setup_for_git_auth?
2017-09-10 17:25:29 +05:30
end
2019-02-15 15:39:39 +05:30
def show_auto_devops_implicitly_enabled_banner? ( project , user )
return false unless user_can_see_auto_devops_implicitly_enabled_banner? ( project , user )
2018-11-20 20:47:30 +05:30
2019-02-15 15:39:39 +05:30
cookies [ " hide_auto_devops_implicitly_enabled_banner_ #{ project . id } " . to_sym ] . blank?
2018-11-20 20:47:30 +05:30
end
2017-09-10 17:25:29 +05:30
def link_to_set_password
2018-03-17 18:26:18 +05:30
if current_user . require_password_creation_for_git?
2017-09-10 17:25:29 +05:30
link_to s_ ( 'SetPasswordToCloneLink|set a password' ) , edit_profile_password_path
else
link_to s_ ( 'CreateTokenToCloneLink|create a personal access token' ) , profile_personal_access_tokens_path
end
end
# Returns true if any projects are present.
#
# If the relation has a LIMIT applied we'll cast the relation to an Array
# since repeated any? checks would otherwise result in multiple COUNT queries
# being executed.
#
# If no limit is applied we'll just issue a COUNT since the result set could
# be too large to load into memory.
def any_projects? ( projects )
return projects . any? if projects . is_a? ( Array )
if projects . limit_value
projects . to_a . any?
else
projects . except ( :offset ) . any?
end
end
2019-07-31 22:56:46 +05:30
# TODO: Remove this method when removing the feature flag
2019-12-04 20:38:33 +05:30
# https://gitlab.com/gitlab-org/gitlab/merge_requests/11209#note_162234863
2019-09-04 21:01:54 +05:30
# make sure to remove from the EE specific controller as well: ee/app/controllers/ee/dashboard/projects_controller.rb
2018-03-17 18:26:18 +05:30
def show_projects? ( projects , params )
2019-07-31 22:56:46 +05:30
Feature . enabled? ( :project_list_filter_bar ) || ! ! ( params [ :personal ] || params [ :name ] || any_projects? ( projects ) )
2017-08-17 22:00:37 +05:30
end
2018-03-27 19:54:05 +05:30
def push_to_create_project_command ( user = current_user )
repository_url =
if Gitlab :: CurrentSettings . current_application_settings . enabled_git_access_protocol == 'http'
user_url ( user )
else
Gitlab . config . gitlab_shell . ssh_path_prefix + user . username
end
" git push --set-upstream #{ repository_url } /$(git rev-parse --show-toplevel | xargs basename).git $(git rev-parse --abbrev-ref HEAD) "
end
2018-11-08 19:23:39 +05:30
def show_xcode_link? ( project = @project )
browser . platform . mac? && project . repository . xcode_project?
end
def xcode_uri_to_repo ( project = @project )
" xcode://clone?repo= #{ CGI . escape ( default_url_to_repo ( project ) ) } "
end
2020-06-23 00:09:42 +05:30
def link_to_filter_repo
link_to 'git filter-repo' , 'https://github.com/newren/git-filter-repo' , target : '_blank' , rel : 'noopener noreferrer'
2019-02-15 15:39:39 +05:30
end
def explore_projects_tab?
current_page? ( explore_projects_path ) ||
current_page? ( trending_explore_projects_path ) ||
current_page? ( starred_explore_projects_path )
end
def show_merge_request_count? ( disabled : false , compact_mode : false )
2020-05-24 23:13:21 +05:30
! disabled && ! compact_mode
2019-02-15 15:39:39 +05:30
end
def show_issue_count? ( disabled : false , compact_mode : false )
2020-05-24 23:13:21 +05:30
! disabled && ! compact_mode
2019-02-15 15:39:39 +05:30
end
# overridden in EE
def settings_operations_available?
can? ( current_user , :read_environment , @project )
end
2019-07-07 11:18:12 +05:30
def error_tracking_setting_project_json
setting = @project . error_tracking_setting
return if setting . blank? || setting . project_slug . blank? ||
setting . organization_slug . blank?
{
name : setting . project_name ,
organization_name : setting . organization_name ,
organization_slug : setting . organization_slug ,
slug : setting . project_slug
} . to_json
end
2019-07-31 22:56:46 +05:30
def directory?
@path . present?
end
2019-07-07 11:18:12 +05:30
def external_classification_label_help_message
default_label = :: Gitlab :: CurrentSettings . current_application_settings
. external_authorization_service_default_label
s_ (
" ExternalAuthorizationService|When no classification label is set the " \
" default label `%{default_label}` will be used. "
) % { default_label : default_label }
end
2019-09-04 21:01:54 +05:30
def can_import_members?
Ability . allowed? ( current_user , :admin_project_member , @project )
end
def project_can_be_shared?
! membership_locked? || @project . allowed_to_share_with_group?
end
def membership_locked?
false
end
def share_project_description ( project )
share_with_group = project . allowed_to_share_with_group?
share_with_members = ! membership_locked?
description =
if share_with_group && share_with_members
_ ( " You can invite a new member to <strong>%{project_name}</strong> or invite another group. " )
elsif share_with_group
_ ( " You can invite another group to <strong>%{project_name}</strong>. " )
elsif share_with_members
_ ( " You can invite a new member to <strong>%{project_name}</strong>. " )
end
description . html_safe % { project_name : project . name }
end
def metrics_external_dashboard_url
@project . metrics_setting_external_dashboard_url
end
2020-06-23 00:09:42 +05:30
def metrics_dashboard_timezone
@project . metrics_setting_dashboard_timezone
end
2019-12-21 20:55:43 +05:30
def grafana_integration_url
@project . grafana_integration & . grafana_url
end
2020-02-01 01:16:34 +05:30
def grafana_integration_masked_token
@project . grafana_integration & . masked_token
2019-12-21 20:55:43 +05:30
end
2019-12-26 22:10:19 +05:30
def grafana_integration_enabled?
@project . grafana_integration & . enabled?
end
2020-04-08 14:13:33 +05:30
def project_license_name ( project )
project . repository . license & . name
rescue GRPC :: Unavailable , GRPC :: DeadlineExceeded , Gitlab :: Git :: CommandError = > e
Gitlab :: ErrorTracking . track_exception ( e )
nil
end
2014-09-02 18:07:02 +05:30
private
def get_project_nav_tabs ( project , current_user )
2016-06-02 11:05:42 +05:30
nav_tabs = [ :home ]
2014-09-02 18:07:02 +05:30
2019-07-31 22:56:46 +05:30
unless project . empty_repo?
nav_tabs << [ :files , :commits , :network , :graphs , :forks ] if can? ( current_user , :download_code , project )
nav_tabs << :releases if can? ( current_user , :read_release , project )
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
if project . repo_exists? && can? ( current_user , :read_merge_request , project )
2014-09-02 18:07:02 +05:30
nav_tabs << :merge_requests
end
2016-06-02 11:05:42 +05:30
if Gitlab . config . registry . enabled && can? ( current_user , :read_container_image , project )
nav_tabs << :container_registry
end
2019-02-02 18:00:53 +05:30
# Pipelines feature is tied to presence of builds
if can? ( current_user , :read_build , project )
2017-09-10 17:25:29 +05:30
nav_tabs << :pipelines
end
2014-09-02 18:07:02 +05:30
2020-06-23 00:09:42 +05:30
if can_view_operations_tab? ( current_user , project )
2018-11-08 19:23:39 +05:30
nav_tabs << :operations
end
2020-03-13 15:44:24 +05:30
if can? ( current_user , :read_cycle_analytics , project )
nav_tabs << :cycle_analytics
end
2017-08-17 22:00:37 +05:30
tab_ability_map . each do | tab , ability |
if can? ( current_user , ability , project )
nav_tabs << tab
end
2015-04-26 12:48:37 +05:30
end
2019-02-02 18:00:53 +05:30
nav_tabs << external_nav_tabs ( project )
2014-09-02 18:07:02 +05:30
nav_tabs . flatten
end
2019-02-02 18:00:53 +05:30
def external_nav_tabs ( project )
[ ] . tap do | tabs |
tabs << :external_issue_tracker if project . external_issue_tracker
2019-02-15 15:39:39 +05:30
tabs << :external_wiki if project . external_wiki
2019-02-02 18:00:53 +05:30
end
end
2017-09-10 17:25:29 +05:30
def tab_ability_map
{
2020-06-23 00:09:42 +05:30
environments : :read_environment ,
metrics_dashboards : :metrics_dashboard ,
milestones : :read_milestone ,
snippets : :read_snippet ,
settings : :admin_project ,
builds : :read_build ,
clusters : :read_cluster ,
serverless : :read_cluster ,
error_tracking : :read_sentry_issue ,
alert_management : :read_alert_management_alert ,
labels : :read_label ,
issues : :read_issue ,
project_members : :read_project_member ,
wiki : :read_wiki
2017-09-10 17:25:29 +05:30
}
end
2020-06-23 00:09:42 +05:30
def can_view_operations_tab? ( current_user , project )
[ :read_environment , :read_cluster , :metrics_dashboard ] . any? do | ability |
can? ( current_user , ability , project )
end
end
2017-09-10 17:25:29 +05:30
def search_tab_ability_map
@search_tab_ability_map || = tab_ability_map . merge (
blobs : :download_code ,
commits : :download_code ,
merge_requests : :read_merge_request ,
2020-03-13 15:44:24 +05:30
notes : [ :read_merge_request , :download_code , :read_issue , :read_snippet ] ,
2019-07-07 11:18:12 +05:30
members : :read_project_member
2017-09-10 17:25:29 +05:30
)
end
2016-09-29 09:46:39 +05:30
def project_lfs_status ( project )
if project . lfs_enabled?
content_tag ( :span , class : 'lfs-enabled' ) do
2017-09-10 17:25:29 +05:30
s_ ( 'LFSStatus|Enabled' )
2016-09-29 09:46:39 +05:30
end
else
content_tag ( :span , class : 'lfs-disabled' ) do
2017-09-10 17:25:29 +05:30
s_ ( 'LFSStatus|Disabled' )
2016-09-29 09:46:39 +05:30
end
end
end
2014-09-02 18:07:02 +05:30
def git_user_name
if current_user
2018-03-17 18:26:18 +05:30
current_user . name . gsub ( '"' , '\"' )
2014-09-02 18:07:02 +05:30
else
2017-09-10 17:25:29 +05:30
_ ( " Your name " )
2014-09-02 18:07:02 +05:30
end
end
def git_user_email
if current_user
2019-12-04 20:38:33 +05:30
current_user . commit_email
2014-09-02 18:07:02 +05:30
else
" your@email.com "
end
end
2015-12-23 02:04:40 +05:30
def default_url_to_repo ( project = @project )
2016-06-02 11:05:42 +05:30
case default_clone_protocol
when 'ssh'
2015-12-23 02:04:40 +05:30
project . ssh_url_to_repo
else
2017-09-10 17:25:29 +05:30
project . http_url_to_repo
2015-12-23 02:04:40 +05:30
end
2014-09-02 18:07:02 +05:30
end
2018-11-20 20:47:30 +05:30
def default_clone_label
_ ( " Copy %{protocol} clone URL " ) % { protocol : default_clone_protocol . upcase }
end
2014-09-02 18:07:02 +05:30
def default_clone_protocol
2016-08-24 12:49:21 +05:30
if allowed_protocols_present?
enabled_protocol
2015-12-23 02:04:40 +05:30
else
2018-11-08 19:23:39 +05:30
extra_default_clone_protocol
end
end
def extra_default_clone_protocol
if ! current_user || current_user . require_ssh_key?
gitlab_config . protocol
else
'ssh'
2015-12-23 02:04:40 +05:30
end
2014-09-02 18:07:02 +05:30
end
2019-02-15 15:39:39 +05:30
def sidebar_operations_link_path ( project = @project )
metrics_project_environments_path ( project ) if can? ( current_user , :read_environment , project )
end
2014-09-02 18:07:02 +05:30
def project_last_activity ( project )
if project . last_activity_at
2015-09-11 14:41:01 +05:30
time_ago_with_tooltip ( project . last_activity_at , placement : 'bottom' , html_class : 'last_activity_time_ago' )
2014-09-02 18:07:02 +05:30
else
2017-09-10 17:25:29 +05:30
s_ ( " ProjectLastActivity|Never " )
2014-09-02 18:07:02 +05:30
end
end
2015-04-26 12:48:37 +05:30
def project_status_css_class ( status )
case status
when " started "
2018-11-08 19:23:39 +05:30
" table-active "
2015-04-26 12:48:37 +05:30
when " failed "
2018-11-08 19:23:39 +05:30
" table-danger "
2015-04-26 12:48:37 +05:30
when " finished "
2018-11-08 19:23:39 +05:30
" table-success "
2015-04-26 12:48:37 +05:30
end
end
2015-09-11 14:41:01 +05:30
def readme_cache_key
sha = @project . commit . try ( :sha ) || 'nil'
2017-09-10 17:25:29 +05:30
[ @project . full_path , sha , " readme " ] . join ( '-' )
2015-09-11 14:41:01 +05:30
end
2015-09-25 12:07:36 +05:30
def current_ref
@ref || @repository . try ( :root_ref )
end
2016-11-03 12:29:30 +05:30
def project_child_container_class ( view_path )
view_path == " projects/issues/issues " ? " prepend-top-default " : " project-show- #{ view_path } "
end
2017-08-17 22:00:37 +05:30
def project_issues ( project )
IssuesFinder . new ( current_user , project_id : project . id ) . execute
end
def restricted_levels
return [ ] if current_user . admin?
2018-03-17 18:26:18 +05:30
Gitlab :: CurrentSettings . restricted_visibility_levels || [ ]
end
def project_permissions_settings ( project )
feature = project . project_feature
{
visibilityLevel : project . visibility_level ,
requestAccessEnabled : ! ! project . request_access_enabled ,
issuesAccessLevel : feature . issues_access_level ,
repositoryAccessLevel : feature . repository_access_level ,
2020-03-13 15:44:24 +05:30
forkingAccessLevel : feature . forking_access_level ,
2018-03-17 18:26:18 +05:30
mergeRequestsAccessLevel : feature . merge_requests_access_level ,
buildsAccessLevel : feature . builds_access_level ,
wikiAccessLevel : feature . wiki_access_level ,
snippetsAccessLevel : feature . snippets_access_level ,
2018-12-05 23:21:45 +05:30
pagesAccessLevel : feature . pages_access_level ,
2018-03-17 18:26:18 +05:30
containerRegistryEnabled : ! ! project . container_registry_enabled ,
2019-10-12 21:52:04 +05:30
lfsEnabled : ! ! project . lfs_enabled ,
2020-05-24 23:13:21 +05:30
emailsDisabled : project . emails_disabled? ,
metricsDashboardAccessLevel : feature . metrics_dashboard_access_level ,
showDefaultAwardEmojis : project . show_default_award_emojis?
2018-03-17 18:26:18 +05:30
}
end
def project_permissions_panel_data ( project )
2018-11-20 20:47:30 +05:30
{
2018-03-17 18:26:18 +05:30
currentSettings : project_permissions_settings ( project ) ,
2019-10-12 21:52:04 +05:30
canDisableEmails : can_disable_emails? ( project , current_user ) ,
2018-03-17 18:26:18 +05:30
canChangeVisibilityLevel : can_change_visibility_level? ( project , current_user ) ,
allowedVisibilityOptions : project_allowed_visibility_levels ( project ) ,
visibilityHelpPath : help_page_path ( 'public_access/public_access' ) ,
registryAvailable : Gitlab . config . registry . enabled ,
2019-12-04 20:38:33 +05:30
registryHelpPath : help_page_path ( 'user/packages/container_registry/index' ) ,
2018-10-15 14:42:47 +05:30
lfsAvailable : Gitlab . config . lfs . enabled ,
2020-04-22 19:07:51 +05:30
lfsHelpPath : help_page_path ( 'topics/git/lfs/index' ) ,
lfsObjectsExist : project . lfs_objects . exists? ,
lfsObjectsRemovalHelpPath : help_page_path ( 'topics/git/lfs/index' , anchor : 'removing-objects-from-lfs' ) ,
2018-12-05 23:21:45 +05:30
pagesAvailable : Gitlab . config . pages . enabled ,
pagesAccessControlEnabled : Gitlab . config . pages . access_control ,
2020-03-13 15:44:24 +05:30
pagesAccessControlForced : :: Gitlab :: Pages . access_control_is_forced? ,
2019-12-21 20:55:43 +05:30
pagesHelpPath : help_page_path ( 'user/project/pages/introduction' , anchor : 'gitlab-pages-access-control-core' )
2018-03-17 18:26:18 +05:30
}
2018-11-20 20:47:30 +05:30
end
2018-03-17 18:26:18 +05:30
2018-11-20 20:47:30 +05:30
def project_permissions_panel_data_json ( project )
project_permissions_panel_data ( project ) . to_json . html_safe
2018-03-17 18:26:18 +05:30
end
def project_allowed_visibility_levels ( project )
Gitlab :: VisibilityLevel . values . select do | level |
project . visibility_level_allowed? ( level ) && ! restricted_levels . include? ( level )
end
2017-08-17 22:00:37 +05:30
end
2017-09-10 17:25:29 +05:30
def find_file_path
return unless @project && ! @project . empty_repo?
2020-05-01 12:34:13 +05:30
return unless can? ( current_user , :download_code , @project )
2017-09-10 17:25:29 +05:30
ref = @ref || @project . repository . root_ref
project_find_file_path ( @project , ref )
end
2018-03-27 19:54:05 +05:30
def can_show_last_commit_in_list? ( project )
can? ( current_user , :read_cross_project ) && project . commit
end
2018-05-09 12:01:36 +05:30
def pages_https_only_disabled?
! @project . pages_domains . all? ( & :https? )
end
def pages_https_only_title
return unless pages_https_only_disabled?
" You must enable HTTPS for all your domains first "
end
def pages_https_only_label_class
if pages_https_only_disabled?
" list-label disabled "
else
" list-label "
end
end
2018-11-08 19:23:39 +05:30
2019-10-12 21:52:04 +05:30
def filter_starrer_path ( options = { } )
options = params . slice ( :sort ) . merge ( options ) . permit!
" #{ request . path } ? #{ options . to_param } "
end
2018-11-08 19:23:39 +05:30
def sidebar_projects_paths
%w[
projects #show
projects #activity
2019-02-15 15:39:39 +05:30
releases #index
2018-11-08 19:23:39 +05:30
]
end
def sidebar_settings_paths
%w[
projects #edit
integrations #show
services #edit
2020-04-08 14:13:33 +05:30
hooks #index
hooks #edit
2020-05-24 23:13:21 +05:30
access_tokens #index
2020-04-08 14:13:33 +05:30
hook_logs #show
2018-11-08 19:23:39 +05:30
repository #show
ci_cd #show
2019-02-15 15:39:39 +05:30
operations #show
2018-11-08 19:23:39 +05:30
badges #index
pages #show
]
end
def sidebar_repository_paths
%w[
tree
blob
blame
edit_tree
new_tree
find_file
commit
commits
compare
projects / repositories
tags
branches
graphs
network
]
end
2018-12-13 13:39:08 +05:30
def sidebar_operations_paths
%w[
environments
clusters
2019-02-15 15:39:39 +05:30
functions
error_tracking
2020-05-24 23:13:21 +05:30
alert_management
2018-12-13 13:39:08 +05:30
user
gcp
2020-01-01 13:55:28 +05:30
logs
2018-12-13 13:39:08 +05:30
]
end
2019-02-15 15:39:39 +05:30
def user_can_see_auto_devops_implicitly_enabled_banner? ( project , user )
Ability . allowed? ( user , :admin_project , project ) &&
project . has_auto_devops_implicitly_enabled? &&
project . builds_enabled? &&
! project . repository . gitlab_ci_yml
end
2019-09-04 21:01:54 +05:30
def vue_file_list_enabled?
2020-03-13 15:44:24 +05:30
Feature . enabled? ( :vue_file_list , @project , default_enabled : true )
end
def native_code_navigation_enabled? ( project )
2020-06-23 00:09:42 +05:30
Feature . enabled? ( :code_navigation , project , default_enabled : true )
2019-09-04 21:01:54 +05:30
end
2020-01-01 13:55:28 +05:30
def show_visibility_confirm_modal? ( project )
project . unlink_forks_upon_visibility_decrease_enabled? && project . visibility_level > Gitlab :: VisibilityLevel :: PRIVATE && project . forks_count > 0
end
2020-03-13 15:44:24 +05:30
def settings_container_registry_expiration_policy_available? ( project )
Gitlab . config . registry . enabled &&
can? ( current_user , :destroy_container_image , project )
end
2020-05-24 23:13:21 +05:30
def project_access_token_available? ( project )
return false if :: Gitlab . com?
:: Feature . enabled? ( :resource_access_token , project )
end
2014-09-02 18:07:02 +05:30
end
2020-04-22 19:07:51 +05:30
ProjectsHelper . prepend_if_ee ( 'EE::ProjectsHelper' )