katello 4.0.3 → 4.1.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of katello might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/javascripts/katello/hosts/host_and_hostgroup_edit.js +0 -33
- data/app/assets/stylesheets/katello/contents.scss +1 -1
- data/app/controllers/katello/api/registry/registry_proxies_controller.rb +5 -11
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +2 -9
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +10 -24
- data/app/controllers/katello/api/v2/api_controller.rb +15 -3
- data/app/controllers/katello/api/v2/content_credentials_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +1 -8
- data/app/controllers/katello/api/v2/content_exports_controller.rb +1 -14
- data/app/controllers/katello/api/v2/content_imports_controller.rb +38 -15
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_components_controller.rb +22 -1
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +6 -1
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +2 -59
- data/app/controllers/katello/api/v2/content_views_controller.rb +3 -58
- data/app/controllers/katello/api/v2/host_errata_controller.rb +7 -6
- data/app/controllers/katello/api/v2/host_packages_controller.rb +4 -4
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +18 -22
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +16 -16
- data/app/controllers/katello/api/v2/organizations_controller.rb +2 -1
- data/app/controllers/katello/api/v2/package_groups_controller.rb +4 -0
- data/app/controllers/katello/api/v2/repositories_controller.rb +13 -12
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +50 -4
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +7 -1
- data/app/controllers/katello/concerns/api/api_controller.rb +10 -0
- data/app/controllers/katello/concerns/api/v2/registration_commands_controller_extensions.rb +46 -0
- data/app/controllers/katello/concerns/api/v2/registration_controller_extensions.rb +8 -0
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +31 -22
- data/app/controllers/katello/concerns/hosts_controller_extensions.rb +0 -8
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +1 -1
- data/app/controllers/katello/concerns/registration_commands_controller_extensions.rb +34 -0
- data/app/helpers/katello/katello_urls_helper.rb +23 -0
- data/app/lib/actions/candlepin/owner/import.rb +10 -3
- data/app/lib/actions/candlepin/product/content_update.rb +1 -1
- data/app/lib/actions/foreman/environment/destroy.rb +2 -2
- data/app/lib/actions/katello/agent_action.rb +1 -6
- data/app/lib/actions/katello/capsule_content/refresh_repos.rb +0 -7
- data/app/lib/actions/katello/capsule_content/sync.rb +1 -1
- data/app/lib/actions/katello/capsule_content/sync_capsule.rb +1 -2
- data/app/lib/actions/katello/content_view/add_to_environment.rb +9 -7
- data/app/lib/actions/katello/content_view/incremental_updates.rb +3 -10
- data/app/lib/actions/katello/content_view/presenters/incremental_updates_presenter.rb +2 -3
- data/app/lib/actions/katello/content_view/promote_to_environment.rb +1 -4
- data/app/lib/actions/katello/content_view/publish.rb +21 -31
- data/app/lib/actions/katello/content_view_environment/destroy.rb +0 -5
- data/app/lib/actions/katello/content_view_version/auto_create_products.rb +22 -0
- data/app/lib/actions/katello/content_view_version/auto_create_repositories.rb +22 -0
- data/app/lib/actions/katello/content_view_version/destroy.rb +0 -10
- data/app/lib/actions/katello/content_view_version/export.rb +20 -22
- data/app/lib/actions/katello/content_view_version/import.rb +27 -13
- data/app/lib/actions/katello/content_view_version/import_library.rb +4 -2
- data/app/lib/actions/katello/content_view_version/incremental_update.rb +12 -67
- data/app/lib/actions/katello/content_view_version/republish_repositories.rb +0 -4
- data/app/lib/actions/katello/content_view_version/reset_content_view_repositories_from_metadata.rb +11 -0
- data/app/lib/actions/katello/foreman/content_update.rb +0 -3
- data/app/lib/actions/katello/host/auto_attach_subscriptions.rb +0 -4
- data/app/lib/actions/katello/organization/manifest_import.rb +7 -1
- data/app/lib/actions/katello/organization/manifest_refresh.rb +28 -7
- data/app/lib/actions/katello/orphan_cleanup/remove_orphans.rb +2 -2
- data/app/lib/actions/katello/product/create.rb +0 -1
- data/app/lib/actions/katello/repository/check_matching_content.rb +4 -3
- data/app/lib/actions/katello/repository/destroy.rb +1 -1
- data/app/lib/actions/katello/repository/discover.rb +1 -1
- data/app/lib/actions/katello/repository/filtered_index_content.rb +1 -4
- data/app/lib/actions/katello/repository/import_upload.rb +0 -1
- data/app/lib/actions/katello/repository/update.rb +0 -1
- data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +0 -5
- data/app/lib/actions/pulp/repository/create.rb +1 -7
- data/app/lib/actions/pulp/repository/distributor_publish.rb +2 -10
- data/app/lib/actions/pulp/repository/sync.rb +1 -3
- data/app/lib/actions/pulp3/capsule_content/refresh_content_guard.rb +17 -0
- data/app/lib/actions/pulp3/content_guard/refresh.rb +10 -6
- data/app/lib/actions/pulp3/content_view_version/create_export_history.rb +57 -0
- data/app/lib/actions/pulp3/content_view_version/create_import_history.rb +34 -0
- data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +2 -3
- data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +34 -51
- data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +2 -2
- data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +13 -1
- data/app/lib/actions/pulp3/orchestration/orphan_cleanup/remove_orphans.rb +1 -1
- data/app/lib/actions/pulp3/orchestration/repository/sync.rb +1 -0
- data/app/lib/actions/pulp3/repository/refresh_remote.rb +17 -0
- data/app/lib/katello/agent/client_message_handler.rb +3 -11
- data/app/lib/katello/concerns/base_template_scope_extensions.rb +117 -3
- data/app/lib/katello/errors.rb +6 -11
- data/app/lib/katello/event_daemon/monitor.rb +0 -1
- data/app/lib/katello/event_daemon/runner.rb +2 -2
- data/app/lib/katello/event_daemon/services/agent_event_receiver.rb +10 -6
- data/app/lib/katello/http_resource.rb +1 -6
- data/app/lib/katello/logging.rb +11 -6
- data/app/lib/katello/qpid/connection.rb +1 -3
- data/app/lib/katello/repo_discovery.rb +15 -1
- data/app/lib/katello/resources/candlepin/owner.rb +3 -2
- data/app/lib/katello/resources/candlepin/pool.rb +6 -2
- data/app/lib/katello/resources/candlepin.rb +10 -0
- data/app/lib/katello/util/package.rb +1 -1
- data/app/lib/katello/util/pulpcore_content_filters.rb +1 -1
- data/app/lib/katello/validators/hostgroup_kickstart_repository_validator.rb +0 -6
- data/app/models/katello/authorization/content_view.rb +8 -0
- data/app/models/katello/authorization/content_view_version_import_history.rb +11 -0
- data/app/models/katello/concerns/content_facet_host_extensions.rb +1 -1
- data/app/models/katello/concerns/content_view_filter_rule_common.rb +2 -2
- data/app/models/katello/concerns/host_managed_extensions.rb +1 -32
- data/app/models/katello/concerns/hostgroup_extensions.rb +2 -9
- data/app/models/katello/concerns/http_proxy_extensions.rb +2 -4
- data/app/models/katello/concerns/location_extensions.rb +2 -25
- data/app/models/katello/concerns/operatingsystem_extensions.rb +0 -2
- data/app/models/katello/concerns/organization_extensions.rb +4 -18
- data/app/models/katello/concerns/redhat_extensions.rb +10 -18
- data/app/models/katello/concerns/smart_proxy_extensions.rb +6 -31
- data/app/models/katello/content_view.rb +17 -113
- data/app/models/katello/content_view_component.rb +5 -0
- data/app/models/katello/content_view_docker_filter_rule.rb +1 -0
- data/app/models/katello/content_view_package_filter_rule.rb +4 -0
- data/app/models/katello/content_view_package_group_filter.rb +1 -0
- data/app/models/katello/content_view_repository.rb +4 -5
- data/app/models/katello/content_view_version.rb +9 -33
- data/app/models/katello/content_view_version_export_history.rb +18 -4
- data/app/models/katello/content_view_version_import_history.rb +42 -0
- data/app/models/katello/erratum.rb +1 -1
- data/app/models/katello/events/delete_pool.rb +19 -0
- data/app/models/katello/glue/candlepin/environment.rb +7 -0
- data/app/models/katello/glue/candlepin/owner.rb +12 -1
- data/app/models/katello/glue/candlepin/pool.rb +42 -25
- data/app/models/katello/glue/provider.rb +3 -6
- data/app/models/katello/glue/pulp/repo.rb +19 -9
- data/app/models/katello/host/content_facet.rb +1 -0
- data/app/models/katello/host/subscription_facet.rb +3 -1
- data/app/models/katello/kt_environment.rb +0 -6
- data/app/models/katello/package_group.rb +4 -0
- data/app/models/katello/ping.rb +15 -4
- data/app/models/katello/pool.rb +9 -0
- data/app/models/katello/product.rb +0 -6
- data/app/models/katello/product_content.rb +3 -1
- data/app/models/katello/pulp_sync_status.rb +0 -10
- data/app/models/katello/repository.rb +20 -35
- data/app/models/katello/root_repository.rb +0 -5
- data/app/models/katello/subscription.rb +10 -0
- data/app/models/katello/sync_plan.rb +7 -0
- data/app/models/setting/content.rb +7 -8
- data/app/presenters/katello/content_view_version_compare_presenter.rb +2 -6
- data/app/presenters/katello/product_content_presenter.rb +3 -5
- data/app/services/cert/certs.rb +3 -7
- data/app/services/katello/applicability/applicable_content_helper.rb +1 -2
- data/app/services/katello/candlepin/event_handler.rb +22 -22
- data/app/services/katello/candlepin/message_handler.rb +24 -15
- data/app/services/katello/content_view_manager.rb +24 -0
- data/app/services/katello/event_monitor/poller_thread.rb +25 -20
- data/app/services/katello/managed_content_medium_provider.rb +4 -0
- data/app/services/katello/organization_creator.rb +120 -0
- data/app/services/katello/product_content_finder.rb +5 -1
- data/app/services/katello/pulp/pulp_content_unit.rb +6 -6
- data/app/services/katello/pulp/smart_proxy_repository.rb +2 -17
- data/app/services/katello/pulp3/api/ansible_collection.rb +14 -2
- data/app/services/katello/pulp3/api/apt.rb +1 -1
- data/app/services/katello/pulp3/api/content_guard.rb +6 -40
- data/app/services/katello/pulp3/api/core.rb +27 -2
- data/app/services/katello/pulp3/api/docker.rb +1 -1
- data/app/services/katello/pulp3/api/file.rb +5 -1
- data/app/services/katello/pulp3/api/yum.rb +9 -1
- data/app/services/katello/pulp3/content_view_version/export.rb +18 -40
- data/app/services/katello/pulp3/content_view_version/import.rb +75 -30
- data/app/services/katello/pulp3/content_view_version/import_gpg_keys.rb +32 -0
- data/app/services/katello/pulp3/content_view_version/import_validator.rb +53 -21
- data/app/services/katello/pulp3/content_view_version/importable_products.rb +47 -0
- data/app/services/katello/pulp3/content_view_version/importable_repositories.rb +52 -0
- data/app/services/katello/pulp3/content_view_version/metadata_generator.rb +99 -0
- data/app/services/katello/pulp3/pulp_content_unit.rb +1 -1
- data/app/services/katello/pulp3/repository/ansible_collection.rb +5 -1
- data/app/services/katello/pulp3/repository/apt.rb +2 -1
- data/app/services/katello/pulp3/repository/yum.rb +0 -16
- data/app/services/katello/pulp3/repository.rb +20 -1
- data/app/services/katello/pulp3/rpm.rb +5 -1
- data/app/services/katello/pulp3/task.rb +12 -5
- data/app/services/katello/pulp3/task_group.rb +10 -5
- data/app/services/katello/smart_proxy_helper.rb +1 -8
- data/app/services/katello/ui_notifications/pulp/proxy_disk_space.rb +0 -1
- data/app/services/katello/ui_notifications/system_error.rb +25 -0
- data/app/views/katello/api/v2/content_view_components/show.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_filters/show.json.rabl +0 -1
- data/app/views/katello/api/v2/{puppet_modules → content_view_version_import_histories}/index.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_version_import_histories/show.json.rabl +14 -0
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +2 -2
- data/app/views/katello/api/v2/content_view_versions/show.json.rabl +0 -7
- data/app/views/katello/api/v2/content_views/base.json.rabl +20 -9
- data/app/views/katello/api/v2/environments/show.json.rabl +0 -1
- data/app/views/katello/api/v2/package_groups/index.json.rabl +4 -0
- data/app/views/katello/api/v2/repositories/base.json.rabl +0 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repository_sets/index.json.rabl +4 -1
- data/app/views/katello/api/v2/repository_sets/show.json.rabl +22 -0
- data/app/views/katello/api/v2/subscriptions/show.json.rabl +1 -1
- data/app/views/overrides/activation_keys/_host_media_type_select.html.erb +1 -1
- data/app/views/overrides/smart_proxies/_download_policy.erb +1 -1
- data/config/initializers/monkeys.rb +0 -1
- data/config/katello.yaml.example +0 -1
- data/config/routes/api/v2.rb +9 -21
- data/config/routes/overrides.rb +1 -2
- data/db/migrate/20140422000001_update_products_add_organization.rb +3 -2
- data/db/migrate/20160701180402_add_sortable_version_to_puppet_modules.rb +2 -0
- data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +1 -1
- data/db/migrate/20210119162528_delete_puppet_and_ostree_repos.rb +14 -20
- data/db/migrate/20210224160921_remove_disabled_products_from_sync_plans.rb +6 -0
- data/db/migrate/20210302165636_remove_katello_puppet_modules.rb +62 -0
- data/db/migrate/20210309160925_create_katello_content_view_version_import_histories.rb +13 -0
- data/db/migrate/20210318204533_add_import_type_to_import_histories.rb +8 -0
- data/db/migrate/20210319123300_add_foreign_keys_to_import_export_histories.rb +6 -0
- data/db/migrate/20210322142311_add_auth_url_token_to_root_repositories.rb +6 -0
- data/db/migrate/20210331180353_katello_pool_organization_id_not_nullable.rb +16 -0
- data/db/migrate/20210409033915_add_created_in_katello_to_taxonomy.rb +9 -0
- data/db/seeds.d/101-locations.rb +0 -3
- data/db/seeds.d/102-organizations.rb +1 -5
- data/db/seeds.d/109-katello-notification-blueprints.rb +12 -0
- data/db/seeds.d/111-upgrade_tasks.rb +3 -2
- data/engines/bastion/vendor/assets/javascripts/bastion/angular/angular.js +325 -156
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-animate/angular-animate.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-resource/angular-resource.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-route/angular-route.js +3 -3
- data/engines/bastion/vendor/assets/javascripts/bastion/angular-sanitize/angular-sanitize.js +21 -43
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-repository-sets.controller.js +9 -10
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-repository-sets.html +2 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion-katello-bootstrap.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion_katello.js +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-errata-modal.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-packages-modal.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-errata-modal.html +11 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-packages-modal.html +18 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +10 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-errata.controller.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-actions.controller.js +5 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-applicable.controller.js +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-packages-installed.controller.js +7 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-errata.html +6 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-actions.html +7 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-applicable.html +14 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages-installed.html +5 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.routes.js +0 -14
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-repository-sets.controller.js +9 -11
- 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/details/views/content-host-repository-sets.html +2 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +3 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-view.factory.js +0 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -56
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +2 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -12
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +2 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-versions.module.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/content.service.js +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.module.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.routes.js +0 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +0 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/apply-errata.controller.js +21 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/views/apply-errata-confirm.html +9 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +71 -311
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +0 -10
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/fenced-pages.service.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-manage-content.controller.js +2 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +13 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +21 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repositories.routes.js +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/views/product-repositories.html +0 -6
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +3 -3
- data/lib/katello/engine.rb +16 -15
- data/lib/katello/middleware/organization_created_enforcer.rb +22 -0
- data/lib/katello/permission_creator.rb +12 -28
- data/lib/katello/permissions/host_permissions.rb +3 -2
- data/lib/katello/plugin.rb +6 -19
- data/lib/katello/repository_types/ansible_collection.rb +1 -1
- data/lib/katello/repository_types/deb.rb +1 -1
- data/lib/katello/repository_types/docker.rb +1 -1
- data/lib/katello/repository_types/file.rb +1 -1
- data/lib/katello/repository_types/yum.rb +1 -1
- data/lib/katello/tasks/clean_backend_objects.rake +25 -0
- data/lib/katello/tasks/jenkins.rake +6 -0
- data/lib/katello/tasks/receptor/extract_orgs.rake +1 -3
- data/lib/katello/tasks/reimport.rake +0 -1
- data/lib/katello/tasks/repository.rake +0 -30
- data/lib/katello/tasks/update_subscription_facet_backend_data.rake +3 -3
- data/lib/katello/tasks/upgrades/4.0/remove_ostree_puppet_content.rake +2 -4
- data/lib/katello/tasks/upgrades/4.1/fix_invalid_pools.rake +62 -0
- data/lib/katello/tasks/upgrades/4.1/sync_noarch_content.rake +15 -0
- data/lib/katello/version.rb +1 -1
- data/lib/katello.rb +1 -1
- data/locale/action_names.rb +65 -63
- data/locale/bn/katello.edit.po +1357 -1606
- data/locale/bn/katello.po +465 -744
- data/locale/cs/katello.edit.po +1213 -1087
- data/locale/cs/katello.po +307 -219
- data/locale/de/katello.edit.po +1498 -1520
- data/locale/de/katello.po +589 -625
- data/locale/en/katello.edit.po +1198 -1074
- data/locale/en/katello.po +304 -213
- data/locale/es/katello.edit.po +2344 -2304
- data/locale/es/katello.po +1407 -1407
- data/locale/fr/katello.edit.po +2720 -2642
- data/locale/fr/katello.po +1703 -1750
- data/locale/gu/katello.edit.po +1546 -1797
- data/locale/gu/katello.po +654 -935
- data/locale/hi/katello.edit.po +1545 -1793
- data/locale/hi/katello.po +653 -931
- data/locale/it/katello.edit.po +1323 -1310
- data/locale/it/katello.po +407 -409
- data/locale/ja/katello.edit.po +2645 -2557
- data/locale/ja/katello.po +1646 -1664
- data/locale/katello.pot +1435 -1289
- data/locale/kn/katello.edit.po +1546 -1795
- data/locale/kn/katello.po +654 -933
- data/locale/ko/katello.edit.po +1464 -1449
- data/locale/ko/katello.po +554 -554
- data/locale/mr/katello.edit.po +1545 -1758
- data/locale/mr/katello.po +653 -896
- data/locale/or/katello.edit.po +1546 -1795
- data/locale/or/katello.po +654 -933
- data/locale/pa/katello.edit.po +1541 -1775
- data/locale/pa/katello.po +649 -913
- data/locale/pt/katello.edit.po +1289 -1255
- data/locale/pt/katello.po +398 -394
- data/locale/pt_BR/katello.edit.po +2370 -2315
- data/locale/pt_BR/katello.po +1435 -1421
- data/locale/ru/katello.edit.po +1611 -1608
- data/locale/ru/katello.po +704 -716
- data/locale/ta/katello.edit.po +1358 -1605
- data/locale/ta/katello.po +465 -742
- data/locale/te/katello.edit.po +1545 -1792
- data/locale/te/katello.po +653 -930
- data/locale/zh_CN/katello.edit.po +3052 -2930
- data/locale/zh_CN/katello.po +2055 -2039
- data/locale/zh_TW/katello.edit.po +1571 -1669
- data/locale/zh_TW/katello.po +649 -777
- data/package.json +2 -2
- data/webpack/{scenes/ContentViews/Details/Repositories/RepoAddedStatus.js → components/AddedStatusLabel.js} +5 -5
- data/webpack/components/RoutedTabs/RoutedTabs.js +91 -0
- data/webpack/components/RoutedTabs/__tests__/RoutedTabs.test.js +32 -0
- data/webpack/components/RoutedTabs/index.js +4 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageConstants.js +2 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageHelpers.js +21 -0
- data/webpack/components/extensions/RegistrationCommands/RegistrationCommandsPageSelectors.js +21 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/ActivationKeys.test.js +18 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/Force.test.js +9 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/IgnoreSubmanErrors.test.js +9 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/LifeCycleEnvironment.test.js +11 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/ActivationKeys.test.js.snap +58 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/Force.test.js.snap +25 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/IgnoreSubmanErrors.test.js.snap +25 -0
- data/webpack/components/extensions/RegistrationCommands/__tests__/__snapshots__/LifeCycleEnvironment.test.js.snap +27 -0
- data/webpack/components/extensions/RegistrationCommands/fields/ActivationKeys.js +99 -0
- data/webpack/components/extensions/RegistrationCommands/fields/Force.js +38 -0
- data/webpack/components/extensions/RegistrationCommands/fields/IgnoreSubmanErrors.js +38 -0
- data/webpack/components/extensions/RegistrationCommands/fields/LifecycleEnvironment.js +56 -0
- data/webpack/components/extensions/RegistrationCommands/index.js +81 -0
- data/webpack/components/pf3Table/formatters/EntitlementsInlineEditFormatter.js +23 -24
- data/webpack/components/pf3Table/formatters/__tests__/__snapshots__/EntitlementsInlineEditFormatter.test.js.snap +3 -1
- data/webpack/components/pf3Table/formatters/entitlementsValueFormatter.js +16 -0
- data/webpack/containers/Application/overrides.scss +3 -0
- data/webpack/fills_index.js +3 -0
- data/webpack/redux/reducers/RedHatRepositories/enabled.fixtures.js +0 -2
- data/webpack/scenes/ContentViews/ContentViewsConstants.js +8 -1
- data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +1 -3
- data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +1 -3
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentEnvironments.js +28 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ComponentVersion.js +45 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +124 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.fixtures.json +161 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +163 -0
- data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/unpublishedCVComponents.fixtures.json +64 -0
- data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +67 -7
- data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +61 -4
- data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +34 -11
- data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +33 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +117 -0
- data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +115 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +7 -10
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetails.js +49 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilterDetailsHeader.js +56 -0
- data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +3 -17
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +116 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/allFilterPackageGroups.fixtures.json +69 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetail.fixtures.json +103 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +116 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterDetail.fixtures.json +147 -0
- data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvPackageFilterRules.fixtures.json +30 -0
- data/webpack/scenes/ContentViews/Details/Histories/ContentViewHistories.js +136 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.fixtures.json +370 -0
- data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +94 -0
- data/webpack/scenes/ContentViews/Details/Repositories/ContentCounts.js +0 -1
- data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +106 -13
- data/webpack/scenes/ContentViews/Details/Repositories/LastSync.js +11 -5
- data/webpack/scenes/ContentViews/Details/Repositories/RepoIcon.js +5 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +138 -0
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.fixtures.json +0 -2
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +1 -1
- data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewRepoAdd.fixture.json +57 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionContent.js +73 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionEnvironments.js +31 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.js +64 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionErrata.scss +8 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersionPackages.js +0 -0
- data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +105 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.fixtures.json +728 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +154 -0
- data/webpack/scenes/ContentViews/Details/Versions/__tests__/emptyCVVersion.fixtures.json +13 -0
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +3 -1
- data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetails.fixtures.json +0 -2
- data/webpack/scenes/ContentViews/Table/ContentViewVersionCell.js +33 -0
- data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +17 -22
- data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +51 -102
- data/webpack/scenes/ContentViews/__tests__/basicContentViews.fixtures.js +5 -3
- data/webpack/scenes/ContentViews/__tests__/contentViewList.fixtures.json +30 -5
- data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +95 -0
- data/webpack/scenes/ContentViews/components/ContentViewIcon.js +11 -5
- data/webpack/scenes/ContentViews/components/EnvironmentLabels.js +16 -0
- data/webpack/scenes/ContentViews/components/IconWithCount.js +1 -1
- data/webpack/scenes/ContentViews/components/InactiveText.js +15 -0
- data/webpack/scenes/ContentViews/expansions/DetailsExpansion.js +19 -1
- data/webpack/scenes/Subscriptions/Details/SubscriptionPurposeAttributes.js +1 -1
- data/webpack/scenes/Subscriptions/Details/__tests__/__snapshots__/SubscriptionDetailInfo.test.js.snap +1 -1
- data/webpack/scenes/Subscriptions/Details/__tests__/__snapshots__/SubscriptionDetails.test.js.snap +3 -3
- data/webpack/scenes/Subscriptions/Details/__tests__/subscriptionDetails.fixtures.js +1 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableHelpers.js +17 -0
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/SubscriptionsTableSchema.js +2 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/SubscriptionsTable.test.js +1 -1
- data/webpack/scenes/Subscriptions/components/SubscriptionsTable/__tests__/__snapshots__/SubscriptionsTable.test.js.snap +144 -0
- data/webpack/scenes/Tasks/helpers.js +2 -2
- data/webpack/test-utils/react-testing-lib-wrapper.js +11 -3
- data/webpack/utils/__tests__/useParamsWithHash.test.js +22 -0
- data/webpack/utils/helpers.js +2 -0
- data/webpack/utils/paramsFromHash.js +16 -0
- data/webpack/utils/useUrlParams.js +14 -0
- metadata +122 -206
- data/app/controllers/katello/api/v2/content_view_puppet_modules_controller.rb +0 -82
- data/app/controllers/katello/api/v2/puppet_modules_controller.rb +0 -19
- data/app/controllers/katello/concerns/registration_controller_extensions.rb +0 -16
- data/app/helpers/katello/concerns/hosts_and_hostgroups_helper_extensions.rb +0 -20
- data/app/lib/actions/candlepin/owner/create.rb +0 -16
- data/app/lib/actions/katello/content_view_puppet_environment/clear.rb +0 -11
- data/app/lib/actions/katello/content_view_puppet_environment/clone.rb +0 -78
- data/app/lib/actions/katello/content_view_puppet_environment/clone_content_for_version.rb +0 -20
- data/app/lib/actions/katello/content_view_puppet_environment/create.rb +0 -34
- data/app/lib/actions/katello/content_view_puppet_environment/create_for_version.rb +0 -23
- data/app/lib/actions/katello/content_view_puppet_environment/destroy.rb +0 -28
- data/app/lib/actions/katello/content_view_puppet_module/destroy.rb +0 -46
- data/app/lib/actions/katello/environment/library_create.rb +0 -35
- data/app/lib/actions/katello/organization/create.rb +0 -38
- data/app/lib/actions/pulp/content_view_puppet_environment/copy_contents.rb +0 -36
- data/app/lib/actions/pulp/content_view_puppet_environment/index_content.rb +0 -19
- data/app/lib/actions/pulp/repository/presenters/puppet_presenter.rb +0 -54
- data/app/lib/actions/pulp3/content_migration.rb +0 -31
- data/app/lib/actions/pulp3/content_migration_presenter.rb +0 -59
- data/app/lib/actions/pulp3/content_migration_reset.rb +0 -22
- data/app/lib/katello/foreman.rb +0 -32
- data/app/lib/katello/mapping.rb +0 -31
- data/app/lib/katello/util/hostgroup_facets_helper.rb +0 -126
- data/app/lib/katello/validators/content_view_puppet_module_validator.rb +0 -32
- data/app/models/katello/concerns/environment_extensions.rb +0 -74
- data/app/models/katello/content_view_puppet_environment.rb +0 -116
- data/app/models/katello/content_view_puppet_environment_puppet_module.rb +0 -11
- data/app/models/katello/content_view_puppet_module.rb +0 -63
- data/app/models/katello/puppet_module.rb +0 -77
- data/app/models/katello/repository_puppet_module.rb +0 -7
- data/app/services/katello/pulp/puppet_module.rb +0 -21
- data/app/services/katello/pulp/repository/puppet.rb +0 -68
- data/app/services/katello/pulp3/migration.rb +0 -329
- data/app/services/katello/pulp3/migration_plan.rb +0 -178
- data/app/services/katello/pulp3/migration_switchover.rb +0 -126
- data/app/services/katello/puppet_class_importer_extensions.rb +0 -32
- data/app/views/foreman/hosts/_registration.html.erb +0 -12
- data/app/views/katello/api/v2/activation_keys/product_content.json.rabl +0 -30
- data/app/views/katello/api/v2/content_view_puppet_modules/create.json.rabl +0 -3
- data/app/views/katello/api/v2/content_view_puppet_modules/index.json.rabl +0 -7
- data/app/views/katello/api/v2/content_view_puppet_modules/show.json.rabl +0 -9
- data/app/views/katello/api/v2/content_views/puppet_modules.json.rabl +0 -7
- data/app/views/katello/api/v2/host_subscriptions/content_override.json.rabl +0 -3
- data/app/views/katello/api/v2/host_subscriptions/product_content.json.rabl +0 -29
- data/app/views/katello/api/v2/puppet_modules/backend.json.rabl +0 -7
- data/app/views/katello/api/v2/puppet_modules/base.json.rabl +0 -9
- data/app/views/katello/api/v2/puppet_modules/compare.json.rabl +0 -10
- data/app/views/katello/api/v2/puppet_modules/name.json.rabl +0 -3
- data/app/views/katello/api/v2/puppet_modules/names.json.rabl +0 -7
- data/app/views/katello/api/v2/puppet_modules/show.json.rabl +0 -4
- data/db/migrate/20210512192745_fix_red_hat_root_repository_arch.rb +0 -11
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-client.directive.js +0 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-os-client.directive.js +0 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register.controller.js +0 -44
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-client.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-deb-client.html +0 -38
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-oracle-client.html +0 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-sles-client.html +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-puppet-modules.controller.js +0 -9
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-names.controller.js +0 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module-versions.controller.js +0 -61
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-module.factory.js +0 -23
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/content-view-puppet-modules.controller.js +0 -74
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-module-names.html +0 -57
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-module-versions.html +0 -64
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-modules.html +0 -54
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-puppet-modules.html +0 -19
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-puppet-modules.html +0 -25
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +0 -6903
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +0 -7094
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +0 -7303
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +0 -6895
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +0 -6865
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +0 -6720
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +0 -7077
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +0 -6832
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +0 -6766
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +0 -6703
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-manage-puppet-modules.html +0 -66
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-content-views.controller.js +0 -44
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module-repositories.controller.js +0 -36
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/puppet-module.controller.js +0 -34
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-content-views.html +0 -41
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-info.html +0 -32
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module-repositories.html +0 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-module.html +0 -37
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-module.factory.js +0 -28
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.controller.js +0 -35
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.module.js +0 -20
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.routes.js +0 -71
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/views/puppet-modules.html +0 -47
- data/lib/katello/repository_types/puppet.rb +0 -5
- data/lib/katello/tasks/fix_hostgroup_facets.rake +0 -8
- data/lib/katello/tasks/pulp3_content_switchover.rake +0 -32
- data/lib/katello/tasks/pulp3_migration.rake +0 -41
- data/lib/katello/tasks/pulp3_migration_abort.rake +0 -22
- data/lib/katello/tasks/pulp3_migration_reset.rake +0 -26
- data/lib/katello/tasks/pulp3_migration_stats.rake +0 -41
- data/lib/katello/tasks/pulp3_post_migration_check.rake +0 -51
- data/lib/monkeys/passenger_tee_input.rb +0 -20
- data/locale/bn/LC_MESSAGES/katello.mo +0 -0
- data/locale/cs/LC_MESSAGES/katello.mo +0 -0
- data/locale/de/LC_MESSAGES/katello.mo +0 -0
- data/locale/en/LC_MESSAGES/katello.mo +0 -0
- data/locale/es/LC_MESSAGES/katello.mo +0 -0
- data/locale/fr/LC_MESSAGES/katello.mo +0 -0
- data/locale/gu/LC_MESSAGES/katello.mo +0 -0
- data/locale/hi/LC_MESSAGES/katello.mo +0 -0
- data/locale/it/LC_MESSAGES/katello.mo +0 -0
- data/locale/ja/LC_MESSAGES/katello.mo +0 -0
- data/locale/kn/LC_MESSAGES/katello.mo +0 -0
- data/locale/ko/LC_MESSAGES/katello.mo +0 -0
- data/locale/mr/LC_MESSAGES/katello.mo +0 -0
- data/locale/or/LC_MESSAGES/katello.mo +0 -0
- data/locale/pa/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt/LC_MESSAGES/katello.mo +0 -0
- data/locale/pt_BR/LC_MESSAGES/katello.mo +0 -0
- data/locale/ru/LC_MESSAGES/katello.mo +0 -0
- data/locale/ta/LC_MESSAGES/katello.mo +0 -0
- data/locale/te/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_CN/LC_MESSAGES/katello.mo +0 -0
- data/locale/zh_TW/LC_MESSAGES/katello.mo +0 -0
- data/webpack/components/TabWrapper/TabWrapper.js +0 -26
- data/webpack/components/TabWrapper/index.js +0 -3
- data/webpack/components/TabbedView/TabbedView.js +0 -38
- data/webpack/components/TabbedView/TabbedView.scss +0 -3
- data/webpack/components/TabbedView/index.js +0 -3
- data/webpack/scenes/ContentViews/expansions/EnvironmentsExpansion.js +0 -19
- data/webpack/scenes/ContentViews/expansions/VersionsExpansion.js +0 -11
@@ -0,0 +1,57 @@
|
|
1
|
+
module Actions
|
2
|
+
module Pulp3
|
3
|
+
module ContentViewVersion
|
4
|
+
class CreateExportHistory < Actions::EntryAction
|
5
|
+
input_format do
|
6
|
+
param :smart_proxy_id, Integer
|
7
|
+
param :exporter_data, Hash
|
8
|
+
param :content_view_version_id, Integer
|
9
|
+
param :from_content_view_version_id, Integer
|
10
|
+
param :destination_server, String
|
11
|
+
end
|
12
|
+
|
13
|
+
output_format do
|
14
|
+
param :export_history_id, Integer
|
15
|
+
param :path, String
|
16
|
+
param :exported_file_checksum, String
|
17
|
+
end
|
18
|
+
|
19
|
+
def run
|
20
|
+
smart_proxy = ::SmartProxy.find(input[:smart_proxy_id])
|
21
|
+
api = ::Katello::Pulp3::Api::Core.new(smart_proxy)
|
22
|
+
export_data = api.export_api.list(input[:exporter_data][:pulp_href]).results.first
|
23
|
+
output[:exported_file_checksum] = export_data.output_file_info
|
24
|
+
file_name = output[:exported_file_checksum].first&.first
|
25
|
+
path = File.dirname(file_name.to_s)
|
26
|
+
output[:path] = path
|
27
|
+
cvv = ::Katello::ContentViewVersion.find(input[:content_view_version_id])
|
28
|
+
from_cvv = ::Katello::ContentViewVersion.find(input[:from_content_view_version_id]) unless input[:from_content_view_version_id].blank?
|
29
|
+
|
30
|
+
export_metadata = ::Katello::Pulp3::ContentViewVersion::Export.new(
|
31
|
+
content_view_version: cvv,
|
32
|
+
smart_proxy: smart_proxy,
|
33
|
+
from_content_view_version: from_cvv).generate_metadata
|
34
|
+
|
35
|
+
toc_path_info = output[:exported_file_checksum].find { |item| item.first.end_with?("toc.json") }
|
36
|
+
export_metadata[:toc] = File.basename(toc_path_info.first)
|
37
|
+
|
38
|
+
history = ::Katello::ContentViewVersionExportHistory.create!(
|
39
|
+
content_view_version_id: input[:content_view_version_id],
|
40
|
+
destination_server: input[:destination_server],
|
41
|
+
path: path,
|
42
|
+
metadata: export_metadata,
|
43
|
+
audit_comment: ::Katello::ContentViewVersionExportHistory.generate_audit_comment(content_view_version: cvv,
|
44
|
+
user: User.current,
|
45
|
+
from_version: from_cvv,
|
46
|
+
metadata: export_metadata)
|
47
|
+
)
|
48
|
+
output[:export_history_id] = history.id
|
49
|
+
end
|
50
|
+
|
51
|
+
def humanized_name
|
52
|
+
_("Create Export History")
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module Actions
|
2
|
+
module Pulp3
|
3
|
+
module ContentViewVersion
|
4
|
+
class CreateImportHistory < Actions::EntryAction
|
5
|
+
input_format do
|
6
|
+
param :content_view_version_id, Integer
|
7
|
+
param :path, String
|
8
|
+
param :metadata, Hash
|
9
|
+
param :content_view_name, String
|
10
|
+
end
|
11
|
+
|
12
|
+
output_format do
|
13
|
+
param :import_history_id, Integer
|
14
|
+
end
|
15
|
+
|
16
|
+
def run
|
17
|
+
history = ::Katello::ContentViewVersionImportHistory.create!(
|
18
|
+
content_view_version_id: input[:content_view_version_id],
|
19
|
+
path: input[:path],
|
20
|
+
metadata: input[:metadata],
|
21
|
+
audit_comment: ::Katello::ContentViewVersionImportHistory.generate_audit_comment(path: input[:path],
|
22
|
+
user: User.current,
|
23
|
+
content_view_name: input[:content_view_name])
|
24
|
+
)
|
25
|
+
output[:import_history_id] = history.id
|
26
|
+
end
|
27
|
+
|
28
|
+
def humanized_name
|
29
|
+
_("Create Import History")
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb
CHANGED
@@ -7,12 +7,11 @@ module Actions
|
|
7
7
|
concurrence do
|
8
8
|
content_view_version.importable_repositories.each do |repo|
|
9
9
|
sequence do
|
10
|
-
|
10
|
+
plan_action(Actions::Pulp3::Repository::CopyContent, repo, SmartProxy.pulp_primary!,
|
11
11
|
repo.library_instance,
|
12
12
|
copy_all: true,
|
13
13
|
mirror: content_view_version.content_view.library_import?)
|
14
|
-
plan_action(Actions::Pulp3::Repository::SaveVersion, repo.library_instance
|
15
|
-
tasks: copy_action.output[:pulp_tasks])
|
14
|
+
plan_action(Actions::Pulp3::Repository::SaveVersion, repo.library_instance)
|
16
15
|
plan_action(Katello::Repository::IndexContent, id: repo.library_instance_id)
|
17
16
|
plan_action(Katello::Repository::MetadataGenerate, repo.library_instance, :force => true)
|
18
17
|
end
|
@@ -16,81 +16,64 @@ module Actions
|
|
16
16
|
param :exported_file_checksum, Hash
|
17
17
|
param :export_path, String
|
18
18
|
end
|
19
|
-
|
20
|
-
# rubocop:disable Metrics/MethodLength
|
21
19
|
def plan(content_view_version:, destination_server: nil,
|
22
20
|
chunk_size: nil, from_history: nil,
|
23
21
|
validate_incremental: true,
|
24
22
|
fail_on_missing_content: false)
|
25
|
-
action_subject(content_view_version)
|
26
|
-
unless File.directory?(Setting['pulpcore_export_destination'])
|
27
|
-
fail ::Foreman::Exception, N_("Unable to export. 'pulpcore_export_destination' setting is not set to a valid directory.")
|
28
|
-
end
|
29
23
|
|
30
24
|
sequence do
|
31
25
|
smart_proxy = SmartProxy.pulp_primary!
|
32
26
|
from_content_view_version = from_history&.content_view_version
|
33
27
|
export_service = ::Katello::Pulp3::ContentViewVersion::Export.new(
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
28
|
+
smart_proxy: smart_proxy,
|
29
|
+
content_view_version: content_view_version,
|
30
|
+
destination_server: destination_server,
|
31
|
+
from_content_view_version: from_content_view_version)
|
38
32
|
export_service.validate!(fail_on_missing_content: fail_on_missing_content,
|
39
33
|
validate_incremental: validate_incremental)
|
40
34
|
|
41
35
|
action_output = plan_action(::Actions::Pulp3::ContentViewVersion::CreateExporter,
|
42
|
-
|
43
|
-
|
44
|
-
|
36
|
+
content_view_version_id: content_view_version.id,
|
37
|
+
smart_proxy_id: smart_proxy.id,
|
38
|
+
destination_server: destination_server).output
|
45
39
|
|
46
40
|
plan_action(::Actions::Pulp3::ContentViewVersion::Export,
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
41
|
+
content_view_version_id: content_view_version.id,
|
42
|
+
smart_proxy_id: smart_proxy.id,
|
43
|
+
exporter_data: action_output[:exporter_data],
|
44
|
+
chunk_size: chunk_size,
|
45
|
+
from_content_view_version_id: from_content_view_version&.id)
|
46
|
+
|
47
|
+
history_output = plan_action(
|
48
|
+
::Actions::Pulp3::ContentViewVersion::CreateExportHistory,
|
49
|
+
smart_proxy_id: smart_proxy.id,
|
50
|
+
exporter_data: action_output[:exporter_data],
|
51
|
+
pulp_href: action_output[:exporter_data][:pulp_href],
|
52
|
+
content_view_version_id: content_view_version.id,
|
53
|
+
from_content_view_version_id: from_content_view_version&.id,
|
54
|
+
destination_server: destination_server
|
55
|
+
).output
|
56
|
+
|
57
|
+
plan_action(::Actions::Pulp3::ContentViewVersion::DestroyExporter,
|
58
|
+
smart_proxy_id: smart_proxy.id,
|
59
|
+
exporter_data: action_output[:exporter_data])
|
52
60
|
|
53
61
|
plan_self(exporter_data: action_output[:exporter_data], smart_proxy_id: smart_proxy.id,
|
54
62
|
destination_server: destination_server,
|
55
63
|
content_view_version_id: content_view_version.id,
|
56
|
-
from_content_view_version_id: from_content_view_version&.id
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
exporter_data: action_output[:exporter_data])
|
64
|
+
from_content_view_version_id: from_content_view_version&.id,
|
65
|
+
export_history_id: history_output[:export_history_id],
|
66
|
+
exported_file_checksum: history_output[:exported_file_checksum],
|
67
|
+
export_path: history_output[:path])
|
61
68
|
end
|
62
69
|
end
|
63
70
|
|
64
71
|
def run
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
file_name = output[:exported_file_checksum].first&.first
|
70
|
-
path = File.dirname(file_name.to_s)
|
71
|
-
output[:export_path] = path
|
72
|
-
cvv = ::Katello::ContentViewVersion.find(input[:content_view_version_id])
|
73
|
-
from_cvv = ::Katello::ContentViewVersion.find(input[:from_content_view_version_id]) unless input[:from_content_view_version_id].blank?
|
74
|
-
|
75
|
-
export_metadata = ::Katello::Pulp3::ContentViewVersion::Export.new(
|
76
|
-
content_view_version: cvv,
|
77
|
-
smart_proxy: smart_proxy,
|
78
|
-
from_content_view_version: from_cvv).generate_metadata
|
79
|
-
|
80
|
-
toc_path_info = output[:exported_file_checksum].find { |item| item.first.end_with?("toc.json") }
|
81
|
-
export_metadata[:toc] = File.basename(toc_path_info.first)
|
82
|
-
|
83
|
-
history = ::Katello::ContentViewVersionExportHistory.create!(
|
84
|
-
content_view_version_id: input[:content_view_version_id],
|
85
|
-
destination_server: input[:destination_server],
|
86
|
-
path: path,
|
87
|
-
metadata: export_metadata
|
72
|
+
output.update(
|
73
|
+
export_history_id: input[:export_history_id],
|
74
|
+
export_path: input[:export_path],
|
75
|
+
exported_file_checksum: input[:exported_file_checksum]
|
88
76
|
)
|
89
|
-
output[:export_history_id] = history.id
|
90
|
-
end
|
91
|
-
|
92
|
-
def humanized_name
|
93
|
-
_("Export")
|
94
77
|
end
|
95
78
|
|
96
79
|
def rescue_strategy
|
@@ -13,12 +13,12 @@ module Actions
|
|
13
13
|
content_view = ::Katello::Pulp3::ContentViewVersion::Export.find_library_export_view(destination_server: destination_server,
|
14
14
|
organization: organization,
|
15
15
|
create_by_default: true)
|
16
|
-
repo_ids_in_library = organization.default_content_view_version.repositories.
|
16
|
+
repo_ids_in_library = organization.default_content_view_version.repositories.exportable.immediate_or_none.pluck(:id)
|
17
17
|
content_view.update!(repository_ids: repo_ids_in_library)
|
18
18
|
|
19
19
|
sequence do
|
20
20
|
publish_action = plan_action(::Actions::Katello::ContentView::Publish, content_view, '')
|
21
|
-
export_action = plan_action(
|
21
|
+
export_action = plan_action(Actions::Katello::ContentViewVersion::Export,
|
22
22
|
content_view_version: publish_action.version,
|
23
23
|
destination_server: destination_server,
|
24
24
|
chunk_size: chunk_size,
|
@@ -26,10 +26,22 @@ module Actions
|
|
26
26
|
|
27
27
|
plan_action(Actions::Pulp3::Repository::SaveVersions, content_view_version.importable_repositories.pluck(:id),
|
28
28
|
tasks: import_output[:pulp_tasks])
|
29
|
-
|
29
|
+
plan_action(
|
30
|
+
::Actions::Pulp3::ContentViewVersion::CreateImportHistory,
|
31
|
+
content_view_version_id: content_view_version.id,
|
32
|
+
path: path,
|
33
|
+
metadata: metadata,
|
34
|
+
content_view_name: content_view_version.name
|
35
|
+
)
|
30
36
|
plan_action(::Actions::Pulp3::ContentViewVersion::DestroyImporter,
|
31
37
|
smart_proxy_id: smart_proxy.id,
|
32
38
|
importer_data: importer_output[:importer_data])
|
39
|
+
plan_self(
|
40
|
+
content_view_name: content_view_version.name,
|
41
|
+
metadata: metadata,
|
42
|
+
path: path,
|
43
|
+
content_view_version_id: content_view_version.id
|
44
|
+
)
|
33
45
|
end
|
34
46
|
end
|
35
47
|
|
@@ -6,6 +6,7 @@ module Actions
|
|
6
6
|
include Actions::Helpers::OutputPropagator
|
7
7
|
def plan(repository, smart_proxy, options)
|
8
8
|
sequence do
|
9
|
+
plan_action(Actions::Pulp3::Repository::RefreshRemote, repository, smart_proxy)
|
9
10
|
action_output = plan_action(Actions::Pulp3::Repository::Sync, repository, smart_proxy, options).output
|
10
11
|
|
11
12
|
force_fetch_version = true if options[:optimize] == false
|
@@ -0,0 +1,17 @@
|
|
1
|
+
module Actions
|
2
|
+
module Pulp3
|
3
|
+
module Repository
|
4
|
+
class RefreshRemote < Pulp3::AbstractAsyncTask
|
5
|
+
def plan(repository, smart_proxy)
|
6
|
+
plan_self(repository_id: repository.id, smart_proxy_id: smart_proxy.id)
|
7
|
+
end
|
8
|
+
|
9
|
+
def invoke_external_task
|
10
|
+
repo = ::Katello::Repository.find(input[:repository_id])
|
11
|
+
backend = repo.backend_service(smart_proxy)
|
12
|
+
backend.update_remote if backend.remote_needs_updates?
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -34,17 +34,9 @@ module Katello
|
|
34
34
|
private
|
35
35
|
|
36
36
|
def handle_dynflow_event
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
unless task
|
42
|
-
logger.info("Task external_id=#{@dispatch_history.dynflow_execution_plan_id} wasn't found. Skipping dynflow event dispatch")
|
43
|
-
return
|
44
|
-
end
|
45
|
-
|
46
|
-
unless task.result == 'pending'
|
47
|
-
logger.info("Task is no longer pending. Skipping dynflow event dispatch. task_result=#{task.result} external_id=#{@dispatch_history.dynflow_execution_plan_id} dispatch_history_id=#{@dispatch_history.id}")
|
37
|
+
task_exists = ForemanTasks::Task.exists?(external_id: @dispatch_history.dynflow_execution_plan_id, result: 'pending')
|
38
|
+
unless task_exists
|
39
|
+
logger.warn("Couldn't find pending task with external_id=#{@dispatch_history.dynflow_execution_plan_id} dispatch_history_id=#{@dispatch_history.id}")
|
48
40
|
return
|
49
41
|
end
|
50
42
|
|
@@ -2,40 +2,83 @@ module Katello
|
|
2
2
|
module Concerns
|
3
3
|
module BaseTemplateScopeExtensions
|
4
4
|
extend ActiveSupport::Concern
|
5
|
+
extend ApipieDSL::Module
|
5
6
|
|
7
|
+
apipie :class, 'Base macros related to content hosts to use within a template' do
|
8
|
+
name 'Base Content'
|
9
|
+
sections only: %w[all reports provisioning jobs partition_tables]
|
10
|
+
end
|
11
|
+
|
12
|
+
apipie :method, 'Returns an erratum by ID' do
|
13
|
+
required :id, Integer, desc: 'Errata ID'
|
14
|
+
returns Object, desc: 'The erratum object'
|
15
|
+
end
|
6
16
|
def errata(id)
|
7
17
|
Katello::Erratum.in_repositories(Katello::Repository.readable).with_identifiers(id).map(&:attributes).first.slice!('created_at', 'updated_at')
|
8
18
|
end
|
9
19
|
|
20
|
+
apipie :method, 'Returns subscriptions for the host' do
|
21
|
+
required :host, 'Host::Managed', desc: 'Host object to get subscriptions for'
|
22
|
+
returns array_of: 'Subscription', desc: 'Array with subscription object'
|
23
|
+
end
|
10
24
|
def host_subscriptions(host)
|
11
25
|
host.subscriptions
|
12
26
|
end
|
13
27
|
|
28
|
+
apipie :method, 'Returns subscription names for the host' do
|
29
|
+
required :host, 'Host::Managed', desc: 'Host object to get subscriptions for'
|
30
|
+
returns array_of: String, desc: "Array with names of host's subscriptions"
|
31
|
+
end
|
14
32
|
def host_subscriptions_names(host)
|
15
33
|
host.subscriptions.map(&:name)
|
16
34
|
end
|
17
35
|
|
36
|
+
apipie :method, 'Returns Red Hat subscription names for the host' do
|
37
|
+
required :host, 'Host::Managed', desc: 'Host object to get subscriptions for'
|
38
|
+
returns array_of: String, desc: "Array with names of host's subscriptions"
|
39
|
+
end
|
18
40
|
def host_redhat_subscription_names(host)
|
19
41
|
host.subscriptions.redhat.pluck(:name)
|
20
42
|
end
|
21
43
|
|
44
|
+
apipie :method, 'Returns the count of Red Hat subscriptions consumed for the host' do
|
45
|
+
required :host, 'Host::Managed', desc: 'Host object to get subscriptions for'
|
46
|
+
returns Integer, desc: "Count of consumed Red Hat subscriptions"
|
47
|
+
end
|
22
48
|
def host_redhat_subscriptions_consumed(host)
|
23
49
|
presenter = ::Katello::HostSubscriptionsPresenter.new(host)
|
24
50
|
presenter.subscriptions.select(&:redhat?).sum(&:quantity_consumed)
|
25
51
|
end
|
26
52
|
|
53
|
+
apipie :method, 'Returns content facet for the host' do
|
54
|
+
desc "Content facet is an object containing the host's content-related metadata and associations"
|
55
|
+
required :host, 'Host::Managed', desc: 'Host object to get content facet for'
|
56
|
+
returns 'ContentFacet'
|
57
|
+
end
|
27
58
|
def host_content_facet(host)
|
28
59
|
host.content_facet
|
29
60
|
end
|
30
61
|
|
62
|
+
apipie :method, 'Returns service level for the host' do
|
63
|
+
required :host, 'Host::Managed', desc: 'Host object to get service level for'
|
64
|
+
returns String, example: 'host_sla(host) #=> "Standard"'
|
65
|
+
end
|
31
66
|
def host_sla(host)
|
32
67
|
host_subscription_facet(host)&.service_level
|
33
68
|
end
|
34
69
|
|
70
|
+
apipie :method, 'Returns installed products for the host' do
|
71
|
+
required :host, 'Host::Managed', desc: 'Host object to get products for'
|
72
|
+
returns array_of: 'Product', desc: "Array of installed product objects on the host"
|
73
|
+
end
|
35
74
|
def host_products(host)
|
36
75
|
host_subscription_facet(host)&.installed_products
|
37
76
|
end
|
38
77
|
|
78
|
+
apipie :method, 'Returns installed product names for the host' do
|
79
|
+
required :host, 'Host::Managed', desc: 'Host object to get products for'
|
80
|
+
returns array_of: String, desc: 'Array with names of installed products on the host'
|
81
|
+
end
|
39
82
|
def host_products_names(host)
|
40
83
|
products = host_products(host)
|
41
84
|
if products
|
@@ -45,52 +88,113 @@ module Katello
|
|
45
88
|
end
|
46
89
|
end
|
47
90
|
|
91
|
+
apipie :method, 'Returns the host collections the host belongs to' do
|
92
|
+
required :host, 'Host::Managed', desc: 'Host object to get the host collections for'
|
93
|
+
returns array_of: 'HostCollection', desc: "Array of the host collection objects the host belongs to"
|
94
|
+
end
|
48
95
|
def host_collections(host)
|
49
96
|
host.host_collections
|
50
97
|
end
|
51
98
|
|
99
|
+
apipie :method, 'Returns names of the host collections the host belongs to' do
|
100
|
+
required :host, 'Host::Managed', desc: 'Host object to get the host collections for'
|
101
|
+
returns array_of: String, desc: 'Array with names of the host collections the host belongs to'
|
102
|
+
end
|
52
103
|
def host_collections_names(host)
|
53
104
|
host.host_collections.map(&:name)
|
54
105
|
end
|
55
106
|
|
107
|
+
apipie :method, 'Returns subscription name of the pool' do
|
108
|
+
required :pool, 'Katello::Pool', desc: 'Pool object to get subscription name of'
|
109
|
+
returns String, desc: 'Name of the subscription'
|
110
|
+
end
|
56
111
|
def sub_name(pool)
|
57
112
|
return unless pool
|
58
113
|
pool.subscription&.name
|
59
114
|
end
|
60
115
|
|
116
|
+
apipie :method, 'Returns subscription SKU' do
|
117
|
+
required :pool, 'Katello::Pool', desc: 'Pool object to get subscription SKU of'
|
118
|
+
returns String, desc: "SKU's ID of the subscription"
|
119
|
+
end
|
61
120
|
def sub_sku(pool)
|
62
121
|
return unless pool
|
63
122
|
pool.subscription&.cp_id
|
64
123
|
end
|
65
124
|
|
125
|
+
apipie :method, 'Returns the smart proxy that the host was registered through' do
|
126
|
+
required :host, 'Host::Managed', desc: 'Host object to get smart proxy of'
|
127
|
+
returns String, desc: 'Hostname of the smart proxy'
|
128
|
+
end
|
66
129
|
def registered_through(host)
|
67
130
|
host_subscription_facet(host)&.registered_through
|
68
131
|
end
|
69
132
|
|
133
|
+
apipie :method, 'Returns time the host was registered at' do
|
134
|
+
required :host, 'Host::Managed', desc: 'Host object to get registration time of'
|
135
|
+
returns 'ActiveSupport::TimeWithZone', desc: 'Registration time of the host'
|
136
|
+
end
|
70
137
|
def registered_at(host)
|
71
138
|
host_subscription_facet(host)&.registered_at
|
72
139
|
end
|
73
140
|
|
141
|
+
apipie :method, 'Returns IDs of the applicable errata on the host' do
|
142
|
+
required :host, 'Host::Managed', desc: 'Host object to get the applicable errata for'
|
143
|
+
returns array_of: Integer, desc: 'Array with applicable errata IDs of the host'
|
144
|
+
end
|
74
145
|
def host_applicable_errata_ids(host)
|
75
146
|
host.applicable_errata.map(&:errata_id)
|
76
147
|
end
|
77
148
|
|
149
|
+
apipie :method, 'Returns filtered applicable errata for the host' do
|
150
|
+
required :host, 'Host::Managed', desc: 'Host object to get the applicable errata for'
|
151
|
+
optional :filter, String, desc: 'Filter to apply on applicable errata', default: ''
|
152
|
+
returns array_of: 'Erratum', desc: 'Filtered applicable errata for the host'
|
153
|
+
end
|
78
154
|
def host_applicable_errata_filtered(host, filter = '')
|
79
155
|
host.applicable_errata.includes(:cves).search_for(filter)
|
80
156
|
end
|
81
157
|
|
158
|
+
apipie :method, 'Returns version of the latest applicable RPM package' do
|
159
|
+
required :host, 'Host::Managed', desc: 'Host object to get the applicable RPM package version on'
|
160
|
+
required :package, String, desc: 'Name of the package'
|
161
|
+
returns String, desc: 'Package version'
|
162
|
+
end
|
82
163
|
def host_latest_applicable_rpm_version(host, package)
|
83
164
|
host.applicable_rpms.where(name: package).order(:version_sortable).limit(1).pluck(:nvra).first
|
84
165
|
end
|
85
166
|
|
167
|
+
apipie :method, 'Loads Pool objects' do
|
168
|
+
desc 'This macro returns a collection of Pools matching search criteria.
|
169
|
+
The collection is loaded in bulk, 1000 records at a time.'
|
170
|
+
keyword :search, String, desc: 'A search term to limit the resulting collection, using standard search syntax', default: ''
|
171
|
+
keyword :includes, Array, of: [String, Symbol], desc: 'An array of associations represented by strings or symbols, to be included in the SQL query. The list can be extended
|
172
|
+
from plugins and can not be fully documented here. Most used associations are :subscription, :products, :organization', default: nil
|
173
|
+
returns array_of: 'Pool', desc: 'The collection that can be iterated over using each_record'
|
174
|
+
end
|
86
175
|
def load_pools(search: '', includes: nil)
|
87
176
|
load_resource(klass: Pool.readable, search: search, permission: nil, includes: includes)
|
88
177
|
end
|
89
178
|
|
179
|
+
apipie :method, 'Returns the last time the host checked in via RHSM' do
|
180
|
+
required :host, 'Host::Managed', desc: 'Host object to get the last time the host checked in'
|
181
|
+
returns 'ActiveSupport::TimeWithZone', desc: 'The last time the host checked in via RHSM'
|
182
|
+
end
|
90
183
|
def last_checkin(host)
|
91
184
|
host&.subscription_facet&.last_checkin
|
92
185
|
end
|
93
186
|
|
187
|
+
apipie :method, 'Load errata applications' do
|
188
|
+
desc 'This macro returns a collection of task records relating to errata being applied.
|
189
|
+
The collection is loaded in bulk, 1000 records at a time.'
|
190
|
+
keyword :filter_errata_type, String, desc: "Errata type. One of: #{Katello::Erratum::TYPES.join(', ')}", default: nil
|
191
|
+
keyword :include_last_reboot, String, desc: "Set to 'yes' to include the last reboot time of each host", default: 'yes'
|
192
|
+
keyword :since, String, desc: 'Return errata applications after this date'
|
193
|
+
keyword :up_to, String, desc: 'Return errata applications before this date'
|
194
|
+
keyword :status, String, desc: 'Task status. One of: "pending", "success", "error", "warning"'
|
195
|
+
keyword :host_filter, String, desc: 'A filter term to limit the resulting collection, using standard filter syntax', default: nil
|
196
|
+
returns array_of: 'Erratum', desc: 'The collection that can be iterated over using each_record'
|
197
|
+
end
|
94
198
|
# rubocop:disable Metrics/MethodLength
|
95
199
|
# rubocop:disable Metrics/AbcSize
|
96
200
|
# rubocop:disable Metrics/CyclomaticComplexity
|
@@ -101,13 +205,13 @@ module Katello
|
|
101
205
|
filter_errata_type = filter_errata_type.presence || 'all'
|
102
206
|
search_up_to = up_to.present? ? "ended_at < \"#{up_to}\"" : nil
|
103
207
|
search_since = since.present? ? "ended_at > \"#{since}\"" : nil
|
104
|
-
search_result = status.present? ? "result = #{status}" : nil
|
208
|
+
search_result = status.present? && status != 'all' ? "result = #{status}" : nil
|
105
209
|
search = [search_up_to, search_since, search_result].compact.join(' and ')
|
106
210
|
|
107
211
|
if Katello.with_remote_execution?
|
108
|
-
condition = ["state != '
|
212
|
+
condition = ["state != 'stopped' AND (label = 'Actions::RemoteExecution::RunHostJob' AND templates.id = ?) OR label = 'Actions::Katello::Host::Erratum::Install'", RemoteExecutionFeature.feature('katello_errata_install').job_template_id]
|
109
213
|
else
|
110
|
-
condition = "state != '
|
214
|
+
condition = "state != 'stopped' AND label = 'Actions::Katello::Host::Erratum::Install'"
|
111
215
|
end
|
112
216
|
|
113
217
|
tasks = load_resource(klass: ForemanTasks::Task,
|
@@ -165,10 +269,20 @@ module Katello
|
|
165
269
|
end
|
166
270
|
# rubocop:enable Metrics/MethodLength
|
167
271
|
|
272
|
+
apipie :method, 'Converts package version to be sortable' do
|
273
|
+
required :version, String, desc: 'Version to convert'
|
274
|
+
returns String, desc: 'Sortable version of a package'
|
275
|
+
example 'For usage example please refer to **Host - compare content hosts packages** report template'
|
276
|
+
end
|
168
277
|
def sortable_version(version)
|
169
278
|
Util::Package.sortable_version(version)
|
170
279
|
end
|
171
280
|
|
281
|
+
apipie :method, 'Returns true if Katello Agent infrastructure is enabled on the server'
|
282
|
+
def katello_agent_enabled?
|
283
|
+
Katello.with_katello_agent?
|
284
|
+
end
|
285
|
+
|
172
286
|
private
|
173
287
|
|
174
288
|
def host_subscription_facet(host)
|
data/app/lib/katello/errors.rb
CHANGED
@@ -1,11 +1,11 @@
|
|
1
1
|
module Katello
|
2
2
|
module Errors
|
3
|
+
class PingError < StandardError; end
|
4
|
+
|
3
5
|
class InvalidActionOptionError < StandardError; end
|
4
6
|
|
5
7
|
class InvalidRepositoryContent < StandardError; end
|
6
8
|
|
7
|
-
class InvalidPuppetModuleError < InvalidRepositoryContent; end
|
8
|
-
|
9
9
|
class NotFound < StandardError; end
|
10
10
|
|
11
11
|
class RegistrationError < StandardError; end
|
@@ -53,7 +53,7 @@ module Katello
|
|
53
53
|
|
54
54
|
class PulpcoreMissingCapabilities < StandardError
|
55
55
|
def message
|
56
|
-
_("A smart proxy seems to have been refreshed without pulpcore being running.
|
56
|
+
_("A smart proxy seems to have been refreshed without pulpcore being running. You may want to ")
|
57
57
|
end
|
58
58
|
end
|
59
59
|
|
@@ -91,14 +91,6 @@ module Katello
|
|
91
91
|
end
|
92
92
|
end
|
93
93
|
|
94
|
-
class PuppetConflictException < StandardError
|
95
|
-
attr_accessor :conflicts
|
96
|
-
|
97
|
-
def initialize(conflicts)
|
98
|
-
self.conflicts = conflicts
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
94
|
class CandlepinError < StandardError
|
103
95
|
# Return a CandlepinError with the displayMessage
|
104
96
|
# as the message set it
|
@@ -112,6 +104,9 @@ module Katello
|
|
112
104
|
end
|
113
105
|
end
|
114
106
|
|
107
|
+
class CandlepinNotRunning < StandardError; end
|
108
|
+
class CandlepinPoolGone < CandlepinError; end
|
109
|
+
|
115
110
|
class Pulp3Error < StandardError; end
|
116
111
|
class Pulp3MigrationError < StandardError; end
|
117
112
|
|
@@ -17,7 +17,7 @@ module Katello
|
|
17
17
|
def pid
|
18
18
|
return unless pid_file && File.exist?(pid_file)
|
19
19
|
|
20
|
-
File.
|
20
|
+
File.read(pid_file).to_i
|
21
21
|
end
|
22
22
|
|
23
23
|
def pid_file
|
@@ -36,7 +36,7 @@ module Katello
|
|
36
36
|
return unless pid_file
|
37
37
|
|
38
38
|
FileUtils.mkdir_p(pid_dir)
|
39
|
-
File.
|
39
|
+
File.write(pid_file, Process.pid)
|
40
40
|
end
|
41
41
|
|
42
42
|
def stop
|