foreman_puppet 1.0.5 → 2.0.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (106) 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/hosts_controller_extensions.rb +0 -1
  7. data/app/controllers/concerns/foreman_puppet/extensions/parameters_hostgroup.rb +2 -8
  8. data/app/controllers/foreman_puppet/api/v2/environments_controller.rb +0 -1
  9. data/app/controllers/foreman_puppet/api/v2/hostgroup_classes_controller.rb +1 -1
  10. data/app/controllers/foreman_puppet/puppetclasses_controller.rb +1 -1
  11. data/app/helpers/foreman_puppet/environments_helper.rb +1 -1
  12. data/app/helpers/foreman_puppet/hosts_and_hostgroups_helper.rb +0 -5
  13. data/app/helpers/foreman_puppet/hosts_helper.rb +6 -10
  14. data/app/helpers/foreman_puppet/puppetclass_lookup_keys_helper.rb +1 -1
  15. data/app/models/concerns/foreman_puppet/extensions/host.rb +2 -16
  16. data/app/models/concerns/foreman_puppet/extensions/hostgroup.rb +2 -7
  17. data/app/models/concerns/foreman_puppet/extensions/provisioning_template.rb +7 -12
  18. data/app/models/concerns/foreman_puppet/extensions/template_combination.rb +5 -10
  19. data/app/services/foreman_puppet/puppet_class_importer.rb +0 -6
  20. data/app/views/foreman_puppet/api/v2/host_puppet_facets/host_list.json.rabl +3 -0
  21. data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/base.json.rabl +2 -0
  22. data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/hostgroup_list.json.rabl +3 -0
  23. data/app/views/foreman_puppet/config_groups/index.html.erb +1 -1
  24. data/config/api_routes.rb +1 -9
  25. data/config/initializers/api_reroute.rb +73 -5
  26. data/db/migrate/20101121140000_add_environment_to_template_combinations.foreman_puppet.rb +1 -1
  27. data/db/migrate/20200803113803_migrate_environment_to_puppet_facet.foreman_puppet.rb +2 -0
  28. data/db/migrate/20201125113903_migrate_puppetclasses_to_facets.foreman_puppet.rb +0 -8
  29. data/db/migrate/20210924103241_remove_katello_id_from_environments.foreman_puppet.rb +5 -0
  30. data/db/migrate/20211111125003_drop_puppetclasses_direct_references.foreman_puppet.rb +11 -0
  31. data/db/migrate/20220201205305_migrate_host_class_permission.foreman_puppet.rb +9 -0
  32. data/db/migrate/20220208135305_migrate_environment_ignore_type.foreman_puppet.rb +15 -0
  33. data/db/migrate_foreman/{20090722141107_create_environments.rb → 20090722141107_create_environments.foreman_puppet.rb} +3 -3
  34. data/db/migrate_foreman/20090802062223_create_puppetclasses.foreman_puppet.rb +29 -0
  35. data/db/migrate_foreman/20090905150132_create_hostgroups_puppetclasses.foreman_puppet.rb +14 -0
  36. data/db/migrate_foreman/20110412103238_remove_unused_fields_from_puppet_classes.foreman_puppet.rb +9 -0
  37. data/db/migrate_foreman/20110712070522_create_host_class.foreman_puppet.rb +11 -0
  38. data/db/migrate_foreman/20120824142048_add_some_indexes.foreman_puppet.rb +21 -0
  39. data/db/migrate_foreman/{20120905095532_create_environment_classes.rb → 20120905095532_create_environment_classes.foreman_puppet.rb} +2 -2
  40. data/db/migrate_foreman/20121018152459_create_hostgroup_classes.foreman_puppet.rb +11 -0
  41. data/db/migrate_foreman/{20140407161817_create_config_groups.rb → 20140407161817_create_config_groups.foreman_puppet.rb} +0 -0
  42. data/db/migrate_foreman/{20140407162007_create_config_group_classes.rb → 20140407162007_create_config_group_classes.foreman_puppet.rb} +0 -0
  43. data/db/migrate_foreman/{20140407162059_create_host_config_groups.rb → 20140407162059_create_host_config_groups.foreman_puppet.rb} +0 -0
  44. data/db/migrate_foreman/{20161205142618_delete_orphaned_smart_class_parameters.rb → 20161205142618_delete_orphaned_smart_class_parameters.foreman_puppet.rb} +1 -1
  45. data/db/migrate_foreman/{20170109115157_fix_lookup_key_auditable_type.rb → 20170109115157_fix_lookup_key_auditable_type.foreman_puppet.rb} +0 -0
  46. data/db/migrate_foreman/20180816134832_cast_lookup_key_values.foreman_puppet.rb +5 -0
  47. data/db/migrate_foreman/20180831115634_add_uniqueness_to_puppetclass_name.foreman_puppet.rb +24 -0
  48. data/db/migrate_foreman/{20181023112532_add_environment_puppetclass_id.rb → 20181023112532_add_environment_puppetclass_id.foreman_puppet.rb} +1 -1
  49. 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
  50. data/lib/foreman_puppet/engine.rb +4 -36
  51. data/lib/foreman_puppet/register.rb +51 -46
  52. data/lib/foreman_puppet/version.rb +1 -1
  53. data/lib/foreman_puppet.rb +1 -6
  54. data/locale/ca/LC_MESSAGES/foreman_puppet.mo +0 -0
  55. data/locale/ca/foreman_puppet.po +760 -0
  56. data/locale/cs_CZ/LC_MESSAGES/foreman_puppet.mo +0 -0
  57. data/locale/cs_CZ/foreman_puppet.po +823 -0
  58. data/locale/de/LC_MESSAGES/foreman_puppet.mo +0 -0
  59. data/locale/de/foreman_puppet.po +844 -0
  60. data/locale/en/LC_MESSAGES/foreman_puppet.mo +0 -0
  61. data/locale/en/foreman_puppet.po +119 -8
  62. data/locale/en_GB/LC_MESSAGES/foreman_puppet.mo +0 -0
  63. data/locale/en_GB/foreman_puppet.po +820 -0
  64. data/locale/es/LC_MESSAGES/foreman_puppet.mo +0 -0
  65. data/locale/es/foreman_puppet.po +827 -0
  66. data/locale/foreman_puppet.pot +376 -205
  67. data/locale/fr/LC_MESSAGES/foreman_puppet.mo +0 -0
  68. data/locale/fr/foreman_puppet.po +835 -0
  69. data/locale/gemspec.rb +1 -1
  70. data/locale/gl/LC_MESSAGES/foreman_puppet.mo +0 -0
  71. data/locale/gl/foreman_puppet.po +818 -0
  72. data/locale/it/LC_MESSAGES/foreman_puppet.mo +0 -0
  73. data/locale/it/foreman_puppet.po +822 -0
  74. data/locale/ja/LC_MESSAGES/foreman_puppet.mo +0 -0
  75. data/locale/ja/foreman_puppet.po +830 -0
  76. data/locale/ko/LC_MESSAGES/foreman_puppet.mo +0 -0
  77. data/locale/ko/foreman_puppet.po +819 -0
  78. data/locale/nl_NL/LC_MESSAGES/foreman_puppet.mo +0 -0
  79. data/locale/nl_NL/foreman_puppet.po +823 -0
  80. data/locale/pl/LC_MESSAGES/foreman_puppet.mo +0 -0
  81. data/locale/pl/foreman_puppet.po +822 -0
  82. data/locale/pt_BR/LC_MESSAGES/foreman_puppet.mo +0 -0
  83. data/locale/pt_BR/foreman_puppet.po +826 -0
  84. data/locale/ru/LC_MESSAGES/foreman_puppet.mo +0 -0
  85. data/locale/ru/foreman_puppet.po +827 -0
  86. data/locale/sv_SE/LC_MESSAGES/foreman_puppet.mo +0 -0
  87. data/locale/sv_SE/foreman_puppet.po +822 -0
  88. data/locale/zh_CN/LC_MESSAGES/foreman_puppet.mo +0 -0
  89. data/locale/zh_CN/foreman_puppet.po +831 -0
  90. data/locale/zh_TW/LC_MESSAGES/foreman_puppet.mo +0 -0
  91. data/locale/zh_TW/foreman_puppet.po +821 -0
  92. data/package.json +8 -11
  93. data/test/controllers/foreman_puppet/api/v2/environments_controller_test.rb +0 -231
  94. data/test/controllers/foreman_puppet/api/v2/smart_proxies_controller_test.rb +255 -0
  95. data/test/controllers/foreman_puppet/environments_controller_test.rb +2 -2
  96. data/test/controllers/foreman_puppet/hosts_controller_test.rb +0 -1
  97. data/test/factories/foreman_puppet_factories.rb +0 -2
  98. data/test/helpers/foreman_puppet/puppetclass_lookup_keys_helper_test.rb +34 -0
  99. data/test/integration/foreman_puppet/dashboard_js_test.rb +31 -0
  100. data/test/integration/foreman_puppet/host_js_test.rb +0 -1
  101. data/test/integration/foreman_puppet/puppetclass_js_test.rb +1 -1
  102. data/test/models/foreman_puppet/host_test.rb +26 -0
  103. data/test/models/foreman_puppet/user_test.rb +1 -5
  104. data/test/unit/foreman_puppet/puppet_class_importer_test.rb +1 -1
  105. metadata +69 -16
  106. 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: 7f8a5c7b68f8d77f54787c4c9de924bc02f27d7a0f957fc6539b5b4aa6c64b49
