foreman_puppet 1.0.3 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (116) hide show
  1. checksums.yaml +4 -4
  2. data/app/controllers/concerns/foreman_puppet/extensions/api_hostgroups_controller.rb +14 -16
  3. data/app/controllers/concerns/foreman_puppet/{api/import_puppetclasses_common_controller.rb → extensions/api_smart_proxies_controller.rb} +9 -3
  4. data/app/controllers/concerns/foreman_puppet/extensions/api_template_combinations_controller.rb +23 -1
  5. data/app/controllers/concerns/foreman_puppet/extensions/api_v2_hosts_controller.rb +15 -17
  6. data/app/controllers/concerns/foreman_puppet/extensions/hostgroups_controller_extensions.rb +3 -1
  7. data/app/controllers/concerns/foreman_puppet/extensions/hosts_controller_extensions.rb +0 -1
  8. data/app/controllers/concerns/foreman_puppet/extensions/parameters_host.rb +41 -32
  9. data/app/controllers/concerns/foreman_puppet/extensions/parameters_hostgroup.rb +37 -34
  10. data/app/controllers/foreman_puppet/api/v2/environments_controller.rb +0 -1
  11. data/app/controllers/foreman_puppet/api/v2/hostgroup_classes_controller.rb +1 -1
  12. data/app/controllers/foreman_puppet/puppetclasses_controller.rb +1 -1
  13. data/app/helpers/foreman_puppet/environments_helper.rb +1 -1
  14. data/app/helpers/foreman_puppet/hosts_and_hostgroups_helper.rb +0 -5
  15. data/app/helpers/foreman_puppet/hosts_helper.rb +6 -10
  16. data/app/models/concerns/foreman_puppet/extensions/host.rb +2 -16
  17. data/app/models/concerns/foreman_puppet/extensions/hostgroup.rb +2 -7
  18. data/app/models/concerns/foreman_puppet/extensions/provisioning_template.rb +7 -12
  19. data/app/models/concerns/foreman_puppet/extensions/template_combination.rb +5 -10
  20. data/app/models/foreman_puppet/host_puppet_facet.rb +1 -1
  21. data/app/models/foreman_puppet/hostgroup_puppet_facet.rb +2 -0
  22. data/app/services/concerns/foreman_puppet/extensions/host_counter.rb +17 -0
  23. data/app/services/foreman_puppet/puppet_class_importer.rb +0 -6
  24. data/app/views/foreman_puppet/api/v2/host_puppet_facets/host_list.json.rabl +3 -0
  25. data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/base.json.rabl +2 -0
  26. data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/hostgroup_list.json.rabl +3 -0
  27. data/app/views/foreman_puppet/config_groups/index.html.erb +1 -1
  28. data/config/api_routes.rb +1 -9
  29. data/config/initializers/api_reroute.rb +73 -5
  30. data/db/migrate/20101121140000_add_environment_to_template_combinations.foreman_puppet.rb +1 -1
  31. data/db/migrate/20200803113803_migrate_environment_to_puppet_facet.foreman_puppet.rb +2 -0
  32. data/db/migrate/20200803113903_migrate_host_type_in_host_config_groups.foreman_puppet.rb +36 -20
  33. data/db/migrate/20201125113903_migrate_puppetclasses_to_facets.foreman_puppet.rb +0 -8
  34. data/db/migrate/20210924103241_remove_katello_id_from_environments.foreman_puppet.rb +5 -0
  35. data/db/migrate/20211111125003_drop_puppetclasses_direct_references.foreman_puppet.rb +11 -0
  36. data/db/migrate/20211112130803_cleanup_environment_from_core_tables.foreman_puppet.rb +10 -0
  37. data/db/migrate_foreman/{20090722141107_create_environments.rb → 20090722141107_create_environments.foreman_puppet.rb} +3 -3
  38. data/db/migrate_foreman/20090802062223_create_puppetclasses.foreman_puppet.rb +29 -0
  39. data/db/migrate_foreman/20090905150132_create_hostgroups_puppetclasses.foreman_puppet.rb +12 -0
  40. data/db/migrate_foreman/20110412103238_remove_unused_fields_from_puppet_classes.foreman_puppet.rb +9 -0
  41. data/db/migrate_foreman/20110712070522_create_host_class.foreman_puppet.rb +11 -0
  42. data/db/migrate_foreman/20120824142048_add_some_indexes.foreman_puppet.rb +21 -0
  43. data/db/migrate_foreman/{20120905095532_create_environment_classes.rb → 20120905095532_create_environment_classes.foreman_puppet.rb} +2 -2
  44. data/db/migrate_foreman/20121018152459_create_hostgroup_classes.foreman_puppet.rb +11 -0
  45. data/db/migrate_foreman/{20140407161817_create_config_groups.rb → 20140407161817_create_config_groups.foreman_puppet.rb} +0 -0
  46. data/db/migrate_foreman/{20140407162007_create_config_group_classes.rb → 20140407162007_create_config_group_classes.foreman_puppet.rb} +0 -0
  47. data/db/migrate_foreman/{20140407162059_create_host_config_groups.rb → 20140407162059_create_host_config_groups.foreman_puppet.rb} +0 -0
  48. data/db/migrate_foreman/{20161205142618_delete_orphaned_smart_class_parameters.rb → 20161205142618_delete_orphaned_smart_class_parameters.foreman_puppet.rb} +1 -1
  49. data/db/migrate_foreman/{20170109115157_fix_lookup_key_auditable_type.rb → 20170109115157_fix_lookup_key_auditable_type.foreman_puppet.rb} +0 -0
  50. data/db/migrate_foreman/20180816134832_cast_lookup_key_values.foreman_puppet.rb +5 -0
  51. data/db/migrate_foreman/20180831115634_add_uniqueness_to_puppetclass_name.foreman_puppet.rb +24 -0
  52. data/db/migrate_foreman/{20181023112532_add_environment_puppetclass_id.rb → 20181023112532_add_environment_puppetclass_id.foreman_puppet.rb} +1 -1
  53. data/db/migrate_foreman/{20181224174419_add_index_to_environment_class_by_lookup_key_and_puppetclass.rb → 20181224174419_add_index_to_environment_class_by_lookup_key_and_puppetclass.foreman_puppet.rb} +0 -0
  54. data/lib/foreman_puppet/engine.rb +6 -36
  55. data/lib/foreman_puppet/register.rb +49 -45
  56. data/lib/foreman_puppet/version.rb +1 -1
  57. data/lib/foreman_puppet.rb +1 -6
  58. data/locale/ca/LC_MESSAGES/foreman_puppet.mo +0 -0
  59. data/locale/ca/foreman_puppet.po +760 -0
  60. data/locale/cs_CZ/LC_MESSAGES/foreman_puppet.mo +0 -0
  61. data/locale/cs_CZ/foreman_puppet.edit.po +1085 -0
  62. data/locale/cs_CZ/foreman_puppet.po +823 -0
  63. data/locale/cs_CZ/foreman_puppet.po.time_stamp +0 -0
  64. data/locale/de/LC_MESSAGES/foreman_puppet.mo +0 -0
  65. data/locale/de/foreman_puppet.po +844 -0
  66. data/locale/en/LC_MESSAGES/foreman_puppet.mo +0 -0
  67. data/locale/en/foreman_puppet.edit.po +317 -162
  68. data/locale/en/foreman_puppet.po +119 -8
  69. data/locale/en_GB/LC_MESSAGES/foreman_puppet.mo +0 -0
  70. data/locale/en_GB/foreman_puppet.po +820 -0
  71. data/locale/es/LC_MESSAGES/foreman_puppet.mo +0 -0
  72. data/locale/es/foreman_puppet.po +827 -0
  73. data/locale/foreman_puppet.pot +376 -205
  74. data/locale/fr/LC_MESSAGES/foreman_puppet.mo +0 -0
  75. data/locale/fr/foreman_puppet.po +835 -0
  76. data/locale/gemspec.rb +1 -1
  77. data/locale/gl/LC_MESSAGES/foreman_puppet.mo +0 -0
  78. data/locale/gl/foreman_puppet.po +818 -0
  79. data/locale/it/LC_MESSAGES/foreman_puppet.mo +0 -0
  80. data/locale/it/foreman_puppet.po +822 -0
  81. data/locale/ja/LC_MESSAGES/foreman_puppet.mo +0 -0
  82. data/locale/ja/foreman_puppet.po +830 -0
  83. data/locale/ko/LC_MESSAGES/foreman_puppet.mo +0 -0
  84. data/locale/ko/foreman_puppet.po +819 -0
  85. data/locale/nl_NL/LC_MESSAGES/foreman_puppet.mo +0 -0
  86. data/locale/nl_NL/foreman_puppet.po +823 -0
  87. data/locale/pl/LC_MESSAGES/foreman_puppet.mo +0 -0
  88. data/locale/pl/foreman_puppet.po +822 -0
  89. data/locale/pt_BR/LC_MESSAGES/foreman_puppet.mo +0 -0
  90. data/locale/pt_BR/foreman_puppet.po +826 -0
  91. data/locale/ru/LC_MESSAGES/foreman_puppet.mo +0 -0
  92. data/locale/ru/foreman_puppet.po +827 -0
  93. data/locale/sv_SE/LC_MESSAGES/foreman_puppet.mo +0 -0
  94. data/locale/sv_SE/foreman_puppet.po +822 -0
  95. data/locale/zh_CN/LC_MESSAGES/foreman_puppet.mo +0 -0
  96. data/locale/zh_CN/foreman_puppet.po +831 -0
  97. data/locale/zh_TW/LC_MESSAGES/foreman_puppet.mo +0 -0
  98. data/locale/zh_TW/foreman_puppet.po +821 -0
  99. data/package.json +8 -11
  100. data/test/controllers/foreman_puppet/api/v2/environments_controller_test.rb +0 -231
  101. data/test/controllers/foreman_puppet/api/v2/smart_proxies_controller_test.rb +255 -0
  102. data/test/controllers/foreman_puppet/environments_controller_test.rb +2 -2
  103. data/test/controllers/foreman_puppet/hosts_controller_test.rb +0 -1
  104. data/test/factories/foreman_puppet_factories.rb +0 -2
  105. data/test/helpers/foreman_puppet/hosts_and_hostgroups_helper_test.rb +70 -31
  106. data/test/integration/foreman_puppet/dashboard_js_test.rb +31 -0
  107. data/test/integration/foreman_puppet/host_js_test.rb +0 -1
  108. data/test/integration/foreman_puppet/puppetclass_js_test.rb +1 -1
  109. data/test/models/foreman_puppet/host_puppet_facet_test.rb +7 -1
  110. data/test/models/foreman_puppet/host_test.rb +26 -0
  111. data/test/models/foreman_puppet/user_test.rb +1 -5
  112. data/test/services/foreman_puppet/host_counter_test.rb +17 -0
  113. data/test/unit/foreman_puppet/puppet_class_importer_test.rb +1 -1
  114. data/webpack/src/Components/Environments/Welcome.js +2 -2
  115. metadata +73 -18
  116. data/db/migrate_foreman/20180816134832_cast_lookup_key_values.rb +0 -35
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 06c268d86cd3905acdfcd56bc9898df23218553a632bb167c08de6c708351ee8
4
- data.tar.gz: fc9d44ecfdd418571796ccc39a302a5ac086bae221bc155ba5e827edfd45a9f0
3
+ metadata.gz: c850f32331462f52510a8e895c149eb470e9982ad819de78529c38c888ab549c
4
+ data.tar.gz: 81460cb582b62baa3f96083c3573a99607a9b2619d2a20c31df4f41da48677c6
5
5
  SHA512:
