katello 4.4.2.2 → 4.5.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/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +5 -1
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +98 -0
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +39 -3
- data/app/controllers/katello/api/v2/content_exports_controller.rb +19 -0
- data/app/controllers/katello/api/v2/content_imports_controller.rb +13 -16
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +0 -12
- data/app/controllers/katello/api/v2/content_views_controller.rb +13 -0
- data/app/controllers/katello/api/v2/environments_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_module_streams_controller.rb +8 -2
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +25 -3
- data/app/controllers/katello/api/v2/organizations_controller.rb +4 -2
- data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +9 -3
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +40 -7
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +2 -2
- data/app/controllers/katello/concerns/api/v2/hosts_controller_extensions.rb +1 -1
- data/app/helpers/katello/concerns/smart_proxy_helper_extensions.rb +4 -0
- data/app/helpers/katello/hosts_and_hostgroups_helper.rb +21 -3
- data/app/lib/actions/katello/alternate_content_source/create.rb +24 -0
- data/app/lib/actions/katello/alternate_content_source/destroy.rb +27 -0
- data/app/lib/actions/katello/alternate_content_source/update.rb +41 -0
- data/app/lib/actions/katello/cdn_configuration/update.rb +2 -2
- data/app/lib/actions/katello/content_view/destroy.rb +2 -1
- data/app/lib/actions/katello/content_view/incremental_updates.rb +7 -3
- data/app/lib/actions/katello/content_view/publish.rb +7 -9
- data/app/lib/actions/katello/content_view_version/auto_create_products.rb +4 -4
- data/app/lib/actions/katello/content_view_version/auto_create_redhat_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +6 -4
- data/app/lib/actions/katello/content_view_version/import.rb +25 -22
- data/app/lib/actions/katello/content_view_version/import_library.rb +0 -1
- data/app/lib/actions/katello/content_view_version/import_repository.rb +21 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +85 -93
- data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +2 -2
- data/app/lib/actions/katello/product/content_create.rb +10 -8
- data/app/lib/actions/katello/repository/destroy.rb +36 -12
- data/app/lib/actions/katello/repository_set/disable_repository.rb +8 -3
- data/app/lib/actions/pulp3/alternate_content_source/create.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +20 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update.rb +16 -0
- data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +17 -0
- data/app/lib/actions/pulp3/content_view_version/{import.rb → create_import.rb} +5 -5
- data/app/lib/actions/pulp3/content_view_version/create_importer.rb +4 -3
- data/app/lib/actions/pulp3/content_view_version/destroy_importer.rb +12 -1
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +23 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +18 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_repository.rb +51 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +5 -2
- data/app/lib/actions/pulp3/repository/refresh_distribution.rb +4 -1
- data/app/lib/actions/pulp3/repository/save_distribution_references.rb +2 -0
- data/app/lib/katello/api/v2/error_handling.rb +1 -0
- data/app/lib/katello/resources/cdn/katello_cdn.rb +3 -1
- data/app/lib/katello/util/errata.rb +2 -3
- data/app/lib/katello/validators/alternate_content_source_path_validator.rb +29 -0
- data/app/lib/katello/validators/content_default_http_proxy_setting_validator.rb +12 -0
- data/app/lib/katello/validators/content_view_environment_validator.rb +10 -5
- data/app/models/katello/alternate_content_source.rb +66 -0
- data/app/models/katello/authorization/alternate_content_source.rb +33 -0
- data/app/models/katello/authorization/repository.rb +3 -3
- data/app/models/katello/candlepin/repository_mapper.rb +13 -6
- data/app/models/katello/cdn_configuration.rb +15 -15
- data/app/models/katello/concerns/content_facet_host_extensions.rb +25 -0
- data/app/models/katello/concerns/host_managed_extensions.rb +7 -5
- data/app/models/katello/concerns/http_proxy_extensions.rb +14 -0
- data/app/models/katello/concerns/organization_extensions.rb +4 -2
- data/app/models/katello/concerns/setting_extensions.rb +14 -0
- data/app/models/katello/concerns/smart_proxy_extensions.rb +2 -1
- data/app/models/katello/content.rb +1 -0
- data/app/models/katello/content_credential.rb +6 -0
- data/app/models/katello/content_override.rb +7 -3
- data/app/models/katello/content_view.rb +33 -2
- data/app/models/katello/content_view_erratum_filter.rb +26 -12
- data/app/models/katello/content_view_filter.rb +4 -0
- data/app/models/katello/content_view_version.rb +12 -0
- data/app/models/katello/content_view_version_export_history.rb +3 -1
- data/app/models/katello/erratum.rb +9 -5
- data/app/models/katello/events/delete_latest_content_view_version.rb +40 -0
- data/app/models/katello/host/content_facet.rb +14 -0
- data/app/models/katello/host_available_module_stream.rb +12 -0
- data/app/models/katello/product_content.rb +1 -0
- data/app/models/katello/purpose_sla_status.rb +1 -1
- data/app/models/katello/purpose_status.rb +2 -2
- data/app/models/katello/repository.rb +7 -4
- data/app/models/katello/root_repository.rb +1 -1
- data/app/models/katello/smart_proxy_alternate_content_source.rb +8 -0
- data/app/models/katello/sync_plan.rb +1 -1
- data/app/presenters/katello/product_content_presenter.rb +15 -0
- data/app/services/katello/applicable_host_queue.rb +1 -1
- data/app/services/katello/content_unit_indexer.rb +2 -1
- data/app/services/katello/product_content_finder.rb +12 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +117 -0
- data/app/services/katello/pulp3/api/file.rb +8 -0
- data/app/services/katello/pulp3/api/yum.rb +8 -0
- data/app/services/katello/pulp3/content_view_version/export.rb +27 -5
- data/app/services/katello/pulp3/content_view_version/import.rb +97 -71
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +4 -4
- data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +13 -11
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +67 -72
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +40 -24
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +88 -39
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +2 -2
- data/app/services/katello/pulp3/content_view_version/metadata_map.rb +117 -0
- data/app/services/katello/pulp3/pulp_content_unit.rb +6 -1
- data/app/services/katello/pulp3/repository/yum.rb +70 -12
- data/app/services/katello/pulp3/repository.rb +7 -91
- data/app/services/katello/pulp3/service_common.rb +66 -0
- data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +4 -1
- data/app/services/katello/ui_notifications/content_view/delete_latest_version_failure.rb +22 -0
- data/app/views/foreman/job_templates/change_content_source.erb +1 -1
- data/app/views/foreman/job_templates/install_errata.erb +5 -5
- data/app/views/foreman/job_templates/install_errata_by_search_query.erb +7 -6
- data/app/views/foreman/job_templates/install_group.erb +4 -4
- data/app/views/foreman/job_templates/install_package.erb +4 -4
- data/app/views/foreman/job_templates/install_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/remove_group.erb +4 -4
- data/app/views/foreman/job_templates/remove_package.erb +4 -4
- data/app/views/foreman/job_templates/remove_packages_by_search_query.erb +3 -3
- data/app/views/foreman/job_templates/resolve_traces.erb +2 -2
- data/app/views/foreman/job_templates/restart_services.erb +3 -3
- data/app/views/foreman/job_templates/update_group.erb +4 -4
- data/app/views/foreman/job_templates/update_package.erb +4 -4
- data/app/views/foreman/job_templates/update_packages_by_search_query.erb +3 -3
- data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +15 -0
- data/app/views/katello/api/v2/alternate_content_sources/index.json.rabl +7 -0
- data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +3 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +2 -3
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +1 -1
- data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
- data/app/views/katello/api/v2/environments/show.json.rabl +2 -0
- data/app/views/katello/api/v2/errata/_counts.json.rabl +2 -2
- data/app/views/katello/api/v2/host_module_streams/base.json.rabl +2 -2
- data/app/views/katello/api/v2/hosts/host_collections.json.rabl +1 -1
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +2 -1
- data/app/views/katello/sync_management/_repo.html.erb +8 -29
- data/config/routes/api/v2.rb +7 -0
- data/db/migrate/20150930183738_migrate_content_hosts.rb +0 -399
- data/db/migrate/20171025163149_remove_use_pulp_oauth_setting.rb +1 -1
- data/db/migrate/20171114150937_cleanup_installed_packages.rb +1 -1
- data/db/migrate/20180402160223_clean_up_force_post_sync_action_setting.rb +1 -1
- data/db/migrate/20211129200124_remove_dependency_solving_algorithm_setting.rb +1 -1
- data/db/migrate/20211220185935_clean_duplicate_content_units.rb +10 -12
- data/db/migrate/20220110223754_update_disconnected_settings.rb +5 -5
- data/db/migrate/20220117151612_add_alternate_content_sources.rb +48 -0
- data/db/migrate/20220124191056_add_type_to_cdn_configuration.rb +9 -4
- data/db/migrate/20220209203251_add_generated_for_to_content_views.rb +13 -0
- data/db/migrate/20220209205137_expand_sync_timeout_settings.rb +7 -7
- data/db/migrate/20220228173251_remove_drpm_from_ignorable_content.rb +12 -0
- data/db/migrate/20220404190836_delete_old_setting_data.rb +9 -0
- data/db/migrate/20220405220616_update_cdn_configuration_type.rb +11 -0
- data/db/migrate/20220419193414_content_settings_to_dsl_category.rb +5 -0
- data/db/seeds.d/110-content-view-autopublish.rb +13 -0
- data/db/seeds.d/150-module_job_templates.rb +1 -1
- data/engines/bastion/README.md +1 -0
- data/engines/bastion/app/assets/javascripts/bastion/components/bst-modal.directive.js +1 -0
- data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +10 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-module-streams.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-traces.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.controller.js +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-deb-repositories.html +26 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-debs.html +27 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +22 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +13 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +63 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +7 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details.controller.js +10 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-details.html +21 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +8 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/new-repository.controller.js +7 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/discovery-create.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/views/discovery-create.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.routes.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/content-access-mode-banner.html +6 -1
- data/lib/katello/engine.rb +1 -5
- data/lib/katello/permission_creator.rb +32 -4
- data/lib/katello/plugin.rb +378 -4
- data/lib/katello/tasks/reset.rake.bak +67 -0
- data/lib/katello/tasks/update_content_default_http_proxy.rake +2 -3
- data/lib/katello/version.rb +1 -1
- data/locale/action_names.rb +47 -41
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/bn/katello.po +820 -106
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/katello.po +818 -104
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/katello.po +893 -179
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/katello.po +817 -103
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/katello.po +882 -168
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/katello.po +1219 -505
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/katello.po +826 -112
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/katello.po +826 -112
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/katello.po +863 -148
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/katello.po +1216 -499
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +3847 -2507
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/katello.po +826 -112
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/katello.po +912 -198
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/katello.po +826 -112
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/katello.po +826 -112
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/katello.po +826 -112
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/katello.po +817 -103
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/katello.po +879 -165
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/katello.po +927 -213
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/katello.po +820 -106
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/katello.po +826 -112
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/katello.po +1202 -486
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/katello.po +856 -142
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/webpack/components/EditableTextInput/EditableTextInput.js +20 -5
- data/webpack/components/Errata/index.js +38 -8
- data/webpack/components/Packages/index.js +1 -4
- data/webpack/components/Search/Search.js +18 -3
- data/webpack/components/SelectAllCheckbox/index.js +1 -0
- data/webpack/components/SelectableDropdown/SelectableDropdown.js +4 -2
- data/webpack/components/Table/EmptyStateMessage.js +21 -7
- data/webpack/components/Table/MainTable.js +29 -4
- data/webpack/components/Table/TableHooks.js +63 -19
- data/webpack/components/Table/TableWrapper.js +4 -2
- data/webpack/components/Table/components/SortableColumnHeaders.js +19 -0
- data/webpack/components/Table/components/TranslatedPlural.js +57 -0
- data/webpack/components/TypeAhead/TypeAhead.js +8 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +13 -11
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +5 -2
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +27 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +256 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +202 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewActions.js +19 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/HostContentViewConstants.js +2 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/changeHostCVModal.test.js +131 -0
- data/webpack/components/extensions/HostDetails/Cards/{__tests__ → ContentViewDetailsCard/__tests__}/contentViewDetailsCard.test.js +22 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/contentViews.fixtures.json +443 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/__tests__/envPaths.fixtures.json +320 -0
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.js +57 -33
- data/webpack/components/extensions/HostDetails/Cards/ErrataOverviewCard.scss +3 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsActions.js +30 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsCard.js +187 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsConstants.js +7 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +227 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsSelectors.js +18 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/availableHostCollections.fixtures.json +106 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsCard.test.js +110 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/hostCollectionsModal.test.js +235 -0
- data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/__tests__/removableHostCollections.fixtures.json +45 -0
- data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +33 -8
- data/webpack/components/extensions/HostDetails/DetailsTabCards/InstalledProductsCard.js +44 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/RegistrationCard.js +107 -0
- data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +38 -0
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +62 -39
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/HostErrataActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsActions.js +1 -3
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsConstants.js +28 -0
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +486 -116
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/moduleStreamsTab.test.js +147 -1
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/modules.fixtures.json +6 -3
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +48 -19
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +35 -47
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsActions.js +33 -54
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsConstants.js +20 -0
- data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +269 -132
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +47 -11
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +30 -42
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +36 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +94 -46
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +18 -2
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +6 -0
- data/webpack/containers/Application/config.js +5 -0
- data/webpack/global_index.js +30 -7
- data/webpack/global_test_setup.js +13 -0
- data/webpack/redux/actions/RedHatRepositories/enabled.js +2 -1
- data/webpack/redux/actions/RedHatRepositories/helpers.js +9 -8
- data/webpack/scenes/AlternateContentSources/ACSActions.js +53 -0
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +4 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +23 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +152 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsIndex.fixtures.json +91 -0
- data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +67 -0
- data/webpack/scenes/AlternateContentSources/index.js +4 -0
- data/webpack/scenes/Content/Details/ContentRepositories.js +1 -0
- data/webpack/scenes/Content/Table/ContentTable.js +1 -0
- data/webpack/scenes/ContentViews/ContentViewsActions.js +6 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +11 -3
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +2 -1
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +10 -1
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +4 -3
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +1 -1
- data/webpack/scenes/ContentViews/Delete/ContentViewDeleteWizard.js +7 -5
- data/webpack/scenes/ContentViews/Delete/Steps/CVDeletionFinish.js +29 -21
- data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +15 -8
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewAddModal.js +3 -3
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +4 -4
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +3 -1
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +4 -4
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +34 -8
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +33 -29
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +130 -79
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +17 -3
- data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/AffectedRepositories/AffectedRepositoryTable.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +6 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataDateFilterContent.js +41 -21
- data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +38 -20
- data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +2 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +8 -1
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +9 -1
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +2 -1
- data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVRpmMatchContentModal.js +1 -0
- data/webpack/scenes/ContentViews/Details/Filters/Rules/ContainerTag/AddEditContainerTagRuleModal.js +27 -12
- data/webpack/scenes/ContentViews/Details/Filters/Rules/Package/AddEditPackageRuleModal.js +39 -17
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +27 -10
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +46 -23
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +3 -2
- data/webpack/scenes/ContentViews/Details/Promote/ContentViewVersionPromote.js +5 -2
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +161 -108
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +7 -7
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/ActionSummary.js +58 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteContextWrapper.js +45 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteHelpers.js +30 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/BulkDeleteModal.js +56 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ConfirmBulkDelete.js +126 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/FinishBulkDelete.js +61 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignActivationKeys.js +196 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReassignHosts.js +220 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/Steps/ReviewEnvironments.js +104 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +122 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteVersions.fixtures.json +600 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentView.fixtures.json +1504 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/contentViewVersion.fixtures.json +936 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/environmentPaths.fixtures.json +261 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/hosts.fixtures.json +163 -0
- data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/bulkDeleteSteps.js +79 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +192 -167
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveCVVersionWizard.js +2 -5
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionDeleteFinish.js +38 -53
- data/webpack/scenes/ContentViews/Details/Versions/Delete/RemoveSteps/CVVersionRemoveReview.js +1 -1
- data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +6 -12
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedActivationKeys.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/Delete/affectedHosts.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +1 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetails.js +8 -20
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsHeader.js +23 -13
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailsTable.js +3 -0
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.fixtures.json +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +0 -3
- data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +4 -4
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +12 -14
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +1 -0
- data/webpack/scenes/ContentViews/Publish/CVPublishFinish.js +96 -117
- data/webpack/scenes/ContentViews/Publish/PublishContentViewWizard.js +13 -19
- data/webpack/scenes/ContentViews/Publish/__tests__/publishContentView.test.js +9 -20
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +165 -148
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +2 -0
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +4 -4
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +14 -3
- data/webpack/scenes/ContentViews/components/ContentViewsCounter.js +1 -1
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +9 -5
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.scss +6 -1
- data/webpack/scenes/ContentViews/components/TaskPresenter/TaskPresenter.js +40 -35
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +2 -2
- data/webpack/scenes/ContentViews/expansions/RelatedCompositeContentViewsModal.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +4 -4
- data/webpack/scenes/ContentViews/expansions/__tests__/contentViewComponentsModal.test.js +1 -1
- data/webpack/scenes/ContentViews/helpers.js +3 -0
- data/webpack/scenes/Hosts/ChangeContentSource/helpers.js +5 -0
- data/webpack/scenes/RedHatRepositories/RedHatRepositoriesPage.js +3 -3
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/EnabledRepository.js +2 -1
- data/webpack/scenes/RedHatRepositories/components/EnabledRepository/__tests__/EnabledRepository.test.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnConfigurationConstants.js +3 -3
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/CdnTypeForm.js +2 -0
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{AirGappedTypeForm.js → ExportSyncForm.js} +7 -6
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/{UpstreamServerTypeForm.js → NetworkSyncForm.js} +15 -7
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{AirGappedTypeForm.test.js → ExportSyncForm.test.js} +4 -4
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/__tests__/{UpstreamServerTypeForm.test.js → NetworkSyncForm.test.js} +8 -8
- data/webpack/scenes/Subscriptions/Manifest/CdnConfigurationTab/index.js +11 -11
- data/webpack/scenes/Subscriptions/SubscriptionConstants.js +1 -0
- data/webpack/scenes/Subscriptions/SubscriptionsPage.js +8 -7
- data/webpack/scenes/Tasks/TaskActions.js +6 -0
- data/webpack/scenes/Tasks/TaskSelectors.js +11 -0
- data/webpack/scenes/Tasks/helpers.js +33 -5
- data/webpack/utils/helpers.js +2 -0
- metadata +158 -40
- data/app/models/setting/content.rb +0 -201
- data/webpack/components/Table/__test__/useBulkSelect.test.js +0 -99
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +0 -96
- data/webpack/scenes/ContentViews/Details/DetailsContainer.js +0 -36
data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsActions.js
CHANGED
@@ -1,13 +1,16 @@
|
|
1
1
|
import { translate as __ } from 'foremanReact/common/I18n';
|
2
|
-
import {
|
3
|
-
|
4
|
-
|
5
|
-
|
2
|
+
import {
|
3
|
+
API_OPERATIONS,
|
4
|
+
get,
|
5
|
+
put,
|
6
|
+
} from 'foremanReact/redux/API';
|
7
|
+
import { errorToast } from '../../../../../scenes/Tasks/helpers';
|
6
8
|
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
9
|
+
import katelloApi, { foremanApi } from '../../../../../services/api';
|
10
|
+
import {
|
11
|
+
CONTENT_OVERRIDES_KEY,
|
12
|
+
REPOSITORY_SETS_KEY,
|
13
|
+
} from './RepositorySetsConstants';
|
11
14
|
|
12
15
|
export const getHostRepositorySets = params => get({
|
13
16
|
type: API_OPERATIONS.GET,
|
@@ -17,57 +20,33 @@ export const getHostRepositorySets = params => get({
|
|
17
20
|
params,
|
18
21
|
});
|
19
22
|
|
20
|
-
export const
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
value: true,
|
29
|
-
})),
|
30
|
-
},
|
31
|
-
updateData: () => {
|
32
|
-
updateResults({ labels, enabled: true });
|
33
|
-
},
|
34
|
-
successToast: () => (labels.length === 1 ? __('Repository set enabled') : __('Repository sets enabled')),
|
35
|
-
errorToast: error => errorToast(error),
|
36
|
-
});
|
37
|
-
|
38
|
-
export const disableRepoSetRepo = ({ hostId, labels, updateResults }) => put({
|
39
|
-
type: API_OPERATIONS.PUT,
|
40
|
-
key: CONTENT_OVERRIDES_KEY,
|
41
|
-
url: foremanApi.getApiUrl(`/hosts/${hostId}/subscriptions/content_override`),
|
42
|
-
params: {
|
43
|
-
content_overrides: labels.map(label => ({
|
44
|
-
content_label: label,
|
45
|
-
name: 'enabled',
|
46
|
-
value: false,
|
47
|
-
})),
|
48
|
-
},
|
49
|
-
updateData: () => {
|
50
|
-
updateResults({ labels, enabled: false });
|
51
|
-
},
|
52
|
-
successToast: () => (labels.length === 1 ? __('Repository set disabled') : __('Repository sets disabled')),
|
53
|
-
errorToast: error => errorToast(error),
|
54
|
-
});
|
55
|
-
|
56
|
-
export const resetRepoSetRepo = ({ hostId, labels, updateResults }) => put({
|
23
|
+
export const setContentOverrides = ({
|
24
|
+
hostId,
|
25
|
+
search,
|
26
|
+
enabled,
|
27
|
+
remove = false,
|
28
|
+
updateResults,
|
29
|
+
singular,
|
30
|
+
}) => put({
|
57
31
|
type: API_OPERATIONS.PUT,
|
58
32
|
key: CONTENT_OVERRIDES_KEY,
|
59
33
|
url: foremanApi.getApiUrl(`/hosts/${hostId}/subscriptions/content_override`),
|
60
34
|
params: {
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
})),
|
35
|
+
content_overrides_search: {
|
36
|
+
search,
|
37
|
+
enabled,
|
38
|
+
remove,
|
39
|
+
},
|
67
40
|
},
|
68
|
-
updateData: (_, resp) =>
|
69
|
-
|
41
|
+
updateData: (_, resp) => updateResults(resp),
|
42
|
+
successToast: () => {
|
43
|
+
if (enabled) {
|
44
|
+
return singular ? __('Repository set enabled') :
|
45
|
+
__('Repository sets enabled');
|
46
|
+
} else if (remove) {
|
47
|
+
return singular ? __('Repository set reset to default') : __('Repository sets reset to default');
|
48
|
+
}
|
49
|
+
return singular ? __('Repository set disabled') : __('Repository sets disabled');
|
70
50
|
},
|
71
|
-
successToast: () => (labels.length === 1 ? __('Repository set reset to default') : __('Repository sets reset to default')),
|
72
51
|
errorToast: error => errorToast(error),
|
73
52
|
});
|
data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsConstants.js
CHANGED
@@ -1,2 +1,22 @@
|
|
1
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
2
|
+
|
1
3
|
export const REPOSITORY_SETS_KEY = 'HOST_DETAIL_REPOSITORY_SETS';
|
2
4
|
export const CONTENT_OVERRIDES_KEY = 'HOST_DETAIL_CONTENT_OVERRIDES';
|
5
|
+
|
6
|
+
export const STATUSES = {
|
7
|
+
ENABLED: __('Enabled'),
|
8
|
+
DISABLED: __('Disabled'),
|
9
|
+
OVERRIDDEN: __('Overridden'),
|
10
|
+
};
|
11
|
+
|
12
|
+
export const STATUS_TO_PARAM = {
|
13
|
+
[STATUSES.ENABLED]: 'enabled',
|
14
|
+
[STATUSES.DISABLED]: 'disabled',
|
15
|
+
[STATUSES.OVERRIDDEN]: 'overridden',
|
16
|
+
};
|
17
|
+
|
18
|
+
export const PARAM_TO_FRIENDLY_NAME = {
|
19
|
+
enabled: __('Enabled'),
|
20
|
+
disabled: __('Disabled'),
|
21
|
+
overridden: __('Overridden'),
|
22
|
+
};
|
@@ -1,29 +1,64 @@
|
|
1
|
-
import React, {
|
2
|
-
|
1
|
+
import React, {
|
2
|
+
useCallback,
|
3
|
+
useEffect,
|
4
|
+
useState,
|
5
|
+
useMemo,
|
6
|
+
} from 'react';
|
7
|
+
|
8
|
+
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
9
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
10
|
+
import { selectAPIResponse } from 'foremanReact/redux/API/APISelectors';
|
3
11
|
import PropTypes from 'prop-types';
|
4
|
-
import {
|
5
|
-
import {
|
12
|
+
import { FormattedMessage } from 'react-intl';
|
13
|
+
import { STATUS } from 'foremanReact/constants';
|
14
|
+
import {
|
15
|
+
useDispatch,
|
16
|
+
useSelector,
|
17
|
+
} from 'react-redux';
|
18
|
+
|
19
|
+
import {
|
20
|
+
ActionList,
|
21
|
+
ActionListItem,
|
22
|
+
Alert,
|
23
|
+
AlertActionCloseButton,
|
24
|
+
Dropdown,
|
25
|
+
DropdownItem,
|
26
|
+
KebabToggle,
|
27
|
+
Label,
|
28
|
+
Skeleton,
|
29
|
+
Split,
|
30
|
+
SplitItem,
|
31
|
+
ToggleGroup,
|
32
|
+
ToggleGroupItem,
|
33
|
+
Tooltip,
|
34
|
+
} from '@patternfly/react-core';
|
35
|
+
import { FlagIcon } from '@patternfly/react-icons';
|
6
36
|
import {
|
7
37
|
TableVariant,
|
8
|
-
Thead,
|
9
38
|
Tbody,
|
10
|
-
Tr,
|
11
|
-
Th,
|
12
39
|
Td,
|
40
|
+
Th,
|
41
|
+
Thead,
|
42
|
+
Tr,
|
13
43
|
} from '@patternfly/react-table';
|
14
|
-
|
15
|
-
import {
|
16
|
-
|
17
|
-
|
18
|
-
|
44
|
+
|
45
|
+
import {
|
46
|
+
useBulkSelect,
|
47
|
+
useTableSort,
|
48
|
+
useUrlParams,
|
49
|
+
} from '../../../../../components/Table/TableHooks';
|
19
50
|
import TableWrapper from '../../../../../components/Table/TableWrapper';
|
20
|
-
import
|
21
|
-
import { selectRepositorySetsStatus } from './RepositorySetsSelectors';
|
51
|
+
import hostIdNotReady from '../../HostDetailsActions';
|
22
52
|
import { selectHostDetailsStatus } from '../../HostDetailsSelectors.js';
|
23
|
-
import {
|
24
|
-
|
53
|
+
import {
|
54
|
+
getHostRepositorySets,
|
55
|
+
setContentOverrides,
|
56
|
+
} from './RepositorySetsActions';
|
57
|
+
import { REPOSITORY_SETS_KEY, STATUSES, STATUS_TO_PARAM, PARAM_TO_FRIENDLY_NAME } from './RepositorySetsConstants.js';
|
58
|
+
import { selectRepositorySetsStatus } from './RepositorySetsSelectors';
|
25
59
|
import './RepositorySetsTab.scss';
|
26
|
-
import
|
60
|
+
import SortableColumnHeaders from '../../../../Table/components/SortableColumnHeaders';
|
61
|
+
import SelectableDropdown from '../../../../SelectableDropdown';
|
27
62
|
|
28
63
|
const getEnabledValue = ({ enabled, enabledContentOverride }) => {
|
29
64
|
const isOverridden = (enabledContentOverride !== null);
|
@@ -68,6 +103,8 @@ const RepositorySetsTab = () => {
|
|
68
103
|
subscription_status: subscriptionStatus,
|
69
104
|
content_facet_attributes: contentFacetAttributes,
|
70
105
|
} = hostDetails;
|
106
|
+
const STATUS_LABEL = __('Status');
|
107
|
+
|
71
108
|
const contentFacet = propsToCamelCase(contentFacetAttributes ?? {});
|
72
109
|
const {
|
73
110
|
contentViewDefault,
|
@@ -75,48 +112,80 @@ const RepositorySetsTab = () => {
|
|
75
112
|
contentViewName,
|
76
113
|
lifecycleEnvironmentName,
|
77
114
|
} = contentFacet;
|
78
|
-
const nonLibraryHost = contentViewDefault === false
|
115
|
+
const nonLibraryHost = contentViewDefault === false &&
|
79
116
|
lifecycleEnvironmentLibrary === false;
|
80
117
|
const simpleContentAccess = (Number(subscriptionStatus) === 5);
|
118
|
+
const [isBulkActionOpen, setIsBulkActionOpen] = useState(false);
|
119
|
+
const toggleBulkAction = () => setIsBulkActionOpen(prev => !prev);
|
81
120
|
const dispatch = useDispatch();
|
82
|
-
const { searchParam, show } = useUrlParams();
|
121
|
+
const { searchParam, show, status: initialStatus } = useUrlParams();
|
122
|
+
|
83
123
|
const toggleGroupStates = ['noLimit', 'limitToEnvironment'];
|
84
124
|
const [noLimit, limitToEnvironment] = toggleGroupStates;
|
85
125
|
const defaultToggleGroupState = nonLibraryHost ? limitToEnvironment : noLimit;
|
86
126
|
const [toggleGroupState, setToggleGroupState] =
|
87
127
|
useState(show ?? defaultToggleGroupState);
|
128
|
+
const [statusSelected, setStatusSelected]
|
129
|
+
= useState(PARAM_TO_FRIENDLY_NAME[initialStatus] ?? STATUS_LABEL);
|
130
|
+
const activeFilters = [statusSelected, toggleGroupState];
|
131
|
+
const defaultFilters = [STATUS_LABEL, defaultToggleGroupState];
|
132
|
+
|
88
133
|
const [alertShowing, setAlertShowing] = useState(false);
|
89
134
|
const emptyContentTitle = __('No repository sets to show.');
|
90
135
|
const emptyContentBody = __('Repository sets will appear here when available.');
|
91
136
|
const emptySearchTitle = __('No matching repository sets found');
|
92
137
|
const emptySearchBody = __('Try changing your search query.');
|
93
|
-
const
|
138
|
+
const errorSearchTitle = __('Problem searching repository sets');
|
139
|
+
const columnHeaders = useMemo(() => [
|
94
140
|
__('Repository'),
|
95
141
|
__('Product'),
|
96
142
|
__('Repository path'),
|
97
143
|
__('Status'),
|
98
|
-
];
|
144
|
+
], []);
|
145
|
+
|
146
|
+
const COLUMNS_TO_SORT_PARAMS = {
|
147
|
+
[columnHeaders[0]]: 'name',
|
148
|
+
[columnHeaders[1]]: 'product',
|
149
|
+
[columnHeaders[3]]: 'enabled_by_default',
|
150
|
+
};
|
151
|
+
|
152
|
+
const {
|
153
|
+
pfSortParams, apiSortParams,
|
154
|
+
activeSortColumn, activeSortDirection,
|
155
|
+
} = useTableSort({
|
156
|
+
allColumns: columnHeaders,
|
157
|
+
columnsToSortParams: COLUMNS_TO_SORT_PARAMS,
|
158
|
+
});
|
159
|
+
|
99
160
|
const fetchItems = useCallback(
|
100
|
-
params =>
|
101
|
-
|
161
|
+
(params) => {
|
162
|
+
if (!hostId) return hostIdNotReady;
|
163
|
+
const modifiedParams = { ...params };
|
164
|
+
if (statusSelected !== STATUS_LABEL) {
|
165
|
+
modifiedParams.status = STATUS_TO_PARAM[statusSelected];
|
166
|
+
}
|
167
|
+
return getHostRepositorySets({
|
102
168
|
content_access_mode_env: toggleGroupState === limitToEnvironment,
|
103
169
|
content_access_mode_all: simpleContentAccess,
|
104
170
|
host_id: hostId,
|
105
|
-
...
|
106
|
-
|
107
|
-
|
171
|
+
...apiSortParams,
|
172
|
+
...modifiedParams,
|
173
|
+
});
|
174
|
+
},
|
175
|
+
[hostId, toggleGroupState, limitToEnvironment,
|
176
|
+
simpleContentAccess, apiSortParams, statusSelected, STATUS_LABEL],
|
108
177
|
);
|
109
178
|
|
110
179
|
const response = useSelector(state => selectAPIResponse(state, REPOSITORY_SETS_KEY));
|
111
|
-
const { results, ...metadata } = response;
|
180
|
+
const { results, error: errorSearchBody, ...metadata } = response;
|
112
181
|
const status = useSelector(state => selectRepositorySetsStatus(state));
|
182
|
+
const repoSetSearchQuery = label => `cp_content_id = ${label}`;
|
113
183
|
const {
|
114
184
|
selectOne, isSelected, searchQuery, selectedCount, isSelectable,
|
115
185
|
updateSearchQuery, selectNone, fetchBulkParams, ...selectAll
|
116
186
|
} = useBulkSelect({
|
117
187
|
results,
|
118
188
|
metadata,
|
119
|
-
isSelectable: () => false,
|
120
189
|
initialSearchQuery: searchParam || '',
|
121
190
|
});
|
122
191
|
|
@@ -130,66 +199,130 @@ const RepositorySetsTab = () => {
|
|
130
199
|
}, [hostDetailsStatus, nonLibraryHost]);
|
131
200
|
|
132
201
|
if (!hostId) return <Skeleton />;
|
133
|
-
|
134
|
-
const updateResults = ({ labels, enabled, newResponse }) => dispatch({
|
202
|
+
const updateResults = newResponse => dispatch({
|
135
203
|
type: `${REPOSITORY_SETS_KEY}_SUCCESS`,
|
136
204
|
key: REPOSITORY_SETS_KEY,
|
137
205
|
response: {
|
138
206
|
...response,
|
139
207
|
results: results.map((result) => {
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
208
|
+
const {
|
209
|
+
enabled,
|
210
|
+
enabled_content_override: enabledContentOverride,
|
211
|
+
} = newResponse.results.find(r => r.id === result.id);
|
212
|
+
if (enabled !== null) {
|
213
|
+
return { ...result, enabled, enabled_content_override: enabledContentOverride };
|
145
214
|
}
|
146
215
|
return result;
|
147
216
|
}),
|
148
217
|
},
|
149
218
|
});
|
150
|
-
const overrideToEnabled = ({ labels }) =>
|
151
|
-
dispatch(enableRepoSetRepo({ hostId, labels, updateResults }));
|
152
|
-
const overrideToDisabled = ({ labels }) =>
|
153
|
-
dispatch(disableRepoSetRepo({ hostId, labels, updateResults }));
|
154
|
-
const resetToDefault = ({ labels }) =>
|
155
|
-
dispatch(resetRepoSetRepo({ hostId, labels, updateResults }));
|
156
219
|
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
// <DropdownItem aria-label="bulk_disable" key="bulk_disable" component="button" onClick={overrideToDisabled}>
|
164
|
-
// {__('Override to disabled')}
|
165
|
-
// </DropdownItem>,
|
166
|
-
// <DropdownItem aria-label="bulk_disable" key="bulk_disable" component="button" onClick={resetToDefault}>
|
167
|
-
// {__('Reset to default')}
|
168
|
-
// </DropdownItem>,
|
169
|
-
// ];
|
170
|
-
/* eslint-enable max-len */
|
220
|
+
const handleStatusSelected = newType => setStatusSelected((prevType) => {
|
221
|
+
if (prevType === newType) {
|
222
|
+
return STATUS_LABEL;
|
223
|
+
}
|
224
|
+
return newType;
|
225
|
+
});
|
171
226
|
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
227
|
+
const updateOverrides = ({
|
228
|
+
enabled, remove = false, search, singular = false,
|
229
|
+
}) => {
|
230
|
+
setIsBulkActionOpen(false);
|
231
|
+
selectNone();
|
232
|
+
|
233
|
+
dispatch(setContentOverrides({
|
234
|
+
hostId,
|
235
|
+
search,
|
236
|
+
enabled,
|
237
|
+
remove,
|
238
|
+
updateResults: resp => updateResults(resp),
|
239
|
+
singular: singular || selectedCount === 1,
|
240
|
+
}));
|
241
|
+
};
|
242
|
+
const bulkParams = () => fetchBulkParams('cp_content_id');
|
243
|
+
const enableRepoSets = () => updateOverrides({ enabled: true, search: bulkParams() });
|
244
|
+
const disableRepoSets = () => updateOverrides({ enabled: false, search: bulkParams() });
|
245
|
+
const resetToDefaultRepoSets = () => updateOverrides({ remove: true, search: bulkParams() });
|
246
|
+
|
247
|
+
const enableRepoSet = id => updateOverrides({
|
248
|
+
enabled: true,
|
249
|
+
search: repoSetSearchQuery(id),
|
250
|
+
singular: true,
|
251
|
+
});
|
252
|
+
const disableRepoSet = id => updateOverrides({
|
253
|
+
enabled: false,
|
254
|
+
search: repoSetSearchQuery(id),
|
255
|
+
singular: true,
|
256
|
+
});
|
257
|
+
const resetToDefaultRepoSet = id => updateOverrides({
|
258
|
+
remove: true,
|
259
|
+
search: repoSetSearchQuery(id),
|
260
|
+
singular: true,
|
261
|
+
});
|
262
|
+
|
263
|
+
const dropdownItems = [
|
264
|
+
<DropdownItem aria-label="bulk_enable" key="bulk_enable" component="button" onClick={enableRepoSets} isDisabled={selectedCount === 0}>
|
265
|
+
{__('Override to enabled')}
|
266
|
+
</DropdownItem>,
|
267
|
+
<DropdownItem aria-label="bulk_disable" key="bulk_disable" component="button" onClick={disableRepoSets} isDisabled={selectedCount === 0}>
|
268
|
+
{__('Override to disabled')}
|
269
|
+
</DropdownItem>,
|
270
|
+
<DropdownItem aria-label="bulk_reset_default" key="bulk_reset_default" component="button" onClick={resetToDefaultRepoSets} isDisabled={selectedCount === 0}>
|
271
|
+
{__('Reset to default')}
|
272
|
+
</DropdownItem>,
|
273
|
+
];
|
274
|
+
|
275
|
+
const toggleGroup = (
|
276
|
+
<Split hasGutter>
|
277
|
+
{nonLibraryHost &&
|
278
|
+
<SplitItem>
|
279
|
+
<ToggleGroup aria-label="Repository Set toggle">
|
280
|
+
<ToggleGroupItem
|
281
|
+
text={__('Show all')}
|
282
|
+
buttonId="no-limit-toggle"
|
283
|
+
aria-label="No limit"
|
284
|
+
isSelected={toggleGroupState === noLimit}
|
285
|
+
onChange={() => setToggleGroupState(noLimit)}
|
286
|
+
/>
|
287
|
+
<ToggleGroupItem
|
288
|
+
text={__('Limit to environment')}
|
289
|
+
buttonId="limit-to-env-toggle"
|
290
|
+
aria-label="Limit to environment"
|
291
|
+
isSelected={toggleGroupState === limitToEnvironment}
|
292
|
+
onChange={() => setToggleGroupState(limitToEnvironment)}
|
293
|
+
/>
|
294
|
+
</ToggleGroup>
|
295
|
+
</SplitItem>
|
296
|
+
}
|
297
|
+
<SplitItem>
|
298
|
+
<SelectableDropdown
|
299
|
+
id="status-dropdown"
|
300
|
+
title={STATUS_LABEL}
|
301
|
+
showTitle={false}
|
302
|
+
items={Object.values(STATUSES)}
|
303
|
+
selected={statusSelected}
|
304
|
+
setSelected={handleStatusSelected}
|
189
305
|
/>
|
190
|
-
</
|
191
|
-
|
192
|
-
|
306
|
+
</SplitItem>
|
307
|
+
</Split>
|
308
|
+
);
|
309
|
+
|
310
|
+
const actionButtons = (
|
311
|
+
<Split hasGutter>
|
312
|
+
<SplitItem>
|
313
|
+
<ActionList isIconList>
|
314
|
+
<ActionListItem>
|
315
|
+
<Dropdown
|
316
|
+
toggle={<KebabToggle aria-label="bulk_actions" onToggle={toggleBulkAction} />}
|
317
|
+
isOpen={isBulkActionOpen}
|
318
|
+
isPlain
|
319
|
+
dropdownItems={dropdownItems}
|
320
|
+
/>
|
321
|
+
</ActionListItem>
|
322
|
+
</ActionList>
|
323
|
+
</SplitItem>
|
324
|
+
</Split>
|
325
|
+
);
|
193
326
|
|
194
327
|
const hostEnvText = 'the "{contentViewName}" content view and "{lifecycleEnvironmentName}" environment';
|
195
328
|
|
@@ -207,7 +340,6 @@ const RepositorySetsTab = () => {
|
|
207
340
|
} else {
|
208
341
|
alertText = nonScaAlert;
|
209
342
|
}
|
210
|
-
|
211
343
|
return (
|
212
344
|
<div>
|
213
345
|
<div id="repo-sets-tab">
|
@@ -247,41 +379,48 @@ const RepositorySetsTab = () => {
|
|
247
379
|
metadata,
|
248
380
|
emptyContentTitle,
|
249
381
|
emptyContentBody,
|
250
|
-
emptySearchTitle,
|
251
|
-
emptySearchBody,
|
252
382
|
status,
|
253
383
|
searchQuery,
|
254
384
|
updateSearchQuery,
|
255
385
|
selectedCount,
|
256
386
|
selectNone,
|
257
387
|
toggleGroup,
|
388
|
+
actionButtons,
|
389
|
+
emptySearchTitle,
|
390
|
+
emptySearchBody,
|
391
|
+
activeFilters,
|
392
|
+
defaultFilters,
|
258
393
|
}
|
259
394
|
}
|
260
|
-
|
261
|
-
|
262
|
-
|
395
|
+
ouiaId="host-repository-sets-table"
|
396
|
+
errorSearchTitle={errorSearchTitle}
|
397
|
+
errorSearchBody={errorSearchBody}
|
398
|
+
additionalListeners={[hostId, toggleGroupState, statusSelected,
|
399
|
+
activeSortColumn, activeSortDirection]}
|
263
400
|
fetchItems={fetchItems}
|
264
401
|
autocompleteEndpoint="/repository_sets/auto_complete_search"
|
265
402
|
bookmarkController="katello_product_contents" // Katello::ProductContent.table_name
|
266
403
|
rowsCount={results?.length}
|
267
404
|
variant={TableVariant.compact}
|
268
405
|
{...selectAll}
|
269
|
-
displaySelectAllCheckbox
|
406
|
+
displaySelectAllCheckbox
|
270
407
|
>
|
271
408
|
<Thead>
|
272
409
|
<Tr>
|
273
410
|
<Th key="select-all" />
|
274
|
-
|
275
|
-
|
411
|
+
<SortableColumnHeaders
|
412
|
+
columnHeaders={columnHeaders}
|
413
|
+
pfSortParams={pfSortParams}
|
414
|
+
columnsToSortParams={COLUMNS_TO_SORT_PARAMS}
|
415
|
+
/>
|
276
416
|
<Th />
|
277
417
|
<Th key="action-menu" />
|
278
418
|
</Tr>
|
279
419
|
</Thead>
|
280
|
-
|
420
|
+
<Tbody>
|
281
421
|
{results?.map((repoSet, rowIndex) => {
|
282
422
|
const {
|
283
423
|
id,
|
284
|
-
label,
|
285
424
|
content: { name: repoName },
|
286
425
|
enabled,
|
287
426
|
enabled_content_override: enabledContentOverride,
|
@@ -291,56 +430,54 @@ const RepositorySetsTab = () => {
|
|
291
430
|
const { isEnabled, isOverridden } =
|
292
431
|
getEnabledValue({ enabled, enabledContentOverride });
|
293
432
|
return (
|
294
|
-
<
|
295
|
-
<
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
433
|
+
<Tr key={id}>
|
434
|
+
<Td select={{
|
435
|
+
disable: !isSelectable(id),
|
436
|
+
isSelected: isSelected(id),
|
437
|
+
onSelect: (event, selected) => selectOne(selected, id),
|
438
|
+
rowIndex,
|
439
|
+
variant: 'checkbox',
|
440
|
+
}}
|
441
|
+
/>
|
442
|
+
<Td>
|
443
|
+
<span>{repoName}</span>
|
444
|
+
</Td>
|
445
|
+
<Td>
|
446
|
+
<a href={`/products/${productId}`}>{productName}</a>
|
447
|
+
</Td>
|
448
|
+
<Td>
|
449
|
+
<span>{repoPath}</span>
|
450
|
+
</Td>
|
451
|
+
<Td>
|
452
|
+
<span><EnabledIcon key={`enabled-icon-${id}`} {...{ isEnabled, isOverridden }} /></span>
|
453
|
+
</Td>
|
454
|
+
<Td
|
455
|
+
key={`rowActions-${id}`}
|
456
|
+
actions={{
|
457
|
+
items: [
|
458
|
+
{
|
459
|
+
title: __('Override to disabled'),
|
460
|
+
isDisabled: isOverridden && !isEnabled,
|
461
|
+
onClick: () => disableRepoSet(id),
|
462
|
+
},
|
463
|
+
{
|
464
|
+
title: __('Override to enabled'),
|
465
|
+
isDisabled: isOverridden && isEnabled,
|
466
|
+
onClick: () => enableRepoSet(id),
|
467
|
+
},
|
468
|
+
{
|
469
|
+
title: __('Reset to default'),
|
470
|
+
isDisabled: !isOverridden,
|
471
|
+
onClick: () => resetToDefaultRepoSet(id),
|
472
|
+
},
|
473
|
+
],
|
302
474
|
}}
|
303
|
-
|
304
|
-
|
305
|
-
<span>{repoName}</span>
|
306
|
-
</Td>
|
307
|
-
<Td>
|
308
|
-
<a href={`/products/${productId}`}>{productName}</a>
|
309
|
-
</Td>
|
310
|
-
<Td>
|
311
|
-
<span>{repoPath}</span>
|
312
|
-
</Td>
|
313
|
-
<Td>
|
314
|
-
<span><EnabledIcon key={`enabled-icon-${id}`} {...{ isEnabled, isOverridden }} /></span>
|
315
|
-
</Td>
|
316
|
-
<Td
|
317
|
-
key={`rowActions-${id}`}
|
318
|
-
actions={{
|
319
|
-
items: [
|
320
|
-
{
|
321
|
-
title: __('Override to disabled'),
|
322
|
-
isDisabled: isOverridden && !isEnabled,
|
323
|
-
onClick: () => overrideToDisabled({ labels: [label] }),
|
324
|
-
},
|
325
|
-
{
|
326
|
-
title: __('Override to enabled'),
|
327
|
-
isDisabled: isOverridden && isEnabled,
|
328
|
-
onClick: () => overrideToEnabled({ labels: [label] }),
|
329
|
-
},
|
330
|
-
{
|
331
|
-
title: __('Reset to default'),
|
332
|
-
isDisabled: !isOverridden,
|
333
|
-
onClick: () => resetToDefault({ labels: [label] }),
|
334
|
-
},
|
335
|
-
],
|
336
|
-
}}
|
337
|
-
/>
|
338
|
-
</Tr>
|
339
|
-
</Tbody>
|
475
|
+
/>
|
476
|
+
</Tr>
|
340
477
|
);
|
341
478
|
})
|
342
479
|
}
|
343
|
-
|
480
|
+
</Tbody>
|
344
481
|
</TableWrapper>
|
345
482
|
</div>
|
346
483
|
</div>
|