4
- data.tar.gz: 6cd563d9cc2f56c22186bbbb0fb9d3c9679c8718e965d7fd952bbed3efacf222
3
+ metadata.gz: 83861f53b9f2944dda945591b245097569b4477df77ed2760f42cb1d92bd3ed0
4
+ data.tar.gz: 620b8fb7524015970cd4aa1e42ea130483434ccb0af7474a1a4ca23ca8d8199f
5
5
  SHA512:
6
- metadata.gz: 1a09cf7ff50545983f0e472b3c03f0708087dddf8d2136dc32978f49a1fd76ba7ca4c716db6e6b3add3055279745754b2d2eddf2cd1630a91e75187ba9683c1e
7
- data.tar.gz: 5c4bb18d77784e2a9c43c7f102adc9df6469b739525fee007d1c89bf635713e1dd051140489101ebeb9d66298100195f56571fa5fb55a1a179c8381cac56a65b
6
+ metadata.gz: 9ac189449b5b6f819e82ee4f14dbccfdf0da012dd0a8345441225b76f062912a9b3f184bc7f2c87715dd5e460d1deadc6943f45e060a4bf109d8d3ba87ce8bc7
7
+ data.tar.gz: 13157df73faa3eb07f8e1299ad9367bd09d6292e45ff59741d2c6e108542bb239ad25ba04eb8fae97125b54cba6f452248c91b9bddffda1c0829b2e8953fdb57
@@ -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
@@ -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
@@ -44,14 +44,8 @@ module ForemanPuppet
44
44
  end
