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
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 623f96f2d316d946b9a19bbed0bd70a58c56541dfcde05261848efb7f868881d
|
4
|
+
data.tar.gz: f39b3c6dca68f3b742f6a09fb5a821ab5e9d11128835023f09a5a8df30a27272
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3d4e46aa5cdededbea344d58cc4dd5c43c1fcdd480e5a62594a1bf0892ff80c048e07a3a7460646b2778502849cc58d7ab6f8f22aaeb1ce3fd0ea8aa59f844c7
|
7
|
+
data.tar.gz: 97fa1540ab108458032dc4a4963b9644af0a6c7207079bf2c3ef2cc895cacab6521eec73e4ed4aadc2eaf8428fc3b2d5b7bec489a03f02a2d972310344b7c07f
|
@@ -161,25 +161,9 @@ module Katello
|
|
161
161
|
end
|
162
162
|
|
163
163
|
if (manifest_response = redirect_client { Resources::Registry::Proxy.get(@_request.fullpath, headers) })
|
164
|
-
#for some requests, we get a redirect, but for others we get the actual manifest in response
|
165
|
-
results = JSON.parse(manifest_response)
|
166
164
|
response.header['Docker-Content-Digest'] = manifest_response.headers[:docker_content_digest]
|
167
|
-
|
168
|
-
|
169
|
-
media_type = results['mediaType']
|
170
|
-
if media_type.blank?
|
171
|
-
# so mediaType is not schema2 v2 only set the mediaType based on
|
172
|
-
# https://docs.docker.com/registry/spec/manifest-v2-1/
|
173
|
-
media_type = if results["signatures"].blank?
|
174
|
-
'application/vnd.docker.distribution.manifest.v1+json'
|
175
|
-
else
|
176
|
-
'application/vnd.docker.distribution.manifest.v1+prettyjws'
|
177
|
-
end
|
178
|
-
end
|
179
|
-
response.headers['Content-Type'] = media_type
|
180
|
-
length = manifest_response.try(:body).try(:size)
|
181
|
-
length ||= 0
|
182
|
-
response.header['Content-Length'] = "#{length}"
|
165
|
+
response.headers['Content-Type'] = manifest_response.headers[:content_type]
|
166
|
+
response.header['Content-Length'] = manifest_response.headers[:content_length]
|
183
167
|
render json: manifest_response
|
184
168
|
end
|
185
169
|
end
|
@@ -210,12 +194,10 @@ module Katello
|
|
210
194
|
def pull_blob
|
211
195
|
headers = {}
|
212
196
|
headers['Accept'] = request.headers['Accept'] if request.headers['Accept']
|
213
|
-
|
214
|
-
#when pulp 2 is removed, this should no longer be needed, and all clients should be redirected
|
215
|
-
render json: blob_response
|
216
|
-
end
|
197
|
+
redirect_client { Resources::Registry::Proxy.get(@_request.fullpath, headers, max_redirects: 0) }
|
217
198
|
end
|
218
199
|
|
200
|
+
# FIXME: Reimplement for Pulp 3.
|
219
201
|
def push_manifest
|
220
202
|
repository = params[:repository]
|
221
203
|
tag = params[:tag]
|
@@ -242,6 +224,8 @@ module Katello
|
|
242
224
|
render json: {}
|
243
225
|
end
|
244
226
|
|
227
|
+
# FIXME: This is referring to a non-existent Pulp 2 server.
|
228
|
+
# Pulp 3 container push support is needed instead.
|
245
229
|
def pulp_content
|
246
230
|
Katello.pulp_server.resources.content
|
247
231
|
end
|
@@ -414,6 +398,7 @@ module Katello
|
|
414
398
|
tar_file
|
415
399
|
end
|
416
400
|
|
401
|
+
# FIXME: Reimplement for Pulp 3.
|
417
402
|
def upload_manifest(tar_file)
|
418
403
|
upload_id = pulp_content.create_upload_request['upload_id']
|
419
404
|
filename = tmp_file(tar_file)
|
@@ -439,6 +424,7 @@ module Katello
|
|
439
424
|
pulp_content.delete_upload_request(upload_id) if upload_id
|
440
425
|
end
|
441
426
|
|
427
|
+
# FIXME: Reimplement for Pulp 3.
|
442
428
|
def upload_tag(digest, tag)
|
443
429
|
upload_id = pulp_content.create_upload_request['upload_id']
|
444
430
|
uploads = [{
|
@@ -59,6 +59,16 @@ module Katello
|
|
59
59
|
@host = facet.host
|
60
60
|
end
|
61
61
|
|
62
|
+
rescue_from RestClient::Exception do |e|
|
63
|
+
Rails.logger.error(pp_exception(e, with_backtrace: false))
|
64
|
+
Rails.logger.error(e.backtrace.detect { |line| line.match("katello.*controller") })
|
65
|
+
if request_from_katello_cli?
|
66
|
+
render :json => { :errors => [e.http_body] }, :status => e.http_code
|
67
|
+
else
|
68
|
+
render :plain => e.http_body, :status => e.http_code
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
62
72
|
def authorize_client_or_user
|
63
73
|
client_authorized? || authorize
|
64
74
|
end
|
@@ -211,7 +211,7 @@ module Katello
|
|
211
211
|
|
212
212
|
#api :POST, "/environments/:environment_id/consumers", N_("Register a consumer in environment")
|
213
213
|
def consumer_create
|
214
|
-
host = Katello::RegistrationManager.process_registration(rhsm_params,
|
214
|
+
host = Katello::RegistrationManager.process_registration(rhsm_params, find_content_view_environments)
|
215
215
|
|
216
216
|
host.reload
|
217
217
|
|
@@ -271,7 +271,7 @@ module Katello
|
|
271
271
|
|
272
272
|
def get_parent_host(headers)
|
273
273
|
hostnames = headers["HTTP_X_FORWARDED_HOST"]
|
274
|
-
host = hostnames.split(/[
|
274
|
+
host = hostnames.split(/[,,:]/)[0].strip if hostnames
|
275
275
|
host || URI.parse(Setting[:foreman_url]).host
|
276
276
|
end
|
277
277
|
|
@@ -308,21 +308,27 @@ module Katello
|
|
308
308
|
@host = ::Host::Managed.unscoped.find(facet.host_id)
|
309
309
|
end
|
310
310
|
|
311
|
-
def
|
312
|
-
|
311
|
+
def find_content_view_environments
|
312
|
+
environments = []
|
313
313
|
|
314
314
|
if params.key?(:environment_id)
|
315
|
-
|
316
|
-
elsif params.key?(:
|
315
|
+
environments = [get_content_view_environment("cp_id", params[:environment_id])]
|
316
|
+
elsif params.key?(:environments)
|
317
|
+
if params['environments'].length > 1 && !Setting['allow_multiple_content_views']
|
318
|
+
fail HttpErrors::BadRequest, _('Registering to multiple environments is not enabled.')
|
319
|
+
end
|
320
|
+
environments = params[:environments].map do |env|
|
321
|
+
get_content_view_environment("cp_id", env['id'])
|
322
|
+
end
|
323
|
+
elsif params.key?(:organization_id) && !params.key?(:environment_id) && !params.key?(:environments)
|
317
324
|
organization = Organization.current
|
318
|
-
|
325
|
+
environments = organization.library.content_view_environment
|
319
326
|
elsif User.current.default_organization.present?
|
320
|
-
|
327
|
+
environments = User.current.default_organization.library.content_view_environment
|
321
328
|
else
|
322
329
|
fail HttpErrors::NotFound, _("User '%s' did not specify an organization ID and does not have a default organization.") % current_user.login
|
323
330
|
end
|
324
|
-
|
325
|
-
environment
|
331
|
+
environments
|
326
332
|
end
|
327
333
|
|
328
334
|
def find_hypervisor_organization
|
@@ -11,6 +11,7 @@ module Katello
|
|
11
11
|
:content_override, :add_subscriptions, :remove_subscriptions,
|
12
12
|
:subscriptions]
|
13
13
|
before_action :verify_simple_content_access_disabled, :only => [:add_subscriptions]
|
14
|
+
before_action :validate_release_version, :only => [:create, :update]
|
14
15
|
|
15
16
|
wrap_parameters :include => (ActivationKey.attribute_names + %w(host_collection_ids service_level auto_attach purpose_role purpose_usage purpose_addons content_view_environment))
|
16
17
|
|
@@ -229,6 +230,7 @@ module Katello
|
|
229
230
|
param :id, String, :desc => N_("ID of the activation key"), :required => true
|
230
231
|
param :content_access_mode_all, :bool, :desc => N_("Get all content available, not just that provided by subscriptions")
|
231
232
|
param :content_access_mode_env, :bool, :desc => N_("Limit content to just that available in the activation key's content view version")
|
233
|
+
param_group :search, Api::V2::ApiController
|
232
234
|
def product_content
|
233
235
|
# note this is just there as a place holder for apipie.
|
234
236
|
# The routing would automatically redirect it to repository_sets#index
|
@@ -337,5 +339,12 @@ module Katello
|
|
337
339
|
fail HttpErrors::BadRequest, _("The specified organization is in Simple Content Access mode. Attaching subscriptions is disabled")
|
338
340
|
end
|
339
341
|
end
|
342
|
+
|
343
|
+
def validate_release_version
|
344
|
+
@organization ||= find_organization
|
345
|
+
if params[:release_version].present? && !@organization.library.available_releases.include?(params[:release_version])
|
346
|
+
fail HttpErrors::BadRequest, _("Invalid release version: [%s]") % params[:release_version]
|
347
|
+
end
|
348
|
+
end
|
340
349
|
end
|
341
350
|
end
|
@@ -2,10 +2,12 @@ module Katello
|
|
2
2
|
class Api::V2::AlternateContentSourcesController < Api::V2::ApiController
|
3
3
|
include Katello::Concerns::FilteredAutoCompleteSearch
|
4
4
|
|
5
|
-
acs_wrap_params = AlternateContentSource.attribute_names + [:smart_proxy_ids, :smart_proxy_names]
|
5
|
+
acs_wrap_params = AlternateContentSource.attribute_names + [:smart_proxy_ids, :smart_proxy_names, :product_ids]
|
6
6
|
wrap_parameters :alternate_content_source, include: acs_wrap_params
|
7
7
|
|
8
8
|
before_action :find_authorized_katello_resource, only: [:show, :update, :destroy, :refresh]
|
9
|
+
before_action :find_smart_proxies, only: :create
|
10
|
+
before_action :find_products, only: :create
|
9
11
|
|
10
12
|
def_param_group :acs do
|
11
13
|
param :name, String, desc: N_("Name of the alternate content source")
|
@@ -14,18 +16,18 @@ module Katello
|
|
14
16
|
param :subpaths, Array, desc: N_('Path suffixes for finding alternate content'), required: false
|
15
17
|
param :smart_proxy_ids, Array, desc: N_("Ids of smart proxies to associate"), required: false
|
16
18
|
param :smart_proxy_names, Array, desc: N_("Names of smart proxies to associate"), required: false
|
17
|
-
param :content_type, RepositoryTypeManager.defined_repository_types.keys & AlternateContentSource::CONTENT_TYPES, desc: N_("The content type for the Alternate Content Source"), required: false
|
18
|
-
param :alternate_content_source_type, AlternateContentSource::ACS_TYPES, desc: N_("The Alternate Content Source type")
|
19
19
|
param :upstream_username, String, desc: N_("Basic authentication username"), required: false
|
20
20
|
param :upstream_password, String, desc: N_("Basic authentication password"), required: false
|
21
21
|
param :ssl_ca_cert_id, :number, desc: N_("Identifier of the content credential containing the SSL CA Cert"), required: false
|
22
22
|
param :ssl_client_cert_id, :number, desc: N_("Identifier of the content credential containing the SSL Client Cert"), required: false
|
23
23
|
param :ssl_client_key_id, :number, desc: N_("Identifier of the content credential containing the SSL Client Key"), required: false
|
24
|
-
param :http_proxy_id, :number, desc: N_("ID of a HTTP Proxy"), required: false
|
25
24
|
param :verify_ssl, :bool, desc: N_("If SSL should be verified for the upstream URL"), required: false
|
25
|
+
param :use_http_proxies, :bool, desc: N_("If the smart proxies' assigned HTTP proxies should be used"), required: false
|
26
|
+
param :product_ids, Array, desc: N_("IDs of products to copy repository information from into a Simplified Alternate Content Source. Products must include at least one repository of the chosen content type."), required: false
|
26
27
|
end
|
27
28
|
|
28
|
-
api :GET, "/alternate_content_sources", N_("List
|
29
|
+
api :GET, "/alternate_content_sources", N_("List alternate content sources.")
|
30
|
+
param :name, String, :desc => N_("Name of the alternate content source"), :required => false
|
29
31
|
param_group :search, Api::V2::ApiController
|
30
32
|
add_scoped_search_description_for(AlternateContentSource)
|
31
33
|
def index
|
@@ -33,9 +35,15 @@ module Katello
|
|
33
35
|
format.csv do
|
34
36
|
options[:csv] = true
|
35
37
|
alternate_content_sources = scoped_search(index_relation, :name, :asc)
|
36
|
-
|
37
|
-
|
38
|
-
|
38
|
+
if @acs.custom? || @acs.rhui?
|
39
|
+
csv_response(alternate_content_sources,
|
40
|
+
[:id, :name, :description, :label, :base_url, :subpaths, :content_type, :alternate_content_source_type],
|
41
|
+
['Id', 'Name', 'Description', 'label', 'Base URL', 'Subpaths', 'Content Type', 'Alternate Content Source Type'])
|
42
|
+
elsif @acs.simplified?
|
43
|
+
csv_response(alternate_content_sources,
|
44
|
+
[:id, :name, :description, :label, :content_type, :alternate_content_source_type, :products],
|
45
|
+
['Id', 'Name', 'Description', 'label', 'Content Type', 'Alternate Content Source Type', 'Products'])
|
46
|
+
end
|
39
47
|
end
|
40
48
|
format.any do
|
41
49
|
alternate_content_sources = scoped_search(index_relation, :name, :asc)
|
@@ -45,49 +53,60 @@ module Katello
|
|
45
53
|
end
|
46
54
|
|
47
55
|
def index_relation
|
48
|
-
AlternateContentSource.readable.distinct
|
56
|
+
query = AlternateContentSource.readable.distinct
|
57
|
+
query = query.where(name: params[:name]) if params[:name]
|
58
|
+
query
|
49
59
|
end
|
50
60
|
|
51
|
-
api :GET, '/alternate_content_sources/:id', N_('Show an alternate content source')
|
61
|
+
api :GET, '/alternate_content_sources/:id', N_('Show an alternate content source.')
|
52
62
|
param :id, :number, :required => true, :desc => N_("Alternate content source ID")
|
53
63
|
def show
|
54
64
|
respond_for_show(:resource => @alternate_content_source)
|
55
65
|
end
|
56
66
|
|
57
|
-
api :POST, '/alternate_content_sources', N_('Create an
|
67
|
+
api :POST, '/alternate_content_sources', N_('Create an alternate content source to download content from during repository syncing. Note: alternate content sources are global and affect ALL sync actions on their smart proxies regardless of organization.')
|
68
|
+
param :content_type, RepositoryTypeManager.defined_repository_types.keys & AlternateContentSource::CONTENT_TYPES, desc: N_("The content type for the Alternate Content Source"), required: false
|
69
|
+
param :alternate_content_source_type, AlternateContentSource::ACS_TYPES, desc: N_("The Alternate Content Source type")
|
58
70
|
param_group :acs
|
59
71
|
def create
|
60
|
-
|
61
|
-
|
62
|
-
sync_task(::Actions::Katello::AlternateContentSource::Create, @alternate_content_source, @smart_proxies)
|
72
|
+
@alternate_content_source = ::Katello::AlternateContentSource.new(acs_params.except(:smart_proxy_ids, :smart_proxy_names, :product_ids))
|
73
|
+
sync_task(::Actions::Katello::AlternateContentSource::Create, @alternate_content_source, @smart_proxies, @products)
|
63
74
|
@alternate_content_source.reload
|
64
75
|
respond_for_create(resource: @alternate_content_source)
|
65
76
|
end
|
66
77
|
|
67
|
-
api :PUT, '/alternate_content_sources/:id', N_('Update an alternate content source')
|
78
|
+
api :PUT, '/alternate_content_sources/:id', N_('Update an alternate content source.')
|
68
79
|
param_group :acs
|
69
80
|
param :id, :number, :required => true, :desc => N_("Alternate content source ID")
|
70
81
|
def update
|
71
|
-
# If a user doesn't include smart proxies in the update call, don't accidentally remove all of them.
|
72
|
-
if params[:smart_proxy_ids].nil?
|
82
|
+
# If a user doesn't include smart proxies or products in the update call, don't accidentally remove all of them.
|
83
|
+
if params[:smart_proxy_ids].nil? && params[:smart_proxy_names].nil?
|
73
84
|
@smart_proxies = @alternate_content_source.smart_proxies
|
74
|
-
elsif params[:smart_proxy_ids]
|
85
|
+
elsif params[:smart_proxy_ids] == [] || params[:smart_proxy_names] == []
|
75
86
|
@smart_proxies = []
|
76
87
|
else
|
77
88
|
find_smart_proxies
|
78
89
|
end
|
79
|
-
|
90
|
+
if params[:product_ids].nil?
|
91
|
+
@products = @alternate_content_source.products
|
92
|
+
elsif params[:product_ids] == []
|
93
|
+
@products = []
|
94
|
+
else
|
95
|
+
find_products
|
96
|
+
end
|
97
|
+
|
98
|
+
sync_task(::Actions::Katello::AlternateContentSource::Update, @alternate_content_source, @smart_proxies, @products, acs_params.except(:smart_proxy_ids, :smart_proxy_names, :product_ids))
|
80
99
|
respond_for_show(:resource => @alternate_content_source)
|
81
100
|
end
|
82
101
|
|
83
|
-
api :DELETE, '/alternate_content_sources/:id', N_('Destroy an alternate content source')
|
102
|
+
api :DELETE, '/alternate_content_sources/:id', N_('Destroy an alternate content source.')
|
84
103
|
param :id, :number, :required => true, :desc => N_("Alternate content source ID")
|
85
104
|
def destroy
|
86
105
|
sync_task(::Actions::Katello::AlternateContentSource::Destroy, @alternate_content_source)
|
87
106
|
respond_for_destroy
|
88
107
|
end
|
89
108
|
|
90
|
-
api :POST, '/alternate_content_sources/:id/refresh', N_('Refresh an alternate content source')
|
109
|
+
api :POST, '/alternate_content_sources/:id/refresh', N_('Refresh an alternate content source. Refreshing, like repository syncing, is required before using an alternate content source.')
|
91
110
|
param :id, :number, :required => true, :desc => N_("Alternate content source ID")
|
92
111
|
def refresh
|
93
112
|
task = async_task(::Actions::Katello::AlternateContentSource::Refresh, @alternate_content_source)
|
@@ -97,9 +116,12 @@ module Katello
|
|
97
116
|
protected
|
98
117
|
|
99
118
|
def acs_params
|
100
|
-
keys = [
|
101
|
-
|
102
|
-
|
119
|
+
keys = [
|
120
|
+
:name, :label, :description, {smart_proxy_ids: []}, {smart_proxy_names: []}, :content_type,
|
121
|
+
:alternate_content_source_type, :use_http_proxies, :base_url, {subpaths: []}, :upstream_username,
|
122
|
+
:upstream_password, :ssl_ca_cert_id, :ssl_client_cert_id, :ssl_client_key_id, :verify_ssl, {product_ids: []}
|
123
|
+
]
|
124
|
+
|
103
125
|
params.require(:alternate_content_source).permit(*keys).to_h.with_indifferent_access
|
104
126
|
end
|
105
127
|
|
@@ -117,5 +139,18 @@ module Katello
|
|
117
139
|
fail HttpErrors::NotFound, _("Couldn't find smart proxies with name '%s'") % missing_smart_proxies.to_sentence
|
118
140
|
end
|
119
141
|
end
|
142
|
+
|
143
|
+
def find_products
|
144
|
+
if params[:product_ids]
|
145
|
+
@products = ::Katello::Product.where(id: params[:product_ids])
|
146
|
+
else
|
147
|
+
@products = nil
|
148
|
+
end
|
149
|
+
|
150
|
+
if params[:product_ids] && @products.length < params[:product_ids].length
|
151
|
+
missing_products = params[:product_ids] - @products.pluck(:id)
|
152
|
+
fail HttpErrors::NotFound, _("Couldn't find products with id '%s'") % missing_products.to_sentence
|
153
|
+
end
|
154
|
+
end
|
120
155
|
end
|
121
156
|
end
|
@@ -7,6 +7,7 @@ module Katello
|
|
7
7
|
before_action :find_capsule, :except => [:sync, :cancel_sync, :add_lifecycle_environment, :remove_lifecycle_environment, :reclaim_space]
|
8
8
|
before_action :find_editable_capsule, :only => [:sync, :cancel_sync, :add_lifecycle_environment, :remove_lifecycle_environment]
|
9
9
|
before_action :find_environment, :only => [:add_lifecycle_environment, :remove_lifecycle_environment]
|
10
|
+
before_action :find_acs_http_proxy, :only => [:add_acs_http_proxy]
|
10
11
|
before_action :find_optional_organization, :only => [:sync_status]
|
11
12
|
|
12
13
|
def_param_group :lifecycle_environments do
|
@@ -123,6 +124,10 @@ module Katello
|
|
123
124
|
@environment = Katello::KTEnvironment.readable.find(params[:environment_id])
|
124
125
|
end
|
125
126
|
|
127
|
+
def find_acs_http_proxy
|
128
|
+
@acs_http_proxy = ::HttpProxy.readable.find(params[:alternate_content_source_http_proxy_id])
|
129
|
+
end
|
130
|
+
|
126
131
|
def find_content_view
|
127
132
|
@content_view = Katello::ContentView.readable.find(params[:content_view_id])
|
128
133
|
end
|
@@ -130,9 +135,5 @@ module Katello
|
|
130
135
|
def find_repository
|
131
136
|
@repository = Katello::Repository.readable.find(params[:repository_id])
|
132
137
|
end
|
133
|
-
|
134
|
-
def smart_proxy_service
|
135
|
-
Pulp::SmartProxyRepository.new(@capsule)
|
136
|
-
end
|
137
138
|
end
|
138
139
|
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Katello
|
2
|
-
class Api::V2::ContentExportIncrementalsController < Api::V2::
|
2
|
+
class Api::V2::ContentExportIncrementalsController < Api::V2::ExportsController
|
3
3
|
before_action :find_exportable_organization, :only => [:library]
|
4
4
|
before_action :find_exportable_content_view_version, :only => [:version]
|
5
5
|
before_action :find_exportable_repository, :only => [:repository]
|
@@ -7,70 +7,45 @@ module Katello
|
|
7
7
|
before_action :find_repository_export_view, :only => [:repository]
|
8
8
|
before_action :find_history, :only => [:version, :library, :repository]
|
9
9
|
|
10
|
+
def_param_group :incremental do
|
11
|
+
param :from_history_id, :number, :desc => N_("Export history identifier used for incremental export. "\
|
12
|
+
"If not provided the most recent export history will be used."), :required => false
|
13
|
+
end
|
14
|
+
|
10
15
|
api :POST, "/content_export_incrementals/version", N_("Performs an incremental-export of a content view version.")
|
11
16
|
param :id, :number, :desc => N_("Content view version identifier"), :required => true
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
"If not provided the most recent export history will be used."), :required => false
|
17
|
-
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this version"\
|
18
|
-
" are unexportable. False by default."), :required => false
|
17
|
+
param_group :version_fail_on_missing_content, Api::V2::ExportsController
|
18
|
+
param_group :destination_server, Api::V2::ExportsController
|
19
|
+
param_group :export, Api::V2::ExportsController
|
20
|
+
param_group :incremental
|
19
21
|
def version
|
20
|
-
|
21
|
-
content_view_version: @version,
|
22
|
-
destination_server: params[:destination_server],
|
23
|
-
chunk_size: params[:chunk_size_gb],
|
24
|
-
from_history: @history,
|
25
|
-
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
26
|
-
|
27
|
-
respond_for_async :resource => tasks
|
22
|
+
export_content_view_version
|
28
23
|
end
|
29
24
|
|
30
25
|
api :POST, "/content_export_incrementals/library", N_("Performs an incremental-export of the repositories in library.")
|
31
26
|
param :organization_id, :number, :desc => N_("Organization identifier"), :required => true
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
"If not provided the most recent export history will be used."), :required => false
|
37
|
-
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this organization"\
|
38
|
-
" are unexportable. False by default."), :required => false
|
27
|
+
param_group :org_fail_on_missing_content, Api::V2::ExportsController
|
28
|
+
param_group :destination_server, Api::V2::ExportsController
|
29
|
+
param_group :export, Api::V2::ExportsController
|
30
|
+
param_group :incremental
|
39
31
|
def library
|
40
|
-
|
41
|
-
@organization,
|
42
|
-
destination_server: params[:destination_server],
|
43
|
-
chunk_size: params[:chunk_size_gb],
|
44
|
-
from_history: @history,
|
45
|
-
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
46
|
-
respond_for_async :resource => tasks
|
32
|
+
export_library
|
47
33
|
end
|
48
34
|
|
49
35
|
api :POST, "/content_export_incrementals/repository", N_("Performs a incremental-export of the repository in library.")
|
50
36
|
param :id, :number, :desc => N_("Repository identifier"), :required => true
|
51
|
-
|
52
|
-
|
53
|
-
param :from_history_id, :number, :desc => N_("Export history identifier used for incremental export. "\
|
54
|
-
"If not provided the most recent export history will be used."), :required => false
|
37
|
+
param_group :export, Api::V2::ExportsController
|
38
|
+
param_group :incremental
|
55
39
|
def repository
|
56
|
-
|
57
|
-
@repository,
|
58
|
-
chunk_size: params[:chunk_size_gb],
|
59
|
-
from_history: @history)
|
60
|
-
respond_for_async :resource => tasks
|
40
|
+
export_repository
|
61
41
|
end
|
62
42
|
|
63
43
|
private
|
64
44
|
|
65
|
-
def find_exportable_content_view_version
|
66
|
-
@version = ContentViewVersion.exportable.find_by_id(params[:id])
|
67
|
-
throw_resource_not_found(name: 'content view version', id: params[:id]) if @version.blank?
|
68
|
-
@view = @version.content_view
|
69
|
-
end
|
70
|
-
|
71
45
|
def find_library_export_view
|
72
46
|
@view = ::Katello::Pulp3::ContentViewVersion::Export.find_library_export_view(destination_server: params[:destination_server],
|
73
47
|
organization: @organization,
|
48
|
+
format: find_export_format,
|
74
49
|
create_by_default: false)
|
75
50
|
if @view.blank?
|
76
51
|
msg = _("Unable to incrementally export. Do a Full Export on the library content "\
|
@@ -82,46 +57,12 @@ module Katello
|
|
82
57
|
def find_repository_export_view
|
83
58
|
@view = ::Katello::Pulp3::ContentViewVersion::Export.find_repository_export_view(
|
84
59
|
repository: @repository,
|
85
|
-
create_by_default: false
|
60
|
+
create_by_default: false,
|
61
|
+
format: find_export_format)
|
86
62
|
if @view.blank?
|
87
63
|
msg = _("Unable to incrementally export. Do a Full Export on the repository content.")
|
88
64
|
fail HttpErrors::BadRequest, msg
|
89
65
|
end
|
90
66
|
end
|
91
|
-
|
92
|
-
def find_history
|
93
|
-
if params[:from_history_id].present?
|
94
|
-
@history = ::Katello::ContentViewVersionExportHistory.find(params[:from_history_id])
|
95
|
-
if @history.blank?
|
96
|
-
throw_resource_not_found(name: 'export history',
|
97
|
-
id: params[:from_history_id])
|
98
|
-
end
|
99
|
-
else
|
100
|
-
@history = ::Katello::ContentViewVersionExportHistory.
|
101
|
-
latest(@view, destination_server: params[:destination_server])
|
102
|
-
if @history.blank?
|
103
|
-
msg = _("No existing export history was found to perform an incremental export. A full export must be performed")
|
104
|
-
fail HttpErrors::NotFound, msg
|
105
|
-
end
|
106
|
-
end
|
107
|
-
end
|
108
|
-
|
109
|
-
def find_exportable_organization
|
110
|
-
find_organization
|
111
|
-
unless @organization.can_export_content?
|
112
|
-
throw_resource_not_found(name: 'organization', id: params[:organization_id])
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
def find_exportable_repository
|
117
|
-
@repository = Repository.find_by_id(params[:id])
|
118
|
-
if @repository.blank?
|
119
|
-
throw_resource_not_found(name: 'repository', id: params[:id])
|
120
|
-
end
|
121
|
-
|
122
|
-
unless @repository.organization.can_export_content?
|
123
|
-
throw_resource_not_found(name: 'organization', id: @repository.organization.id)
|
124
|
-
end
|
125
|
-
end
|
126
67
|
end
|
127
68
|
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Katello
|
2
|
-
class Api::V2::ContentExportsController < Api::V2::
|
2
|
+
class Api::V2::ContentExportsController < Api::V2::ExportsController
|
3
3
|
before_action :find_exportable_organization, :only => [:library]
|
4
4
|
before_action :find_exportable_content_view_version, :only => [:version]
|
5
5
|
before_action :find_exportable_repository, :only => [:repository]
|
@@ -29,96 +29,27 @@ module Katello
|
|
29
29
|
|
30
30
|
api :POST, "/content_exports/version", N_("Performs a full-export of a content view version.")
|
31
31
|
param :id, :number, :desc => N_("Content view version identifier"), :required => true
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this version"\
|
36
|
-
" are unexportable. False by default."), :required => false
|
37
|
-
param :format, ::Katello::Pulp3::ContentViewVersion::Export::FORMATS,
|
38
|
-
:desc => N_("Export formats. Choose syncable if content is to be imported via repository sync. "\
|
39
|
-
"Choose importable if content is to be imported via hammer content-import.
|
40
|
-
Defaults to importable."),
|
41
|
-
:required => false
|
32
|
+
param_group :version_fail_on_missing_content, Api::V2::ExportsController
|
33
|
+
param_group :destination_server, Api::V2::ExportsController
|
34
|
+
param_group :export, Api::V2::ExportsController
|
42
35
|
def version
|
43
|
-
|
44
|
-
content_view_version: @version,
|
45
|
-
destination_server: params[:destination_server],
|
46
|
-
chunk_size: params[:chunk_size_gb],
|
47
|
-
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]),
|
48
|
-
format: find_export_format)
|
49
|
-
respond_for_async :resource => tasks
|
36
|
+
export_content_view_version
|
50
37
|
end
|
51
38
|
|
52
39
|
api :POST, "/content_exports/library", N_("Performs a full-export of the repositories in library.")
|
53
40
|
param :organization_id, :number, :desc => N_("Organization identifier"), :required => true
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this organization"\
|
58
|
-
" are unexportable. False by default."), :required => false
|
59
|
-
param :format, ::Katello::Pulp3::ContentViewVersion::Export::FORMATS,
|
60
|
-
:desc => N_("Export formats. Choose syncable if content is to be imported via repository sync. "\
|
61
|
-
"Choose importable if content is to be imported via hammer content-import.
|
62
|
-
Defaults to importable."),
|
63
|
-
:required => false
|
41
|
+
param_group :org_fail_on_missing_content, Api::V2::ExportsController
|
42
|
+
param_group :destination_server, Api::V2::ExportsController
|
43
|
+
param_group :export, Api::V2::ExportsController
|
64
44
|
def library
|
65
|
-
|
66
|
-
@organization,
|
67
|
-
destination_server: params[:destination_server],
|
68
|
-
chunk_size: params[:chunk_size_gb],
|
69
|
-
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]),
|
70
|
-
format: find_export_format)
|
71
|
-
respond_for_async :resource => tasks
|
45
|
+
export_library
|
72
46
|
end
|
73
47
|
|
74
48
|
api :POST, "/content_exports/repository", N_("Performs a full-export of the repository in library.")
|
75
49
|
param :id, :number, :desc => N_("Repository identifier"), :required => true
|
76
|
-
|
77
|
-
"no greater than the specified size in gigabytes."), :required => false
|
78
|
-
param :format, ::Katello::Pulp3::ContentViewVersion::Export::FORMATS,
|
79
|
-
:desc => N_("Export formats. Choose syncable if content is to be imported via repository sync. "\
|
80
|
-
"Choose importable if content is to be imported via hammer content-import.
|
81
|
-
Defaults to importable."),
|
82
|
-
:required => false
|
50
|
+
param_group :export, Api::V2::ExportsController
|
83
51
|
def repository
|
84
|
-
|
85
|
-
@repository,
|
86
|
-
chunk_size: params[:chunk_size_gb],
|
87
|
-
format: find_export_format)
|
88
|
-
respond_for_async :resource => tasks
|
89
|
-
end
|
90
|
-
|
91
|
-
private
|
92
|
-
|
93
|
-
def find_exportable_repository
|
94
|
-
@repository = Repository.find_by_id(params[:id])
|
95
|
-
if @repository.blank? || !@repository.organization.can_export_content?
|
96
|
-
throw_resource_not_found(name: 'repository', id: params[:id])
|
97
|
-
end
|
98
|
-
end
|
99
|
-
|
100
|
-
def find_exportable_content_view_version
|
101
|
-
@version = ContentViewVersion.exportable.find_by_id(params[:id])
|
102
|
-
throw_resource_not_found(name: 'content view version', id: params[:id]) if @version.blank?
|
103
|
-
end
|
104
|
-
|
105
|
-
def find_exportable_organization
|
106
|
-
find_organization
|
107
|
-
unless @organization.can_export_content?
|
108
|
-
throw_resource_not_found(name: 'organization', id: params[:organization_id])
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
def find_export_format
|
113
|
-
if params[:format]
|
114
|
-
unless ::Katello::Pulp3::ContentViewVersion::Export::FORMATS.include?(params[:format])
|
115
|
-
fail HttpErrors::UnprocessableEntity, _('Invalid export format provided. Format must be one of %s ') %
|
116
|
-
::Katello::Pulp3::ContentViewVersion::Export::FORMATS.join(',')
|
117
|
-
end
|
118
|
-
params[:format]
|
119
|
-
else
|
120
|
-
::Katello::Pulp3::ContentViewVersion::Export::IMPORTABLE
|
121
|
-
end
|
52
|
+
export_repository
|
122
53
|
end
|
123
54
|
end
|
124
55
|
end
|