katello 4.5.1 → 4.6.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 (440) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/katello/api/rhsm/candlepin_dynflow_proxy_controller.rb +10 -0
  3. data/app/controllers/katello/api/v2/activation_keys_controller.rb +7 -0
  4. data/app/controllers/katello/api/v2/alternate_content_sources_controller.rb +52 -22
  5. data/app/controllers/katello/api/v2/content_uploads_controller.rb +2 -0
  6. data/app/controllers/katello/api/v2/content_view_filter_rules_controller.rb +1 -1
  7. data/app/controllers/katello/api/v2/content_view_filters_controller.rb +1 -1
  8. data/app/controllers/katello/api/v2/debs_controller.rb +42 -10
  9. data/app/controllers/katello/api/v2/host_collections_controller.rb +5 -1
  10. data/app/controllers/katello/api/v2/host_errata_controller.rb +1 -0
  11. data/app/controllers/katello/api/v2/host_module_streams_controller.rb +9 -1
  12. data/app/controllers/katello/api/v2/host_subscriptions_controller.rb +8 -1
  13. data/app/controllers/katello/api/v2/organizations_controller.rb +3 -1
  14. data/app/controllers/katello/api/v2/simple_content_access_controller.rb +8 -0
  15. data/app/controllers/katello/concerns/api/v2/repository_content_controller.rb +34 -11
  16. data/app/controllers/katello/concerns/organizations_controller_extensions.rb +7 -16
  17. data/app/lib/actions/katello/alternate_content_source/alternate_content_source_common.rb +16 -0
  18. data/app/lib/actions/katello/alternate_content_source/create.rb +11 -5
  19. data/app/lib/actions/katello/alternate_content_source/destroy.rb +3 -4
  20. data/app/lib/actions/katello/alternate_content_source/refresh.rb +3 -5
  21. data/app/lib/actions/katello/alternate_content_source/update.rb +57 -13
  22. data/app/lib/actions/katello/applicability/hosts/bulk_generate.rb +2 -2
  23. data/app/lib/actions/katello/organization/manifest_refresh.rb +8 -4
  24. data/app/lib/actions/katello/organization/simple_content_access/toggle.rb +1 -9
  25. data/app/lib/actions/katello/repository/create.rb +9 -0
  26. data/app/lib/actions/katello/repository/destroy.rb +21 -0
  27. data/app/lib/actions/katello/repository/errata_mail.rb +3 -3
  28. data/app/lib/actions/katello/repository/refresh_repository.rb +3 -0
  29. data/app/lib/actions/katello/repository/update.rb +33 -0
  30. data/app/lib/actions/katello/repository/update_redhat_repository.rb +1 -1
  31. data/app/lib/actions/pulp3/alternate_content_source/create.rb +5 -4
  32. data/app/lib/actions/pulp3/alternate_content_source/create_remote.rb +5 -4
  33. data/app/lib/actions/pulp3/alternate_content_source/delete.rb +4 -4
  34. data/app/lib/actions/pulp3/alternate_content_source/delete_remote.rb +4 -4
  35. data/app/lib/actions/pulp3/alternate_content_source/refresh.rb +4 -4
  36. data/app/lib/actions/pulp3/alternate_content_source/update.rb +4 -4
  37. data/app/lib/actions/pulp3/alternate_content_source/update_remote.rb +5 -5
  38. data/app/lib/actions/pulp3/capsule_content/reclaim_space.rb +1 -0
  39. data/app/lib/actions/pulp3/orchestration/alternate_content_source/create.rb +3 -3
  40. data/app/lib/actions/pulp3/orchestration/alternate_content_source/delete.rb +6 -7
  41. data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh.rb +2 -2
  42. data/app/lib/actions/pulp3/orchestration/alternate_content_source/refresh_remote.rb +18 -0
  43. data/app/lib/actions/pulp3/orchestration/alternate_content_source/update.rb +3 -3
  44. data/app/lib/actions/pulp3/orchestration/repository/generate_metadata.rb +1 -1
  45. data/app/lib/katello/concerns/base_template_scope_extensions.rb +1 -1
  46. data/app/lib/katello/errors.rb +1 -1
  47. data/app/lib/katello/resources/candlepin/owner.rb +9 -2
  48. data/app/lib/katello/validators/alternate_content_source_products_validator.rb +17 -0
  49. data/app/models/katello/alternate_content_source.rb +39 -8
  50. data/app/models/katello/alternate_content_source_product.rb +13 -0
  51. data/app/models/katello/concerns/host_managed_extensions.rb +12 -2
  52. data/app/models/katello/concerns/pulp_database_unit.rb +2 -2
  53. data/app/models/katello/concerns/smart_proxy_extensions.rb +5 -6
  54. data/app/models/katello/content_view.rb +4 -0
  55. data/app/models/katello/content_view_deb_filter.rb +51 -0
  56. data/app/models/katello/content_view_deb_filter_rule.rb +24 -0
  57. data/app/models/katello/content_view_filter.rb +10 -3
  58. data/app/models/katello/glue/candlepin/owner.rb +0 -1
  59. data/app/models/katello/installed_package.rb +1 -0
  60. data/app/models/katello/product.rb +3 -0
  61. data/app/models/katello/repository.rb +2 -0
  62. data/app/models/katello/smart_proxy_alternate_content_source.rb +6 -0
  63. data/app/services/cert/certs.rb +8 -16
  64. data/app/services/katello/content_unit_indexer.rb +2 -1
  65. data/app/services/katello/organization_creator.rb +4 -4
  66. data/app/services/katello/pulp/server.rb +2 -2
  67. data/app/services/katello/pulp3/alternate_content_source.rb +22 -4
  68. data/app/services/katello/pulp3/api/apt.rb +12 -0
  69. data/app/services/katello/pulp3/erratum.rb +1 -4
  70. data/app/services/katello/pulp3/repository/apt.rb +186 -2
  71. data/app/services/katello/pulp3/repository.rb +4 -3
  72. data/app/services/katello/pulp3/service_common.rb +1 -1
  73. data/app/services/katello/pulp3/smart_proxy_mirror_repository.rb +1 -1
  74. data/app/views/foreman/smart_proxies/show.html.erb +3 -3
  75. data/app/views/katello/api/v2/alternate_content_sources/base.json.rabl +18 -3
  76. data/app/views/katello/api/v2/alternate_content_sources/show.json.rabl +20 -0
  77. data/app/views/katello/api/v2/ansible_collections/compare.json.rabl +10 -0
  78. data/app/views/katello/api/v2/content_view_filters/base.json.rabl +5 -0
  79. data/app/views/katello/api/v2/module_streams/compare.json.rabl +10 -0
  80. data/app/views/katello/api/v2/repository_sets/show.json.rabl +4 -0
  81. data/app/views/katello/layouts/foreman_with_bastion.html.erb +1 -1
  82. data/app/views/katello/layouts/react.html.erb +1 -1
  83. data/app/views/overrides/organizations/_edit_override.html.erb +5 -8
  84. data/app/views/overrides/organizations/_index_row_override.html.erb +1 -1
  85. data/app/views/overrides/organizations/_step_1_override.html.erb +5 -0
  86. data/ca/redhat-uep.pem +18 -23
  87. data/config/katello.yaml.example +0 -2
  88. data/config/routes/api/v2.rb +2 -0
  89. data/config/routes/overrides.rb +1 -0
  90. data/db/migrate/20201116161820_create_content_view_deb_filter_rules.rb +17 -0
  91. data/db/migrate/20220524132259_remove_last_refreshed_from_katello_alternate_content_sources.rb +5 -0
  92. data/db/migrate/20220601163911_add_vendor_to_katello_installed_packages.rb +5 -0
  93. data/db/migrate/20220610165621_add_repositories_and_products_to_acs.rb +23 -0
  94. data/db/seeds.d/102-organizations.rb +1 -1
  95. data/engines/bastion/app/views/bastion/layouts/application.html.erb +1 -1
  96. data/engines/bastion/app/views/bastion/layouts/application_ie.html.erb +1 -1
  97. data/engines/bastion/app/views/bastion/layouts/assets.html.erb +1 -1
  98. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment-content.controller.js +2 -0
  99. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/environment.controller.js +2 -0
  100. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/details/views/environment-content-views.html +1 -1
  101. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/environments.controller.js +1 -0
  102. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/environments/views/environments.html +3 -3
  103. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/i18n/bastion_katello.pot +4 -5
  104. data/engines/bastion_katello/lib/bastion_katello/engine.rb +0 -1
  105. data/lib/katello/engine.rb +1 -2
  106. data/lib/katello/permission_creator.rb +2 -2
  107. data/lib/katello/permissions/host_permissions.rb +1 -0
  108. data/lib/katello/plugin.rb +6 -12
  109. data/lib/katello/version.rb +1 -1
  110. data/locale/action_names.rb +49 -46
  111. data/locale/bn/katello.po +361 -53
  112. data/{webpack/scenes/AnsibleCollections/AnsibleCollectionsTables.scss → locale/bn/katello.po.time_stamp} +0 -0
  113. data/locale/cs/katello.po +361 -53
  114. data/locale/cs/katello.po.time_stamp +0 -0
  115. data/locale/de/katello.po +366 -58
  116. data/locale/de/katello.po.time_stamp +0 -0
  117. data/locale/en/katello.po +361 -53
  118. data/locale/en/katello.po.time_stamp +0 -0
  119. data/locale/es/katello.po +364 -56
  120. data/locale/es/katello.po.time_stamp +0 -0
  121. data/locale/fr/katello.po +376 -68
  122. data/locale/fr/katello.po.time_stamp +0 -0
  123. data/locale/gu/katello.po +361 -53
  124. data/locale/gu/katello.po.time_stamp +0 -0
  125. data/locale/hi/katello.po +361 -53
  126. data/locale/hi/katello.po.time_stamp +0 -0
  127. data/locale/it/katello.po +361 -53
  128. data/locale/it/katello.po.time_stamp +0 -0
  129. data/locale/ja/katello.po +374 -66
  130. data/locale/ja/katello.po.time_stamp +0 -0
  131. data/locale/katello.pot +1626 -1079
  132. data/locale/kn/katello.po +361 -53
  133. data/locale/kn/katello.po.time_stamp +0 -0
  134. data/locale/ko/katello.po +361 -53
  135. data/locale/ko/katello.po.time_stamp +0 -0
  136. data/locale/mr/katello.po +361 -53
  137. data/locale/mr/katello.po.time_stamp +0 -0
  138. data/locale/or/katello.po +361 -53
  139. data/locale/or/katello.po.time_stamp +0 -0
  140. data/locale/pa/katello.po +361 -53
  141. data/locale/pa/katello.po.time_stamp +0 -0
  142. data/locale/pt/katello.po +361 -53
  143. data/locale/pt/katello.po.time_stamp +0 -0
  144. data/locale/pt_BR/katello.po +364 -56
  145. data/locale/pt_BR/katello.po.time_stamp +0 -0
  146. data/locale/ru/katello.po +361 -53
  147. data/locale/ru/katello.po.time_stamp +0 -0
  148. data/locale/ta/katello.po +361 -53
  149. data/locale/ta/katello.po.time_stamp +0 -0
  150. data/locale/te/katello.po +361 -53
  151. data/locale/te/katello.po.time_stamp +0 -0
  152. data/locale/zh_CN/katello.po +374 -66
  153. data/locale/zh_CN/katello.po.time_stamp +0 -0
  154. data/locale/zh_TW/katello.po +361 -53
  155. data/locale/zh_TW/katello.po.time_stamp +0 -0
  156. data/package.json +0 -3
  157. data/webpack/components/EditableTextInput/EditableTextInput.js +3 -16
  158. data/webpack/components/EditableTextInput/PencilEditButton.js +33 -0
  159. data/webpack/components/Errata/index.js +18 -3
  160. data/webpack/components/Loading.js +1 -1
  161. data/webpack/components/RoutedTabs/index.js +1 -17
  162. data/webpack/components/Search/Search.js +0 -1
  163. data/webpack/components/Search/__tests__/search.test.js +1 -2
  164. data/webpack/components/SelectAllCheckbox/index.js +7 -4
  165. data/webpack/components/SelectableDropdown/SelectableDropdown.js +1 -0
  166. data/webpack/components/Table/EmptyStateMessage.js +77 -2
  167. data/webpack/components/Table/MainTable.js +46 -4
  168. data/webpack/components/Table/TableHooks.js +9 -6
  169. data/webpack/components/Table/TableWrapper.js +14 -8
  170. data/webpack/components/TypeAhead/TypeAhead.js +26 -11
  171. data/webpack/components/TypeAhead/pf3Search/TypeAheadItems.js +1 -1
  172. data/webpack/components/TypeAhead/pf4Search/TypeAheadInput.js +1 -0
  173. data/webpack/components/extensions/HostDetails/Cards/ContentViewDetailsCard/ChangeHostCVModal.js +2 -1
  174. data/webpack/components/extensions/HostDetails/Cards/HostCollectionsCard/HostCollectionsModal.js +9 -4
  175. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeActions.js +37 -0
  176. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.js +173 -0
  177. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeCard.scss +6 -0
  178. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeConstants.js +6 -0
  179. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeEditModal.js +301 -0
  180. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/SystemPurposeSelectors.js +25 -0
  181. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeCard.test.js +108 -0
  182. data/webpack/components/extensions/HostDetails/Cards/SystemPurposeCard/__tests__/SystemPurposeEditModal.test.js +161 -0
  183. data/webpack/components/extensions/HostDetails/Cards/__tests__/errataOverviewCard.test.js +12 -12
  184. data/webpack/components/extensions/HostDetails/DetailsTabCards/HwPropertiesCard.js +100 -0
  185. data/webpack/components/extensions/HostDetails/DetailsTabCards/SystemPropertiesCardExtensions.js +26 -4
  186. data/webpack/components/extensions/HostDetails/HostDetailsConstants.js +3 -1
  187. data/webpack/components/extensions/HostDetails/HostDetailsReducer.js +14 -0
  188. data/webpack/components/extensions/HostDetails/HostDetailsSelectors.js +8 -2
  189. data/webpack/components/extensions/HostDetails/Tabs/ErrataTab/ErrataTab.js +8 -12
  190. data/webpack/components/extensions/HostDetails/Tabs/ModuleStreamsTab/ModuleStreamsTab.js +23 -2
  191. data/webpack/components/extensions/HostDetails/Tabs/PackagesTab/PackagesTab.js +5 -0
  192. data/webpack/components/extensions/HostDetails/Tabs/RepositorySetsTab/RepositorySetsTab.js +57 -7
  193. data/webpack/components/extensions/HostDetails/Tabs/TracesTab/TracesTab.js +2 -0
  194. data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySets.fixtures.json +3 -0
  195. data/webpack/components/extensions/HostDetails/Tabs/__tests__/repositorySetsTab.test.js +4 -1
  196. data/webpack/components/extensions/HostDetails/Tabs/__tests__/tracesTab.test.js +1 -10
  197. data/webpack/components/extensions/HostDetails/hostDetailsHelpers.js +1 -1
  198. data/webpack/components/extensions/RegistrationCommands/index.js +49 -17
  199. data/webpack/containers/Application/config.js +5 -10
  200. data/webpack/global_index.js +19 -7
  201. data/webpack/global_test_setup.js +14 -2
  202. data/webpack/ouia_id_check.js +95 -0
  203. data/webpack/redux/actions/RedHatRepositories/helpers.js +2 -0
  204. data/webpack/redux/reducers/index.js +2 -4
  205. data/webpack/scenes/AlternateContentSources/ACSActions.js +36 -3
  206. data/webpack/scenes/AlternateContentSources/ACSConstants.js +3 -0
  207. data/webpack/scenes/AlternateContentSources/ACSSelectors.js +15 -6
  208. data/webpack/scenes/AlternateContentSources/Create/ACSCreateWizard.js +73 -42
  209. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSCreateFinish.js +26 -10
  210. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSProducts.js +44 -0
  211. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSReview.js +59 -45
  212. data/webpack/scenes/AlternateContentSources/Create/Steps/ACSSmartProxies.js +2 -1
  213. data/webpack/scenes/AlternateContentSources/Create/Steps/AcsUrlPaths.js +0 -1
  214. data/webpack/scenes/AlternateContentSources/Create/Steps/SelectSource.js +35 -19
  215. data/webpack/scenes/AlternateContentSources/Create/__tests__/acsCreate.test.js +120 -13
  216. data/webpack/scenes/AlternateContentSources/Create/__tests__/products.fixtures.json +92 -0
  217. data/webpack/scenes/AlternateContentSources/Details/ACSExpandableDetails.js +459 -0
  218. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditCredentials.js +354 -0
  219. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditDetails.js +104 -0
  220. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditProducts.js +120 -0
  221. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditSmartProxies.js +118 -0
  222. data/webpack/scenes/AlternateContentSources/Details/EditModals/ACSEditURLPaths.js +118 -0
  223. data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSEdits.test.js +242 -0
  224. data/webpack/scenes/AlternateContentSources/Details/__tests__/ACSExpandableDetails.test.js +106 -0
  225. data/webpack/scenes/AlternateContentSources/Details/__tests__/acsDetails.fixtures.json +49 -0
  226. data/webpack/scenes/AlternateContentSources/Details/__tests__/acsProducts.fixtures.json +95 -0
  227. data/webpack/scenes/AlternateContentSources/Details/__tests__/simplifiedAcsDetails.fixtures.json +39 -0
  228. data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.js +215 -87
  229. data/webpack/scenes/AlternateContentSources/MainTable/ACSTable.scss +3 -0
  230. data/webpack/scenes/AlternateContentSources/MainTable/__tests__/acsTable.test.js +1 -2
  231. data/webpack/scenes/Content/__tests__/contentTable.test.js +1 -2
  232. data/webpack/scenes/ContentViews/ContentViewsConstants.js +15 -4
  233. data/webpack/scenes/ContentViews/Delete/__tests__/contentViewDelete.test.js +1 -2
  234. data/webpack/scenes/ContentViews/Details/ComponentContentViews/ContentViewComponents.js +2 -0
  235. data/webpack/scenes/ContentViews/Details/ComponentContentViews/__tests__/contentViewComponents.test.js +1 -2
  236. data/webpack/scenes/ContentViews/Details/ContentViewDetailActions.js +113 -0
  237. data/webpack/scenes/ContentViews/Details/ContentViewDetailSelectors.js +89 -0
  238. data/webpack/scenes/ContentViews/Details/Filters/Add/CVFilterAddModal.js +32 -9
  239. data/webpack/scenes/ContentViews/Details/Filters/Add/__tests__/cvFilterAdd.test.js +13 -3
  240. data/webpack/scenes/ContentViews/Details/Filters/CVContainerImageFilterContent.js +39 -27
  241. data/webpack/scenes/ContentViews/Details/Filters/CVDebFilterContent.js +236 -0
  242. data/webpack/scenes/ContentViews/Details/Filters/CVErrataIDFilterContent.js +1 -0
  243. data/webpack/scenes/ContentViews/Details/Filters/CVFilterDetailType.js +10 -0
  244. data/webpack/scenes/ContentViews/Details/Filters/CVModuleStreamFilterContent.js +3 -0
  245. data/webpack/scenes/ContentViews/Details/Filters/CVPackageGroupFilterContent.js +3 -1
  246. data/webpack/scenes/ContentViews/Details/Filters/CVRpmFilterContent.js +17 -4
  247. data/webpack/scenes/ContentViews/Details/Filters/ContentType.js +1 -0
  248. data/webpack/scenes/ContentViews/Details/Filters/ContentViewFilters.js +34 -22
  249. data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/CVDebMatchContentModal.js +97 -0
  250. data/webpack/scenes/ContentViews/Details/Filters/MatchContentModal/__tests__/CVRpmMatchContentModal.test.js +1 -2
  251. data/webpack/scenes/ContentViews/Details/Filters/Rules/DebPackage/AddEditDebPackageRuleModal.js +128 -0
  252. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVContainerImageFilterContent.test.js +56 -3
  253. data/webpack/scenes/ContentViews/Details/Filters/__tests__/CVRpmFilterContent.test.js +62 -8
  254. data/webpack/scenes/ContentViews/Details/Filters/__tests__/ContentViewPackageGroupFilter.test.js +1 -5
  255. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilterDetails.test.js +1 -2
  256. data/webpack/scenes/ContentViews/Details/Filters/__tests__/contentViewFilters.test.js +32 -2
  257. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvErrataIDFilter.test.js +1 -2
  258. data/webpack/scenes/ContentViews/Details/Filters/__tests__/cvModuleStreamFilter.test.js +1 -2
  259. data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVContainerImageFilterContent.fixtures.json +13 -0
  260. data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyCVPackageFilterRules.fixtures.json +13 -0
  261. data/webpack/scenes/ContentViews/Details/Filters/__tests__/emptyContentViewFilters.fixtures.json +13 -0
  262. data/webpack/scenes/ContentViews/Details/Histories/__tests__/contentViewHistory.test.js +1 -2
  263. data/webpack/scenes/ContentViews/Details/Repositories/ContentViewRepositories.js +5 -1
  264. data/webpack/scenes/ContentViews/Details/Repositories/__tests__/contentViewAddRemove.test.js +1 -2
  265. data/webpack/scenes/ContentViews/Details/Versions/BulkDelete/__tests__/BulkDeleteModal.test.js +3 -0
  266. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.js +143 -0
  267. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompare.scss +51 -0
  268. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareConfig.js +314 -0
  269. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareHeader.js +186 -0
  270. data/webpack/scenes/ContentViews/Details/Versions/Compare/CVVersionCompareTable.js +74 -0
  271. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/AnsibleCollectionsCompareAllContentData.fixtures.json +63 -0
  272. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionCompare.test.js +657 -0
  273. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/CVVersionEmptyContentCompareData.fixtures.json +14 -0
  274. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ContainerTagsCompareAllContentData.fixtures.json +95 -0
  275. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/DebPackagesCompareAllContentData.fixtures.json +87 -0
  276. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareAllContentData.fixtures.json +319 -0
  277. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ErrataCompareThreeContentTypesData.fixtures.json +131 -0
  278. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareAllContentData.fixtures.json +51 -0
  279. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/FilesCompareThreeContentTypesData.fixtures.json +48 -0
  280. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/ModuleStreamsCompareAllContentData.fixtures.json +239 -0
  281. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PackageGroupsCompareAllContentData.fixtures.json +51 -0
  282. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/PythonPackagesCompareAllContentData.fixtures.json +315 -0
  283. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareAllContentData.fixtures.json +470 -0
  284. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/RPMPackagesCompareThreeContentTypesData.fixtures.json +475 -0
  285. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewDetails.fixtures.json +160 -0
  286. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionOneDetials.fixtures.json +161 -0
  287. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionThreeDetails.fixtures.json +154 -0
  288. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersionTwoDetails.fixtures.json +211 -0
  289. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/contentViewVersions.fixtures.json +1013 -0
  290. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionOneDetails.fixtures.json +145 -0
  291. data/webpack/scenes/ContentViews/Details/Versions/Compare/__tests__/emptyStateCVVersionTwoDetails.fixtures.json +145 -0
  292. data/webpack/scenes/ContentViews/Details/Versions/ContentViewVersions.js +102 -36
  293. data/webpack/scenes/ContentViews/Details/Versions/Delete/__tests__/cvVersionRemove.test.js +1 -2
  294. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/ContentViewVersionDetailConfig.js +4 -2
  295. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetails.test.js +1 -2
  296. data/webpack/scenes/ContentViews/Details/Versions/VersionDetails/__tests__/ContentViewVersionDetailsEmpty.test.js +1 -2
  297. data/webpack/scenes/ContentViews/Details/Versions/__tests__/contentViewVersions.test.js +113 -40
  298. data/webpack/scenes/ContentViews/Table/ContentViewsTable.js +96 -81
  299. data/webpack/scenes/ContentViews/__tests__/contentViewPage.test.js +1 -2
  300. data/webpack/scenes/ContentViews/__tests__/mockDetails.fixtures.json +7 -2
  301. data/webpack/scenes/SmartProxy/SmartProxyContentActions.js +1 -1
  302. data/webpack/scenes/Subscriptions/Manifest/ManageManifestModal.js +0 -30
  303. data/webpack/test-utils/nockWrapper.js +7 -0
  304. metadata +100 -145
  305. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.controller.js +0 -34
  306. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/content-views.routes.js +0 -751
  307. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-deletion.controller.js +0 -42
  308. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-activation-keys.controller.js +0 -81
  309. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-confirm.controller.js +0 -65
  310. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-content-hosts.controller.js +0 -82
  311. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion-environments.controller.js +0 -76
  312. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/content-view-version-deletion.controller.js +0 -160
  313. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/content-view-deletion.html +0 -58
  314. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-activation-keys.html +0 -94
  315. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-confirm.html +0 -76
  316. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-content-hosts.html +0 -88
  317. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/deletion/views/version-deletion-environments.html +0 -73
  318. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-component.factory.js +0 -32
  319. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-available-content-views.controller.js +0 -75
  320. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/content-view-composite-content-views-list.controller.js +0 -68
  321. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-available-content-views.html +0 -81
  322. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite-content-views-list.html +0 -81
  323. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/components/views/content-view-composite.html +0 -24
  324. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-deb-repositories.controller.js +0 -50
  325. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-docker-repositories.controller.js +0 -42
  326. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-file-repositories.controller.js +0 -50
  327. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-ostree-repositories.controller.js +0 -42
  328. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-available-repositories.controller.js +0 -45
  329. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-deb-repositories-list.controller.js +0 -48
  330. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-details.controller.js +0 -100
  331. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-docker-repositories-list.controller.js +0 -49
  332. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-file-repositories-list.controller.js +0 -48
  333. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-ostree-repositories-list.controller.js +0 -49
  334. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-promotion.controller.js +0 -129
  335. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-publish.controller.js +0 -46
  336. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories-list.controller.js +0 -42
  337. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-repositories.service.js +0 -91
  338. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/content-view-versions.controller.js +0 -240
  339. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-errata-filter.controller.js +0 -115
  340. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-module-stream-filter.controller.js +0 -68
  341. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/available-package-group-filter.controller.js +0 -66
  342. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/date-type-errata-filter.controller.js +0 -77
  343. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/docker-tag-filter.controller.js +0 -137
  344. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/edit-filter.controller.js +0 -36
  345. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter-list.controller.js +0 -78
  346. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/errata-filter.controller.js +0 -74
  347. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-content-type.filter.js +0 -21
  348. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-details.controller.js +0 -34
  349. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-helper.service.js +0 -30
  350. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-repositories.controller.js +0 -86
  351. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-rule-matching-package-modal.controller.js +0 -37
  352. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter-type.filter.js +0 -21
  353. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filter.factory.js +0 -66
  354. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/filters.controller.js +0 -85
  355. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/module-stream-list-filter.controller.js +0 -73
  356. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/new-filter.controller.js +0 -100
  357. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-filter.controller.js +0 -179
  358. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/package-group-list-filter.controller.js +0 -75
  359. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/rule.factory.js +0 -21
  360. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata-filter.html +0 -9
  361. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/date-type-errata.html +0 -75
  362. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-filter.html +0 -28
  363. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/docker-tag-filter-details.html +0 -65
  364. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/edit-filter.html +0 -19
  365. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter-details.html +0 -63
  366. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/errata-filter.html +0 -50
  367. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-details.html +0 -9
  368. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-repositories.html +0 -121
  369. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filter-rule-matching-package-modal.html +0 -43
  370. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/filters.html +0 -85
  371. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter-details.html +0 -58
  372. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/module-stream-filter.html +0 -43
  373. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/new-filter.html +0 -62
  374. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter-details.html +0 -182
  375. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-filter.html +0 -28
  376. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter-details.html +0 -42
  377. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/package-group-filter.html +0 -43
  378. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/filters/views/partials/filter-repositories-count.html +0 -2
  379. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.controller.js +0 -47
  380. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/content-view-history.factory.js +0 -22
  381. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/histories/views/content-view-history.html +0 -36
  382. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-copy.html +0 -20
  383. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-deb-repositories.html +0 -87
  384. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details-tasks.html +0 -4
  385. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-details.html +0 -144
  386. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-docker-repositories.html +0 -114
  387. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-file-repositories.html +0 -87
  388. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-info.html +0 -63
  389. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-ostree-repositories.html +0 -87
  390. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-promotion.html +0 -59
  391. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-publish.html +0 -58
  392. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-repositories.html +0 -116
  393. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/details/views/content-view-versions.html +0 -126
  394. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/content-view-new.controller.js +0 -78
  395. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/new/views/content-view-new.html +0 -127
  396. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version-content.controller.js +0 -138
  397. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/content-view-version.controller.js +0 -59
  398. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-apt.html +0 -25
  399. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-components.html +0 -19
  400. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-deb.html +0 -19
  401. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-details.html +0 -15
  402. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-docker.html +0 -23
  403. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-errata.html +0 -48
  404. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-file.html +0 -21
  405. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-module-streams.html +0 -8
  406. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-package-groups.html +0 -21
  407. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-packages.html +0 -27
  408. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version-yum.html +0 -42
  409. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/versions/views/content-view-version.html +0 -83
  410. data/engines/bastion_katello/app/assets/javascripts/bastion_katello/content-views/views/content-views.html +0 -74
  411. data/webpack/components/Table/__test__/useBulkSelect.test.js +0 -99
  412. data/webpack/scenes/AnsibleCollections/AnsibleCollectionsActions.js +0 -30
  413. data/webpack/scenes/AnsibleCollections/AnsibleCollectionsConstants.js +0 -3
  414. data/webpack/scenes/AnsibleCollections/AnsibleCollectionsPage.js +0 -80
  415. data/webpack/scenes/AnsibleCollections/AnsibleCollectionsReducer.js +0 -39
  416. data/webpack/scenes/AnsibleCollections/AnsibleCollectionsTableSchema.js +0 -60
  417. data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetails.js +0 -94
  418. data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsActions.js +0 -23
  419. data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsConstants.js +0 -3
  420. data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionDetailsReducer.js +0 -30
  421. data/webpack/scenes/AnsibleCollections/Details/AnsibleCollectionsSchema.js +0 -35
  422. data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailInfo.test.js +0 -16
  423. data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.fixtures.js +0 -25
  424. data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetails.test.js +0 -27
  425. data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsActions.test.js +0 -41
  426. data/webpack/scenes/AnsibleCollections/Details/__tests__/AnsibleCollectionDetailsReducer.test.js +0 -33
  427. data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailInfo.test.js.snap +0 -83
  428. data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetails.test.js.snap +0 -190
  429. data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsActions.test.js.snap +0 -58
  430. data/webpack/scenes/AnsibleCollections/Details/__tests__/__snapshots__/AnsibleCollectionDetailsReducer.test.js.snap +0 -50
  431. data/webpack/scenes/AnsibleCollections/Details/index.js +0 -17
  432. data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionPage.test.js +0 -23
  433. data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollections.fixtures.js +0 -52
  434. data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsActions.test.js +0 -48
  435. data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsReducer.test.js +0 -46
  436. data/webpack/scenes/AnsibleCollections/__tests__/AnsibleCollectionsTable.test.js +0 -25
  437. data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionPage.test.js.snap +0 -73
  438. data/webpack/scenes/AnsibleCollections/__tests__/__snapshots__/AnsibleCollectionsTable.test.js.snap +0 -81
  439. data/webpack/scenes/AnsibleCollections/index.js +0 -17
  440. data/webpack/scenes/Subscriptions/Manifest/__tests__/ManageManifestModal.test.js +0 -123