45
45
 
46
46
  def process_deprecated_hostgroup_environment_params!(params, top_level_hash = 'hostgroup')
47
- env_id = env_name = nil
48
- if ForemanPuppet.extracted_from_core?
49
- env_id = params.delete(:environment_id)
50
- env_name = params.delete(:environment_name)
51
- else
52
- env_id = params[:environment_id]
53
- env_name = params[:environment_name]
54
- end
47
+ env_id = params.delete(:environment_id)
48
+ env_name = params.delete(:environment_name)
55
49
 
56
50
  return unless env_id || env_name
57
51
  ::Foreman::Deprecation.api_deprecation_warning("param #{top_level_hash}[environment_*] has been deprecated in favor of #{top_level_hash}[puppet_attributes][environment_*]")
@@ -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)
@@ -9,7 +9,7 @@ module ForemanPuppet
9
9
  # ------ Host(group) Form Helpers -----
10
10
 
11
11
  def overridable_puppet_lookup_keys(klass, obj)
12
- klass.class_params.override.where(environment_classes: { environment_id: obj.environment_id })
12
+ klass.class_params.override.where(environment_classes: { environment_id: obj.environment })
13
13
  end
14
14
 
15
15
  def hidden_puppet_lookup_value_fields(lookup_key, lookup_value, disabled)
@@ -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
@@ -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
@@ -2,7 +2,7 @@
2
2
  <% content_for(:search_bar) { } %>
3
3
  <% title _('Config Groups') %>
4
4
 
5
- <% title_actions new_link(_('Create Config Group'), engine: foreman_puppet), help_button %>
5
+ <% title_actions new_link(_('Create Config Group'), { engine: foreman_puppet }, id: 'new_config_group'), help_button %>
6
6
 
7
7
  <table class="<%= table_css_classes 'table-fixed' %>">
8
8
  <thead>
data/config/api_routes.rb CHANGED
@@ -2,14 +2,6 @@ ForemanPuppet::Engine.routes.draw do
2
2
  namespace :api, defaults: { format: 'json' } do
3
3
  scope '(:apiv)', module: :v2, defaults: { apiv: 'v2' }, apiv: /v1|v2/, constraints: ApiConstraints.new(version: 2, default: true) do
