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 )
2020-11-24 15:15:51 +05:30
link_to namespace_project_path ( namespace_id : project . namespace , id : project ) , title : h ( project . name ) , class : 'gl-link' 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 = { } )
2021-11-18 22:05:49 +05:30
default_opts = { size : 16 }
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
2021-11-18 22:05:49 +05:30
image_tag ( avatar , width : opts [ :size ] , class : classes , alt : '' )
2018-03-17 18:26:18 +05:30
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 )
2021-01-29 00:20:46 +05:30
namespace_link = build_namespace_breadcrumb_link ( project )
project_link = build_project_breadcrumb_link ( project )
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 )
2020-10-24 23:57:45 +05:30
_ ( " You are going to delete %{project_full_name}. Deleted projects CANNOT be restored! Are you ABSOLUTELY sure? " ) %
2018-03-27 19:54:05 +05:30
{ 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 )
2020-11-24 15:15:51 +05:30
_ ( " You are going to transfer %{project_full_name} to another namespace. Are you ABSOLUTELY sure? " ) %
2018-03-27 19:54:05 +05:30
{ 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
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
2015-09-11 14:41:01 +05:30
def can_change_visibility_level? ( project , current_user )
2021-03-08 18:12:59 +05:30
can? ( current_user , :change_visibility_level , project )
2015-09-11 14:41:01 +05:30
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
2020-07-28 23:09:34 +05:30
link_to _ ( 'About auto deploy' ) , help_page_path ( 'topics/autodevops/stages.md' , anchor : 'auto-deploy' ) , target : '_blank'
2017-08-17 22:00:37 +05:30
end
def autodeploy_flash_notice ( branch_name )
2020-10-24 23:57:45 +05:30
html_escape ( _ ( " Branch %{branch_name} was created. To set up auto deploy, choose a GitLab CI Yaml template and commit your changes. %{link_to_autodeploy_doc} " ) ) %
{ branch_name : tag . strong ( truncate ( sanitize ( branch_name ) ) ) , link_to_autodeploy_doc : link_to_autodeploy_doc }
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
2021-12-11 22:18:48 +05:30
def no_password_message
push_pull_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">' . html_safe % { url : help_page_path ( 'gitlab-basics/start-using-git' , anchor : 'pull-and-push' ) }
clone_with_https_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">' . html_safe % { url : help_page_path ( 'gitlab-basics/start-using-git' , anchor : 'clone-with-https' ) }
set_password_link_start = '<a href="%{url}">' . html_safe % { url : edit_profile_password_path }
set_up_pat_link_start = '<a href="%{url}">' . html_safe % { url : profile_personal_access_tokens_path }
message = if current_user . require_password_creation_for_git?
_ ( 'Your account is authenticated with SSO or SAML. To %{push_pull_link_start}push and pull%{link_end} over %{protocol} with Git using this account, you must %{set_password_link_start}set a password%{link_end} or %{set_up_pat_link_start}set up a Personal Access Token%{link_end} to use instead of a password. For more information, see %{clone_with_https_link_start}Clone with HTTPS%{link_end}.' )
else
_ ( 'Your account is authenticated with SSO or SAML. To %{push_pull_link_start}push and pull%{link_end} over %{protocol} with Git using this account, you must %{set_up_pat_link_start}set up a Personal Access Token%{link_end} to use instead of a password. For more information, see %{clone_with_https_link_start}Clone with HTTPS%{link_end}.' )
end
html_escape ( message ) % {
push_pull_link_start : push_pull_link_start ,
protocol : gitlab_config . protocol . upcase ,
clone_with_https_link_start : clone_with_https_link_start ,
set_password_link_start : set_password_link_start ,
set_up_pat_link_start : set_up_pat_link_start ,
link_end : '</a>' . html_safe
}
2017-09-10 17:25:29 +05:30
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
2019-02-15 15:39:39 +05:30
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
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
2021-10-27 15:23:28 +05:30
def can_admin_project_member? ( project )
Ability . allowed? ( current_user , :admin_project_member , project ) && ! membership_locked?
2019-09-04 21:01:54 +05:30
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
2020-10-24 23:57:45 +05:30
_ ( " You can invite a new member to %{project_name} or invite another group. " )
2019-09-04 21:01:54 +05:30
elsif share_with_group
2020-10-24 23:57:45 +05:30
_ ( " You can invite another group to %{project_name}. " )
2019-09-04 21:01:54 +05:30
elsif share_with_members
2020-10-24 23:57:45 +05:30
_ ( " You can invite a new member to %{project_name}. " )
2019-09-04 21:01:54 +05:30
end
2020-10-24 23:57:45 +05:30
html_escape ( description ) % { project_name : tag . strong ( project . name ) }
2019-09-04 21:01:54 +05:30
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 )
2020-07-28 23:09:34 +05:30
key = " project: #{ project . id } :license_name "
Gitlab :: SafeRequestStore . fetch ( key ) { project . repository . license & . name }
2020-04-08 14:13:33 +05:30
rescue GRPC :: Unavailable , GRPC :: DeadlineExceeded , Gitlab :: Git :: CommandError = > e
Gitlab :: ErrorTracking . track_exception ( e )
2020-07-28 23:09:34 +05:30
Gitlab :: SafeRequestStore [ key ] = nil
2020-04-08 14:13:33 +05:30
nil
end
2021-09-30 23:02:18 +05:30
def show_terraform_banner? ( project )
2021-11-18 22:05:49 +05:30
Feature . enabled? ( :show_terraform_banner , type : :ops , default_enabled : true ) && project . repository_languages . with_programming_language ( 'HCL' ) . exists? && project . terraform_states . empty?
2021-09-30 23:02:18 +05:30
end
2021-10-27 15:23:28 +05:30
def project_permissions_panel_data ( project )
{
packagesAvailable : :: Gitlab . config . packages . enabled ,
packagesHelpPath : help_page_path ( 'user/packages/index' ) ,
currentSettings : project_permissions_settings ( project ) ,
canDisableEmails : can_disable_emails? ( project , current_user ) ,
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 ,
registryHelpPath : help_page_path ( 'user/packages/container_registry/index' ) ,
lfsAvailable : Gitlab . config . lfs . enabled ,
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' ) ,
pagesAvailable : Gitlab . config . pages . enabled ,
pagesAccessControlEnabled : Gitlab . config . pages . access_control ,
pagesAccessControlForced : :: Gitlab :: Pages . access_control_is_forced? ,
pagesHelpPath : help_page_path ( 'user/project/pages/introduction' , anchor : 'gitlab-pages-access-control' ) ,
issuesHelpPath : help_page_path ( 'user/project/issues/index' )
}
end
2021-10-29 20:43:33 +05:30
def project_classes ( project )
return " project-highlight-puc " if project . warn_about_potentially_unwanted_characters?
" "
end
2021-12-11 22:18:48 +05:30
# Returns the confirm phrase the user needs to type in order to delete the project
#
# Thus the phrase should include the namespace to make it very clear to the
# user which project is subject to deletion.
# Relevant issue: https://gitlab.com/gitlab-org/gitlab/-/issues/343591
def delete_confirm_phrase ( project )
project . path_with_namespace
end
2014-09-02 18:07:02 +05:30
private
2017-09-10 17:25:29 +05:30
def tab_ability_map
{
2020-07-28 23:09:34 +05:30
cycle_analytics : :read_cycle_analytics ,
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 ,
2021-01-29 00:20:46 +05:30
terraform : :read_terraform_state ,
2020-06-23 00:09:42 +05:30
error_tracking : :read_sentry_issue ,
alert_management : :read_alert_management_alert ,
2021-01-03 14:25:43 +05:30
incidents : :read_issue ,
2020-06-23 00:09:42 +05:30
labels : :read_label ,
issues : :read_issue ,
project_members : :read_project_member ,
2021-01-03 14:25:43 +05:30
wiki : :read_wiki ,
2021-02-22 17:27:13 +05:30
feature_flags : :read_feature_flag ,
analytics : :read_analytics
2017-09-10 17:25:29 +05:30
}
end
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
2021-11-11 11:23:49 +05:30
current_user . commit_email_or_default
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
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 )
2020-07-28 23:09:34 +05:30
view_path == " projects/issues/issues " ? " gl-mt-3 " : " project-show- #{ view_path } "
2016-11-03 12:29:30 +05:30
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
{
2020-10-24 23:57:45 +05:30
packagesEnabled : ! ! project . packages_enabled ,
2018-03-17 18:26:18 +05:30
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 ,
2021-02-22 17:27:13 +05:30
analyticsAccessLevel : feature . analytics_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 ,
2021-02-22 17:27:13 +05:30
operationsAccessLevel : feature . operations_access_level ,
showDefaultAwardEmojis : project . show_default_award_emojis? ,
2021-10-29 20:43:33 +05:30
warnAboutPotentiallyUnwantedCharacters : project . warn_about_potentially_unwanted_characters? ,
2021-10-27 15:23:28 +05:30
securityAndComplianceAccessLevel : project . security_and_compliance_access_level ,
containerRegistryAccessLevel : feature . container_registry_access_level
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-12-13 13:39:08 +05:30
def sidebar_operations_paths
%w[
environments
clusters
2021-12-11 22:18:48 +05:30
cluster_agents
2019-02-15 15:39:39 +05:30
functions
error_tracking
2020-05-24 23:13:21 +05:30
alert_management
2020-10-24 23:57:45 +05:30
incidents
incident_management
2018-12-13 13:39:08 +05:30
user
gcp
2020-01-01 13:55:28 +05:30
logs
2020-10-24 23:57:45 +05:30
product_analytics
metrics_dashboard
2021-01-03 14:25:43 +05:30
feature_flags
tracings
2021-01-29 00:20:46 +05:30
terraform
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
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
2021-01-29 00:20:46 +05:30
def build_project_breadcrumb_link ( project )
project_name = simple_sanitize ( project . name )
push_to_schema_breadcrumb ( project_name , project_path ( project ) )
link_to project_path ( project ) do
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 " , project_name , class : " breadcrumb-item-text js-breadcrumb-item-text " ) ] . join . html_safe
end
end
def build_namespace_breadcrumb_link ( project )
if project . group
group_title ( project . group , nil , nil )
else
owner = project . namespace . owner
name = simple_sanitize ( owner . name )
url = user_path ( owner )
push_to_schema_breadcrumb ( name , url )
link_to ( name , url )
end
end
2014-09-02 18:07:02 +05:30
end
2020-04-22 19:07:51 +05:30
2021-06-08 01:23:25 +05:30
ProjectsHelper . prepend_mod_with ( 'ProjectsHelper' )