katello 3.1.0.1 → 3.2.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/README.md +8 -47
- data/app/assets/javascripts/katello/common/index.js +0 -1
- data/app/assets/javascripts/katello/providers/redhat/index.js +0 -1
- data/app/assets/stylesheets/katello/_katello_colors.scss +0 -2
- data/app/assets/stylesheets/katello/katello.scss +0 -2
- data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +45 -42
- data/app/controllers/katello/api/v2/activation_keys_controller.rb +7 -19
- data/app/controllers/katello/api/v2/api_controller.rb +3 -3
- data/app/controllers/katello/api/v2/capsule_content_controller.rb +3 -3
- data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -2
- data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +29 -18
- data/app/controllers/katello/api/v2/content_view_filters_controller.rb +2 -2
- data/app/controllers/katello/api/v2/content_view_histories_controller.rb +1 -1
- data/app/controllers/katello/api/v2/content_view_puppet_modules_controller.rb +2 -2
- data/app/controllers/katello/api/v2/content_view_versions_controller.rb +10 -8
- data/app/controllers/katello/api/v2/content_views_controller.rb +5 -5
- data/app/controllers/katello/api/v2/environments_controller.rb +10 -9
- data/app/controllers/katello/api/v2/file_units_controller.rb +16 -0
- data/app/controllers/katello/api/v2/gpg_keys_controller.rb +4 -4
- data/app/controllers/katello/api/v2/host_autocomplete_controller.rb +2 -2
- data/app/controllers/katello/api/v2/host_collections_controller.rb +41 -13
- data/app/controllers/katello/api/v2/host_errata_controller.rb +12 -5
- data/app/controllers/katello/api/v2/host_packages_controller.rb +4 -4
- data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +9 -9
- data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +52 -13
- data/app/controllers/katello/api/v2/organizations_controller.rb +3 -3
- data/app/controllers/katello/api/v2/packages_controller.rb +1 -1
- data/app/controllers/katello/api/v2/ping_controller.rb +2 -2
- data/app/controllers/katello/api/v2/products_bulk_actions_controller.rb +2 -2
- data/app/controllers/katello/api/v2/products_controller.rb +6 -16
- data/app/controllers/katello/api/v2/repositories_bulk_actions_controller.rb +1 -1
- data/app/controllers/katello/api/v2/repositories_controller.rb +60 -21
- data/app/controllers/katello/api/v2/repository_sets_controller.rb +3 -3
- data/app/controllers/katello/api/v2/root_controller.rb +2 -2
- data/app/controllers/katello/api/v2/subscriptions_controller.rb +19 -10
- data/app/controllers/katello/api/v2/sync_controller.rb +3 -3
- data/app/controllers/katello/api/v2/sync_plans_controller.rb +2 -2
- data/app/controllers/katello/api/v2/uebercerts_controller.rb +1 -1
- data/app/controllers/katello/application_controller.rb +7 -7
- data/app/controllers/katello/auto_complete_search_controller.rb +1 -1
- data/app/controllers/katello/concerns/api/api_controller.rb +1 -1
- data/app/controllers/katello/concerns/api/v2/hostgroups_controller_extensions.rb +19 -16
- data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +8 -6
- data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +10 -6
- data/app/controllers/katello/concerns/organizations_controller_extensions.rb +1 -1
- data/app/controllers/katello/concerns/smart_proxies_controller_extensions.rb +1 -1
- data/app/controllers/katello/errors_controller.rb +2 -2
- data/app/controllers/katello/organizations_controller.rb +1 -1
- data/app/controllers/katello/products_controller.rb +4 -4
- data/app/controllers/katello/providers_controller.rb +2 -2
- data/app/helpers/katello/application_helper.rb +0 -240
- data/app/helpers/katello/concerns/hosts_and_hostgroups_helper_extensions.rb +19 -0
- data/app/lib/actions/candlepin/import_pool_handler.rb +11 -6
- data/app/lib/actions/katello/capsule_content/create_repos.rb +3 -3
- data/app/lib/actions/katello/capsule_content/sync.rb +23 -9
- data/app/lib/actions/katello/content_view/add_to_environment.rb +1 -1
- data/app/lib/actions/katello/content_view/errata_mail.rb +2 -2
- data/app/lib/actions/katello/content_view/incremental_updates.rb +60 -1
- data/app/lib/actions/katello/content_view/remove.rb +2 -2
- data/app/lib/actions/katello/content_view_environment/destroy.rb +1 -1
- data/app/lib/actions/katello/content_view_environment/reassign_objects.rb +2 -2
- data/app/lib/actions/katello/content_view_puppet_environment/create.rb +3 -1
- data/app/lib/actions/katello/host/attach_subscriptions.rb +13 -6
- data/app/lib/actions/katello/host/destroy.rb +0 -19
- data/app/lib/actions/katello/host/generate_applicability.rb +8 -3
- data/app/lib/actions/katello/host/hypervisors.rb +17 -9
- data/app/lib/actions/katello/host/hypervisors_update.rb +19 -44
- data/app/lib/actions/katello/host/reassign.rb +14 -0
- data/app/lib/actions/katello/host/register.rb +3 -22
- data/app/lib/actions/katello/host/remove_subscriptions.rb +15 -2
- data/app/lib/actions/katello/host/update.rb +0 -6
- data/app/lib/actions/katello/organization/destroy.rb +2 -2
- data/app/lib/actions/katello/product/content_destroy.rb +7 -9
- data/app/lib/actions/katello/product/destroy.rb +23 -7
- data/app/lib/actions/katello/repository/clear.rb +1 -0
- data/app/lib/actions/katello/repository/clone_file_content.rb +17 -0
- data/app/lib/actions/katello/repository/clone_to_environment.rb +2 -0
- data/app/lib/actions/katello/repository/clone_to_version.rb +2 -0
- data/app/lib/actions/katello/repository/create.rb +2 -1
- data/app/lib/actions/katello/repository/destroy.rb +20 -10
- data/app/lib/actions/katello/repository/errata_mail.rb +2 -2
- data/app/lib/actions/katello/repository/filtered_index_content.rb +2 -0
- data/app/lib/actions/katello/repository/import_upload.rb +6 -2
- data/app/lib/actions/katello/repository/{refresh_repostiory.rb → refresh_repository.rb} +0 -0
- data/app/lib/actions/katello/repository/remove_content.rb +2 -0
- data/app/lib/actions/katello/repository/sync.rb +8 -12
- data/app/lib/actions/katello/repository_set/disable_repository.rb +6 -5
- data/app/lib/actions/katello/repository_set/enable_repository.rb +1 -1
- data/app/lib/actions/katello/repository_set/scan_cdn.rb +1 -1
- data/app/lib/actions/pulp/abstract_async_task.rb +1 -1
- data/app/lib/actions/pulp/consumer/unassociate_units.rb +20 -0
- data/app/lib/actions/pulp/repository/copy_files.rb +11 -0
- data/app/lib/actions/pulp/repository/create.rb +5 -1
- data/app/lib/actions/pulp/repository/presenters/file_presenter.rb +1 -1
- data/app/lib/actions/pulp/repository/refresh.rb +4 -2
- data/app/lib/actions/pulp/repository/remove_file.rb +15 -0
- data/app/lib/actions/pulp/repository/sync.rb +3 -1
- data/app/lib/actions/pulp/repository_group/export.rb +1 -1
- data/app/lib/katello/errors.rb +1 -1
- data/app/lib/katello/lazy_accessor.rb +1 -1
- data/app/lib/katello/resources/candlepin.rb +14 -0
- data/app/lib/katello/util/cdn_var_substitutor.rb +5 -2
- data/app/lib/katello/util/model.rb +1 -2
- data/app/lib/katello/util/package.rb +2 -2
- data/app/models/katello/activation_key.rb +0 -49
- data/app/models/katello/authorization/content_view_version.rb +7 -0
- data/app/models/katello/candlepin/content.rb +15 -3
- data/app/models/katello/concerns/container_extensions.rb +1 -2
- data/app/models/katello/concerns/content_facet_host_extensions.rb +11 -1
- data/app/models/katello/concerns/host_managed_extensions.rb +4 -13
- data/app/models/katello/concerns/hostgroup_extensions.rb +0 -2
- data/app/models/katello/concerns/medium_extensions.rb +2 -2
- data/app/models/katello/concerns/organization_extensions.rb +0 -5
- data/app/models/katello/concerns/pulp_database_unit.rb +5 -1
- data/app/models/katello/concerns/smart_proxy_extensions.rb +21 -1
- data/app/models/katello/concerns/subscription_facet_host_extensions.rb +1 -2
- data/app/models/katello/content_view.rb +12 -6
- data/app/models/katello/content_view_component.rb +0 -3
- data/app/models/katello/content_view_environment.rb +2 -2
- data/app/models/katello/content_view_package_filter_rule.rb +13 -0
- data/app/models/katello/content_view_puppet_environment.rb +2 -2
- data/app/models/katello/content_view_repository.rb +2 -1
- data/app/models/katello/content_view_version.rb +9 -2
- data/app/models/katello/erratum.rb +1 -5
- data/app/models/katello/file_unit.rb +41 -0
- data/app/models/katello/glue/candlepin/activation_key.rb +2 -2
- data/app/models/katello/glue/candlepin/pool.rb +19 -14
- data/app/models/katello/glue/pulp/repo.rb +44 -10
- data/app/models/katello/host/content_facet.rb +6 -6
- data/app/models/katello/host/subscription_facet.rb +6 -8
- data/app/models/katello/kt_environment.rb +3 -5
- data/app/models/katello/package_group.rb +1 -3
- data/app/models/katello/pool.rb +7 -2
- data/app/models/katello/pool_with_quantities.rb +12 -0
- data/app/models/katello/product.rb +6 -0
- data/app/models/katello/provider.rb +1 -1
- data/app/models/katello/puppet_module.rb +1 -2
- data/app/models/katello/repository.rb +7 -3
- data/app/models/katello/repository_file.rb +9 -0
- data/app/models/katello/rpm.rb +1 -1
- data/app/models/katello/subscription_status.rb +1 -1
- data/app/models/katello/sync_plan.rb +2 -1
- data/app/models/katello/task_status.rb +3 -36
- data/app/models/setting/content.rb +4 -1
- data/app/overrides/add_activation_keys_input.rb +2 -2
- data/app/presenters/katello/activation_key_subscriptions_presenter.rb +10 -0
- data/app/services/katello/candlepin/consumer.rb +5 -1
- data/app/services/katello/pulp/file_unit.rb +13 -0
- data/app/views/dashboard/_errata_widget.html.erb +1 -1
- data/app/views/dashboard/_subscription_widget.html.erb +30 -8
- data/app/views/foreman/job_templates/install_errata.erb +1 -1
- data/app/views/katello/api/v2/activation_keys/product_content.json.rabl +1 -0
- data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +2 -2
- data/app/views/katello/api/v2/content_facet/base.json.rabl +2 -4
- data/app/views/katello/api/v2/{systems → content_facet}/erratum.json.rabl +0 -0
- data/app/views/katello/api/v2/content_facet/show.json.rabl +1 -1
- data/app/views/katello/api/v2/content_view_versions/base.json.rabl +5 -4
- data/app/views/katello/api/v2/environments/show.json.rabl +1 -1
- data/app/views/katello/api/v2/file_units/base.json.rabl +7 -0
- data/app/views/katello/api/v2/{systems → file_units}/index.json.rabl +1 -1
- data/app/views/katello/api/v2/file_units/show.json.rabl +3 -0
- data/app/views/katello/api/v2/host_errata/index.json.rabl +1 -1
- data/app/views/katello/api/v2/host_errata/show.json.rabl +1 -1
- data/app/views/katello/api/v2/package_groups/base.json.rabl +1 -1
- data/app/views/katello/api/v2/ping/show.json.rabl +1 -1
- data/app/views/katello/api/v2/repositories/base.json.rabl +2 -1
- data/app/views/katello/api/v2/repositories/show.json.rabl +1 -1
- data/app/views/katello/api/v2/subscription_facet/base.json.rabl +1 -1
- data/app/views/katello/api/v2/subscription_facet/base_with_root.json.rabl +0 -4
- data/app/views/katello/api/v2/subscription_facet/show.json.rabl +1 -5
- data/app/views/katello/api/v2/subscriptions/base.json.rabl +3 -3
- data/app/views/katello/api/v2/subscriptions/index.json.rabl +1 -0
- data/app/views/katello/api/v2/tasks/task_status_show.json.rabl +0 -1
- data/app/views/katello/providers/redhat/show.html.erb +1 -1
- data/app/views/katello/sync_management/_products.html.erb +5 -1
- data/app/views/overrides/activation_keys/_host_environment_select.html.erb +1 -9
- data/app/views/overrides/activation_keys/_host_synced_content_select.html.erb +1 -0
- data/config/routes/api/v2.rb +9 -2
- data/config/routes/overrides.rb +9 -0
- data/db/migrate/20150930183738_migrate_content_hosts.rb +1 -1
- data/db/migrate/20160617124149_remove_duplicate_view_filters.rb +38 -0
- data/db/migrate/20160627125310_delete_system.rb +7 -0
- data/db/migrate/20160722193256_add_verify_ssl_on_sync_to_repository.rb +9 -0
- data/db/migrate/20160727144242_add_registered_through_to_katello_subscription_facets.rb +5 -0
- data/db/migrate/20160808002834_add_files.rb +30 -0
- data/db/migrate/20160906181923_add_puppet_path_to_smart_proxy.rb +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/activation-keys.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/activation-key-associations.controller.js +7 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-add-subscriptions.html +6 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-associations-content-hosts.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-details.html +101 -102
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/details/views/activation-key-subscriptions-list.html +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/new/views/activation-key-new.html +82 -83
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/activation-keys/views/activation-keys.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/bastion-katello-bootstrap.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.module.js +3 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsules/capsules.module.js +4 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/common.module.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/views/registration.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-action-subscriptions.controller.js +46 -72
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/content-hosts-bulk-action.controller.js +1 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/bulk-actions-errata.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/bulk-actions-host-collections.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/bulk-actions-subscriptions.html +79 -33
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-hosts.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/content-host-errata.controller.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-errata.html +27 -15
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content/views/content-host-packages.html +57 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-add-subscriptions.controller.js +5 -18
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-base-subscriptions.controller.js +2 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-details.controller.js +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/content-host-subscriptions.controller.js +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-add-subscriptions.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-details.html +117 -118
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +13 -8
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-subscriptions-list.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +26 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +11 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +3 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +47 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +45 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +6 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-module-names.html +6 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/puppet-modules/views/content-view-puppet-modules.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-composite-available-content-views.html +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-composite-content-views-list.html +2 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +151 -140
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +118 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +13 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +8 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-versions.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +8 -6
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +22 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +6 -16
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/docker-manifests/docker-manifests.module.js +6 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/docker-tags/details/views/docker-tags-details.html +59 -61
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/docker-tags/docker-tags.module.js +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/docker-tags/views/docker-tags.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-docker.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-errata.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-ostree.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-packages.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-puppet-modules.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-repositories.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/details/errata-content-hosts.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/details/views/errata-details-content-hosts.html +6 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/details/views/errata-details-repositories.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/details/views/errata-details.html +44 -45
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/errata.module.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/errata/views/errata.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/gpg-key-details-info.controller.js +11 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/gpg-key-details.controller.js +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/views/gpg-key-details.html +52 -48
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/views/gpg-key-info.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/views/gpg-key-products.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/details/views/gpg-key-repositories.html +1 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/gpg-keys.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/new/views/gpg-key-new.html +62 -63
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/gpg-keys/views/gpg-keys.html +6 -3
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-add-hosts.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-details.html +85 -86
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/details/views/host-collection-hosts-list.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/host-collections.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/new/views/host-collection-new.html +16 -17
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/host-collections/views/host-collections.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/host-bulk-action.factory.js +28 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/host-erratum.factory.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/host.factory.js +1 -27
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/hosts/hosts.module.js +3 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/organization.factory.js +0 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/organizations/organizations.module.js +4 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/ostree-branches-details-repositories.controller.js +60 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/ostree-branches-details.controller.js +31 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/views/ostree-branches-details-info.html +23 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/views/ostree-branches-details-repositories.html +83 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/details/views/ostree-branches-details.html +43 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/ostree-branches.controller.js +67 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/ostree-branches.module.js +5 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/ostree-branches.routes.js +53 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/views/ostree-branches-table-collapsed.html +19 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/views/ostree-branches-table-full.html +21 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/ostree-branches/views/ostree-branches.html +19 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/package-groups/package-groups.module.js +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/package-details.controller.js +17 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/views/packages-details-info.html +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/views/packages-details-repositories.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/details/views/packages-details.html +51 -52
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/packages.module.js +3 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/packages/views/packages.html +5 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/views/product-details.html +72 -73
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/views/product-repositories.html +19 -7
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/discovery/views/discovery-create.html +144 -145
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/new/views/product-new.html +17 -18
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/views/products.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/details/views/puppet-modules-details.html +44 -40
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/puppet-modules.module.js +7 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/puppet-modules/views/puppet-modules.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/repositories/details/repository-details-info.controller.js +11 -5
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/repositories/details/views/repository-info.html +343 -324
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/repositories/new/new-repository.controller.js +4 -4
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/repositories/new/views/repository-new.html +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/repositories/repositories.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/settings/settings.module.js +2 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/details/views/subscription-associations-content-hosts.html +2 -2
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/details/views/subscription-details.html +46 -47
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/manifest/manifest-import.controller.js +10 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/manifest/views/manifest-import.html +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/manifest/views/manifest.html +41 -42
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscriptions-helper.service.js +15 -1
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/subscriptions.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/subscriptions/views/subscriptions.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/details/views/sync-plan-details.html +54 -55
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/sync-plans.module.js +1 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/sync-plans/views/sync-plans.html +4 -0
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/tasks/tasks.module.js +3 -1
- data/engines/bastion_katello/lib/bastion_katello/engine.rb +1 -0
- data/lib/katello/engine.rb +11 -1
- data/lib/katello/permissions/host_permissions.rb +13 -1
- data/lib/katello/plugin.rb +20 -1
- data/lib/katello/tasks/reimport.rake +1 -0
- data/lib/katello/tasks/test.rake +8 -0
- data/lib/katello/tasks/unify_hosts.rake +91 -0
- data/lib/katello/tasks/upgrade_check.rake +3 -2
- data/lib/katello/tasks/upgrades/3.0/update_subscription_facet_backend_data.rake +2 -4
- data/lib/katello/version.rb +1 -1
- data/lib/proxy_api/pulp.rb +7 -0
- data/lib/proxy_api/pulp_node.rb +7 -0
- metadata +79 -67
- data/app/assets/javascripts/katello/common/jquery.jeditable.custominputs.js +0 -180
- data/app/assets/javascripts/katello/widgets/jquery.jeditable.helpers.js +0 -247
- data/app/assets/stylesheets/katello/widgets/_scrollpane.scss +0 -66
- data/app/controllers/katello/api/v2/systems_controller.rb +0 -213
- data/app/helpers/katello/activation_keys_helper.rb +0 -4
- data/app/helpers/katello/host_collection_events_helper.rb +0 -7
- data/app/helpers/katello/katello_form_builder.rb +0 -150
- data/app/helpers/katello/packages_helper.rb +0 -67
- data/app/helpers/katello/subscriptions_helper.rb +0 -32
- data/app/helpers/katello/system_events_helper.rb +0 -4
- data/app/helpers/katello/system_packages_helper.rb +0 -42
- data/app/lib/actions/katello/repository/incremental_import.rb +0 -61
- data/app/lib/actions/katello/subscription/subscribe.rb +0 -26
- data/app/lib/actions/katello/system/destroy.rb +0 -17
- data/app/lib/actions/katello/system/reassign.rb +0 -14
- data/app/models/katello/authorization/system.rb +0 -53
- data/app/models/katello/glue/candlepin/consumer.rb +0 -386
- data/app/models/katello/glue/pulp/consumer.rb +0 -171
- data/app/models/katello/hypervisor.rb +0 -15
- data/app/models/katello/system.rb +0 -283
- data/app/models/katello/system_activation_key.rb +0 -8
- data/app/models/katello/system_repository.rb +0 -8
- data/app/presenters/katello/activation_key_subscription_presenter.rb +0 -10
- data/app/views/katello/api/v2/errata/_applicable_errata.json.rabl +0 -3
- data/app/views/katello/api/v2/subscriptions/create.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/_pool.json.rabl +0 -6
- data/app/views/katello/api/v2/systems/activate.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/add_host_collections.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/available_host_collections.json.rabl +0 -5
- data/app/views/katello/api/v2/systems/base.json.rabl +0 -35
- data/app/views/katello/api/v2/systems/enabled_repos.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/events.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/package.json.rabl +0 -5
- data/app/views/katello/api/v2/systems/package_profile.json.rabl +0 -7
- data/app/views/katello/api/v2/systems/pools.json.rabl +0 -7
- data/app/views/katello/api/v2/systems/regenerate_identity_certificates.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/remove_host_collections.json.rabl +0 -3
- data/app/views/katello/api/v2/systems/show.json.rabl +0 -64
- data/app/views/katello/api/v2/systems/subscriptions.json.rabl +0 -8
- data/app/views/katello/api/v2/systems/upload_package_profile.json.rabl +0 -3
- data/db/seeds.d/105-roles_permissions.rb +0 -71
- data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host.factory.js +0 -25
- data/lib/katello/permissions/content_host_permissions.rb +0 -30
- data/lib/katello/tasks/yard.rake +0 -9
- data/vendor/assets/stylesheets/katello/jquery.jscrollpane.css +0 -120
@@ -0,0 +1,31 @@
|
|
1
|
+
/**
|
2
|
+
* @ngdoc object
|
3
|
+
* @name Bastion.ostree-branches.controller:OstreeBranchesDetailsController
|
4
|
+
*
|
5
|
+
* @requires $scope
|
6
|
+
* @requires OstreeBranch
|
7
|
+
* @requires ApiErrorHandler
|
8
|
+
*
|
9
|
+
* @description
|
10
|
+
* Provides the functionality for the Ostree Branch action pane.
|
11
|
+
*/
|
12
|
+
angular.module('Bastion.ostree-branches').controller('OstreeBranchesDetailsController', ['$scope', 'OstreeBranch', 'ApiErrorHandler',
|
13
|
+
function ($scope, OstreeBranch, ApiErrorHandler) {
|
14
|
+
$scope.panel = {
|
15
|
+
error: false,
|
16
|
+
loading: true
|
17
|
+
};
|
18
|
+
|
19
|
+
if ($scope.branch) {
|
20
|
+
$scope.panel.loading = false;
|
21
|
+
}
|
22
|
+
|
23
|
+
$scope.branch = OstreeBranch.get({id: $scope.$stateParams.branchId}, function (branch) {
|
24
|
+
$scope.$broadcast('branch.loaded', branch);
|
25
|
+
$scope.panel.loading = false;
|
26
|
+
}, function (response) {
|
27
|
+
$scope.panel.loading = false;
|
28
|
+
ApiErrorHandler.handleGETRequestErrors(response, $scope);
|
29
|
+
});
|
30
|
+
}
|
31
|
+
]);
|
@@ -0,0 +1,23 @@
|
|
1
|
+
<span page-title ng-model="branch">{{ 'OSTree Branch: ' | translate }} {{ branch.name }}</span>
|
2
|
+
|
3
|
+
<section>
|
4
|
+
|
5
|
+
<div class="details">
|
6
|
+
<h4 translate>Branch Info</h4>
|
7
|
+
|
8
|
+
<div class="detail">
|
9
|
+
<span class="info-label" translate>Version</span>
|
10
|
+
<span class="info-value">{{ branch.version }}</span>
|
11
|
+
</div>
|
12
|
+
|
13
|
+
<div class="detail">
|
14
|
+
<span class="info-label" translate>Commit</span>
|
15
|
+
<span class="info-value">{{ branch.commit }}</span>
|
16
|
+
</div>
|
17
|
+
|
18
|
+
<div class="detail">
|
19
|
+
<span class="info-label" translate>Date</span>
|
20
|
+
<span class="info-value">{{ branch.version_date }}</span>
|
21
|
+
</div>
|
22
|
+
</div>
|
23
|
+
</section>
|
@@ -0,0 +1,83 @@
|
|
1
|
+
<span page-title ng-model="branch">{{ 'OSTree Branch: ' | translate }} {{ branch.name }}</span>
|
2
|
+
|
3
|
+
<div data-extend-template="layouts/details-nutupane.html">
|
4
|
+
|
5
|
+
<div data-block="header">
|
6
|
+
<h3 translate>Repositories containing branch {{ branch.name }}</h3>
|
7
|
+
</div>
|
8
|
+
|
9
|
+
<div data-block="actions"></div>
|
10
|
+
|
11
|
+
<div data-block="filters">
|
12
|
+
<form class="form-horizontal">
|
13
|
+
<div class="form-group">
|
14
|
+
<div class="col-sm-2">
|
15
|
+
<select class="form-control"
|
16
|
+
ng-disabled="!environments"
|
17
|
+
ng-model="environmentFilter"
|
18
|
+
ng-options="e.id as e.name for e in environments"
|
19
|
+
ng-change="filterBranches()">
|
20
|
+
</select>
|
21
|
+
</div>
|
22
|
+
|
23
|
+
<div class="col-sm-2">
|
24
|
+
<select class="form-control"
|
25
|
+
ng-disabled="!contentViews || filteredCVs.length === 0"
|
26
|
+
ng-model="contentViewFilter"
|
27
|
+
ng-options="cv as cv.name for cv in filteredCVs = (contentViews | filter:{environments: environmentFilter})"
|
28
|
+
ng-change="filterBranches()">
|
29
|
+
</select>
|
30
|
+
<p class="help-block" translate ng-show="filteredCVs.length === 0">
|
31
|
+
There are no Content Views in this Environment.
|
32
|
+
</p>
|
33
|
+
</div>
|
34
|
+
</div>
|
35
|
+
</form>
|
36
|
+
</div>
|
37
|
+
|
38
|
+
<span data-block="no-rows-message" translate>
|
39
|
+
No Repositories contain this Branch.
|
40
|
+
</span>
|
41
|
+
|
42
|
+
<div data-block="table">
|
43
|
+
<table class="table table-striped table-bordered"
|
44
|
+
ng-class="{'table-mask': detailsTable.working}"
|
45
|
+
ng-show="detailsTable.rows.length > 0">
|
46
|
+
<thead>
|
47
|
+
<tr bst-table-head>
|
48
|
+
<th bst-table-column="name"><span translate>Name</span></th>
|
49
|
+
<th bst-table-column="product"><span translate>Product</span></th>
|
50
|
+
<th bst-table-column="lastSync"><span translate>Last Sync</span></th>
|
51
|
+
</tr>
|
52
|
+
</thead>
|
53
|
+
|
54
|
+
<tbody>
|
55
|
+
<tr bst-table-row
|
56
|
+
ng-repeat="repository in detailsTable.rows">
|
57
|
+
<td bst-table-cell>
|
58
|
+
<a ng-href="/products/{{ repository.product.id }}/repositories/{{ repository.library_instance_id || repository.id }}">
|
59
|
+
{{ repository.name }}
|
60
|
+
</a>
|
61
|
+
</td>
|
62
|
+
<td bst-table-cell>
|
63
|
+
<a ui-sref="products.details.repositories.index({productId: repository.product.id})">
|
64
|
+
{{ repository.product.name }}
|
65
|
+
</a>
|
66
|
+
</td>
|
67
|
+
<td bst-table-cell>
|
68
|
+
<span ng-show="repository.url">
|
69
|
+
<span ng-show="repository.last_sync == null" translate>
|
70
|
+
Not Synced
|
71
|
+
</span>
|
72
|
+
<span ng-hide="repository.last_sync == null">
|
73
|
+
<a href="/foreman_tasks/tasks/{{repository.last_sync.id}}">{{ repository.last_sync.result | capitalize}}</a>
|
74
|
+
<span translate>{{ repository.last_sync_words }} ago</span>
|
75
|
+
</span>
|
76
|
+
</span>
|
77
|
+
<span ng-hide="repository.url" translate>N/A</span>
|
78
|
+
</td>
|
79
|
+
</tr>
|
80
|
+
</tbody>
|
81
|
+
</table>
|
82
|
+
</div>
|
83
|
+
</div>
|
@@ -0,0 +1,43 @@
|
|
1
|
+
<span page-title ng-model="branch">{{ 'OSTree Branch: ' | translate }} {{ branch.name }}</span>
|
2
|
+
|
3
|
+
<div class="loading-mask loading-mask-panel" ng-show="panel.loading">
|
4
|
+
<i class="fa fa-spinner fa-spin"></i>
|
5
|
+
{{ "Loading..." | translate }}
|
6
|
+
</div>
|
7
|
+
|
8
|
+
<section class="nutupane-details" ng-cloak bst-container-scroll>
|
9
|
+
|
10
|
+
<header class="details-header">
|
11
|
+
<h2 class="fl">{{ branch.name }}</h2>
|
12
|
+
|
13
|
+
<div class="details-actions fr">
|
14
|
+
<button class="btn btn-default" ui-sref="ostree-branches.index">
|
15
|
+
<i class="fa fa-remove"></i>
|
16
|
+
{{ "Close" | translate }}
|
17
|
+
</button>
|
18
|
+
</div>
|
19
|
+
</header>
|
20
|
+
|
21
|
+
<nav class="details-navigation">
|
22
|
+
<ul>
|
23
|
+
<li ng-class="{active: isState('ostree-branches.details.info')}">
|
24
|
+
<a ui-sref="ostree-branches.details.info">
|
25
|
+
<span translate>
|
26
|
+
Details
|
27
|
+
</span>
|
28
|
+
</a>
|
29
|
+
</li>
|
30
|
+
<li ng-class="{active: isState('ostree-branches.details.repositories')}">
|
31
|
+
<a ui-sref="ostree-branches.details.repositories">
|
32
|
+
<span translate>
|
33
|
+
Repositories
|
34
|
+
</span>
|
35
|
+
</a>
|
36
|
+
</li>
|
37
|
+
</ul>
|
38
|
+
</nav>
|
39
|
+
|
40
|
+
<div bst-alerts success-messages="successMessages" error-messages="errorMessages"></div>
|
41
|
+
|
42
|
+
<section ui-view></section>
|
43
|
+
</section>
|
@@ -0,0 +1,67 @@
|
|
1
|
+
/**
|
2
|
+
* @ngdoc object
|
3
|
+
* @name Bastion.ostree-branches.controller:OstreeBranchesController
|
4
|
+
*
|
5
|
+
* @requires $scope
|
6
|
+
* @requires $location
|
7
|
+
* @requires translate
|
8
|
+
* @requires Nutupane
|
9
|
+
* @requires OstreeBranch
|
10
|
+
* @requires Repository
|
11
|
+
* @requires CurrentOrganization
|
12
|
+
*
|
13
|
+
* @description
|
14
|
+
* Provides the functionality specific to ostree branches for use with the Nutupane UI pattern.
|
15
|
+
* Defines the columns to display and the transform function for how to generate each row
|
16
|
+
* within the table.
|
17
|
+
*/
|
18
|
+
|
19
|
+
angular.module('Bastion.ostree-branches').controller('OstreeBranchesController',
|
20
|
+
['$scope', '$location', 'translate', 'Nutupane', 'OstreeBranch', 'Repository', 'CurrentOrganization',
|
21
|
+
function ($scope, $location, translate, Nutupane, OstreeBranch, Repository, CurrentOrganization) {
|
22
|
+
var nutupane, params = {
|
23
|
+
'organization_id': CurrentOrganization,
|
24
|
+
'search': $location.search().search || "",
|
25
|
+
'paged': true
|
26
|
+
};
|
27
|
+
|
28
|
+
nutupane = $scope.nutupane = new Nutupane(OstreeBranch, params);
|
29
|
+
$scope.table = nutupane.table;
|
30
|
+
$scope.removeRow = nutupane.removeRow;
|
31
|
+
$scope.controllerName = 'katello_ostree_branches';
|
32
|
+
|
33
|
+
$scope.table.closeItem = function () {
|
34
|
+
$scope.transitionTo('ostree-branches.index');
|
35
|
+
};
|
36
|
+
|
37
|
+
$scope.repository = {name: translate('All Repositories'), id: 'all'};
|
38
|
+
|
39
|
+
Repository.queryUnpaged({'organization_id': CurrentOrganization, 'content_type': 'ostree'}, function (response) {
|
40
|
+
$scope.repositories = [$scope.repository];
|
41
|
+
$scope.repositories = $scope.repositories.concat(response.results);
|
42
|
+
|
43
|
+
if ($location.search().repositoryId) {
|
44
|
+
$scope.repository = _.find($scope.repositories, function (repository) {
|
45
|
+
return repository.id === parseInt($location.search().repositoryId, 10);
|
46
|
+
});
|
47
|
+
}
|
48
|
+
});
|
49
|
+
|
50
|
+
$scope.$watch('repository', function (repository) {
|
51
|
+
var nutupaneParams = nutupane.getParams();
|
52
|
+
|
53
|
+
if (repository.id === 'all') {
|
54
|
+
nutupaneParams['repository_id'] = null;
|
55
|
+
nutupane.setParams(nutupaneParams);
|
56
|
+
} else {
|
57
|
+
$location.search('repositoryId', repository.id);
|
58
|
+
nutupaneParams['repository_id'] = repository.id;
|
59
|
+
nutupane.setParams(nutupaneParams);
|
60
|
+
}
|
61
|
+
|
62
|
+
if (!nutupane.table.initialLoad) {
|
63
|
+
nutupane.refresh();
|
64
|
+
}
|
65
|
+
});
|
66
|
+
}]
|
67
|
+
);
|
@@ -0,0 +1,53 @@
|
|
1
|
+
/**
|
2
|
+
* @ngdoc object
|
3
|
+
* @name Bastion.ostree-branches.config
|
4
|
+
*
|
5
|
+
* @requires $stateProvider
|
6
|
+
*
|
7
|
+
* @description
|
8
|
+
* State routes defined for the ostree branches module.
|
9
|
+
*/
|
10
|
+
angular.module('Bastion.ostree-branches').config(['$stateProvider', function ($stateProvider) {
|
11
|
+
$stateProvider.state('ostree-branches', {
|
12
|
+
abstract: true,
|
13
|
+
controller: 'OstreeBranchesController',
|
14
|
+
templateUrl: 'ostree-branches/views/ostree-branches.html'
|
15
|
+
})
|
16
|
+
.state('ostree-branches.index', {
|
17
|
+
url: '/ostree_branches?repositoryId',
|
18
|
+
permission: ['view_products', 'view_content_views'],
|
19
|
+
views: {
|
20
|
+
'table': {
|
21
|
+
templateUrl: 'ostree-branches/views/ostree-branches-table-full.html'
|
22
|
+
}
|
23
|
+
}
|
24
|
+
})
|
25
|
+
.state('ostree-branches.details', {
|
26
|
+
abstract: true,
|
27
|
+
url: '/ostree_branches/:branchId',
|
28
|
+
permission: ['view_products', 'view_content_views'],
|
29
|
+
collapsed: true,
|
30
|
+
views: {
|
31
|
+
'table': {
|
32
|
+
templateUrl: 'ostree-branches/views/ostree-branches-table-collapsed.html'
|
33
|
+
},
|
34
|
+
'action-panel': {
|
35
|
+
controller: 'OstreeBranchesDetailsController',
|
36
|
+
templateUrl: 'ostree-branches/details/views/ostree-branches-details.html'
|
37
|
+
}
|
38
|
+
}
|
39
|
+
})
|
40
|
+
.state('ostree-branches.details.info', {
|
41
|
+
url: '/ostree_branches/info',
|
42
|
+
collapsed: true,
|
43
|
+
permission: ['view_products', 'view_content_views'],
|
44
|
+
templateUrl: 'ostree-branches/details/views/ostree-branches-details-info.html'
|
45
|
+
})
|
46
|
+
.state('ostree-branches.details.repositories', {
|
47
|
+
url: '/ostree_branches/repositories',
|
48
|
+
collapsed: true,
|
49
|
+
permission: ['view_products', 'view_content_views'],
|
50
|
+
controller: 'OstreeBranchesDetailsRepositoriesController',
|
51
|
+
templateUrl: 'ostree-branches/details/views/ostree-branches-details-repositories.html'
|
52
|
+
});
|
53
|
+
}]);
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<table class="table table-striped table-full" ng-class="{'table-mask': table.working}">
|
2
|
+
<thead>
|
3
|
+
<tr bst-table-head>
|
4
|
+
<th bst-table-column="name" sortable>{{ "Name" | translate }}</th>
|
5
|
+
</tr>
|
6
|
+
</thead>
|
7
|
+
|
8
|
+
<tbody>
|
9
|
+
<tr bst-table-row
|
10
|
+
ng-repeat="branch in table.rows"
|
11
|
+
active-row="stateIncludes('ostree-branches.details', {branchId: branch.id})">
|
12
|
+
<td bst-table-cell clas="ellipsis-column">
|
13
|
+
<a ui-sref="ostree-branches.details.info({branchId: branch.id})">
|
14
|
+
{{ branch.name }}
|
15
|
+
</a>
|
16
|
+
</td>
|
17
|
+
</tr>
|
18
|
+
</tbody>
|
19
|
+
</table>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<table class="table table-striped" ng-class="{'table-mask': table.working}">
|
2
|
+
<thead>
|
3
|
+
<tr bst-table-head>
|
4
|
+
<th bst-table-column="name">{{ "Name" | translate }}</th>
|
5
|
+
<th bst-table-column="version">{{ "Version" | translate }}</th>
|
6
|
+
</tr>
|
7
|
+
</thead>
|
8
|
+
|
9
|
+
<tbody>
|
10
|
+
<tr bst-table-row ng-repeat="branch in table.rows">
|
11
|
+
<td bst-table-cell>
|
12
|
+
<a ui-sref="ostree-branches.details.info({branchId: branch.id})">
|
13
|
+
{{ branch.name }}
|
14
|
+
</a>
|
15
|
+
</td>
|
16
|
+
<td bst-table-cell>
|
17
|
+
{{ branch.version }}
|
18
|
+
</td>
|
19
|
+
</tr>
|
20
|
+
</tbody>
|
21
|
+
</table>
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<span page-title>{{ 'OSTree Branches' | translate }}</span>
|
2
|
+
|
3
|
+
<div data-extend-template="layouts/nutupane.html">
|
4
|
+
|
5
|
+
<div data-block="header">
|
6
|
+
{{ 'OSTree Branches' | translate }}
|
7
|
+
</div>
|
8
|
+
|
9
|
+
<div data-block="search-filter">
|
10
|
+
<div class="col-sm-3">
|
11
|
+
<select class="form-control" ng-model="repository" ng-options="repository.name for (id, repository) in repositories"></select>
|
12
|
+
</div>
|
13
|
+
</div>
|
14
|
+
|
15
|
+
<span data-block="no-rows-message" translate>
|
16
|
+
You currently don't have any OSTree Branches.
|
17
|
+
</span>
|
18
|
+
|
19
|
+
</div>
|
@@ -9,6 +9,12 @@
|
|
9
9
|
* Module for Package Group related functionality.
|
10
10
|
*/
|
11
11
|
angular
|
12
|
-
.module('Bastion.package-groups', [
|
12
|
+
.module('Bastion.package-groups', [
|
13
|
+
'ui.router',
|
14
|
+
'ngResource',
|
15
|
+
'Bastion',
|
16
|
+
'Bastion.i18n',
|
17
|
+
'Bastion.components'
|
18
|
+
]);
|
13
19
|
|
14
20
|
})();
|
@@ -9,8 +9,9 @@
|
|
9
9
|
* @description
|
10
10
|
* Provides the functionality for the errata details action pane.
|
11
11
|
*/
|
12
|
-
angular.module('Bastion.packages').controller('PackageDetailsController',
|
13
|
-
|
12
|
+
angular.module('Bastion.packages').controller('PackageDetailsController',
|
13
|
+
['$scope', 'Package', 'Host', 'CurrentOrganization', 'ApiErrorHandler',
|
14
|
+
function ($scope, Package, Host, CurrentOrganization, ApiErrorHandler) {
|
14
15
|
$scope.panel = {
|
15
16
|
error: false,
|
16
17
|
loading: true
|
@@ -20,8 +21,22 @@ angular.module('Bastion.packages').controller('PackageDetailsController', ['$sco
|
|
20
21
|
$scope.panel.loading = false;
|
21
22
|
}
|
22
23
|
|
24
|
+
$scope.installedPackageCount = undefined;
|
25
|
+
|
26
|
+
$scope.fetchHostCount = function() {
|
27
|
+
Host.get({'per_page': 0, 'search': $scope.createSearchString(), 'organization_id': CurrentOrganization}, function (data) {
|
28
|
+
$scope.installedPackageCount = data.subtotal;
|
29
|
+
});
|
30
|
+
};
|
31
|
+
|
32
|
+
$scope.createSearchString = function() {
|
33
|
+
return 'installed_package=' + $scope.package.name + '-' + $scope.package.version + '-' + $scope.package.release + '.' +
|
34
|
+
$scope.package.arch;
|
35
|
+
};
|
36
|
+
|
23
37
|
$scope.package = Package.get({id: $scope.$stateParams.packageId}, function () {
|
24
38
|
$scope.panel.loading = false;
|
39
|
+
$scope.fetchHostCount();
|
25
40
|
}, function(response) {
|
26
41
|
$scope.panel.loading = false;
|
27
42
|
ApiErrorHandler.handleGETRequestErrors(response, $scope);
|
@@ -5,6 +5,16 @@
|
|
5
5
|
<div class="details">
|
6
6
|
<h4 translate>Package Info</h4>
|
7
7
|
|
8
|
+
<div class="detail">
|
9
|
+
<span class="info-label" translate>Installed On</span>
|
10
|
+
<span class="info-value" ng-show="installedPackageCount === undefined"><i class="fa fa-spinner fa-spin" ></i></span>
|
11
|
+
<span class="info-value" ng-show="installedPackageCount !== undefined">
|
12
|
+
<a href="{{ '/content_hosts?search=' + createSearchString() }}">
|
13
|
+
{{ installedPackageCount }} Host(s)
|
14
|
+
</a>
|
15
|
+
</span>
|
16
|
+
</div>
|
17
|
+
|
8
18
|
<div class="detail">
|
9
19
|
<span class="info-label" translate>Description</span>
|
10
20
|
<span class="info-value">{{ package.description }}</span>
|