4
4
  constraints(id: %r{[^/]+}) do
5
- resources :puppet_smart_proxies, only: [] do
6
- post :import_puppetclasses, on: :member, controller: 'environments'
7
-
8
- resources :environments, only: [] do
9
- post :import_puppetclasses, on: :member
10
- end
11
- end
12
-
13
5
  resources :config_groups, except: %i[new edit]
14
6
 
15
7
  resources :hosts, only: [] do
@@ -40,7 +32,7 @@ ForemanPuppet::Engine.routes.draw do
40
32
  end
41
33
  end
42
34
  resources :hosts, only: %i[index show], controller: '/api/v2/hosts'
43
- resources :template_combinations, only: %i[index], controller: '/api/v2/template_combinations'
35
+ resources :template_combinations, only: %i[index show create update], controller: '/api/v2/template_combinations'
44
36
  end
45
37
 
46
38
  resources :puppetclasses, except: %i[new edit] do
@@ -1,13 +1,81 @@
1
1
  Foreman::Application.routes.prepend do
2
2
  namespace :api, defaults: { format: 'json' } do
3
3
  scope '(:apiv)', module: :v2, defaults: { apiv: 'v2' }, apiv: /v2/, constraints: ApiConstraints.new(version: 2, default: true) do
4
- resources :puppetclasses, controller: '/foreman_puppet/api/v2/puppetclasses', except: %i[new edit]
5
- resources :environments, controller: '/foreman_puppet/api/v2/environments', except: %i[new edit]
6
- resources :hosts, controller: '/foreman_puppet/api/v2/hosts', only: []
7
- resources :hostgroups, controller: '/foreman_puppet/api/v2/hostgroups', only: %i[]
4
+ resources :smart_proxies, only: [] do
5
+ post :import_puppetclasses, on: :member
6
+ resources :environments, only: [] do
7
+ post :import_puppetclasses, on: :member, controller: '/api/v2/smart_proxies'
8
+ end
9
+ end
10
+
8
11
  resources :config_groups, controller: '/foreman_puppet/api/v2/config_groups', except: %i[new edit]
9
- resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit]
12
+
13
+ resources :hosts, only: [] do
14
+ resources :puppetclasses, controller: '/foreman_puppet/api/v2/puppetclasses', except: %i[new edit]
15
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
16
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
17
+ end
18
+ resources :host_classes, path: :puppetclass_ids, controller: '/foreman_puppet/api/v2/host_classes', only: %i[index create destroy]
19
+ end
20
+
21
+ resources :hostgroups, only: [] do
22
+ resources :puppetclasses, controller: '/foreman_puppet/api/v2/puppetclasses', except: %i[new edit]
23
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
24
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
25
+ end
26
+ resources :hostgroup_classes, path: :puppetclass_ids, controller: '/foreman_puppet/api/v2/hostgroup_classes', only: %i[index create destroy]
27
+ end
28
+
29
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', except: %i[new edit] do
30
+ resources :locations, only: %i[index show]
31
+ resources :organizations, only: %i[index show]
32
+ resources :smart_proxies, only: [] do
33
+ post :import_puppetclasses, on: :member
34
+ end
35
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
36
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
37
+ end
38
+ resources :puppetclasses, controller: '/foreman_puppet/api/v2/puppetclasses', except: %i[new edit] do
39
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
40
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit destroy]
41
+ end
42
+ end
43
+ resources :hosts, only: %i[index show]
44
+ resources :template_combinations, only: %i[index show create update]
45
+ end
46
+
47
+ resources :puppetclasses, controller: '/foreman_puppet/api/v2/puppetclasses', except: %i[new edit] do
48
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
49
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
50
+ end
51
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', only: %i[index show] do
52
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create] do
53
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
54
+ end
55
+ end
56
+ end
57
+
58
+ resources :smart_class_parameters, controller: '/foreman_puppet/api/v2/smart_class_parameters', except: %i[new edit create destroy] do
59
+ resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
60
+ end
61
+
10
62
  resources :override_values, controller: '/foreman_puppet/api/v2/override_values', except: %i[new edit]
63
+
64
+ resources :locations, only: [] do
65
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', only: %i[index show]
66
+
67
+ resources :organizations, only: [] do
68
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', only: %i[index show]
69
+ end
70
+ end
71
+
72
+ resources :organizations, only: [] do
73
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', only: %i[index show]
74
+
75
+ resources :locations, only: [] do
76
+ resources :environments, controller: '/foreman_puppet/api/v2/environments', only: %i[index show]
77
+ end
78
+ end
11
79
  end