@@ -5,11 +5,10 @@ module Actions
5
5
  def plan(acs)
6
6
  action_subject(acs)
7
7
  sequence do
8
- acs.smart_proxies.each do |smart_proxy|
9
- plan_action(Pulp3::Orchestration::AlternateContentSource::Delete,
10
- acs, smart_proxy)
8
+ acs.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
9
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Delete, smart_proxy_acs)
11
10
  end
12
- plan_self(:acs_id => acs.id)
11
+ plan_self(acs_id: acs.id)
13
12
  end
14
13
  end
15
14
 
@@ -5,17 +5,15 @@ module Actions
5
5
  def plan(acs)
6
6
  action_subject(acs)
7
7
  concurrence do
8
- acs.smart_proxies.each do |smart_proxy|
9
- plan_action(Pulp3::Orchestration::AlternateContentSource::Refresh,
10
- acs, smart_proxy)
8
+ acs.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
9
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Refresh, smart_proxy_acs)
11
10
  end
12
11
  end
13
12
  plan_self(acs_id: acs.id)
14
13
  end
15
14
 
16
15
  def finalize
17
- acs = ::Katello::AlternateContentSource.find_by(id: input[:acs_id])
18
- acs.update(last_refreshed: ::DateTime.now)
16
+ ::Katello::AlternateContentSource.find_by(id: input[:acs_id])&.audit_refresh
19
17
  end
