OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/app/services/scm/checkout_instructions_servi...

158 lines
4.9 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is a project management system.
# Copyright (C) 2012-2017 the OpenProject Foundation (OPF)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2017 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
##
# Implements a repository service for building checkout instructions if supported
class Scm::CheckoutInstructionsService
attr_reader :repository, :user, :path
def initialize(repository, path: nil, user: User.current)
@repository = repository
@user = user
@path = path
end
##
# Retrieve the checkout URL using the repository vendor information
# It may additionally set a path parameter, if the repository supports subtree checkout
def checkout_url(with_path = false)
repository.scm.checkout_url(repository,
checkout_base_url,
with_path ? URI.escape(@path) : nil)
end
##
# Returns the checkout command from SCM adapter
# (e.g., `git clone`)
def checkout_command
repository.scm.checkout_command
end
##
# Returns the checkout base URL as defined in settings.
def checkout_base_url
checkout_settings['base_url']
end
##
# Returns the instructions defined in the settings.
def instructions
checkout_settings['text'].presence ||
I18n.t("repositories.checkout.default_instructions.#{repository.vendor}")
end
##
# Returns true when the checkout URL may target a subtree of the repository.
def subtree_checkout?
repository.scm.subtree_checkout?
end
##
# Determines whether the checkout URL may be built, i.e. all information is available
# This is the case when the base_url is set or the vendor doesn't use base URLs.
def checkout_url_buildable?
!repository.class.requires_checkout_base_url? || checkout_base_url.present?
end
##
# Returns whether the repository supports showing checkout information
# and has been configured for it.
def available?
checkout_enabled? &&
repository.supports_checkout_info? &&
checkout_url_buildable?
end
def checkout_enabled?
checkout_settings['enabled'].to_i > 0
end
def supported_but_not_enabled?
repository.supports_checkout_info? && !checkout_enabled?
end
##
# Determines whether permissions for the given repository
# are available.
def manages_permissions?
repository.managed?
end
##
# Returns one of the following permission symbols for the given user
#
# - :readwrite: When user is allowed to read and commit (:commit_access)
# - :read: When user is allowed to checkout the repository, but not commit (:browse_repository)
# - :none: Otherwise
#
# Note that this information is only applicable when the repository is managed,
# because otherwise OpenProject does not control the repository permissions.
# Use +manages_permissions?+ to check whether this is the case.
#
def permission
project = repository.project
if user.allowed_to?(:commit_access, project)
:readwrite
elsif user.allowed_to?(:browse_repository, project)
:read
else
:none
end
end
##
# Returns whether the given user may checkout the repository
#
# Note that this information is only applicable when the repository is managed,
# because otherwise OpenProject does not control the repository permissions.
# Use +manages_permissions?+ to check whether this is the case.
def may_checkout?
[:readwrite, :read].include?(permission)
end
##
# Returns whether the given user may commit to the repository
#
# Note that this information is only applicable when the repository is managed,
# because otherwise OpenProject does not control the repository permissions.
# Use +manages_permissions?+ to check whether this is the case.
def may_commit?
permission == :readwrite
end
private
def checkout_settings
@settings ||= begin
hash = Setting.repository_checkout_data[repository.vendor.to_s]
hash.presence || {}
end
end
end