Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Debian support on RMT #1078

Merged
merged 53 commits into from
Apr 10, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
75d33f6
WIP: Add ssl parsing config keys
ngetahun Dec 14, 2023
2d4fe72
Revert "Revert "[1/x] Prepare code sprint and implement repository ty…
felixsch Jan 4, 2024
f1a77ba
WIP: Refactoring mirroring and add debian mirror class
ngetahun Dec 20, 2023
7a3f173
Added more tests for base mirroing class
felixsch Dec 21, 2023
f512b7f
Parse debian release file
likhitha77 Dec 21, 2023
1cf3929
Refactor GPG check and implement debian metadata mirroring
likhitha77 Dec 22, 2023
ec07a7a
Rubocop and minor test fixes
likhitha77 Dec 22, 2023
9745871
WIP: Refactoring mirroring and add debian mirror class
ngetahun Dec 20, 2023
c92a70d
Added more tests for base mirroing class
felixsch Dec 21, 2023
20b3bdf
Parse debian release file
likhitha77 Dec 21, 2023
c1ebdfc
Refactor GPG check and implement debian metadata mirroring
likhitha77 Dec 22, 2023
6b1636e
Rubocop and minor test fixes
likhitha77 Dec 22, 2023
5392c52
Parse package list files
felixsch Dec 27, 2023
e7f25f7
Debian package deduplication check + refactor FileReference
likhitha77 Dec 28, 2023
8825c33
Moving Debian files to correct location from temp dir
likhitha77 Dec 28, 2023
e8012bb
minor spec fix
likhitha77 Dec 28, 2023
fd0b606
Finalize tests and make rubocop happy :>
felixsch Dec 28, 2023
b9aecd6
Adding tests to improve coverage
likhitha77 Jan 8, 2024
f9426a4
Refactoring: Moved suma product tree mirroring into a separate class
ngetahun Jan 2, 2024
30a31fa
Rerfactor suma product tree mirroring in repomd and mirror classes
ngetahun Jan 2, 2024
b737406
Fix broken specs
ngetahun Jan 3, 2024
906dcfb
refactor repomd mirror
ngetahun Jan 3, 2024
1512346
Complete remaining license mirror specs
ngetahun Jan 5, 2024
fcda31f
Cleanup files
ngetahun Jan 5, 2024
d584789
Refactor repomd mirror_metadata
likhitha77 Jan 8, 2024
d86a37a
Cleanup + rubocop
likhitha77 Jan 8, 2024
2cb4267
Added specs for parse_packages_metadata
ngetahun Jan 8, 2024
e982e9f
Refactor Mirror::Repomd package mirroring
lcaparroz Jan 9, 2024
763fcd2
Remove obsolete VCR files
ngetahun Jan 9, 2024
7a0b2f6
Implements RMT::Mirror repository mirroring
lcaparroz Jan 9, 2024
f81c7be
Remove unused config option verify_rpm_checksums
felixsch Jan 10, 2024
5108f36
Cleanup tests in cli/mirror and started refreshing import/export
felixsch Jan 11, 2024
f2274f9
Export now is using the new mirroring classes.
felixsch Jan 11, 2024
21999d2
Make import logic use our new implemenations
felixsch Jan 11, 2024
df66d1a
Cleanup naming, adding missing tests, fix renames
felixsch Jan 11, 2024
3b48f94
Fixing updates.license issue
likhitha77 Jan 12, 2024
13949f5
Adding tests for cli/base
likhitha77 Jan 15, 2024
64fee8f
Extend mirroring test to authorized repositories
ngetahun Jan 15, 2024
55c8fb4
Removing repomd from rubocop exceptions
likhitha77 Jan 15, 2024
ceb41b1
Mirroring nested debian repos
likhitha77 Jan 16, 2024
c700742
Improve log messages
ngetahun Jan 17, 2024
a934cec
I'm a not working commit!
felixsch Jan 18, 2024
796eb01
Fix cache_dir for nested Debian repos
lcaparroz Jan 18, 2024
b1ff16d
Update changelog and version
ngetahun Jan 29, 2024
8aa785a
Fixed linting and added comments
felixsch Jan 30, 2024
0c765a3
Remove SSL mariadb connection options
felixsch Jan 31, 2024
c92bc00
Fix regex issue, require Packages.gz files when downloading
ngetahun Jan 31, 2024
9d22217
Revert converage filtering
ngetahun Feb 7, 2024
88a8817
Cleanup unmerged config changes
ngetahun Apr 2, 2024
e326e83
Switch to repomd_parser 1.1.0 interface
felixsch Apr 10, 2024
a6a45af
Remove superflous imports from lib/rmt/mirror/repomd.rb
felixsch Apr 10, 2024
5c5ce99
Merge branch 'master' into rmt_deb_codesprint
felixsch Apr 10, 2024
55d4d84
Merge pull request #1117 from SUSE/fix-redefinition-warnings
mssola Apr 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions .rubocop.yml
Original file line number Diff line number Diff line change
Expand Up @@ -50,3 +50,11 @@ Style/OpenStructUse:

RSpec/MessageChain:
Enabled: false

# We disable this check since we are stubing class methods
# that are already tested in their respective tests.
# This way we circumvent tight coupling between tests and
# implementation.
# Count: 107 offenses
RSpec/SubjectStub:
Enabled: false
14 changes: 0 additions & 14 deletions .rubocop_todo.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ Layout/ArgumentAlignment:
- 'app/models/product.rb'
- 'engines/instance_verification/spec/requests/api/connect/v3/systems/products_controller_spec.rb'
- 'spec/factories/products.rb'
- 'spec/lib/rmt/mirror_spec.rb'
- 'spec/models/migration_engine_spec.rb'

# Offense count: 3
Expand All @@ -40,7 +39,6 @@ Layout/EmptyLineAfterGuardClause:
- 'lib/rmt/cli/repos_custom.rb'
- 'lib/rmt/cli/smt_importer.rb'
- 'lib/rmt/fiber_request.rb'
- 'spec/lib/rmt/mirror_spec.rb'

# Offense count: 2
# Cop supports --auto-correct.
Expand Down Expand Up @@ -102,7 +100,6 @@ Layout/LineEndStringConcatenationIndentation:
# Cop supports --auto-correct.
Lint/AmbiguousOperatorPrecedence:
Exclude:
- 'lib/rmt/cli/mirror.rb'
- 'lib/rmt/cli/products.rb'
- 'lib/rmt/cli/repos.rb'
- 'lib/rmt/cli/repos_custom.rb'
Expand Down Expand Up @@ -241,15 +238,13 @@ Performance/RegexpMatch:
- 'engines/registration_sharing/lib/registration_sharing.rb'
- 'engines/strict_authentication/app/controllers/strict_authentication/authentication_controller.rb'
- 'lib/rmt/cli/base.rb'
- 'spec/lib/rmt/mirror_spec.rb'

# Offense count: 4
# Cop supports --auto-correct.
# Configuration parameters: AutoCorrect.
Performance/StringInclude:
Exclude:
- 'engines/strict_authentication/app/controllers/strict_authentication/authentication_controller.rb'
- 'spec/lib/rmt/mirror_spec.rb'

# Offense count: 167
# Configuration parameters: Prefixes.
Expand Down Expand Up @@ -279,7 +274,6 @@ RSpec/EmptyLineAfterHook:
- 'engines/strict_authentication/spec/requests/services_controller_spec.rb'
- 'engines/strict_authentication/spec/requests/strict_authentication/authentication_controller_spec.rb'
- 'spec/lib/rmt/config_spec.rb'
- 'spec/lib/rmt/mirror_spec.rb'
- 'spec/models/product_spec.rb'
- 'spec/requests/api/connect/v3/subscriptions/systems_controller_spec.rb'
- 'spec/requests/api/connect/v3/systems/activations_controller_spec.rb'
Expand Down Expand Up @@ -321,7 +315,6 @@ RSpec/ExpectInHook:
- 'spec/lib/rmt/cli/main_spec.rb'
- 'spec/lib/rmt/cli/repos_custom_spec.rb'
- 'spec/lib/rmt/cli/repos_spec.rb'
- 'spec/lib/rmt/mirror_spec.rb'
- 'spec/lib/rmt/scc_spec.rb'

