katello 3.18.0.rc2.1 → 4.0.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/stylesheets/katello/katello.scss +0 -72
- data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +0 -19
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +1 -3
- data/app/controllers/katello/api/v2/api_controller.rb +1 -2
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +2 -2
- data/app/controllers/katello/api/v2/content_credentials_controller.rb +24 -24
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +98 -0
- data/app/controllers/katello/api/v2/content_exports_controller.rb +88 -0
- data/app/controllers/katello/api/v2/content_imports_controller.rb +59 -0
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +56 -94
- data/app/controllers/katello/api/v2/content_views_controller.rb +2 -2
- data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -1
- data/app/controllers/katello/api/v2/host_packages_controller.rb +6 -6
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +2 -3
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +3 -2
- data/app/controllers/katello/api/v2/repositories_controller.rb +5 -19
- data/app/controllers/katello/api/v2/simple_content_access_controller.rb +34 -0
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +8 -4
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +1 -1
- data/app/helpers/katello/sync_management_helper.rb +0 -2
- data/app/lib/actions/candlepin/environment/create.rb +1 -1
- data/app/lib/actions/candlepin/environment/set_content.rb +1 -1
- data/app/lib/actions/katello/activation_key/create.rb +9 -11
- data/app/lib/actions/katello/agent/dispatch_history_presenter.rb +64 -0
- data/app/lib/actions/katello/agent_action.rb +107 -0
- data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +6 -2
- data/app/lib/actions/katello/bulk_agent_action.rb +21 -0
- data/app/lib/actions/katello/capsule_content/sync.rb +8 -8
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +16 -2
- data/app/lib/actions/katello/check_matching_content.rb +17 -0
- data/app/lib/actions/katello/content_view/environment_create.rb +6 -8
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +1 -1
- data/app/lib/actions/katello/content_view/publish.rb +2 -2
- data/app/lib/actions/katello/content_view_version/import.rb +2 -1
- data/app/lib/actions/katello/content_view_version/import_library.rb +17 -0
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +30 -10
- data/app/lib/actions/katello/host/erratum/applicable_errata_install.rb +1 -1
- data/app/lib/actions/katello/host/erratum/install.rb +8 -26
- data/app/lib/actions/katello/host/hypervisors_update.rb +4 -4
- data/app/lib/actions/katello/host/package/install.rb +8 -21
- data/app/lib/actions/katello/host/package/remove.rb +8 -20
- data/app/lib/actions/katello/host/package/update.rb +9 -22
- data/app/lib/actions/katello/host/package_group/install.rb +8 -21
- data/app/lib/actions/katello/host/package_group/remove.rb +8 -20
- data/app/lib/actions/katello/host/update_system_purpose.rb +1 -1
- data/app/lib/actions/katello/organization/create.rb +3 -5
- data/app/lib/actions/katello/organization/destroy.rb +1 -1
- data/app/lib/actions/katello/organization/manifest_delete.rb +3 -5
- data/app/lib/actions/katello/organization/manifest_import.rb +1 -1
- data/app/lib/actions/katello/organization/manifest_refresh.rb +1 -1
- data/app/lib/actions/katello/repository/check_matching_content.rb +3 -1
- data/app/lib/actions/katello/repository/clone_contents.rb +8 -11
- data/app/lib/actions/katello/repository/create.rb +0 -8
- data/app/lib/actions/katello/repository/filtered_index_content.rb +3 -0
- data/app/lib/actions/katello/repository/index_content.rb +1 -0
- data/app/lib/actions/katello/repository/multi_clone_contents.rb +9 -12
- data/app/lib/actions/katello/repository/update.rb +0 -8
- data/app/lib/actions/middleware/execute_if_contents_changed.rb +4 -1
- data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +24 -4
- data/app/lib/actions/pulp/consumer.rb +0 -11
- data/app/lib/actions/pulp/orchestration/repository/refresh_repos.rb +0 -6
- data/app/lib/actions/pulp3/capsule_content/refresh_distribution.rb +3 -3
- data/app/lib/actions/pulp3/content_migration.rb +10 -0
- data/app/lib/actions/pulp3/content_migration_presenter.rb +59 -0
- data/app/lib/actions/pulp3/content_view/delete_repository_references.rb +1 -1
- data/app/lib/actions/pulp3/content_view_version/export.rb +3 -2
- data/app/lib/actions/pulp3/import_migration.rb +6 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +2 -1
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +17 -13
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +60 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +0 -4
- data/app/lib/actions/pulp3/orchestration/repository/import_upload.rb +16 -3
- data/app/lib/actions/pulp3/orchestration/repository/refresh_repos.rb +1 -6
- data/app/lib/actions/pulp3/repository/copy_content.rb +1 -1
- data/app/lib/actions/pulp3/repository/delete.rb +1 -1
- data/app/lib/actions/pulp3/repository/save_version.rb +1 -1
- data/app/lib/actions/pulp3/repository/upload_tag.rb +18 -0
- data/app/lib/katello/agent/base_message.rb +38 -0
- data/app/lib/katello/agent/client_message_handler.rb +60 -0
- data/app/lib/katello/agent/connection.rb +24 -0
- data/app/lib/katello/agent/install_errata_message.rb +25 -0
- data/app/lib/katello/agent/install_package_group_message.rb +25 -0
- data/app/lib/katello/agent/install_package_message.rb +28 -0
- data/app/lib/katello/agent/remove_package_group_message.rb +25 -0
- data/app/lib/katello/agent/remove_package_message.rb +28 -0
- data/app/lib/katello/agent/update_package_message.rb +25 -0
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +8 -0
- data/app/lib/katello/event_daemon/monitor.rb +53 -0
- data/app/lib/katello/event_daemon/runner.rb +99 -0
- data/app/lib/katello/event_daemon/services/agent_event_receiver.rb +62 -0
- data/app/lib/katello/logging.rb +32 -0
- data/app/lib/katello/messaging/connection.rb +1 -7
- data/app/lib/katello/messaging/received_message.rb +1 -1
- data/app/lib/katello/qpid/connection.rb +130 -0
- data/app/lib/katello/validators/content_view_puppet_module_validator.rb +1 -1
- data/app/models/katello/activation_key.rb +2 -2
- data/app/models/katello/agent/dispatch_history.rb +17 -0
- data/app/models/katello/authorization/content_view_version.rb +25 -2
- data/app/models/katello/authorization/content_view_version_export_history.rb +1 -1
- data/app/models/katello/authorization/organization.rb +8 -0
- data/app/models/katello/candlepin/repository_mapper.rb +1 -1
- data/app/models/katello/concerns/host_managed_extensions.rb +3 -0
- data/app/models/katello/concerns/operatingsystem_extensions.rb +2 -0
- data/app/models/katello/concerns/organization_extensions.rb +2 -2
- data/app/models/katello/concerns/pulp_database_unit.rb +7 -0
- data/app/models/katello/concerns/redhat_extensions.rb +2 -2
- data/app/models/katello/concerns/smart_proxy_extensions.rb +31 -5
- data/app/models/katello/content_migration_progress.rb +4 -0
- data/app/models/katello/content_view.rb +10 -1
- data/app/models/katello/content_view_environment.rb +2 -2
- data/app/models/katello/content_view_history.rb +2 -1
- data/app/models/katello/content_view_package_filter.rb +1 -1
- data/app/models/katello/content_view_puppet_environment.rb +2 -2
- data/app/models/katello/content_view_version.rb +2 -1
- data/app/models/katello/content_view_version_export_history.rb +26 -1
- data/app/models/katello/erratum.rb +3 -1
- data/app/models/katello/events/delete_host_agent_queue.rb +19 -0
- data/app/models/katello/glue/candlepin/pool.rb +2 -0
- data/app/models/katello/glue/pulp/repo.rb +0 -6
- data/app/models/katello/glue/pulp/repos.rb +1 -22
- data/app/models/katello/host/subscription_facet.rb +4 -0
- data/app/models/katello/ping.rb +12 -4
- data/app/models/katello/pool.rb +5 -0
- data/app/models/katello/product.rb +3 -3
- data/app/models/katello/repository.rb +10 -3
- data/app/models/katello/subscription_status.rb +3 -2
- data/app/models/setting/content.rb +0 -2
- data/app/presenters/katello/host_subscription_presenter.rb +3 -4
- data/app/presenters/katello/host_subscriptions_presenter.rb +24 -0
- data/app/services/katello/agent/dispatcher.rb +66 -0
- data/app/services/katello/applicability/applicable_content_helper.rb +44 -15
- data/app/services/katello/candlepin_event_listener.rb +12 -19
- data/app/services/katello/event_monitor/poller_thread.rb +3 -11
- data/app/services/katello/pulp/smart_proxy_repository.rb +0 -15
- data/app/services/katello/pulp3/api/docker.rb +4 -0
- data/app/services/katello/pulp3/content_view_version/export.rb +63 -5
- data/app/services/katello/pulp3/content_view_version/import.rb +40 -0
- data/app/services/katello/pulp3/content_view_version/import_export_common.rb +0 -16
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +26 -49
- data/app/services/katello/pulp3/docker_manifest.rb +1 -0
- data/app/services/katello/pulp3/docker_tag.rb +1 -0
- data/app/services/katello/pulp3/migration.rb +44 -9
- data/app/services/katello/pulp3/repository.rb +13 -4
- data/app/services/katello/pulp3/repository/docker.rb +5 -0
- data/app/services/katello/pulp3/repository/yum.rb +15 -9
- data/app/services/katello/pulp3/task.rb +4 -0
- data/app/services/katello/pulp3/task_group.rb +4 -0
- data/app/services/katello/registration_manager.rb +10 -0
- data/app/services/katello/repository_type.rb +1 -1
- data/app/views/foreman/smart_proxies/_content_tab.html.erb +4 -47
- data/app/views/foreman/smart_proxies/show.html.erb +1 -1
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +22 -25
- data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +1 -0
- data/app/views/katello/api/v2/content_views/show.json.rabl +6 -0
- data/app/views/katello/api/v2/organizations/show.json.rabl +7 -9
- data/app/views/katello/layouts/react.html.erb +3 -2
- data/app/views/katello/sync_management/_products.html.erb +1 -1
- data/app/views/overrides/activation_keys/_host_tab_pane.html.erb +1 -5
- data/app/views/overrides/organizations/_edit_override.html.erb +1 -4
- data/app/views/overrides/smart_proxies/_environment_tab.html.erb +1 -1
- data/app/views/overrides/smart_proxies/_environment_tab_pane.html.erb +1 -1
- data/config/katello.yaml.example +0 -3
- data/config/routes/api/v2.rb +31 -13
- data/db/migrate/20150930183738_migrate_content_hosts.rb +1 -1
- data/db/migrate/20191204214919_add_content_view_version_counts.rb +0 -1
- data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +5 -2
- data/db/migrate/20201119211133_pulp3_migration_progress.rb +9 -0
- data/db/migrate/20210119162528_delete_puppet_and_ostree_repos.rb +56 -0
- data/db/migrate/20210122200618_create_katello_agent_dispatch_history.rb +11 -0
- data/db/migrate/20210125161911_delete_erratum_install_batch_size_setting.rb +5 -0
- data/db/migrate/20210128231228_add_type_and_from_cvv_to_cvv_export_history.rb +14 -0
- data/db/migrate/20210201163238_migrate_background_download_policy_to_migrate.rb +7 -0
- data/db/migrate/20210208213920_add_available_module_stream_context.rb +8 -0
- data/db/seeds.d/104-proxy.rb +1 -1
- data/db/seeds.d/111-upgrade_tasks.rb +2 -1
- data/engines/bastion/app/assets/javascripts/bastion/auth/authorization.service.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/views/katello-agent-notice.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +35 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-os-client.directive.js +17 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +2 -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/content-hosts/views/register-client.html +12 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-deb-client.html +38 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-oracle-client.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-sles-client.html +28 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register.html +14 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +8 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +9 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +78 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +17 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +17 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +1292 -1170
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +17 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +858 -807
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +18 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +17 -24
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +17 -18
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +986 -971
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +19 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +9 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/download-policy.service.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.controller.js +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscription-start-date.directive.js +21 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscription-type.directive.js +16 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/subscription-start-date.html +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/subscription-type.html +18 -0
- data/lib/katello/engine.rb +12 -6
- data/lib/katello/middleware/event_daemon.rb +1 -1
- data/lib/katello/permission_creator.rb +26 -5
- data/lib/katello/plugin.rb +3 -2
- data/lib/katello/tasks/delete_orphaned_content.rake +1 -3
- data/lib/katello/tasks/jenkins.rake +1 -1
- data/lib/katello/tasks/pulp3_content_switchover.rake +1 -1
- data/lib/katello/tasks/pulp3_migration.rake +18 -6
- data/lib/katello/tasks/pulp3_migration_abort.rake +7 -2
- data/lib/katello/tasks/pulp3_migration_stats.rake +28 -8
- data/lib/katello/tasks/pulp3_post_migration_check.rake +1 -3
- data/lib/katello/tasks/receptor/extract_orgs.rake +1 -1
- data/lib/katello/tasks/reimport.rake +1 -1
- data/lib/katello/tasks/repository.rake +3 -5
- data/lib/katello/tasks/reset.rake +0 -15
- data/lib/katello/tasks/upgrades/4.0/remove_ostree_puppet_content.rake +16 -0
- data/lib/katello/version.rb +1 -1
- data/lib/proxy_api/container_gateway.rb +21 -0
- data/locale/action_names.rb +51 -51
- data/locale/bn/katello.edit.po +8538 -0
- data/locale/bn/katello.po +136 -51
- data/locale/bn/katello.po.time_stamp +0 -0
- data/locale/cs/katello.edit.po +8440 -0
- data/locale/cs/katello.po +136 -49
- data/locale/cs/katello.po.time_stamp +0 -0
- data/locale/de/katello.edit.po +8344 -0
- data/locale/de/katello.po +136 -48
- data/locale/de/katello.po.time_stamp +0 -0
- data/locale/en/katello.edit.po +8161 -0
- data/locale/en/katello.po +136 -48
- data/locale/en/katello.po.time_stamp +0 -0
- data/locale/es/katello.edit.po +8306 -0
- data/locale/es/katello.po +136 -48
- data/locale/es/katello.po.time_stamp +0 -0
- data/locale/fr/katello.edit.po +8356 -0
- data/locale/fr/katello.po +136 -48
- data/locale/fr/katello.po.time_stamp +0 -0
- data/locale/gu/katello.edit.po +8540 -0
- data/locale/gu/katello.po +136 -51
- data/locale/gu/katello.po.time_stamp +0 -0
- data/locale/hi/katello.edit.po +8537 -0
- data/locale/hi/katello.po +136 -51
- data/locale/hi/katello.po.time_stamp +0 -0
- data/locale/it/katello.edit.po +8293 -0
- data/locale/it/katello.po +136 -48
- data/locale/it/katello.po.time_stamp +0 -0
- data/locale/ja/katello.edit.po +8322 -0
- data/locale/ja/katello.po +136 -48
- data/locale/ja/katello.po.time_stamp +0 -0
- data/locale/katello.pot +941 -767
- data/locale/kn/katello.edit.po +8538 -0
- data/locale/kn/katello.po +136 -51
- data/locale/kn/katello.po.time_stamp +0 -0
- data/locale/ko/katello.edit.po +8289 -0
- data/locale/ko/katello.po +136 -48
- data/locale/ko/katello.po.time_stamp +0 -0
- data/locale/mr/katello.edit.po +8502 -0
- data/locale/mr/katello.po +136 -51
- data/locale/mr/katello.po.time_stamp +0 -0
- data/locale/or/katello.edit.po +8538 -0
- data/locale/or/katello.po +136 -51
- data/locale/or/katello.po.time_stamp +0 -0
- data/locale/pa/katello.edit.po +8524 -0
- data/locale/pa/katello.po +136 -51
- data/locale/pa/katello.po.time_stamp +0 -0
- data/locale/pt/katello.edit.po +8255 -0
- data/locale/pt/katello.po +136 -51
- data/locale/pt/katello.po.time_stamp +0 -0
- data/locale/pt_BR/katello.edit.po +8289 -0
- data/locale/pt_BR/katello.po +136 -48
- data/locale/pt_BR/katello.po.time_stamp +0 -0
- data/locale/ru/katello.edit.po +8309 -0
- data/locale/ru/katello.po +136 -48
- data/locale/ru/katello.po.time_stamp +0 -0
- data/locale/ta/katello.edit.po +8536 -0
- data/locale/ta/katello.po +136 -51
- data/locale/ta/katello.po.time_stamp +0 -0
- data/locale/te/katello.edit.po +8536 -0
- data/locale/te/katello.po +136 -51
- data/locale/te/katello.po.time_stamp +0 -0
- data/locale/zh_CN/katello.edit.po +8288 -0
- data/locale/zh_CN/katello.po +136 -48
- data/locale/zh_CN/katello.po.time_stamp +0 -0
- data/locale/zh_TW/katello.edit.po +8420 -0
- data/locale/zh_TW/katello.po +136 -48
- data/locale/zh_TW/katello.po.time_stamp +0 -0
- data/package.json +1 -1
- data/webpack/__mocks__/foremanReact/Root/Context/ForemanContext.js +0 -1
- data/webpack/__mocks__/foremanReact/components/Pagination/PaginationHooks.js +2 -0
- data/webpack/__mocks__/foremanReact/components/common/dates/LongDateTime.js +5 -0
- data/webpack/{scenes/ContentViews/Details/Repositories → components/SelectableDropdown}/SelectableDropdown.js +20 -3
- data/webpack/components/SelectableDropdown/__tests__/SelectableDropdown.test.js +45 -0
- data/webpack/components/SelectableDropdown/index.js +3 -0
- data/webpack/components/Table/TableWrapper.js +2 -1
- data/webpack/components/Table/helpers.js +14 -0
- data/webpack/components/TypeAhead/TypeAhead.js +2 -1
- data/webpack/components/TypeAhead/pf3Search/TypeAheadSearch.js +2 -1
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +0 -1
- data/webpack/containers/Application/overrides.scss +6 -0
- data/webpack/index.js +6 -0
- data/webpack/redux/actions/RedHatRepositories/helpers.js +5 -5
- data/webpack/scenes/ContentViews/ContentViewsActions.js +31 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +5 -1
- data/webpack/scenes/ContentViews/Copy/ContentViewCopySelectors.js +16 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +77 -0
- data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +44 -0
- data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +42 -0
- data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +39 -0
- data/webpack/scenes/ContentViews/Copy/index.js +4 -0
- data/webpack/scenes/ContentViews/Create/ContentViewCreateSelectors.js +16 -0
- data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +58 -0
- data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +175 -0
- data/webpack/scenes/ContentViews/Create/CreateContentViewModal.js +27 -0
- data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +42 -0
- data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +92 -0
- data/webpack/scenes/ContentViews/Create/index.js +4 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +16 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +20 -1
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +17 -7
- data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +19 -13
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +40 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +124 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.fixtures.json +134 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +92 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +44 -25
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +17 -7
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +24 -0
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +53 -3
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +4 -3
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +41 -0
- data/webpack/scenes/ContentViews/helpers.js +13 -0
- data/webpack/scenes/SmartProxy/Content.js +17 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +11 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentConstants.js +3 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentSelectors.js +16 -0
- data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +152 -0
- data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentResult.fixtures.json +140 -0
- data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentTest.js +38 -0
- data/webpack/scenes/SmartProxy/index.js +4 -0
- data/webpack/scenes/Subscriptions/Manifest/ManifestActions.js +3 -3
- data/webpack/scenes/Subscriptions/Manifest/__tests__/ManifestActions.test.js +2 -2
- data/webpack/scenes/Subscriptions/Manifest/__tests__/SimpleContentAccess.test.js +2 -2
- data/webpack/test-utils/react-testing-lib-wrapper.js +5 -2
- data/webpack/utils/helpers.js +3 -0
- metadata +160 -40
- data/app/controllers/katello/api/v2/gpg_keys_controller.rb +0 -114
- data/app/lib/actions/pulp/consumer/abstract_content_action.rb +0 -71
- data/app/lib/actions/pulp/consumer/content_install.rb +0 -43
- data/app/lib/actions/pulp/consumer/content_uninstall.rb +0 -26
- data/app/lib/actions/pulp/consumer/content_update.rb +0 -32
- data/app/overrides/disable_turbolinks_on_proxies_index.rb +0 -5
- data/app/services/katello/event_daemon.rb +0 -135
- data/app/services/katello/pulp/content_counts_calculator.rb +0 -60
- data/db/functions/empty_v01.sql +0 -7
- data/db/functions/evr_trigger_v01.sql +0 -9
- data/db/functions/isalpha_v01.sql +0 -11
- data/db/functions/isalphanum_v01.sql +0 -12
- data/db/functions/isdigit_v01.sql +0 -10
- data/db/functions/rpmver_array_v01.sql +0 -60
- data/lib/katello/tasks/common.rake +0 -7
- data/lib/katello/tasks/reports.rake +0 -4
- data/lib/katello/tasks/upgrades/3.10/update_gpg_key_urls.rake +0 -32
- data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.scss +0 -5
- data/webpack/scenes/ContentViews/Table/actionResolver.js +0 -28
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 336a4ba95971459cc367612026947e16d536f4002aa4edbbf1ef2f5c75fc8d79
|
4
|
+
data.tar.gz: bf25590898a3e0485037acb025c7d654c3a98dce1dfb2830f85db8923eb78bdd
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 19244df2d07a33451ae52bf787b7cd5d173db7647a90b88535077e27266a14814315d7b31f124c66cad14a41eb27bdbb8e78a2fe06b900b3f931f833b89b89c6
|
7
|
+
data.tar.gz: 753d1c2598e96cdf3ce57c79abe0f997733ea296c29f5ccedafd0502530046a727be430ae87b3d4b3030415f66c9d7801f8222dca6e388c576ca6ad46766cd9b
|
@@ -163,78 +163,6 @@ input:focus {
|
|
163
163
|
@extend .status_exclamation_icon;
|
164
164
|
}
|
165
165
|
|
166
|
-
/* BUTTONS */
|
167
|
-
input[type='submit'], button, .button {
|
168
|
-
font-size: 10px;
|
169
|
-
display: inline-block;
|
170
|
-
vertical-align: bottom;
|
171
|
-
background: -moz-linear-gradient(top, #f9f9f9, #f0f0f0, #e5e5e5, #e9e9e9);
|
172
|
-
background: -webkit-gradient(linear, left top, left bottom, from(#f9f9f9), color-stop(0.9, #e5e5e5), to(#e9e9e9));
|
173
|
-
box-shadow: none;
|
174
|
-
border: 1px solid darken($stroke_color, 20%);
|
175
|
-
color: #221e1f;
|
176
|
-
cursor: pointer;
|
177
|
-
padding: 4px 8px;
|
178
|
-
border-radius: 5px;
|
179
|
-
text-shadow: 0 1px 0 rgba($white_color, 1);
|
180
|
-
min-height: 14px;
|
181
|
-
.nomargin {
|
182
|
-
margin: 0;
|
183
|
-
}
|
184
|
-
&:hover {
|
185
|
-
background: -moz-linear-gradient(top, $white_color, $white_color, #cfcfcf);
|
186
|
-
background: -webkit-gradient(linear, left top, left bottom, from($white_color), color-stop(0.6, $white_color), to(#cfcfcf));
|
187
|
-
box-shadow: 0 1px 2px rgba(0,0,0,0.5);
|
188
|
-
text-decoration: none;
|
189
|
-
color: black;
|
190
|
-
}
|
191
|
-
&:active {
|
192
|
-
background: -moz-linear-gradient(top, #c2c3c0, #e4e5e4);
|
193
|
-
background: -webkit-gradient(linear, left top, left bottom, from(#c2c3c0), to(#e4e5e4));
|
194
|
-
box-shadow: none;
|
195
|
-
text-decoration: none;
|
196
|
-
}
|
197
|
-
&:focus {
|
198
|
-
text-decoration: none;
|
199
|
-
color: #000;
|
200
|
-
border-width: 2px;
|
201
|
-
}
|
202
|
-
&.dialogbutton {
|
203
|
-
float: right;
|
204
|
-
margin-left: 3px;
|
205
|
-
margin: 40px 4px 4px;
|
206
|
-
}
|
207
|
-
&.formbutton {
|
208
|
-
display: inline-block;
|
209
|
-
margin-left: 3px;
|
210
|
-
margin: 40px 4px 4px;
|
211
|
-
}
|
212
|
-
&.actionlink {
|
213
|
-
margin: 40px 0 0;
|
214
|
-
}
|
215
|
-
&.disabled, &[disabled] {
|
216
|
-
cursor: default;
|
217
|
-
background: transparent;
|
218
|
-
opacity: 0.4;
|
219
|
-
|
220
|
-
&:hover {
|
221
|
-
background: transparent;
|
222
|
-
box-shadow: none;
|
223
|
-
}
|
224
|
-
}
|
225
|
-
&.iconbutton {
|
226
|
-
display: inline-block;
|
227
|
-
}
|
228
|
-
&.tiny {
|
229
|
-
padding: 4px;
|
230
|
-
margin: 0;
|
231
|
-
&:active, &:focus {
|
232
|
-
margin: 0;
|
233
|
-
padding: 3px;
|
234
|
-
}
|
235
|
-
}
|
236
|
-
}
|
237
|
-
|
238
166
|
table {
|
239
167
|
border-collapse: collapse;
|
240
168
|
border: 1px solid $stroke_color;
|
@@ -4,8 +4,6 @@ module Katello
|
|
4
4
|
include ForemanTasks::Triggers
|
5
5
|
include AbstractController::Callbacks
|
6
6
|
|
7
|
-
before_action :deprecated, only: :deb_package_profile
|
8
|
-
|
9
7
|
skip_before_action :authorize, :only => [:upload_package_profile, :upload_profiles, :deb_package_profile]
|
10
8
|
before_action :find_host, :only => [:upload_package_profile, :upload_profiles, :deb_package_profile]
|
11
9
|
before_action :authorize_client_or_user, :only => [:upload_package_profile, :upload_profiles, :deb_package_profile]
|
@@ -31,19 +29,6 @@ module Katello
|
|
31
29
|
render :json => Resources::Candlepin::Consumer.get(@host.subscription_facet.uuid)
|
32
30
|
end
|
33
31
|
|
34
|
-
api :PUT, "/systems/:id/deb_package_profile", N_("Update installed deb packages")
|
35
|
-
param :deb_package_profile, Hash, :required => true do
|
36
|
-
param :deb_packages, Array, :required => true do
|
37
|
-
param :name, String, :required => true
|
38
|
-
param :architecture, String, :required => true
|
39
|
-
param :version, String, :required => true
|
40
|
-
end
|
41
|
-
end
|
42
|
-
param :id, String, :desc => N_("UUID of the system"), :required => true
|
43
|
-
def deb_package_profile
|
44
|
-
upload_profiles
|
45
|
-
end
|
46
|
-
|
47
32
|
def find_host(uuid = nil)
|
48
33
|
params = request.path_parameters
|
49
34
|
uuid ||= params[:id]
|
@@ -65,9 +50,5 @@ module Katello
|
|
65
50
|
authorized = (User.current.uuid == @host.subscription_facet.uuid) if @host && User.consumer?
|
66
51
|
authorized
|
67
52
|
end
|
68
|
-
|
69
|
-
def deprecated
|
70
|
-
::Foreman::Deprecation.api_deprecation_warning("it will be removed in Katello 4.0. Please use /consumers/:id/profiles instead.")
|
71
|
-
end
|
72
53
|
end
|
73
54
|
end
|
@@ -41,8 +41,6 @@ module Katello
|
|
41
41
|
body_json['displayMessage'] = body_json['message']
|
42
42
|
end
|
43
43
|
response.body = body_json.to_s
|
44
|
-
|
45
|
-
# rubocop:disable Lint/SuppressedException
|
46
44
|
rescue JSON::ParserError
|
47
45
|
# Not a json response, leave as-is
|
48
46
|
end
|
@@ -370,7 +368,7 @@ module Katello
|
|
370
368
|
|
371
369
|
if (ak_names = params[:activation_keys])
|
372
370
|
fail HttpErrors::NotFound, _("Organization not found") if organization.nil?
|
373
|
-
ak_names = ak_names.split(",")
|
371
|
+
ak_names = ak_names.split(",").uniq.compact
|
374
372
|
activation_keys = ak_names.map do |ak_name|
|
375
373
|
activation_key = organization.activation_keys.find_by(:name => ak_name)
|
376
374
|
fail HttpErrors::NotFound, _("Couldn't find activation key '%s'") % ak_name unless activation_key
|
@@ -39,8 +39,7 @@ module Katello
|
|
39
39
|
end
|
40
40
|
|
41
41
|
def deprecate_katello_agent
|
42
|
-
::Foreman::Deprecation.api_deprecation_warning("
|
43
|
-
"You may consider switching to Remote Execution.")
|
42
|
+
::Foreman::Deprecation.api_deprecation_warning("Katello-agent is deprecated and will be removed in a future release.")
|
44
43
|
end
|
45
44
|
|
46
45
|
def full_result_response(collection)
|
@@ -93,14 +93,14 @@ module Katello
|
|
93
93
|
|
94
94
|
def find_editable_capsule
|
95
95
|
@capsule = SmartProxy.unscoped.authorized(:manage_capsule_content).find(params[:id])
|
96
|
-
unless @capsule&.
|
96
|
+
unless @capsule&.pulp_mirror?
|
97
97
|
fail _("This request may only be performed on a Smart proxy that has the Pulp Node feature.")
|
98
98
|
end
|
99
99
|
end
|
100
100
|
|
101
101
|
def find_capsule
|
102
102
|
@capsule = SmartProxy.unscoped.authorized(:view_capsule_content).find(params[:id])
|
103
|
-
unless @capsule&.
|
103
|
+
unless @capsule&.pulp_mirror?
|
104
104
|
fail _("This request may only be performed on a Smart proxy that has the Pulp Node feature.")
|
105
105
|
end
|
106
106
|
end
|
@@ -10,9 +10,9 @@ module Katello
|
|
10
10
|
end
|
11
11
|
|
12
12
|
def_param_group :content_credential do
|
13
|
-
param :name, :identifier, :action_aware => true, :required => true, :desc => N_(
|
14
|
-
param :content_type, String, :action_aware => true, :required => true, :desc => N_(
|
15
|
-
param :content, String, :action_aware => true, :required => true, :desc => N_(
|
13
|
+
param :name, :identifier, :action_aware => true, :required => true, :desc => N_('Name of the Content Credential')
|
14
|
+
param :content_type, String, :action_aware => true, :required => true, :desc => N_('Type of content: "cert", "gpg_key"')
|
15
|
+
param :content, String, :action_aware => true, :required => true, :desc => N_('Public key block in DER encoding or certificate content')
|
16
16
|
end
|
17
17
|
|
18
18
|
resource_description do
|
@@ -22,13 +22,13 @@ module Katello
|
|
22
22
|
Content Credentials are used to store credentials like GPG Keys and Certificates for the authentication
|
23
23
|
to Products / Repositories.
|
24
24
|
DESC
|
25
|
-
api_version
|
25
|
+
api_version 'v2'
|
26
26
|
end
|
27
27
|
|
28
|
-
api :GET, "/content_credentials", N_(
|
29
|
-
param :organization_id, :number, :desc => N_(
|
30
|
-
param :name, String, :desc => N_(
|
31
|
-
param :content_type, String, :desc => N_(
|
28
|
+
api :GET, "/content_credentials", N_('List Content Credentials')
|
29
|
+
param :organization_id, :number, :desc => N_('Organization identifier'), :required => true
|
30
|
+
param :name, String, :desc => N_('Name of the Content Credential'), :required => false
|
31
|
+
param :content_type, String, :desc => N_('Type of content'), :required => false
|
32
32
|
param_group :search, Api::V2::ApiController
|
33
33
|
def index
|
34
34
|
respond(:collection => scoped_search(index_relation.distinct, :name, :asc))
|
@@ -41,15 +41,15 @@ module Katello
|
|
41
41
|
query
|
42
42
|
end
|
43
43
|
|
44
|
-
api :POST, "/content_credentials", N_(
|
45
|
-
param :organization_id, :number, :desc => N_(
|
44
|
+
api :POST, "/content_credentials", N_('Create a Content Credential')
|
45
|
+
param :organization_id, :number, :desc => N_('Organization identifier'), :required => true
|
46
46
|
param_group :content_credential, :as => :create
|
47
47
|
def create
|
48
48
|
filepath = params.try(:[], :file_path).try(:path)
|
49
49
|
|
50
50
|
content = nil
|
51
51
|
if filepath
|
52
|
-
content = File.open(filepath,
|
52
|
+
content = File.open(filepath, 'rb') { |file| file.read }
|
53
53
|
else
|
54
54
|
content = params[:content]
|
55
55
|
end
|
@@ -58,45 +58,45 @@ module Katello
|
|
58
58
|
respond_for_create(:resource => content_credential)
|
59
59
|
end
|
60
60
|
|
61
|
-
api :GET, "/content_credentials/:id", N_(
|
62
|
-
param :id, :number, :desc => N_(
|
61
|
+
api :GET, "/content_credentials/:id", N_('Show a Content Credential')
|
62
|
+
param :id, :number, :desc => N_('Content Credential numeric identifier'), :required => true
|
63
63
|
def show
|
64
64
|
respond_for_show(:resource => @content_credential)
|
65
65
|
end
|
66
66
|
|
67
|
-
api :PUT, "/content_credentials/:id", N_(
|
68
|
-
param :id, :number, :desc => N_(
|
67
|
+
api :PUT, "/content_credentials/:id", N_('Update a Content Credential')
|
68
|
+
param :id, :number, :desc => N_('Content Credential ID'), :required => true
|
69
69
|
param_group :content_credential
|
70
70
|
def update
|
71
71
|
sync_task(::Actions::Katello::GpgKey::Update, @content_credential, content_credential_params.to_h)
|
72
72
|
respond_for_show(:resource => @content_credential)
|
73
73
|
end
|
74
74
|
|
75
|
-
api :DELETE, "/content_credentials/:id", N_(
|
76
|
-
param :id, :number, :desc => N_(
|
75
|
+
api :DELETE, "/content_credentials/:id", N_('Destroy a Content Credential')
|
76
|
+
param :id, :number, :desc => N_('Content Credential ID'), :required => true
|
77
77
|
def destroy
|
78
78
|
@content_credential.destroy
|
79
79
|
respond_for_destroy
|
80
80
|
end
|
81
81
|
|
82
|
-
api :GET, "/content_credentials/:id/content", N_(
|
82
|
+
api :GET, "/content_credentials/:id/content", N_('Return the content of a Content Credential, used directly by yum')
|
83
83
|
param :id, :number, :required => true
|
84
84
|
def content
|
85
85
|
render(:plain => @content_credential.content, :layout => false)
|
86
86
|
end
|
87
87
|
|
88
|
-
api :POST, "/content_credentials/:id/content", N_(
|
89
|
-
param :id, :number, :desc => N_(
|
90
|
-
param :content, File, :desc => N_(
|
88
|
+
api :POST, "/content_credentials/:id/content", N_('Upload Content Credential contents')
|
89
|
+
param :id, :number, :desc => N_('Content Credential ID'), :required => true
|
90
|
+
param :content, File, :desc => N_('File contents'), :required => true
|
91
91
|
def set_content
|
92
92
|
filepath = params.try(:[], :content).try(:path)
|
93
93
|
|
94
94
|
if filepath
|
95
|
-
content = File.open(filepath,
|
95
|
+
content = File.open(filepath, 'rb') { |file| file.read }
|
96
96
|
@content_credential.update!(:content => content)
|
97
|
-
render :json => {:status =>
|
97
|
+
render :json => {:status => 'success'}
|
98
98
|
else
|
99
|
-
fail HttpErrors::BadRequest, _(
|
99
|
+
fail HttpErrors::BadRequest, _('No file uploaded')
|
100
100
|
end
|
101
101
|
end
|
102
102
|
|
@@ -0,0 +1,98 @@
|
|
1
|
+
module Katello
|
2
|
+
class Api::V2::ContentExportIncrementalsController < Api::V2::ApiController
|
3
|
+
before_action :fail_if_not_pulp3, :only => [:version, :library]
|
4
|
+
before_action :find_exportable_organization, :only => [:library]
|
5
|
+
before_action :find_exportable_content_view_version, :only => [:version]
|
6
|
+
before_action :find_library_export_view, :only => [:library]
|
7
|
+
before_action :find_history, :only => [:version, :library]
|
8
|
+
|
9
|
+
api :POST, "/content_export_incrementals/version", N_("Performs an incremental-export of a content view version.")
|
10
|
+
param :id, :number, :desc => N_("Content view version identifier"), :required => true
|
11
|
+
param :destination_server, String, :desc => N_("Destination Server name"), :required => false
|
12
|
+
param :chunk_size_mb, :number, :desc => N_("Split the exported content into archives "\
|
13
|
+
"no greater than the specified size in megabytes."), :required => false
|
14
|
+
param :from_history_id, :number, :desc => N_("Export history identifier used for incremental export. "\
|
15
|
+
"If not provided the most recent export history will be used."), :required => false
|
16
|
+
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this version"\
|
17
|
+
" are unexportable. False by default."), :required => false
|
18
|
+
def version
|
19
|
+
tasks = async_task(::Actions::Pulp3::Orchestration::ContentViewVersion::Export,
|
20
|
+
content_view_version: @version,
|
21
|
+
destination_server: params[:destination_server],
|
22
|
+
chunk_size: params[:chunk_size_mb],
|
23
|
+
from_history: @history,
|
24
|
+
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
25
|
+
|
26
|
+
respond_for_async :resource => tasks
|
27
|
+
end
|
28
|
+
|
29
|
+
api :POST, "/content_export_incrementals/library", N_("Performs an incremental-export of the repositories in library.")
|
30
|
+
param :organization_id, :number, :desc => N_("Organization identifier"), :required => true
|
31
|
+
param :destination_server, String, :desc => N_("Destination Server name"), :required => false
|
32
|
+
param :chunk_size_mb, :number, :desc => N_("Split the exported content into archives "\
|
33
|
+
"no greater than the specified size in megabytes."), :required => false
|
34
|
+
param :from_history_id, :number, :desc => N_("Export history identifier used for incremental export. "\
|
35
|
+
"If not provided the most recent export history will be used."), :required => false
|
36
|
+
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this organization"\
|
37
|
+
" are unexportable. False by default."), :required => false
|
38
|
+
def library
|
39
|
+
tasks = async_task(::Actions::Pulp3::Orchestration::ContentViewVersion::ExportLibrary,
|
40
|
+
@organization,
|
41
|
+
destination_server: params[:destination_server],
|
42
|
+
chunk_size: params[:chunk_size_mb],
|
43
|
+
from_history: @history,
|
44
|
+
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
45
|
+
respond_for_async :resource => tasks
|
46
|
+
end
|
47
|
+
|
48
|
+
private
|
49
|
+
|
50
|
+
def find_exportable_content_view_version
|
51
|
+
@version = ContentViewVersion.exportable.find_by_id(params[:id])
|
52
|
+
throw_resource_not_found(name: 'content view version', id: params[:id]) if @version.blank?
|
53
|
+
@view = @version.content_view
|
54
|
+
end
|
55
|
+
|
56
|
+
def find_library_export_view
|
57
|
+
@view = ::Katello::Pulp3::ContentViewVersion::Export.find_library_export_view(destination_server: params[:destination_server],
|
58
|
+
organization: @organization,
|
59
|
+
create_by_default: false)
|
60
|
+
if @view.blank?
|
61
|
+
msg = _("Unable to incrementally export. Do a Full Export on the library content "\
|
62
|
+
"before updating from the latest increment.")
|
63
|
+
fail HttpErrors::BadRequest, msg
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
def find_history
|
68
|
+
if params[:from_history_id].present?
|
69
|
+
@history = ::Katello::ContentViewVersionExportHistory.find(params[:from_history_id])
|
70
|
+
if @history.blank?
|
71
|
+
throw_resource_not_found(name: 'export history',
|
72
|
+
id: params[:from_history_id])
|
73
|
+
end
|
74
|
+
else
|
75
|
+
@history = ::Katello::ContentViewVersionExportHistory.
|
76
|
+
latest(@view,
|
77
|
+
destination_server: params[:destination_server])
|
78
|
+
if @history.blank?
|
79
|
+
msg = _("No existing export history was found to perform an incremental export. A full export must be performed")
|
80
|
+
fail HttpErrors::NotFound, msg
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
def find_exportable_organization
|
86
|
+
find_organization
|
87
|
+
unless @organization.can_export_library_content?
|
88
|
+
throw_resource_not_found(name: 'organization', id: params[:organization_id])
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
def fail_if_not_pulp3
|
93
|
+
unless SmartProxy.pulp_primary.pulp3_repository_type_support?(Katello::Repository::YUM_TYPE)
|
94
|
+
fail HttpErrors::BadRequest, _("Invalid usage for Pulp 2 repositories. Use export for Yum repositories")
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
@@ -0,0 +1,88 @@
|
|
1
|
+
module Katello
|
2
|
+
class Api::V2::ContentExportsController < Api::V2::ApiController
|
3
|
+
before_action :fail_if_not_pulp3, :only => [:version, :library]
|
4
|
+
before_action :find_exportable_organization, :only => [:library]
|
5
|
+
before_action :find_exportable_content_view_version, :only => [:version]
|
6
|
+
|
7
|
+
api :GET, "/content_exports", N_("List export histories")
|
8
|
+
param :content_view_version_id, :number, :desc => N_("Content view version identifier"), :required => false
|
9
|
+
param :content_view_id, :number, :desc => N_("Content view identifier"), :required => false
|
10
|
+
param :destination_server, String, :desc => N_("Destination Server name"), :required => false
|
11
|
+
param :organization_id, :number, :desc => N_("Organization identifier"), :required => false
|
12
|
+
param :id, :number, :desc => N_("Content view version export history identifier"), :required => false
|
13
|
+
param :type, ::Katello::ContentViewVersionExportHistory::EXPORT_TYPES,
|
14
|
+
:desc => N_("Export Types"),
|
15
|
+
:required => false
|
16
|
+
param_group :search, Api::V2::ApiController
|
17
|
+
add_scoped_search_description_for(ContentViewVersionExportHistory)
|
18
|
+
def index
|
19
|
+
history = ContentViewVersionExportHistory.readable
|
20
|
+
history = history.where(:id => params[:id]) unless params[:id].blank?
|
21
|
+
history = history.where(:content_view_version_id => params[:content_view_version_id]) unless params[:content_view_version_id].blank?
|
22
|
+
history = history.where(:destination_server => params[:destination_server]) unless params[:destination_server].blank?
|
23
|
+
history = history.where(:export_type => params[:type]) unless params[:type].blank?
|
24
|
+
history = history.with_organization_id(params[:organization_id]) unless params[:organization_id].blank?
|
25
|
+
history = history.with_content_view_id(params[:content_view_id]) unless params[:content_view_id].blank?
|
26
|
+
respond_with_template_collection("index", 'content_view_version_export_histories',
|
27
|
+
:collection => scoped_search(history, 'id', 'asc', resource_class: ContentViewVersionExportHistory))
|
28
|
+
end
|
29
|
+
|
30
|
+
api :GET, "/content_exports/api_status", N_("true if the export api is pulp3 ready and usable. This API is intended for use by hammer-cli only.")
|
31
|
+
def api_status
|
32
|
+
::Foreman::Deprecation.api_deprecation_warning("/content_exports/api_status is being deprecated and will be removed in a future version of Katello.")
|
33
|
+
render json: { api_usable: SmartProxy.pulp_primary.pulp3_repository_type_support?(Katello::Repository::YUM_TYPE) }, status: :ok
|
34
|
+
end
|
35
|
+
|
36
|
+
api :POST, "/content_exports/version", N_("Performs a full-export of a content view version.")
|
37
|
+
param :id, :number, :desc => N_("Content view version identifier"), :required => true
|
38
|
+
param :destination_server, String, :desc => N_("Destination Server name"), :required => false
|
39
|
+
param :chunk_size_mb, :number, :desc => N_("Split the exported content into archives "\
|
40
|
+
"no greater than the specified size in megabytes."), :required => false
|
41
|
+
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this version"\
|
42
|
+
" are unexportable. False by default."), :required => false
|
43
|
+
def version
|
44
|
+
tasks = async_task(::Actions::Pulp3::Orchestration::ContentViewVersion::Export,
|
45
|
+
content_view_version: @version,
|
46
|
+
destination_server: params[:destination_server],
|
47
|
+
chunk_size: params[:chunk_size_mb],
|
48
|
+
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
49
|
+
respond_for_async :resource => tasks
|
50
|
+
end
|
51
|
+
|
52
|
+
api :POST, "/content_exports/library", N_("Performs a full-export of the repositories in library.")
|
53
|
+
param :organization_id, :number, :desc => N_("Organization identifier"), :required => true
|
54
|
+
param :destination_server, String, :desc => N_("Destination Server name"), :required => false
|
55
|
+
param :chunk_size_mb, :number, :desc => N_("Split the exported content into archives "\
|
56
|
+
"no greater than the specified size in megabytes."), :required => false
|
57
|
+
param :fail_on_missing_content, :bool, :desc => N_("Fails if any of the repositories belonging to this organization"\
|
58
|
+
" are unexportable. False by default."), :required => false
|
59
|
+
def library
|
60
|
+
tasks = async_task(::Actions::Pulp3::Orchestration::ContentViewVersion::ExportLibrary,
|
61
|
+
@organization,
|
62
|
+
destination_server: params[:destination_server],
|
63
|
+
chunk_size: params[:chunk_size_mb],
|
64
|
+
fail_on_missing_content: ::Foreman::Cast.to_bool(params[:fail_on_missing_content]))
|
65
|
+
respond_for_async :resource => tasks
|
66
|
+
end
|
67
|
+
|
68
|
+
private
|
69
|
+
|
70
|
+
def find_exportable_content_view_version
|
71
|
+
@version = ContentViewVersion.exportable.find_by_id(params[:id])
|
72
|
+
throw_resource_not_found(name: 'content view version', id: params[:id]) if @version.blank?
|
73
|
+
end
|
74
|
+
|
75
|
+
def find_exportable_organization
|
76
|
+
find_organization
|
77
|
+
unless @organization.can_export_library_content?
|
78
|
+
throw_resource_not_found(name: 'organization', id: params[:organization_id])
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
def fail_if_not_pulp3
|
83
|
+
unless SmartProxy.pulp_primary.pulp3_repository_type_support?(Katello::Repository::YUM_TYPE)
|
84
|
+
fail HttpErrors::BadRequest, _("Invalid usage for Pulp 2 repositories. Use export for Yum repositories")
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|