20
18
 
21
19
  def humanized_name
@@ -2,32 +2,76 @@ module Actions
2
2
  module Katello
3
3
  module AlternateContentSource
4
4
  class Update < Actions::EntryAction
5
+ include Actions::Katello::AlternateContentSource::AlternateContentSourceCommon
5
6
  # smart_proxies ALWAYS represents the smart proxies to remain associated
6
7
  # after the action runs. If smart_proxies == [], there will be none afterwards.
7
- def plan(acs, smart_proxies, acs_params)
8
+ # The same rule applies to products.
9
+ def plan(acs, smart_proxies, products, acs_params)
8
10
  action_subject(acs)
9
11
  acs.update!(acs_params)
10
12
 
11
13
  smart_proxies = smart_proxies.uniq
12
- smart_proxies_to_add = smart_proxies - acs.smart_proxies
13
- smart_proxies_to_delete = acs.smart_proxies - smart_proxies
14
+ smart_proxies_to_associate = smart_proxies - acs.smart_proxies
15
+ smart_proxies_to_disassociate = acs.smart_proxies - smart_proxies
14
16
  smart_proxies_to_update = smart_proxies & acs.smart_proxies
15
17
 
18
+ products ||= []
19
+ products_to_associate = []
20
+ products_to_disassociate = []
21
+
22
+ if acs.simplified?
23
+ products = products.uniq
24
+ products_to_associate = products - acs.products
25
+ products_to_disassociate = acs.products - products
26
+ old_product_ids = acs.products.pluck(:id)
27
+ acs.products = products
28
+ acs.audit_updated_products(old_product_ids) unless products_to_associate.empty? && products_to_disassociate.empty?
29
+ end
30
+
16
31
  concurrence do