# Offense count: 3
Expand Down Expand Up @@ -358,11 +351,6 @@ RSpec/ImplicitSubject:
- 'spec/models/migration_engine_spec.rb'
- 'spec/models/product_spec.rb'

# Offense count: 34
# Configuration parameters: AssignmentOnly.
RSpec/InstanceVariable:
Exclude:
- 'spec/lib/rmt/mirror_spec.rb'

# Offense count: 1
RSpec/IteratedExpectation:
Expand Down Expand Up @@ -430,7 +418,6 @@ RSpec/Rails/HttpStatus:
RSpec/ReceiveCounts:
Exclude:
- 'spec/lib/rmt/lockfile_spec.rb'
- 'spec/lib/rmt/mirror_spec.rb'
- 'spec/suse/connect/api_spec.rb'

# Offense count: 3
Expand All @@ -454,7 +441,6 @@ RSpec/StubbedMock:
- 'spec/lib/rmt/cli/main_spec.rb'
- 'spec/lib/rmt/cli/smt_importer_spec.rb'
- 'spec/lib/rmt/cli/systems_spec.rb'
- 'spec/lib/rmt/mirror_spec.rb'
- 'spec/lib/rmt/scc_spec.rb'
- 'spec/support/shared_examples/cli.rb'
- 'spec/suse/connect/api_spec.rb'
Expand Down
1 change: 0 additions & 1 deletion config/rmt.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ scc:

mirroring:
mirror_src: false
verify_rpm_checksums: false
dedup_method: hardlink

http_client:
Expand Down
2 changes: 1 addition & 1 deletion lib/rmt.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
module RMT
VERSION ||= '2.15'.freeze
VERSION ||= '2.16'.freeze

DEFAULT_USER = '_rmt'.freeze
DEFAULT_GROUP = 'nginx'.freeze
Expand Down
4 changes: 2 additions & 2 deletions lib/rmt/cli/base.rb
Original file line number Diff line number Diff line change
Expand Up @@ -117,8 +117,6 @@ def logger
@logger
end

private

def needs_path(path, writable: false)
# expand the path to make it easier to work with
path = File.expand_path(path)
Expand All @@ -137,6 +135,8 @@ def needs_path(path, writable: false)
path
end

private

# Allows to have any type of multi input that you want:
#
# 1575 (alone)
Expand Down
24 changes: 14 additions & 10 deletions lib/rmt/cli/export.rb
Original file line number Diff line number Diff line change
Expand Up @@ -29,26 +29,30 @@ def settings(path)
REPOS
def repos(path)
path = needs_path(path, writable: true)

mirror = RMT::Mirror.new(mirroring_base_dir: path, logger: logger, airgap_mode: true)
suma_product_tree = RMT::Mirror::SumaProductTree.new(mirroring_base_dir: path, logger: logger)

begin
mirror.mirror_suma_product_tree(repository_url: 'https://scc.suse.com/suma/')
suma_product_tree.mirror
rescue RMT::Mirror::Exception => e
logger.warn(e.message)
logger.warn(_('Exporting SUSE Manager product tree failed: %{error_message}') % { error_message: e.message })
end

repos_file = File.join(path, 'repos.json')
raise RMT::CLI::Error.new(_('%{file} does not exist.') % { file: repos_file }) unless File.exist?(repos_file)

repos = JSON.parse(File.read(repos_file))
repos.each do |repo|
repos.each do |repo_json|
repo = Repository.find_by(external_url: repo_json['url'])

