katello 3.18.0.rc1 → 4.0.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.

Files changed (345) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +0 -19
  3. data/app/controllers/katello/api/rhsm/candlepin_proxies_controller.rb +1 -3
  4. data/app/controllers/katello/api/v2/api_controller.rb +1 -2
  5. data/app/controllers/katello/api/v2/capsule_content_controller.rb +2 -2
  6. data/app/controllers/katello/api/v2/content_credentials_controller.rb +24 -24
  7. data/app/controllers/katello/api/v2/content_export_incrementals_controller.rb +98 -0
  8. data/app/controllers/katello/api/v2/content_exports_controller.rb +88 -0
  9. data/app/controllers/katello/api/v2/content_imports_controller.rb +59 -0
  10. data/app/controllers/katello/api/v2/content_view_filters_controller.rb +16 -7
  11. data/app/controllers/katello/api/v2/content_view_versions_controller.rb +57 -92
  12. data/app/controllers/katello/api/v2/content_views_controller.rb +12 -3
  13. data/app/controllers/katello/api/v2/host_debs_controller.rb +1 -0
  14. data/app/controllers/katello/api/v2/host_errata_controller.rb +2 -2
  15. data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +2 -3
  16. data/app/controllers/katello/api/v2/hosts_bulk_actions_controller.rb +20 -7
  17. data/app/controllers/katello/api/v2/products_bulk_actions_controller.rb +1 -1
  18. data/app/controllers/katello/api/v2/products_controller.rb +9 -9
  19. data/app/controllers/katello/api/v2/repositories_controller.rb +5 -19
  20. data/app/controllers/katello/api/v2/repository_sets_controller.rb +24 -14
  21. data/app/controllers/katello/api/v2/simple_content_access_controller.rb +34 -0
  22. data/app/controllers/katello/api/v2/subscriptions_controller.rb +1 -1
  23. data/app/controllers/katello/api/v2/upstream_subscriptions_controller.rb +8 -4
  24. data/app/controllers/katello/concerns/api/v2/authorization.rb +10 -0
  25. data/app/controllers/katello/concerns/api/v2/bulk_hosts_extensions.rb +22 -18
  26. data/app/controllers/katello/concerns/authorization/api/v2/content_views_controller.rb +1 -1
  27. data/app/controllers/katello/concerns/registration_controller_extensions.rb +16 -0
  28. data/app/helpers/katello/sync_management_helper.rb +0 -2
  29. data/app/lib/actions/candlepin/environment/create.rb +1 -1
  30. data/app/lib/actions/candlepin/environment/set_content.rb +1 -1
  31. data/app/lib/actions/helpers/smart_proxy_sync_history_helper.rb +24 -0
  32. data/app/lib/actions/katello/activation_key/create.rb +9 -11
  33. data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +6 -2
  34. data/app/lib/actions/katello/capsule_content/sync.rb +8 -8
  35. data/app/lib/actions/katello/capsule_content/sync_capsule.rb +31 -8
  36. data/app/lib/actions/katello/check_matching_content.rb +17 -0
  37. data/app/lib/actions/katello/content_view/environment_create.rb +6 -8
  38. data/app/lib/actions/katello/content_view/promote_to_environment.rb +1 -1
  39. data/app/lib/actions/katello/content_view/publish.rb +6 -5
  40. data/app/lib/actions/katello/content_view_version/import.rb +5 -11
  41. data/app/lib/actions/katello/content_view_version/import_library.rb +17 -0
  42. data/app/lib/actions/katello/content_view_version/incremental_update.rb +30 -10
  43. data/app/lib/actions/katello/host/hypervisors_update.rb +4 -4
  44. data/app/lib/actions/katello/host/update_system_purpose.rb +1 -1
  45. data/app/lib/actions/katello/host/upload_package_profile.rb +3 -1
  46. data/app/lib/actions/katello/host/upload_profiles.rb +8 -6
  47. data/app/lib/actions/katello/organization/create.rb +3 -5
  48. data/app/lib/actions/katello/organization/destroy.rb +1 -1
  49. data/app/lib/actions/katello/organization/manifest_delete.rb +3 -5
  50. data/app/lib/actions/katello/organization/manifest_import.rb +1 -1
  51. data/app/lib/actions/katello/organization/manifest_refresh.rb +1 -1
  52. data/app/lib/actions/katello/repository/check_matching_content.rb +3 -1
  53. data/app/lib/actions/katello/repository/clone_contents.rb +8 -11
  54. data/app/lib/actions/katello/repository/create.rb +0 -8
  55. data/app/lib/actions/katello/repository/filtered_index_content.rb +3 -0
  56. data/app/lib/actions/katello/repository/import_upload.rb +2 -0
  57. data/app/lib/actions/katello/repository/index_content.rb +1 -0
  58. data/app/lib/actions/katello/repository/multi_clone_contents.rb +9 -12
  59. data/app/lib/actions/katello/repository/remove_content.rb +1 -1
  60. data/app/lib/actions/katello/repository/sync.rb +3 -1
  61. data/app/lib/actions/katello/repository/update.rb +1 -8
  62. data/app/lib/actions/katello/repository/upload_files.rb +1 -0
  63. data/app/lib/actions/middleware/execute_if_contents_changed.rb +4 -1
  64. data/app/lib/actions/middleware/record_smart_proxy_sync_history.rb +35 -0
  65. data/app/lib/actions/pulp/consumer/sync_capsule.rb +4 -2
  66. data/app/lib/actions/pulp/orchestration/repository/refresh_repos.rb +0 -6
  67. data/app/lib/actions/pulp/repository/distributor_publish.rb +1 -1
  68. data/app/lib/actions/pulp3/abstract_async_task.rb +1 -0
  69. data/app/lib/actions/pulp3/capsule_content/refresh_distribution.rb +3 -3
  70. data/app/lib/actions/pulp3/capsule_content/sync.rb +1 -0
  71. data/app/lib/actions/pulp3/content_migration.rb +10 -0
  72. data/app/lib/actions/pulp3/content_migration_presenter.rb +59 -0
  73. data/app/lib/actions/pulp3/content_view/delete_repository_references.rb +1 -1
  74. data/app/lib/actions/pulp3/content_view_version/export.rb +6 -1
  75. data/app/lib/actions/pulp3/import_migration.rb +6 -1
  76. data/app/lib/actions/pulp3/orchestration/content_view_version/copy_version_units_to_library.rb +2 -1
  77. data/app/lib/actions/pulp3/orchestration/content_view_version/export.rb +30 -9
  78. data/app/lib/actions/pulp3/orchestration/content_view_version/export_library.rb +60 -0
  79. data/app/lib/actions/pulp3/orchestration/content_view_version/import.rb +0 -4
  80. data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +4 -1
  81. data/app/lib/actions/pulp3/orchestration/repository/import_upload.rb +16 -3
  82. data/app/lib/actions/pulp3/orchestration/repository/refresh_repos.rb +1 -6
  83. data/app/lib/actions/pulp3/repository/copy_content.rb +1 -1
  84. data/app/lib/actions/pulp3/repository/delete.rb +1 -1
  85. data/app/lib/actions/pulp3/repository/save_version.rb +1 -1
  86. data/app/lib/actions/pulp3/repository/upload_tag.rb +18 -0
  87. data/app/lib/katello/concerns/base_template_scope_extensions.rb +8 -0
  88. data/app/lib/katello/event_daemon/monitor.rb +53 -0
  89. data/app/lib/katello/event_daemon/runner.rb +99 -0
  90. data/app/lib/katello/logging.rb +32 -0
  91. data/app/lib/katello/messaging/connection.rb +1 -7
  92. data/app/lib/katello/validators/content_view_puppet_module_validator.rb +1 -1
  93. data/app/models/katello/activation_key.rb +2 -2
  94. data/app/models/katello/authorization/content_view_filter.rb +15 -0
  95. data/app/models/katello/authorization/content_view_version.rb +25 -2
  96. data/app/models/katello/authorization/content_view_version_export_history.rb +1 -1
  97. data/app/models/katello/authorization/organization.rb +8 -0
  98. data/app/models/katello/candlepin/repository_mapper.rb +1 -1
  99. data/app/models/katello/concerns/operatingsystem_extensions.rb +2 -0
  100. data/app/models/katello/concerns/organization_extensions.rb +2 -2
  101. data/app/models/katello/concerns/pulp_database_unit.rb +7 -0
  102. data/app/models/katello/concerns/redhat_extensions.rb +2 -2
  103. data/app/models/katello/concerns/smart_proxy_extensions.rb +33 -5
  104. data/app/models/katello/content_migration_progress.rb +4 -0
  105. data/app/models/katello/content_view.rb +35 -5
  106. data/app/models/katello/content_view_environment.rb +2 -2
  107. data/app/models/katello/content_view_filter.rb +5 -0
  108. data/app/models/katello/content_view_history.rb +2 -1
  109. data/app/models/katello/content_view_package_filter.rb +1 -1
  110. data/app/models/katello/content_view_puppet_environment.rb +2 -2
  111. data/app/models/katello/content_view_puppet_module.rb +8 -0
  112. data/app/models/katello/content_view_repository.rb +13 -1
  113. data/app/models/katello/content_view_version.rb +2 -1
  114. data/app/models/katello/content_view_version_export_history.rb +26 -1
  115. data/app/models/katello/erratum.rb +3 -1
  116. data/app/models/katello/glue/candlepin/pool.rb +2 -0
  117. data/app/models/katello/glue/pulp/repo.rb +0 -6
  118. data/app/models/katello/glue/pulp/repos.rb +1 -22
  119. data/app/models/katello/host/subscription_facet.rb +4 -0
  120. data/app/models/katello/ping.rb +11 -6
  121. data/app/models/katello/pool.rb +5 -0
  122. data/app/models/katello/product.rb +3 -3
  123. data/app/models/katello/repository.rb +36 -3
  124. data/app/models/katello/smart_proxy_sync_history.rb +8 -0
  125. data/app/models/katello/subscription_status.rb +3 -2
  126. data/app/presenters/katello/host_subscription_presenter.rb +3 -4
  127. data/app/presenters/katello/host_subscriptions_presenter.rb +24 -0
  128. data/app/services/katello/applicability/applicable_content_helper.rb +44 -15
  129. data/app/services/katello/candlepin_event_listener.rb +11 -19
  130. data/app/services/katello/event_monitor/poller_thread.rb +2 -11
  131. data/app/services/katello/pulp/smart_proxy_repository.rb +0 -15
  132. data/app/services/katello/pulp3/api/docker.rb +4 -0
  133. data/app/services/katello/pulp3/content_view_version/export.rb +122 -6
  134. data/app/services/katello/pulp3/content_view_version/import.rb +37 -22
  135. data/app/services/katello/pulp3/content_view_version/import_export_common.rb +6 -16
  136. data/app/services/katello/pulp3/content_view_version/import_validator.rb +84 -0
  137. data/app/services/katello/pulp3/docker_manifest.rb +1 -0
  138. data/app/services/katello/pulp3/docker_tag.rb +1 -0
  139. data/app/services/katello/pulp3/migration.rb +51 -10
  140. data/app/services/katello/pulp3/repository.rb +13 -4
  141. data/app/services/katello/pulp3/repository/docker.rb +5 -0
  142. data/app/services/katello/pulp3/repository/yum.rb +15 -10
  143. data/app/services/katello/pulp3/task.rb +7 -3
  144. data/app/services/katello/pulp3/task_group.rb +10 -0
  145. data/app/services/katello/repository_type.rb +3 -2
  146. data/app/services/katello/smart_proxy_helper.rb +9 -0
  147. data/app/views/foreman/hosts/_registration.html.erb +12 -0
  148. data/app/views/foreman/smart_proxies/_content_tab.html.erb +4 -47
  149. data/app/views/foreman/smart_proxies/show.html.erb +1 -1
  150. data/app/views/katello/api/v2/capsule_content/sync_status.json.rabl +22 -25
  151. data/app/views/katello/api/v2/content_view_version_export_histories/show.json.rabl +1 -0
  152. data/app/views/katello/api/v2/content_views/base.json.rabl +1 -0
  153. data/app/views/katello/api/v2/content_views/show.json.rabl +6 -0
  154. data/app/views/katello/api/v2/organizations/show.json.rabl +7 -9
  155. data/app/views/katello/layouts/react.html.erb +3 -2
  156. data/app/views/overrides/activation_keys/_host_tab_pane.html.erb +1 -5
  157. data/app/views/overrides/organizations/_edit_override.html.erb +1 -4
  158. data/app/views/overrides/smart_proxies/_environment_tab.html.erb +1 -1
  159. data/app/views/overrides/smart_proxies/_environment_tab_pane.html.erb +1 -1
  160. data/config/katello.yaml.example +0 -3
  161. data/config/routes/api/v2.rb +31 -13
  162. data/db/migrate/20150930183738_migrate_content_hosts.rb +1 -1
  163. data/db/migrate/20191204214919_add_content_view_version_counts.rb +0 -1
  164. data/db/migrate/20200514092553_move_katello_fields_from_hostgroups.katello.rb +5 -2
  165. data/db/migrate/20200929200357_create_katello_smart_proxy_sync_history.rb +13 -0
  166. data/db/migrate/20201021150008_add_import_only_to_katello_content_view.rb +5 -0
  167. data/db/migrate/20201119211133_pulp3_migration_progress.rb +9 -0
  168. data/db/migrate/20210119162528_delete_puppet_and_ostree_repos.rb +56 -0
  169. data/db/migrate/20210128231228_add_type_and_from_cvv_to_cvv_export_history.rb +14 -0
  170. data/db/migrate/20210201163238_migrate_background_download_policy_to_migrate.rb +7 -0
  171. data/db/seeds.d/104-proxy.rb +1 -1
  172. data/db/seeds.d/111-upgrade_tasks.rb +2 -1
  173. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/capsule-content/capsule-content.controller.js +1 -1
  174. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/common/views/katello-agent-notice.html +1 -1
  175. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/bulk/views/content-hosts-bulk-system-purpose-modal.html +35 -40
  176. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/content-host-register-os-client.directive.js +17 -0
  177. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/details/views/content-host-info.html +2 -2
  178. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/content-hosts.html +2 -2
  179. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-client.html +12 -5
  180. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-deb-client.html +38 -0
  181. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-oracle-client.html +5 -0
  182. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register-sles-client.html +28 -0
  183. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-hosts/views/register.html +14 -11
  184. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +6 -2
  185. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +8 -3
  186. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +9 -3
  187. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +12 -0
  188. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +2 -2
  189. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +7 -7
  190. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +7 -1
  191. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +4 -0
  192. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +17 -3
  193. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +16 -2
  194. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +5 -0
  195. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +78 -7
  196. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/de.po +17 -20
  197. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/es.po +17 -24
  198. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/fr.po +1292 -1170
  199. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/it.po +17 -20
  200. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ja.po +858 -807
  201. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ko.po +18 -19
  202. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/pt_BR.po +17 -24
  203. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/ru.po +17 -18
  204. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_CN.po +986 -971
  205. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/locale/zh_TW.po +19 -20
  206. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/translations.js +9 -9
  207. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/repository-details-info.controller.js +2 -2
  208. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/details/views/repository-info.html +1 -1
  209. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/download-policy.service.js +0 -1
  210. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/new/views/new-repository.html +1 -1
  211. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/details/repositories/repository-types.service.js +8 -1
  212. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/products/products.controller.js +2 -2
  213. data/lib/katello/engine.rb +6 -6
  214. data/lib/katello/middleware/event_daemon.rb +1 -1
  215. data/lib/katello/permission_creator.rb +35 -14
  216. data/lib/katello/plugin.rb +8 -3
  217. data/lib/katello/tasks/delete_orphaned_content.rake +1 -3
  218. data/lib/katello/tasks/jenkins.rake +1 -1
  219. data/lib/katello/tasks/pulp3_content_switchover.rake +1 -1
  220. data/lib/katello/tasks/pulp3_migration.rake +18 -6
  221. data/lib/katello/tasks/pulp3_migration_abort.rake +22 -0
  222. data/lib/katello/tasks/pulp3_migration_stats.rake +28 -8
  223. data/lib/katello/tasks/pulp3_post_migration_check.rake +1 -3
  224. data/lib/katello/tasks/receptor/extract_orgs.rake +1 -1
  225. data/lib/katello/tasks/reimport.rake +1 -1
  226. data/lib/katello/tasks/repository.rake +3 -5
  227. data/lib/katello/tasks/upgrades/4.0/remove_ostree_puppet_content.rake +16 -0
  228. data/lib/katello/version.rb +1 -1
  229. data/lib/proxy_api/container_gateway.rb +21 -0
  230. data/locale/action_names.rb +51 -51
  231. data/locale/bn/katello.edit.po +0 -0
  232. data/locale/bn/katello.po +136 -51
  233. data/locale/cs/katello.edit.po +0 -0
  234. data/locale/cs/katello.po +136 -49
  235. data/locale/de/katello.edit.po +0 -0
  236. data/locale/de/katello.po +136 -48
  237. data/locale/en/katello.edit.po +0 -0
  238. data/locale/en/katello.po +136 -48
  239. data/locale/es/katello.edit.po +0 -0
  240. data/locale/es/katello.po +136 -48
  241. data/locale/fr/katello.edit.po +0 -0
  242. data/locale/fr/katello.po +136 -48
  243. data/locale/gu/katello.edit.po +0 -0
  244. data/locale/gu/katello.po +136 -51
  245. data/locale/hi/katello.edit.po +0 -0
  246. data/locale/hi/katello.po +136 -51
  247. data/locale/it/katello.edit.po +0 -0
  248. data/locale/it/katello.po +136 -48
  249. data/locale/ja/katello.edit.po +0 -0
  250. data/locale/ja/katello.po +136 -48
  251. data/locale/katello.pot +941 -767
  252. data/locale/kn/katello.edit.po +0 -0
  253. data/locale/kn/katello.po +136 -51
  254. data/locale/ko/katello.edit.po +0 -0
  255. data/locale/ko/katello.po +136 -48
  256. data/locale/mr/katello.edit.po +0 -0
  257. data/locale/mr/katello.po +136 -51
  258. data/locale/or/katello.edit.po +0 -0
  259. data/locale/or/katello.po +136 -51
  260. data/locale/pa/katello.edit.po +0 -0
  261. data/locale/pa/katello.po +136 -51
  262. data/locale/pt/katello.edit.po +0 -0
  263. data/locale/pt/katello.po +136 -51
  264. data/locale/pt_BR/katello.edit.po +0 -0
  265. data/locale/pt_BR/katello.po +136 -48
  266. data/locale/ru/katello.edit.po +0 -0
  267. data/locale/ru/katello.po +136 -48
  268. data/locale/ta/katello.edit.po +0 -0
  269. data/locale/ta/katello.po +136 -51
  270. data/locale/te/katello.edit.po +0 -0
  271. data/locale/te/katello.po +136 -51
  272. data/locale/zh_CN/katello.edit.po +0 -0
  273. data/locale/zh_CN/katello.po +136 -48
  274. data/locale/zh_TW/katello.edit.po +0 -0
  275. data/locale/zh_TW/katello.po +136 -48
  276. data/package.json +1 -1
  277. data/webpack/__mocks__/foremanReact/Root/Context/ForemanContext.js +0 -1
  278. data/webpack/__mocks__/foremanReact/components/Pagination/PaginationHooks.js +2 -0
  279. data/webpack/__mocks__/foremanReact/components/common/dates/LongDateTime.js +5 -0
  280. data/webpack/{scenes/ContentViews/Details/Repositories → components/SelectableDropdown}/SelectableDropdown.js +20 -3
  281. data/webpack/components/SelectableDropdown/__tests__/SelectableDropdown.test.js +45 -0
  282. data/webpack/components/SelectableDropdown/index.js +3 -0
  283. data/webpack/components/Table/TableWrapper.js +2 -1
  284. data/webpack/components/Table/helpers.js +14 -0
  285. data/webpack/components/TypeAhead/TypeAhead.js +2 -1
  286. data/webpack/components/TypeAhead/pf3Search/TypeAheadSearch.js +2 -1
  287. data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.js +0 -1
  288. data/webpack/containers/Application/overrides.scss +6 -0
  289. data/webpack/index.js +6 -0
  290. data/webpack/redux/actions/RedHatRepositories/helpers.js +5 -5
  291. data/webpack/scenes/ContentViews/ContentViewsActions.js +31 -2
  292. data/webpack/scenes/ContentViews/ContentViewsConstants.js +5 -1
  293. data/webpack/scenes/ContentViews/Copy/ContentViewCopySelectors.js +16 -0
  294. data/webpack/scenes/ContentViews/Copy/CopyContentViewForm.js +77 -0
  295. data/webpack/scenes/ContentViews/Copy/CopyContentViewModal.js +44 -0
  296. data/webpack/scenes/ContentViews/Copy/__tests__/contentViewCopyResult.fixtures.json +42 -0
  297. data/webpack/scenes/ContentViews/Copy/__tests__/copyContentView.test.js +39 -0
  298. data/webpack/scenes/ContentViews/Copy/index.js +4 -0
  299. data/webpack/scenes/ContentViews/Create/ContentViewCreateSelectors.js +16 -0
  300. data/webpack/scenes/ContentViews/Create/ContentViewFormComponents.js +58 -0
  301. data/webpack/scenes/ContentViews/Create/CreateContentViewForm.js +175 -0
  302. data/webpack/scenes/ContentViews/Create/CreateContentViewModal.js +27 -0
  303. data/webpack/scenes/ContentViews/Create/__tests__/contentViewCreateResult.fixtures.json +42 -0
  304. data/webpack/scenes/ContentViews/Create/__tests__/createContentView.test.js +92 -0
  305. data/webpack/scenes/ContentViews/Create/index.js +4 -0
  306. data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +16 -0
  307. data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +20 -1
  308. data/webpack/scenes/ContentViews/Details/ContentViewDetails.js +17 -7
  309. data/webpack/scenes/ContentViews/Details/ContentViewInfo.js +19 -13
  310. data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +40 -0
  311. data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +124 -0
  312. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.fixtures.json +134 -0
  313. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +92 -0
  314. data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +44 -25
  315. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewDetailRepos.test.js +17 -7
  316. data/webpack/scenes/ContentViews/Details/__tests__/contentViewDetail.test.js +24 -0
  317. data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +53 -3
  318. data/webpack/scenes/ContentViews/Table/tableDataGenerator.js +4 -3
  319. data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +41 -0
  320. data/webpack/scenes/ContentViews/helpers.js +13 -0
  321. data/webpack/scenes/SmartProxy/Content.js +17 -0
  322. data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +11 -0
  323. data/webpack/scenes/SmartProxy/SmartProxyContentConstants.js +3 -0
  324. data/webpack/scenes/SmartProxy/SmartProxyContentSelectors.js +16 -0
  325. data/webpack/scenes/SmartProxy/SmartProxyContentTable.js +152 -0
  326. data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentResult.fixtures.json +140 -0
  327. data/webpack/scenes/SmartProxy/__tests__/SmartProxyContentTest.js +38 -0
  328. data/webpack/scenes/SmartProxy/index.js +4 -0
  329. data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +13 -11
  330. data/webpack/scenes/Subscriptions/Manifest/ManifestActions.js +3 -3
  331. data/webpack/scenes/Subscriptions/Manifest/__tests__/ManifestActions.test.js +2 -2
  332. data/webpack/scenes/Subscriptions/Manifest/__tests__/SimpleContentAccess.test.js +2 -2
  333. data/webpack/test-utils/react-testing-lib-wrapper.js +8 -2
  334. data/webpack/utils/helpers.js +3 -0
  335. metadata +110 -31
  336. data/app/controllers/katello/api/v2/gpg_keys_controller.rb +0 -114
  337. data/app/overrides/disable_turbolinks_on_proxies_index.rb +0 -5
  338. data/app/services/katello/event_daemon.rb +0 -135
  339. data/app/services/katello/pulp/content_counts_calculator.rb +0 -60
  340. data/lib/katello/tasks/common.rake +0 -7
  341. data/lib/katello/tasks/reports.rake +0 -4
  342. data/lib/katello/tasks/upgrades/3.10/update_gpg_key_urls.rake +0 -32
  343. data/webpack/__mocks__/foremanReact/components/common/Fill/GlobalFill.js +0 -3
  344. data/webpack/components/TypeAhead/pf4Search/TypeAheadSearch.scss +0 -5
  345. data/webpack/scenes/ContentViews/Table/actionResolver.js +0 -28