17
- smart_proxies_to_add&.each do |smart_proxy|
18
- ::Katello::SmartProxyAlternateContentSource.create(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id)
19
- plan_action(Pulp3::Orchestration::AlternateContentSource::Create,
20
- acs, smart_proxy)
32
+ create_acss(acs, smart_proxies_to_associate)
33
+ delete_acss(acs, smart_proxies_to_disassociate)
34
+ update_acss(acs, smart_proxies_to_update, products_to_associate, products_to_disassociate)
35
+ end
36
+ end
37
+
38
+ def create_acss(acs, smart_proxies_to_associate)
39
+ smart_proxies_to_associate&.each do |smart_proxy|
40
+ if acs.custom?
41
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.create(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id)
42
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Create, smart_proxy_acs)
43
+ elsif acs.simplified?
44
+ create_simplified_acs(acs, smart_proxy)
21
45
  end
46
+ end
47
+ end
22
48
 
23
- smart_proxies_to_delete&.each do |smart_proxy|
24
- plan_action(Pulp3::Orchestration::AlternateContentSource::Delete,
25
- acs, smart_proxy)
49
+ def delete_acss(acs, smart_proxies_to_disassociate)
50
+ smart_proxies_to_disassociate&.each do |smart_proxy|
51
+ acs.smart_proxy_alternate_content_sources.where(smart_proxy_id: smart_proxy.id).each do |smart_proxy_acs|
52
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Delete, smart_proxy_acs)
26
53
  end