6
- metadata.gz: e4169751ebd02e01e6628a8583490d7257e27c7f0852e7539fc42b4b989258d3efef9324c684db31776a0d8f48e9360d0e3d40bdb12c03e8dd66d923f7d521e2
7
- data.tar.gz: a0384e376fa23ed7dd0ada27f525d04cbeaebd19a1933e91ce97628dc3a4abe74ba79d6857040e4c920071e3afeef7858d121329ecbd3f6db2aa0486de9dba5f
6
+ metadata.gz: f0b20469d894d6a1cc2e8c6f486ef5f09dd9c04742c0be684f68846fe930536a813ee404fb30af2ba0ae9031df6c2c00ea3a4af0233be5b24640b81d2a58d031
7
+ data.tar.gz: 16cab8e0431a72b04795046e4e66ca67a029247f4bf182a7a3f36e7ec8f2c5d45a1ae3db4ce8d96a48869a698eebec284eef6d9c0290d10270c41ab19789d0ee
@@ -6,25 +6,23 @@ module ForemanPuppet
6
6
  included do
7
7
  prepend PatchMethods
8
8
 
9
- if ForemanPuppet.extracted_from_core?
10
- method_desc = Apipie.get_method_description(self, :index)
11
- method_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/puppetclasses/:puppetclass_id/hostgroups', N_('List all host groups for a Puppet class'), {})
9
+ method_desc = Apipie.get_method_description(self, :index)
10
+ method_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/puppetclasses/:puppetclass_id/hostgroups', N_('List all host groups for a Puppet class'), {})
12
11
 