begin
mirror.mirror(
repository_url: repo['url'],
local_path: Repository.make_local_path(repo['url']),
auth_token: repo['auth_token']
)
configuration = {
repository: repo,
logger: logger,
mirroring_base_dir: path,
mirror_sources: RMT::Config.mirror_src_files?,
is_airgapped: true
}
RMT::Mirror.new(**configuration).mirror_now
rescue RMT::Mirror::Exception => e
warn e.to_s
end
Expand Down
37 changes: 24 additions & 13 deletions lib/rmt/cli/import.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,23 +12,26 @@ def data(path)
def repos(path)
RMT::Lockfile.lock do
path = needs_path(path)

mirror = RMT::Mirror.new(logger: logger, airgap_mode: true)

repos_file = File.join(path, 'repos.json')

raise RMT::CLI::Error.new(_('%{file} does not exist.') % { file: repos_file }) unless File.exist?(repos_file)

begin
exported_suma_path = File.join(path, '/suma/')
suma_repo_url = URI.join('file://', exported_suma_path).to_s
mirror.mirror_suma_product_tree(repository_url: suma_repo_url)
suma_repo_url = URI.join('file://', File.join(path, '/suma/')).to_s

RMT::Mirror::SumaProductTree.new(
mirroring_base_dir: RMT::DEFAULT_MIRROR_DIR,
logger: logger,
url: suma_repo_url
).mirror
rescue RMT::Mirror::Exception => e
logger.warn(e.message)
logger.warn(_('Importing suma product tree failed: %{error_message}') % { error_message: e.message })
end

repos = JSON.parse(File.read(repos_file))
repos.each do |repo_json|
repo = Repository.find_by(external_url: repo_json['url'])

if repo.nil?
warn _('repository by URL %{url} does not exist in database') % { url: repo_json['url'] }
next
Expand All @@ -37,12 +40,20 @@ def repos(path)
begin
exported_repo_path = File.join(path, Repository.make_local_path(repo_json['url']))
repo_url = URI.join('file://', exported_repo_path).to_s
mirror.mirror(
repository_url: repo_url,
local_path: Repository.make_local_path(repo.external_url),
auth_token: repo.auth_token,
repo_name: repo.name
)

# We temporary alter the external_url to point to files on this. This is
# a bit of a hack to make sure we import from the disk rather the a real
# remote origin
repo.external_url = repo_url

configuration = {
repository: repo,
logger: logger,
mirroring_base_dir: RMT::DEFAULT_MIRROR_DIR,
mirror_sources: RMT::Config.mirror_src_files?,
is_airgapped: true
}
RMT::Mirror.new(**configuration).mirror_now

repo.refresh_timestamp!
rescue RMT::Mirror::Exception => e
Expand Down
48 changes: 26 additions & 22 deletions lib/rmt/cli/mirror.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,12 @@ class RMT::CLI::Mirror < RMT::CLI::Base
def all
RMT::Lockfile.lock('mirror') do
begin
mirror.mirror_suma_product_tree(repository_url: 'https://scc.suse.com/suma/')
suma_product_tree.mirror
rescue RMT::Mirror::Exception => e
errors << _('Mirroring SUMA product tree failed: %{error_message}') % { error_message: e.message }
errors << (_('Mirroring SUMA product tree failed: %{error_message}') % { error_message: e.message })
end


raise RMT::CLI::Error.new(_('There are no repositories marked for mirroring.')) if Repository.only_mirroring_enabled.empty?

# The set of repositories to be mirrored can change while the command is
Expand All @@ -19,7 +20,7 @@ def all
# could lead to different Repositories sets where it's used.
mirrored_repo_ids = []
until (repos = Repository.only_mirroring_enabled.where.not(id: mirrored_repo_ids).load).empty?
mirror_repos!(repos)
mirror_repositories!(repos)
mirrored_repo_ids.concat(repos.pluck(:id))
end