54
+ end
55
+ end
27
56
 
28
- smart_proxies_to_update&.each do |smart_proxy|
29
- plan_action(Pulp3::Orchestration::AlternateContentSource::Update,
30
- acs, smart_proxy)
57
+ def update_acss(acs, smart_proxies_to_update, products_to_associate, products_to_disassociate)
58
+ smart_proxies_to_update&.each do |smart_proxy|
59
+ if acs.custom?
60
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find_by(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id, repository_id: nil)
61
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Update, smart_proxy_acs)
62
+ elsif acs.simplified?
63
+ products_to_associate.each do |product|
64
+ product.repositories.library.with_type(acs.content_type).each do |repo|
65
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.create(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id, repository_id: repo.id)
66
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Create, smart_proxy_acs)
67
+ end
68
+ end
69
+ products_to_disassociate.each do |product|
70
+ product.repositories.library.with_type(acs.content_type).each do |repo|
71
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find_by(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id, repository_id: repo.id)
72
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Delete, smart_proxy_acs)
73
+ end
74
+ end
31
75
  end
32
76
  end
33
77
  end
@@ -32,8 +32,8 @@ module Actions
32
32
  end
33
33
 
34
34
  def humanized_name
35
- if input[:host_ids]&.length == 1
36
- _("Bulk generate applicability for host %s" % hostname(input[:host_ids].first))
35
+ if input && input[:host_ids]&.length == 1
36
+ _("Bulk generate applicability for host %s" % hostname(input[:host_ids]&.first))
37
37
  else