13
- apipie_update_methods([:index]) do
14
- param :puppetclass_id, String, desc: N_('ID of Puppetclass')
15
- end
12
+ apipie_update_methods([:index]) do
13
+ param :puppetclass_id, String, desc: N_('ID of Puppetclass')
14
+ end
16
15
 
17
- apipie_update_methods(%i[create update]) do
18
- param :hostgroup, Hash do
19
- param :environment_id, String, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/environment_id')
20
- param :puppetclass_ids, Array, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/puppetclass_ids')
21
- param :config_group_ids, Array, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/config_group_ids')
16
+ apipie_update_methods(%i[create update]) do
17
+ param :hostgroup, Hash do
18
+ param :environment_id, String, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/environment_id')
19
+ param :puppetclass_ids, Array, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/puppetclass_ids')
20
+ param :config_group_ids, Array, desc: N_('Deprecated in favor of hostgroup/puppet_attributes/config_group_ids')
22
21
 
23
- param :puppet_attributes, Hash do
24
- param :environment_id, String, desc: N_('ID of associated puppet Environment')
25
- param :puppetclass_ids, Array, desc: N_('IDs of associated Puppetclasses')
26
- param :config_group_ids, Array, desc: N_('IDs of associated ConfigGroups')
27
- end
22
+ param :puppet_attributes, Hash do
23
+ param :environment_id, String, desc: N_('ID of associated puppet Environment')
24
+ param :puppetclass_ids, Array, desc: N_('IDs of associated Puppetclasses')
25
+ param :config_group_ids, Array, desc: N_('IDs of associated ConfigGroups')
28
26
  end
29
27
  end
30
28
  end
@@ -1,6 +1,6 @@
1
1
  module ForemanPuppet
2
- module Api
3
- module ImportPuppetclassesCommonController
2
+ module Extensions
3
+ module ApiSmartProxiesController
4
4
  extend ActiveSupport::Concern
5
5
 
6
6
  included do
@@ -74,7 +74,13 @@ module ForemanPuppet
74
74
  end
75
75
 
76
76
  unless @environments.any?
77
- render_message(_('No changes to your environments detected'))
77
+ # check if environment id/name was valid at all
78
+ if @env_id && \
79
+ Environment.authorized(:view_environments).where(name: @env_id).or(Environment.authorized(:view_environments).where(id: @env_id)).empty?
80
+ render_message(_('The requested environment cannot be found.'))
81
+ else
82
+ render_message(_('No changes to your environments detected'))
83
+ end
78
84
  return false
79
85
  end
80
86
 
@@ -4,7 +4,29 @@ module ForemanPuppet
4
4
  extend ActiveSupport::Concern
5
5
 
6
6
  included do
