katello 4.4.1 → 4.5.0
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/activation_key_edit.js +9 -2
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +3 -0
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +5 -1
- data/app/controllers/katello/api/v2/alternate_content_sources_bulk_actions_controller.rb +44 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +121 -0
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +39 -3
- data/app/controllers/katello/api/v2/content_exports_controller.rb +19 -0
- data/app/controllers/katello/api/v2/content_imports_controller.rb +13 -16
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_repositories_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +0 -12
- data/app/controllers/katello/api/v2/content_views_controller.rb +13 -0
- data/app/controllers/katello/api/v2/environments_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +8 -2
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +25 -3
- data/app/controllers/katello/api/v2/organizations_controller.rb +4 -2
- data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +40 -7
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +2 -2
- data/app/controllers/katello/concerns/api/v2/hosts_controller_extensions.rb +1 -1
- data/app/helpers/katello/concerns/smart_proxy_helper_extensions.rb +4 -0
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +21 -3
- data/app/lib/actions/katello/alternate_content_source/create.rb +24 -0
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +27 -0
- data/app/lib/actions/katello/alternate_content_source/refresh.rb +27 -0
- data/app/lib/actions/katello/alternate_content_source/update.rb +41 -0
- data/app/lib/actions/katello/cdn_configuration/update.rb +3 -3
- data/app/lib/actions/katello/content_view/destroy.rb +2 -1
- data/app/lib/actions/katello/content_view/incremental_updates.rb +7 -3
- data/app/lib/actions/katello/content_view/publish.rb +8 -10
- data/app/lib/actions/katello/content_view_version/auto_create_products.rb +4 -4
- data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/import.rb +25 -22
- data/app/lib/actions/katello/content_view_version/import_library.rb +0 -1
- data/app/lib/actions/katello/content_view_version/import_repository.rb +21 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +85 -93
- data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +2 -2
- data/app/lib/actions/katello/organization/manifest_refresh.rb +1 -1
- data/app/lib/actions/katello/product/content_create.rb +10 -8
- data/app/lib/actions/katello/repository/destroy.rb +36 -12
- data/app/lib/actions/katello/repository_set/disable_repository.rb +8 -3
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +23 -0
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +17 -0
- data/app/lib/actions/pulp3/content_view_version/{import.rb → create_import.rb} +5 -5
- data/app/lib/actions/pulp3/content_view_version/create_importer.rb +4 -3
- data/app/lib/actions/pulp3/content_view_version/destroy_importer.rb +12 -1
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +16 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +23 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +15 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +16 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +51 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +5 -2
- data/app/lib/actions/pulp3/repository/save_artifact.rb +1 -1
- data/app/lib/katello/api/v2/error_handling.rb +1 -0
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +24 -11
- data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -1
- data/app/lib/katello/util/errata.rb +2 -3
- data/app/lib/katello/validators/alternate_content_source_path_validator.rb +29 -0
- data/app/lib/katello/validators/content_default_http_proxy_setting_validator.rb +12 -0
- data/app/lib/katello/validators/content_view_environment_validator.rb +10 -5
- data/app/models/katello/alternate_content_source.rb +71 -0
- data/app/models/katello/authorization/alternate_content_source.rb +33 -0
- data/app/models/katello/authorization/repository.rb +5 -3
- data/app/models/katello/candlepin/repository_mapper.rb +13 -6
- data/app/models/katello/cdn_configuration.rb +15 -15
- data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -0
- data/app/models/katello/concerns/host_managed_extensions.rb +7 -6
- data/app/models/katello/concerns/http_proxy_extensions.rb +14 -0
- data/app/models/katello/concerns/organization_extensions.rb +4 -2
- data/app/models/katello/concerns/setting_extensions.rb +14 -0
- data/app/models/katello/concerns/smart_proxy_extensions.rb +2 -1
- data/app/models/katello/content.rb +1 -0
- data/app/models/katello/content_credential.rb +6 -0
- data/app/models/katello/content_override.rb +7 -3
- data/app/models/katello/content_view.rb +33 -2
- data/app/models/katello/content_view_erratum_filter.rb +26 -12
- data/app/models/katello/content_view_filter.rb +4 -0
- data/app/models/katello/content_view_version.rb +12 -0
- data/app/models/katello/content_view_version_export_history.rb +3 -1
- data/app/models/katello/erratum.rb +9 -5
- data/app/models/katello/events/delete_latest_content_view_version.rb +40 -0
- data/app/models/katello/host/content_facet.rb +14 -0
- data/app/models/katello/host_available_module_stream.rb +12 -0
- data/app/models/katello/product_content.rb +1 -0
- data/app/models/katello/purpose_sla_status.rb +1 -1
- data/app/models/katello/purpose_status.rb +2 -2
- data/app/models/katello/repository.rb +7 -4
- data/app/models/katello/root_repository.rb +1 -1
- data/app/models/katello/smart_proxy_alternate_content_source.rb +8 -0
- data/app/models/katello/sync_plan.rb +1 -1
- data/app/presenters/katello/product_content_presenter.rb +15 -0
- data/app/services/katello/applicable_host_queue.rb +1 -1
- data/app/services/katello/product_content_finder.rb +12 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +123 -0
- data/app/services/katello/pulp3/api/file.rb +8 -0
- data/app/services/katello/pulp3/api/yum.rb +8 -0
- data/app/services/katello/pulp3/content_view_version/export.rb +27 -5
- data/app/services/katello/pulp3/content_view_version/import.rb +104 -71
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +4 -4
- data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +13 -11
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +67 -72
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +40 -24
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +102 -38
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +2 -2
- data/app/services/katello/pulp3/content_view_version/metadata_map.rb +117 -0
- data/app/services/katello/pulp3/pulp_content_unit.rb +6 -1
- data/app/services/katello/pulp3/repository/yum.rb +70 -12
- data/app/services/katello/pulp3/repository.rb +6 -62
- data/app/services/katello/pulp3/service_common.rb +66 -0
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +4 -1
- data/app/services/katello/ui_notifications/content_view/delete_latest_version_failure.rb +22 -0
- data/app/views/foreman/job_templates/change_content_source.erb +1 -1
- data/app/views/foreman/job_templates/install_errata.erb +5 -5
- data/app/views/foreman/job_templates/install_errata_by_search_query.erb +10 -8
- data/app/views/foreman/job_templates/install_group.erb +4 -4
- data/app/views/foreman/job_templates/install_package.erb +4 -4
- data/app/views/foreman/job_templates/install_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/remove_group.erb +4 -4
- data/app/views/foreman/job_templates/remove_package.erb +4 -4
- data/app/views/foreman/job_templates/remove_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/resolve_traces.erb +2 -2
- data/app/views/foreman/job_templates/restart_services.erb +3 -3
- data/app/views/foreman/job_templates/update_group.erb +4 -4
- data/app/views/foreman/job_templates/update_package.erb +4 -4
- data/app/views/foreman/job_templates/update_packages_by_search_query.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +24 -0
- data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +7 -0
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +3 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_facet/show.json.rabl +12 -0
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +2 -3
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +1 -1
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
- data/app/views/katello/api/v2/environments/show.json.rabl +2 -0
- data/app/views/katello/api/v2/errata/_counts.json.rabl +2 -2
- data/app/views/katello/api/v2/host_module_streams/base.json.rabl +2 -2
- data/app/views/katello/api/v2/hosts/host_collections.json.rabl +1 -1
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +2 -1
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/sync_management/_repo.html.erb +8 -29
- data/config/routes/api/v2.rb +19 -0
- data/db/migrate/20150930183738_migrate_content_hosts.rb +0 -399
- data/db/migrate/20171025163149_remove_use_pulp_oauth_setting.rb +1 -1
- data/db/migrate/20171114150937_cleanup_installed_packages.rb +1 -1
- data/db/migrate/20180402160223_clean_up_force_post_sync_action_setting.rb +1 -1
- data/db/migrate/20211129200124_remove_dependency_solving_algorithm_setting.rb +1 -1
- data/db/migrate/20211220185935_clean_duplicate_content_units.rb +1 -1
- data/db/migrate/20220110223754_update_disconnected_settings.rb +5 -5
- data/db/migrate/20220117151612_add_alternate_content_sources.rb +48 -0
- data/db/migrate/20220124191056_add_type_to_cdn_configuration.rb +9 -4
- data/db/migrate/20220209203251_add_generated_for_to_content_views.rb +13 -0
- data/db/migrate/20220209205137_expand_sync_timeout_settings.rb +7 -7
- data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +12 -0
- data/db/migrate/20220303160220_remove_duplicate_errata.rb +1 -1
- data/db/migrate/20220404190836_delete_old_setting_data.rb +9 -0
- data/db/migrate/20220405220616_update_cdn_configuration_type.rb +11 -0
- data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +5 -0
- data/db/migrate/20220428203334_add_last_refreshed_to_katello_alternate_content_sources.rb +5 -0
- data/db/seeds.d/110-content-view-autopublish.rb +13 -0
- data/db/seeds.d/150-module_job_templates.rb +1 -1
- data/engines/bastion/README.md +1 -0
- data/engines/bastion/app/assets/javascripts/bastion/components/bst-modal.directive.js +1 -0
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/activation-keys.routes.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +11 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-module-streams.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages.controller.js +11 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-traces.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-deb-repositories.html +26 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-debs.html +27 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +22 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +13 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +63 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +7 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +10 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +21 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +8 -12
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +7 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/discovery-create.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/views/discovery-create.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.routes.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +6 -1
- data/lib/katello/engine.rb +1 -5
- data/lib/katello/permission_creator.rb +34 -4
- data/lib/katello/plugin.rb +377 -3
- data/lib/katello/tasks/refresh_alternate_content_sources.rake +15 -0
- data/lib/katello/tasks/reset.rake.bak +67 -0
- data/lib/katello/tasks/update_content_default_http_proxy.rake +2 -3
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +47 -41
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/bn/katello.po +820 -106
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/katello.po +818 -104
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/katello.po +893 -179
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/katello.po +817 -103
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/katello.po +882 -168
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/katello.po +1219 -505
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/katello.po +826 -112
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/katello.po +826 -112
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/katello.po +863 -148
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/katello.po +1216 -499
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +3847 -2507
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/katello.po +826 -112
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/katello.po +912 -198
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/katello.po +826 -112
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/katello.po +826 -112
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/katello.po +826 -112
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/katello.po +817 -103
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/katello.po +879 -165
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/katello.po +927 -213
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/katello.po +820 -106
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/katello.po +826 -112
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/katello.po +1202 -486
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/katello.po +856 -142
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/webpack/components/Bookmark/index.js +22 -14
- data/webpack/components/EditableTextInput/EditableTextInput.js +20 -5
- data/webpack/components/Errata/index.js +38 -8
- data/webpack/components/Packages/index.js +1 -4
- data/webpack/components/Search/Search.js +22 -3
- data/webpack/components/SelectAllCheckbox/index.js +1 -0
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +4 -2
- data/webpack/components/Table/EmptyStateMessage.js +21 -7
- data/webpack/components/Table/MainTable.js +29 -4
- data/webpack/components/Table/MainTable.scss +5 -1
- data/webpack/components/Table/TableHooks.js +65 -20
- data/webpack/components/Table/TableWrapper.js +9 -3
- data/webpack/components/Table/components/SortableColumnHeaders.js +19 -0
- data/webpack/components/Table/components/TranslatedPlural.js +57 -0
- data/webpack/components/TypeAhead/TypeAhead.js +12 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +13 -11
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +7 -2
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +27 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +250 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +232 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewActions.js +19 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewConstants.js +2 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +131 -0
- data/webpack/components/extensions/HostDetails/Cards/{__tests__ → ContentViewDetailsCard/__tests__}/contentViewDetailsCard.test.js +22 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +443 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/envPaths.fixtures.json +320 -0
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +57 -33
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +3 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsActions.js +30 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +206 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsConstants.js +7 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +227 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsSelectors.js +18 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/availableHostCollections.fixtures.json +106 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +118 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +235 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/removableHostCollections.fixtures.json +45 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +33 -8
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +44 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RecentCommunicationCardExtensions.js +37 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +107 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +38 -0
- data/webpack/components/extensions/HostDetails/HostDetailsActions.js +11 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/SecondaryTabsRoutes.js +4 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/constants.js +2 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/index.js +6 -1
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +176 -72
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/HostErrataActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsActions.js +1 -3
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsConstants.js +28 -0
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +522 -118
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +6 -4
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +164 -58
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +59 -49
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionHooks.js +85 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsActions.js +33 -54
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsConstants.js +20 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +298 -107
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +14 -7
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/HostTracesActions.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +104 -0
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +134 -57
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +37 -32
- data/webpack/components/extensions/HostDetails/Tabs/{ModuleStreamsTab/__tests__/modules.fixtures.json → __tests__/moduleStreams.fixtures.json} +6 -3
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +261 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +21 -15
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +44 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +4 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +105 -6
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +25 -6
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +6 -0
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +18 -0
- data/webpack/containers/Application/config.js +5 -0
- data/webpack/global_index.js +32 -9
- data/webpack/global_test_setup.js +13 -0
- data/webpack/redux/actions/RedHatRepositories/enabled.js +2 -1
- data/webpack/redux/actions/RedHatRepositories/helpers.js +13 -8
- data/webpack/scenes/AlternateContentSources/ACSActions.js +65 -0
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +18 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +23 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +24 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateContext.js +4 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +160 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +79 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +199 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +104 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +41 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +71 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +57 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +77 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +149 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreateData.fixtures.json +3 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/contentCredentials.fixtures.json +69 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/smartProxy.fixtures.json +65 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +162 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +91 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +67 -0
- data/webpack/scenes/AlternateContentSources/index.js +4 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +1 -0
- data/webpack/scenes/Content/Table/ContentTable.js +1 -0
- data/webpack/scenes/ContentCredentials/ContentCredentialSelectors.js +4 -1
- data/webpack/scenes/ContentViews/ContentViewsActions.js +6 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +11 -3
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +2 -1
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +10 -1
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +2 -1
- data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +7 -5
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionFinish.js +29 -21
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +15 -8
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +2 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +2 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +3 -1
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +34 -8
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +33 -29
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +130 -79
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +16 -2
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +6 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +41 -21
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +38 -20
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +8 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +9 -1
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/Rules/ContainerTag/AddEditContainerTagRuleModal.js +27 -12
- data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +39 -17
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +27 -10
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +46 -23
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +3 -2
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +5 -2
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +161 -108
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +7 -7
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +58 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteContextWrapper.js +45 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteHelpers.js +30 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +56 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +126 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/FinishBulkDelete.js +61 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +196 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +220 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +104 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +122 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteVersions.fixtures.json +600 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentView.fixtures.json +1504 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentViewVersion.fixtures.json +936 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/environmentPaths.fixtures.json +261 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/hosts.fixtures.json +163 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/bulkDeleteSteps.js +79 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +192 -167
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +2 -5
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionDeleteFinish.js +38 -53
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +1 -1
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +6 -12
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +8 -20
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +23 -13
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.fixtures.json +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +0 -3
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +12 -14
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +96 -117
- data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +13 -19
- data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +9 -20
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +165 -148
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +2 -0
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +14 -3
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +10 -6
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +6 -1
- data/webpack/scenes/ContentViews/components/TaskPresenter/TaskPresenter.js +40 -35
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +2 -2
- data/webpack/scenes/ContentViews/helpers.js +3 -0
- data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +5 -0
- data/webpack/scenes/RedHatRepositories/RedHatRepositoriesPage.js +3 -3
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepository.js +2 -1
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/EnabledRepository.test.js +2 -0
- data/webpack/scenes/RedHatRepositories/components/Search.js +4 -4
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +9 -2
- data/webpack/scenes/SmartProxy/SmartProxyContentConstants.js +1 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentSelectors.js +10 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +3 -3
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{AirGappedTypeForm.js → ExportSyncForm.js} +7 -6
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{UpstreamServerTypeForm.js → NetworkSyncForm.js} +15 -7
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{AirGappedTypeForm.test.js → ExportSyncForm.test.js} +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{UpstreamServerTypeForm.test.js → NetworkSyncForm.test.js} +8 -8
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +11 -11
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +1 -0
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +8 -7
- data/webpack/scenes/Tasks/TaskActions.js +6 -0
- data/webpack/scenes/Tasks/TaskSelectors.js +11 -0
- data/webpack/scenes/Tasks/helpers.js +60 -5
- data/webpack/utils/helpers.js +2 -0
- metadata +183 -38
- data/app/models/setting/content.rb +0 -201
- data/db/seeds.d/107-enable_dynflow.rb +0 -8
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +0 -96
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/moduleStreamsTab.test.js +0 -108
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerEmptyState.js +0 -42
- data/webpack/scenes/ContentViews/Details/DetailsContainer.js +0 -36
@@ -0,0 +1,123 @@
|
|
1
|
+
require "pulpcore_client"
|
2
|
+
module Katello
|
3
|
+
module Pulp3
|
4
|
+
class AlternateContentSource
|
5
|
+
include Katello::Pulp3::ServiceCommon
|
6
|
+
attr_accessor :acs
|
7
|
+
attr_accessor :smart_proxy
|
8
|
+
|
9
|
+
def initialize(acs, smart_proxy)
|
10
|
+
@acs = acs
|
11
|
+
@smart_proxy = smart_proxy
|
12
|
+
end
|
13
|
+
|
14
|
+
def api
|
15
|
+
@api ||= ::Katello::Pulp3::Repository.api(smart_proxy, @acs.content_type)
|
16
|
+
end
|
17
|
+
|
18
|
+
def generate_backend_object_name
|
19
|
+
"#{acs.label}-#{smart_proxy.url}-#{rand(9999)}"
|
20
|
+
end
|
21
|
+
|
22
|
+
def smart_proxy_acs
|
23
|
+
::Katello::SmartProxyAlternateContentSource.find_by(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id)
|
24
|
+
end
|
25
|
+
|
26
|
+
def remote_options
|
27
|
+
remote_options = {
|
28
|
+
tls_validation: acs.verify_ssl,
|
29
|
+
name: generate_backend_object_name,
|
30
|
+
url: acs.base_url,
|
31
|
+
policy: 'on_demand',
|
32
|
+
proxy_url: acs.http_proxy&.url,
|
33
|
+
proxy_username: acs.http_proxy&.username,
|
34
|
+
proxy_password: acs.http_proxy&.password,
|
35
|
+
total_timeout: Setting[:sync_connect_timeout]
|
36
|
+
}
|
37
|
+
if acs.content_type == ::Katello::Repository::FILE_TYPE && acs.subpaths.empty? && !remote_options[:url].end_with?('/PULP_MANIFEST')
|
38
|
+
remote_options[:url] = acs.base_url + '/PULP_MANIFEST'
|
39
|
+
end
|
40
|
+
remote_options.merge!(username: acs&.upstream_username, password: acs&.upstream_password)
|
41
|
+
remote_options.merge!(ssl_remote_options)
|
42
|
+
end
|
43
|
+
|
44
|
+
def ssl_remote_options
|
45
|
+
if acs.custom?
|
46
|
+
{
|
47
|
+
client_cert: acs.ssl_client_cert&.content,
|
48
|
+
client_key: acs.ssl_client_key&.content,
|
49
|
+
ca_cert: acs.ssl_ca_cert&.content
|
50
|
+
}
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
def create_remote
|
55
|
+
if smart_proxy_acs&.remote_href.nil?
|
56
|
+
response = super
|
57
|
+
smart_proxy_acs.update!(remote_href: response.pulp_href)
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
def get_remote(href = smart_proxy_acs.remote_href)
|
62
|
+
acs.base_url&.start_with?('uln') ? api.remotes_uln_api.read(href) : api.remotes_api.read(href)
|
63
|
+
end
|
64
|
+
|
65
|
+
def update_remote
|
66
|
+
api.remotes_api.partial_update(smart_proxy_acs.remote_href, remote_options)
|
67
|
+
end
|
68
|
+
|
69
|
+
def delete_remote(href = smart_proxy_acs.remote_href)
|
70
|
+
ignore_404_exception { remote_options[:url]&.start_with?('uln') ? api.remotes_uln_api.delete(href) : api.remotes_api.delete(href) } if href
|
71
|
+
end
|
72
|
+
|
73
|
+
def create
|
74
|
+
if smart_proxy_acs&.alternate_content_source_href.nil?
|
75
|
+
paths = acs.subpaths.deep_dup
|
76
|
+
if acs.content_type == ::Katello::Repository::FILE_TYPE && acs.subpaths.present?
|
77
|
+
paths = insert_pulp_manifest!(paths)
|
78
|
+
end
|
79
|
+
response = api.alternate_content_source_api.create(name: generate_backend_object_name, paths: paths,
|
80
|
+
remote: smart_proxy_acs.remote_href)
|
81
|
+
smart_proxy_acs.update!(alternate_content_source_href: response.pulp_href)
|
82
|
+
return response
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
def read(href = smart_proxy_acs.alternate_content_source_href)
|
87
|
+
api.alternate_content_source_api.read(href)
|
88
|
+
end
|
89
|
+
|
90
|
+
def update
|
91
|
+
href = smart_proxy_acs.alternate_content_source_href
|
92
|
+
paths = acs.subpaths.deep_dup
|
93
|
+
if acs.content_type == ::Katello::Repository::FILE_TYPE && acs.subpaths.present?
|
94
|
+
paths = insert_pulp_manifest!(paths)
|
95
|
+
end
|
96
|
+
api.alternate_content_source_api.update(href, name: generate_backend_object_name, paths: paths, remote: smart_proxy_acs.remote_href)
|
97
|
+
end
|
98
|
+
|
99
|
+
def delete_alternate_content_source
|
100
|
+
href = smart_proxy_acs.alternate_content_source_href
|
101
|
+
ignore_404_exception { api.alternate_content_source_api.delete(href) } if href
|
102
|
+
end
|
103
|
+
|
104
|
+
def refresh
|
105
|
+
href = smart_proxy_acs.alternate_content_source_href
|
106
|
+
# https://github.com/pulp/pulp_rpm/issues/2504
|
107
|
+
api.alternate_content_source_api.refresh(href, 'placeholder')
|
108
|
+
end
|
109
|
+
|
110
|
+
private
|
111
|
+
|
112
|
+
def insert_pulp_manifest!(subpaths)
|
113
|
+
subpaths.map! do |subpath|
|
114
|
+
if subpath.end_with?('/PULP_MANIFEST')
|
115
|
+
subpath
|
116
|
+
else
|
117
|
+
subpath + '/PULP_MANIFEST'
|
118
|
+
end
|
119
|
+
end
|
120
|
+
end
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
@@ -7,6 +7,14 @@ module Katello
|
|
7
7
|
def self.add_remove_content_class
|
8
8
|
PulpFileClient::RepositoryAddRemoveContent
|
9
9
|
end
|
10
|
+
|
11
|
+
def self.alternate_content_source_class
|
12
|
+
PulpFileClient::FileFileAlternateContentSource
|
13
|
+
end
|
14
|
+
|
15
|
+
def alternate_content_source_api
|
16
|
+
PulpFileClient::AcsFileApi.new(api_client)
|
17
|
+
end
|
10
18
|
end
|
11
19
|
end
|
12
20
|
end
|
@@ -20,6 +20,14 @@ module Katello
|
|
20
20
|
PulpRpmClient::RepositoryAddRemoveContent
|
21
21
|
end
|
22
22
|
|
23
|
+
def self.alternate_content_source_class
|
24
|
+
PulpRpmClient::RpmRpmAlternateContentSource
|
25
|
+
end
|
26
|
+
|
27
|
+
def alternate_content_source_api
|
28
|
+
PulpRpmClient::AcsRpmApi.new(api_client)
|
29
|
+
end
|
30
|
+
|
23
31
|
def remotes_uln_api
|
24
32
|
PulpRpmClient::RemotesUlnApi.new(api_client)
|
25
33
|
end
|
@@ -46,7 +46,7 @@ module Katello
|
|
46
46
|
end
|
47
47
|
|
48
48
|
def create_exporter(export_base_dir: Setting['pulpcore_export_destination'])
|
49
|
-
api.exporter_api.create(name: generate_id,
|
49
|
+
api.exporter_api.create(name: generate_id(content_view_version),
|
50
50
|
path: "#{export_base_dir}/#{generate_exporter_path}",
|
51
51
|
repositories: repository_hrefs)
|
52
52
|
end
|
@@ -150,13 +150,35 @@ module Katello
|
|
150
150
|
MetadataGenerator.new(export_service: self).generate!
|
151
151
|
end
|
152
152
|
|
153
|
+
def self.find_generated_export_view(create_by_default: false,
|
154
|
+
destination_server:,
|
155
|
+
organization:,
|
156
|
+
name:,
|
157
|
+
generated_for:)
|
158
|
+
name += "-#{destination_server}" unless destination_server.blank?
|
159
|
+
select_method = create_by_default ? :first_or_create : :first
|
160
|
+
::Katello::ContentView.where(name: name,
|
161
|
+
organization: organization,
|
162
|
+
generated_for: generated_for).send(select_method)
|
163
|
+
end
|
164
|
+
|
153
165
|
def self.find_library_export_view(create_by_default: false,
|
154
166
|
destination_server:,
|
155
167
|
organization:)
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
168
|
+
find_generated_export_view(create_by_default: create_by_default,
|
169
|
+
destination_server: destination_server,
|
170
|
+
organization: organization,
|
171
|
+
name: ::Katello::ContentView::EXPORT_LIBRARY,
|
172
|
+
generated_for: :library_export)
|
173
|
+
end
|
174
|
+
|
175
|
+
def self.find_repository_export_view(create_by_default: false,
|
176
|
+
repository:)
|
177
|
+
find_generated_export_view(create_by_default: create_by_default,
|
178
|
+
destination_server: nil,
|
179
|
+
organization: repository.organization,
|
180
|
+
name: "Export-#{repository.label}-#{repository.library_instance_or_self.id}",
|
181
|
+
generated_for: :repository_export)
|
160
182
|
end
|
161
183
|
|
162
184
|
def self.generate_product_repo_strings(repositories:)
|
@@ -4,33 +4,23 @@ module Katello
|
|
4
4
|
class Import
|
5
5
|
include ImportExportCommon
|
6
6
|
|
7
|
-
|
7
|
+
attr_reader :content_view, :path, :metadata_map, :smart_proxy, :organization
|
8
|
+
|
9
|
+
def initialize(organization:, smart_proxy:, path:, metadata_map:)
|
10
|
+
@organization = organization
|
8
11
|
@smart_proxy = smart_proxy
|
9
|
-
@content_view_version = content_view_version
|
10
12
|
@path = path
|
11
|
-
@
|
13
|
+
@metadata_map = metadata_map
|
14
|
+
@content_view = find_or_create_import_view
|
12
15
|
end
|
13
16
|
|
14
|
-
def
|
15
|
-
|
16
|
-
|
17
|
-
repo = @content_view_version.importable_repositories.joins(:root, :product).
|
18
|
-
where("#{::Katello::Product.table_name}" => {:label => value[:product][:label]},
|
19
|
-
"#{::Katello::RootRepository.table_name}" => {:label => value[:label]}).first
|
20
|
-
next unless repo&.version_href
|
21
|
-
repo_info = fetch_repository_info(repo.version_href)
|
22
|
-
mapping[key] = repo_info.name
|
23
|
-
end
|
24
|
-
mapping
|
25
|
-
end
|
26
|
-
|
27
|
-
def create_importer
|
28
|
-
api.importer_api.create(name: generate_id,
|
29
|
-
repo_mapping: repository_mapping)
|
17
|
+
def create_importer(content_view_version)
|
18
|
+
api.importer_api.create(name: generate_id(content_view_version),
|
19
|
+
repo_mapping: repository_mapping(content_view_version))
|
30
20
|
end
|
31
21
|
|
32
22
|
def create_import(importer_href)
|
33
|
-
[api.import_api.create(importer_href, toc: "#{@path}/#{@
|
23
|
+
[api.import_api.create(importer_href, toc: "#{@path}/#{@metadata_map.toc}")]
|
34
24
|
end
|
35
25
|
|
36
26
|
def fetch_import(importer_href)
|
@@ -43,53 +33,32 @@ module Katello
|
|
43
33
|
api.importer_api.delete(importer_href)
|
44
34
|
end
|
45
35
|
|
46
|
-
def
|
47
|
-
ImportValidator.new(
|
48
|
-
content_view: content_view,
|
49
|
-
metadata: metadata,
|
50
|
-
path: path).check!
|
51
|
-
end
|
52
|
-
|
53
|
-
def self.create_or_update_gpg!(organization:, params:)
|
54
|
-
return if params.blank?
|
55
|
-
gpg = organization.gpg_keys.find_by(:name => params[:name])
|
56
|
-
if gpg
|
57
|
-
gpg.update!(params.except(:name))
|
58
|
-
else
|
59
|
-
gpg = organization.gpg_keys.create!(params)
|
60
|
-
end
|
61
|
-
gpg
|
62
|
-
end
|
63
|
-
|
64
|
-
def self.metadata_map(metadata, product_only: false, custom_only: false, redhat_only: false)
|
65
|
-
# Create a map that looks like -> {[product, repo]: {name: 'Foo Repo', label:.....}}
|
66
|
-
# these values should be curated from the metadata.
|
67
|
-
metadata_map = {}
|
68
|
-
metadata[:repositories].values.each do |repo|
|
69
|
-
next if (custom_only && repo[:redhat]) || (redhat_only && !repo[:redhat])
|
70
|
-
if product_only
|
71
|
-
metadata_map[repo[:product][:label]] = repo[:product]
|
72
|
-
else
|
73
|
-
metadata_map[[repo[:product][:label], repo[:label]]] = repo
|
74
|
-
end
|
75
|
-
end
|
76
|
-
metadata_map
|
36
|
+
def check!
|
37
|
+
ImportValidator.new(import: self).check!
|
77
38
|
end
|
78
39
|
|
79
|
-
def
|
40
|
+
def intersecting_repos_library_and_metadata
|
80
41
|
# Returns repositories in library that are part of the metadata
|
81
42
|
# In other words if metadata had repos {label:foo, product: bar}
|
82
43
|
# this would match it to the repo with the label foo and product bar
|
83
44
|
# in the library.
|
84
|
-
queries = metadata_map
|
85
|
-
|
86
|
-
|
87
|
-
|
45
|
+
queries = metadata_map.repositories.map do |repo|
|
46
|
+
if repo.redhat && repo.product.cp_id && repo.content&.id
|
47
|
+
library_repositories.where("#{Katello::Product.table_name}.cp_id": repo.product.cp_id,
|
48
|
+
"#{::Katello::RootRepository.table_name}" => {
|
49
|
+
content_id: repo.content.id,
|
50
|
+
arch: repo.arch,
|
51
|
+
major: repo.major,
|
52
|
+
minor: repo.minor })
|
53
|
+
else
|
54
|
+
library_repositories.where("#{Katello::Product.table_name}.label": repo.product.label,
|
55
|
+
"#{Katello::RootRepository.table_name}.label": repo.label)
|
56
|
+
end
|
88
57
|
end
|
89
58
|
queries.inject(&:or)
|
90
59
|
end
|
91
60
|
|
92
|
-
def
|
61
|
+
def library_repositories
|
93
62
|
Katello::Repository.
|
94
63
|
in_default_view.
|
95
64
|
exportable.
|
@@ -98,7 +67,7 @@ module Katello
|
|
98
67
|
where("#{::Katello::ContentView.table_name}.organization_id": organization)
|
99
68
|
end
|
100
69
|
|
101
|
-
def
|
70
|
+
def reset_content_view_repositories!
|
102
71
|
# Given metadata from the dump and a content view
|
103
72
|
# this method
|
104
73
|
# 1) Fetches ids of the library repos whose product name, repo name amd redhat?
|
@@ -107,26 +76,90 @@ module Katello
|
|
107
76
|
# 3) Adds the repositories matched from the dump
|
108
77
|
# The main intent of this method is to assume that the user intends for the
|
109
78
|
# content view to exaclty look like what is specified in metadata
|
110
|
-
repo_ids = intersecting_repos_library_and_metadata(
|
111
|
-
metadata: metadata).
|
112
|
-
pluck("#{Katello::Repository.table_name}.id")
|
79
|
+
repo_ids = intersecting_repos_library_and_metadata.pluck("#{Katello::Repository.table_name}.id")
|
113
80
|
content_view.update!(repository_ids: repo_ids)
|
114
81
|
end
|
115
82
|
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
83
|
+
private
|
84
|
+
|
85
|
+
def repository_mapping(content_view_version)
|
86
|
+
mapping = {}
|
87
|
+
relation = content_view_version.importable_repositories.joins(:root, :product)
|
88
|
+
|
89
|
+
metadata_map.repositories.each do |metadata_repo|
|
90
|
+
if metadata_repo.redhat && metadata_repo.product.cp_id && metadata_repo.content&.id
|
91
|
+
repo = relation.where("#{::Katello::Product.table_name}" => {cp_id: metadata_repo.product.cp_id},
|
92
|
+
"#{::Katello::RootRepository.table_name}" => {
|
93
|
+
content_id: metadata_repo.content.id,
|
94
|
+
arch: metadata_repo.arch,
|
95
|
+
major: metadata_repo.major,
|
96
|
+
minor: metadata_repo.minor}).first
|
97
|
+
else
|
98
|
+
repo = relation.where("#{::Katello::Product.table_name}" => {label: metadata_repo.product.label},
|
99
|
+
"#{::Katello::RootRepository.table_name}" => {label: metadata_repo.label}).first
|
100
|
+
end
|
101
|
+
|
102
|
+
next unless repo&.version_href
|
103
|
+
repo_info = fetch_repository_info(repo.version_href)
|
104
|
+
mapping[metadata_repo.pulp_name] = repo_info.name
|
122
105
|
end
|
106
|
+
mapping
|
107
|
+
end
|
108
|
+
|
109
|
+
def import_cv_name_from_export(name:, generated_for:)
|
110
|
+
if generated_for == :library_import
|
111
|
+
::Katello::ContentView::IMPORT_LIBRARY
|
112
|
+
elsif generated_for == :repository_import
|
113
|
+
name.gsub(/^Export/, 'Import')
|
114
|
+
else
|
115
|
+
name
|
116
|
+
end
|
117
|
+
end
|
118
|
+
|
119
|
+
def import_content_view_params
|
120
|
+
generated_for = metadata_map.content_view.generated_for
|
121
|
+
|
122
|
+
if generated_for.blank?
|
123
|
+
generated_for = if metadata_map.content_view.label.start_with?(::Katello::ContentView::EXPORT_LIBRARY)
|
124
|
+
"library_export"
|
125
|
+
else
|
126
|
+
"none"
|
127
|
+
end
|
128
|
+
end
|
129
|
+
|
130
|
+
generated_for = generated_for.to_sym
|
131
|
+
|
132
|
+
if generated_for == :none
|
133
|
+
return {
|
134
|
+
name: metadata_map.content_view.name,
|
135
|
+
label: metadata_map.content_view.label,
|
136
|
+
description: metadata_map.content_view.description,
|
137
|
+
generated_for: generated_for
|
138
|
+
}
|
139
|
+
end
|
140
|
+
|
141
|
+
if generated_for == :library_export
|
142
|
+
generated_for = :library_import
|
143
|
+
elsif generated_for == :repository_export
|
144
|
+
generated_for = :repository_import
|
145
|
+
end
|
146
|
+
|
147
|
+
{
|
148
|
+
name: import_cv_name_from_export(name: metadata_map.content_view.name, generated_for: generated_for),
|
149
|
+
label: import_cv_name_from_export(name: metadata_map.content_view.label, generated_for: generated_for),
|
150
|
+
description: "Content View used for importing into library",
|
151
|
+
generated_for: generated_for
|
152
|
+
}
|
153
|
+
end
|
123
154
|
|
124
|
-
|
155
|
+
def find_or_create_import_view
|
156
|
+
fail _("Content View label not provided.") if metadata_map.content_view.label.blank?
|
125
157
|
|
126
|
-
|
158
|
+
params = import_content_view_params
|
159
|
+
cv = ::Katello::ContentView.find_by(label: params[:label],
|
127
160
|
organization: organization)
|
128
161
|
if cv.blank?
|
129
|
-
::Katello::ContentView.create!(
|
162
|
+
::Katello::ContentView.create!(params.merge(organization: organization, import_only: true))
|
130
163
|
elsif !cv.import_only?
|
131
164
|
msg = _("Unable to import in to Content View specified in the metadata - '%{name}'. "\
|
132
165
|
"The 'import_only' attribute for the content view is set to false. "\
|
@@ -136,7 +169,7 @@ module Katello
|
|
136
169
|
command = "foreman-rake katello:set_content_view_import_only ID=#{cv.id}"
|
137
170
|
fail msg + "\n" + command
|
138
171
|
else
|
139
|
-
cv.update!(description:
|
172
|
+
cv.update!(description: params[:description]) if cv.description != params[:description]
|
140
173
|
cv
|
141
174
|
end
|
142
175
|
end
|
@@ -2,12 +2,12 @@ module Katello
|
|
2
2
|
module Pulp3
|
3
3
|
module ContentViewVersion
|
4
4
|
module ImportExportCommon
|
5
|
-
def generate_name
|
6
|
-
|
5
|
+
def generate_name(content_view_version)
|
6
|
+
content_view_version.name.gsub(/\s/, '_')
|
7
7
|
end
|
8
8
|
|
9
|
-
def generate_id
|
10
|
-
"#{
|
9
|
+
def generate_id(content_view_version)
|
10
|
+
"#{content_view_version.organization.label}_#{generate_name(content_view_version)}"
|
11
11
|
end
|
12
12
|
|
13
13
|
def api
|
@@ -2,28 +2,30 @@ module Katello
|
|
2
2
|
module Pulp3
|
3
3
|
module ContentViewVersion
|
4
4
|
class ImportGpgKeys
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
self.organization = organization
|
9
|
-
self.metadata = metadata
|
5
|
+
def initialize(organization:, metadata_gpg_keys:)
|
6
|
+
@organization = organization
|
7
|
+
@metadata_gpg_keys = metadata_gpg_keys
|
10
8
|
end
|
11
9
|
|
12
10
|
def create_or_update_gpg!(params)
|
13
|
-
|
14
|
-
gpg = organization.gpg_keys.find_by(:name => params[:name])
|
11
|
+
gpg = @organization.gpg_keys.find_by(:name => params[:name])
|
15
12
|
if gpg
|
16
13
|
gpg.update!(params.except(:name))
|
17
14
|
else
|
18
|
-
gpg = organization.gpg_keys.create!(params)
|
15
|
+
gpg = @organization.gpg_keys.create!(params)
|
19
16
|
end
|
20
17
|
gpg
|
21
18
|
end
|
22
19
|
|
23
20
|
def import!
|
24
|
-
|
25
|
-
|
26
|
-
|
21
|
+
@metadata_gpg_keys.each do |gpg|
|
22
|
+
params = {
|
23
|
+
name: gpg.name,
|
24
|
+
content_type: ::Katello::ContentCredential::GPG_KEY_TYPE,
|
25
|
+
content: gpg.content
|
26
|
+
}
|
27
|
+
|
28
|
+
create_or_update_gpg!(params)
|
27
29
|
end
|
28
30
|
end
|
29
31
|
end
|