38
38
  _("Bulk generate applicability for hosts")
39
39
  end
@@ -44,10 +44,14 @@ module Actions
44
44
 
45
45
  def plan_refresh_repos(import_products_action, org)
46
46
  repositories = ::Katello::Repository.in_default_view.in_product(::Katello::Product.redhat.in_org(org))
47
- repositories.each do |repo|
48
- plan_action(Katello::Repository::RefreshRepository,
49
- repo,
50
- :dependency => import_products_action.output)
47
+ repositories.in_groups_of(Setting[:foreman_proxy_content_batch_size], false) do |repo_batch|
48
+ concurrence do
49
+ repo_batch.each do |repo|
50
+ plan_action(Katello::Repository::RefreshRepository,
51
+ repo,
52
+ :dependency => import_products_action.output)
53
+ end
54
+ end
51
55
  end
52
56
  end
53
57
 
@@ -14,15 +14,7 @@ module Actions
14
14
  def plan(organization_id)
15
15
  @organization = ::Organization.find(organization_id)
16
16
  action_subject organization
17
- ::Katello::Resources::Candlepin::UpstreamConsumer.update(
18
- "#{consumer['apiUrl']}#{consumer['uuid']}",
19
- consumer['idCert']['cert'],
20
- consumer['idCert']['key'],
21
- nil,
22
- {contentAccessMode: content_access_mode_value}
23
- )
24
-
25
- plan_action(::Actions::Katello::Organization::ManifestRefresh, organization)
17
+ ::Katello::Resources::Candlepin::Owner.update(@organization.label, contentAccessMode: content_access_mode_value)
26
18
  end
27
19
 
28
20
  def failure_notification(plan)
@@ -2,6 +2,7 @@ module Actions
2
2
  module Katello
3
3
  module Repository
4
4
  class Create < Actions::EntryAction
5
+ # rubocop:disable Metrics/MethodLength
5
6
  def plan(repository, args = {})
6
7
  clone = args[:clone] || false
7
8
  force_repo_create = args[:force_repo_create] || false
@@ -33,6 +34,14 @@ module Actions
33
34
 
34
35
  concurrence do
35
36
  plan_self(:repository_id => repository.id, :clone => clone)
37
+ if repository.url.present?
38
+ repository.product.alternate_content_sources.with_type(repository.content_type).each do |acs|
39
+ acs.smart_proxies.each do |smart_proxy|
40
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.create(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id, repository_id: repository.id)
41
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Create, smart_proxy_acs)
42
+ end
43
+ end
44
+ end
36
45
  end
37
46
  end
38
47
  end
@@ -25,6 +25,8 @@ module Actions
25
25
 
26
26
  remove_versions(repository, repository.content_views.generated_for_none, affected_cvv_ids) if remove_from_content_view_versions
27
27
 
28
+ handle_alternate_content_sources(repository)
29
+
28
30
  plan_self(:user_id => ::User.current.id, :affected_cvv_ids => affected_cvv_ids)
29
31
  sequence do
30
32
  if repository.redhat?
@@ -52,6 +54,25 @@ module Actions
52
54
  end
53
55
  end
54
56
 
57
+ def handle_alternate_content_sources(repository)
58
+ product = repository.product
59
+ content_type = repository.content_type
60
+ repository.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
61
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Delete, smart_proxy_acs)
62
+ end
63
+
64
+ # Remove the product from the ACS if it's empty.
65
+ # An ACS with only an empty product will not function correctly
66
+ ## because there will be no smart_proxy_alternate_content_sources.
67
+ if product.repositories.with_type(content_type).count == 1
68
+ ::Katello::AlternateContentSource.with_products(product).each do |acs|
69
+ acs.products = acs.products - [product]
70
+ Rails.logger.info _('Removing product %{prod_name} with ID %{prod_id} from ACS %{acs_name} with ID %{acs_id}') %
71
+ { prod_name: product.name, prod_id: product.id, acs_name: acs.name, acs_id: acs.id }
72
+ end
73
+ end
74
+ end
75
+
55
76
  def handle_custom_content(repository, remove_from_content_view_versions)
56
77
  #if this is the last instance of a custom repo, destroy the content
57
78
  if remove_from_content_view_versions || repository.root.repositories.where.not(id: repository.id).empty?
@@ -5,15 +5,15 @@ module Actions
5
5
  middleware.use Actions::Middleware::ExecuteIfContentsChanged
6
6
 
7
7
  def plan(repo, contents_changed = nil)
8
- plan_self(:repo => repo.id, :contents_changed => contents_changed)
8
+ last_updated = repo.repository_errata.order('updated_at ASC').last.try(:updated_at) || Time.now
9
+ plan_self(:repo => repo.id, :contents_changed => contents_changed, :last_updated => last_updated.to_s)
9
10
  end
10
11
 
11
12
  def run
12
13
  ::User.current = ::User.anonymous_admin
13
14
  repo = ::Katello::Repository.find(input[:repo])
14
- last_updated = repo.repository_errata.order('updated_at ASC').last.try(:updated_at) || Time.now
15
15
  users = ::User.select { |user| user.receives?(:sync_errata) && user.organization_ids.include?(repo.organization.id) && user.can?(:view_products, repo.product) }.compact
16
- errata = ::Katello::Erratum.where(:id => repo.repository_errata.where('katello_repository_errata.updated_at > ?', last_updated).pluck(:erratum_id))
16
+ errata = ::Katello::Erratum.where(:id => repo.repository_errata.where('katello_repository_errata.updated_at > ?', input['last_updated'].to_datetime).pluck(:erratum_id))
17
17
 
18
18
  begin
19
19
  MailNotification[:sync_errata].deliver(:users => users, :repo => repo, :errata => errata) unless (users.blank? || errata.blank?)
@@ -7,6 +7,9 @@ module Actions
7
7
  repo = ::Katello::Repository.find(repo.id)