@@ -0,0 +1,42 @@
1
+ {
2
+ "content_host_count": 0,
3
+ "composite": false,
4
+ "component_ids": [],
5
+ "default": false,
6
+ "force_puppet_environment": false,
7
+ "version_count": 0,
8
+ "latest_version": null,
9
+ "auto_publish": false,
10
+ "solve_dependencies": false,
11
+ "import_only": false,
12
+ "repository_ids": [],
13
+ "id": 34,
14
+ "name": "copy cv",
15
+ "label": "copy_cv",
16
+ "description": "",
17
+ "organization_id": 1,
18
+ "organization": {
19
+ "name": "Default Organization",
20
+ "label": "Default_Organization",
21
+ "id": 1
22
+ },
23
+ "created_at": "2020-12-14 12:45:59 -0500",
24
+ "updated_at": "2020-12-14 12:45:59 -0500",
25
+ "environments": [],
26
+ "repositories": [],
27
+ "puppet_modules": [],
28
+ "versions": [],
29
+ "components": [],
30
+ "content_view_components": [],
31
+ "activation_keys": [],
32
+ "next_version": "1.0",
33
+ "last_published": null,
34
+ "permissions": {
35
+ "view_content_views": true,
36
+ "edit_content_views": true,
37
+ "destroy_content_views": true,
38
+ "publish_content_views": true,
39
+ "promote_or_remove_content_views": true
40
+ },
41
+ "duplicate_repositories_to_publish": []
42
+ }
@@ -0,0 +1,39 @@
1
+ import React from 'react';
2
+ import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
3
+
4
+ import { nockInstance, assertNockRequest } from '../../../../test-utils/nockWrapper';
5
+ import api from '../../../../services/api';
6
+ import CopyContentViewForm from '../CopyContentViewForm';
7
+
8
+ const cvCopyData = require('./contentViewCopyResult.fixtures.json');
9
+
10
+ const cvId = '1';
11
+ const cvCopyPath = api.getApiUrl(`/content_views/${cvId}/copy`);
12
+ const setModalOpen = jest.fn();
13
+
14
+ const copyParams = {
15
+ id: cvId,
16
+ name: 'cv copy',
17
+ };
18
+
19
+ const copiedCVDetails = { ...cvCopyData };
20
+
21
+ const form = <CopyContentViewForm cvId={cvId} setModalOpen={setModalOpen} />;
22
+
23
+ test('Can copy content view from form', async (done) => {
24
+ const copyscope = nockInstance
25
+ .post(cvCopyPath, copyParams)
26
+ .reply(201, copiedCVDetails);
27
+ const { queryByText, getByLabelText } = renderWithRedux(form);
28
+ expect(queryByText('Name')).toBeInTheDocument();
29
+
30
+ fireEvent.change(getByLabelText('input_name'), { target: { value: 'cv copy' } });
31
+
32
+ getByLabelText('copy_content_view').click();
33
+ // Form closes it self on success
34
+ await patientlyWaitFor(() => {
35
+ expect(queryByText('Name')).not.toBeInTheDocument();
36
+ });
37
+
38
+ assertNockRequest(copyscope, done);
39
+ });
@@ -0,0 +1,4 @@
1
+ import { withRouter } from 'react-router-dom';
2
+ import CopyContentViewModal from './CopyContentViewModal';
3
+
4
+ export default withRouter(CopyContentViewModal);
@@ -0,0 +1,16 @@
1
+ import {
2
+ selectAPIStatus,
3
+ selectAPIError,
4
+ selectAPIResponse,
5
+ } from 'foremanReact/redux/API/APISelectors';
6
+ import { STATUS } from 'foremanReact/constants';
7
+ import { CREATE_CONTENT_VIEW_KEY } from '../ContentViewsConstants';
8
+
9
+ export const selectCreateContentViews = state =>
10
+ selectAPIResponse(state, CREATE_CONTENT_VIEW_KEY) || {};
11
+
12
+ export const selectCreateContentViewStatus = state =>
13
+ selectAPIStatus(state, CREATE_CONTENT_VIEW_KEY) || STATUS.PENDING;
14
+
15
+ export const selectCreateContentViewError = state =>
16
+ selectAPIError(state, CREATE_CONTENT_VIEW_KEY);
@@ -0,0 +1,58 @@
1
+ import React from 'react';
2
+ import { translate as __ } from 'foremanReact/common/I18n';
3
+ import { OutlinedQuestionCircleIcon } from '@patternfly/react-icons';
4
+ import { Tooltip, TooltipPosition, Flex, FlexItem } from '@patternfly/react-core';
5
+ import { autoPublishHelpText, dependenciesHelpText, importOnlyHelpText } from '../helpers';
6
+ import ContentViewIcon from '../components/ContentViewIcon';
7
+
8
+ const HelpToolTip = tooltip => (
9
+ <span className="foreman-spaced-icon">
10
+ <Tooltip
11
+ position={TooltipPosition.top}
12
+ content={tooltip}
13
+ >
14
+ <OutlinedQuestionCircleIcon />
15
+ </Tooltip>
16
+ </span>
17
+ );
18
+
19
+ export const LabelComposite = () => (
20
+ <Flex>
21
+ <FlexItem spacer={{ default: 'spacerNone' }}><ContentViewIcon composite /></FlexItem>
22
+ <FlexItem>{__('Composite Content View')}</FlexItem>
23
+ </Flex>
24
+ );
25
+
26
+ export const LabelComponent = () => (
27
+ <Flex>
28
+ <FlexItem spacer={{ default: 'spacerNone' }}><ContentViewIcon composite={false} /></FlexItem>
29
+ <FlexItem>{__('Component Content View')}</FlexItem>
30
+ </Flex>
31
+ );
32
+
33
+ export const LabelDependencies = () => (
34
+ <Flex>
35
+ <FlexItem spacer={{ default: 'spacerSm' }}>{__('Solve Dependencies')}</FlexItem>
36
+ <FlexItem>
37
+ {HelpToolTip(dependenciesHelpText)}
38
+ </FlexItem>
39
+ </Flex>
40
+ );
41
+
42
+ export const LabelAutoPublish = () => (
43
+ <Flex>
44
+ <FlexItem spacer={{ default: 'spacerSm' }}>{__('Auto Publish')}</FlexItem>
45
+ <FlexItem>
46
+ {HelpToolTip(autoPublishHelpText)}
47
+ </FlexItem>
48
+ </Flex>
49
+ );
50
+
51
+ export const LabelImportOnly = () => (
52
+ <Flex>
53
+ <FlexItem spacer={{ default: 'spacerSm' }}>{__('Import Only')}</FlexItem>
54
+ <FlexItem>
55
+ {HelpToolTip(importOnlyHelpText)}
56
+ </FlexItem>
57
+ </Flex>
58
+ );
@@ -0,0 +1,175 @@
1
+ import { STATUS } from 'foremanReact/constants';
2
+ import React, { useState, useEffect } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ import { useDispatch, useSelector } from 'react-redux';
5
+ import { Redirect } from 'react-router-dom';
6
+ import { Form, FormGroup, TextInput, TextArea, Checkbox, ActionGroup, Button, Tile, Grid, GridItem } from '@patternfly/react-core';
7
+ import { createContentView } from '../ContentViewsActions';
8
+ import { selectCreateContentViews, selectCreateContentViewStatus, selectCreateContentViewError } from './ContentViewCreateSelectors';
9
+ import { LabelDependencies, LabelAutoPublish, LabelImportOnly } from './ContentViewFormComponents';
10
+ import ContentViewIcon from '../components/ContentViewIcon';
11
+
12
+ const CreateContentViewForm = ({ setModalOpen }) => {
13
+ const dispatch = useDispatch();
14
+ const [name, setName] = useState('');
15
+ const [label, setLabel] = useState('');
16
+ const [description, setDescription] = useState('');
17
+ const [composite, setComposite] = useState(false);
18
+ const [component, setComponent] = useState(true);
19
+ const [autoPublish, setAutoPublish] = useState(false);
20
+ const [importOnly, setImportOnly] = useState(false);
21
+ const [dependencies, setDependencies] = useState(false);
22
+ const [redirect, setRedirect] = useState(false);
23
+ const [saving, setSaving] = useState(false);
24
+
25
+ const response = useSelector(selectCreateContentViews);
26
+ const status = useSelector(selectCreateContentViewStatus);
27
+ const error = useSelector(selectCreateContentViewError);
28
+
29
+ useEffect(() => {
30
+ const { id } = response;
31
+ if (id && status === STATUS.RESOLVED) {
32
+ setSaving(false);
33
+ setRedirect(true);
34
+ } else if (status === STATUS.ERROR) {
35
+ setSaving(false);
36
+ }
37
+ }, [JSON.stringify(response), status, error]);
38
+
39
+ const onSave = () => {
40
+ setSaving(true);
41
+ dispatch(createContentView({
42
+ name,
43
+ label,
44
+ description,
45
+ composite,
46
+ solve_dependencies: dependencies,
47
+ auto_publish: (autoPublish && composite),
48
+ import_only: importOnly,
49
+ }));
50
+ };
51
+
52
+ useEffect(
53
+ () => {
54
+ setLabel(name.replace(/ /g, '_'));
55
+ },
56
+ [name],
57
+ );
58
+
59
+ if (redirect) {
60
+ const { id } = response;
61
+ return (<Redirect to={`/labs/content_views/${id}`} />);
62
+ }
63
+
64
+ return (
65
+ <Form>
66
+ <FormGroup label="Name" isRequired fieldId="name">
67
+ <TextInput
68
+ isRequired
69
+ type="text"
70
+ id="name"
71
+ aria-label="input_name"
72
+ name="name"
73
+ value={name}
74
+ onChange={value => setName(value)}
75
+ />
76
+ </FormGroup>
77
+ <FormGroup label="Label" isRequired fieldId="label">
78
+ <TextInput
79
+ isRequired
80
+ type="text"
81
+ id="label"
82
+ aria-label="input_label"
83
+ name="label"
84
+ value={label}
85
+ onChange={value => setLabel(value)}
86
+ />
87
+ </FormGroup>
88
+ <FormGroup label="Description" fieldId="description">
89
+ <TextArea
90
+ isRequired
91
+ type="text"
92
+ id="description"
93
+ name="description"
94
+ aria-label="input_description"
95
+ value={description}
96
+ onChange={value => setDescription(value)}
97
+ />
98
+ </FormGroup>
99
+ <FormGroup isInline fieldId="type" label="Type">
100
+ <Grid hasGutter>
101
+ <GridItem span={6}>
102
+ <Tile
103
+ isStacked
104
+ aria-label="component_tile"
105
+ icon={<ContentViewIcon composite={false} />}
106
+ id="component"
107
+ title="Component content view"
108
+ onClick={() => { setComponent(true); setComposite(false); }}
109
+ isSelected={component}
110
+ >
111
+ Single content view consisting of repositories
112
+ </Tile>
113
+ </GridItem>
114
+ <GridItem span={6}>
115
+ <Tile
116
+ isStacked
117
+ aria-label="composite_tile"
118
+ icon={<ContentViewIcon composite />}
119
+ id="composite"
120
+ title="Composite content view"
121
+ onClick={() => { setComposite(true); setComponent(false); }}
122
+ isSelected={composite}
123
+ >
124
+ Consists of component content views
125
+ </Tile>
126
+ </GridItem>
127
+ </Grid>
128
+ </FormGroup>
129
+ {!composite &&
130
+ <FormGroup isInline fieldId="dependencies">
131
+ <Checkbox
132
+ id="dependencies"
133
+ name="dependencies"
134
+ label={LabelDependencies()}
135
+ isChecked={dependencies}
136
+ onChange={checked => setDependencies(checked)}
137
+ />
138
+ </FormGroup>}
139
+ {!composite &&
140
+ <FormGroup isInline fieldId="importOnly">
141
+ <Checkbox
142
+ id="importOnly"
143
+ name="importOnly"
144
+ label={LabelImportOnly()}
145
+ isChecked={importOnly}
146
+ onChange={checked => setImportOnly(checked)}
147
+ />
148
+ </FormGroup>}
149
+ {composite &&
150
+ <FormGroup isInline fieldId="autoPublish">
151
+ <Checkbox
152
+ id="autoPublish"
153
+ name="autoPublish"
154
+ label={LabelAutoPublish()}
155
+ isChecked={autoPublish}
156
+ onChange={checked => setAutoPublish(checked)}
157
+ />
158
+ </FormGroup>}
159
+ <ActionGroup>
160
+ <Button aria-label="create_content_view" variant="primary" isDisabled={saving} onClick={() => onSave()}>Create content view</Button>
161
+ <Button variant="link" onClick={() => setModalOpen(false)}>Cancel</Button>
162
+ </ActionGroup>
163
+ </Form>
164
+ );
165
+ };
166
+
167
+ CreateContentViewForm.propTypes = {
168
+ setModalOpen: PropTypes.func,
169
+ };
170
+
171
+ CreateContentViewForm.defaultProps = {
172
+ setModalOpen: null,
173
+ };
174
+
175
+ export default CreateContentViewForm;
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { Modal, ModalVariant } from '@patternfly/react-core';
4
+ import CreateContentViewForm from './CreateContentViewForm';
5
+
6
+ const CreateContentViewModal = ({ show, setIsOpen }) => (
7
+ <Modal
8
+ title="Create content view"
9
+ variant={ModalVariant.small}
10
+ isOpen={show}
11
+ onClose={() => { setIsOpen(false); }}
12
+ appendTo={document.body}
13
+ ><CreateContentViewForm setModalOpen={setIsOpen} />
14
+ </Modal>
15
+ );
16
+
17
+ CreateContentViewModal.propTypes = {
18
+ show: PropTypes.bool,
19
+ setIsOpen: PropTypes.func,
20
+ };
21
+
22
+ CreateContentViewModal.defaultProps = {
23
+ show: false,
24
+ setIsOpen: null,
25
+ };
26
+
27
+ export default CreateContentViewModal;
@@ -0,0 +1,42 @@
1
+ {
2
+ "content_host_count": 0,
3
+ "composite": false,
4
+ "component_ids": [],
5
+ "default": false,
6
+ "force_puppet_environment": false,
7
+ "version_count": 0,
8
+ "latest_version": null,
9
+ "auto_publish": false,
10
+ "solve_dependencies": false,
11
+ "import_only": false,
12
+ "repository_ids": [],
13
+ "id": 34,
14
+ "name": "1232123",
15
+ "label": "1232123",
16
+ "description": "",
17
+ "organization_id": 1,
18
+ "organization": {
19
+ "name": "Default Organization",
20
+ "label": "Default_Organization",
21
+ "id": 1
22
+ },
23
+ "created_at": "2020-12-14 12:45:59 -0500",
24
+ "updated_at": "2020-12-14 12:45:59 -0500",
25
+ "environments": [],
26
+ "repositories": [],
27
+ "puppet_modules": [],
28
+ "versions": [],
29
+ "components": [],
30
+ "content_view_components": [],
31
+ "activation_keys": [],
32
+ "next_version": "1.0",
33
+ "last_published": null,
34
+ "permissions": {
35
+ "view_content_views": true,
36
+ "edit_content_views": true,
37
+ "destroy_content_views": true,
38
+ "publish_content_views": true,
39
+ "promote_or_remove_content_views": true
40
+ },
41
+ "duplicate_repositories_to_publish": []
42
+ }
@@ -0,0 +1,92 @@
1
+ import React from 'react';
2
+ import { renderWithRedux, patientlyWaitFor, fireEvent } from 'react-testing-lib-wrapper';
3
+
4
+ import { nockInstance, assertNockRequest } from '../../../../test-utils/nockWrapper';
5
+ import api from '../../../../services/api';
6
+ import CreateContentViewForm from '../CreateContentViewForm';
7
+
8
+ const cvCreateData = require('./contentViewCreateResult.fixtures.json');
9
+
10
+ const cvCreatePath = api.getApiUrl('/content_views');
11
+
12
+ const setModalOpen = jest.fn();
13
+
14
+ const createDetails = {
15
+ name: '1232123',
16
+ label: '1232123',
17
+ description: '',
18
+ composite: false,
19
+ solve_dependencies: false,
20
+ auto_publish: false,
21
+ import_only: false,
22
+ };
23
+
24
+ const createdCVDetails = { ...cvCreateData };
25
+
26
+ const form = <CreateContentViewForm setModalOpen={setModalOpen} />;
27
+
28
+ test('Can save content view from form', async (done) => {
29
+ const createscope = nockInstance
30
+ .post(cvCreatePath, createDetails)
31
+ .reply(201, createdCVDetails);
32
+ const { queryByText, getByLabelText } = renderWithRedux(form);
33
+ expect(queryByText('Description')).toBeInTheDocument();
34
+
35
+ fireEvent.change(getByLabelText('input_name'), { target: { value: '1232123' } });
36
+
37
+ await patientlyWaitFor(() => { expect(getByLabelText('input_label')).toHaveAttribute('value', '1232123'); });
38
+
39
+ getByLabelText('create_content_view').click();
40
+
41
+ assertNockRequest(createscope, done);
42
+ });
43
+
44
+ test('Form closes itself upon save', async (done) => {
45
+ const createscope = nockInstance
46
+ .post(cvCreatePath, createDetails)
47
+ .reply(201, createdCVDetails);
48
+ const { getByText, queryByText, getByLabelText } = renderWithRedux(form);
49
+ expect(getByText('Description')).toBeInTheDocument();
50
+ expect(getByText('Name')).toBeInTheDocument();
51
+ expect(getByText('Label')).toBeInTheDocument();
52
+
53
+ fireEvent.change(getByLabelText('input_name'), { target: { value: '1232123' } });
54
+
55
+ await patientlyWaitFor(() => { expect(getByLabelText('input_label')).toHaveAttribute('value', '1232123'); });
56
+
57
+ getByLabelText('create_content_view').click();
58
+ // Form closes it self on success
59
+ await patientlyWaitFor(() => {
60
+ expect(queryByText('Description')).not.toBeInTheDocument();
61
+ });
62
+
63
+ assertNockRequest(createscope, done);
64
+ });
65
+
66
+ test('Displays dependent fields correctly', () => {
67
+ const { getByText, queryByText, getByLabelText } = renderWithRedux(form);
68
+ expect(getByText('Description')).toBeInTheDocument();
69
+ expect(getByText('Name')).toBeInTheDocument();
70
+ expect(getByText('Label')).toBeInTheDocument();
71
+ expect(getByText('Composite content view')).toBeInTheDocument();
72
+ expect(getByText('Component content view')).toBeInTheDocument();
73
+ expect(getByText('Solve Dependencies')).toBeInTheDocument();
74
+ expect(queryByText('Auto Publish')).not.toBeInTheDocument();
75
+ expect(getByText('Import Only')).toBeInTheDocument();
76
+
77
+ // label auto_set
78
+ fireEvent.change(getByLabelText('input_name'), { target: { value: '123 2123' } });
79
+ expect(getByLabelText('input_label')).toHaveAttribute('value', '123_2123');
80
+
81
+ // display Auto Publish when Composite CV
82
+ fireEvent.click(getByLabelText('composite_tile'));
83
+ expect(queryByText('Solve Dependencies')).not.toBeInTheDocument();
84
+ expect(getByText('Auto Publish')).toBeInTheDocument();
85
+ expect(queryByText('Import Only')).not.toBeInTheDocument();
86
+
87
+ // display Solve Dependencies when Component CV
88
+ fireEvent.click(getByLabelText('component_tile'));
89
+ expect(getByText('Solve Dependencies')).toBeInTheDocument();
90
+ expect(queryByText('Auto Publish')).not.toBeInTheDocument();
91
+ expect(getByText('Import Only')).toBeInTheDocument();
92
+ });