Expand All @@ -39,11 +40,11 @@ def repository(*ids)
repos = ids.map do |id|
repo = Repository.find_by(friendly_id: id)
errored_repos_id << id if options[:do_not_raise_unpublished] && repo.nil?
errors << _('Repository with ID %{repo_id} not found') % { repo_id: id } if repo.nil?
errors << (_('Repository with ID %{repo_id} not found') % { repo_id: id }) if repo.nil?
repo
end

mirror_repos!(repos)
mirror_repositories!(repos)
finish_execution
end
end
Expand All @@ -57,29 +58,29 @@ def product(*targets)
repos = []
targets.each do |target|
products = Product.get_by_target!(target)
errors << _('Product for target %{target} not found') % { target: target } if products.empty?
errors << (_('Product for target %{target} not found') % { target: target }) if products.empty?
products.each do |product|
product_repos = product.repositories.only_mirroring_enabled
if product_repos.empty?
errors << _('Product %{target} has no repositories enabled') % { target: target }
errors << (_('Product %{target} has no repositories enabled') % { target: target })
errored_products_id << target if options[:do_not_raise_unpublished]
end
repos += product_repos.to_a
end
rescue ActiveRecord::RecordNotFound
errors << _('Product with ID %{target} not found') % { target: target }
errors << (_('Product with ID %{target} not found') % { target: target })
errored_products_id << target if options[:do_not_raise_unpublished]
end

mirror_repos!(repos)
mirror_repositories!(repos)
finish_execution
end
end

protected
private

def mirror
@mirror ||= RMT::Mirror.new(logger: logger, mirror_src: RMT::Config.mirror_src_files?)
def suma_product_tree
RMT::Mirror::SumaProductTree.new(logger: logger, mirroring_base_dir: RMT::DEFAULT_MIRROR_DIR)
end

def errors
Expand Down Expand Up @@ -123,24 +124,27 @@ def in_alpha_or_beta?
true
end

def mirror_repos!(repos)
def mirror_repositories!(repos)
repos.compact.each do |repo|
unless repo.mirroring_enabled
errors << _('Mirroring of repository with ID %{repo_id} is not enabled') % { repo_id: repo.friendly_id }
errors << (_('Mirroring of repository with ID %{repo_id} is not enabled') % { repo_id: repo.friendly_id })
next
end

mirror.mirror(
repository_url: repo.external_url,
local_path: Repository.make_local_path(repo.external_url),
auth_token: repo.auth_token,
repo_name: repo.name
)
configuration = {
repository: repo,
logger: logger,
mirroring_base_dir: RMT::DEFAULT_MIRROR_DIR,
mirror_sources: RMT::Config.mirror_src_files?,
is_airgapped: false
}

RMT::Mirror.new(**configuration).mirror_now
repo.refresh_timestamp!
rescue RMT::Mirror::Exception => e
errors << _("Repository '%{repo_name}' (%{repo_id}): %{error_message}") % {
errors << (_("Repository '%{repo_name}' (%{repo_id}): %{error_message}") % {
repo_id: repo.friendly_id, repo_name: repo.name, error_message: e.message
}
})
errored_repos_id << repo.id if options[:do_not_raise_unpublished]
end
end
Expand Down
4 changes: 2 additions & 2 deletions lib/rmt/deduplicator.rb
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ def deduplicate(target_file)
make_file_dir(target_file.local_path)
source_file_path = source_files.first.local_path

if RMT::Config.deduplication_by_hardlink? && !airgap_mode
if RMT::Config.deduplication_by_hardlink? && !is_airgapped
hardlink(source_file_path, target_file.local_path)
logger.info("← #{File.basename(target_file.local_path)}")
else
Expand All @@ -25,7 +25,7 @@ def deduplicate(target_file)
end

# we don't want to track airgap files in our database
unless airgap_mode
unless is_airgapped
DownloadedFile.track_file(checksum: target_file.checksum,
checksum_type: target_file.checksum_type,
local_path: target_file.local_path,
Expand Down
Loading