katello 4.5.1 → 4.8.0.rc2
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/common/vendor.js +0 -1
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +8 -22
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +10 -0
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +16 -10
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +9 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +59 -24
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +5 -4
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +22 -81
- data/app/controllers/katello/api/v2/content_exports_controller.rb +11 -80
- data/app/controllers/katello/api/v2/content_imports_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -0
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_views_controller.rb +1 -1
- data/app/controllers/katello/api/v2/debs_controller.rb +42 -10
- data/app/controllers/katello/api/v2/exports_controller.rb +130 -0
- data/app/controllers/katello/api/v2/host_collections_controller.rb +5 -1
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -0
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +9 -1
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +17 -10
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +9 -5
- data/app/controllers/katello/api/v2/organizations_controller.rb +7 -1
- data/app/controllers/katello/api/v2/package_groups_controller.rb +0 -52
- data/app/controllers/katello/api/v2/products_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +86 -30
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +25 -14
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +10 -2
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +1 -1
- data/app/controllers/katello/concerns/api/v2/bulk_hosts_extensions.rb +4 -6
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +7 -3
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +34 -11
- data/app/controllers/katello/concerns/api/v2/smart_proxies_controller_extensions.rb +1 -0
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +4 -1
- data/app/controllers/katello/concerns/content_facet_hosts_controller_extensions.rb +24 -0
- data/app/controllers/katello/concerns/hosts_controller_extensions.rb +14 -12
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +7 -16
- data/app/helpers/katello/content_source_helper.rb +11 -0
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +88 -21
- data/app/helpers/katello/katello_urls_helper.rb +0 -15
- data/app/helpers/katello/sync_management_helper.rb +0 -4
- data/app/lib/actions/candlepin/abstract_async_task.rb +7 -3
- data/app/lib/actions/candlepin/environment/set_content.rb +7 -1
- data/app/lib/actions/candlepin/owner/destroy_imports.rb +1 -1
- data/app/lib/actions/candlepin/owner/{upstream_export.rb → retrieve_upstream_export.rb} +3 -3
- data/app/lib/actions/candlepin/owner/start_upstream_export.rb +24 -0
- data/app/lib/actions/candlepin/upstream_abstract_async_task.rb +30 -0
- data/app/lib/actions/katello/activation_key/destroy.rb +1 -0
- data/app/lib/actions/katello/agent_action.rb +1 -0
- data/app/lib/actions/katello/alternate_content_source/alternate_content_source_common.rb +16 -0
- data/app/lib/actions/katello/alternate_content_source/create.rb +13 -5
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +3 -4
- data/app/lib/actions/katello/alternate_content_source/refresh.rb +3 -5
- data/app/lib/actions/katello/alternate_content_source/update.rb +59 -13
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +2 -2
- data/app/lib/actions/katello/capsule_content/sync.rb +10 -6
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +1 -2
- data/app/lib/actions/katello/cdn_configuration/update.rb +1 -1
- data/app/lib/actions/katello/content_view/promote.rb +1 -0
- data/app/lib/actions/katello/content_view/publish.rb +11 -4
- data/app/lib/actions/katello/content_view/remove.rb +8 -2
- data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +7 -3
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +4 -2
- data/app/lib/actions/katello/content_view_version/destroy.rb +1 -1
- data/app/lib/actions/katello/content_view_version/import.rb +22 -10
- data/app/lib/actions/katello/environment/destroy.rb +8 -2
- data/app/lib/actions/katello/host/reassign.rb +4 -2
- data/app/lib/actions/katello/organization/manifest_refresh.rb +20 -11
- data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +1 -9
- data/app/lib/actions/katello/orphan_cleanup/remove_orphans.rb +0 -1
- data/app/lib/actions/katello/product/destroy.rb +3 -2
- data/app/lib/actions/katello/repository/create.rb +9 -0
- data/app/lib/actions/katello/repository/destroy.rb +24 -3
- data/app/lib/actions/katello/repository/errata_mail.rb +9 -6
- data/app/lib/actions/katello/repository/filtered_index_content.rb +2 -10
- data/app/lib/actions/katello/repository/import_upload.rb +0 -1
- data/app/lib/actions/katello/repository/refresh_repository.rb +3 -0
- data/app/lib/actions/katello/repository/sync.rb +15 -9
- data/app/lib/actions/katello/repository/update.rb +39 -3
- data/app/lib/actions/katello/repository/update_redhat_repository.rb +1 -1
- data/app/lib/actions/katello/repository/upload_files.rb +0 -1
- data/app/lib/actions/katello/repository_set/enable_repository.rb +6 -2
- data/app/lib/actions/middleware/propagate_candlepin_errors.rb +6 -1
- data/app/lib/actions/pulp3/abstract.rb +0 -6
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +5 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/refresh_remote.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +4 -4
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +5 -5
- data/app/lib/actions/pulp3/capsule_content/reclaim_space.rb +1 -0
- data/app/lib/actions/pulp3/content_view/delete_repository_references.rb +1 -2
- data/app/lib/actions/pulp3/content_view_version/create_syncable_export_history.rb +4 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +6 -7
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +3 -2
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +3 -3
- 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.rb +12 -11
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +17 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/syncable_export.rb +7 -4
- data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +1 -0
- data/app/lib/actions/pulp3/orchestration/repository/copy_all_units.rb +1 -0
- data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +1 -1
- data/app/lib/actions/pulp3/orphan_cleanup/delete_orphan_alternate_content_sources.rb +16 -0
- data/app/lib/actions/pulp3/repository/reclaim_space.rb +1 -1
- data/app/lib/actions/pulp3/repository/refresh_distribution.rb +1 -2
- data/app/lib/actions/pulp3/repository/repair.rb +1 -1
- data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -2
- data/app/lib/katello/api/v2/error_handling.rb +12 -2
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +8 -4
- data/app/lib/katello/concerns/renderer_extensions.rb +3 -2
- data/app/lib/katello/errors.rb +4 -3
- data/app/lib/katello/event_daemon/runner.rb +12 -9
- data/app/lib/katello/resources/candlepin/consumer.rb +9 -6
- data/app/lib/katello/resources/candlepin/owner.rb +10 -3
- data/app/lib/katello/resources/candlepin/upstream_consumer.rb +4 -5
- data/app/lib/katello/resources/candlepin/upstream_job.rb +28 -0
- data/app/lib/katello/resources/candlepin.rb +11 -5
- data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -13
- data/app/lib/katello/resources/cdn.rb +14 -9
- data/app/lib/katello/util/candlepin_repository_checker.rb +75 -0
- data/app/lib/katello/util/errata.rb +12 -10
- data/app/lib/katello/util/search.rb +0 -1
- data/app/lib/katello/validators/alternate_content_source_products_validator.rb +17 -0
- data/app/lib/katello/validators/content_view_environment_org_validator.rb +5 -2
- data/app/lib/katello/validators/content_view_environment_validator.rb +1 -2
- data/app/lib/katello/validators/generated_content_view_validator.rb +16 -0
- data/app/mailers/katello/errata_mailer.rb +4 -2
- data/app/models/katello/activation_key.rb +12 -1
- data/app/models/katello/alternate_content_source.rb +107 -11
- data/app/models/katello/alternate_content_source_product.rb +13 -0
- data/app/models/katello/authorization/repository.rb +2 -2
- data/app/models/katello/cdn_configuration.rb +12 -3
- data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -14
- data/app/models/katello/concerns/host_managed_extensions.rb +61 -13
- data/app/models/katello/concerns/http_proxy_extensions.rb +5 -10
- data/app/models/katello/concerns/organization_extensions.rb +4 -4
- data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
- data/app/models/katello/concerns/redhat_extensions.rb +16 -6
- data/app/models/katello/concerns/smart_proxy_extensions.rb +36 -34
- data/app/models/katello/concerns/subscription_facet_host_extensions.rb +1 -0
- data/app/models/katello/content.rb +16 -1
- data/app/models/katello/content_credential.rb +8 -9
- data/app/models/katello/content_view.rb +42 -11
- data/app/models/katello/content_view_component.rb +4 -0
- data/app/models/katello/content_view_deb_filter.rb +51 -0
- data/app/models/katello/content_view_deb_filter_rule.rb +24 -0
- data/app/models/katello/content_view_environment.rb +11 -2
- data/app/models/katello/content_view_environment_content_facet.rb +9 -0
- data/app/models/katello/content_view_erratum_filter.rb +5 -4
- data/app/models/katello/content_view_filter.rb +10 -3
- data/app/models/katello/content_view_version.rb +11 -6
- data/app/models/katello/erratum.rb +12 -3
- data/app/models/katello/glue/candlepin/owner.rb +4 -1
- data/app/models/katello/glue/candlepin/pool.rb +6 -0
- data/app/models/katello/glue/candlepin/product.rb +7 -1
- data/app/models/katello/glue/candlepin/subscription.rb +5 -0
- data/app/models/katello/glue/provider.rb +55 -45
- data/app/models/katello/host/content_facet.rb +121 -21
- data/app/models/katello/host/info_provider.rb +25 -21
- data/app/models/katello/host/subscription_facet.rb +18 -14
- data/app/models/katello/installed_package.rb +1 -0
- data/app/models/katello/kt_environment.rb +12 -7
- data/app/models/katello/package_group.rb +0 -12
- data/app/models/katello/pool.rb +4 -1
- data/app/models/katello/product.rb +14 -1
- data/app/models/katello/repository.rb +28 -12
- data/app/models/katello/root_repository.rb +8 -3
- data/app/models/katello/rpm.rb +1 -0
- data/app/models/katello/smart_proxy_alternate_content_source.rb +6 -0
- data/app/models/katello/task_status.rb +0 -18
- data/app/overrides/add_smart_proxy_form.rb +5 -0
- data/app/presenters/katello/content_view_version_compare_presenter.rb +5 -0
- data/app/presenters/katello/host_package_presenter.rb +4 -4
- data/app/services/cert/certs.rb +8 -16
- data/app/services/katello/bulk_items_helper.rb +3 -3
- data/app/services/katello/candlepin/consumer.rb +2 -2
- data/app/services/katello/host/package_profile_uploader.rb +1 -1
- data/app/services/katello/organization_creator.rb +4 -4
- data/app/services/katello/product_content_finder.rb +11 -8
- data/app/services/katello/product_content_importer.rb +61 -5
- data/app/services/katello/pulp3/alternate_content_source.rb +36 -10
- data/app/services/katello/pulp3/ansible_collection.rb +10 -7
- data/app/services/katello/pulp3/api/apt.rb +12 -0
- data/app/services/katello/pulp3/api/core.rb +2 -2
- data/app/services/katello/pulp3/api/generic.rb +0 -4
- data/app/services/katello/pulp3/content_view_version/export.rb +36 -63
- data/app/services/katello/pulp3/content_view_version/export_validation_error.rb +7 -0
- data/app/services/katello/pulp3/content_view_version/export_validator.rb +121 -0
- data/app/services/katello/pulp3/content_view_version/import.rb +2 -0
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +21 -5
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +12 -2
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +38 -9
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +12 -5
- data/app/services/katello/pulp3/content_view_version/metadata_map.rb +13 -2
- data/app/services/katello/pulp3/content_view_version/syncable_format_export.rb +12 -2
- data/app/services/katello/pulp3/docker_manifest.rb +2 -1
- data/app/services/katello/pulp3/docker_manifest_list.rb +2 -1
- data/app/services/katello/pulp3/erratum.rb +1 -0
- data/app/services/katello/pulp3/module_stream.rb +26 -11
- data/app/services/katello/pulp3/pulp_content_unit.rb +3 -0
- data/app/services/katello/pulp3/repository/apt.rb +192 -2
- data/app/services/katello/pulp3/repository/yum.rb +7 -4
- data/app/services/katello/pulp3/repository.rb +26 -11
- data/app/services/katello/pulp3/repository_mirror.rb +1 -0
- data/app/services/katello/pulp3/service_common.rb +1 -1
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +24 -2
- data/app/services/katello/pulp3/task_group.rb +18 -1
- data/app/services/katello/registration_manager.rb +46 -26
- data/app/services/katello/repository_type.rb +7 -10
- data/app/services/katello/repository_type_manager.rb +4 -3
- data/app/services/katello/simple_package.rb +22 -0
- data/app/views/dashboard/_content_views_widget.html.erb +1 -1
- data/app/views/foreman/job_templates/change_content_source.erb +6 -0
- data/app/views/foreman/job_templates/update_packages_by_search_query.erb +7 -1
- data/app/views/foreman/smart_proxies/_content_sync.html.erb +2 -1
- data/app/views/foreman/smart_proxies/_reclaim_space.html.erb +1 -0
- data/app/views/foreman/smart_proxies/show.html.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +19 -4
- data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +1 -0
- data/app/views/katello/api/v2/alternate_content_sources/permissions.rabl +11 -0
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +20 -0
- data/app/views/katello/api/v2/ansible_collections/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_credentials/show.json.rabl +12 -0
- data/app/views/katello/api/v2/content_facet/base.json.rabl +23 -2
- data/app/views/katello/api/v2/content_facet/show.json.rabl +11 -8
- data/app/views/katello/api/v2/content_view_filters/base.json.rabl +5 -0
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -1
- data/app/views/katello/api/v2/content_views/permissions.rabl +1 -0
- data/app/views/katello/api/v2/host_packages/base.json.rabl +1 -1
- data/app/views/katello/api/v2/hosts/base.json.rabl +22 -2
- data/app/views/katello/api/v2/module_streams/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/module_streams/show.json.rabl +7 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repositories/compare.json.rabl +10 -0
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/api/v2/smart_proxies/pulp_info.json.rabl +1 -0
- data/app/views/katello/hosts/_errata_counts.html.erb +46 -0
- data/app/views/katello/layouts/foreman_with_bastion.html.erb +1 -1
- data/app/views/katello/layouts/react.html.erb +1 -1
- data/app/views/overrides/activation_keys/_host_environment_select.html.erb +2 -2
- data/app/views/overrides/activation_keys/_host_synced_content_select.html.erb +1 -0
- data/app/views/overrides/organizations/_edit_override.html.erb +5 -8
- data/app/views/overrides/organizations/_index_row_override.html.erb +1 -1
- data/app/views/overrides/organizations/_step_1_override.html.erb +5 -0
- data/app/views/overrides/smart_proxies/_acs_http_proxy.html.erb +6 -0
- data/ca/redhat-uep.pem +18 -23
- data/config/katello.yaml.example +0 -2
- data/config/routes/api/registry.rb +8 -7
- data/config/routes/api/v2.rb +4 -2
- data/config/routes/overrides.rb +1 -0
- data/config/routes.rb +6 -0
- data/db/migrate/20200429153103_installed_package_bad_nvrea.rb +1 -1
- data/db/migrate/20201116161820_create_content_view_deb_filter_rules.rb +17 -0
- data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +7 -3
- data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +1 -1
- data/db/migrate/20220524132259_remove_last_refreshed_from_katello_alternate_content_sources.rb +5 -0
- data/db/migrate/20220601163911_add_vendor_to_katello_installed_packages.rb +5 -0
- data/db/migrate/20220610165621_add_repositories_and_products_to_acs.rb +23 -0
- data/db/migrate/20220730033504_update_custom_cdn.rb +13 -0
- data/db/migrate/20220920173656_add_http_proxy_to_smart_proxy.rb +7 -0
- data/db/migrate/20220920180858_remove_http_proxy_from_katello_alternate_content_sources.rb +6 -0
- data/db/migrate/20220929204746_add_content_view_environment_content_facet.rb +52 -0
- data/db/migrate/20221123212341_remove_pulp_docker_registry_port_setting.rb +5 -0
- data/db/migrate/20221206170122_update_ignore_srpm_to_false_for_mirror_complete.rb +5 -0
- data/db/migrate/20230119003859_ensure_repo_username_password_nil_not_blank.rb +9 -0
- data/db/migrate/20230203141353_set_new_acs_verify_ssl_default.rb +5 -0
- data/db/seeds.d/111-upgrade_tasks.rb +3 -1
- data/engines/bastion/app/assets/javascripts/bastion/components/notification.service.js +1 -1
- data/engines/bastion/app/assets/stylesheets/bastion/bastion.scss +4 -0
- data/engines/bastion/app/views/bastion/layouts/application.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/application_ie.html.erb +1 -1
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +7 -6
- data/engines/bastion/vendor/assets/javascripts/bastion/angular/angular.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/content-credential.factory.js +17 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/content-credentials.routes.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-acs.controller.js +36 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-details.controller.js +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/views/content-credential-acs.html +38 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/views/content-credential-details.html +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/views/content-credentials.html +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-errata-modal.controller.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +5 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment-content.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +1 -1
- 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/views/environments.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/apply-errata.controller.js +11 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-hosts-list.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +28 -1403
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +5485 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +5397 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +5658 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +5284 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ka.po +5231 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +5275 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +5389 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +5212 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +5145 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +9 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/katello-features.run.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/bulk/views/products-bulk-advanced-sync-modal.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +7 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-advanced-sync-options.html +4 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +7 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.routes.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +2 -2
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +0 -1
- data/lib/katello/engine.rb +4 -3
- data/lib/katello/permission_creator.rb +5 -6
- data/lib/katello/permissions/host_permissions.rb +1 -0
- data/lib/katello/permissions/registry_permissions.rb +5 -5
- data/lib/katello/plugin.rb +58 -33
- data/lib/katello/repository_types/README.md +136 -19
- data/lib/katello/repository_types/deb.rb +1 -2
- data/lib/katello/repository_types/docker.rb +3 -3
- data/lib/katello/repository_types/file.rb +0 -1
- data/lib/katello/repository_types/python.rb +3 -3
- data/lib/katello/repository_types/yum.rb +0 -4
- data/lib/katello/tasks/check_candlepin_content.rake +16 -0
- data/lib/katello/tasks/clean_candlepin_orphaned_products.rake +38 -0
- data/lib/katello/tasks/clean_orphaned_facets.rb +20 -0
- data/lib/katello/tasks/refresh_repos.rake +8 -0
- data/lib/katello/tasks/reimport.rake +1 -2
- data/lib/katello/tasks/repository.rake +1 -22
- data/lib/katello/tasks/reset.rake +2 -1
- data/lib/katello/tasks/upgrades/4.8/fix_incorrect_providers.rake +29 -0
- data/lib/katello/tasks/upgrades/4.8/regenerate_imported_repository_metadata.rake +33 -0
- data/lib/katello/version.rb +1 -1
- data/lib/katello.rb +0 -5
- data/locale/action_names.rb +65 -62
- data/locale/bn/katello.po +816 -128
- data/locale/cs/katello.po +817 -129
- data/locale/de/katello.po +889 -200
- data/locale/en/katello.po +815 -127
- data/locale/es/katello.po +1161 -469
- data/locale/fr/katello.po +1313 -615
- data/locale/gu/katello.po +816 -128
- data/locale/hi/katello.po +817 -129
- data/locale/it/katello.po +827 -137
- data/locale/ja/katello.po +1315 -623
- data/locale/ka/katello.po +8872 -0
- data/locale/katello.pot +3358 -2013
- data/locale/kn/katello.po +816 -128
- data/locale/ko/katello.po +859 -170
- data/locale/mr/katello.po +817 -129
- data/locale/or/katello.po +817 -129
- data/locale/pa/katello.po +817 -129
- data/locale/pt/katello.po +817 -128
- data/locale/pt_BR/katello.po +1265 -573
- data/locale/ru/katello.po +836 -148
- data/locale/ta/katello.po +816 -128
- data/locale/te/katello.po +816 -128
- data/locale/zh_CN/katello.po +1311 -619
- data/locale/zh_TW/katello.po +830 -142
- data/package.json +0 -3
- data/webpack/components/Bookmark/index.js +5 -1
- data/webpack/components/Content/ContentPage.js +51 -35
- data/webpack/components/Content/Details/ContentDetails.js +1 -1
- data/webpack/components/Content/Details/__tests__/__snapshots__/ContentDetails.test.js.snap +6 -0
- data/webpack/components/Content/__tests__/ContentPage.test.js +2 -4
- data/webpack/components/Content/__tests__/__snapshots__/ContentPage.test.js.snap +22 -3
- data/webpack/components/EditableSwitch.js +1 -0
- data/webpack/components/EditableTextInput/EditableTextInput.js +6 -19
- data/webpack/components/EditableTextInput/PencilEditButton.js +33 -0
- data/webpack/components/Errata/errataHelpers.js +33 -0
- data/webpack/components/Errata/index.js +56 -8
- data/webpack/components/Loading.js +19 -9
- data/webpack/components/Packages/index.js +8 -24
- data/webpack/components/RoutedTabs/index.js +8 -28
- data/webpack/components/Search/Search.js +20 -3
- data/webpack/components/Search/__tests__/search.test.js +4 -5
- data/webpack/components/SelectAllCheckbox/index.js +7 -4
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +1 -0
- data/webpack/components/Table/EmptyStateMessage.js +83 -5
- data/webpack/components/Table/MainTable.js +78 -15
- data/webpack/components/Table/PageControls.js +1 -0
- data/webpack/components/Table/TableHooks.js +12 -4
- data/webpack/components/Table/TableWrapper.js +45 -36
- data/webpack/components/Table/__test__/emptyStateMessage.test.js +51 -0
- data/webpack/components/TypeAhead/TypeAhead.js +26 -11
- data/webpack/components/TypeAhead/pf3Search/TypeAheadItems.js +1 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +2 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadItems.js +2 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +1 -1
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +8 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +19 -84
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +2 -1
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +2 -2
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +128 -71
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +5 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +30 -4
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.scss +23 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +15 -9
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +25 -10
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +1 -17
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeActions.js +37 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +175 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeConstants.js +6 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +307 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeSelectors.js +25 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +109 -0
- data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +161 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +155 -42
- data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +103 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +1 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +5 -2
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +84 -5
- data/webpack/components/extensions/HostDetails/HostDetailsConstants.js +3 -1
- data/webpack/components/extensions/HostDetails/HostDetailsReducer.js +14 -0
- data/webpack/components/extensions/HostDetails/HostDetailsSelectors.js +8 -2
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/constants.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/index.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +97 -27
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +54 -9
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +10 -6
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +147 -25
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.scss +6 -1
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +9 -8
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +135 -27
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +7 -2
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +23 -6
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +60 -61
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +3 -30
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +3 -12
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packages.fixtures.json +3 -3
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +8 -24
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +3 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +12 -20
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +4 -27
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +4 -4
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +1 -1
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +7 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +2 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +2 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/LifeCycleEnvironment.test.js.snap +1 -0
- data/webpack/components/extensions/RegistrationCommands/index.js +49 -17
- data/webpack/containers/Application/config.js +6 -11
- data/webpack/containers/Application/overrides.scss +25 -1
- data/webpack/global_index.js +21 -7
- data/webpack/global_test_setup.js +33 -3
- data/webpack/ouia_id_check.js +93 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +8 -8
- data/webpack/redux/reducers/index.js +2 -4
- data/webpack/scenes/AlternateContentSources/ACSActions.js +72 -8
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +5 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +1 -1
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +21 -12
- data/webpack/scenes/AlternateContentSources/Acs.scss +3 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +96 -49
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +49 -17
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +31 -4
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSProducts.js +44 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +73 -48
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +30 -3
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +42 -18
- data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +1 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +92 -23
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +273 -18
- data/webpack/scenes/AlternateContentSources/Create/__tests__/products.fixtures.json +92 -0
- data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +514 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +356 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +106 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditProducts.js +121 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +152 -0
- data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +143 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +245 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +109 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsDetails.fixtures.json +49 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/acsProducts.fixtures.json +95 -0
- data/webpack/scenes/AlternateContentSources/Details/__tests__/simplifiedAcsDetails.fixtures.json +39 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +401 -97
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.scss +3 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +5 -1
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +10 -16
- data/webpack/scenes/AlternateContentSources/helpers.js +26 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +5 -4
- data/webpack/scenes/Content/Details/__tests__/contentDetail.test.js +1 -12
- data/webpack/scenes/Content/Table/ContentTable.js +2 -1
- data/webpack/scenes/Content/__tests__/contentTable.test.js +1 -15
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +16 -4
- data/webpack/scenes/ContentViews/ContentViewsPage.js +1 -1
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +1 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +1 -0
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +17 -7
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +30 -7
- data/webpack/scenes/ContentViews/Create/CreateContentViewModal.js +1 -0
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +21 -6
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeleteEnvironmentsSelection.js +3 -3
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignActivationKeysForm.js +10 -9
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionReassignHostsForm.js +10 -9
- data/webpack/scenes/ContentViews/Delete/__tests__/CvData.fixtures.json +2 -0
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +7 -32
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +3 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +4 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentVersion.js +1 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +6 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +44 -32
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +127 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +99 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +4 -1
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +37 -9
- data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +13 -3
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositorySelection.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +6 -1
- data/webpack/scenes/ContentViews/Details/Filters/ArtifactsWithNoErrata.js +9 -8
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +48 -29
- data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +241 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +24 -8
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +25 -12
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +10 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +15 -9
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +15 -4
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +27 -13
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +70 -10
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +37 -23
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVDebMatchContentModal.js +97 -0
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +4 -3
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +35 -34
- data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +128 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +98 -42
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +124 -36
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +71 -11
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +37 -22
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +71 -24
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +7 -21
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +7 -23
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVContainerImageFilterContent.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVPackageFilterRules.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyContentViewFilters.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +4 -3
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -11
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +2 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +9 -3
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +1 -11
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +9 -10
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +13 -10
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.js +151 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +82 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareConfig.js +409 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +184 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareTable.js +109 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/AnsibleCollectionsCompareAllContentData.fixtures.json +63 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionCompare.test.js +679 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionEmptyContentCompareData.fixtures.json +14 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ContainerTagsCompareAllContentData.fixtures.json +95 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/DebPackagesCompareAllContentData.fixtures.json +87 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareAllContentData.fixtures.json +319 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareThreeContentTypesData.fixtures.json +131 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareThreeContentTypesData.fixtures.json +48 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ModuleStreamsCompareAllContentData.fixtures.json +239 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PackageGroupsCompareAllContentData.fixtures.json +51 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PythonPackagesCompareAllContentData.fixtures.json +315 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareAllContentData.fixtures.json +470 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareThreeContentTypesData.fixtures.json +475 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewDetails.fixtures.json +160 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionOneDetials.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionThreeDetails.fixtures.json +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionTwoDetails.fixtures.json +211 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersions.fixtures.json +1013 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/cvCompareRepositories.fixtures.json +175 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionOneDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionTwoDetails.fixtures.json +145 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +111 -39
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVEnvironmentSelectionForm.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignActivationKeysForm.js +18 -17
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVReassignHostsForm.js +11 -6
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +7 -22
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +3 -3
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +3 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +37 -13
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +4 -1
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +9 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +30 -15
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +1 -2
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +113 -40
- data/webpack/scenes/ContentViews/Publish/CVPublishForm.js +5 -1
- data/webpack/scenes/ContentViews/Publish/CVPublishReview.js +3 -3
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +104 -84
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +2 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +60 -64
- data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +7 -2
- data/webpack/scenes/ContentViews/components/CVBreadCrumb.js +1 -1
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelect.js +40 -0
- data/webpack/scenes/ContentViews/components/ContentViewSelect/ContentViewSelectOption.js +87 -0
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +2 -1
- data/webpack/scenes/ContentViews/components/InactiveText.js +9 -1
- data/webpack/scenes/ContentViews/components/WizardHeader.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +4 -2
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +4 -3
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +8 -1
- data/webpack/scenes/Hosts/ChangeContentSource/actions.js +18 -12
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceForm.js +176 -30
- data/webpack/scenes/Hosts/ChangeContentSource/components/ContentSourceTemplate.js +13 -17
- data/webpack/scenes/Hosts/ChangeContentSource/components/FormField.js +3 -4
- data/webpack/scenes/Hosts/ChangeContentSource/components/Hosts.js +55 -0
- data/webpack/scenes/Hosts/ChangeContentSource/components/HostsModal.js +59 -0
- data/webpack/scenes/Hosts/ChangeContentSource/constants.js +1 -0
- data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +2 -5
- data/webpack/scenes/Hosts/ChangeContentSource/index.js +118 -74
- data/webpack/scenes/Hosts/ChangeContentSource/selectors.js +9 -5
- data/webpack/scenes/Hosts/ChangeContentSource/styles.scss +10 -2
- data/webpack/scenes/ModuleStreams/Details/ModuleDetailsSchema.js +10 -1
- data/webpack/scenes/ModuleStreams/Details/ModuleStreamDetails.js +1 -1
- data/webpack/scenes/ModuleStreams/Details/__tests__/__snapshots__/ModuleStreamDetails.test.js.snap +97 -2
- data/webpack/scenes/ModuleStreams/ModuleStreamsPage.js +3 -9
- data/webpack/scenes/ModuleStreams/__tests__/__snapshots__/ModuleStreamPage.test.js.snap +7 -1
- data/webpack/scenes/Organizations/OrganizationSelectors.js +1 -0
- data/webpack/scenes/RedHatRepositories/components/Search.js +22 -16
- data/webpack/scenes/RedHatRepositories/index.scss +20 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +1 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +12 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +2 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +11 -26
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CustomCdnTypeForm.js +154 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/ExportSyncForm.js +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/NetworkSyncForm.js +59 -44
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CdnTypeForm.test.js +3 -28
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/CustomCdnTypeForm.test.js +97 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/ExportSyncForm.test.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/NetworkSyncForm.test.js +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +23 -10
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +1 -31
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +2 -1
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +25 -23
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/UpstreamSubscriptionsPage.js +3 -3
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/__tests__/__snapshots__/UpstreamSubscriptionsPage.test.js.snap +2 -2
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsPage.test.js.snap +37 -4
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/SubscriptionsToolbar.js +23 -10
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/SubscriptionsToolbar.test.js +0 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/__snapshots__/SubscriptionsToolbar.test.js.snap +65 -15
- data/webpack/scenes/Tasks/helpers.js +14 -7
- data/webpack/test-utils/nockWrapper.js +7 -0
- metadata +158 -272
- data/app/lib/actions/katello/pulp_selector.rb +0 -24
- data/app/lib/actions/katello/repository/correct_checksum.rb +0 -24
- data/app/lib/actions/katello/repository/destroy_package_group.rb +0 -26
- data/app/lib/actions/katello/repository/upload_package_group.rb +0 -24
- data/app/lib/actions/pulp/abstract.rb +0 -37
- data/app/lib/actions/pulp/abstract_async_task.rb +0 -154
- data/app/lib/actions/pulp/abstract_async_task_group.rb +0 -94
- data/app/lib/actions/pulp/consumer/sync_capsule.rb +0 -45
- data/app/lib/actions/pulp/consumer/unassociate_units.rb +0 -20
- data/app/lib/actions/pulp/expect_one_task.rb +0 -11
- data/app/lib/actions/pulp/orchestration/orphan_cleanup/remove_orphans.rb +0 -16
- data/app/lib/actions/pulp/orchestration/repository/copy_all_units.rb +0 -19
- data/app/lib/actions/pulp/orchestration/repository/delete.rb +0 -15
- data/app/lib/actions/pulp/orchestration/repository/refresh.rb +0 -14
- data/app/lib/actions/pulp/orchestration/repository/refresh_if_needed.rb +0 -13
- data/app/lib/actions/pulp/orchestration/repository/refresh_repos.rb +0 -19
- data/app/lib/actions/pulp/orchestration/repository/remove_units.rb +0 -14
- data/app/lib/actions/pulp/orchestration/repository/smart_proxy_sync.rb +0 -34
- data/app/lib/actions/pulp/orchestration/repository/sync.rb +0 -18
- data/app/lib/actions/pulp/orchestration/repository/upload_content.rb +0 -37
- data/app/lib/actions/pulp/orphan_cleanup/remove_orphans.rb +0 -15
- data/app/lib/actions/pulp/orphan_cleanup/remove_unneeded_repos.rb +0 -16
- data/app/lib/actions/pulp/repository/abstract_copy_content.rb +0 -45
- data/app/lib/actions/pulp/repository/abstract_remove_content.rb +0 -32
- data/app/lib/actions/pulp/repository/clear.rb +0 -18
- data/app/lib/actions/pulp/repository/copy_all_units.rb +0 -30
- data/app/lib/actions/pulp/repository/copy_units.rb +0 -25
- data/app/lib/actions/pulp/repository/create.rb +0 -28
- data/app/lib/actions/pulp/repository/create_in_plan.rb +0 -15
- data/app/lib/actions/pulp/repository/create_upload_request.rb +0 -20
- data/app/lib/actions/pulp/repository/delete_upload_request.rb +0 -19
- data/app/lib/actions/pulp/repository/destroy.rb +0 -28
- data/app/lib/actions/pulp/repository/distributor_publish.rb +0 -25
- data/app/lib/actions/pulp/repository/download.rb +0 -16
- data/app/lib/actions/pulp/repository/import_upload.rb +0 -19
- data/app/lib/actions/pulp/repository/presenters/abstract_sync_presenter.rb +0 -47
- data/app/lib/actions/pulp/repository/presenters/deb_presenter.rb +0 -95
- data/app/lib/actions/pulp/repository/presenters/docker_presenter.rb +0 -103
- data/app/lib/actions/pulp/repository/presenters/file_unit_presenter.rb +0 -42
- data/app/lib/actions/pulp/repository/presenters/yum_presenter.rb +0 -131
- data/app/lib/actions/pulp/repository/refresh.rb +0 -21
- data/app/lib/actions/pulp/repository/regenerate_applicability.rb +0 -21
- data/app/lib/actions/pulp/repository/remove_distribution.rb +0 -11
- data/app/lib/actions/pulp/repository/remove_units.rb +0 -44
- data/app/lib/actions/pulp/repository/sync.rb +0 -99
- data/app/lib/actions/pulp/repository/upload_file.rb +0 -28
- data/app/lib/actions/pulp/repository_group/create.rb +0 -31
- data/app/lib/actions/pulp/repository_group/delete.rb +0 -17
- data/app/lib/actions/pulp/repository_group/export.rb +0 -51
- data/app/lib/katello/util/package_clause_generator.rb +0 -77
- data/app/models/katello/glue/pulp/pulp_errors.rb +0 -9
- data/app/models/katello/glue/pulp/repo.rb +0 -353
- data/app/models/katello/pulp_sync_status.rb +0 -165
- data/app/models/katello/pulp_task_status.rb +0 -63
- data/app/services/katello/candlepin/upstream_consumer.rb +0 -28
- data/app/services/katello/pulp/content.rb +0 -24
- data/app/services/katello/pulp/importer_comparison.rb +0 -28
- data/app/services/katello/pulp/repository/deb.rb +0 -61
- data/app/services/katello/pulp/repository/docker.rb +0 -82
- data/app/services/katello/pulp/repository/file.rb +0 -52
- data/app/services/katello/pulp/repository/yum.rb +0 -205
- data/app/services/katello/pulp/repository.rb +0 -327
- data/app/services/katello/pulp/server.rb +0 -35
- data/app/services/katello/pulp/simple_package.rb +0 -24
- data/app/services/katello/pulp/smart_proxy_repository.rb +0 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -751
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-deletion.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-confirm.controller.js +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +0 -82
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +0 -160
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-activation-keys.html +0 -94
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-confirm.html +0 -76
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +0 -88
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-component.factory.js +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -81
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite.html +0 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-deb-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-repositories.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-deb-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +0 -49
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-promotion.controller.js +0 -129
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-publish.controller.js +0 -46
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories-list.controller.js +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories.service.js +0 -91
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +0 -240
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +0 -115
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-module-stream-filter.controller.js +0 -68
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/date-type-errata-filter.controller.js +0 -77
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/docker-tag-filter.controller.js +0 -137
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/edit-filter.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter-list.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-content-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-details.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-helper.service.js +0 -30
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-repositories.controller.js +0 -86
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-rule-matching-package-modal.controller.js +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-type.filter.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter.factory.js +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filters.controller.js +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/module-stream-list-filter.controller.js +0 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/new-filter.controller.js +0 -100
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-filter.controller.js +0 -179
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-group-list-filter.controller.js +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/rule.factory.js +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata-filter.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata.html +0 -75
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-tag-filter-details.html +0 -65
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/edit-filter.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter.html +0 -50
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-details.html +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-repositories.html +0 -121
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-rule-matching-package-modal.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +0 -85
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter-details.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/new-filter.html +0 -62
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +0 -182
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter-details.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter.html +0 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/partials/filter-repositories-count.html +0 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.controller.js +0 -47
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.factory.js +0 -22
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/views/content-view-history.html +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-copy.html +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-deb-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details-tasks.html +0 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +0 -144
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +0 -114
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +0 -87
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-promotion.html +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +0 -58
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +0 -116
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -126
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +0 -78
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +0 -127
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +0 -138
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version.controller.js +0 -59
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-apt.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-components.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-deb.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +0 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-docker.html +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-errata.html +0 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-module-streams.html +0 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-package-groups.html +0 -21
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-packages.html +0 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-yum.html +0 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -83
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +0 -74
- data/locale/zanata.xml +0 -28
- data/vendor/assets/javascripts/katello/jquery.trunk8.js +0 -203
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +0 -30
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsPage.js +0 -80
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsReducer.js +0 -39
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +0 -60
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTables.scss +0 -0
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetails.js +0 -94
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +0 -23
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsConstants.js +0 -3
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsReducer.js +0 -30
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionsSchema.js +0 -35
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js +0 -16
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js +0 -25
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.test.js +0 -27
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +0 -41
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js +0 -33
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailInfo.test.js.snap +0 -83
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetails.test.js.snap +0 -190
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsActions.test.js.snap +0 -58
- data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsReducer.test.js.snap +0 -50
- data/webpack/scenes/AnsibleCollections/Details/index.js +0 -17
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionPage.test.js +0 -23
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollections.fixtures.js +0 -52
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsActions.test.js +0 -48
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsReducer.test.js +0 -46
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +0 -25
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionPage.test.js.snap +0 -73
- data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionsTable.test.js.snap +0 -81
- data/webpack/scenes/AnsibleCollections/index.js +0 -17
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentSearch.fixtures.json +0 -33
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +0 -123
@@ -38,25 +38,29 @@ module Katello
|
|
38
38
|
|
39
39
|
lazy_accessor :pulp_repositories, :initializer => lambda { |_s| pulp_node.extensions.repository.retrieve_all }
|
40
40
|
|
41
|
+
# A smart proxy's HTTP proxy is used for all related alternate content sources.
|
42
|
+
belongs_to :http_proxy, :inverse_of => :smart_proxies, :class_name => '::HttpProxy'
|
43
|
+
|
41
44
|
has_many :capsule_lifecycle_environments,
|
42
|
-
:class_name
|
45
|
+
:class_name => "Katello::CapsuleLifecycleEnvironment",
|
43
46
|
:foreign_key => :capsule_id,
|
44
|
-
:dependent
|
47
|
+
:dependent => :destroy,
|
45
48
|
:inverse_of => :capsule
|
46
49
|
|
47
50
|
has_many :lifecycle_environments,
|
48
51
|
:class_name => "Katello::KTEnvironment",
|
49
|
-
:through
|
50
|
-
:source
|
52
|
+
:through => :capsule_lifecycle_environments,
|
53
|
+
:source => :lifecycle_environment
|
51
54
|
|
52
55
|
has_many :content_facets, :class_name => "::Katello::Host::ContentFacet", :foreign_key => :content_source_id,
|
53
|
-
|
56
|
+
:inverse_of => :content_source, :dependent => :nullify
|
54
57
|
|
55
58
|
has_many :smart_proxy_sync_histories, :class_name => "::Katello::SmartProxySyncHistory", :inverse_of => :smart_proxy, dependent: :delete_all
|
56
59
|
|
57
60
|
has_many :hostgroup_content_facets, :class_name => "::Katello::Hostgroup::ContentFacet", :foreign_key => :content_source_id,
|
58
|
-
|
61
|
+
:inverse_of => :content_source, :dependent => :nullify
|
59
62
|
has_many :hostgroups, :class_name => "::Hostgroup", :through => :hostgroup_content_facets
|
63
|
+
has_many :smart_proxy_alternate_content_sources, :class_name => "::Katello::SmartProxyAlternateContentSource", :inverse_of => :smart_proxy, :dependent => :delete_all
|
60
64
|
|
61
65
|
validates :download_policy, inclusion: {
|
62
66
|
:in => DOWNLOAD_POLICIES,
|
@@ -66,7 +70,7 @@ module Katello
|
|
66
70
|
|
67
71
|
def self.with_repo(repo)
|
68
72
|
joins(:capsule_lifecycle_environments).
|
69
|
-
|
73
|
+
where("#{Katello::CapsuleLifecycleEnvironment.table_name}.lifecycle_environment_id" => repo.environment_id)
|
70
74
|
end
|
71
75
|
|
72
76
|
def self.pulp_primary
|
@@ -100,12 +104,12 @@ module Katello
|
|
100
104
|
features << PULP_FEATURE if include_default
|
101
105
|
|
102
106
|
unscoped.with_features(features).joins(:capsule_lifecycle_environments).
|
103
|
-
|
107
|
+
where(katello_capsule_lifecycle_environments: { lifecycle_environment_id: environment.id })
|
104
108
|
end
|
105
109
|
|
106
110
|
def self.pulpcore_proxies_with_environment(environment)
|
107
111
|
unscoped.where(id: unscoped.select { |p| p.pulp_mirror? }.pluck(:id)).joins(:capsule_lifecycle_environments).
|
108
|
-
|
112
|
+
where(katello_capsule_lifecycle_environments: { lifecycle_environment_id: environment.id })
|
109
113
|
end
|
110
114
|
|
111
115
|
def self.sync_needed?(environment)
|
@@ -113,6 +117,10 @@ module Katello
|
|
113
117
|
end
|
114
118
|
end
|
115
119
|
|
120
|
+
def alternate_content_sources
|
121
|
+
SmartProxy.joins(:smart_proxy_alternate_content_sources).where('katello_smart_proxy_alternate_content_sources.smart_proxy_id' => self.id)
|
122
|
+
end
|
123
|
+
|
116
124
|
def sync_container_gateway
|
117
125
|
if has_feature?(::SmartProxy::CONTAINER_GATEWAY_FEATURE)
|
118
126
|
update_container_repo_list
|
@@ -179,7 +187,7 @@ module Katello
|
|
179
187
|
config.host = uri.host
|
180
188
|
config.scheme = uri.scheme
|
181
189
|
pulp3_ssl_configuration(config)
|
182
|
-
config.debugging =
|
190
|
+
config.debugging = ::Foreman::Logging.logger('katello/pulp_rest').debug?
|
183
191
|
config.timeout = SETTINGS[:katello][:rest_client_timeout]
|
184
192
|
config.logger = ::Foreman::Logging.logger('katello/pulp_rest')
|
185
193
|
config.username = self.setting(PULP3_FEATURE, 'username')
|
@@ -188,14 +196,12 @@ module Katello
|
|
188
196
|
end
|
189
197
|
|
190
198
|
def pulp3_ssl_configuration(config, connection_adapter = Faraday.default_adapter)
|
191
|
-
legacy_pulp_cert = !self.setting(PULP3_FEATURE, 'client_authentication')&.include?('client_certificate')
|
192
|
-
|
193
199
|
if connection_adapter == :excon
|
194
|
-
config.ssl_client_cert = ::Cert::Certs.ssl_client_cert_filename
|
195
|
-
config.ssl_client_key = ::Cert::Certs.ssl_client_key_filename
|
200
|
+
config.ssl_client_cert = ::Cert::Certs.ssl_client_cert_filename
|
201
|
+
config.ssl_client_key = ::Cert::Certs.ssl_client_key_filename
|
196
202
|
elsif connection_adapter == :net_http
|
197
|
-
config.ssl_client_cert = ::Cert::Certs.ssl_client_cert
|
198
|
-
config.ssl_client_key = ::Cert::Certs.ssl_client_key
|
203
|
+
config.ssl_client_cert = ::Cert::Certs.ssl_client_cert
|
204
|
+
config.ssl_client_key = ::Cert::Certs.ssl_client_key
|
199
205
|
else
|
200
206
|
fail "Unexpected connection_adapter #{Faraday.default_adapter}! Cannot continue, this is likely a bug."
|
201
207
|
end
|
@@ -229,14 +235,6 @@ module Katello
|
|
229
235
|
end
|
230
236
|
end
|
231
237
|
|
232
|
-
def backend_service_type(repository)
|
233
|
-
if pulp3_support?(repository)
|
234
|
-
Actions::Pulp3::Abstract::BACKEND_SERVICE_TYPE
|
235
|
-
else
|
236
|
-
Actions::Pulp::Abstract::BACKEND_SERVICE_TYPE
|
237
|
-
end
|
238
|
-
end
|
239
|
-
|
240
238
|
def pulp3_enabled?
|
241
239
|
self.has_feature? PULP3_FEATURE
|
242
240
|
end
|
@@ -250,7 +248,7 @@ module Katello
|
|
250
248
|
end
|
251
249
|
|
252
250
|
def fix_pulp3_capabilities(type)
|
253
|
-
if type.is_a?(String) ||
|
251
|
+
if type.is_a?(String) || type.is_a?(Symbol)
|
254
252
|
repository_type_obj = Katello::RepositoryTypeManager.defined_repository_types[type]
|
255
253
|
else
|
256
254
|
repository_type_obj = type
|
@@ -271,7 +269,7 @@ module Katello
|
|
271
269
|
repository_type_obj.pulp3_plugin.present? &&
|
272
270
|
pulp3_enabled? &&
|
273
271
|
(self.capabilities(PULP3_FEATURE).try(:include?, repository_type_obj.pulp3_plugin) ||
|
274
|
-
|
272
|
+
self.capabilities(PULP3_FEATURE).try(:include?, 'pulp_' + repository_type_obj.pulp3_plugin))
|
275
273
|
end
|
276
274
|
|
277
275
|
def pulp3_content_support?(content_type)
|
@@ -345,7 +343,7 @@ module Katello
|
|
345
343
|
content_type_string = content_type_obj&.label || content_type
|
346
344
|
unless content_type_obj
|
347
345
|
fail _("Content type %{content_type_string} does not belong to an enabled repo type.") %
|
348
|
-
|
346
|
+
{ content_type_string: content_type_string }
|
349
347
|
end
|
350
348
|
content_type_obj.pulp3_service_class
|
351
349
|
end
|
@@ -378,7 +376,7 @@ module Katello
|
|
378
376
|
end
|
379
377
|
|
380
378
|
def sync_tasks
|
381
|
-
ForemanTasks::Task.for_resource(self)
|
379
|
+
ForemanTasks::Task.for_resource(self).where(:label => 'Actions::Katello::CapsuleContent::Sync')
|
382
380
|
end
|
383
381
|
|
384
382
|
def active_sync_tasks
|
@@ -389,10 +387,14 @@ module Katello
|
|
389
387
|
sync_tasks.where('started_at > ?', last_sync_time).where.not(:result => 'pending')
|
390
388
|
end
|
391
389
|
|
390
|
+
def last_sync_audit
|
391
|
+
Audited::Audit.where(:auditable_id => self, :auditable_type => SmartProxy.name, action: "sync capsule").order(:created_at).last
|
392
|
+
end
|
393
|
+
|
392
394
|
def last_sync_time
|
393
395
|
task = sync_tasks.where.not(:ended_at => nil).where(:result => 'success').order(:ended_at).last
|
394
396
|
|
395
|
-
task&.ended_at
|
397
|
+
task&.ended_at || last_sync_audit&.created_at&.to_s
|
396
398
|
end
|
397
399
|
|
398
400
|
def environment_syncable?(env)
|
@@ -441,15 +443,11 @@ module Katello
|
|
441
443
|
repos_in_env_cv(environment, content_view) - repos_in_sync_history
|
442
444
|
end
|
443
445
|
|
444
|
-
def smart_proxy_service
|
445
|
-
@smart_proxy_service ||= Pulp::SmartProxyRepository.new(self)
|
446
|
-
end
|
447
|
-
|
448
446
|
def rhsm_url
|
449
447
|
# Since Foreman 3.1 this setting is set
|
450
448
|
if (rhsm_url = setting(SmartProxy::PULP3_FEATURE, 'rhsm_url'))
|
451
449
|
URI(rhsm_url)
|
452
|
-
|
450
|
+
# Compatibility fall back
|
453
451
|
elsif pulp_primary?
|
454
452
|
URI("https://#{URI.parse(url).host}/rhsm")
|
455
453
|
elsif pulp_mirror?
|
@@ -461,6 +459,10 @@ module Katello
|
|
461
459
|
URI(setting(SmartProxy::PULP3_FEATURE, 'content_app_url'))
|
462
460
|
end
|
463
461
|
|
462
|
+
def audit_capsule_sync
|
463
|
+
write_audit(action: "sync capsule", comment: _('Successfully synced capsule.'), audited_changes: {})
|
464
|
+
end
|
465
|
+
|
464
466
|
class ::SmartProxy::Jail < ::Safemode::Jail
|
465
467
|
allow :rhsm_url, :pulp_content_url
|
466
468
|
end
|
@@ -41,7 +41,7 @@ module Katello
|
|
41
41
|
cp_products = ::Katello::Resources::Candlepin::Product.all(org.label, [:id, :productContent])
|
42
42
|
product_hash = cp_products.group_by { |prod| prod['id'] }
|
43
43
|
|
44
|
-
prod_content_importer = Katello::ProductContentImporter.new
|
44
|
+
prod_content_importer = Katello::ProductContentImporter.new(product_hash)
|
45
45
|
org.products.each do |product|
|
46
46
|
product_json = product_hash[product.cp_id]&.first
|
47
47
|
|
@@ -63,5 +63,20 @@ module Katello
|
|
63
63
|
new_url_subs = new_url&.scan(/\$\w+/)&.sort
|
64
64
|
current_subs == new_url_subs
|
65
65
|
end
|
66
|
+
|
67
|
+
def self.substitute_content_path(arch: nil, releasever: nil, content_path:)
|
68
|
+
arch = nil if arch == "noarch"
|
69
|
+
substitutions = {
|
70
|
+
:releasever => releasever,
|
71
|
+
:basearch => arch
|
72
|
+
}.compact
|
73
|
+
path = substitutions.inject(content_path) do |path_url, (key, value)|
|
74
|
+
path_url.gsub("$#{key}", value)
|
75
|
+
end
|
76
|
+
{
|
77
|
+
path: path,
|
78
|
+
substitutions: substitutions
|
79
|
+
}
|
80
|
+
end
|
66
81
|
end
|
67
82
|
end
|
@@ -9,26 +9,25 @@ module Katello
|
|
9
9
|
GPG_KEY_TYPE = 'gpg_key'.freeze
|
10
10
|
CERT_TYPE = 'cert'.freeze
|
11
11
|
|
12
|
-
has_many :root_repositories, :class_name => "Katello::RootRepository", :inverse_of => :gpg_key, :dependent => :
|
12
|
+
has_many :root_repositories, :class_name => "Katello::RootRepository", :inverse_of => :gpg_key, :dependent => :restrict_with_exception, :foreign_key => 'gpg_key_id'
|
13
13
|
has_many :repositories, :through => :root_repositories
|
14
14
|
|
15
|
-
has_many :products, :class_name => "Katello::Product", :inverse_of => :gpg_key, :dependent => :
|
16
|
-
|
15
|
+
has_many :products, :class_name => "Katello::Product", :inverse_of => :gpg_key, :dependent => :restrict_with_exception, :foreign_key => 'gpg_key_id'
|
17
16
|
has_many :ssl_ca_cdn_configurations, :class_name => "Katello::CdnConfiguration", :foreign_key => 'ssl_ca_credential_id',
|
18
17
|
:inverse_of => :ssl_ca_credential, :dependent => :nullify
|
19
18
|
|
20
19
|
has_many :ssl_ca_products, :class_name => "Katello::Product", :foreign_key => "ssl_ca_cert_id",
|
21
|
-
:inverse_of => :ssl_ca_cert, :dependent => :
|
20
|
+
:inverse_of => :ssl_ca_cert, :dependent => :restrict_with_exception
|
22
21
|
has_many :ssl_client_products, :class_name => "Katello::Product", :foreign_key => "ssl_client_cert_id",
|
23
|
-
:inverse_of => :ssl_client_cert, :dependent => :
|
22
|
+
:inverse_of => :ssl_client_cert, :dependent => :restrict_with_exception
|
24
23
|
has_many :ssl_key_products, :class_name => "Katello::Product", :foreign_key => "ssl_client_key_id",
|
25
|
-
:inverse_of => :ssl_client_key, :dependent => :
|
24
|
+
:inverse_of => :ssl_client_key, :dependent => :restrict_with_exception
|
26
25
|
has_many :ssl_ca_root_repos, :class_name => "Katello::RootRepository", :foreign_key => "ssl_ca_cert_id",
|
27
|
-
:inverse_of => :ssl_ca_cert, :dependent => :
|
26
|
+
:inverse_of => :ssl_ca_cert, :dependent => :restrict_with_exception
|
28
27
|
has_many :ssl_client_root_repos, :class_name => "Katello::RootRepository", :foreign_key => "ssl_client_cert_id",
|
29
|
-
:inverse_of => :ssl_client_cert, :dependent => :
|
28
|
+
:inverse_of => :ssl_client_cert, :dependent => :restrict_with_exception
|
30
29
|
has_many :ssl_key_root_repos, :class_name => "Katello::RootRepository", :foreign_key => "ssl_client_key_id",
|
31
|
-
:inverse_of => :ssl_client_key, :dependent => :
|
30
|
+
:inverse_of => :ssl_client_key, :dependent => :restrict_with_exception
|
32
31
|
has_many :ssl_ca_alternate_content_sources, :class_name => "Katello::AlternateContentSource", :foreign_key => "ssl_ca_cert_id",
|
33
32
|
:inverse_of => :ssl_ca_cert, :dependent => :nullify
|
34
33
|
has_many :ssl_client_alternate_content_sources, :class_name => "Katello::AlternateContentSource", :foreign_key => "ssl_client_cert_id",
|
@@ -39,10 +39,13 @@ module Katello
|
|
39
39
|
|
40
40
|
has_many :activation_keys, :class_name => "Katello::ActivationKey", :dependent => :restrict_with_exception
|
41
41
|
|
42
|
-
has_many :
|
43
|
-
:
|
42
|
+
has_many :content_view_environment_content_facets, :class_name => "Katello::ContentViewEnvironmentContentFacet",
|
43
|
+
:through => :content_view_environments
|
44
|
+
has_many :content_facets, :class_name => "Katello::Host::ContentFacet", :through => :content_view_environment_content_facets,
|
45
|
+
:inverse_of => :content_views
|
44
46
|
has_many :hosts, :class_name => "::Host::Managed", :through => :content_facets,
|
45
|
-
:inverse_of => :
|
47
|
+
:inverse_of => :content_views
|
48
|
+
|
46
49
|
has_many :hostgroup_content_facets, :class_name => "Katello::Hostgroup::ContentFacet",
|
47
50
|
:inverse_of => :content_view, :dependent => :nullify
|
48
51
|
has_many :hostgroups, :class_name => "::Hostgroup", :through => :hostgroup_content_facets,
|
@@ -87,9 +90,17 @@ module Katello
|
|
87
90
|
scope :composite, -> { where(:composite => true) }
|
88
91
|
scope :non_composite, -> { where(:composite => [nil, false]) }
|
89
92
|
scope :generated, -> { where.not(:generated_for => :none) }
|
90
|
-
scope :generated_for_repository, -> {
|
91
|
-
|
92
|
-
|
93
|
+
scope :generated_for_repository, -> {
|
94
|
+
where(:generated_for => [:repository_export,
|
95
|
+
:repository_import,
|
96
|
+
:repository_export_syncable])
|
97
|
+
}
|
98
|
+
scope :ignore_generated, -> {
|
99
|
+
where.not(:generated_for => [:repository_export,
|
100
|
+
:repository_import,
|
101
|
+
:library_export_syncable,
|
102
|
+
:repository_export_syncable])
|
103
|
+
}
|
93
104
|
scope :generated_for_library, -> { where(:generated_for => [:library_export, :library_import]) }
|
94
105
|
|
95
106
|
scoped_search :on => :name, :complete_value => true
|
@@ -104,7 +115,9 @@ module Katello
|
|
104
115
|
library_export: 1,
|
105
116
|
repository_export: 2,
|
106
117
|
library_import: 3,
|
107
|
-
repository_import: 4
|
118
|
+
repository_import: 4,
|
119
|
+
library_export_syncable: 5,
|
120
|
+
repository_export_syncable: 6
|
108
121
|
}, _prefix: true
|
109
122
|
|
110
123
|
set_crud_hooks :content_view
|
@@ -204,6 +217,10 @@ module Katello
|
|
204
217
|
new_view.filters << new_filter
|
205
218
|
|
206
219
|
case filter.type
|
220
|
+
when ContentViewDebFilter.name
|
221
|
+
filter.deb_rules.each do |rule|
|
222
|
+
new_filter.deb_rules << rule.dup
|
223
|
+
end
|
207
224
|
when ContentViewPackageFilter.name
|
208
225
|
filter.package_rules.each do |rule|
|
209
226
|
new_filter.package_rules << rule.dup
|
@@ -407,8 +424,10 @@ module Katello
|
|
407
424
|
# update errata applicability counts for all hosts in the CV & LE
|
408
425
|
Location.no_taxonomy_scope do
|
409
426
|
User.as_anonymous_admin do
|
410
|
-
::Katello::Host::ContentFacet.
|
411
|
-
|
427
|
+
::Katello::Host::ContentFacet.in_content_views_and_environments(
|
428
|
+
content_views: [self],
|
429
|
+
lifecycle_environments: [environment]
|
430
|
+
).each do |facet|
|
412
431
|
facet.update_applicability_counts
|
413
432
|
facet.update_errata_status
|
414
433
|
end
|
@@ -575,16 +594,17 @@ module Katello
|
|
575
594
|
true
|
576
595
|
end
|
577
596
|
|
578
|
-
def check_ready_to_publish!(importing: false)
|
597
|
+
def check_ready_to_publish!(importing: false, syncable: false)
|
579
598
|
fail _("User must be logged in.") if ::User.current.nil?
|
580
599
|
fail _("Cannot publish default content view") if default?
|
581
600
|
|
582
601
|
if importing
|
583
602
|
check_ready_to_import!
|
584
603
|
else
|
585
|
-
fail _("Import-only content views can not be published directly") if import_only?
|
604
|
+
fail _("Import-only content views can not be published directly") if import_only? && !syncable
|
586
605
|
check_composite_action_allowed!(organization.library)
|
587
606
|
check_docker_repository_names!([organization.library])
|
607
|
+
check_orphaned_content_facets!(environments: self.environments)
|
588
608
|
end
|
589
609
|
|
590
610
|
true
|
@@ -631,6 +651,17 @@ module Katello
|
|
631
651
|
true
|
632
652
|
end
|
633
653
|
|
654
|
+
def check_orphaned_content_facets!(environments: [])
|
655
|
+
::Katello::Host::ContentFacet.in_content_views_and_environments(
|
656
|
+
content_views: [self],
|
657
|
+
lifecycle_environments: environments
|
658
|
+
).each do |facet|
|
659
|
+
unless facet.host
|
660
|
+
fail _("Orphaned content facets for deleted hosts exist for the content view and environment. Please run rake task : katello:clean_orphaned_facets and try again!")
|
661
|
+
end
|
662
|
+
end
|
663
|
+
end
|
664
|
+
|
634
665
|
def check_remove_from_environment!(env)
|
635
666
|
errors = []
|
636
667
|
|
@@ -56,6 +56,10 @@ module Katello
|
|
56
56
|
if attached_content_view_ids.include?(view.id)
|
57
57
|
errors.add(:base, _("Another component already includes content view with ID %s" % view.id))
|
58
58
|
end
|
59
|
+
|
60
|
+
unless view.generated_for_none?
|
61
|
+
errors.add(:base, _("Cannot add generated content view versions to composite content view"))
|
62
|
+
end
|
59
63
|
end
|
60
64
|
|
61
65
|
def ensure_valid_attributes
|
@@ -0,0 +1,51 @@
|
|
1
|
+
module Katello
|
2
|
+
class ContentViewDebFilter < ContentViewFilter
|
3
|
+
CONTENT_TYPE = Deb::CONTENT_TYPE
|
4
|
+
|
5
|
+
has_many :deb_rules, :dependent => :destroy, :foreign_key => :content_view_filter_id,
|
6
|
+
:class_name => "Katello::ContentViewDebFilterRule"
|
7
|
+
validates_lengths_from_database
|
8
|
+
|
9
|
+
def generate_clauses(repo)
|
10
|
+
package_filenames = []
|
11
|
+
|
12
|
+
self.deb_rules.each do |rule|
|
13
|
+
package_filenames.concat(query_debs(repo, rule))
|
14
|
+
end
|
15
|
+
|
16
|
+
ContentViewDebFilter.generate_deb_clauses(package_filenames)
|
17
|
+
end
|
18
|
+
|
19
|
+
def content_unit_pulp_ids(repo)
|
20
|
+
deb_filenames = []
|
21
|
+
self.deb_rules.each do |rule|
|
22
|
+
deb_filenames.concat(query_debs(repo, rule))
|
23
|
+
end
|
24
|
+
debs = Deb.in_repositories(repo)
|
25
|
+
debs.where(filename: deb_filenames).pluck(:pulp_id).flatten.uniq
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.generate_deb_clauses(package_filenames = [])
|
29
|
+
{ 'filename' => { "$in" => package_filenames } } unless package_filenames.empty?
|
30
|
+
end
|
31
|
+
|
32
|
+
def applicable_debs
|
33
|
+
Deb.in_repositories(self.applicable_repos)
|
34
|
+
end
|
35
|
+
|
36
|
+
def query_debs(repo, rule)
|
37
|
+
debs = Deb.in_repositories(repo)
|
38
|
+
query_debs_from_collection(debs, rule).pluck("#{Deb.table_name}.filename")
|
39
|
+
end
|
40
|
+
|
41
|
+
def query_debs_from_collection(collection, rule)
|
42
|
+
query_name = rule.name.tr("*", "%")
|
43
|
+
query = collection.where("#{Deb.table_name}.name ilike ?", query_name)
|
44
|
+
if rule.architecture.present?
|
45
|
+
query_arch = rule.architecture.tr("*", "%")
|
46
|
+
query = query.where("#{Deb.table_name}.architecture ilike ?", query_arch)
|
47
|
+
end
|
48
|
+
query.default_sort
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
module Katello
|
2
|
+
class ContentViewDebFilterRule < Katello::Model
|
3
|
+
include ::Katello::Concerns::ContentViewFilterRuleCommon
|
4
|
+
|
5
|
+
belongs_to :filter,
|
6
|
+
:class_name => "Katello::ContentViewDebFilter",
|
7
|
+
:inverse_of => :deb_rules,
|
8
|
+
:foreign_key => :content_view_filter_id
|
9
|
+
|
10
|
+
validates :name, :presence => true
|
11
|
+
validate :ensure_unique_attributes
|
12
|
+
validates_with Validators::ContentViewFilterVersionValidator
|
13
|
+
|
14
|
+
def ensure_unique_attributes
|
15
|
+
other = self.class.where(:name => self.name,
|
16
|
+
:content_view_filter_id => self.content_view_filter_id,
|
17
|
+
:architecture => self.architecture)
|
18
|
+
other = other.where.not(:id => self.id) if self.id
|
19
|
+
if other.exists?
|
20
|
+
errors.add(:base, "This deb package filter rule already exists.")
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -8,9 +8,13 @@ module Katello
|
|
8
8
|
|
9
9
|
belongs_to :content_view, :class_name => "Katello::ContentView", :inverse_of => :content_view_environments
|
10
10
|
belongs_to :environment, :class_name => "Katello::KTEnvironment", :inverse_of => :content_view_environments
|
11
|
+
belongs_to :lifecycle_environment, :class_name => "Katello::KTEnvironment", :foreign_key => :environment_id, :inverse_of => :content_view_environments
|
11
12
|
belongs_to :content_view_version, :class_name => "Katello::ContentViewVersion",
|
12
13
|
:inverse_of => :content_view_environments
|
13
14
|
|
15
|
+
has_many :content_view_environment_content_facets, :class_name => "Katello::ContentViewEnvironmentContentFacet", :dependent => :destroy, :inverse_of => :content_view_environment
|
16
|
+
has_many :content_facets, through: :content_view_environment_content_facets, :class_name => "::Katello::Host::ContentFacet", :inverse_of => :content_view_environments
|
17
|
+
|
14
18
|
validates_lengths_from_database
|
15
19
|
validates :environment_id, uniqueness: {scope: :content_view_id}, presence: true
|
16
20
|
validates :content_view_id, presence: true
|
@@ -19,10 +23,10 @@ module Katello
|
|
19
23
|
before_save :generate_info
|
20
24
|
|
21
25
|
scope :non_default, -> { joins(:content_view).where("katello_content_views.default" => false) }
|
26
|
+
alias :lifecycle_environment :environment
|
22
27
|
|
23
28
|
def self.for_content_facets(content_facets)
|
24
|
-
joins(
|
25
|
-
where("#{Host::ContentFacet.table_name}.content_view_id = #{ContentViewEnvironment.table_name}.content_view_id").where("#{Host::ContentFacet.table_name}.id" => content_facets).uniq
|
29
|
+
joins(:content_view_environment_content_facets, :content_facets).where("#{Katello::ContentViewEnvironmentContentFacet.table_name}.content_facet_id" => content_facets).uniq
|
26
30
|
end
|
27
31
|
|
28
32
|
# retrieve the owning environment for this content view environment.
|
@@ -38,6 +42,11 @@ module Katello
|
|
38
42
|
content_view.activation_keys.in_environment(environment)
|
39
43
|
end
|
40
44
|
|
45
|
+
# TODO: uncomment when we need to start showing multiple CVE names in UI
|
46
|
+
# def candlepin_name
|
47
|
+
# "#{environment.label}/#{content_view.label}"
|
48
|
+
# end
|
49
|
+
|
41
50
|
private
|
42
51
|
|
43
52
|
def generate_info
|
@@ -0,0 +1,9 @@
|
|
1
|
+
module Katello
|
2
|
+
class ContentViewEnvironmentContentFacet < Katello::Model
|
3
|
+
belongs_to :content_view_environment, :class_name => "::Katello::ContentViewEnvironment", :inverse_of => :content_view_environment_content_facets
|
4
|
+
belongs_to :content_facet, :class_name => "::Katello::Host::ContentFacet", :inverse_of => :content_view_environment_content_facets
|
5
|
+
|
6
|
+
validates :content_view_environment_id, presence: true
|
7
|
+
validates :content_facet_id, presence: true, unless: :new_record?
|
8
|
+
end
|
9
|
+
end
|
@@ -34,10 +34,10 @@ module Katello
|
|
34
34
|
# additional_included_errata and inclusion filters don't work together (since it only applies when excluding)
|
35
35
|
if self.inclusion?
|
36
36
|
errata_pulp_ids = errata_package_pulp_ids_from_errata_ids(repo, errata_ids, [])
|
37
|
-
errata_pulp_ids += errata_module_stream_pulp_ids_from_errata_ids(errata_ids, [])
|
37
|
+
errata_pulp_ids += errata_module_stream_pulp_ids_from_errata_ids(repo, errata_ids, [])
|
38
38
|
else
|
39
39
|
errata_pulp_ids = errata_package_pulp_ids_from_errata_ids(repo, errata_ids, additional_included_errata)
|
40
|
-
errata_pulp_ids += errata_module_stream_pulp_ids_from_errata_ids(errata_ids, additional_included_errata)
|
40
|
+
errata_pulp_ids += errata_module_stream_pulp_ids_from_errata_ids(repo, errata_ids, additional_included_errata)
|
41
41
|
end
|
42
42
|
else
|
43
43
|
clauses = []
|
@@ -74,10 +74,11 @@ module Katello
|
|
74
74
|
rpms_by_filename(repo, package_filenames).pluck(:pulp_id)
|
75
75
|
end
|
76
76
|
|
77
|
-
def errata_module_stream_pulp_ids_from_errata_ids(errata_ids, additional_included_errata)
|
77
|
+
def errata_module_stream_pulp_ids_from_errata_ids(repo, errata_ids, additional_included_errata)
|
78
78
|
module_streams = Katello::Erratum.where(:errata_id => errata_ids).map(&:module_streams).compact.flatten -
|
79
79
|
Katello::Erratum.where(:errata_id => additional_included_errata.pluck(:errata_id)).map(&:module_streams).compact.flatten
|
80
|
-
|
80
|
+
ModuleStream.joins(:repository_module_streams).
|
81
|
+
where(:id => module_streams.pluck(:id), "#{RepositoryModuleStream.table_name}.repository_id" => repo.id).pluck(:pulp_id)
|
81
82
|
end
|
82
83
|
|
83
84
|
def errata_package_pulp_ids_from_errata_ids(repo, errata_ids, additional_included_errata)
|
@@ -9,7 +9,7 @@ module Katello
|
|
9
9
|
MODULE_STREAM = ModuleStream::CONTENT_TYPE
|
10
10
|
DEB = Deb::CONTENT_TYPE
|
11
11
|
CONTENT_TYPES = [RPM, PACKAGE_GROUP, ERRATA, DOCKER, DEB, MODULE_STREAM].freeze
|
12
|
-
CONTENT_OPTIONS = { _('Packages') => RPM, _('Module Streams') => ModuleStream, _('Package Groups') => PACKAGE_GROUP, _('Errata') => ERRATA, _('Container Images') => DOCKER, _('
|
12
|
+
CONTENT_OPTIONS = { _('Packages') => RPM, _('Module Streams') => ModuleStream, _('Package Groups') => PACKAGE_GROUP, _('Errata') => ERRATA, _('Container Images') => DOCKER, _('Deb Packages') => DEB }.freeze
|
13
13
|
|
14
14
|
belongs_to :content_view,
|
15
15
|
:class_name => "Katello::ContentView",
|
@@ -31,6 +31,7 @@ module Katello
|
|
31
31
|
scoped_search :on => :name, :complete_value => true
|
32
32
|
scoped_search :on => :type, :rename => :content_type,
|
33
33
|
:complete_value => {Rpm::CONTENT_TYPE.to_sym => "Katello::ContentViewPackageFilter",
|
34
|
+
Deb::CONTENT_TYPE.to_sym => "Katello::ContentViewDebFilter",
|
34
35
|
PackageGroup::CONTENT_TYPE.to_sym => "Katello::ContentViewPackageGroupFilter",
|
35
36
|
Erratum::CONTENT_TYPE.to_sym => "Katello::ContentViewErratumFilter",
|
36
37
|
DOCKER.to_sym => "Katello::ContentViewDockerFilter",
|
@@ -47,8 +48,7 @@ module Katello
|
|
47
48
|
end
|
48
49
|
|
49
50
|
def self.deb
|
50
|
-
|
51
|
-
[]
|
51
|
+
where(:type => ::Katello::ContentViewDebFilter.name)
|
52
52
|
end
|
53
53
|
|
54
54
|
def self.docker
|
@@ -69,6 +69,7 @@ module Katello
|
|
69
69
|
|
70
70
|
def content_type
|
71
71
|
{
|
72
|
+
ContentViewDebFilter => DEB,
|
72
73
|
ContentViewPackageFilter => RPM,
|
73
74
|
ContentViewErratumFilter => ERRATA,
|
74
75
|
ContentViewPackageGroupFilter => PACKAGE_GROUP,
|
@@ -79,6 +80,8 @@ module Katello
|
|
79
80
|
|
80
81
|
def self.class_for(content_type)
|
81
82
|
case content_type
|
83
|
+
when DEB
|
84
|
+
ContentViewDebFilter
|
82
85
|
when RPM
|
83
86
|
ContentViewPackageFilter
|
84
87
|
when PACKAGE_GROUP
|
@@ -97,6 +100,8 @@ module Katello
|
|
97
100
|
|
98
101
|
def self.rule_class_for(filter)
|
99
102
|
case filter.type
|
103
|
+
when ContentViewDebFilter.name
|
104
|
+
ContentViewDebFilterRule
|
100
105
|
when ContentViewPackageFilter.name
|
101
106
|
ContentViewPackageFilterRule
|
102
107
|
when ContentViewPackageGroupFilter.name
|
@@ -115,6 +120,8 @@ module Katello
|
|
115
120
|
|
116
121
|
def self.rule_ids_for(filter)
|
117
122
|
case filter.type
|
123
|
+
when ContentViewDebFilter.name
|
124
|
+
filter.deb_rule_ids
|
118
125
|
when ContentViewPackageFilter.name
|
119
126
|
filter.package_rule_ids
|
120
127
|
when ContentViewPackageGroupFilter.name
|
@@ -56,7 +56,7 @@ module Katello
|
|
56
56
|
scope :with_organization_id, ->(organization_id) do
|
57
57
|
joins(:content_view).where("#{Katello::ContentView.table_name}.organization_id" => organization_id)
|
58
58
|
end
|
59
|
-
|
59
|
+
scope :not_ignorable, -> { where(content_view_id: Katello::ContentView.ignore_generated) }
|
60
60
|
scope :triggered_by, ->(content_view_version_id) do
|
61
61
|
sql = Katello::ContentViewHistory.where(:triggered_by_id => content_view_version_id).select(:katello_content_view_version_id).to_sql
|
62
62
|
where("#{Katello::ContentViewVersion.table_name}.id in (#{sql})")
|
@@ -99,8 +99,7 @@ module Katello
|
|
99
99
|
def self.for_version(version)
|
100
100
|
major, minor = version.to_s.split('.')
|
101
101
|
minor ||= 0
|
102
|
-
|
103
|
-
query
|
102
|
+
where(:major => major, :minor => minor)
|
104
103
|
end
|
105
104
|
|
106
105
|
def to_s
|
@@ -165,6 +164,10 @@ module Katello
|
|
165
164
|
"#{major}.#{minor}"
|
166
165
|
end
|
167
166
|
|
167
|
+
def incrementally_updated?
|
168
|
+
minor != 0
|
169
|
+
end
|
170
|
+
|
168
171
|
def repos(env)
|
169
172
|
self.repositories.in_environment(env)
|
170
173
|
end
|
@@ -333,9 +336,10 @@ module Katello
|
|
333
336
|
def update_content_counts!
|
334
337
|
self.content_counts = {}
|
335
338
|
RepositoryTypeManager.indexable_content_types.each do |content_type|
|
336
|
-
|
339
|
+
case content_type&.model_class::CONTENT_TYPE
|
340
|
+
when DockerTag::CONTENT_TYPE
|
337
341
|
content_counts[DockerTag::CONTENT_TYPE] = docker_tags.count
|
338
|
-
|
342
|
+
when GenericContentUnit::CONTENT_TYPE
|
339
343
|
content_counts[content_type.content_type] = content_type&.model_class&.in_repositories(self.repositories.archived)&.where(:content_type => content_type.content_type)&.count
|
340
344
|
else
|
341
345
|
content_counts[content_type&.model_class::CONTENT_TYPE] = content_type&.model_class&.in_repositories(self.repositories.archived)&.count
|
@@ -376,9 +380,10 @@ module Katello
|
|
376
380
|
fail _("Default content view versions cannot be promoted") if default?
|
377
381
|
content_view.check_composite_action_allowed!(to_env)
|
378
382
|
content_view.check_docker_repository_names!(to_env)
|
383
|
+
content_view.check_orphaned_content_facets!(environments: [to_env])
|
379
384
|
end
|
380
385
|
|
381
|
-
def validate_destroyable!(skip_environment_check
|
386
|
+
def validate_destroyable!(skip_environment_check: false)
|
382
387
|
unless organization.being_deleted?
|
383
388
|
if !skip_environment_check && in_environment?
|
384
389
|
fail _("Cannot delete version while it is in environments: %s") %
|