8
8
  plan_action(Actions::Pulp3::Orchestration::Repository::RefreshIfNeeded,
9
9
  repo, SmartProxy.default_capsule!, :dependency => options[:dependency])
10
+ repo.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
11
+ plan_action(::Actions::Pulp3::Orchestration::AlternateContentSource::RefreshRemote, smart_proxy_acs)
12
+ end
10
13
  plan_self(:name => repo.name, :dependency => options[:dependency])
11
14
  end
12
15
  end
@@ -10,7 +10,11 @@ module Actions
10
10
 
11
11
  repo_params[:url] = nil if repo_params[:url] == ''
12
12
  update_cv_cert_protected = repo_params.key?(:unprotected) && (repo_params[:unprotected] != repository.unprotected)
13
+ create_acs = create_acs?(repository.url, repo_params[:url])
14
+ delete_acs = delete_acs?(repository.url, repo_params[:url])
13
15
 
16
+ # Keep the old URL for RPM vs ULN remote cleanup
17
+ old_url = root.url
14
18
  root.update!(repo_params)
15
19
 
16
20
  if update_content?(repository)
@@ -43,6 +47,8 @@ module Actions
43
47
  if update_cv_cert_protected
44
48
  plan_optional_pulp_action([::Actions::Pulp3::Orchestration::Repository::TriggerUpdateRepoCertGuard], repository, ::SmartProxy.pulp_primary)
45
49
  end
50
+
51
+ handle_alternate_content_sources(repository, create_acs, delete_acs, old_url)
46
52
  end
47
53
  end
48
54
  end
@@ -55,9 +61,36 @@ module Actions
55
61
 
56
62
  private
57
63
 
64
+ def handle_alternate_content_sources(repository, create_acs, delete_acs, old_url)
65
+ if create_acs
66
+ repository.product.alternate_content_sources.each do |acs|
67
+ acs.smart_proxies.each do |smart_proxy|
68
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.create(alternate_content_source_id: acs.id, smart_proxy_id: smart_proxy.id, repository_id: repository.id)
69
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Create, smart_proxy_acs)
70
+ end
71
+ end
72
+ elsif delete_acs
73
+ repository.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
74
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Delete, smart_proxy_acs, old_url: old_url)
75
+ end
76
+ else
77
+ repository.smart_proxy_alternate_content_sources.each do |smart_proxy_acs|
78
+ plan_action(Pulp3::Orchestration::AlternateContentSource::Update, smart_proxy_acs)
79
+ end
80
+ end
81
+ end
82
+
58
83
  def update_content?(repository)
59
84
  repository.library_instance? && !repository.product.redhat?
60
85
  end
86
+
87
+ def create_acs?(old_url, new_url)
88
+ old_url.nil? && new_url.present?
89
+ end
90
+
91
+ def delete_acs?(old_url, new_url)
92
+ old_url.present? && new_url.nil?
93
+ end
61
94
  end
62
95
  end
63
96
  end
@@ -6,7 +6,7 @@ module Actions
6
6
  action_subject repo
7
7
  repo.root.update!(:url => upstream_url(repo)) if repo.library_instance?
8
8
  repo.update!(relative_path: relative_path(repo))
9
- plan_action(::Actions::Pulp3::Orchestration::Repository::RefreshIfNeeded, repo)
9
+ plan_action(::Actions::Katello::Repository::RefreshRepository, repo)
10
10
  plan_self(:repository_id => repo.id)
11
11
  end
12
12
 
@@ -2,13 +2,14 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class Create < Pulp3::Abstract
5
- def plan(acs, smart_proxy)
6
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id)
7
7
  end
8
8
 
9
9
  def run
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).create
10
+ smart_proxy_acs_id = input[:smart_proxy_acs_id]
11
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(smart_proxy_acs_id)
12
+ output[:response] = smart_proxy_acs.backend_service.create
12
13
  end
13
14
 
14
15
  def rescue_strategy
@@ -2,13 +2,14 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class CreateRemote < Pulp3::Abstract
5
- def plan(acs, smart_proxy)
6
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id)
7
7
  end
8
8
 
9
9
  def run
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).create_remote
10
+ smart_proxy_acs_id = input[:smart_proxy_acs_id]
11
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(smart_proxy_acs_id)
12
+ output[:response] = smart_proxy_acs.backend_service.create_remote
12
13
  end
13
14
 
14
15
  def rescue_strategy
@@ -2,13 +2,13 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class Delete < Pulp3::AbstractAsyncTask
5
- def plan(acs, smart_proxy)
6
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id)
7
7
  end
8
8
 
9
9
  def invoke_external_task
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).delete_alternate_content_source
10
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
11
+ output[:response] = smart_proxy_acs.backend_service.delete_alternate_content_source
12
12
  end
13
13
  end
14
14
  end
@@ -2,13 +2,13 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class DeleteRemote < Pulp3::AbstractAsyncTask
5
- def plan(acs, smart_proxy)
6
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs, options = {})
6
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id, old_url: options[:old_url])
7
7
  end
8
8
 
9
9
  def invoke_external_task
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).delete_remote
10
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
11
+ output[:response] = smart_proxy_acs.backend_service.delete_remote(old_url: input[:old_url])
12
12
  end
13
13
  end
14
14
  end
@@ -2,13 +2,13 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class Refresh < Pulp3::AbstractAsyncTask
5
- def plan(acs, smart_proxy)
6
- plan_self(acs_id: acs.id, smart_proxy_id: smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id)
7
7
  end
8
8
 
9
9
  def invoke_external_task
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).refresh
10
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
11
+ output[:response] = smart_proxy_acs.backend_service.refresh
12
12
  end
13
13
 
14
14
  def rescue_strategy_for_self
@@ -2,13 +2,13 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class Update < Pulp3::AbstractAsyncTask
5
- def plan(acs, smart_proxy)
6
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ plan_self(smart_proxy_acs_id: smart_proxy_acs.id, smart_proxy_id: smart_proxy_acs.smart_proxy_id)
7
7
  end
8
8
 
9
9
  def invoke_external_task
10
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
11
- output[:response] = acs.backend_service(smart_proxy).update
10
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
11
+ output[:response] = smart_proxy_acs.backend_service.update
12
12
  end
13
13
  end
14
14
  end
@@ -2,14 +2,14 @@ module Actions
2
2
  module Pulp3
3
3
  module AlternateContentSource
4
4
  class UpdateRemote < Pulp3::AbstractAsyncTask
5
- def plan(acs, smart_proxy)
6
- acs.backend_service(smart_proxy).create_test_remote
7
- plan_self(:acs_id => acs.id, :smart_proxy_id => smart_proxy.id)
5
+ def plan(smart_proxy_acs)
6
+ smart_proxy_acs.backend_service.create_test_remote
7
+ plan_self(smart_proxy_acs_id: smart_proxy_acs.id, smart_proxy_id: smart_proxy_acs.smart_proxy_id)
8
8
  end
9
9
 
10
10
  def invoke_external_task
11
- acs = ::Katello::AlternateContentSource.find(input[:acs_id])
12
- output[:response] = acs.backend_service(smart_proxy).update_remote
11
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
12
+ output[:response] = smart_proxy_acs.backend_service.update_remote
13
13
  end
14
14
  end
15
15
  end
@@ -12,6 +12,7 @@ module Actions
12
12
  end
13
13
  repository_hrefs = ::Katello::Pulp3::Api::Core.new(smart_proxy).core_repositories_list_all(fields: 'pulp_href').map(&:pulp_href)