7
- if ForemanPuppet.extracted_from_core?
7
+ if Gem::Dependency.new('', '>= 3.1').match?('', SETTINGS[:version].notag)
8
+ index_desc = Apipie.get_method_description(self, :index)
9
+ index_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/environments/:environment_id/template_combinations', N_('List template combination'), {})
10
+
11
+ create_desc = Apipie.get_method_description(self, :create)
12
+ create_desc.apis << Apipie::MethodDescription::Api.new(:POST, '/environments/:environment_id/template_combinations', N_('Add a template combination'), {})
13
+
14
+ show_desc = Apipie.get_method_description(self, :show)
15
+ show_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/environments/:environment_id/template_combinations/:id', N_('Show template combination'), {})
16
+
17
+ update_desc = Apipie.get_method_description(self, :update)
18
+ update_desc.apis << Apipie::MethodDescription::Api.new(:PUT, '/environments/:environment_id/template_combinations/:id', N_('Update template combination'), {})
19
+
20
+ apipie_update_methods(%i[index create show update]) do
21
+ param :environment_id, String, desc: N_('ID of Puppet environment')
22
+ end
23
+
24
+ apipie_update_methods(%i[create update]) do
25
+ param :template_combination, Hash do
26
+ param :environment_id, :number, allow_nil: true, desc: N_('environment id')
27
+ end
28
+ end
29
+ elsif ForemanPuppet.extracted_from_core?
8
30
  apipie_update_methods(%i[index create show update]) do
9
31
  param :environment_id, nil, desc: N_('ID of environment')
10
32
  end
@@ -6,25 +6,23 @@ module ForemanPuppet
6
6
  included do
7
7
  prepend PatchMethods
8
8
 
9
- if ForemanPuppet.extracted_from_core?
10
- method_desc = Apipie.get_method_description(self, :index)
11
- method_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/environments/:environment_id/hosts', N_('List hosts per environment'), {})
9
+ method_desc = Apipie.get_method_description(self, :index)
10
+ method_desc.apis << Apipie::MethodDescription::Api.new(:GET, '/environments/:environment_id/hosts', N_('List hosts per environment'), {})
12
11
 
13
- apipie_update_methods([:index]) do
14
- param :environment_id, String, desc: N_('ID of puppet environment')
15
- end
12
+ apipie_update_methods([:index]) do
13
+ param :environment_id, String, desc: N_('ID of puppet environment')
14
+ end
16
15
 
17
- apipie_update_methods(%i[create update]) do
18
- param :host, Hash do
19
- param :environment_id, String, desc: N_('Deprecated in favor of host/puppet_attributes/environment_id')
20
- param :puppetclass_ids, Array, desc: N_('Deprecated in favor of host/puppet_attributes/puppetclass_ids')
21
- param :config_group_ids, Array, desc: N_('Deprecated in favor of host/puppet_attributes/config_group_ids')
16
+ apipie_update_methods(%i[create update]) do
17
+ param :host, Hash do
18
+ param :environment_id, String, desc: N_('Deprecated in favor of host/puppet_attributes/environment_id')
19
+ param :puppetclass_ids, Array, desc: N_('Deprecated in favor of host/puppet_attributes/puppetclass_ids')
20
+ param :config_group_ids, Array, desc: N_('Deprecated in favor of host/puppet_attributes/config_group_ids')
22
21
 
23
- param :puppet_attributes, Hash do
24
- param :environment_id, String, desc: N_('ID of associated puppet Environment')
25
- param :puppetclass_ids, Array, desc: N_('IDs of associated Puppetclasses')
26
- param :config_group_ids, Array, desc: N_('IDs of associated ConfigGroups')
27
- end
22
+ param :puppet_attributes, Hash do
23
+ param :environment_id, String, desc: N_('ID of associated puppet Environment')
24
+ param :puppetclass_ids, Array, desc: N_('IDs of associated Puppetclasses')
25
+ param :config_group_ids, Array, desc: N_('IDs of associated ConfigGroups')
28
26
  end
29
27
  end
30
28
  end
@@ -39,7 +37,7 @@ module ForemanPuppet
39
37
 
40
38
  def allowed_nested_id
41
39
  ids = super
42
- ids << 'environment_id' if ForemanPuppet.extracted_from_core?
40
+ ids << 'environment_id'
43
41
  ids.uniq
44
42
  end
45
43
  end
@@ -23,7 +23,9 @@ module ForemanPuppet
23
23
  module Actions
24
24
  def nest
25
25
  super
26
- @hostgroup.puppetclasses = @parent.puppetclasses
26
+ return unless @parent.puppet
27
+ puppet = @hostgroup.puppet || @hostgroup.build_puppet
28
+ puppet.puppetclasses = @parent.puppet.puppetclasses
27
29
  end
28
30
 
29
31
  def environment_selected
@@ -31,7 +31,6 @@ module ForemanPuppet
31
31
  helper ForemanPuppet::PuppetclassLookupKeysHelper
32
32
  end
33
33
 
34
- # TODO: unless ForemanPuppet.extracted_from_core?
35
34
  def select_multiple_puppet_proxy_hosts_path(*args)
36
35
  foreman_puppet.select_multiple_puppet_proxy_hosts_path(*args)
37
36
  end
@@ -14,12 +14,7 @@ module ForemanPuppet
14
14
  module PatchedClassMethods
15
15
  def host_params_filter
16
16
  super.tap do |filter|
17
- filter.permit :environment_id, :environment_name, :environment,
18
- config_groups: [], config_group_ids: [], config_group_names: [],
19
- puppetclasses: [], puppetclass_ids: [], puppetclass_names: []
20
-
21
- # TODO: bring to core - this is what facets should do, but does not
22
- filter.permit(puppet_attributes: {})
17
+ add_host_puppet_params_filter(filter)
23
18
  end