12
80
  end
13
81
  end
@@ -4,6 +4,6 @@ class AddEnvironmentToTemplateCombinations < ActiveRecord::Migration[4.2]
4
4
  end
5
5
 
6
6
  def down
7
- remove_reference :template_combinations, :environment, foreign_key: true if ForemanPuppet.extracted_from_core?
7
+ remove_reference :template_combinations, :environment, foreign_key: true
8
8
  end
9
9
  end
@@ -1,5 +1,6 @@
1
1
  class MigrateEnvironmentToPuppetFacet < ActiveRecord::Migration[6.0]
2
2
  def up
3
+ return true unless column_exists?(:hosts, :environment_id)
3
4
  puppet_hostgroups = ::Hostgroup.unscoped.where.not(environment_id: nil).pluck(:id, :environment_id)
4
5
  puppet_hostgroups.map! { |hg_id, env_id| { hostgroup_id: hg_id, environment_id: env_id } }
5
6
  ForemanPuppet::HostgroupPuppetFacet.insert_all!(puppet_hostgroups) if puppet_hostgroups.any?
@@ -10,6 +11,7 @@ class MigrateEnvironmentToPuppetFacet < ActiveRecord::Migration[6.0]
10
11
  end
11
12
 
12
13
  def down
14
+ return true unless column_exists?(:hosts, :environment_id)
13
15
  hostgroup_facet_ids = ForemanPuppet::HostgroupPuppetFacet.all.pluck(:hostgroup_id, :environment_id)
14
16
  hostgroup_facet_ids.each do |hostgroup_id, env_id|
15
17
  ::Hostgroup.unscoped.where(id: hostgroup_id).update_all(environment_id: env_id)
@@ -33,17 +33,9 @@ class MigratePuppetclassesToFacets < ActiveRecord::Migration[6.0]
33
33
  hostgroup_facet ||= ForemanPuppet::HostgroupPuppetFacet.create(hostgroup: Hostgroup.unscoped.find(hostgroup_id))
34
34
  ForemanPuppet::HostgroupClass.where(hostgroup_id: hostgroup_id).update_all(hostgroup_puppet_facet_id: hostgroup_facet.id)
35
35
  end
36
-
37
- change_column_null(:host_classes, :host_id, true)
38
- change_column_null(:hostgroup_classes, :hostgroup_id, true)
39
- # remove_reference(:host_classes, :host, index: true, foreign_key: true)
40
- # remove_reference(:hostgroup_classes, :hostgroup, index: true, foreign_key: true)
41
36
  end
42
37
 
43
38
  def down
44
- # add_reference :host_classes, :host, foreign_key: true, index: true
45
- # add_reference :hostgroup_classes, :hostgroup, foreign_key: true, index: true
46
-
47
39
  host_facets_ids = ForemanPuppet::HostClass.joins(:host_puppet_facet).pluck(:host_puppet_facet_id, 'host_puppet_facets.host_id')
48
40
  host_facets_ids.each do |host_facet_id, host_id|
49
41
  ForemanPuppet::HostClass.where(host_puppet_facet_id: host_facet_id).update_all(host_id: host_id)
@@ -0,0 +1,5 @@
1
+ class RemoveKatelloIdFromEnvironments < ActiveRecord::Migration[6.0]
2
+ def up
3
+ remove_column :environments, :katello_id if column_exists?(:environments, :katello_id)
4
+ end
5
+ end
@@ -0,0 +1,11 @@
1
+ class DropPuppetclassesDirectReferences < ActiveRecord::Migration[6.0]
2
+ def up
3
+ remove_reference(:host_classes, :host, index: true, foreign_key: true)
4
+ remove_reference(:hostgroup_classes, :hostgroup, index: true, foreign_key: true)
5
+ end
6
+
7
+ def down
8
+ add_reference :host_classes, :host, foreign_key: true, index: true
9
+ add_reference :hostgroup_classes, :hostgroup, foreign_key: true, index: true
10
+ end
11
+ end
@@ -0,0 +1,9 @@
1
+ class MigrateHostClassPermission < ActiveRecord::Migration[6.0]
2
+ def up
3
+ Permission.where(resource_type: 'HostClass').update_all(resource_type: 'ForemanPuppet::HostClass')
4
+ end
5
+
6
+ def down
7
+ # no can do
8
+ end
9
+ end