14
14
  end
15
+ fail _('There is no downloaded content to clean.') if repository_hrefs.empty?
15
16
  plan_self(repository_hrefs: repository_hrefs, smart_proxy_id: smart_proxy.id)
16
17
  end
17
18
 
@@ -3,10 +3,10 @@ module Actions
3
3
  module Orchestration
4
4
  module AlternateContentSource
5
5
  class Create < Pulp3::Abstract
6
- def plan(acs, smart_proxy)
6
+ def plan(smart_proxy_acs)
7
7
  sequence do
8
- plan_action(Actions::Pulp3::AlternateContentSource::CreateRemote, acs, smart_proxy)
9
- plan_action(Actions::Pulp3::AlternateContentSource::Create, acs, smart_proxy)
8
+ plan_action(Actions::Pulp3::AlternateContentSource::CreateRemote, smart_proxy_acs)
9
+ plan_action(Actions::Pulp3::AlternateContentSource::Create, smart_proxy_acs)
10
10
  end
11
11
  end
12
12
  end
@@ -3,18 +3,17 @@ module Actions
3
3
  module Orchestration
4
4
  module AlternateContentSource
5
5
  class Delete < Pulp3::Abstract
6
- def plan(acs, smart_proxy)
6
+ def plan(smart_proxy_acs, options = {})
7
7
  sequence do
8
- plan_action(Actions::Pulp3::AlternateContentSource::Delete, acs, smart_proxy)
9
- plan_action(Actions::Pulp3::AlternateContentSource::DeleteRemote, acs, smart_proxy)
10
- plan_self(acs_id: acs.id, smart_proxy_id: smart_proxy.id)
8
+ plan_action(Actions::Pulp3::AlternateContentSource::Delete, smart_proxy_acs)
9
+ plan_action(Actions::Pulp3::AlternateContentSource::DeleteRemote, smart_proxy_acs, options)
10
+ plan_self(smart_proxy_id: smart_proxy_acs.smart_proxy_id, smart_proxy_acs_id: smart_proxy_acs.id)
11
11
  end
12
12
  end
13
13
 
14
14
  def finalize
15
- acs_id = input[:acs_id]
16
- smart_proxy_id = input[:smart_proxy_id]
17
- ::Katello::SmartProxyAlternateContentSource.find_by(alternate_content_source_id: acs_id, smart_proxy_id: smart_proxy_id).destroy
15
+ smart_proxy_acs_id = input[:smart_proxy_acs_id]
16
+ ::Katello::SmartProxyAlternateContentSource.find_by(id: smart_proxy_acs_id).destroy
18
17
  end
19
18
  end
20
19
  end
@@ -3,9 +3,9 @@ module Actions
3
3
  module Orchestration
4
4
  module AlternateContentSource
5
5
  class Refresh < Pulp3::Abstract
6
- def plan(acs, smart_proxy)
6
+ def plan(smart_proxy_acs)
7
7
  sequence do
8
- plan_action(Actions::Pulp3::AlternateContentSource::Refresh, acs, smart_proxy)
8
+ plan_action(Actions::Pulp3::AlternateContentSource::Refresh, smart_proxy_acs)
9
9
  end
10
10
  end
11
11
  end
@@ -0,0 +1,18 @@
1
+ module Actions
2
+ module Pulp3
3
+ module Orchestration
4
+ module AlternateContentSource
5
+ class RefreshRemote < Pulp3::AbstractAsyncTask
6
+ def plan(smart_proxy_acs)
7
+ plan_self(smart_proxy_acs_id: smart_proxy_acs.id, smart_proxy_id: smart_proxy_acs.smart_proxy_id)
8
+ end
9
+
10
+ def invoke_external_task
11
+ smart_proxy_acs = ::Katello::SmartProxyAlternateContentSource.find(input[:smart_proxy_acs_id])
12
+ smart_proxy_acs.backend_service.update_remote
13
+ end
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -3,10 +3,10 @@ module Actions
3
3
  module Orchestration
4
4
  module AlternateContentSource
5
5
  class Update < Pulp3::Abstract
6
- def plan(acs, smart_proxy)
6
+ def plan(smart_proxy_acs)
7
7
  sequence do
8
- plan_action(Actions::Pulp3::AlternateContentSource::UpdateRemote, acs, smart_proxy)
9
- plan_action(Actions::Pulp3::AlternateContentSource::Update, acs, smart_proxy)
8
+ plan_action(Actions::Pulp3::AlternateContentSource::UpdateRemote, smart_proxy_acs)
9
+ plan_action(Actions::Pulp3::AlternateContentSource::Update, smart_proxy_acs)
10
10
  end
11
11
  end
12
12
  end
@@ -16,7 +16,7 @@ module Actions
16
16
  plan_action(Actions::Pulp3::Repository::CreatePublication, repository, smart_proxy, options)
17
17
  end
18
18
  plan_action(Actions::Pulp3::ContentGuard::Refresh, smart_proxy) unless repository.unprotected
19
- plan_action(Actions::Pulp3::Repository::RefreshDistribution, repository, smart_proxy, :contents_changed => options[:contents_changed]) if repository.environment
19
+ plan_action(Actions::Pulp3::Repository::RefreshDistribution, repository, smart_proxy, :contents_changed => options[:contents_changed]) if Setting[:distribute_archived_cvv] || repository.environment
20
20
  end
21
21
  end
22
22
 
@@ -161,7 +161,7 @@ module Katello
161
161
  returns String, desc: 'Package version'
162
162
  end
163
163
  def host_latest_applicable_rpm_version(host, package)
164
- host.applicable_rpms.where(name: package).order(:version_sortable).limit(1).pluck(:nvra).first
164
+ ::Katello::Rpm.latest(host.applicable_rpms.where(name: package)).first.nvra
165
165
  end
166
166
 
167
167
  apipie :method, 'Loads Pool objects' do
@@ -154,7 +154,7 @@ module Katello
154
154
 
155
155
  class NoManifestImported < StandardError
156
156
  def message
157
- _("Current organization has no manifest imported.")
157
+ _("Current organization does not have a manifest imported.")
158
158
  end
159
159
  end
160
160
 
@@ -12,8 +12,14 @@ module Katello
12
12
 
13
13
  # Set the contentPrefix at creation time so that the client will get
14
14
  # content only for the org it has been subscribed to
15
- def create(key, description)
16
- attrs = {:key => key, :displayName => description, :contentPrefix => "/#{key}/$env"}
15
+ def create(key, description, content_access_mode: 'org_environment')
16
+ attrs = {
17
+ :key => key,
18
+ :displayName => description,
19
+ :contentPrefix => "/#{key}/$env",
20
+ :contentAccessMode => content_access_mode,
21
+ :contentAccessModeList => ['entitlement', 'org_environment'].join(',')
22
+ }
17
23
  owner_json = self.post(path, attrs.to_json, self.default_headers).body
18
24
  JSON.parse(owner_json).with_indifferent_access
19
25
  end
@@ -36,6 +42,7 @@ module Katello
36
42
  def update(key, attrs)
37
43
  owner = find(key)
38
44
  owner.merge!(attrs)
45
+ owner.merge!(:contentAccessModeList => ['entitlement', 'org_environment'].join(','))
39
46
  self.put(path(key), JSON.generate(owner), self.default_headers).body
40
47
  end
41
48