24
19
  end
25
20
  end
@@ -27,40 +22,54 @@ module ForemanPuppet
27
22
  module PatchedMethods
28
23
  def host_params(*attrs)
29
24
  params = super(*attrs)
30
-
31
- process_deprecated_environment_params!(params)
32
- process_deprecated_attributes!(params)
25
+ process_deprecated_puppet_params!(params)
33
26
  params
34
27
  end
28
+ end
35
29
 
36
- def process_deprecated_environment_params!(params)
37
- env_id = params.delete(:environment_id)
38
- env_name = params.delete(:environment_name)
39
- env = params.delete(:environment)
40
-
41
- return unless env_id || env_name || env
42
- ::Foreman::Deprecation.api_deprecation_warning('param host[environment_*] has been deprecated in favor of host[puppet_attributes][environment_*]')
30
+ class_methods do
31
+ def add_host_puppet_params_filter(filter)
32
+ filter.permit :environment_id, :environment_name, :environment,
33
+ config_groups: [], config_group_ids: [], config_group_names: [],
34
+ puppetclasses: [], puppetclass_ids: [], puppetclass_names: []
43
35
 
44
- params[:puppet_attributes] ||= {}
45
- params[:puppet_attributes][:environment_id] ||= env_id if env_id
46
- params[:puppet_attributes][:environment_name] ||= env_name if env_name
47
- params[:puppet_attributes][:environment] ||= env if env
36
+ # TODO: bring to core - this is what facets should do, but does not
37
+ filter.permit(puppet_attributes: {})
48
38
  end
39
+ end
40
+
41
+ def process_deprecated_puppet_params!(params, top_level_hash = controller_name.singularize)
42
+ process_deprecated_environment_params!(params, top_level_hash)
43
+ process_deprecated_attributes!(params, top_level_hash)
44
+ end
49
45
 
50
- def process_deprecated_attributes!(params)
51
- %w[puppetclass config_group].each do |relation|
52
- ids = params.delete("#{relation}_ids".to_sym)
53
- names = params.delete("#{relation}_names".to_sym)
54
- plains = params.delete(relation.pluralize.to_sym)
46
+ def process_deprecated_environment_params!(params, top_level_hash = 'host')
47
+ env_id = params.delete(:environment_id)
48
+ env_name = params.delete(:environment_name)
49
+ env = params.delete(:environment)
55
50
 
56
- next unless ids || names || plains
57
- ::Foreman::Deprecation.api_deprecation_warning("param host[#{relation}_*] has been deprecated in favor of host[puppet_attributes][#{relation}_*]")
51
+ return unless env_id || env_name || env
52
+ ::Foreman::Deprecation.api_deprecation_warning("param #{top_level_hash}[environment_*] has been deprecated in favor of #{top_level_hash}[puppet_attributes][environment_*]")
58
53
 
59
- params[:puppet_attributes] ||= {}
60
- params[:puppet_attributes]["#{relation}_ids".to_sym] ||= ids if ids
61
- params[:puppet_attributes]["#{relation}_names".to_sym] ||= names if names
62
- params[:puppet_attributes][relation.pluralize.to_sym] ||= plains if plains
63
- end
54
+ params[:puppet_attributes] ||= {}
55
+ params[:puppet_attributes][:environment_id] ||= env_id if env_id
56
+ params[:puppet_attributes][:environment_name] ||= env_name if env_name
57
+ params[:puppet_attributes][:environment] ||= env if env
58
+ end
59
+
60
+ def process_deprecated_attributes!(params, top_level_hash = 'host')
61
+ %w[puppetclass config_group].each do |relation|
62
+ ids = params.delete("#{relation}_ids".to_sym)
63
+ names = params.delete("#{relation}_names".to_sym)
64
+ plains = params.delete(relation.pluralize.to_sym)
65
+
66
+ next unless ids || names || plains
67
+ ::Foreman::Deprecation.api_deprecation_warning("param #{top_level_hash}[#{relation}_*] has been deprecated in favor of #{top_level_hash}[puppet_attributes][#{relation}_*]")
68
+
69
+ params[:puppet_attributes] ||= {}
70
+ params[:puppet_attributes]["#{relation}_ids".to_sym] ||= ids if ids
71
+ params[:puppet_attributes]["#{relation}_names".to_sym] ||= names if names
72
+ params[:puppet_attributes][relation.pluralize.to_sym] ||= plains if plains
64
73
  end
65
74
  end
66
75
  end
@@ -14,12 +14,7 @@ module ForemanPuppet
14
14
  module PatchedClassMethods
15
15
  def hostgroup_params_filter
16
16
  super.tap do |filter|
17
- filter.permit :environment_id, :environment_name,
18
- config_group_ids: [], config_group_names: [],
19
- puppetclass_ids: [], puppetclass_names: []
20
-
21
- # TODO: bring to core - this is what facets should do, but does not
22
- filter.permit(puppet_attributes: {})
17
+ add_hostgroup_puppet_params_filter(filter)
23
18
  end
24
19
  end
25
20
  end
@@ -27,42 +22,50 @@ module ForemanPuppet
27
22
  module PatchedMethods
28
23
  def hostgroup_params(*attrs)
29
24
  params = super(*attrs)
