katello 3.16.1.2 → 3.18.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/stylesheets/katello/katello.scss +3 -7
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +42 -23
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +1 -1
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +4 -2
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +17 -14
- data/app/controllers/katello/api/v2/api_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_credentials_controller.rb +2 -9
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +5 -5
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +31 -14
- data/app/controllers/katello/api/v2/content_view_repositories_controller.rb +48 -0
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +92 -24
- data/app/controllers/katello/api/v2/content_views_controller.rb +27 -25
- data/app/controllers/katello/api/v2/environments_controller.rb +8 -8
- data/app/controllers/katello/api/v2/gpg_keys_controller.rb +6 -6
- data/app/controllers/katello/api/v2/host_collections_controller.rb +19 -16
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +10 -4
- data/app/controllers/katello/api/v2/host_tracer_controller.rb +16 -36
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +39 -1
- data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +23 -16
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +2 -2
- data/app/controllers/katello/api/v2/sync_plans_controller.rb +8 -9
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +23 -0
- data/app/controllers/katello/concerns/api/v2/{associations_permission_check.rb → authorization.rb} +24 -2
- data/app/controllers/katello/concerns/api/v2/bulk_hosts_extensions.rb +4 -4
- data/app/controllers/katello/concerns/api/v2/hostgroups_controller_extensions.rb +1 -1
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +21 -0
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +1 -1
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +24 -0
- data/app/helpers/katello/concerns/dashboard_helper_extensions.rb +10 -0
- data/app/helpers/katello/content_view_helper.rb +1 -1
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +6 -7
- data/app/helpers/katello/katello_urls_helper.rb +5 -2
- data/app/lib/actions/candlepin/product/content_create.rb +2 -0
- data/app/lib/actions/candlepin/product/content_update.rb +2 -0
- data/app/lib/actions/katello/capsule_content/sync.rb +1 -1
- data/app/lib/actions/katello/content_view/capsule_sync.rb +1 -1
- data/app/lib/actions/katello/content_view/destroy.rb +2 -2
- data/app/lib/actions/katello/content_view/incremental_updates.rb +1 -1
- data/app/lib/actions/katello/content_view/promote.rb +2 -2
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +13 -3
- data/app/lib/actions/katello/content_view/publish.rb +29 -9
- data/app/lib/actions/katello/content_view_puppet_environment/clone.rb +1 -1
- data/app/lib/actions/katello/content_view_puppet_environment/create.rb +2 -2
- data/app/lib/actions/katello/content_view_version/import.rb +37 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +23 -8
- data/app/lib/actions/katello/host/hypervisors_update.rb +18 -0
- data/app/lib/actions/katello/host/update_system_purpose.rb +31 -0
- data/app/lib/actions/katello/organization/create.rb +1 -1
- data/app/lib/actions/katello/organization/simple_content_access/disable.rb +25 -0
- data/app/lib/actions/katello/organization/simple_content_access/enable.rb +25 -0
- data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +50 -0
- data/app/lib/actions/katello/orphan_cleanup/remove_orphans.rb +13 -0
- data/app/lib/actions/katello/product/content_create.rb +7 -6
- data/app/lib/actions/katello/repository/clone_contents.rb +3 -3
- data/app/lib/actions/katello/repository/clone_to_environment.rb +2 -2
- data/app/lib/actions/katello/repository/clone_to_version.rb +1 -1
- data/app/lib/actions/katello/repository/create.rb +1 -1
- data/app/lib/actions/katello/repository/destroy.rb +5 -3
- data/app/lib/actions/katello/repository/export.rb +3 -3
- data/app/lib/actions/katello/repository/filtered_index_content.rb +10 -1
- data/app/lib/actions/katello/repository/finish_upload.rb +2 -2
- data/app/lib/actions/katello/repository/import_upload.rb +5 -4
- data/app/lib/actions/katello/repository/metadata_generate.rb +1 -1
- data/app/lib/actions/katello/repository/multi_clone_contents.rb +9 -7
- data/app/lib/actions/katello/repository/purge_empty_content.rb +1 -1
- data/app/lib/actions/katello/repository/remove_content.rb +1 -1
- data/app/lib/actions/katello/repository/sync.rb +2 -2
- data/app/lib/actions/katello/repository/update.rb +6 -3
- data/app/lib/actions/katello/repository/update_http_proxy_details.rb +1 -1
- data/app/lib/actions/katello/repository/update_metadata_sync.rb +1 -1
- data/app/lib/actions/katello/repository/upload_files.rb +2 -2
- data/app/lib/actions/katello/repository/verify_checksum.rb +2 -2
- data/app/lib/actions/pulp/content_view_puppet_environment/copy_contents.rb +1 -1
- data/app/lib/actions/pulp/orchestration/orphan_cleanup/remove_orphans.rb +1 -1
- data/app/lib/actions/pulp/orchestration/repository/smart_proxy_sync.rb +1 -0
- data/app/lib/actions/pulp/repository/copy_all_units.rb +1 -1
- data/app/lib/actions/pulp/repository/copy_units.rb +1 -1
- data/app/lib/actions/pulp/repository/create.rb +1 -1
- data/app/lib/actions/pulp/repository/destroy.rb +1 -1
- data/app/lib/actions/pulp/repository/remove_units.rb +2 -2
- data/app/lib/actions/pulp/repository/sync.rb +1 -1
- data/app/lib/actions/pulp3/content_guard/refresh_all_distributions.rb +19 -0
- data/app/lib/actions/pulp3/content_migration.rb +3 -3
- data/app/lib/actions/pulp3/content_view_version/create_exporter.rb +20 -0
- data/app/lib/actions/pulp3/content_view_version/create_importer.rb +24 -0
- data/app/lib/actions/pulp3/content_view_version/destroy_exporter.rb +16 -0
- data/app/lib/actions/pulp3/content_view_version/destroy_importer.rb +16 -0
- data/app/lib/actions/pulp3/content_view_version/export.rb +20 -0
- data/app/lib/actions/pulp3/content_view_version/import.rb +25 -0
- data/app/lib/actions/pulp3/import_migration.rb +3 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +25 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +82 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +47 -0
- data/app/lib/actions/pulp3/orchestration/repository/create.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/repository/upload_content.rb +1 -1
- data/app/lib/actions/pulp3/repository/commit_upload.rb +2 -1
- data/app/lib/actions/pulp3/repository/copy_content.rb +6 -1
- data/app/lib/actions/pulp3/repository/multi_copy_units.rb +2 -2
- data/app/lib/actions/pulp3/repository/refresh_distribution.rb +11 -5
- data/app/lib/actions/pulp3/repository/save_artifact.rb +2 -2
- data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -2
- data/app/lib/actions/pulp3/repository/save_version.rb +1 -1
- data/app/lib/actions/pulp3/repository/save_versions.rb +1 -1
- data/app/lib/actions/pulp3/repository/upload_file.rb +1 -1
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +5 -3
- data/app/lib/katello/concerns/permission_extensions.rb +14 -0
- data/app/lib/katello/foreman.rb +1 -1
- data/app/lib/katello/resources/candlepin/consumer.rb +2 -2
- data/app/lib/katello/resources/candlepin/owner.rb +5 -0
- data/app/lib/katello/resources/candlepin/upstream_consumer.rb +6 -0
- data/app/lib/katello/resources/registry.rb +6 -6
- data/app/lib/katello/validators/hostgroup_kickstart_repository_validator.rb +11 -11
- data/app/models/katello/activation_key.rb +1 -1
- data/app/models/katello/authorization/activation_key.rb +4 -0
- data/app/models/katello/authorization/content_view.rb +13 -0
- data/app/models/katello/authorization/content_view_component.rb +15 -0
- data/app/models/katello/authorization/content_view_version_export_history.rb +11 -0
- data/app/models/katello/authorization/gpg_key.rb +12 -4
- data/app/models/katello/authorization/lifecycle_environment.rb +8 -0
- data/app/models/katello/authorization/product.rb +4 -0
- data/app/models/katello/authorization/repository.rb +8 -0
- data/app/models/katello/authorization/sync_plan.rb +16 -0
- data/app/models/katello/concerns/content_facet_host_extensions.rb +9 -1
- data/app/models/katello/concerns/host_managed_extensions.rb +39 -0
- data/app/models/katello/concerns/hostgroup_extensions.rb +46 -24
- data/app/models/katello/concerns/organization_extensions.rb +5 -1
- data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
- data/app/models/katello/concerns/redhat_extensions.rb +4 -2
- data/app/models/katello/concerns/smart_proxy_extensions.rb +21 -18
- data/app/models/katello/concerns/subscription_facet_host_extensions.rb +1 -1
- data/app/models/katello/concerns/widget_extensions.rb +23 -0
- data/app/models/katello/content_view.rb +16 -2
- data/app/models/katello/content_view_component.rb +2 -0
- data/app/models/katello/content_view_puppet_environment.rb +1 -1
- data/app/models/katello/content_view_version.rb +20 -2
- data/app/models/katello/content_view_version_export_history.rb +24 -0
- data/app/models/katello/docker_meta_tag.rb +1 -1
- data/app/models/katello/errata_status.rb +21 -12
- data/app/models/katello/erratum.rb +14 -1
- data/app/models/katello/erratum_cve.rb +8 -0
- data/app/models/katello/glue/candlepin/owner.rb +4 -2
- data/app/models/katello/glue/candlepin/pool.rb +9 -14
- data/app/models/katello/glue/pulp/repo.rb +12 -2
- data/app/models/katello/gpg_key.rb +1 -1
- data/app/models/katello/host/content_facet.rb +25 -0
- data/app/models/katello/host_collection.rb +6 -0
- data/app/models/katello/hostgroup/content_facet.rb +18 -0
- data/app/models/katello/installed_package.rb +8 -0
- data/app/models/katello/kt_environment.rb +10 -2
- data/app/models/katello/model.rb +16 -0
- data/app/models/katello/package_group.rb +1 -1
- data/app/models/katello/ping.rb +8 -3
- data/app/models/katello/pool.rb +17 -0
- data/app/models/katello/product.rb +6 -0
- data/app/models/katello/pulp3/content_guard.rb +1 -1
- data/app/models/katello/purpose_addons_status.rb +1 -0
- data/app/models/katello/purpose_role_status.rb +1 -0
- data/app/models/katello/purpose_sla_status.rb +1 -0
- data/app/models/katello/purpose_status.rb +2 -2
- data/app/models/katello/purpose_usage_status.rb +1 -0
- data/app/models/katello/repository.rb +21 -16
- data/app/models/katello/rhsm_fact_parser.rb +1 -1
- data/app/models/katello/root_repository.rb +42 -14
- data/app/models/katello/subscription_status.rb +1 -1
- data/app/models/katello/sync_plan.rb +8 -0
- data/app/models/katello/trace_status.rb +1 -1
- data/app/models/setting/content.rb +7 -1
- data/app/overrides/add_organization_attributes.rb +12 -0
- data/app/services/katello/candlepin/event_handler.rb +3 -0
- data/app/services/katello/candlepin/message_handler.rb +34 -0
- data/app/services/katello/candlepin/upstream_consumer.rb +28 -0
- data/app/services/katello/event_daemon.rb +7 -8
- data/app/services/katello/host_status_manager.rb +29 -0
- data/app/services/katello/host_trace_manager.rb +38 -0
- data/app/services/katello/pulp/content.rb +1 -1
- data/app/services/katello/pulp/repository.rb +7 -7
- data/app/services/katello/pulp/repository/deb.rb +2 -2
- data/app/services/katello/pulp/repository/docker.rb +5 -5
- data/app/services/katello/pulp/repository/file.rb +2 -2
- data/app/services/katello/pulp/repository/ostree.rb +2 -2
- data/app/services/katello/pulp/repository/puppet.rb +2 -2
- data/app/services/katello/pulp/repository/yum.rb +5 -6
- data/app/services/katello/pulp/smart_proxy_repository.rb +1 -1
- data/app/services/katello/pulp3/ansible_collection.rb +2 -2
- data/app/services/katello/pulp3/api/apt.rb +57 -0
- data/app/services/katello/pulp3/api/core.rb +24 -0
- data/app/services/katello/pulp3/content.rb +3 -3
- data/app/services/katello/pulp3/content_view_version/export.rb +68 -0
- data/app/services/katello/pulp3/content_view_version/import.rb +77 -0
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +44 -0
- data/app/services/katello/pulp3/deb.rb +38 -0
- data/app/services/katello/pulp3/distribution.rb +2 -2
- data/app/services/katello/pulp3/docker_blob.rb +2 -2
- data/app/services/katello/pulp3/docker_manifest.rb +2 -2
- data/app/services/katello/pulp3/docker_manifest_list.rb +2 -2
- data/app/services/katello/pulp3/docker_tag.rb +2 -2
- data/app/services/katello/pulp3/erratum.rb +2 -2
- data/app/services/katello/pulp3/file_unit.rb +2 -2
- data/app/services/katello/pulp3/migration.rb +139 -34
- data/app/services/katello/pulp3/migration_plan.rb +50 -14
- data/app/services/katello/pulp3/migration_switchover.rb +41 -9
- data/app/services/katello/pulp3/module_stream.rb +2 -2
- data/app/services/katello/pulp3/package_group.rb +2 -2
- data/app/services/katello/pulp3/pulp_content_unit.rb +5 -0
- data/app/services/katello/pulp3/repository.rb +9 -2
- data/app/services/katello/pulp3/repository/ansible_collection.rb +9 -0
- data/app/services/katello/pulp3/repository/apt.rb +63 -0
- data/app/services/katello/pulp3/repository/docker.rb +22 -10
- data/app/services/katello/pulp3/repository/yum.rb +24 -11
- data/app/services/katello/pulp3/repository_mirror.rb +11 -5
- data/app/services/katello/pulp3/rpm.rb +2 -2
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +1 -1
- data/app/services/katello/pulp3/smart_proxy_repository.rb +1 -1
- data/app/services/katello/pulp3/srpm.rb +2 -2
- data/app/services/katello/pulp3/task.rb +1 -1
- data/app/services/katello/pulp3/task_group.rb +1 -1
- data/app/services/katello/pulp3/yum_metadata_file.rb +2 -2
- data/app/services/katello/registration_manager.rb +9 -3
- data/app/services/katello/repository_type.rb +1 -1
- data/app/services/katello/smart_proxy_helper.rb +1 -1
- data/app/services/katello/ui_notifications/subscriptions/sca_disable_error.rb +13 -0
- data/app/services/katello/ui_notifications/subscriptions/sca_disable_success.rb +13 -0
- data/app/services/katello/ui_notifications/subscriptions/sca_enable_error.rb +13 -0
- data/app/services/katello/ui_notifications/subscriptions/sca_enable_success.rb +13 -0
- data/app/views/dashboard/_subscription_widget.html.erb +0 -5
- data/app/views/foreman/job_templates/install_errata_-_katello_ansible_default.erb +10 -2
- data/app/views/foreman/smart_proxies/_content_sync.html.erb +1 -1
- data/app/views/katello/api/v2/content_view_repositories/show_all.json.rabl +8 -0
- data/app/views/katello/api/v2/content_view_version_export_histories/index.json.rabl +7 -0
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +13 -0
- data/app/views/katello/api/v2/package_groups/show.json.rabl +1 -1
- data/app/views/katello/api/v2/packages/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repositories/base.json.rabl +2 -1
- data/app/views/katello/api/v2/srpms/show.json.rabl +1 -1
- data/app/views/katello/api/v2/sync_plans/show.json.rabl +2 -1
- data/app/views/overrides/organizations/_edit_override.html.erb +10 -1
- data/app/views/overrides/organizations/_index_header_override.html.erb +3 -0
- data/app/views/overrides/organizations/_index_row_override.html.erb +3 -0
- data/config/routes/api/v2.rb +11 -7
- data/config/routes/overrides.rb +5 -0
- data/db/migrate/20141222151001_add_host_content_view_environment.rb +1 -1
- data/db/migrate/20180904122343_create_hostgroup_content_facet.katello.rb +16 -0
- data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +53 -0
- data/db/migrate/20200610112009_remove_audits_of_root_repo_with_content_id.rb +9 -0
- data/db/migrate/20200701150946_add_auto_enabled_to_root_repository.rb +5 -0
- data/db/migrate/20200818040551_add_content_view_version_export_history.rb +13 -0
- data/db/migrate/20200818192230_update_system_purpose_status.rb +12 -0
- data/db/migrate/20200820145217_add_download_concurrency_to_katello_root_repositories.rb +5 -0
- data/db/migrate/20200910140340_remove_distribution_uuid.rb +5 -0
- data/db/migrate/20200914200906_remove_auto_enabled.rb +5 -0
- data/db/migrate/20201008204114_add_os_versions_to_katello_root_repositories.rb +5 -0
- data/db/migrate/20201012172713_remove_gpg_key_perms.rb +23 -0
- data/db/migrate/20201012192035_add_metadata_to_katello_content_view_version_export_history.rb +5 -0
- data/db/seeds.d/109-katello-notification-blueprints.rb +24 -0
- data/db/seeds.d/111-upgrade_tasks.rb +2 -1
- data/db/seeds.d/75-job_templates.rb +2 -2
- data/engines/bastion/app/assets/javascripts/bastion/bastion.js +1 -0
- data/engines/bastion/app/assets/javascripts/bastion/components/notification.service.js +1 -1
- data/engines/bastion/app/assets/javascripts/bastion/components/nutupane.factory.js +11 -14
- data/engines/bastion/app/assets/javascripts/bastion/routing.module.js +1 -1
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-ui-router/stateEvents.js +300 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/activation-keys.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-add-subscriptions.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-associations.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-repository-sets.controller.js +4 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-subscriptions.controller.js +3 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-add-subscriptions.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-associations-content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-repository-sets.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-products.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-credentials/details/content-credential-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-errata-modal.controller.js +5 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-host-collections-modal.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-module-streams-modal.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-packages-modal.controller.js +4 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-repository-sets-modal.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-subscriptions-modal.controller.js +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-system-purpose-modal.controller.js +112 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-traces-modal.controller.js +4 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-environment-modal.html +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-errata-modal.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-packages-modal.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +78 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-modal-helper.service.js +11 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts-helper.service.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +10 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.routes.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-debs-installed.controller.js +3 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-errata.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-module-streams.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-applicable.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-traces.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-add-host-collections.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-add-subscriptions.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details-info.controller.js +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-host-collections.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-repository-sets.controller.js +4 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-subscriptions.controller.js +3 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-add-subscriptions.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-details.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +16 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-repository-sets.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-subscriptions-list.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +10 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-names.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-versions.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-modules.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/debs.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/deb-content-views.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/debs/details/deb-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment-content.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/details/erratum-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/files/details/file-content-views.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/files/details/file-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/files/files.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/host-collection-details.controller.js +9 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-info.html +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/host-collections.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/host-bulk-action.factory.js +3 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +51 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +58 -13
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +46 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +43 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +46 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +37 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +4 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/fenced-pages.service.js +11 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/organization-selector.controller.js +5 -14
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/ostree-branch-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/package-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/packages.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/bulk/products-bulk-advanced-sync-modal.controller.js +6 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/bulk/products-bulk-sync-plan-modal.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/product-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +168 -155
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-manage-content.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +19 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +125 -113
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +20 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/os-versions.service.js +46 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-content-views.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-repositories.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/sync-plan-details-info.controller.js +4 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/views/sync-plan-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/views/sync-plan-info.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/sync-plans.controller.js +1 -1
- data/lib/katello/engine.rb +9 -5
- data/lib/katello/permission_creator.rb +81 -67
- data/lib/katello/permissions/host_permissions.rb +2 -0
- data/lib/katello/plugin.rb +24 -17
- data/lib/katello/repository_types/deb.rb +9 -1
- data/lib/katello/tasks/clean_published_repo_directories.rake +3 -3
- data/lib/katello/tasks/pulp3_content_switchover.rake +24 -6
- data/lib/katello/tasks/pulp3_migration.rake +4 -2
- data/lib/katello/tasks/pulp3_migration_stats.rake +21 -0
- data/lib/katello/tasks/pulp3_post_migration_check.rake +2 -2
- data/lib/katello/tasks/reimport.rake +2 -2
- data/lib/katello/tasks/reports.rake +0 -12
- data/lib/katello/tasks/repository.rake +15 -2
- data/lib/katello/tasks/reset.rake +2 -1
- data/lib/katello/tasks/test.rake +15 -0
- data/lib/katello/tasks/unify_hosts.rake +1 -0
- data/lib/katello/tasks/upgrades/3.11/update_puppet_repos.rake +3 -3
- data/lib/katello/tasks/upgrades/3.12/remove_pulp2_notifier.rake +2 -2
- data/lib/katello/tasks/upgrades/3.18/add_cvv_export_history_metadata.rb +18 -0
- data/lib/katello/tasks/upgrades/3.8/clear_checksum_type.rake +2 -2
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +47 -40
- data/locale/bn/katello.po +293 -31
- data/locale/cs/katello.po +292 -29
- data/locale/de/katello.po +294 -32
- data/locale/en/katello.po +292 -28
- data/locale/es/katello.po +294 -31
- data/locale/fr/katello.po +294 -31
- data/locale/gu/katello.po +293 -31
- data/locale/hi/katello.po +293 -31
- data/locale/it/katello.po +294 -31
- data/locale/ja/katello.po +294 -32
- data/locale/katello.pot +1431 -997
- data/locale/kn/katello.po +293 -31
- data/locale/ko/katello.po +294 -31
- data/locale/mr/katello.po +293 -31
- data/locale/or/katello.po +293 -31
- data/locale/pa/katello.po +293 -31
- data/locale/pt/katello.po +292 -28
- data/locale/pt_BR/katello.po +294 -31
- data/locale/ru/katello.po +294 -31
- data/locale/ta/katello.po +293 -31
- data/locale/te/katello.po +293 -31
- data/locale/zh_CN/katello.po +294 -31
- data/locale/zh_TW/katello.po +294 -32
- data/package.json +8 -25
- data/webpack/__mocks__/foremanReact/Root/Context/ForemanContext.js +3 -0
- data/webpack/components/ActionableDetail.js +64 -0
- data/webpack/components/Content/ContentTable.js +2 -2
- data/webpack/components/Content/Details/ContentDetailRepositoryTableSchema.js +1 -1
- data/webpack/components/Content/Details/ContentDetails.js +1 -1
- data/webpack/components/Content/__tests__/ContentTable.test.js +2 -2
- data/webpack/components/Content/__tests__/__snapshots__/ContentPage.test.js.snap +1 -1
- data/webpack/components/EditableSwitch.js +30 -0
- data/webpack/components/EditableTextInput/EditableTextInput.js +120 -0
- data/webpack/components/EditableTextInput/__tests__/editableTextInput.test.js +52 -0
- data/webpack/components/EditableTextInput/editableTextInput.scss +14 -0
- data/webpack/components/EditableTextInput/index.js +3 -0
- data/webpack/{scenes/ContentViews/components → components}/Loading.js +8 -5
- data/webpack/{move_to_pf → components}/LoadingState/LoadingState.js +0 -0
- data/webpack/{move_to_pf → components}/LoadingState/LoadingState.scss +0 -0
- data/webpack/{move_to_pf → components}/LoadingState/LoadingState.test.js +0 -0
- data/webpack/{move_to_pf → components}/LoadingState/__snapshots__/LoadingState.test.js.snap +0 -0
- data/webpack/{move_to_pf → components}/LoadingState/index.js +0 -0
- data/webpack/components/MultiSelect/index.js +1 -1
- data/webpack/{move_to_pf → components}/OptionTooltip/OptionTooltip.scss +0 -0
- data/webpack/{move_to_pf → components}/OptionTooltip/__tests__/OptionTooltip.test.js +0 -0
- data/webpack/{move_to_pf → components}/OptionTooltip/__tests__/__snapshots__/OptionTooltip.test.js.snap +0 -0
- data/webpack/{move_to_pf → components}/OptionTooltip/index.js +0 -0
- data/webpack/components/Search/Search.js +124 -0
- data/webpack/components/Search/Search.test.js +2 -1
- data/webpack/components/Search/__snapshots__/Search.test.js.snap +2 -0
- data/webpack/components/Search/__tests__/search.test.js +124 -0
- data/webpack/components/Search/index.js +11 -87
- data/webpack/{move_to_pf → components}/Select/Select.js +0 -0
- data/webpack/components/SelectOrg/SetOrganization.js +2 -2
- data/webpack/components/TabWrapper/TabWrapper.js +26 -0
- data/webpack/components/TabWrapper/index.js +3 -0
- data/webpack/components/TabbedView/TabbedView.js +38 -0
- data/webpack/components/TabbedView/TabbedView.scss +3 -0
- data/webpack/components/TabbedView/index.js +3 -0
- data/webpack/components/Table/EmptyStateMessage.js +61 -0
- data/webpack/components/Table/MainTable.js +70 -0
- data/webpack/components/Table/TableWrapper.js +131 -0
- data/webpack/{move_to_pf → components}/TooltipButton/TooltipButton.js +0 -0
- data/webpack/{move_to_pf → components}/TooltipButton/TooltipButton.scss +0 -0
- data/webpack/{move_to_pf → components}/TooltipButton/TooltipButton.test.js +0 -0
- data/webpack/{move_to_pf → components}/TooltipButton/__snapshots__/TooltipButton.test.js.snap +0 -0
- data/webpack/{move_to_pf → components}/TooltipButton/index.js +0 -0
- data/webpack/components/TypeAhead/TypeAhead.js +109 -0
- data/webpack/{move_to_pf → components}/TypeAhead/TypeAhead.scss +0 -0
- data/webpack/components/TypeAhead/helpers/commonPropTypes.js +35 -0
- data/webpack/components/TypeAhead/helpers/helpers.js +32 -0
- data/webpack/components/TypeAhead/index.js +3 -0
- data/webpack/{move_to_pf/TypeAhead → components/TypeAhead/pf3Search}/TypeAheadInput.js +3 -6
- data/webpack/{move_to_pf/TypeAhead → components/TypeAhead/pf3Search}/TypeAheadItems.js +3 -7
- data/webpack/components/TypeAhead/pf3Search/TypeAheadSearch.js +52 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +44 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.scss +11 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadItems.js +57 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +66 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.scss +5 -0
- data/webpack/components/extensions/about/__tests__/SystemStatuses.test.js +1 -1
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/CollapseSubscriptionGroupButton.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/CollapseSubscriptionGroupButton.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/Table.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/Table.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableBody.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableBody.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableBodyMessage.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableBodyMessage.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableFixtures.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableSelectionCell.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableSelectionCell.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableSelectionHeaderCell.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/TableSelectionHeaderCell.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/CollapseSubscriptionGroupButton.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/Table.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/TableBody.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/TableBodyMessage.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/TableSelectionCell.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/__snapshots__/TableSelectionHeaderCell.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/components/index.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/EntitlementsInlineEditFormatter.js +1 -1
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/__tests__/EntitlementsInlineEditFormatter.test.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/__tests__/__snapshots__/EntitlementsInlineEditFormatter.test.js.snap +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/cellFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/collapseableAndSelectionCellFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/ellipsisCellFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/headerFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/index.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/selectionCellFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/formatters/selectionHeaderCellFormatter.js +0 -0
- data/webpack/{move_to_foreman/components/common/table → components/pf3Table}/index.js +0 -0
- data/webpack/{move_to_pf → components}/react-bootstrap-select/index.js +0 -0
- data/webpack/containers/Application/config.js +9 -4
- data/webpack/containers/Application/overrides.scss +5 -0
- data/webpack/global_test_setup.js +3 -1
- data/webpack/index.js +0 -1
- data/webpack/redux/OrganizationProducts/OrganizationProductsActions.js +1 -1
- data/webpack/redux/OrganizationProducts/__tests__/OrganizationProductsActions.test.js +2 -2
- data/webpack/redux/actions/RedHatRepositories/enabled.js +1 -1
- data/webpack/redux/actions/RedHatRepositories/repositorySetRepositories.js +1 -1
- data/webpack/redux/reducers/index.js +2 -0
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +1 -1
- data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +1 -1
- data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +1 -1
- data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +2 -2
- data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +1 -1
- data/webpack/scenes/ContentViews/ContentViewSelectors.js +6 -3
- data/webpack/scenes/ContentViews/ContentViewsActions.js +4 -4
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +12 -1
- data/webpack/scenes/ContentViews/ContentViewsPage.js +14 -15
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +66 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailReducer.js +23 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +28 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +71 -0
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +116 -0
- data/webpack/scenes/ContentViews/{details → Details}/DetailsContainer.js +8 -4
- data/webpack/scenes/ContentViews/Details/Repositories/ContentCounts.js +56 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +169 -0
- data/webpack/scenes/ContentViews/Details/Repositories/LastSync.js +47 -0
- data/webpack/scenes/ContentViews/Details/Repositories/RepoAddedStatus.js +17 -0
- data/webpack/scenes/ContentViews/Details/Repositories/RepoIcon.js +23 -0
- data/webpack/scenes/ContentViews/Details/Repositories/SelectableDropdown.js +49 -0
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.fixtures.json +154 -0
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +131 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +104 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +106 -0
- data/webpack/scenes/ContentViews/Details/contentViewInfo.scss +8 -0
- data/webpack/scenes/ContentViews/Details/index.js +7 -0
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +55 -37
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +47 -44
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +31 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +2 -1
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +173 -23
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +26 -0
- data/webpack/scenes/ContentViews/components/{contentViewName.scss → contentViewIcon.scss} +0 -0
- data/webpack/scenes/ModuleStreams/Details/ModuleStreamDetailsActions.js +1 -1
- data/webpack/scenes/ModuleStreams/Details/Profiles/TableSchema.js +1 -1
- data/webpack/scenes/ModuleStreams/Details/__tests__/ModuleStreamDetailsActions.test.js +2 -2
- data/webpack/scenes/ModuleStreams/ModuleStreamsActions.js +1 -1
- data/webpack/scenes/ModuleStreams/ModuleStreamsTableSchema.js +1 -1
- data/webpack/scenes/ModuleStreams/__tests__/ModuleStreamsTable.test.js +1 -1
- data/webpack/scenes/Organizations/OrganizationSelectors.js +14 -0
- data/webpack/scenes/Products/ProductActions.js +1 -1
- data/webpack/scenes/RedHatRepositories/RedHatRepositoriesPage.js +1 -1
- data/webpack/scenes/Settings/SettingsConstants.js +3 -0
- data/webpack/scenes/Settings/SettingsReducer.js +33 -0
- data/webpack/scenes/Settings/SettingsSelectors.js +4 -0
- data/webpack/scenes/Settings/index.js +2 -1
- data/webpack/scenes/Subscriptions/Details/SubscriptionDetailActions.js +1 -1
- data/webpack/scenes/Subscriptions/Details/SubscriptionDetails.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +75 -91
- data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.scss +15 -0
- data/webpack/scenes/Subscriptions/Manifest/ManifestActions.js +60 -1
- data/webpack/scenes/Subscriptions/Manifest/ManifestConstants.js +12 -0
- data/webpack/scenes/Subscriptions/Manifest/ManifestHistoryTableSchema.js +1 -1
- data/webpack/scenes/Subscriptions/Manifest/SimpleContentAccess.js +95 -0
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManifestActions.test.js +56 -1
- data/webpack/scenes/Subscriptions/Manifest/__tests__/SimpleContentAccess.test.js +108 -0
- data/webpack/scenes/Subscriptions/Manifest/__tests__/__snapshots__/ManageManifestModal.test.js.snap +6 -6
- data/webpack/scenes/Subscriptions/Manifest/__tests__/manifest.fixtures.js +36 -0
- data/webpack/scenes/Subscriptions/Manifest/index.js +5 -5
- data/webpack/scenes/Subscriptions/SubscriptionActions.js +1 -1
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +4 -0
- data/webpack/scenes/Subscriptions/SubscriptionHelpers.js +0 -3
- data/webpack/scenes/Subscriptions/SubscriptionReducer.js +51 -12
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +36 -19
- data/webpack/scenes/Subscriptions/SubscriptionsSelectors.js +5 -2
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/UpstreamSubscriptionsActions.js +1 -1
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/UpstreamSubscriptionsPage.js +2 -2
- data/webpack/scenes/Subscriptions/UpstreamSubscriptions/UpstreamSubscriptionsTableSchema.js +1 -1
- data/webpack/scenes/Subscriptions/__tests__/SubscriptionHelpers.test.js +0 -11
- data/webpack/scenes/Subscriptions/__tests__/SubscriptionsPage.test.js +3 -0
- data/webpack/scenes/Subscriptions/__tests__/SubscriptionsReducer.test.js +24 -0
- data/webpack/scenes/Subscriptions/__tests__/SubscriptionsSelectors.test.js +6 -0
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsActions.test.js.snap +2 -2
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsPage.test.js.snap +4 -4
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsReducer.test.js.snap +114 -1
- data/webpack/scenes/Subscriptions/__tests__/__snapshots__/SubscriptionsSelectors.test.js.snap +6 -0
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionTypeFormatter.js +2 -2
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTable.js +27 -21
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableHelpers.js +6 -2
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableSchema.js +2 -2
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/__snapshots__/SubscriptionTypeFormatter.test.js.snap +3 -3
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/components/Table.js +1 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/SubscriptionsToolbar.js +15 -2
- data/webpack/scenes/Subscriptions/components/SubscriptionsToolbar/__snapshots__/SubscriptionsToolbar.test.js.snap +5 -10
- data/webpack/scenes/Subscriptions/index.js +6 -2
- data/webpack/test-utils/nockWrapper.js +39 -5
- data/webpack/test-utils/react-testing-lib-wrapper.js +35 -9
- data/webpack/{move_to_foreman/common → utils}/helpers.js +12 -8
- data/webpack/utils/useEventListener.js +37 -0
- metadata +264 -107
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/host-traces-resolve.factory.js +0 -18
- data/vendor/assets/stylesheets/katello/jquery.loadmask.css.scss +0 -40
- data/vendor/assets/stylesheets/katello/ui.spinner.css.scss +0 -3
- data/webpack/__mocks__/foremanReact/components/ForemanModal/ForemanModalActions.js +0 -2
- data/webpack/__mocks__/foremanReact/components/ForemanModal/ForemanModalSelectors.js +0 -2
- data/webpack/__mocks__/foremanReact/components/ForemanModal/index.js +0 -4
- data/webpack/__mocks__/foremanReact/components/Settings/SettingsActions.js +0 -4
- data/webpack/__mocks__/foremanReact/components/Settings/SettingsConstants.js +0 -2
- data/webpack/move_to_pf/TypeAhead/TypeAhead.js +0 -138
- data/webpack/move_to_pf/TypeAhead/helpers.js +0 -5
- data/webpack/scenes/ContentViews/Table/TableWrapper.js +0 -55
- data/webpack/scenes/ContentViews/components/ContentViewName.js +0 -33
- data/webpack/scenes/ContentViews/components/EmptyStateMessage.js +0 -43
- data/webpack/scenes/ContentViews/details/ContentViewDetailActions.js +0 -12
- data/webpack/scenes/ContentViews/details/ContentViewDetailSelectors.js +0 -15
- data/webpack/scenes/ContentViews/expansions/RepositoriesExpansion.js +0 -12
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7163fd6dce0ae11188b016225be2effa59131c5bcc4a4b3482a749dfba7ef545
|
4
|
+
data.tar.gz: 202f81621e52adce6d318faa95fa9a527c0e3fc0f25bab3c3cb2ca7133cb12e3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 29f15645418ab0683328f83b804dc3fdf45d7f93ce4d23578a558310e0f1ad3cb7f2d98fe74ba3d16181505df56f081092aacb2bb028364995ac15413674862a
|
7
|
+
data.tar.gz: 99b0a150d0d689951d63b2acb37a0bbab702bfb5a13739572e764f9b49eeda60bb3451b6cc6a7aae4c20886755b499637213afef91eb565a92e2c887a4dcc376
|
@@ -1,10 +1,3 @@
|
|
1
|
-
/**
|
2
|
-
* = require "katello/jquery.loadmask.css"
|
3
|
-
* = require "katello/jquery-ui-1.8.11.custom.css"
|
4
|
-
* = require "katello/jquery.treeTable.css"
|
5
|
-
* = require "katello/ui.spinner.css"
|
6
|
-
*/
|
7
|
-
|
8
1
|
@import "katello/overrides";
|
9
2
|
@import "katello/katello_base";
|
10
3
|
@import "katello/look";
|
@@ -18,6 +11,9 @@
|
|
18
11
|
@import "katello/generic";
|
19
12
|
@import "katello/notifications";
|
20
13
|
|
14
|
+
@import "katello/jquery.treeTable";
|
15
|
+
@import "katello/jquery-ui-1.8.11.custom.css";
|
16
|
+
|
21
17
|
body {
|
22
18
|
background-color: white;
|
23
19
|
}
|
@@ -10,8 +10,8 @@ module Katello
|
|
10
10
|
before_action :registry_authorize, except: [:token, :v1_search, :catalog]
|
11
11
|
before_action :authorize_repository_read, only: [:pull_manifest, :tags_list]
|
12
12
|
before_action :authorize_repository_write, only: [:push_manifest]
|
13
|
-
skip_before_action :
|
14
|
-
|
13
|
+
skip_before_action :check_media_type, only: [:start_upload_blob, :upload_blob, :finish_upload_blob,
|
14
|
+
:chunk_upload_blob, :push_manifest]
|
15
15
|
|
16
16
|
wrap_parameters false
|
17
17
|
|
@@ -166,25 +166,27 @@ module Katello
|
|
166
166
|
headers[header[0].split('_')[1..-1].join('-')] = header[1]
|
167
167
|
end
|
168
168
|
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
169
|
+
if (manifest_response = redirect_client { Resources::Registry::Proxy.get(@_request.fullpath, headers) })
|
170
|
+
#when pulp 2 is removed, this should no longer be needed, and all clients should be redirected
|
171
|
+
logger.debug filter_sensitive_data(manifest_response)
|
172
|
+
results = JSON.parse(manifest_response)
|
173
|
+
|
174
|
+
response.header['Docker-Content-Digest'] = "sha256:#{Digest::SHA256.hexdigest(manifest_response)}"
|
175
|
+
# https://docs.docker.com/registry/spec/manifest-v2-2/
|
176
|
+
# If its v2 schema 2 only the mediaType attribute will be present in the manifest
|
177
|
+
media_type = results['mediaType']
|
178
|
+
if media_type.blank?
|
179
|
+
# so mediaType is not schema2 v2 only set the mediaType based on
|
180
|
+
# https://docs.docker.com/registry/spec/manifest-v2-1/
|
181
|
+
media_type = if results["signatures"].blank?
|
182
|
+
'application/vnd.docker.distribution.manifest.v1+json'
|
183
|
+
else
|
184
|
+
'application/vnd.docker.distribution.manifest.v1+prettyjws'
|
185
|
+
end
|
186
|
+
end
|
186
187
|
|
187
|
-
|
188
|
+
render json: manifest_response, content_type: media_type
|
189
|
+
end
|
188
190
|
end
|
189
191
|
|
190
192
|
def check_blob
|
@@ -199,9 +201,24 @@ module Katello
|
|
199
201
|
render json: {}
|
200
202
|
end
|
201
203
|
|
204
|
+
def redirect_client
|
205
|
+
return yield
|
206
|
+
rescue RestClient::Exception => exception
|
207
|
+
if [301, 302, 307].include?(exception.response.code)
|
208
|
+
redirect_to exception.response.headers[:location]
|
209
|
+
nil
|
210
|
+
else
|
211
|
+
raise exception
|
212
|
+
end
|
213
|
+
end
|
214
|
+
|
202
215
|
def pull_blob
|
203
|
-
|
204
|
-
|
216
|
+
headers = {}
|
217
|
+
headers['Accept'] = request.headers['Accept'] if request.headers['Accept']
|
218
|
+
if (blob_response = redirect_client { Resources::Registry::Proxy.get(@_request.fullpath, headers, max_redirects: 0) })
|
219
|
+
#when pulp 2 is removed, this should no longer be needed, and all clients should be redirected
|
220
|
+
render json: blob_response
|
221
|
+
end
|
205
222
|
end
|
206
223
|
|
207
224
|
def push_manifest
|
@@ -476,7 +493,9 @@ module Katello
|
|
476
493
|
end
|
477
494
|
|
478
495
|
def confirm_settings
|
479
|
-
|
496
|
+
if SETTINGS.dig(:katello, :container_image_registry) || SmartProxy.pulp_primary&.pulp3_repository_type_support?(::Katello::Repository::DOCKER_TYPE)
|
497
|
+
return true
|
498
|
+
end
|
480
499
|
render_error('custom_error', :status => :not_found,
|
481
500
|
:locals => { :message => "Registry not configured" })
|
482
501
|
end
|
@@ -10,7 +10,7 @@ module Katello
|
|
10
10
|
before_action :find_host, :only => [:upload_package_profile, :upload_profiles, :deb_package_profile]
|
11
11
|
before_action :authorize_client_or_user, :only => [:upload_package_profile, :upload_profiles, :deb_package_profile]
|
12
12
|
|
13
|
-
skip_before_action :
|
13
|
+
skip_before_action :check_media_type
|
14
14
|
|
15
15
|
#api :PUT, "/consumers/:id/packages", N_("Update installed packages")
|
16
16
|
#api :PUT, "/consumers/:id/profile", N_("Update installed packages")
|
@@ -26,7 +26,7 @@ module Katello
|
|
26
26
|
before_action :set_organization_id, :except => [:hypervisors_update, :async_hypervisors_update]
|
27
27
|
before_action :find_hypervisor_organization, :only => [:async_hypervisors_update, :hypervisors_update]
|
28
28
|
|
29
|
-
before_action :
|
29
|
+
before_action :check_media_type, :except => :async_hypervisors_update
|
30
30
|
|
31
31
|
prepend_before_action :convert_owner_to_organization_id, :except => [:hypervisors_update, :async_hypervisors_update], :if => lambda { params.key?(:owner) }
|
32
32
|
prepend_before_action :convert_organization_label_to_id, :only => [:rhsm_index, :consumer_activate, :consumer_create], :if => lambda { params.key?(:organization_id) }
|
@@ -119,7 +119,9 @@ module Katello
|
|
119
119
|
# Note that this request comes in as content-type 'text/plain' so that
|
120
120
|
# tomcat won't parse the json. Here we just pass the plain body through to candlepin
|
121
121
|
def async_hypervisors_update
|
122
|
-
task = Katello::Resources::Candlepin::Consumer.async_hypervisors(params[:owner],
|
122
|
+
task = Katello::Resources::Candlepin::Consumer.async_hypervisors(owner: params[:owner],
|
123
|
+
reporter_id: params[:reporter_id],
|
124
|
+
raw_json: request.raw_post)
|
123
125
|
async_task(::Actions::Katello::Host::Hypervisors, nil, :task_id => task['id'])
|
124
126
|
|
125
127
|
render :json => task
|
@@ -6,11 +6,11 @@ module Katello
|
|
6
6
|
before_action :find_environment, :only => [:index, :create, :update]
|
7
7
|
before_action :find_optional_organization, :only => [:index, :create, :show]
|
8
8
|
before_action :find_content_view, :only => [:index]
|
9
|
-
before_action :
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
before_action :
|
9
|
+
before_action :find_authorized_katello_resource, :only => [:show, :update, :destroy, :available_releases, :product_content,
|
10
|
+
:available_host_collections, :add_host_collections, :remove_host_collections,
|
11
|
+
:content_override, :add_subscriptions, :remove_subscriptions,
|
12
|
+
:subscriptions]
|
13
|
+
before_action :verify_simple_content_access_disabled, :only => [:add_subscriptions]
|
14
14
|
|
15
15
|
wrap_parameters :include => (ActivationKey.attribute_names + %w(host_collection_ids service_level auto_attach purpose_role purpose_usage purpose_addons content_view_environment))
|
16
16
|
|
@@ -95,6 +95,9 @@ module Katello
|
|
95
95
|
param :id, :number, :desc => N_("ID of the activation key"), :required => true
|
96
96
|
param :organization_id, :number, :desc => N_("organization identifier"), :required => false
|
97
97
|
def copy
|
98
|
+
@activation_key = Katello::ActivationKey.readable.find_by(:id => params[:id])
|
99
|
+
throw_resource_not_found(name: 'activation_key', id: params[:id]) if @activation_key.nil?
|
100
|
+
|
98
101
|
fail HttpErrors::BadRequest, _("New name cannot be blank") unless params[:new_name]
|
99
102
|
@new_activation_key = @activation_key.copy(params[:new_name])
|
100
103
|
@new_activation_key.user = current_user
|
@@ -254,12 +257,6 @@ module Katello
|
|
254
257
|
activation_keys
|
255
258
|
end
|
256
259
|
|
257
|
-
def find_activation_key
|
258
|
-
@activation_key = ActivationKey.find(params[:id])
|
259
|
-
fail HttpErrors::NotFound, _("Couldn't find activation key '%s'") % params[:id] if @activation_key.nil?
|
260
|
-
@activation_key
|
261
|
-
end
|
262
|
-
|
263
260
|
private
|
264
261
|
|
265
262
|
def subscription_index
|
@@ -279,7 +276,7 @@ module Katello
|
|
279
276
|
environment_id = params[:environment][:id] if !environment_id && params[:environment]
|
280
277
|
return unless environment_id
|
281
278
|
|
282
|
-
@environment = KTEnvironment.
|
279
|
+
@environment = KTEnvironment.readable.find_by(id: environment_id)
|
283
280
|
fail HttpErrors::NotFound, _("Couldn't find environment '%s'") % params[:environment_id] if @environment.nil?
|
284
281
|
@organization = @environment.organization
|
285
282
|
@environment
|
@@ -290,7 +287,7 @@ module Katello
|
|
290
287
|
@host_collections = []
|
291
288
|
|
292
289
|
ids&.each do |host_collection_id|
|
293
|
-
host_collection = HostCollection.find(host_collection_id)
|
290
|
+
host_collection = HostCollection.readable.find(host_collection_id)
|
294
291
|
fail HttpErrors::NotFound, _("Couldn't find host collection '%s'") % host_collection_id if host_collection.nil?
|
295
292
|
@host_collections << host_collection
|
296
293
|
end
|
@@ -304,7 +301,7 @@ module Katello
|
|
304
301
|
def find_content_view
|
305
302
|
if params.include?(:content_view_id)
|
306
303
|
cv_id = params[:content_view_id]
|
307
|
-
@content_view = ContentView.find_by(:id => cv_id)
|
304
|
+
@content_view = ContentView.readable.find_by(:id => cv_id)
|
308
305
|
fail HttpErrors::NotFound, _("Couldn't find content view '%s'") % cv_id if @content_view.nil?
|
309
306
|
end
|
310
307
|
end
|
@@ -348,5 +345,11 @@ module Katello
|
|
348
345
|
|
349
346
|
key_params
|
350
347
|
end
|
348
|
+
|
349
|
+
def verify_simple_content_access_disabled
|
350
|
+
if @activation_key.organization.simple_content_access?
|
351
|
+
fail HttpErrors::BadRequest, _("The specified organization is in Simple Content Access mode. Attaching subscriptions is disabled")
|
352
|
+
end
|
353
|
+
end
|
351
354
|
end
|
352
355
|
end
|
@@ -5,7 +5,7 @@ module Katello
|
|
5
5
|
include Api::V2::Rendering
|
6
6
|
include Api::V2::ErrorHandling
|
7
7
|
include ::Foreman::Controller::CsvResponder
|
8
|
-
include Concerns::Api::V2::
|
8
|
+
include Concerns::Api::V2::Authorization
|
9
9
|
|
10
10
|
# support for session (thread-local) variables must be the last filter in this class
|
11
11
|
include Foreman::ThreadSession::Cleaner
|
@@ -1,10 +1,9 @@
|
|
1
1
|
module Katello
|
2
2
|
class Api::V2::ContentCredentialsController < Api::V2::ApiController
|
3
3
|
include Katello::Concerns::FilteredAutoCompleteSearch
|
4
|
-
before_action :authorize
|
5
4
|
before_action :find_organization, :only => [:create, :index, :auto_complete_search]
|
6
|
-
before_action :
|
7
|
-
skip_before_action :
|
5
|
+
before_action :find_authorized_katello_resource, :only => [:show, :update, :destroy, :content, :set_content]
|
6
|
+
skip_before_action :check_media_type, :only => [:create, :content, :set_content]
|
8
7
|
|
9
8
|
def resource_class
|
10
9
|
Katello::GpgKey
|
@@ -103,12 +102,6 @@ module Katello
|
|
103
102
|
|
104
103
|
protected
|
105
104
|
|
106
|
-
def find_content_credential
|
107
|
-
@content_credential = GpgKey.find(params[:id])
|
108
|
-
rescue ActiveRecord::RecordNotFound
|
109
|
-
raise HttpErrors::NotFound, _("Couldn't find Content Credential '%s'") % params[:id]
|
110
|
-
end
|
111
|
-
|
112
105
|
def content_credential_params
|
113
106
|
params.permit(:name, :content_type, :content)
|
114
107
|
end
|
@@ -1,7 +1,7 @@
|
|
1
1
|
module Katello
|
2
2
|
class Api::V2::ContentUploadsController < Api::V2::ApiController
|
3
3
|
before_action :find_repository
|
4
|
-
skip_before_action :
|
4
|
+
skip_before_action :check_media_type, :only => [:update]
|
5
5
|
|
6
6
|
include ::Foreman::Controller::FilterParameters
|
7
7
|
filter_parameters :content
|
@@ -13,8 +13,8 @@ module Katello
|
|
13
13
|
param :content_type, RepositoryTypeManager.uploadable_content_types.map(&:label), :required => false, :desc => N_("content type ('deb', 'docker_manifest', 'file', 'ostree', 'puppet_module', 'rpm', 'srpm')")
|
14
14
|
def create
|
15
15
|
content_type = params[:content_type] || ::Katello::RepositoryTypeManager.find(@repository.content_type).default_managed_content_type.label
|
16
|
-
unit_type_id = SmartProxy.
|
17
|
-
render :json => @repository.backend_content_service(::SmartProxy.
|
16
|
+
unit_type_id = SmartProxy.pulp_primary.content_service(content_type).content_type
|
17
|
+
render :json => @repository.backend_content_service(::SmartProxy.pulp_primary).create_upload(params[:size], params[:checksum], unit_type_id)
|
18
18
|
end
|
19
19
|
|
20
20
|
api :PUT, "/repositories/:repository_id/content_uploads/:id", N_("Upload a chunk of the file's content")
|
@@ -24,7 +24,7 @@ module Katello
|
|
24
24
|
param :offset, :number, :required => true, :desc => N_("The offset in the file where the content starts")
|
25
25
|
param :content, File, :required => true, :desc => N_("The actual file contents")
|
26
26
|
def update
|
27
|
-
@repository.backend_content_service(::SmartProxy.
|
27
|
+
@repository.backend_content_service(::SmartProxy.pulp_primary)
|
28
28
|
.upload_chunk(params[:id], params[:offset], params[:content], params[:size])
|
29
29
|
head :no_content
|
30
30
|
end
|
@@ -33,7 +33,7 @@ module Katello
|
|
33
33
|
param :repository_id, :number, :required => true, :desc => N_("Repository id")
|
34
34
|
param :id, String, :required => true, :desc => N_("Upload request id")
|
35
35
|
def destroy
|
36
|
-
@repository.backend_content_service(::SmartProxy.
|
36
|
+
@repository.backend_content_service(::SmartProxy.pulp_primary).delete_upload(params[:id])
|
37
37
|
head :no_content
|
38
38
|
end
|
39
39
|
|
@@ -1,7 +1,8 @@
|
|
1
1
|
module Katello
|
2
2
|
class Api::V2::ContentViewComponentsController < Api::V2::ApiController
|
3
|
-
before_action :find_composite_content_view
|
4
|
-
before_action :
|
3
|
+
before_action :find_composite_content_view, :only => [:show, :index]
|
4
|
+
before_action :find_composite_content_view_for_edit, :only => [:add_components, :remove_components, :update]
|
5
|
+
before_action :find_authorized_katello_resource, :only => [:show, :update]
|
5
6
|
|
6
7
|
wrap_parameters :include => %w(composite_content_view_id content_view_version_id content_view_id latest)
|
7
8
|
|
@@ -13,7 +14,7 @@ module Katello
|
|
13
14
|
end
|
14
15
|
|
15
16
|
def index_response
|
16
|
-
results = @view.content_view_components
|
17
|
+
results = @view.content_view_components.readable
|
17
18
|
{
|
18
19
|
:results => results.uniq,
|
19
20
|
:subtotal => results.count,
|
@@ -31,15 +32,26 @@ module Katello
|
|
31
32
|
param :latest, :bool, :desc => N_("true if the latest version of the component's content view is desired")
|
32
33
|
end
|
33
34
|
def add_components
|
35
|
+
@view.add_components(authorized_components)
|
36
|
+
@view.save!
|
37
|
+
respond_for_index(:collection => index_response, :template => "index")
|
38
|
+
end
|
39
|
+
|
40
|
+
private def authorized_components
|
34
41
|
components = params.require(:components).map do |component|
|
35
42
|
component = component.permit([:latest, :content_view_version_id, :content_view_id])
|
36
43
|
options = {}
|
37
44
|
options[:latest] = ::Foreman::Cast.to_bool(component[:latest]) if component.key?(:latest)
|
38
|
-
options.merge(component.slice(:content_view_version_id, :content_view_id))
|
45
|
+
options.merge(component.slice(:content_view_version_id, :content_view_id)).with_indifferent_access
|
46
|
+
end
|
47
|
+
|
48
|
+
components.each do |component|
|
49
|
+
if component[:content_view_version_id] && Katello::ContentViewVersion.readable.find_by(id: component[:content_view_version_id]).nil?
|
50
|
+
throw_resource_not_found(name: 'content_view_version', id: component[:content_view_version_id])
|
51
|
+
elsif component[:content_view_id] && Katello::ContentView.readable.find_by(id: component[:content_view_id]).nil?
|
52
|
+
throw_resource_not_found(name: 'content_view', id: component[:content_view_id])
|
53
|
+
end
|
39
54
|
end
|
40
|
-
@view.add_components(components)
|
41
|
-
@view.save!
|
42
|
-
respond_for_index(:collection => index_response, :template => "index")
|
43
55
|
end
|
44
56
|
|
45
57
|
api :PUT, "/content_views/:composite_content_view_id/content_view_components/remove",
|
@@ -56,7 +68,7 @@ module Katello
|
|
56
68
|
param :composite_content_view_id, :number, :desc => N_("composite content view numeric identifier"), :required => true
|
57
69
|
param :id, :number, :desc => N_("content view component ID. Identifier of the component association"), :required => true
|
58
70
|
def show
|
59
|
-
respond :resource => @
|
71
|
+
respond :resource => @content_view_component
|
60
72
|
end
|
61
73
|
|
62
74
|
api :PUT, "/content_views/:composite_content_view_id/content_view_components/:id",
|
@@ -67,6 +79,9 @@ module Katello
|
|
67
79
|
param :latest, :bool, :desc => N_("true if the latest version of the components content view is desired")
|
68
80
|
def update
|
69
81
|
cvv_id = component_params[:content_view_version_id]
|
82
|
+
if cvv_id && Katello::ContentViewVersion.readable.find_by(id: cvv_id).nil?
|
83
|
+
throw_resource_not_found(name: 'content view version', id: cvv_id)
|
84
|
+
end
|
70
85
|
if component_params.key?(:latest) && component_params.key?(:content_view_version_id)
|
71
86
|
latest = ::Foreman::Cast.to_bool(component_params[:latest])
|
72
87
|
if latest && cvv_id.present?
|
@@ -75,22 +90,24 @@ module Katello
|
|
75
90
|
end
|
76
91
|
end
|
77
92
|
if cvv_id.present?
|
78
|
-
@
|
93
|
+
@content_view_component.update!(:content_view_version_id => cvv_id, :latest => false)
|
79
94
|
elsif component_params.key?(:latest)
|
80
95
|
latest = ::Foreman::Cast.to_bool(component_params[:latest])
|
81
|
-
@
|
96
|
+
@content_view_component.update!(:content_view_version_id => nil, :latest => latest)
|
82
97
|
end
|
83
|
-
respond :resource => @
|
98
|
+
respond :resource => @content_view_component
|
84
99
|
end
|
85
100
|
|
86
101
|
private
|
87
102
|
|
88
103
|
def find_composite_content_view
|
89
|
-
@view = ContentView.composite.non_default.
|
104
|
+
@view = ContentView.composite.non_default.readable.find_by(id: params[:composite_content_view_id])
|
105
|
+
throw_resource_not_found(name: 'composite content view', id: params[:composite_content_view_id]) if @view.nil?
|
90
106
|
end
|
91
107
|
|
92
|
-
def
|
93
|
-
@
|
108
|
+
def find_composite_content_view_for_edit
|
109
|
+
@view = ContentView.composite.non_default.editable.find_by(id: params[:composite_content_view_id])
|
110
|
+
throw_resource_not_found(name: 'composite content view', id: params[:composite_content_view_id]) if @view.nil?
|
94
111
|
end
|
95
112
|
|
96
113
|
def component_params
|
@@ -0,0 +1,48 @@
|
|
1
|
+
module Katello
|
2
|
+
class Api::V2::ContentViewRepositoriesController < Api::V2::ApiController
|
3
|
+
# There are other Content View Repository related endpoints that are in RepositoriesController
|
4
|
+
include Katello::Concerns::FilteredAutoCompleteSearch
|
5
|
+
|
6
|
+
before_action :find_content_view
|
7
|
+
before_action :find_organization_from_cv
|
8
|
+
|
9
|
+
# content_views/:id/repositories/show_all
|
10
|
+
# Shows all repositories, added and available to add, for a content view
|
11
|
+
# Undocumented endpoint since the functionality exists in separate calls already.
|
12
|
+
# This was created for ease of pagination and search for the UI
|
13
|
+
param :id, :number, desc: N_("Content View id"), required: true
|
14
|
+
def show_all
|
15
|
+
kr = Katello::Repository.table_name
|
16
|
+
krr = Katello::RootRepository.table_name
|
17
|
+
kcvr = Katello::ContentViewRepository.table_name
|
18
|
+
join_query = <<-SQL
|
19
|
+
LEFT OUTER JOIN #{kcvr}
|
20
|
+
ON #{kr}.id = #{kcvr}.repository_id
|
21
|
+
AND #{kcvr}.content_view_id = #{@content_view.id}
|
22
|
+
SQL
|
23
|
+
order_query = <<-SQL
|
24
|
+
CAST (#{kcvr}.repository_id as BOOLEAN) ASC, #{krr}.name
|
25
|
+
SQL
|
26
|
+
|
27
|
+
query = Katello::Repository.readable.in_default_view.in_organization(@organization)
|
28
|
+
query = query.with_type(params[:content_type]) if params[:content_type]
|
29
|
+
# Use custom sort to perform the join and order since we need to order by specific content_view
|
30
|
+
# and the ORDER BY query needs access to the katello_content_view_repositories table
|
31
|
+
custom_sort = ->(sort_query) { sort_query.joins(:root).joins(join_query).order(order_query) }
|
32
|
+
options = { resource_class: Katello::Repository, custom_sort: custom_sort }
|
33
|
+
repos = scoped_search(query, nil, nil, options)
|
34
|
+
|
35
|
+
respond_for_index(:collection => repos)
|
36
|
+
end
|
37
|
+
|
38
|
+
private
|
39
|
+
|
40
|
+
def find_content_view
|
41
|
+
@content_view = ContentView.find(params[:content_view_id])
|
42
|
+
end
|
43
|
+
|
44
|
+
def find_organization_from_cv
|
45
|
+
@organization = @content_view.organization
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|