katello 4.4.1 → 4.5.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/katello/hosts/activation_key_edit.js +9 -2
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +3 -0
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +5 -1
- data/app/controllers/katello/api/v2/alternate_content_sources_bulk_actions_controller.rb +44 -0
- data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +121 -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_components_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_repositories_controller.rb +1 -1
- 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 +1 -1
- 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/refresh.rb +27 -0
- data/app/lib/actions/katello/alternate_content_source/update.rb +41 -0
- data/app/lib/actions/katello/cdn_configuration/update.rb +3 -3
- 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 +8 -10
- 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/organization/manifest_refresh.rb +1 -1
- 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/refresh.rb +23 -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 +16 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +23 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +15 -0
- data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +16 -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/save_artifact.rb +1 -1
- data/app/lib/katello/api/v2/error_handling.rb +1 -0
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +24 -11
- 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 +71 -0
- data/app/models/katello/authorization/alternate_content_source.rb +33 -0
- data/app/models/katello/authorization/repository.rb +5 -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 -6
- 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/product_content_finder.rb +12 -2
- data/app/services/katello/pulp3/alternate_content_source.rb +123 -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 +104 -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 +102 -38
- 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 +6 -62
- 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 +10 -8
- 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 +24 -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_facet/show.json.rabl +12 -0
- 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/api/v2/repository_sets/show.json.rabl +4 -0
- data/app/views/katello/sync_management/_repo.html.erb +8 -29
- data/config/routes/api/v2.rb +19 -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 +1 -1
- 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/20220303160220_remove_duplicate_errata.rb +1 -1
- 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/migrate/20220428203334_add_last_refreshed_to_katello_alternate_content_sources.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/activation-keys.routes.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-details.controller.js +4 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +11 -6
- 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-packages.controller.js +11 -3
- 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 -12
- 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 +34 -4
- data/lib/katello/plugin.rb +377 -3
- data/lib/katello/tasks/refresh_alternate_content_sources.rake +15 -0
- 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/Bookmark/index.js +22 -14
- 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 +22 -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/MainTable.scss +5 -1
- data/webpack/components/Table/TableHooks.js +65 -20
- data/webpack/components/Table/TableWrapper.js +9 -3
- data/webpack/components/Table/components/SortableColumnHeaders.js +19 -0
- data/webpack/components/Table/components/TranslatedPlural.js +57 -0
- data/webpack/components/TypeAhead/TypeAhead.js +12 -0
- data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +13 -11
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +7 -2
- data/webpack/components/extensions/HostDetails/ActionsBar/index.js +27 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +250 -0
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ContentViewDetailsCard.js +232 -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 +206 -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 +118 -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/RecentCommunicationCardExtensions.js +37 -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/HostDetailsActions.js +11 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/SecondaryTabsRoutes.js +4 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/constants.js +2 -0
- data/webpack/components/extensions/HostDetails/Tabs/ContentTab/index.js +6 -1
- data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +176 -72
- 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 +522 -118
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/HostPackagesActions.js +1 -7
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackageInstallModal.js +6 -4
- data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +164 -58
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionActions.js +59 -49
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionConstants.js +1 -0
- data/webpack/components/extensions/HostDetails/Tabs/RemoteExecutionHooks.js +85 -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 +298 -107
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerModal.js +14 -7
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/HostTracesActions.js +2 -1
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesEnabler.js +104 -0
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +134 -57
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/errataTab.test.js +37 -32
- data/webpack/components/extensions/HostDetails/Tabs/{ModuleStreamsTab/__tests__/modules.fixtures.json → __tests__/moduleStreams.fixtures.json} +6 -3
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/moduleStreamsTab.test.js +261 -0
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packageInstallModal.test.js +21 -15
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/packagesTab.test.js +44 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +4 -1
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +105 -6
- data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +25 -6
- data/webpack/components/extensions/HostDetails/Tabs/customizedRexUrlHelpers.js +6 -0
- data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +18 -0
- data/webpack/containers/Application/config.js +5 -0
- data/webpack/global_index.js +32 -9
- data/webpack/global_test_setup.js +13 -0
- data/webpack/redux/actions/RedHatRepositories/enabled.js +2 -1
- data/webpack/redux/actions/RedHatRepositories/helpers.js +13 -8
- data/webpack/scenes/AlternateContentSources/ACSActions.js +65 -0
- data/webpack/scenes/AlternateContentSources/ACSConstants.js +18 -0
- data/webpack/scenes/AlternateContentSources/ACSIndexPage.js +23 -0
- data/webpack/scenes/AlternateContentSources/ACSSelectors.js +24 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateContext.js +4 -0
- data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +160 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +79 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCredentials.js +199 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +104 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +41 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +71 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/NameACS.js +57 -0
- data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +77 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +149 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreateData.fixtures.json +3 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/contentCredentials.fixtures.json +69 -0
- data/webpack/scenes/AlternateContentSources/Create/__tests__/smartProxy.fixtures.json +65 -0
- data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +162 -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/ContentCredentials/ContentCredentialSelectors.js +4 -1
- 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 +2 -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 +2 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentContentViewBulkAddModal.js +2 -2
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +3 -1
- 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 +16 -2
- 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/components/ContentViewIcon.js +14 -3
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +4 -3
- data/webpack/scenes/ContentViews/components/EnvironmentPaths/EnvironmentPaths.js +10 -6
- 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/RelatedCompositeContentViewsModal.js +1 -1
- data/webpack/scenes/ContentViews/expansions/RelatedContentViewComponentsModal.js +2 -2
- 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/RedHatRepositories/components/Search.js +4 -4
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +9 -2
- data/webpack/scenes/SmartProxy/SmartProxyContentConstants.js +1 -1
- data/webpack/scenes/SmartProxy/SmartProxyContentSelectors.js +10 -1
- 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 +60 -5
- data/webpack/utils/helpers.js +2 -0
- metadata +183 -38
- data/app/models/setting/content.rb +0 -201
- data/db/seeds.d/107-enable_dynflow.rb +0 -8
- data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard.js +0 -96
- data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/__tests__/moduleStreamsTab.test.js +0 -108
- data/webpack/components/extensions/HostDetails/Tabs/TracesTab/EnableTracerEmptyState.js +0 -42
- data/webpack/scenes/ContentViews/Details/DetailsContainer.js +0 -36
@@ -11,5 +11,18 @@
|
|
11
11
|
[
|
12
12
|
]
|
13
13
|
}
|
14
|
+
},
|
15
|
+
{
|
16
|
+
group: N_('Content View'),
|
17
|
+
name: 'delete_latest_content_view_version_error',
|
18
|
+
message: N_('Failed to delete latest content view version of Content View \'%{subject}\'.'),
|
19
|
+
level: 'error',
|
20
|
+
actions:
|
21
|
+
{
|
22
|
+
links:
|
23
|
+
[
|
24
|
+
]
|
25
|
+
}
|
26
|
+
|
14
27
|
}
|
15
28
|
].each { |blueprint| UINotifications::Seed.new(blueprint).configure }
|
@@ -1,7 +1,7 @@
|
|
1
1
|
if Katello.with_remote_execution?
|
2
2
|
User.as_anonymous_admin do
|
3
3
|
JobTemplate.without_auditing do
|
4
|
-
module_template = JobTemplate.find_by(name: 'Module Action -
|
4
|
+
module_template = JobTemplate.find_by(name: 'Module Action - Script Default')
|
5
5
|
if module_template
|
6
6
|
module_template.sync_feature('katello_module_stream_action')
|
7
7
|
module_template.organizations << Organization.unscoped.all if module_template.organizations.empty?
|
data/engines/bastion/README.md
CHANGED
@@ -35,6 +35,7 @@ BASTION_MODULES.push('myModuleName');
|
|
35
35
|
Bastion supplies a common set of testing and development using Grunt. To setup your development environment, from your plugin's checkout:
|
36
36
|
|
37
37
|
```
|
38
|
+
sudo yum -y install npm chromium-headless chromium
|
38
39
|
sudo npm install -g grunt-cli
|
39
40
|
npm install
|
40
41
|
npm install ../bastion/
|
@@ -19,6 +19,7 @@
|
|
19
19
|
angular.module('Bastion').value('currentLocale', '<%= I18n.locale %>');
|
20
20
|
angular.module('Bastion').value('CurrentOrganization', "<%= Organization.current.id if Organization.current %>");
|
21
21
|
angular.module('Bastion').value('simpleContentAccessEnabled', <%= Organization.current.simple_content_access? if Organization.current %>);
|
22
|
+
angular.module('Bastion').value('isManifestImported', <%= !!Organization.current&.manifest_imported?(cached: true) %>)
|
22
23
|
angular.module('Bastion').value('foreman', tfm);
|
23
24
|
angular.module('Bastion').value('repositoryTypes', angular.fromJson('<%= Katello::RepositoryTypeManager.enabled_repository_types.values.to_json.html_safe %>'));
|
24
25
|
angular.module('Bastion').value('deleteHostOnUnregister', angular.fromJson('<%= Setting[:unregister_delete_host] %>'));
|
@@ -115,7 +115,7 @@ angular.module('Bastion.activation-keys').config(['$stateProvider', function ($s
|
|
115
115
|
})
|
116
116
|
.state('activation-key.copy', {
|
117
117
|
url: '/copy',
|
118
|
-
permission: '
|
118
|
+
permission: 'create_activation_keys',
|
119
119
|
controller: 'ActivationKeyCopyController',
|
120
120
|
templateUrl: 'activation-keys/details/views/activation-key-copy.html',
|
121
121
|
ncyBreadcrumb: {
|
@@ -12,18 +12,20 @@
|
|
12
12
|
* @requires Notification
|
13
13
|
* @requires ApiErrorHandler
|
14
14
|
* @requires simpleContentAccessEnabled
|
15
|
+
* @requires isManifestImported
|
15
16
|
*
|
16
17
|
* @description
|
17
18
|
* Provides the functionality for the activation key details action pane.
|
18
19
|
*/
|
19
20
|
angular.module('Bastion.activation-keys').controller('ActivationKeyDetailsController',
|
20
|
-
['$scope', '$state', '$q', 'translate', 'ActivationKey', 'Organization', 'CurrentOrganization', 'Notification', 'ApiErrorHandler', 'simpleContentAccessEnabled',
|
21
|
-
function ($scope, $state, $q, translate, ActivationKey, Organization, CurrentOrganization, Notification, ApiErrorHandler, simpleContentAccessEnabled) {
|
21
|
+
['$scope', '$state', '$q', 'translate', 'ActivationKey', 'Organization', 'CurrentOrganization', 'Notification', 'ApiErrorHandler', 'simpleContentAccessEnabled', 'isManifestImported',
|
22
|
+
function ($scope, $state, $q, translate, ActivationKey, Organization, CurrentOrganization, Notification, ApiErrorHandler, simpleContentAccessEnabled, isManifestImported) {
|
22
23
|
$scope.defaultRoles = ['Red Hat Enterprise Linux Server', 'Red Hat Enterprise Linux Workstation', 'Red Hat Enterprise Linux Compute Node'];
|
23
24
|
$scope.defaultUsages = ['Production', 'Development/Test', 'Disaster Recovery'];
|
24
25
|
|
25
26
|
$scope.purposeAddonsCount = 0;
|
26
27
|
$scope.simpleContentAccessEnabled = simpleContentAccessEnabled;
|
28
|
+
$scope.isManifestImported = isManifestImported;
|
27
29
|
|
28
30
|
$scope.organization = Organization.get({id: CurrentOrganization}, function(org) {
|
29
31
|
$scope.purposeAddonsCount += org.system_purposes.addons.length;
|
@@ -8,7 +8,7 @@
|
|
8
8
|
<div data-block="item-actions" bst-feature-flag="custom_products">
|
9
9
|
<span select-action-dropdown>
|
10
10
|
<ul class="dropdown-menu dropdown-menu-right" uib-dropdown-menu role="menu">
|
11
|
-
<li role="menuitem" ng-hide="denied('
|
11
|
+
<li role="menuitem" ng-hide="denied('create_activation_keys')">
|
12
12
|
<a ui-sref="activation-key.copy" translate>
|
13
13
|
Copy Activation Key
|
14
14
|
</a>
|
@@ -23,9 +23,14 @@ angular.module('Bastion.capsule-content').controller('CapsuleContentController',
|
|
23
23
|
var urlMatcher = $urlMatcherFactory.compile("/smart_proxies/:capsuleId");
|
24
24
|
var capsuleId = urlMatcher.exec($location.path()).capsuleId;
|
25
25
|
|
26
|
-
function processError(response) {
|
26
|
+
function processError(response, prependMsg) {
|
27
|
+
var msg = '';
|
27
28
|
if (response.data && response.data.displayMessage) {
|
28
|
-
|
29
|
+
if (angular.isDefined(prependMsg)) {
|
30
|
+
msg = msg + prependMsg;
|
31
|
+
}
|
32
|
+
msg = msg + response.data.displayMessage;
|
33
|
+
Notification.setErrorMessage(msg);
|
29
34
|
}
|
30
35
|
}
|
31
36
|
|
@@ -104,7 +109,7 @@ angular.module('Bastion.capsule-content').controller('CapsuleContentController',
|
|
104
109
|
} else if (errorCount > 1) {
|
105
110
|
errorMessage += " " + translate("Plus 1 more error");
|
106
111
|
}
|
107
|
-
Notification.setErrorMessage(errorMessage);
|
112
|
+
Notification.setErrorMessage(translate('Last sync failed: ') + errorMessage);
|
108
113
|
}
|
109
114
|
}
|
110
115
|
$scope.syncState.set(stateFromTask(activeOrFailedTask));
|
@@ -113,7 +118,7 @@ angular.module('Bastion.capsule-content').controller('CapsuleContentController',
|
|
113
118
|
'active_sync_tasks': [],
|
114
119
|
'last_failed_sync_tasks': []
|
115
120
|
};
|
116
|
-
processError(response);
|
121
|
+
processError(response, translate('Last sync failed: '));
|
117
122
|
});
|
118
123
|
};
|
119
124
|
|
@@ -141,7 +146,7 @@ angular.module('Bastion.capsule-content').controller('CapsuleContentController',
|
|
141
146
|
$scope.syncTask = aggregateTasks($scope.syncStatus['active_sync_tasks']);
|
142
147
|
$scope.syncState.set(syncState.RECLAIMING_SPACE);
|
143
148
|
}, function (response) {
|
144
|
-
processError(response);
|
149
|
+
processError(response, translate('Last reclaim space failed: '));
|
145
150
|
$scope.syncState.set(syncState.DEFAULT);
|
146
151
|
});
|
147
152
|
}
|
@@ -157,7 +162,7 @@ angular.module('Bastion.capsule-content').controller('CapsuleContentController',
|
|
157
162
|
$scope.syncTask = aggregateTasks($scope.syncStatus['active_sync_tasks']);
|
158
163
|
$scope.syncState.set(syncState.SYNCING);
|
159
164
|
}, function (response) {
|
160
|
-
processError(response);
|
165
|
+
processError(response, translate('Last sync failed: '));
|
161
166
|
$scope.syncState.set(syncState.DEFAULT);
|
162
167
|
});
|
163
168
|
}
|
@@ -21,6 +21,7 @@ angular.module('Bastion.content-hosts').controller('ContentHostModuleStreamsCont
|
|
21
21
|
$scope.working = false;
|
22
22
|
|
23
23
|
$scope.nutupaneParams = { id: $scope.$stateParams.hostId };
|
24
|
+
$scope.controllerName = 'katello_host_available_module_streams';
|
24
25
|
|
25
26
|
$scope.moduleStreamsNutupane = new Nutupane(HostModuleStream, $scope.nutupaneParams);
|
26
27
|
|
@@ -17,6 +17,7 @@ angular.module('Bastion.content-hosts').controller('ContentHostPackagesInstalled
|
|
17
17
|
['$scope', '$timeout', '$window', 'HostPackage', 'translate', 'Nutupane', 'BastionConfig',
|
18
18
|
function ($scope, $timeout, $window, HostPackage, translate, Nutupane, BastionConfig) {
|
19
19
|
var packagesNutupane;
|
20
|
+
$scope.controllerName = 'katello_host_installed_packages';
|
20
21
|
|
21
22
|
$scope.katelloAgentPresent = BastionConfig.katelloAgentPresent;
|
22
23
|
$scope.remoteExecutionPresent = BastionConfig.remoteExecutionPresent;
|
@@ -45,7 +45,7 @@ angular.module('Bastion.content-hosts').controller('ContentHostPackagesControlle
|
|
45
45
|
|
46
46
|
$scope.updateAll = function () {
|
47
47
|
$scope.working = true;
|
48
|
-
|
48
|
+
$scope.performPackageAction('packageUpdate', '');
|
49
49
|
};
|
50
50
|
|
51
51
|
$scope.performPackageAction = function (actionType, term) {
|
@@ -57,9 +57,14 @@ angular.module('Bastion.content-hosts').controller('ContentHostPackagesControlle
|
|
57
57
|
};
|
58
58
|
|
59
59
|
$scope.performViaKatelloAgent = function (actionType, term) {
|
60
|
-
var terms =
|
60
|
+
var terms = [];
|
61
|
+
if (term === '') {
|
62
|
+
packageActions.updateAll();
|
63
|
+
} else {
|
64
|
+
terms = term.split(/ *, */);
|
65
|
+
packageActions[actionType](terms);
|
66
|
+
}
|
61
67
|
$scope.working = true;
|
62
|
-
packageActions[actionType](terms);
|
63
68
|
};
|
64
69
|
|
65
70
|
$scope.performViaRemoteExecution = function(actionType, term, customize) {
|
@@ -76,6 +81,9 @@ angular.module('Bastion.content-hosts').controller('ContentHostPackagesControlle
|
|
76
81
|
};
|
77
82
|
|
78
83
|
packageActions = {
|
84
|
+
updateAll: function () {
|
85
|
+
HostPackage.updateAll({id: $scope.host.id}, $scope.openEventInfo, $scope.errorHandler);
|
86
|
+
},
|
79
87
|
packageInstall: function (termList) {
|
80
88
|
HostPackage.install({id: $scope.host.id, packages: termList}, $scope.openEventInfo, $scope.errorHandler);
|
81
89
|
},
|
@@ -23,6 +23,7 @@ angular.module('Bastion.content-hosts').controller('ContentHostTracesController'
|
|
23
23
|
|
24
24
|
tracesNutupane = new Nutupane(HostTraces, params, 'get', {'disableAutoLoad': true});
|
25
25
|
tracesNutupane.primaryOnly = true;
|
26
|
+
$scope.controllerName = 'katello_host_tracers';
|
26
27
|
$scope.table = tracesNutupane.table;
|
27
28
|
$scope.table.tracesFilterTerm = "";
|
28
29
|
$scope.table.tracesCompare = function (item) {
|
@@ -60,7 +60,7 @@
|
|
60
60
|
<div class="form-group">
|
61
61
|
<button class="btn btn-default" type="button"
|
62
62
|
translate
|
63
|
-
ng-disabled="
|
63
|
+
ng-disabled="working || (!remoteExecutionPresent && !katelloAgentPresent)"
|
64
64
|
ng-click="updateAll()">
|
65
65
|
Update All Packages
|
66
66
|
</button>
|
@@ -169,5 +169,13 @@ angular.module('Bastion.content-hosts').controller('ContentHostsController',
|
|
169
169
|
nutupane.invalidate();
|
170
170
|
ContentHostsModalHelper.openTracesModal();
|
171
171
|
};
|
172
|
+
|
173
|
+
$scope.isDebEnabled = function(hostOS) {
|
174
|
+
return _.isString(hostOS) && hostOS.match(/Debian|Ubuntu/) !== null;
|
175
|
+
};
|
176
|
+
|
177
|
+
$scope.isRpmEnabled = function(hostOS) {
|
178
|
+
return !$scope.isDebEnabled(hostOS);
|
179
|
+
};
|
172
180
|
}]
|
173
181
|
);
|
@@ -14,13 +14,14 @@
|
|
14
14
|
* @requires deleteHostOnUnregister
|
15
15
|
* @requires ContentHostsHelper
|
16
16
|
* @requires simpleContentAccessEnabled
|
17
|
+
* @requires isManifestImported
|
17
18
|
*
|
18
19
|
* @description
|
19
20
|
* Provides the functionality for the content host details action pane.
|
20
21
|
*/
|
21
22
|
angular.module('Bastion.content-hosts').controller('ContentHostDetailsController',
|
22
|
-
['$scope', '$state', '$q', '$location', 'translate', 'Host', 'HostSubscription', 'Organization', 'CurrentOrganization', 'Notification', 'MenuExpander', 'ApiErrorHandler', 'deleteHostOnUnregister', 'ContentHostsHelper', 'simpleContentAccessEnabled',
|
23
|
-
function ($scope, $state, $q, $location, translate, Host, HostSubscription, Organization, CurrentOrganization, Notification, MenuExpander, ApiErrorHandler, deleteHostOnUnregister, ContentHostsHelper, simpleContentAccessEnabled) {
|
23
|
+
['$scope', '$state', '$q', '$location', 'translate', 'Host', 'HostSubscription', 'Organization', 'CurrentOrganization', 'Notification', 'MenuExpander', 'ApiErrorHandler', 'deleteHostOnUnregister', 'ContentHostsHelper', 'simpleContentAccessEnabled', 'isManifestImported',
|
24
|
+
function ($scope, $state, $q, $location, translate, Host, HostSubscription, Organization, CurrentOrganization, Notification, MenuExpander, ApiErrorHandler, deleteHostOnUnregister, ContentHostsHelper, simpleContentAccessEnabled, isManifestImported) {
|
24
25
|
$scope.menuExpander = MenuExpander;
|
25
26
|
|
26
27
|
$scope.getHostStatusIcon = ContentHostsHelper.getHostStatusIcon;
|
@@ -36,6 +37,7 @@ angular.module('Bastion.content-hosts').controller('ContentHostDetailsController
|
|
36
37
|
|
37
38
|
$scope.purposeAddonsCount = 0;
|
38
39
|
$scope.simpleContentAccessEnabled = simpleContentAccessEnabled;
|
40
|
+
$scope.isManifestImported = isManifestImported;
|
39
41
|
|
40
42
|
$scope.panel = {
|
41
43
|
error: false,
|
@@ -112,7 +112,7 @@
|
|
112
112
|
<span class="aligned-errata-count" errata-counts="host.content_facet_attributes.errata_counts"></span>
|
113
113
|
</a>
|
114
114
|
|
115
|
-
<span ng-if="host.
|
115
|
+
<span ng-if="isRpmEnabled(host.operatingsystem_name)">
|
116
116
|
<a ui-sref="content-host.packages.applicable({hostId: host.id})">
|
117
117
|
<span class="aligned-errata-count">
|
118
118
|
<span class="errata-count"
|
@@ -126,7 +126,7 @@
|
|
126
126
|
</span>
|
127
127
|
</a>
|
128
128
|
</span>
|
129
|
-
<span ng-if="host.
|
129
|
+
<span ng-if="isDebEnabled(host.operatingsystem_name)">
|
130
130
|
<a ui-sref="content-host.debs.applicable({hostId: host.id})">
|
131
131
|
<span class="aligned-errata-count">
|
132
132
|
<span class="errata-count"
|
data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js
CHANGED
@@ -35,6 +35,11 @@
|
|
35
35
|
resource: 'Repository',
|
36
36
|
params: {'content_type': 'yum'},
|
37
37
|
display: 'Yum Repositories'
|
38
|
+
}, {
|
39
|
+
state: 'deb-repositories',
|
40
|
+
resource: 'Repository',
|
41
|
+
params: {'content_type': 'deb'},
|
42
|
+
display: 'Deb Repositories'
|
38
43
|
}, {
|
39
44
|
state: 'errata',
|
40
45
|
resource: 'Erratum',
|
@@ -55,6 +60,11 @@
|
|
55
60
|
resource: 'ModuleStream',
|
56
61
|
display: translate('Module Streams'),
|
57
62
|
repositoryType: 'yum'
|
63
|
+
}, {
|
64
|
+
state: 'debs',
|
65
|
+
resource: 'Deb',
|
66
|
+
display: translate('Deb Packages'),
|
67
|
+
repositoryType: 'deb'
|
58
68
|
}
|
59
69
|
];
|
60
70
|
|
@@ -0,0 +1,26 @@
|
|
1
|
+
<div data-extend-template="layouts/partials/table.html">
|
2
|
+
<span data-block="search-filter">
|
3
|
+
<select class="form-control" ng-model="contentView" ng-change="contentViewSelected(contentView)" ng-options="contentView.name for (id, contentView) in contentViews"></select>
|
4
|
+
</span>
|
5
|
+
|
6
|
+
<span data-block="no-rows-message" ng-bind="getNoRowsMessage()"></span>
|
7
|
+
<span data-block="no-search-results-message" ng-bind="getZeroResultsMessage()"></span>
|
8
|
+
|
9
|
+
<table data-block="table" class="table table-striped table-bordered">
|
10
|
+
<thead>
|
11
|
+
<tr bst-table-head>
|
12
|
+
<th bst-table-column translate>Name</th>
|
13
|
+
<th bst-table-column translate>Product</th>
|
14
|
+
<th bst-table-column translate>Content View</th>
|
15
|
+
</tr>
|
16
|
+
</thead>
|
17
|
+
|
18
|
+
<tbody>
|
19
|
+
<tr bst-table-row ng-repeat="repository in table.rows">
|
20
|
+
<td bst-table-cell>{{ repository.name }}</td>
|
21
|
+
<td bst-table-cell>{{ repository.product.name }}</td>
|
22
|
+
<td bst-table-cell>{{ repository.content_view.name }}</td>
|
23
|
+
</tr>
|
24
|
+
</tbody>
|
25
|
+
</table>
|
26
|
+
</div>
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<div data-extend-template="layouts/partials/table.html">
|
2
|
+
<div data-block="search-filter">
|
3
|
+
<select class="form-control" ng-model="contentView" ng-change="contentViewSelected(contentView)" ng-options="contentView.name for (id, contentView) in contentViews"></select>
|
4
|
+
<select class="form-control" ng-model="repository" ng-change="repositorySelected(repository)" ng-options="repository.name for (id, repository) in repositories"></select>
|
5
|
+
</div>
|
6
|
+
|
7
|
+
<span data-block="no-rows-message" ng-bind="getNoRowsMessage()"></span>
|
8
|
+
<span data-block="no-search-results-message" ng-bind="getZeroResultsMessage()"></span>
|
9
|
+
|
10
|
+
<table data-block="table" class="table table-striped table-bordered">
|
11
|
+
<thead>
|
12
|
+
<tr bst-table-head>
|
13
|
+
<th bst-table-column translate>Name</th>
|
14
|
+
<th bst-table-column translate>Version</th>
|
15
|
+
<th bst-table-column translate>Architecture</th>
|
16
|
+
</tr>
|
17
|
+
</thead>
|
18
|
+
|
19
|
+
<tbody>
|
20
|
+
<tr bst-table-row ng-repeat="deb in table.rows">
|
21
|
+
<td bst-table-cell>{{ deb.name }}</td>
|
22
|
+
<td bst-table-cell>{{ deb.version }}</td>
|
23
|
+
<td bst-table-cell>{{ deb.architecture }}</td>
|
24
|
+
</tr>
|
25
|
+
</tbody>
|
26
|
+
</table>
|
27
|
+
</div>
|
@@ -27,6 +27,7 @@ angular.module('Bastion.environments').controller('EnvironmentsController',
|
|
27
27
|
|
28
28
|
var nutupane = new Nutupane(Environment, params);
|
29
29
|
$scope.table = nutupane.table;
|
30
|
+
$scope.loading = true;
|
30
31
|
|
31
32
|
PathsService.getActualPaths().then(function (data) {
|
32
33
|
$scope.library = data.library;
|
@@ -86,6 +86,28 @@ angular.module('Bastion.environments').config(['$stateProvider', function ($stat
|
|
86
86
|
parent: 'environment.details'
|
87
87
|
}
|
88
88
|
})
|
89
|
+
.state('environment.deb-repositories', {
|
90
|
+
url: '/deb-repositories?contentViewId',
|
91
|
+
reloadOnSearch: false,
|
92
|
+
permission: 'view_lifecycle_environments',
|
93
|
+
controller: 'EnvironmentContentController',
|
94
|
+
templateUrl: 'environments/details/views/environment-deb-repositories.html',
|
95
|
+
ncyBreadcrumb: {
|
96
|
+
label: '{{ "Deb Repositories" | translate }}',
|
97
|
+
parent: 'environment.details'
|
98
|
+
}
|
99
|
+
})
|
100
|
+
.state('environment.debs', {
|
101
|
+
url: '/debs?repositoryId&contentViewId',
|
102
|
+
reloadOnSearch: false,
|
103
|
+
permission: 'view_lifecycle_environments',
|
104
|
+
controller: 'EnvironmentContentController',
|
105
|
+
templateUrl: 'environments/details/views/environment-debs.html',
|
106
|
+
ncyBreadcrumb: {
|
107
|
+
label: '{{ "Deb Packages" | translate }}',
|
108
|
+
parent: 'environment.details'
|
109
|
+
}
|
110
|
+
})
|
89
111
|
.state('environment.module-streams', {
|
90
112
|
url: '/module-streams?repositoryId&contentViewId',
|
91
113
|
reloadOnSearch: false,
|
@@ -21,30 +21,36 @@
|
|
21
21
|
<section class="row">
|
22
22
|
<div class="col-sm-12">
|
23
23
|
<div ng-hide="denied('view_lifecycle_environments', library)">
|
24
|
-
<table class="table table-bordered info-blocks">
|
24
|
+
<table class="table table-bordered info-blocks" ng-hide="loading">
|
25
25
|
<tbody>
|
26
26
|
<tr>
|
27
27
|
<td class="info-block-head"><a ui-sref="environment.details({environmentId: library.id})" translate>Library</a></td>
|
28
28
|
<td class="info-block" translate>Content Views <div>{{ library.counts.content_views || 0 }}</div></td>
|
29
29
|
<td class="info-block" translate>Products <div>{{ library.counts.products || 0 }}</div></td>
|
30
|
-
<td class="info-block" ng-
|
30
|
+
<td class="info-block" ng-show="library.counts.yum_repositories > 0" translate>
|
31
31
|
Yum Repositories <div>{{ library.counts.yum_repositories || 0 }}</div>
|
32
32
|
</td>
|
33
|
-
<td class="info-block" ng-
|
33
|
+
<td class="info-block" ng-show="library.counts.ostree_repositories > 0" translate>
|
34
34
|
OSTree Repositories <div>{{ library.counts.ostree_repositories || 0 }}</div>
|
35
35
|
</td>
|
36
|
-
<td class="info-block" ng-
|
36
|
+
<td class="info-block" ng-show="library.counts.docker_repositories > 0" translate>
|
37
|
+
<td class="info-block" ng-show="library.counts.deb_repositories > 0" translate>
|
38
|
+
Deb Repositories <div>{{ library.counts.deb_repositories || 0 }}</div>
|
39
|
+
</td>
|
37
40
|
Docker Repositories <div>{{ library.counts.docker_repositories || 0 }}</div>
|
38
41
|
</td>
|
39
|
-
<td class="info-block" ng-
|
42
|
+
<td class="info-block" ng-show="library.counts.packages > 0" translate>
|
40
43
|
Packages <div>{{ library.counts.packages || 0 }}</div>
|
41
44
|
</td>
|
42
|
-
<td class="info-block" ng-
|
45
|
+
<td class="info-block" ng-show="library.counts.errata.total > 0" translate>
|
43
46
|
Errata <div>{{ library.counts.errata.total || 0 }}</div>
|
44
47
|
</td>
|
45
|
-
<td class="info-block" ng-
|
48
|
+
<td class="info-block" ng-show="library.counts.module_streams > 0" translate>
|
46
49
|
Module Streams <div>{{ library.counts.module_streams || 0 }}</div>
|
47
50
|
</td>
|
51
|
+
<td class="info-block" ng-show="library.counts.debs > 0" translate>
|
52
|
+
Deb Packages <div>{{ library.counts.debs || 0 }}</div>
|
53
|
+
</td>
|
48
54
|
</tr>
|
49
55
|
</tbody>
|
50
56
|
</table>
|