katello 4.0.3 → 4.1.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/katello/hosts/host_and_hostgroup_edit.js +0 -33
- data/app/assets/stylesheets/katello/contents.scss +1 -1
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +5 -11
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +2 -9
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +10 -24
- data/app/controllers/katello/api/v2/api_controller.rb +15 -3
- data/app/controllers/katello/api/v2/content_credentials_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +1 -8
- data/app/controllers/katello/api/v2/content_exports_controller.rb +1 -14
- data/app/controllers/katello/api/v2/content_imports_controller.rb +38 -15
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +22 -1
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +6 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +2 -59
- data/app/controllers/katello/api/v2/content_views_controller.rb +3 -58
- data/app/controllers/katello/api/v2/host_errata_controller.rb +7 -6
- data/app/controllers/katello/api/v2/host_packages_controller.rb +4 -4
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +18 -22
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +16 -16
- data/app/controllers/katello/api/v2/organizations_controller.rb +2 -1
- data/app/controllers/katello/api/v2/package_groups_controller.rb +4 -0
- data/app/controllers/katello/api/v2/repositories_controller.rb +13 -12
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +50 -4
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +7 -1
- data/app/controllers/katello/concerns/api/api_controller.rb +10 -0
- data/app/controllers/katello/concerns/api/v2/registration_commands_controller_extensions.rb +46 -0
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +8 -0
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +31 -22
- data/app/controllers/katello/concerns/hosts_controller_extensions.rb +0 -8
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +1 -1
- data/app/controllers/katello/concerns/registration_commands_controller_extensions.rb +34 -0
- data/app/helpers/katello/katello_urls_helper.rb +23 -0
- data/app/lib/actions/candlepin/owner/import.rb +10 -3
- data/app/lib/actions/candlepin/product/content_update.rb +1 -1
- data/app/lib/actions/foreman/environment/destroy.rb +2 -2
- data/app/lib/actions/katello/agent_action.rb +1 -6
- data/app/lib/actions/katello/capsule_content/refresh_repos.rb +0 -7
- data/app/lib/actions/katello/capsule_content/sync.rb +1 -1
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +1 -2
- data/app/lib/actions/katello/content_view/add_to_environment.rb +9 -7
- data/app/lib/actions/katello/content_view/incremental_updates.rb +3 -10
- data/app/lib/actions/katello/content_view/presenters/incremental_updates_presenter.rb +2 -3
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +1 -4
- data/app/lib/actions/katello/content_view/publish.rb +21 -31
- data/app/lib/actions/katello/content_view_environment/destroy.rb +0 -5
- data/app/lib/actions/katello/content_view_version/auto_create_products.rb +22 -0
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +22 -0
- data/app/lib/actions/katello/content_view_version/destroy.rb +0 -10
- data/app/lib/actions/katello/content_view_version/export.rb +20 -22
- data/app/lib/actions/katello/content_view_version/import.rb +27 -13
- data/app/lib/actions/katello/content_view_version/import_library.rb +4 -2
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +12 -67
- data/app/lib/actions/katello/content_view_version/republish_repositories.rb +0 -4
- data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +11 -0
- data/app/lib/actions/katello/foreman/content_update.rb +0 -3
- data/app/lib/actions/katello/host/auto_attach_subscriptions.rb +0 -4
- data/app/lib/actions/katello/organization/manifest_import.rb +7 -1
- data/app/lib/actions/katello/organization/manifest_refresh.rb +28 -7
- data/app/lib/actions/katello/orphan_cleanup/remove_orphans.rb +2 -2
- data/app/lib/actions/katello/product/create.rb +0 -1
- data/app/lib/actions/katello/repository/check_matching_content.rb +4 -3
- data/app/lib/actions/katello/repository/destroy.rb +1 -1
- data/app/lib/actions/katello/repository/discover.rb +1 -1
- data/app/lib/actions/katello/repository/filtered_index_content.rb +1 -4
- data/app/lib/actions/katello/repository/import_upload.rb +0 -1
- data/app/lib/actions/katello/repository/update.rb +0 -1
- data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +0 -5
- data/app/lib/actions/pulp/repository/create.rb +1 -7
- data/app/lib/actions/pulp/repository/distributor_publish.rb +2 -10
- data/app/lib/actions/pulp/repository/sync.rb +1 -3
- data/app/lib/actions/pulp3/capsule_content/refresh_content_guard.rb +17 -0
- data/app/lib/actions/pulp3/content_guard/refresh.rb +10 -6
- data/app/lib/actions/pulp3/content_view_version/create_export_history.rb +57 -0
- data/app/lib/actions/pulp3/content_view_version/create_import_history.rb +34 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +2 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +34 -51
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +2 -2
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +13 -1
- data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/repository/sync.rb +1 -0
- data/app/lib/actions/pulp3/repository/refresh_remote.rb +17 -0
- data/app/lib/katello/agent/client_message_handler.rb +3 -11
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +117 -3
- data/app/lib/katello/errors.rb +6 -11
- data/app/lib/katello/event_daemon/monitor.rb +0 -1
- data/app/lib/katello/event_daemon/runner.rb +2 -2
- data/app/lib/katello/event_daemon/services/agent_event_receiver.rb +10 -6
- data/app/lib/katello/http_resource.rb +1 -6
- data/app/lib/katello/logging.rb +11 -6
- data/app/lib/katello/qpid/connection.rb +1 -3
- data/app/lib/katello/repo_discovery.rb +15 -1
- data/app/lib/katello/resources/candlepin/owner.rb +3 -2
- data/app/lib/katello/resources/candlepin/pool.rb +6 -2
- data/app/lib/katello/resources/candlepin.rb +10 -0
- data/app/lib/katello/util/package.rb +1 -1
- data/app/lib/katello/util/pulpcore_content_filters.rb +1 -1
- data/app/lib/katello/validators/hostgroup_kickstart_repository_validator.rb +0 -6
- data/app/models/katello/authorization/content_view.rb +8 -0
- data/app/models/katello/authorization/content_view_version_import_history.rb +11 -0
- data/app/models/katello/concerns/content_facet_host_extensions.rb +1 -1
- data/app/models/katello/concerns/content_view_filter_rule_common.rb +2 -2
- data/app/models/katello/concerns/host_managed_extensions.rb +1 -32
- data/app/models/katello/concerns/hostgroup_extensions.rb +2 -9
- data/app/models/katello/concerns/http_proxy_extensions.rb +2 -4
- data/app/models/katello/concerns/location_extensions.rb +2 -25
- data/app/models/katello/concerns/operatingsystem_extensions.rb +0 -2
- data/app/models/katello/concerns/organization_extensions.rb +4 -18
- data/app/models/katello/concerns/redhat_extensions.rb +10 -18
- data/app/models/katello/concerns/smart_proxy_extensions.rb +6 -31
- data/app/models/katello/content_view.rb +17 -113
- data/app/models/katello/content_view_component.rb +5 -0
- data/app/models/katello/content_view_docker_filter_rule.rb +1 -0
- data/app/models/katello/content_view_package_filter_rule.rb +4 -0
- data/app/models/katello/content_view_package_group_filter.rb +1 -0
- data/app/models/katello/content_view_repository.rb +4 -5
- data/app/models/katello/content_view_version.rb +9 -33
- data/app/models/katello/content_view_version_export_history.rb +18 -4
- data/app/models/katello/content_view_version_import_history.rb +42 -0
- data/app/models/katello/erratum.rb +1 -1
- data/app/models/katello/events/delete_pool.rb +19 -0
- data/app/models/katello/glue/candlepin/environment.rb +7 -0
- data/app/models/katello/glue/candlepin/owner.rb +12 -1
- data/app/models/katello/glue/candlepin/pool.rb +42 -25
- data/app/models/katello/glue/provider.rb +3 -6
- data/app/models/katello/glue/pulp/repo.rb +19 -9
- data/app/models/katello/host/content_facet.rb +1 -0
- data/app/models/katello/host/subscription_facet.rb +3 -1
- data/app/models/katello/kt_environment.rb +0 -6
- data/app/models/katello/package_group.rb +4 -0
- data/app/models/katello/ping.rb +15 -4
- data/app/models/katello/pool.rb +9 -0
- data/app/models/katello/product.rb +0 -6
- data/app/models/katello/product_content.rb +3 -1
- data/app/models/katello/pulp_sync_status.rb +0 -10
- data/app/models/katello/repository.rb +20 -35
- data/app/models/katello/root_repository.rb +0 -5
- data/app/models/katello/subscription.rb +10 -0
- data/app/models/katello/sync_plan.rb +7 -0
- data/app/models/setting/content.rb +7 -8
- data/app/presenters/katello/content_view_version_compare_presenter.rb +2 -6
- data/app/presenters/katello/product_content_presenter.rb +3 -5
- data/app/services/cert/certs.rb +3 -7
- data/app/services/katello/applicability/applicable_content_helper.rb +1 -2
- data/app/services/katello/candlepin/event_handler.rb +22 -22
- data/app/services/katello/candlepin/message_handler.rb +24 -15
- data/app/services/katello/content_view_manager.rb +24 -0
- data/app/services/katello/event_monitor/poller_thread.rb +25 -20
- data/app/services/katello/managed_content_medium_provider.rb +4 -0
- data/app/services/katello/organization_creator.rb +120 -0
- data/app/services/katello/product_content_finder.rb +5 -1
- data/app/services/katello/pulp/pulp_content_unit.rb +6 -6
- data/app/services/katello/pulp/smart_proxy_repository.rb +2 -17
- data/app/services/katello/pulp3/api/ansible_collection.rb +14 -2
- data/app/services/katello/pulp3/api/apt.rb +1 -1
- data/app/services/katello/pulp3/api/content_guard.rb +6 -40
- data/app/services/katello/pulp3/api/core.rb +27 -2
- data/app/services/katello/pulp3/api/docker.rb +1 -1
- data/app/services/katello/pulp3/api/file.rb +5 -1
- data/app/services/katello/pulp3/api/yum.rb +9 -1
- data/app/services/katello/pulp3/content_view_version/export.rb +18 -40
- data/app/services/katello/pulp3/content_view_version/import.rb +75 -30
- data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +32 -0
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +53 -21
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +47 -0
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +52 -0
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +99 -0
- data/app/services/katello/pulp3/pulp_content_unit.rb +1 -1
- data/app/services/katello/pulp3/repository/ansible_collection.rb +5 -1
- data/app/services/katello/pulp3/repository/apt.rb +2 -1
- data/app/services/katello/pulp3/repository/yum.rb +0 -16
- data/app/services/katello/pulp3/repository.rb +20 -1
- data/app/services/katello/pulp3/rpm.rb +5 -1
- data/app/services/katello/pulp3/task.rb +12 -5
- data/app/services/katello/pulp3/task_group.rb +10 -5
- data/app/services/katello/smart_proxy_helper.rb +1 -8
- data/app/services/katello/ui_notifications/pulp/proxy_disk_space.rb +0 -1
- data/app/services/katello/ui_notifications/system_error.rb +25 -0
- data/app/views/katello/api/v2/content_view_components/show.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_filters/show.json.rabl +0 -1
- data/app/views/katello/api/v2/{puppet_modules → content_view_version_import_histories}/index.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_version_import_histories/show.json.rabl +14 -0
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +2 -2
- data/app/views/katello/api/v2/content_view_versions/show.json.rabl +0 -7
- data/app/views/katello/api/v2/content_views/base.json.rabl +20 -9
- data/app/views/katello/api/v2/environments/show.json.rabl +0 -1
- data/app/views/katello/api/v2/package_groups/index.json.rabl +4 -0
- data/app/views/katello/api/v2/repositories/base.json.rabl +0 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repository_sets/index.json.rabl +4 -1
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +22 -0
- data/app/views/katello/api/v2/subscriptions/show.json.rabl +1 -1
- data/app/views/overrides/activation_keys/_host_media_type_select.html.erb +1 -1
- data/app/views/overrides/smart_proxies/_download_policy.erb +1 -1
- data/config/initializers/monkeys.rb +0 -1
- data/config/katello.yaml.example +0 -1
- data/config/routes/api/v2.rb +9 -21
- data/config/routes/overrides.rb +1 -2
- data/db/migrate/20140422000001_update_products_add_organization.rb +3 -2
- data/db/migrate/20160701180402_add_sortable_version_to_puppet_modules.rb +2 -0
- data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +1 -1
- data/db/migrate/20210119162528_delete_puppet_and_ostree_repos.rb +14 -20
- data/db/migrate/20210224160921_remove_disabled_products_from_sync_plans.rb +6 -0
- data/db/migrate/20210302165636_remove_katello_puppet_modules.rb +62 -0
- data/db/migrate/20210309160925_create_katello_content_view_version_import_histories.rb +13 -0
- data/db/migrate/20210318204533_add_import_type_to_import_histories.rb +8 -0
- data/db/migrate/20210319123300_add_foreign_keys_to_import_export_histories.rb +6 -0
- data/db/migrate/20210322142311_add_auth_url_token_to_root_repositories.rb +6 -0
- data/db/migrate/20210331180353_katello_pool_organization_id_not_nullable.rb +16 -0
- data/db/migrate/20210409033915_add_created_in_katello_to_taxonomy.rb +9 -0
- data/db/seeds.d/101-locations.rb +0 -3
- data/db/seeds.d/102-organizations.rb +1 -5
- data/db/seeds.d/109-katello-notification-blueprints.rb +12 -0
- data/db/seeds.d/111-upgrade_tasks.rb +3 -2
- data/engines/bastion/vendor/assets/javascripts/bastion/angular/angular.js +325 -156
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-animate/angular-animate.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-resource/angular-resource.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-route/angular-route.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-sanitize/angular-sanitize.js +21 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-repository-sets.controller.js +9 -10
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-repository-sets.html +2 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion-katello-bootstrap.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion_katello.js +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-errata-modal.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-packages-modal.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-errata-modal.html +11 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-packages-modal.html +18 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +10 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-errata.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-actions.controller.js +5 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-applicable.controller.js +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-errata.html +6 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +7 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +14 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-installed.html +5 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.routes.js +0 -14
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-repository-sets.controller.js +9 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-repository-sets.html +2 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +3 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-view.factory.js +0 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -56
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +2 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -12
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +2 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-versions.module.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.module.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +0 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/apply-errata.controller.js +21 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/views/apply-errata-confirm.html +9 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +71 -311
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +0 -10
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/fenced-pages.service.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-manage-content.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +13 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +21 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.routes.js +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/views/product-repositories.html +0 -6
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +3 -3
- data/lib/katello/engine.rb +16 -15
- data/lib/katello/middleware/organization_created_enforcer.rb +22 -0
- data/lib/katello/permission_creator.rb +12 -28
- data/lib/katello/permissions/host_permissions.rb +3 -2
- data/lib/katello/plugin.rb +6 -19
- data/lib/katello/repository_types/ansible_collection.rb +1 -1
- data/lib/katello/repository_types/deb.rb +1 -1
- data/lib/katello/repository_types/docker.rb +1 -1
- data/lib/katello/repository_types/file.rb +1 -1
- data/lib/katello/repository_types/yum.rb +1 -1
- data/lib/katello/tasks/clean_backend_objects.rake +25 -0
- data/lib/katello/tasks/jenkins.rake +6 -0
- data/lib/katello/tasks/receptor/extract_orgs.rake +1 -3
- data/lib/katello/tasks/reimport.rake +0 -1
- data/lib/katello/tasks/repository.rake +0 -30
- data/lib/katello/tasks/update_subscription_facet_backend_data.rake +3 -3
- data/lib/katello/tasks/upgrades/4.0/remove_ostree_puppet_content.rake +2 -4
- data/lib/katello/tasks/upgrades/4.1/fix_invalid_pools.rake +62 -0
- data/lib/katello/tasks/upgrades/4.1/sync_noarch_content.rake +15 -0
- data/lib/katello/version.rb +1 -1
- data/lib/katello.rb +1 -1
- data/locale/action_names.rb +65 -63
- data/locale/bn/katello.edit.po +1357 -1606
- data/locale/bn/katello.po +465 -744
- data/locale/cs/katello.edit.po +1213 -1087
- data/locale/cs/katello.po +307 -219
- data/locale/de/katello.edit.po +1498 -1520
- data/locale/de/katello.po +589 -625
- data/locale/en/katello.edit.po +1198 -1074
- data/locale/en/katello.po +304 -213
- data/locale/es/katello.edit.po +2344 -2304
- data/locale/es/katello.po +1407 -1407
- data/locale/fr/katello.edit.po +2720 -2642
- data/locale/fr/katello.po +1703 -1750
- data/locale/gu/katello.edit.po +1546 -1797
- data/locale/gu/katello.po +654 -935
- data/locale/hi/katello.edit.po +1545 -1793
- data/locale/hi/katello.po +653 -931
- data/locale/it/katello.edit.po +1323 -1310
- data/locale/it/katello.po +407 -409
- data/locale/ja/katello.edit.po +2645 -2557
- data/locale/ja/katello.po +1646 -1664
- data/locale/katello.pot +1435 -1289
- data/locale/kn/katello.edit.po +1546 -1795
- data/locale/kn/katello.po +654 -933
- data/locale/ko/katello.edit.po +1464 -1449
- data/locale/ko/katello.po +554 -554
- data/locale/mr/katello.edit.po +1545 -1758
- data/locale/mr/katello.po +653 -896
- data/locale/or/katello.edit.po +1546 -1795
- data/locale/or/katello.po +654 -933
- data/locale/pa/katello.edit.po +1541 -1775
- data/locale/pa/katello.po +649 -913
- data/locale/pt/katello.edit.po +1289 -1255
- data/locale/pt/katello.po +398 -394
- data/locale/pt_BR/katello.edit.po +2370 -2315
- data/locale/pt_BR/katello.po +1435 -1421
- data/locale/ru/katello.edit.po +1611 -1608
- data/locale/ru/katello.po +704 -716
- data/locale/ta/katello.edit.po +1358 -1605
- data/locale/ta/katello.po +465 -742
- data/locale/te/katello.edit.po +1545 -1792
- data/locale/te/katello.po +653 -930
- data/locale/zh_CN/katello.edit.po +3052 -2930
- data/locale/zh_CN/katello.po +2055 -2039
- data/locale/zh_TW/katello.edit.po +1571 -1669
- data/locale/zh_TW/katello.po +649 -777
- data/package.json +2 -2
- data/webpack/{scenes/ContentViews/Details/Repositories/RepoAddedStatus.js → components/AddedStatusLabel.js} +5 -5
- data/webpack/components/RoutedTabs/RoutedTabs.js +91 -0
- data/webpack/components/RoutedTabs/__tests__/RoutedTabs.test.js +32 -0
- data/webpack/components/RoutedTabs/index.js +4 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageConstants.js +2 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageHelpers.js +21 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageSelectors.js +21 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/ActivationKeys.test.js +18 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/Force.test.js +9 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/IgnoreSubmanErrors.test.js +9 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/LifeCycleEnvironment.test.js +11 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +58 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +25 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +25 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/LifeCycleEnvironment.test.js.snap +27 -0
- data/webpack/components/extensions/RegistrationCommands/fields/ActivationKeys.js +99 -0
- data/webpack/components/extensions/RegistrationCommands/fields/Force.js +38 -0
- data/webpack/components/extensions/RegistrationCommands/fields/IgnoreSubmanErrors.js +38 -0
- data/webpack/components/extensions/RegistrationCommands/fields/LifecycleEnvironment.js +56 -0
- data/webpack/components/extensions/RegistrationCommands/index.js +81 -0
- data/webpack/components/pf3Table/formatters/EntitlementsInlineEditFormatter.js +23 -24
- data/webpack/components/pf3Table/formatters/__tests__/__snapshots__/EntitlementsInlineEditFormatter.test.js.snap +3 -1
- data/webpack/components/pf3Table/formatters/entitlementsValueFormatter.js +16 -0
- data/webpack/containers/Application/overrides.scss +3 -0
- data/webpack/fills_index.js +3 -0
- data/webpack/redux/reducers/RedHatRepositories/enabled.fixtures.js +0 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +8 -1
- data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +1 -3
- data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +1 -3
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentEnvironments.js +28 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentVersion.js +45 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +124 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +163 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/unpublishedCVComponents.fixtures.json +64 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +67 -7
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +61 -4
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +34 -11
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +33 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +117 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +115 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +7 -10
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetails.js +49 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +56 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +3 -17
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +116 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/allFilterPackageGroups.fixtures.json +69 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetail.fixtures.json +103 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +116 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterDetail.fixtures.json +147 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterRules.fixtures.json +30 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +136 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.fixtures.json +370 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +94 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentCounts.js +0 -1
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +106 -13
- data/webpack/scenes/ContentViews/Details/Repositories/LastSync.js +11 -5
- data/webpack/scenes/ContentViews/Details/Repositories/RepoIcon.js +5 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +138 -0
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.fixtures.json +0 -2
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +1 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +57 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionContent.js +73 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionEnvironments.js +31 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.js +64 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.scss +8 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionPackages.js +0 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +105 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.fixtures.json +728 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/emptyCVVersion.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +3 -1
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +0 -2
- data/webpack/scenes/ContentViews/Table/ContentViewVersionCell.js +33 -0
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +17 -22
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +51 -102
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +5 -3
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +30 -5
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +95 -0
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +11 -5
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +16 -0
- data/webpack/scenes/ContentViews/components/IconWithCount.js +1 -1
- data/webpack/scenes/ContentViews/components/InactiveText.js +15 -0
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +19 -1
- data/webpack/scenes/Subscriptions/Details/SubscriptionPurposeAttributes.js +1 -1
- data/webpack/scenes/Subscriptions/Details/__tests__/__snapshots__/SubscriptionDetailInfo.test.js.snap +1 -1
- data/webpack/scenes/Subscriptions/Details/__tests__/__snapshots__/SubscriptionDetails.test.js.snap +3 -3
- data/webpack/scenes/Subscriptions/Details/__tests__/subscriptionDetails.fixtures.js +1 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableHelpers.js +17 -0
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableSchema.js +2 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/SubscriptionsTable.test.js +1 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/__snapshots__/SubscriptionsTable.test.js.snap +144 -0
- data/webpack/scenes/Tasks/helpers.js +2 -2
- data/webpack/test-utils/react-testing-lib-wrapper.js +11 -3
- data/webpack/utils/__tests__/useParamsWithHash.test.js +22 -0
- data/webpack/utils/helpers.js +2 -0
- data/webpack/utils/paramsFromHash.js +16 -0
- data/webpack/utils/useUrlParams.js +14 -0
- metadata +122 -206
- data/app/controllers/katello/api/v2/content_view_puppet_modules_controller.rb +0 -82
- data/app/controllers/katello/api/v2/puppet_modules_controller.rb +0 -19
- data/app/controllers/katello/concerns/registration_controller_extensions.rb +0 -16
- data/app/helpers/katello/concerns/hosts_and_hostgroups_helper_extensions.rb +0 -20
- data/app/lib/actions/candlepin/owner/create.rb +0 -16
- data/app/lib/actions/katello/content_view_puppet_environment/clear.rb +0 -11
- data/app/lib/actions/katello/content_view_puppet_environment/clone.rb +0 -78
- data/app/lib/actions/katello/content_view_puppet_environment/clone_content_for_version.rb +0 -20
- data/app/lib/actions/katello/content_view_puppet_environment/create.rb +0 -34
- data/app/lib/actions/katello/content_view_puppet_environment/create_for_version.rb +0 -23
- data/app/lib/actions/katello/content_view_puppet_environment/destroy.rb +0 -28
- data/app/lib/actions/katello/content_view_puppet_module/destroy.rb +0 -46
- data/app/lib/actions/katello/environment/library_create.rb +0 -35
- data/app/lib/actions/katello/organization/create.rb +0 -38
- data/app/lib/actions/pulp/content_view_puppet_environment/copy_contents.rb +0 -36
- data/app/lib/actions/pulp/content_view_puppet_environment/index_content.rb +0 -19
- data/app/lib/actions/pulp/repository/presenters/puppet_presenter.rb +0 -54
- data/app/lib/actions/pulp3/content_migration.rb +0 -31
- data/app/lib/actions/pulp3/content_migration_presenter.rb +0 -59
- data/app/lib/actions/pulp3/content_migration_reset.rb +0 -22
- data/app/lib/katello/foreman.rb +0 -32
- data/app/lib/katello/mapping.rb +0 -31
- data/app/lib/katello/util/hostgroup_facets_helper.rb +0 -126
- data/app/lib/katello/validators/content_view_puppet_module_validator.rb +0 -32
- data/app/models/katello/concerns/environment_extensions.rb +0 -74
- data/app/models/katello/content_view_puppet_environment.rb +0 -116
- data/app/models/katello/content_view_puppet_environment_puppet_module.rb +0 -11
- data/app/models/katello/content_view_puppet_module.rb +0 -63
- data/app/models/katello/puppet_module.rb +0 -77
- data/app/models/katello/repository_puppet_module.rb +0 -7
- data/app/services/katello/pulp/puppet_module.rb +0 -21
- data/app/services/katello/pulp/repository/puppet.rb +0 -68
- data/app/services/katello/pulp3/migration.rb +0 -329
- data/app/services/katello/pulp3/migration_plan.rb +0 -178
- data/app/services/katello/pulp3/migration_switchover.rb +0 -126
- data/app/services/katello/puppet_class_importer_extensions.rb +0 -32
- data/app/views/foreman/hosts/_registration.html.erb +0 -12
- data/app/views/katello/api/v2/activation_keys/product_content.json.rabl +0 -30
- data/app/views/katello/api/v2/content_view_puppet_modules/create.json.rabl +0 -3
- data/app/views/katello/api/v2/content_view_puppet_modules/index.json.rabl +0 -7
- data/app/views/katello/api/v2/content_view_puppet_modules/show.json.rabl +0 -9
- data/app/views/katello/api/v2/content_views/puppet_modules.json.rabl +0 -7
- data/app/views/katello/api/v2/host_subscriptions/content_override.json.rabl +0 -3
- data/app/views/katello/api/v2/host_subscriptions/product_content.json.rabl +0 -29
- data/app/views/katello/api/v2/puppet_modules/backend.json.rabl +0 -7
- data/app/views/katello/api/v2/puppet_modules/base.json.rabl +0 -9
- data/app/views/katello/api/v2/puppet_modules/compare.json.rabl +0 -10
- data/app/views/katello/api/v2/puppet_modules/name.json.rabl +0 -3
- data/app/views/katello/api/v2/puppet_modules/names.json.rabl +0 -7
- data/app/views/katello/api/v2/puppet_modules/show.json.rabl +0 -4
- data/db/migrate/20210512192745_fix_red_hat_root_repository_arch.rb +0 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-client.directive.js +0 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-os-client.directive.js +0 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register.controller.js +0 -44
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-client.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-deb-client.html +0 -38
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-oracle-client.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-sles-client.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-puppet-modules.controller.js +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-names.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-versions.controller.js +0 -61
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module.factory.js +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-modules.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-module-names.html +0 -57
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-module-versions.html +0 -64
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-modules.html +0 -54
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-puppet-modules.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-puppet-modules.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +0 -6903
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +0 -7094
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +0 -7303
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +0 -6895
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +0 -6865
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +0 -6720
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +0 -7077
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +0 -6832
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +0 -6766
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +0 -6703
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-manage-puppet-modules.html +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-content-views.controller.js +0 -44
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-repositories.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-content-views.html +0 -41
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-info.html +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-repositories.html +0 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module.html +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-module.factory.js +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.controller.js +0 -35
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.module.js +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.routes.js +0 -71
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/views/puppet-modules.html +0 -47
- data/lib/katello/repository_types/puppet.rb +0 -5
- data/lib/katello/tasks/fix_hostgroup_facets.rake +0 -8
- data/lib/katello/tasks/pulp3_content_switchover.rake +0 -32
- data/lib/katello/tasks/pulp3_migration.rake +0 -41
- data/lib/katello/tasks/pulp3_migration_abort.rake +0 -22
- data/lib/katello/tasks/pulp3_migration_reset.rake +0 -26
- data/lib/katello/tasks/pulp3_migration_stats.rake +0 -41
- data/lib/katello/tasks/pulp3_post_migration_check.rake +0 -51
- data/lib/monkeys/passenger_tee_input.rb +0 -20
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/webpack/components/TabWrapper/TabWrapper.js +0 -26
- data/webpack/components/TabWrapper/index.js +0 -3
- data/webpack/components/TabbedView/TabbedView.js +0 -38
- data/webpack/components/TabbedView/TabbedView.scss +0 -3
- data/webpack/components/TabbedView/index.js +0 -3
- data/webpack/scenes/ContentViews/expansions/EnvironmentsExpansion.js +0 -19
- data/webpack/scenes/ContentViews/expansions/VersionsExpansion.js +0 -11
@@ -1,68 +0,0 @@
|
|
1
|
-
module Katello
|
2
|
-
module Pulp
|
3
|
-
class Repository
|
4
|
-
class Puppet < ::Katello::Pulp::Repository
|
5
|
-
def generate_primary_importer
|
6
|
-
config = {
|
7
|
-
feed: root.url,
|
8
|
-
remove_missing: root.mirror_on_sync?
|
9
|
-
}
|
10
|
-
importer_class.new(config.merge(primary_importer_connection_options))
|
11
|
-
end
|
12
|
-
|
13
|
-
def generate_mirror_importer
|
14
|
-
config = {
|
15
|
-
:feed => self.external_url,
|
16
|
-
:remove_missing => true
|
17
|
-
}
|
18
|
-
importer_class.new(config.merge(mirror_importer_connection_options))
|
19
|
-
end
|
20
|
-
|
21
|
-
def puppet_install_auto_publish?
|
22
|
-
(smart_proxy.try(:pulp_mirror?) && !@repo.library_instance?) || false
|
23
|
-
end
|
24
|
-
|
25
|
-
def generate_distributors
|
26
|
-
puppet_install_dist = Runcible::Models::PuppetInstallDistributor.new(puppet_install_distributor_path,
|
27
|
-
:subdir => 'modules',
|
28
|
-
:id => repo.pulp_id,
|
29
|
-
:auto_publish => puppet_install_auto_publish?)
|
30
|
-
puppet_dist = Runcible::Models::PuppetDistributor.new(nil, (root.unprotected || false), true,
|
31
|
-
:id => "#{repo.pulp_id}_puppet", :auto_publish => true)
|
32
|
-
[puppet_dist, puppet_install_dist]
|
33
|
-
end
|
34
|
-
|
35
|
-
def puppet_install_distributor_path
|
36
|
-
puppet_env = ::Environment.construct_name(repo.organization, repo.environment, repo.content_view)
|
37
|
-
::File.join(smart_proxy.puppet_path, puppet_env)
|
38
|
-
end
|
39
|
-
|
40
|
-
def distributors_to_publish(_options)
|
41
|
-
if !repo.content_view.default? && !repo.archive?
|
42
|
-
{Runcible::Models::PuppetDistributor => {}, Runcible::Models::PuppetInstallDistributor => {}}
|
43
|
-
else
|
44
|
-
{Runcible::Models::PuppetDistributor => {}}
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
def partial_repo_path
|
49
|
-
"/pulp/puppet/#{repo.pulp_id}/"
|
50
|
-
end
|
51
|
-
|
52
|
-
def importer_class
|
53
|
-
Runcible::Models::PuppetImporter
|
54
|
-
end
|
55
|
-
|
56
|
-
def copy_contents(destination_repo, options = {})
|
57
|
-
if options[:puppet_modules]
|
58
|
-
module_uuids = options[:puppet_modules].pluck(:pulp_id)
|
59
|
-
clauses = {'filters': { 'association': { 'unit_id' => { "$in" => module_uuids } } } }
|
60
|
-
else
|
61
|
-
clauses = {}
|
62
|
-
end
|
63
|
-
@smart_proxy.pulp_api.extensions.puppet_module.copy(@repo.pulp_id, destination_repo.pulp_id, clauses)
|
64
|
-
end
|
65
|
-
end
|
66
|
-
end
|
67
|
-
end
|
68
|
-
end
|
@@ -1,329 +0,0 @@
|
|
1
|
-
require 'pulp_2to3_migration_client'
|
2
|
-
|
3
|
-
module Katello
|
4
|
-
module Pulp3
|
5
|
-
class Migration
|
6
|
-
attr_accessor :smart_proxy, :reimport_all, :task_id
|
7
|
-
GET_QUERY_ID_LENGTH = 90
|
8
|
-
|
9
|
-
MUTABLE_CONTENT_TYPES = [
|
10
|
-
Katello::DockerTag,
|
11
|
-
Katello::Erratum
|
12
|
-
].freeze
|
13
|
-
|
14
|
-
UNIFIED_CONTENT_TYPES = [
|
15
|
-
Katello::Erratum
|
16
|
-
].freeze
|
17
|
-
|
18
|
-
def self.repository_types_for_migration
|
19
|
-
#we can migrate types that pulp3 supports, but are overridden to pulp2. These are in 'migration mode'
|
20
|
-
overridden = (SETTINGS[:katello][:use_pulp_2_for_content_type] || {}).keys.select { |key| SETTINGS[:katello][:use_pulp_2_for_content_type][key] }
|
21
|
-
overridden.select { |type| SmartProxy.pulp_primary.pulp3_repository_type_support?(type.to_s, false) }.map { |t| t.to_s }
|
22
|
-
end
|
23
|
-
|
24
|
-
def initialize(smart_proxy, options = {})
|
25
|
-
self.task_id = options.fetch(:task_id, nil)
|
26
|
-
self.reimport_all = options.fetch(:reimport_all, false)
|
27
|
-
repository_types = options.fetch(:repository_types, Migration.repository_types_for_migration)
|
28
|
-
|
29
|
-
if (repository_types - smart_proxy.supported_pulp_types[:pulp3][:overriden_to_pulp2]).any?
|
30
|
-
fail ::Katello::Errors::Pulp3MigrationError, _("Pulp 3 migration cannot run. Types %s have already been migrated.") %
|
31
|
-
(repository_types - smart_proxy.supported_pulp_types[:pulp3][:overriden_to_pulp2]).join(', ')
|
32
|
-
end
|
33
|
-
|
34
|
-
@repository_types = repository_types
|
35
|
-
@smart_proxy = smart_proxy
|
36
|
-
end
|
37
|
-
|
38
|
-
def api_client
|
39
|
-
Pulp2to3MigrationClient::ApiClient.new(smart_proxy.pulp3_configuration(Pulp2to3MigrationClient::Configuration))
|
40
|
-
end
|
41
|
-
|
42
|
-
def migration_plan_api
|
43
|
-
Pulp2to3MigrationClient::MigrationPlansApi.new(api_client)
|
44
|
-
end
|
45
|
-
|
46
|
-
def pulp2_content_api
|
47
|
-
Pulp2to3MigrationClient::Pulp2ContentApi.new(api_client)
|
48
|
-
rescue NameError
|
49
|
-
Pulp2to3MigrationClient::Pulp2contentApi.new(api_client) #backwards compatible
|
50
|
-
end
|
51
|
-
|
52
|
-
def pulp2_repositories_api
|
53
|
-
Pulp2to3MigrationClient::Pulp2RepositoriesApi.new(api_client)
|
54
|
-
rescue NameError
|
55
|
-
Pulp2to3MigrationClient::Pulp2repositoriesApi.new(api_client) #backwards compatible
|
56
|
-
end
|
57
|
-
|
58
|
-
def create_and_run_migrations
|
59
|
-
migs = create_migrations
|
60
|
-
migs.map { |href| start_migration(href) }
|
61
|
-
end
|
62
|
-
|
63
|
-
def self.ignorable_content_types
|
64
|
-
[YumMetadataFile]
|
65
|
-
end
|
66
|
-
|
67
|
-
def last_successful_migration_time
|
68
|
-
task = ForemanTasks::Task.where(:label => Actions::Pulp3::ContentMigration.to_s, :result => 'success').order("started_at desc").first
|
69
|
-
if reimport_all || task.nil?
|
70
|
-
0
|
71
|
-
else
|
72
|
-
task.started_at.to_i
|
73
|
-
end
|
74
|
-
end
|
75
|
-
|
76
|
-
def content_types_for_migration
|
77
|
-
content_types = @repository_types.collect do |repository_type_label|
|
78
|
-
Katello::RepositoryTypeManager.repository_types[repository_type_label].content_types_to_index
|
79
|
-
end
|
80
|
-
|
81
|
-
content_types.flatten - Migration.ignorable_content_types
|
82
|
-
end
|
83
|
-
|
84
|
-
def update_import_status(message, index = nil)
|
85
|
-
#reduce output updating, only update every 20 items
|
86
|
-
if (index.nil? || index % 20 == 0) && self.task_id
|
87
|
-
progress = Katello::ContentMigrationProgress.find_or_create_by(:task_id => self.task_id)
|
88
|
-
progress.update(:progress_message => message)
|
89
|
-
progress.save!
|
90
|
-
|
91
|
-
fail Katello::Errors::Pulp3MigrationError, "Cancelled by user." if progress.canceled?
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
def import_pulp3_content
|
96
|
-
update_import_status("Starting katello import phase.")
|
97
|
-
|
98
|
-
Katello::Logging.time("CONTENT_MIGRATION - Total Import Process") do
|
99
|
-
@repository_types.each do |repository_type_label|
|
100
|
-
Katello::Logging.time("CONTENT_MIGRATION - Importing Repository", data: {type: repository_type_label}) do
|
101
|
-
import_repositories(repository_type_label)
|
102
|
-
end
|
103
|
-
|
104
|
-
Katello::RepositoryTypeManager.repository_types[repository_type_label].content_types_to_index.each do |content_type|
|
105
|
-
Katello::Logging.time("CONTENT_MIGRATION - Importing Content", data: {type: content_type.label}) do
|
106
|
-
import_content_type(content_type)
|
107
|
-
end
|
108
|
-
end
|
109
|
-
end
|
110
|
-
end
|
111
|
-
end
|
112
|
-
|
113
|
-
def migration_plan
|
114
|
-
Katello::Pulp3::MigrationPlan.new(@repository_types).generate.as_json
|
115
|
-
end
|
116
|
-
|
117
|
-
def reset
|
118
|
-
if @repository_types.empty?
|
119
|
-
fail ::Katello::Errors::Pulp3MigrationError, 'There are no Pulp 3 content types to reset'
|
120
|
-
end
|
121
|
-
|
122
|
-
plugins = @repository_types.sort.map do |repository_type|
|
123
|
-
{
|
124
|
-
type: ::Katello::Pulp3::MigrationPlan.pulp2_repository_type(repository_type)
|
125
|
-
}
|
126
|
-
end
|
127
|
-
plan = { plugins: plugins }
|
128
|
-
|
129
|
-
# TODO: Don't provide the plan as a string once this is resolved: https://pulp.plan.io/issues/8211
|
130
|
-
migration_plan_api.reset(migration_plan_api.create(plan: plan).pulp_href)
|
131
|
-
|
132
|
-
content_types_for_migration.each do |content_type|
|
133
|
-
if content_type.model_class == ::Katello::Erratum
|
134
|
-
::Katello::RepositoryErratum.update_all(erratum_pulp3_href: nil)
|
135
|
-
else
|
136
|
-
content_type.model_class.update_all(migrated_pulp3_href: nil)
|
137
|
-
end
|
138
|
-
end
|
139
|
-
|
140
|
-
@repository_types.each do |repo_type|
|
141
|
-
if repo_type == "file"
|
142
|
-
::Katello::Repository.file_type.update(remote_href: nil, publication_href: nil, version_href: nil)
|
143
|
-
elsif repo_type == "docker"
|
144
|
-
::Katello::Repository.docker_type.update(remote_href: nil, publication_href: nil, version_href: nil)
|
145
|
-
elsif repo_type == "yum"
|
146
|
-
::Katello::Repository.yum_type.update(remote_href: nil, publication_href: nil, version_href: nil)
|
147
|
-
end
|
148
|
-
end
|
149
|
-
|
150
|
-
::Katello::Pulp3::RepositoryReference.destroy_all
|
151
|
-
::Katello::Pulp3::DistributionReference.destroy_all
|
152
|
-
::Katello::Pulp3::ContentGuard.destroy_all
|
153
|
-
end
|
154
|
-
|
155
|
-
def create_migrations
|
156
|
-
plan = migration_plan
|
157
|
-
Rails.logger.info("Migration Plan: #{plan}")
|
158
|
-
|
159
|
-
if plan['plugins'].empty?
|
160
|
-
Rails.logger.error("No Repositories to migrate")
|
161
|
-
[]
|
162
|
-
else
|
163
|
-
[migration_plan_api.create(plan: plan).pulp_href]
|
164
|
-
end
|
165
|
-
end
|
166
|
-
|
167
|
-
def start_migration(plan_href)
|
168
|
-
migration_plan_api.run(plan_href, dry_run: false, validate: true)
|
169
|
-
end
|
170
|
-
|
171
|
-
def import_repositories(repository_type_label)
|
172
|
-
imported = Katello::Pulp3::Api::Core.fetch_from_list { |opts| pulp2_repositories_api.list(opts) }
|
173
|
-
imported = imported.select { |migrated| !migrated.not_in_plan }
|
174
|
-
katello_repos = Katello::Repository.with_type(repository_type_label)
|
175
|
-
|
176
|
-
if repository_type_label == 'yum'
|
177
|
-
import_yum_repos(imported, katello_repos)
|
178
|
-
else
|
179
|
-
repo_count = katello_repos.count
|
180
|
-
katello_repos.each_with_index do |repo, index|
|
181
|
-
update_import_status("Importing migrated content units #{repository_type_label}: #{index + 1}/#{repo_count}", index)
|
182
|
-
found = imported.find { |migrated_repo| migrated_repo.pulp2_repo_id == repo.pulp_id }
|
183
|
-
import_repo(repo, found) if found
|
184
|
-
end
|
185
|
-
end
|
186
|
-
end
|
187
|
-
|
188
|
-
def import_yum_repos(migrated_repo_items, repos)
|
189
|
-
repo_count = repos.count
|
190
|
-
repos.each_with_index do |yum_repo, index|
|
191
|
-
update_import_status("Importing migrated yum repositories: #{index + 1}/#{repo_count}", index)
|
192
|
-
to_find = nil
|
193
|
-
if yum_repo.content_view.composite?
|
194
|
-
if yum_repo.link?
|
195
|
-
to_find = yum_repo.target_repository
|
196
|
-
else
|
197
|
-
to_find = yum_repo
|
198
|
-
end
|
199
|
-
elsif yum_repo.environment_id.nil? || yum_repo.in_default_view? #non-composite archive repo or default content view repo
|
200
|
-
to_find = yum_repo
|
201
|
-
else #non-composite env-repo
|
202
|
-
to_find = yum_repo.archived_instance
|
203
|
-
end
|
204
|
-
|
205
|
-
if to_find
|
206
|
-
found = migrated_repo_items.find { |migrated_repo| migrated_repo.pulp2_repo_id == to_find.pulp_id }
|
207
|
-
import_repo(yum_repo, found) if found
|
208
|
-
end
|
209
|
-
end
|
210
|
-
end
|
211
|
-
|
212
|
-
def api_for_repository(katello_repo)
|
213
|
-
katello_repo.repository_type.pulp3_api_class
|
214
|
-
end
|
215
|
-
|
216
|
-
def import_repo(katello_repo, migrated_repo)
|
217
|
-
pulp3_api = api_for_repository(katello_repo).new(SmartProxy.pulp_primary)
|
218
|
-
katello_repo.remote_href = migrated_repo.pulp3_remote_href
|
219
|
-
katello_repo.publication_href = migrated_repo.pulp3_publication_href
|
220
|
-
katello_repo.version_href = migrated_repo.pulp3_repository_version
|
221
|
-
katello_repo.save!
|
222
|
-
|
223
|
-
if katello_repo.environment_id.nil? #a cv archive repo
|
224
|
-
environment_instances = Katello::Repository.where(library_instance_id: katello_repo.library_instance_id,
|
225
|
-
content_view_version_id: katello_repo.content_view_version_id)
|
226
|
-
environment_instances.update_all(publication_href: migrated_repo.pulp3_publication_href, version_href: migrated_repo.pulp3_repository_version)
|
227
|
-
end
|
228
|
-
|
229
|
-
repo_ref = Katello::Pulp3::RepositoryReference.find_or_initialize_by(:root_repository_id => katello_repo.root_id, :content_view_id => katello_repo.content_view.id)
|
230
|
-
repo_ref.update!(repository_href: migrated_repo.pulp3_repository_href) if repo_ref.repository_href != migrated_repo.pulp3_repository_href
|
231
|
-
process_distributions(pulp3_api, migrated_repo.pulp3_distribution_hrefs)
|
232
|
-
end
|
233
|
-
|
234
|
-
def distribution_path_from_cache(href, pulp3_api)
|
235
|
-
@distribution_cache ||= {}
|
236
|
-
@distribution_cache[href] ||= pulp3_api.distributions_api.read(href).base_path
|
237
|
-
@distribution_cache[href]
|
238
|
-
end
|
239
|
-
|
240
|
-
def process_distributions(pulp3_api, dist_hrefs_list)
|
241
|
-
#distribution_path_hash(pulp3_api, dist_hrefs_list).each do |relative_path, href|
|
242
|
-
dist_hrefs_list.each do |href|
|
243
|
-
relative_path = distribution_path_from_cache(href, pulp3_api)
|
244
|
-
|
245
|
-
dist_ref = Katello::Pulp3::DistributionReference.find_or_initialize_by(:path => relative_path)
|
246
|
-
if (distribution_repo = Katello::Repository.find_by(:relative_path => relative_path) || Katello::Repository.find_by(:container_repository_name => relative_path))
|
247
|
-
dist_ref.href = href
|
248
|
-
dist_ref.repository_id = distribution_repo.id
|
249
|
-
dist_ref.save!
|
250
|
-
end
|
251
|
-
end
|
252
|
-
end
|
253
|
-
|
254
|
-
def generate_repo_version_map
|
255
|
-
map = {}
|
256
|
-
Katello::Repository.select(:id, :version_href).each do |repo|
|
257
|
-
map[repo.version_href] ||= []
|
258
|
-
map[repo.version_href] << repo.id
|
259
|
-
end
|
260
|
-
map
|
261
|
-
end
|
262
|
-
|
263
|
-
def operate_on_errata
|
264
|
-
last_migration_time = last_successful_migration_time
|
265
|
-
offset = 0
|
266
|
-
limit = SETTINGS[:katello][:pulp][:bulk_load_size]
|
267
|
-
response = pulp2_content_api.list(pulp2_content_type_id: 'erratum', offset: offset, limit: limit, pulp2_last_updated__gt: last_migration_time)
|
268
|
-
total_count = response.count
|
269
|
-
yield(response.results)
|
270
|
-
until (offset + limit > total_count)
|
271
|
-
offset += limit
|
272
|
-
response = pulp2_content_api.list(pulp2_content_type_id: 'erratum', offset: offset, limit: limit, pulp2_last_updated__gt: last_migration_time)
|
273
|
-
update_import_status("Importing migrated content type erratum: #{offset + limit}/#{total_count}")
|
274
|
-
yield(response.results)
|
275
|
-
end
|
276
|
-
end
|
277
|
-
|
278
|
-
def import_errata
|
279
|
-
to_import = {}
|
280
|
-
|
281
|
-
repo_version_map = generate_repo_version_map
|
282
|
-
|
283
|
-
operate_on_errata do |migrated_list|
|
284
|
-
katello_errata = Katello::Erratum.where(:pulp_id => migrated_list.map(&:pulp2_id).uniq)
|
285
|
-
migrated_list.each do |migrated_unit|
|
286
|
-
pulp3_href = migrated_unit.pulp3_content
|
287
|
-
errata_id = katello_errata.find { |erratum| erratum.pulp_id == migrated_unit.pulp2_id }&.id
|
288
|
-
next if errata_id.nil?
|
289
|
-
repo_ids = repo_version_map[migrated_unit.pulp3_repository_version]
|
290
|
-
#currently pulp can have duplicates, so de-duplicate with a hash
|
291
|
-
repo_ids&.each do |repo_id|
|
292
|
-
#currently pulp can have duplicates, so de-duplicate with a hash
|
293
|
-
to_import[[errata_id, repo_id]] ||= {erratum_id: errata_id, erratum_pulp3_href: pulp3_href, repository_id: repo_id}
|
294
|
-
end
|
295
|
-
end
|
296
|
-
|
297
|
-
Katello::RepositoryErratum.import([:erratum_id, :erratum_pulp3_href, :repository_id], to_import.values, :validate => false,
|
298
|
-
on_duplicate_key_update: {conflict_target: [:erratum_id, :repository_id], columns: [:erratum_pulp3_href]})
|
299
|
-
to_import = {}
|
300
|
-
end
|
301
|
-
end
|
302
|
-
|
303
|
-
def import_content_type(content_type)
|
304
|
-
if content_type.model_class == Katello::Erratum
|
305
|
-
import_errata
|
306
|
-
else
|
307
|
-
unmigrated_units = content_type.model_class
|
308
|
-
|
309
|
-
#mutable content types have to be completely re-indexed every time
|
310
|
-
if !MUTABLE_CONTENT_TYPES.include?(content_type.model_class) && !self.reimport_all
|
311
|
-
unmigrated_units = unmigrated_units.where(:migrated_pulp3_href => nil)
|
312
|
-
end
|
313
|
-
|
314
|
-
total_count = unmigrated_units.count
|
315
|
-
current_count = 0
|
316
|
-
|
317
|
-
unmigrated_units.select(:id, :pulp_id).find_in_batches(batch_size: GET_QUERY_ID_LENGTH) do |needing_hrefs|
|
318
|
-
current_count += needing_hrefs.count
|
319
|
-
update_import_status("Importing migrated content type #{content_type.label}: #{current_count}/#{total_count}")
|
320
|
-
migrated_units = pulp2_content_api.list(pulp2_id__in: needing_hrefs.map(&:pulp_id))
|
321
|
-
migrated_units.results.each do |migrated_unit|
|
322
|
-
content_type.model_class.where(pulp_id: migrated_unit.pulp2_id).update_all(migrated_pulp3_href: migrated_unit.pulp3_content)
|
323
|
-
end
|
324
|
-
end
|
325
|
-
end
|
326
|
-
end
|
327
|
-
end
|
328
|
-
end
|
329
|
-
end
|
@@ -1,178 +0,0 @@
|
|
1
|
-
module Katello
|
2
|
-
module Pulp3
|
3
|
-
class MigrationPlan
|
4
|
-
def initialize(repository_type_labels)
|
5
|
-
@repository_types = repository_type_labels
|
6
|
-
end
|
7
|
-
|
8
|
-
def primary_proxy
|
9
|
-
SmartProxy.pulp_primary!
|
10
|
-
end
|
11
|
-
|
12
|
-
def generate
|
13
|
-
plan = {}
|
14
|
-
Katello::Logging.time("CONTENT_MIGRATION - Generating Migration plan") do
|
15
|
-
plan[:plugins] = generate_plugins
|
16
|
-
end
|
17
|
-
Rails.logger.error("Migration Plan: #{plan.to_json}")
|
18
|
-
plan
|
19
|
-
end
|
20
|
-
|
21
|
-
def generate_plugins
|
22
|
-
@repository_types.sort.map do |repository_type|
|
23
|
-
{
|
24
|
-
type: self.class.pulp2_repository_type(repository_type),
|
25
|
-
repositories: repository_migrations(repository_type)
|
26
|
-
}
|
27
|
-
end
|
28
|
-
end
|
29
|
-
|
30
|
-
def self.pulp2_repository_type(repository_type)
|
31
|
-
if repository_type == 'yum'
|
32
|
-
return 'rpm' #migration plugin uses rpm
|
33
|
-
else
|
34
|
-
Katello::RepositoryTypeManager.repository_types[repository_type].service_class::REPOSITORY_TYPE
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
def repository_migrations(repo_type)
|
39
|
-
roots = Katello::RootRepository.where(:content_type => repo_type).order(:label)
|
40
|
-
plans = []
|
41
|
-
roots.each do |root|
|
42
|
-
plans << library_migration_for(root)
|
43
|
-
plans += content_view_migrations_for(root)
|
44
|
-
end
|
45
|
-
plans.compact.sort_by { |plan| plan[:name] }
|
46
|
-
end
|
47
|
-
|
48
|
-
# plugins: [
|
49
|
-
# type: TYPE
|
50
|
-
# repositories: [
|
51
|
-
# {
|
52
|
-
# name: FOO,
|
53
|
-
# pulp2_importer_repository_id: STRING,
|
54
|
-
# repository_versions: [
|
55
|
-
# {
|
56
|
-
# pulp2_repository_id: STRING
|
57
|
-
# pulp2_distributor_repository_ids: [STRING, STRING]
|
58
|
-
# }
|
59
|
-
# ]
|
60
|
-
# }
|
61
|
-
# ]
|
62
|
-
# ]
|
63
|
-
|
64
|
-
def library_migration_for(root)
|
65
|
-
repo = root.library_instance
|
66
|
-
|
67
|
-
return nil unless library_repo_safe_to_migrate?(repo)
|
68
|
-
|
69
|
-
migration = {
|
70
|
-
name: repo.pulp_id,
|
71
|
-
repository_versions: [
|
72
|
-
{
|
73
|
-
pulp2_repository_id: repo.pulp_id,
|
74
|
-
pulp2_distributor_repository_ids: [repo.pulp_id]
|
75
|
-
}
|
76
|
-
]
|
77
|
-
}
|
78
|
-
migration[:pulp2_importer_repository_id] = repo.pulp_id
|
79
|
-
migration
|
80
|
-
end
|
81
|
-
|
82
|
-
def library_repo_safe_to_migrate?(repo)
|
83
|
-
publish_tasks = ForemanTasks::Task.where(label: 'Actions::Katello::ContentView::Publish')
|
84
|
-
publishing_repo_ids = publish_tasks.where(state: ['scheduled', 'running']).collect do |task|
|
85
|
-
::Katello::ContentViewVersion.find(task.input[:content_view_version_id]).library_repos.pluck(:id)
|
86
|
-
end
|
87
|
-
publishing_repo_ids = publishing_repo_ids.flatten
|
88
|
-
|
89
|
-
if publishing_repo_ids.include?(repo.id)
|
90
|
-
warn_string = "Library repository with ID #{repo.id} and name #{repo.name} unmigrated due to being "\
|
91
|
-
"associated with an actively-publishing content view. The migration will need to be run again."
|
92
|
-
Rails.logger.warn(warn_string)
|
93
|
-
return false
|
94
|
-
end
|
95
|
-
|
96
|
-
create_root_tasks = ForemanTasks::Task.where(label: 'Actions::Katello::Repository::CreateRoot')
|
97
|
-
active_creation_task = create_root_tasks.where(state: ['scheduled', 'running']).detect do |task|
|
98
|
-
task.input[:repository][:id] == repo.id
|
99
|
-
end
|
100
|
-
|
101
|
-
if active_creation_task.present?
|
102
|
-
warn_string = "Repository with ID #{repo.id} and name #{repo.name} unmigrated due to being "\
|
103
|
-
"created during the Pulp 3 migration. The migration will need to be run again."
|
104
|
-
Rails.logger.warn(warn_string)
|
105
|
-
return false
|
106
|
-
end
|
107
|
-
true
|
108
|
-
end
|
109
|
-
|
110
|
-
def content_view_migrations_for(root)
|
111
|
-
publish_tasks = ForemanTasks::Task.where(label: 'Actions::Katello::ContentView::Publish')
|
112
|
-
publishing_cv_ids = publish_tasks.where(state: ['scheduled', 'running']).collect do |task|
|
113
|
-
task.input[:content_view_id]
|
114
|
-
end
|
115
|
-
|
116
|
-
plans = []
|
117
|
-
ContentView.non_default.published_with_repositories(root).sort_by(&:label).each do |cv|
|
118
|
-
if publishing_cv_ids.include?(cv.id)
|
119
|
-
warn_string = "Repositories belonging to Content View with ID #{cv.id} and name #{cv.name} unmigrated "\
|
120
|
-
"due to being created during the Pulp 3 migration. The migration will need to be run again."
|
121
|
-
Rails.logger.warn(warn_string)
|
122
|
-
else
|
123
|
-
plans << content_view_migration(cv, root)
|
124
|
-
end
|
125
|
-
end
|
126
|
-
plans
|
127
|
-
end
|
128
|
-
|
129
|
-
#since we don't have an easy to look up all 'link' repos for a target, lets
|
130
|
-
# pre-generate a map of all target_repo => link_repos
|
131
|
-
# This is a fairly inefficient way to do this, but its quite a complex calculation to use AR
|
132
|
-
def target_link_map
|
133
|
-
return @target_link_map if @target_link_map
|
134
|
-
|
135
|
-
map = {}
|
136
|
-
composites_with_repo = ::Katello::ContentViewVersion.where(:content_view_id => ContentView.composite)
|
137
|
-
env_repos = Katello::Repository.yum_type.where(:content_view_version_id => composites_with_repo)
|
138
|
-
env_repos.each do |link_repo|
|
139
|
-
if link_repo.link?
|
140
|
-
target = link_repo.target_repository
|
141
|
-
map[target] ||= []
|
142
|
-
map[target] << link_repo
|
143
|
-
end
|
144
|
-
end
|
145
|
-
@target_link_map = map
|
146
|
-
end
|
147
|
-
|
148
|
-
def name_for_content_view(content_view, root_repo)
|
149
|
-
"#{content_view.label}-#{root_repo.label}"
|
150
|
-
end
|
151
|
-
|
152
|
-
def content_view_migration(content_view, root)
|
153
|
-
plan = {
|
154
|
-
name: name_for_content_view(content_view, root),
|
155
|
-
repository_versions: []
|
156
|
-
}
|
157
|
-
library_instance = root.library_instance
|
158
|
-
content_view.versions.with_library_repo(library_instance).uniq.each do |version|
|
159
|
-
archived_repo = version.archived_repos.find_by(:library_instance_id => library_instance.id)
|
160
|
-
next if archived_repo.link?
|
161
|
-
|
162
|
-
env_repos = version.repositories.where(:library_instance_id => library_instance.id)
|
163
|
-
env_repos += target_link_map[archived_repo] if target_link_map[archived_repo]
|
164
|
-
|
165
|
-
plan[:repository_versions] << {
|
166
|
-
pulp2_repository_id: archived_repo.pulp_id,
|
167
|
-
pulp2_distributor_repository_ids: env_repos.map(&:pulp_id).uniq.sort
|
168
|
-
}
|
169
|
-
end
|
170
|
-
|
171
|
-
if plan[:repository_versions].any?
|
172
|
-
plan[:repository_versions].sort_by! { |v| v[:pulp2_repository_id] }
|
173
|
-
plan
|
174
|
-
end
|
175
|
-
end
|
176
|
-
end
|
177
|
-
end
|
178
|
-
end
|