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
@@ -0,0 +1,45 @@
|
|
1
|
+
{
|
2
|
+
"total": 3,
|
3
|
+
"subtotal": 3,
|
4
|
+
"selectable": 3,
|
5
|
+
"page": "1",
|
6
|
+
"per_page": "20",
|
7
|
+
"error": null,
|
8
|
+
"search": null,
|
9
|
+
"sort": {
|
10
|
+
"by": "name",
|
11
|
+
"order": "asc"
|
12
|
+
},
|
13
|
+
"results": [
|
14
|
+
{
|
15
|
+
"name": "Jer Hosts",
|
16
|
+
"organization_id": 1,
|
17
|
+
"max_hosts": null,
|
18
|
+
"description": null,
|
19
|
+
"total_hosts": 4,
|
20
|
+
"unlimited_hosts": true,
|
21
|
+
"created_at": "2021-11-24 10:12:39 -0500",
|
22
|
+
"updated_at": "2021-11-24 10:12:39 -0500",
|
23
|
+
"id": 1,
|
24
|
+
"permissions": {
|
25
|
+
"deletable": true,
|
26
|
+
"editable": true
|
27
|
+
}
|
28
|
+
},
|
29
|
+
{
|
30
|
+
"name": "Jturel hosts",
|
31
|
+
"organization_id": 1,
|
32
|
+
"max_hosts": 43,
|
33
|
+
"description": "This is my awesome description\n\n\nyeeah\nhi",
|
34
|
+
"total_hosts": 4,
|
35
|
+
"unlimited_hosts": false,
|
36
|
+
"created_at": "2022-02-28 16:18:30 -0500",
|
37
|
+
"updated_at": "2022-02-28 16:23:52 -0500",
|
38
|
+
"id": 2,
|
39
|
+
"permissions": {
|
40
|
+
"deletable": true,
|
41
|
+
"editable": true
|
42
|
+
}
|
43
|
+
}
|
44
|
+
]
|
45
|
+
}
|
@@ -15,9 +15,33 @@ describe('Without errata', () => {
|
|
15
15
|
nock.cleanAll();
|
16
16
|
});
|
17
17
|
|
18
|
-
test('
|
18
|
+
test('shows zero counts when there are 0 installable errata', () => {
|
19
19
|
const hostDetails = {
|
20
20
|
...baseHostDetails,
|
21
|
+
errata_status: 1,
|
22
|
+
content_facet_attributes: {
|
23
|
+
errata_counts: {
|
24
|
+
bugfix: 0,
|
25
|
+
enhancement: 0,
|
26
|
+
security: 0,
|
27
|
+
total: 0,
|
28
|
+
},
|
29
|
+
},
|
30
|
+
};
|
31
|
+
/* eslint-disable max-len */
|
32
|
+
const { queryByLabelText, getByLabelText } = render(<ErrataOverviewCard hostDetails={hostDetails} />);
|
33
|
+
/* eslint-enable max-len */
|
34
|
+
expect(queryByLabelText('errataChart')).not.toBeInTheDocument();
|
35
|
+
expect(getByLabelText('0 total errata')).toBeInTheDocument();
|
36
|
+
expect(getByLabelText('0 security advisories')).toBeInTheDocument();
|
37
|
+
expect(getByLabelText('0 bug fixes')).toBeInTheDocument();
|
38
|
+
expect(getByLabelText('0 enhancements')).toBeInTheDocument();
|
39
|
+
});
|
40
|
+
|
41
|
+
test('shows empty state when there are 0 errata', () => {
|
42
|
+
const hostDetails = {
|
43
|
+
...baseHostDetails,
|
44
|
+
errata_status: 0,
|
21
45
|
content_facet_attributes: {
|
22
46
|
errata_counts: {
|
23
47
|
bugfix: 0,
|
@@ -31,7 +55,7 @@ describe('Without errata', () => {
|
|
31
55
|
const { queryByLabelText, getByText } = render(<ErrataOverviewCard hostDetails={hostDetails} />);
|
32
56
|
/* eslint-enable max-len */
|
33
57
|
expect(queryByLabelText('errataChart')).not.toBeInTheDocument();
|
34
|
-
expect(getByText('
|
58
|
+
expect(getByText('All errata up-to-date')).toBeInTheDocument();
|
35
59
|
});
|
36
60
|
|
37
61
|
test('does not show errata card when host not registered', () => {
|
@@ -60,7 +84,7 @@ describe('With errata', () => {
|
|
60
84
|
nock.cleanAll();
|
61
85
|
});
|
62
86
|
|
63
|
-
test('shows
|
87
|
+
test('shows links when there are errata', () => {
|
64
88
|
const hostDetails = {
|
65
89
|
...baseHostDetails,
|
66
90
|
content_facet_attributes: {
|
@@ -72,12 +96,13 @@ describe('With errata', () => {
|
|
72
96
|
},
|
73
97
|
},
|
74
98
|
};
|
75
|
-
const {
|
99
|
+
const { getByLabelText, container } = render(<ErrataOverviewCard hostDetails={hostDetails} />);
|
76
100
|
expect(container.getElementsByClassName('erratachart')).toHaveLength(1);
|
77
101
|
expect(container.getElementsByClassName('erratalegend')).toHaveLength(1);
|
78
|
-
|
79
|
-
expect(
|
80
|
-
expect(
|
81
|
-
expect(
|
102
|
+
|
103
|
+
expect(getByLabelText('60 total errata')).toBeInTheDocument();
|
104
|
+
expect(getByLabelText('30 security advisories')).toBeInTheDocument();
|
105
|
+
expect(getByLabelText('20 enhancements')).toBeInTheDocument();
|
106
|
+
expect(getByLabelText('10 bug fixes')).toBeInTheDocument();
|
82
107
|
});
|
83
108
|
});
|
@@ -0,0 +1,44 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import { List, ListItem } from '@patternfly/react-core';
|
5
|
+
import CardTemplate from 'foremanReact/components/HostDetails/Templates/CardItem/CardTemplate';
|
6
|
+
|
7
|
+
const InstalledProductsCard = ({ isExpandedGlobal, hostDetails }) => {
|
8
|
+
const installedProducts = hostDetails?.subscription_facet_attributes?.installed_products;
|
9
|
+
if (!installedProducts?.length) return null;
|
10
|
+
return (
|
11
|
+
<CardTemplate
|
12
|
+
header={__('Installed products')}
|
13
|
+
expandable
|
14
|
+
isExpandedGlobal={isExpandedGlobal}
|
15
|
+
>
|
16
|
+
<List isPlain>
|
17
|
+
{installedProducts.map(product => (
|
18
|
+
<ListItem key={product.productId}>
|
19
|
+
{product.productName}
|
20
|
+
</ListItem>
|
21
|
+
))}
|
22
|
+
</List>
|
23
|
+
</CardTemplate>
|
24
|
+
);
|
25
|
+
};
|
26
|
+
|
27
|
+
InstalledProductsCard.propTypes = {
|
28
|
+
isExpandedGlobal: PropTypes.bool,
|
29
|
+
hostDetails: PropTypes.shape({
|
30
|
+
subscription_facet_attributes: PropTypes.shape({
|
31
|
+
installed_products: PropTypes.arrayOf(PropTypes.shape({
|
32
|
+
productId: PropTypes.string,
|
33
|
+
productName: PropTypes.string,
|
34
|
+
})),
|
35
|
+
}),
|
36
|
+
}),
|
37
|
+
};
|
38
|
+
|
39
|
+
InstalledProductsCard.defaultProps = {
|
40
|
+
isExpandedGlobal: false,
|
41
|
+
hostDetails: {},
|
42
|
+
};
|
43
|
+
|
44
|
+
export default InstalledProductsCard;
|
@@ -0,0 +1,107 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
4
|
+
import {
|
5
|
+
DescriptionList,
|
6
|
+
DescriptionListTerm,
|
7
|
+
DescriptionListGroup,
|
8
|
+
DescriptionListDescription,
|
9
|
+
List,
|
10
|
+
ListItem,
|
11
|
+
Text,
|
12
|
+
TextVariants,
|
13
|
+
} from '@patternfly/react-core';
|
14
|
+
import { urlBuilder } from 'foremanReact/common/urlHelpers';
|
15
|
+
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
16
|
+
import IsoDate from 'foremanReact/components/common/dates/IsoDate';
|
17
|
+
import CardTemplate from 'foremanReact/components/HostDetails/Templates/CardItem/CardTemplate';
|
18
|
+
|
19
|
+
export const RegisteredBy = ({ user, activationKeys }) => {
|
20
|
+
if (user) {
|
21
|
+
return (
|
22
|
+
<DescriptionListDescription>{user}</DescriptionListDescription>
|
23
|
+
);
|
24
|
+
}
|
25
|
+
return (
|
26
|
+
<>
|
27
|
+
<List isPlain>
|
28
|
+
<Text component={TextVariants.h4}>{activationKeys.length > 1 ? __('Activation keys') : __('Activation key')}</Text>
|
29
|
+
{activationKeys.map(key => (
|
30
|
+
<ListItem key={key.id}>
|
31
|
+
<a href={urlBuilder(`activation_keys/${key.id}`, '')}>{key.name}</a>
|
32
|
+
</ListItem>
|
33
|
+
))}
|
34
|
+
</List>
|
35
|
+
</>
|
36
|
+
);
|
37
|
+
};
|
38
|
+
|
39
|
+
RegisteredBy.propTypes = {
|
40
|
+
user: PropTypes.string,
|
41
|
+
activationKeys: PropTypes.arrayOf(PropTypes.shape({
|
42
|
+
id: PropTypes.number,
|
43
|
+
name: PropTypes.string,
|
44
|
+
})),
|
45
|
+
};
|
46
|
+
|
47
|
+
RegisteredBy.defaultProps = {
|
48
|
+
user: '',
|
49
|
+
activationKeys: {},
|
50
|
+
};
|
51
|
+
|
52
|
+
const RegistrationCard = ({ isExpandedGlobal, hostDetails }) => {
|
53
|
+
const subscriptionFacetAttributes
|
54
|
+
= propsToCamelCase(hostDetails?.subscription_facet_attributes || {});
|
55
|
+
const {
|
56
|
+
registeredAt, registeredThrough, activationKeys, user,
|
57
|
+
}
|
58
|
+
= subscriptionFacetAttributes;
|
59
|
+
const login = user?.login;
|
60
|
+
if (!registeredAt) return null;
|
61
|
+
return (
|
62
|
+
<CardTemplate
|
63
|
+
header={__('Registration details')}
|
64
|
+
expandable
|
65
|
+
isExpandedGlobal={isExpandedGlobal}
|
66
|
+
>
|
67
|
+
<DescriptionList isHorizontal>
|
68
|
+
<DescriptionListGroup>
|
69
|
+
<DescriptionListTerm>{__('Registered on')}</DescriptionListTerm>
|
70
|
+
<DescriptionListDescription><IsoDate date={registeredAt} /></DescriptionListDescription>
|
71
|
+
</DescriptionListGroup>
|
72
|
+
<DescriptionListGroup>
|
73
|
+
<DescriptionListTerm>{__('Registered by')}</DescriptionListTerm>
|
74
|
+
<RegisteredBy user={login} activationKeys={activationKeys} />
|
75
|
+
</DescriptionListGroup>
|
76
|
+
<DescriptionListGroup>
|
77
|
+
<DescriptionListTerm>{__('Registered through')}</DescriptionListTerm>
|
78
|
+
<DescriptionListDescription>{registeredThrough}</DescriptionListDescription>
|
79
|
+
</DescriptionListGroup>
|
80
|
+
</DescriptionList>
|
81
|
+
</CardTemplate>
|
82
|
+
);
|
83
|
+
};
|
84
|
+
|
85
|
+
RegistrationCard.propTypes = {
|
86
|
+
isExpandedGlobal: PropTypes.bool,
|
87
|
+
hostDetails: PropTypes.shape({
|
88
|
+
subscription_facet_attributes: PropTypes.shape({
|
89
|
+
user: PropTypes.shape({
|
90
|
+
login: PropTypes.string,
|
91
|
+
}),
|
92
|
+
registered_at: PropTypes.string,
|
93
|
+
registered_through: PropTypes.string,
|
94
|
+
activation_keys: PropTypes.arrayOf(PropTypes.shape({
|
95
|
+
id: PropTypes.number,
|
96
|
+
name: PropTypes.string,
|
97
|
+
})),
|
98
|
+
}),
|
99
|
+
}),
|
100
|
+
};
|
101
|
+
|
102
|
+
RegistrationCard.defaultProps = {
|
103
|
+
isExpandedGlobal: false,
|
104
|
+
hostDetails: {},
|
105
|
+
};
|
106
|
+
|
107
|
+
export default RegistrationCard;
|
data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js
ADDED
@@ -0,0 +1,38 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import PropTypes from 'prop-types';
|
3
|
+
import {
|
4
|
+
DescriptionListGroup,
|
5
|
+
DescriptionListTerm,
|
6
|
+
DescriptionListDescription,
|
7
|
+
ClipboardCopy,
|
8
|
+
} from '@patternfly/react-core';
|
9
|
+
import { translate as __ } from 'foremanReact/common/I18n';
|
10
|
+
|
11
|
+
const SystemPropertiesCardExtensions = ({ hostDetails }) => {
|
12
|
+
const subscriptionUuid = hostDetails?.subscription_facet_attributes?.uuid;
|
13
|
+
if (!subscriptionUuid) return null;
|
14
|
+
return (
|
15
|
+
<DescriptionListGroup>
|
16
|
+
<DescriptionListTerm>{__('Subscription UUID')}</DescriptionListTerm>
|
17
|
+
<DescriptionListDescription>
|
18
|
+
<ClipboardCopy isBlock variant="inline-compact" clickTip={__('Copied to clipboard')}>
|
19
|
+
{subscriptionUuid}
|
20
|
+
</ClipboardCopy>
|
21
|
+
</DescriptionListDescription>
|
22
|
+
</DescriptionListGroup>
|
23
|
+
);
|
24
|
+
};
|
25
|
+
|
26
|
+
SystemPropertiesCardExtensions.propTypes = {
|
27
|
+
hostDetails: PropTypes.shape({
|
28
|
+
subscription_facet_attributes: PropTypes.shape({
|
29
|
+
uuid: PropTypes.string,
|
30
|
+
}),
|
31
|
+
}),
|
32
|
+
};
|
33
|
+
|
34
|
+
SystemPropertiesCardExtensions.defaultProps = {
|
35
|
+
hostDetails: {},
|
36
|
+
};
|
37
|
+
|
38
|
+
export default SystemPropertiesCardExtensions;
|
@@ -21,7 +21,7 @@ import IsoDate from 'foremanReact/components/common/dates/IsoDate';
|
|
21
21
|
import { urlBuilder } from 'foremanReact/common/urlHelpers';
|
22
22
|
import { propsToCamelCase } from 'foremanReact/common/helpers';
|
23
23
|
import SelectableDropdown from '../../../../SelectableDropdown';
|
24
|
-
import { useSet, useBulkSelect, useUrlParams } from '../../../../../components/Table/TableHooks';
|
24
|
+
import { useSet, useBulkSelect, useUrlParams, useTableSort } from '../../../../../components/Table/TableHooks';
|
25
25
|
import TableWrapper from '../../../../../components/Table/TableWrapper';
|
26
26
|
import { ErrataType, ErrataSeverity } from '../../../../../components/Errata';
|
27
27
|
import { getInstallableErrata, regenerateApplicability, applyViaKatelloAgent } from './HostErrataActions';
|
@@ -34,6 +34,7 @@ import { errataInstallUrl } from '../customizedRexUrlHelpers';
|
|
34
34
|
import './ErrataTab.scss';
|
35
35
|
import hostIdNotReady from '../../HostDetailsActions';
|
36
36
|
import { defaultRemoteActionMethod, KATELLO_AGENT } from '../../hostDetailsHelpers';
|
37
|
+
import SortableColumnHeaders from '../../../../Table/components/SortableColumnHeaders';
|
37
38
|
|
38
39
|
export const ErrataTab = () => {
|
39
40
|
const hostDetails = useSelector(state => selectAPIResponse(state, 'HOST_DETAILS'));
|
@@ -41,6 +42,7 @@ export const ErrataTab = () => {
|
|
41
42
|
id: hostId,
|
42
43
|
name: hostname,
|
43
44
|
content_facet_attributes: contentFacetAttributes,
|
45
|
+
errata_status: errataStatus,
|
44
46
|
} = hostDetails;
|
45
47
|
const contentFacet = propsToCamelCase(contentFacetAttributes ?? {});
|
46
48
|
const dispatch = useDispatch();
|
@@ -65,11 +67,12 @@ export const ErrataTab = () => {
|
|
65
67
|
= useState(PARAM_TO_FRIENDLY_NAME[initialSeverity] ?? ERRATA_SEVERITY);
|
66
68
|
const activeFilters = [errataTypeSelected, errataSeveritySelected];
|
67
69
|
const defaultFilters = [ERRATA_TYPE, ERRATA_SEVERITY];
|
68
|
-
|
69
|
-
const emptyContentTitle = __('This host
|
70
|
-
const emptyContentBody = __('
|
70
|
+
const allUpToDate = errataStatus === 0;
|
71
|
+
const emptyContentTitle = allUpToDate ? __('All errata up-to-date') : __('This host has errata that are applicable, but not installable.');
|
72
|
+
const emptyContentBody = allUpToDate ? __('No action is needed because there are no applicable errata for this host.') : __("You may want to check the host's content view and lifecycle environment.");
|
71
73
|
const emptySearchTitle = __('No matching errata found');
|
72
74
|
const emptySearchBody = __('Try changing your search settings.');
|
75
|
+
const errorSearchTitle = __('Problem searching errata');
|
73
76
|
const columnHeaders = [
|
74
77
|
__('Errata'),
|
75
78
|
__('Type'),
|
@@ -78,18 +81,22 @@ export const ErrataTab = () => {
|
|
78
81
|
__('Synopsis'),
|
79
82
|
__('Published date'),
|
80
83
|
];
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
}
|
87
|
-
if (errataSeveritySelected !== ERRATA_SEVERITY) {
|
88
|
-
query.push(`severity=${SEVERITIES_TO_PARAM[errataSeveritySelected]}`);
|
89
|
-
}
|
90
|
-
return query.join(' and ');
|
84
|
+
const COLUMNS_TO_SORT_PARAMS = {
|
85
|
+
[columnHeaders[0]]: 'errata_id',
|
86
|
+
[columnHeaders[1]]: 'type',
|
87
|
+
[columnHeaders[2]]: 'severity',
|
88
|
+
[columnHeaders[5]]: 'updated',
|
91
89
|
};
|
92
90
|
|
91
|
+
const {
|
92
|
+
pfSortParams, apiSortParams,
|
93
|
+
activeSortColumn, activeSortDirection,
|
94
|
+
} = useTableSort({
|
95
|
+
allColumns: columnHeaders,
|
96
|
+
columnsToSortParams: COLUMNS_TO_SORT_PARAMS,
|
97
|
+
initialSortColumnName: 'Errata',
|
98
|
+
});
|
99
|
+
|
93
100
|
const fetchItems = useCallback(
|
94
101
|
(params) => {
|
95
102
|
if (!hostId) return hostIdNotReady;
|
@@ -104,16 +111,18 @@ export const ErrataTab = () => {
|
|
104
111
|
hostId,
|
105
112
|
{
|
106
113
|
include_applicable: toggleGroupState === ALL,
|
114
|
+
...apiSortParams,
|
107
115
|
...modifiedParams,
|
108
116
|
},
|
109
117
|
);
|
110
118
|
},
|
111
119
|
[hostId, toggleGroupState, ALL, ERRATA_SEVERITY, ERRATA_TYPE,
|
112
|
-
errataTypeSelected, errataSeveritySelected],
|
120
|
+
errataTypeSelected, errataSeveritySelected, apiSortParams],
|
113
121
|
);
|
114
122
|
|
115
123
|
const response = useSelector(state => selectAPIResponse(state, HOST_ERRATA_KEY));
|
116
124
|
const { results, ...metadata } = response;
|
125
|
+
const { error: errorSearchBody } = metadata;
|
117
126
|
const status = useSelector(state => selectHostErrataStatus(state));
|
118
127
|
const errataSearchQuery = id => `errata_id = ${id}`;
|
119
128
|
const {
|
@@ -123,11 +132,18 @@ export const ErrataTab = () => {
|
|
123
132
|
results,
|
124
133
|
metadata,
|
125
134
|
idColumn: 'errata_id',
|
126
|
-
filtersQuery: filtersQuery(),
|
127
135
|
isSelectable: result => result.installable,
|
128
136
|
initialSearchQuery: searchParam || '',
|
129
137
|
});
|
130
138
|
|
139
|
+
const tdSelect = useCallback((errataId, rowIndex) => ({
|
140
|
+
disable: !isSelectable(errataId),
|
141
|
+
isSelected: isSelected(errataId),
|
142
|
+
onSelect: (event, selected) => selectOne(selected, errataId),
|
143
|
+
rowIndex,
|
144
|
+
variant: 'checkbox',
|
145
|
+
}), [isSelectable, isSelected, selectOne]);
|
146
|
+
|
131
147
|
if (!hostId) return <Skeleton />;
|
132
148
|
|
133
149
|
const applyErratumViaRemoteExecution = id => dispatch(installErrata({
|
@@ -260,7 +276,7 @@ export const ErrataTab = () => {
|
|
260
276
|
);
|
261
277
|
|
262
278
|
const hostIsNonLibrary = (
|
263
|
-
contentFacet?.contentViewDefault === false
|
279
|
+
contentFacet?.contentViewDefault === false && contentFacet.lifecycleEnvironmentLibrary === false
|
264
280
|
);
|
265
281
|
const toggleGroup = (
|
266
282
|
<Split hasGutter>
|
@@ -272,6 +288,7 @@ export const ErrataTab = () => {
|
|
272
288
|
items={Object.values(ERRATA_TYPES)}
|
273
289
|
selected={errataTypeSelected}
|
274
290
|
setSelected={handleErrataTypeSelected}
|
291
|
+
isDisabled={!results?.length}
|
275
292
|
/>
|
276
293
|
</SplitItem>
|
277
294
|
<SplitItem>
|
@@ -282,6 +299,7 @@ export const ErrataTab = () => {
|
|
282
299
|
items={Object.values(ERRATA_SEVERITIES)}
|
283
300
|
selected={errataSeveritySelected}
|
284
301
|
setSelected={handleErrataSeveritySelected}
|
302
|
+
isDisabled={!results?.length}
|
285
303
|
/>
|
286
304
|
</SplitItem>
|
287
305
|
{hostIsNonLibrary &&
|
@@ -294,7 +312,6 @@ export const ErrataTab = () => {
|
|
294
312
|
isSelected={toggleGroupState === ALL}
|
295
313
|
onChange={() => setToggleGroupState(ALL)}
|
296
314
|
/>
|
297
|
-
|
298
315
|
<ToggleGroupItem
|
299
316
|
text={__('Installable')}
|
300
317
|
buttonId="installableToggle"
|
@@ -318,6 +335,8 @@ export const ErrataTab = () => {
|
|
318
335
|
emptyContentBody,
|
319
336
|
emptySearchTitle,
|
320
337
|
emptySearchBody,
|
338
|
+
errorSearchTitle,
|
339
|
+
errorSearchBody,
|
321
340
|
status,
|
322
341
|
activeFilters,
|
323
342
|
defaultFilters,
|
@@ -329,9 +348,13 @@ export const ErrataTab = () => {
|
|
329
348
|
toggleGroup,
|
330
349
|
}
|
331
350
|
}
|
351
|
+
happyEmptyContent={allUpToDate}
|
352
|
+
ouiaId="host-errata-table"
|
332
353
|
additionalListeners={[
|
333
|
-
hostId, toggleGroupState, errataTypeSelected,
|
354
|
+
hostId, toggleGroupState, errataTypeSelected,
|
355
|
+
errataSeveritySelected, activeSortColumn, activeSortDirection]}
|
334
356
|
fetchItems={fetchItems}
|
357
|
+
bookmarkController="katello_errata"
|
335
358
|
autocompleteEndpoint={`/hosts/${hostId}/errata/auto_complete_search`}
|
336
359
|
foremanApiAutoComplete
|
337
360
|
rowsCount={results?.length}
|
@@ -343,8 +366,11 @@ export const ErrataTab = () => {
|
|
343
366
|
<Tr>
|
344
367
|
<Th key="expand-carat" />
|
345
368
|
<Th key="select-all" />
|
346
|
-
|
347
|
-
|
369
|
+
<SortableColumnHeaders
|
370
|
+
columnHeaders={columnHeaders}
|
371
|
+
pfSortParams={pfSortParams}
|
372
|
+
columnsToSortParams={COLUMNS_TO_SORT_PARAMS}
|
373
|
+
/>
|
348
374
|
<Th key="action-menu" />
|
349
375
|
</Tr>
|
350
376
|
</Thead>
|
@@ -399,14 +425,7 @@ export const ErrataTab = () => {
|
|
399
425
|
onToggle: (_event, _rInx, isOpen) => expandedErrata.onToggle(isOpen, id),
|
400
426
|
}}
|
401
427
|
/>
|
402
|
-
<Td select={
|
403
|
-
disable: !isSelectable(errataId),
|
404
|
-
isSelected: isSelected(errataId),
|
405
|
-
onSelect: (event, selected) => selectOne(selected, errataId),
|
406
|
-
rowIndex,
|
407
|
-
variant: 'checkbox',
|
408
|
-
}}
|
409
|
-
/>
|
428
|
+
<Td select={tdSelect(errataId, rowIndex)} />
|
410
429
|
<Td>
|
411
430
|
<a href={urlBuilder(`errata/${id}`, '')}>{errataId}</a>
|
412
431
|
</Td>
|
@@ -439,16 +458,20 @@ export const ErrataTab = () => {
|
|
439
458
|
/>
|
440
459
|
</Tr>
|
441
460
|
<Tr key="child_row" isExpanded={isExpanded}>
|
442
|
-
|
443
|
-
|
444
|
-
<
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
<
|
450
|
-
|
451
|
-
|
461
|
+
{isExpanded && (
|
462
|
+
<>
|
463
|
+
<Td colSpan={3}>
|
464
|
+
<ExpandableRowContent>
|
465
|
+
<ErratumExpansionContents erratum={erratum} />
|
466
|
+
</ExpandableRowContent>
|
467
|
+
</Td>
|
468
|
+
<Td colSpan={4}>
|
469
|
+
<ExpandableRowContent>
|
470
|
+
<ErratumExpansionDetail erratum={erratum} />
|
471
|
+
</ExpandableRowContent>
|
472
|
+
</Td>
|
473
|
+
</>
|
474
|
+
)}
|
452
475
|
</Tr>
|
453
476
|
</Tbody>
|
454
477
|
);
|
@@ -1,13 +1,7 @@
|
|
1
1
|
import { API_OPERATIONS, get, put } from 'foremanReact/redux/API';
|
2
2
|
import { foremanApi } from '../../../../../services/api';
|
3
3
|
import { HOST_ERRATA_KEY, HOST_ERRATA_APPLICABILITY_KEY, HOST_ERRATA_APPLY_KEY } from './HostErrataConstants';
|
4
|
-
import {
|
5
|
-
import { renderTaskStartedToast } from '../../../../../scenes/Tasks/helpers';
|
6
|
-
|
7
|
-
const errorToast = (error) => {
|
8
|
-
const message = getResponseErrorMsgs(error.response);
|
9
|
-
return message;
|
10
|
-
};
|
4
|
+
import { errorToast, renderTaskStartedToast } from '../../../../../scenes/Tasks/helpers';
|
11
5
|
|
12
6
|
export const getInstallableErrata = (hostId, params) => get({
|
13
7
|
type: API_OPERATIONS.GET,
|
data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsActions.js
CHANGED
@@ -1,10 +1,8 @@
|
|
1
1
|
import { API_OPERATIONS, get } from 'foremanReact/redux/API';
|
2
|
+
import { errorToast } from '../../../../../scenes/Tasks/helpers';
|
2
3
|
import { foremanApi } from '../../../../../services/api';
|
3
|
-
import { getResponseErrorMsgs } from '../../../../../utils/helpers';
|
4
4
|
import { MODULE_STREAMS_KEY } from './ModuleStreamsConstants';
|
5
5
|
|
6
|
-
const errorToast = error => getResponseErrorMsgs(error.response);
|
7
|
-
|
8
6
|
export const getHostModuleStreams = (hostId, params) => get({
|
9
7
|
type: API_OPERATIONS.GET,
|
10
8
|
key: MODULE_STREAMS_KEY,
|
data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsConstants.js
CHANGED
@@ -1,3 +1,31 @@
|
|
1
1
|
export const MODULE_STREAMS_KEY = 'MODULE_STREAMS';
|
2
2
|
|
3
|
+
export const INSTALLED_STATE = {
|
4
|
+
UPGRADEABLE: 'Upgradable',
|
5
|
+
UPTODATE: 'Up-to-date',
|
6
|
+
NOTINSTALLED: 'Not installed',
|
7
|
+
};
|
8
|
+
|
9
|
+
export const HOST_MODULE_STREAM_STATUSES = {
|
10
|
+
ENABLED: 'Enabled',
|
11
|
+
INSTALLED: 'Installed',
|
12
|
+
DISABLED: 'Disabled',
|
13
|
+
UNKNOWN: 'Unknown',
|
14
|
+
UPGRADABLE: 'Upgradable',
|
15
|
+
};
|
16
|
+
|
17
|
+
export const STATUS_PARAM_TO_FRIENDLY_NAME = {
|
18
|
+
enabled: 'Enabled',
|
19
|
+
installed: 'Installed',
|
20
|
+
disabled: 'Disabled',
|
21
|
+
unknown: 'Unknown',
|
22
|
+
upgradable: 'Upgradable',
|
23
|
+
};
|
24
|
+
|
25
|
+
export const INSTALL_STATUS_PARAM_TO_FRIENDLY_NAME = {
|
26
|
+
not_installed: 'Not installed',
|
27
|
+
up_to_date: 'Up-to-date',
|
28
|
+
upgradable: 'Upgradable',
|
29
|
+
};
|
30
|
+
|
3
31
|
export default MODULE_STREAMS_KEY;
|