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/lib/open_project/scm/manageable_repository.rb

138 lines
4.3 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is an open source project management software.
# Copyright (C) 2012-2021 the OpenProject GmbH
#
# 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-2013 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 COPYRIGHT and LICENSE files for more details.
#++
module OpenProject
module SCM
module ManageableRepository
def self.included(base)
base.extend(ClassMethods)
##
# Take note when projects are renamed and check for associated managed repositories
OpenProject::Notifications.subscribe('project_renamed') do |payload|
repository = payload[:project].repository
if repository&.managed?
::SCM::RelocateRepositoryJob.perform_later(repository)
end
end
end
module ClassMethods
##
# We let SCM vendor implementation define their own
# types (e.g., for differences in the management of
# local vs. remote repositories).
#
# But if they are manageable by OpenProject, they must
# expose this type through +available_types+.
def managed_type
:managed
end
##
# Reads from configuration whether new repositories of this kind
# may be managed from OpenProject.
def manageable?
!(disabled_types.include?(managed_type) || managed_root.nil?)
end
##
# Returns the managed root for this repository vendor
def managed_root
scm_config[:manages]
end
##
# Returns the managed remote for this repository vendor,
# if any. Use +manages_remote?+ to determine whether the configuration
# specifies local or remote managed repositories.
def managed_remote
URI.parse(scm_config[:manages])
rescue URI::Error
nil
end
##
# Returns whether the managed root is a remote URL to post to
def manages_remote?
managed_remote.present? && managed_remote.absolute?
end
end
def manageable?
self.class.manageable?
end
##
# Determines whether this repository IS currently managed
# by openproject
def managed?
scm_type.to_sym == self.class.managed_type
end
##
# Allows descendants to perform actions
# with the given repository after the managed
# repository has been written to file system.
def managed_repo_created(_args)
nil
end
##
# Returns the absolute path to the repository
# under the +managed_root+ path defined in the configuration
# of this adapter.
# Used only in the creation of a repository, at a later point
# in time, it is referred to in the root_url
def managed_repository_path
File.join(self.class.managed_root, repository_identifier)
end
##
# Returns the access url to the repository
# May be overridden by descendants
# Used only in the creation of a repository, at a later point
# in time, it is referred to in the url
def managed_repository_url
"file://#{managed_repository_path}"
end
##
# Repository relative path from scm managed root.
# Will be overridden by including models to, e.g.,
# append '.git' to that path.
def repository_identifier
project.identifier
end
end
end
end