30
-
31
- process_deprecated_hostgroup_environment_params!(params)
32
- process_deprecated_hostgroup_attributes!(params)
25
+ process_deprecated_hostgroup_puppet_params!(params)
33
26
  params
34
27
  end
28
+ end
35
29
 
36
- def process_deprecated_hostgroup_environment_params!(params)
37
- env_id = env_name = nil
38
- if ForemanPuppet.extracted_from_core?
39
- env_id = params.delete(:environment_id)
40
- env_name = params.delete(:environment_name)
41
- else
42
- env_id = params[:environment_id]
43
- env_name = params[:environment_name]
44
- end
45
-
46
- return unless env_id || env_name
47
- ::Foreman::Deprecation.api_deprecation_warning('param hostgroup[environment_*] has been deprecated in favor of hostgroup[puppet_attributes][environment_*]')
30
+ class_methods do
31
+ def add_hostgroup_puppet_params_filter(filter)
32
+ filter.permit :environment_id, :environment_name,
33
+ config_group_ids: [], config_group_names: [],
34
+ puppetclass_ids: [], puppetclass_names: []
48
35
 
49
- params[:puppet_attributes] ||= {}
50
- params[:puppet_attributes][:environment_id] ||= env_id if env_id
51
- params[:puppet_attributes][:environment_name] ||= env_name if env_name
36
+ # TODO: bring to core - this is what facets should do, but does not
37
+ filter.permit(puppet_attributes: {})
52
38
  end
39
+ end
53
40
 
54
- def process_deprecated_hostgroup_attributes!(params)
55
- %w[puppetclass config_group].each do |relation|
56
- ids = params.delete("#{relation}_ids")
57
- names = params.delete("#{relation}_names")
41
+ def process_deprecated_hostgroup_puppet_params!(params, top_level_hash = 'hostgroup')
42
+ process_deprecated_hostgroup_environment_params!(params, top_level_hash)
43
+ process_deprecated_hostgroup_attributes!(params, top_level_hash)
44
+ end
58
45
 
59
- next unless ids || names
60
- ::Foreman::Deprecation.api_deprecation_warning("param hostgroup[#{relation}_*] has been deprecated in favor of hostgroup[puppet_attributes][#{relation}_*]")
46
+ def process_deprecated_hostgroup_environment_params!(params, top_level_hash = 'hostgroup')
47
+ env_id = params.delete(:environment_id)
48
+ env_name = params.delete(:environment_name)
61
49
 
62
- params[:puppet_attributes] ||= {}
63
- params[:puppet_attributes]["#{relation}_ids".to_sym] ||= ids if ids
64
- params[:puppet_attributes]["#{relation}_names".to_sym] ||= names if names
65
- end
50
+ return unless env_id || env_name
51
+ ::Foreman::Deprecation.api_deprecation_warning("param #{top_level_hash}[environment_*] has been deprecated in favor of #{top_level_hash}[puppet_attributes][environment_*]")
52
+
53
+ params[:puppet_attributes] ||= {}
54
+ params[:puppet_attributes][:environment_id] ||= env_id if env_id
55
+ params[:puppet_attributes][:environment_name] ||= env_name if env_name
56
+ end
57
+
58
+ def process_deprecated_hostgroup_attributes!(params, top_level_hash = 'hostgroup')
59
+ %w[puppetclass config_group].each do |relation|
60
+ ids = params.delete("#{relation}_ids")
61
+ names = params.delete("#{relation}_names")
62
+
63
+ next unless ids || names
64
+ ::Foreman::Deprecation.api_deprecation_warning("param #{top_level_hash}[#{relation}_*] has been deprecated in favor of #{top_level_hash}[puppet_attributes][#{relation}_*]")
65
+
66
+ params[:puppet_attributes] ||= {}
67
+ params[:puppet_attributes]["#{relation}_ids".to_sym] ||= ids if ids
68
+ params[:puppet_attributes]["#{relation}_names".to_sym] ||= names if names
66
69
  end
67
70
  end
68
71
  end
@@ -2,7 +2,6 @@ module ForemanPuppet
2
2
  module Api
3
3
  module V2
4
4
  class EnvironmentsController < ::ForemanPuppet::Api::V2::PuppetBaseController
5
- include ForemanPuppet::Api::ImportPuppetclassesCommonController
6
5
  include ForemanPuppet::Parameters::Environment
7
6
 
8
7
  resource_description do
@@ -20,7 +20,7 @@ module ForemanPuppet
20
20
 
21
21
  def create
22
22
  @hostgroup_class = HostgroupClass.create!(hostgroup_puppet_facet_id: @hostgroup.puppet.id, puppetclass_id: params[:puppetclass_id].to_i)
23
- render json: { hostgroup_id: @hostgroup_class.hostgroup_id, puppetclass_id: @hostgroup_class.puppetclass_id }
23
+ render json: { hostgroup_id: @hostgroup.puppet.hostgroup_id, puppetclass_id: @hostgroup_class.puppetclass_id }
24
24
  end
25
25
 
26
26
  api :DELETE, '/hostgroups/:hostgroup_id/puppetclass_ids/:id/', N_('Remove a Puppet class from host group')
@@ -14,7 +14,7 @@ module ForemanPuppet
14
14
 
15
15
  helper ForemanPuppet::PuppetclassLookupKeysHelper
16
16
 
17
- # TODO: extracted_from_core?
17
+ # TODO: filter for facets needs improving
18
18
  def host_params(top_level_hash = controller_name.singularize)
19
19
  filter = self.class.host_params_filter
20
20
  filter.permit(puppet_attributes: {})
@@ -10,7 +10,7 @@ module ForemanPuppet
10
10
 
11
11
  def environments_title_actions
12
12
  title_actions import_proxy_select(hash_for_import_environments_environments_path.merge(engine: foreman_puppet)),
13
- button_group(new_link(_('Create Puppet Environment'), engine: foreman_puppet)),
13
+ button_group(new_link(_('Create Puppet Environment'), { engine: foreman_puppet }, id: 'new_environment')),
14
14
  button_group(help_button)
15
15
  end
16
16
  end
@@ -1,10 +1,5 @@
1
1
  module ForemanPuppet
2
2
  module HostsAndHostgroupsHelper
3
- # TODO: remove me - prevents the puppetclass tab duplication
4
- # unless ForemanPuppet.extracted_from_core?
5
- def puppetclasses_tab(puppetclasses_receiver)
6
- end
7
-
8
3
  def environment_inherited_by_default?(host)
9
4
  return false unless host.hostgroup && host.hostgroup_id_was.nil?
10
5
  return false if params[:action] == 'clone'
@@ -3,20 +3,16 @@ module ForemanPuppet
3
3
  UI.register_host_description do
4
4
  multiple_actions_provider :puppet_host_multiple_actions
5
5
  # otherwise registered twice
6
- overview_buttons_provider :puppet_host_overview_buttons if ForemanPuppet.extracted_from_core?
7
- overview_fields_provider :puppet_host_overview_fields if ForemanPuppet.extracted_from_core?
6
+ overview_buttons_provider :puppet_host_overview_buttons
7
+ overview_fields_provider :puppet_host_overview_fields
8
8
  end
9
9
 
10
10
  def puppet_host_multiple_actions
11
- if ForemanPuppet.extracted_from_core?
12
- actions = [{ action: [_('Change Environment'), foreman_puppet.select_multiple_environment_hosts_path], priority: 200 }]
13
- if authorized_for(controller: :hosts, action: :edit) && SmartProxy.unscoped.authorized.with_features('Puppet').exists?
14
- actions << { action: [_('Change Puppet Master'), foreman_puppet.select_multiple_puppet_proxy_hosts_path], priority: 1050 }
15
- end
16
- actions
17
- else
18
- []
11
+ actions = [{ action: [_('Change Environment'), foreman_puppet.select_multiple_environment_hosts_path], priority: 200 }]
12
+ if authorized_for(controller: :hosts, action: :edit) && SmartProxy.unscoped.authorized.with_features('Puppet').exists?
13
+ actions << { action: [_('Change Puppet Master'), foreman_puppet.select_multiple_puppet_proxy_hosts_path], priority: 1050 }
19
14
  end
15
+ actions
20
16
  end
21
17
 
22
18
  def puppet_host_overview_buttons(host)
@@ -3,20 +3,12 @@ module ForemanPuppet
3
3
  module Host
4
4
  extend ActiveSupport::Concern
5
5
 
6
- include ForemanPuppet::Extensions::HostCommon if ForemanPuppet.extracted_from_core?
6
+ include ForemanPuppet::Extensions::HostCommon
7
7
 
8
8
  included do
9
9
  prepend PrependedMethods
10
10
 
11
- if ForemanPuppet.extracted_from_core?
12
- has_one :environment, through: :puppet, class_name: 'ForemanPuppet::Environment'
13
- else
14
- env_assoc = reflect_on_association(:environment)
15
- env_assoc&.instance_variable_set(:@class_name, 'ForemanPuppet::Environment')
16
-
17
- host_classes_assoc = reflect_on_association(:host_classes)
18
- host_classes_assoc&.instance_variable_set(:@class_name, 'ForemanPuppet::HostClass')
19
- end
11
+ has_one :environment, through: :puppet, class_name: 'ForemanPuppet::Environment'
20
12
 
21
13
  include_in_clone puppet: %i[config_groups host_config_groups host_classes]
22
14
 
@@ -70,12 +62,6 @@ module ForemanPuppet
70
62
  end
71
63
 
72
64
  module PrependedMethods
73
- # TODO: we can drop this once extracted_from_core?
74
- def validate_association_taxonomy(association_name)
75
- return if association_name.to_sym == :environment
76
- super
77
- end
78
-
79
65
  def provisioning_template(opts = {})
80
66
  opts[:environment_id] ||= puppet&.environment_id
81
67
  super(opts)
@@ -3,19 +3,14 @@ module ForemanPuppet
3
3
  module Hostgroup
4
4
  extend ActiveSupport::Concern
5
5
 
6
- include ForemanPuppet::Extensions::HostCommon if ForemanPuppet.extracted_from_core?
6
+ include ForemanPuppet::Extensions::HostCommon
7
7
 
8
8
  included do
9
9
  class << self
10
10
  prepend PatchedClassMethods
11
11
  end
12
12
 
13
- if ForemanPuppet.extracted_from_core?
14
- has_one :environment, through: :puppet, class_name: 'ForemanPuppet::Environment'
15
- else
16
- env_assoc = reflect_on_association(:environment)
17
- env_assoc&.instance_variable_set(:@class_name, 'ForemanPuppet::Environment')
18
- end
13
+ has_one :environment, through: :puppet, class_name: 'ForemanPuppet::Environment'
19
14
 
20
15
  include_in_clone puppet: %i[host_config_groups config_groups hostgroup_classes]
21
16
 
@@ -4,21 +4,16 @@ module ForemanPuppet
4
4
  extend ActiveSupport::Concern
5
5
 
6
6
  included do
7
- if ForemanPuppet.extracted_from_core?
8
- has_many :environments, through: :template_combinations
9
- before_destroy ActiveRecord::Base::EnsureNotUsedBy.new(:environments)
7
+ has_many :environments, through: :template_combinations
8
+ before_destroy ActiveRecord::Base::EnsureNotUsedBy.new(:environments)
10
9
 
11
- scoped_search relation: :environments, on: :name, rename: :environment, complete_value: true
10
+ scoped_search relation: :environments, on: :name, rename: :environment, complete_value: true
12
11
 
13
- class << self
14
- prepend PrependedClassMethods
15
- end
16
-
17
- prepend PrependedMethods
18
- else
19
- env_assoc = reflect_on_association(:environments)
20
- env_assoc&.instance_variable_set(:@class_name, 'ForemanPuppet::Environment')
12
+ class << self
13
+ prepend PrependedClassMethods
21
14
  end
15
+
16
+ prepend PrependedMethods
22
17
  end
23
18
 
24
19
  module PrependedClassMethods
@@ -4,19 +4,14 @@ module ForemanPuppet
4
4
  extend ActiveSupport::Concern
5
5
 
6
6
  included do
7
- if ForemanPuppet.extracted_from_core?
8
- belongs_to :environment, class_name: 'ForemanPuppet::Environment'
7
+ belongs_to :environment, class_name: 'ForemanPuppet::Environment'
9
8
 
10
- validates :environment_id, uniqueness: { scope: %i[hostgroup_id provisioning_template_id] }
9
+ validates :environment_id, uniqueness: { scope: %i[hostgroup_id provisioning_template_id] }
11
10
 
12
- callback = __callbacks[:validate].detect do |v|
13
- v.filter.is_a?(ActiveRecord::Validations::UniquenessValidator) && v.filter.attributes.include?(:hostgroup_id)
14
- end
15
- callback.filter.options[:scope] << :environment_id
16
- else
17
- env_assoc = reflect_on_association(:environment)
18
- env_assoc&.instance_variable_set(:@class_name, 'ForemanPuppet::Environment')
11
+ callback = __callbacks[:validate].detect do |v|
12
+ v.filter.is_a?(ActiveRecord::Validations::UniquenessValidator) && v.filter.attributes.include?(:hostgroup_id)
19
13
  end
14
+ callback.filter.options[:scope] << :environment_id
20
15
  end
21
16
  end
22
17
  end
@@ -48,7 +48,7 @@ module ForemanPuppet
48
48
 
49
49
  def parent_config_groups
50
50
  return [] unless host.hostgroup
51
- host.hostgroup.puppet&.all_config_groups
51
+ host.hostgroup.puppet&.all_config_groups || []
52
52
  end
53
53
 
54
54
  def ensure_puppet_associations
@@ -48,6 +48,8 @@ module ForemanPuppet
48
48
  Hostgroup.sort_by_ancestry(hostgroup.ancestors.joins(:puppet).where(HostgroupPuppetFacet.arel_table[attr.to_sym].not_eq(nil))).last&.puppet.try(attr)
49
49
  end
50
50
 
51
+ delegate :parent_id, to: :hostgroup
52
+
51
53
  # and helpers
52
54
  def parent_facet_id
53
55
  parent_facet&.id
@@ -0,0 +1,17 @@
1
+ module ForemanPuppet
2
+ module Extensions
3
+ module HostCounter
4
+ extend ActiveSupport::Concern
5
+
6
+ def counted_hosts
7
+ case @association.to_s
8
+ when 'environment'
9
+ hosts_scope = ::Host::Managed.reorder('').joins(:puppet)
10
+ hosts_scope.authorized(:view_hosts).group(HostPuppetFacet.arel_table[:environment_id]).count
11
+ else
12
+ super
13
+ end
14
+ end
15
+ end
16
+ end
17
+ end
@@ -308,12 +308,6 @@ module ForemanPuppet
308
308
  env.puppetclasses.destroy classes
309
309
  # remove all old classes from hosts
310
310
  HostClass.joins(host: :puppet).where(HostPuppetFacet.arel_table[:environment_id].eq(env.id)).where(puppetclass_id: classes).destroy_all
311
- unless ForemanPuppet.extracted_from_core?
312
- # rubocop:disable Rails/SkipsModelValidations
313
- Host.where(environment_id: env).update_all(environment_id: nil)
314
- Hostgroup.where(environment_id: env).update_all(environment_id: nil)
315
- # rubocop:enable Rails/SkipsModelValidations
316
- end
317
311
  # we can't guaranty that the env would be removed as it might have hosts attached to it.
318
312
  env.destroy if klasses.include? '_destroy_'
319
313
  # remove all klasses that have no environment now
@@ -0,0 +1,3 @@
1
+ glue(@facet) do
2
+ extends 'foreman_puppet/api/v2/host_puppet_facets/base'
3
+ end
@@ -1,3 +1,5 @@
1
+ object @facet
2
+
1
3
  attributes :environment_id, :environment_name
2
4
 
3
5
  ForemanPuppet::HostgroupPuppetFacet.nested_attribute_fields.each do |nested_field|
@@ -0,0 +1,3 @@
1
+ glue(@facet) do
2
+ extends 'foreman_puppet/api/v2/hostgroup_puppet_facets/base'
3
+ end