foreman_puppet 1.0.5 → 2.0.0.alpha.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/controllers/concerns/foreman_puppet/extensions/api_hostgroups_controller.rb +14 -16
- data/app/controllers/concerns/foreman_puppet/{api/import_puppetclasses_common_controller.rb → extensions/api_smart_proxies_controller.rb} +9 -3
- data/app/controllers/concerns/foreman_puppet/extensions/api_template_combinations_controller.rb +23 -1
- data/app/controllers/concerns/foreman_puppet/extensions/api_v2_hosts_controller.rb +15 -17
- data/app/controllers/concerns/foreman_puppet/extensions/hosts_controller_extensions.rb +0 -1
- data/app/controllers/concerns/foreman_puppet/extensions/parameters_host.rb +32 -41
- data/app/controllers/concerns/foreman_puppet/extensions/parameters_hostgroup.rb +26 -41
- data/app/controllers/foreman_puppet/api/v2/environments_controller.rb +0 -1
- data/app/controllers/foreman_puppet/puppetclasses_controller.rb +1 -1
- data/app/helpers/foreman_puppet/hosts_and_hostgroups_helper.rb +0 -5
- data/app/helpers/foreman_puppet/hosts_helper.rb +6 -10
- data/app/models/concerns/foreman_puppet/extensions/host.rb +2 -16
- data/app/models/concerns/foreman_puppet/extensions/hostgroup.rb +2 -7
- data/app/models/concerns/foreman_puppet/extensions/provisioning_template.rb +7 -12
- data/app/models/concerns/foreman_puppet/extensions/template_combination.rb +5 -10
- data/app/models/foreman_puppet/host_puppet_facet.rb +1 -1
- data/app/models/foreman_puppet/hostgroup_puppet_facet.rb +0 -2
- data/app/services/foreman_puppet/puppet_class_importer.rb +0 -6
- data/app/views/foreman_puppet/api/v2/host_puppet_facets/host_list.json.rabl +3 -0
- data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/base.json.rabl +2 -0
- data/app/views/foreman_puppet/api/v2/hostgroup_puppet_facets/hostgroup_list.json.rabl +3 -0
- data/config/api_routes.rb +1 -9
- data/config/initializers/api_reroute.rb +73 -5
- data/db/migrate/20101121140000_add_environment_to_template_combinations.foreman_puppet.rb +1 -1
- data/db/migrate/20200803113803_migrate_environment_to_puppet_facet.foreman_puppet.rb +2 -0
- data/db/migrate/20200803113903_migrate_host_type_in_host_config_groups.foreman_puppet.rb +20 -36
- data/db/migrate/20210924103241_remove_katello_id_from_environments.foreman_puppet.rb +5 -0
- data/db/migrate_foreman/20090722141107_create_environments.rb +2 -2
- data/db/migrate_foreman/20090802062223_create_puppetclasses.rb +28 -0
- data/db/migrate_foreman/20090905150132_create_hostgroups_puppetclasses.rb +12 -0
- data/db/migrate_foreman/20110412103238_remove_unused_fields_from_puppet_classes.rb +9 -0
- data/db/migrate_foreman/20110712070522_create_host_class.rb +11 -0
- data/db/migrate_foreman/20120824142048_add_some_indexes.rb +14 -0
- data/db/migrate_foreman/20121018152459_create_hostgroup_classes.rb +11 -0
- data/db/migrate_foreman/20161205142618_delete_orphaned_smart_class_parameters.rb +1 -1
- data/db/migrate_foreman/20180816134832_cast_lookup_key_values.rb +1 -31
- data/db/migrate_foreman/20180831115634_add_uniqueness_to_puppetclass_name.rb +24 -0
- data/db/migrate_foreman/20181023112532_add_environment_puppetclass_id.rb +1 -1
- data/lib/foreman_puppet/engine.rb +4 -36
- data/lib/foreman_puppet/register.rb +16 -47
- data/lib/foreman_puppet/version.rb +1 -1
- data/lib/foreman_puppet.rb +1 -6
- data/locale/en/LC_MESSAGES/foreman_puppet.mo +0 -0
- data/locale/en/foreman_puppet.edit.po +162 -317
- data/locale/en/foreman_puppet.po +62 -8
- data/locale/foreman_puppet.pot +215 -133
- data/locale/gemspec.rb +1 -1
- data/package.json +8 -11
- data/test/controllers/foreman_puppet/api/v2/environments_controller_test.rb +0 -231
- data/test/controllers/foreman_puppet/api/v2/smart_proxies_controller_test.rb +255 -0
- data/test/controllers/foreman_puppet/environments_controller_test.rb +2 -2
- data/test/controllers/foreman_puppet/hosts_controller_test.rb +0 -1
- data/test/factories/foreman_puppet_factories.rb +0 -2
- data/test/helpers/foreman_puppet/hosts_and_hostgroups_helper_test.rb +31 -70
- data/test/integration/foreman_puppet/host_js_test.rb +0 -1
- data/test/integration/foreman_puppet/puppetclass_js_test.rb +1 -1
- data/test/models/foreman_puppet/host_puppet_facet_test.rb +1 -7
- data/test/models/foreman_puppet/host_test.rb +26 -0
- data/test/models/foreman_puppet/user_test.rb +1 -5
- data/test/unit/foreman_puppet/puppet_class_importer_test.rb +1 -1
- metadata +22 -13
- data/db/migrate/20211112130803_cleanup_environment_from_core_tables.foreman_puppet.rb +0 -10
- data/locale/cs_CZ/foreman_puppet.edit.po +0 -1085
- data/locale/cs_CZ/foreman_puppet.po.time_stamp +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 61b910e24e11c9bd100021c5b87cc45b03eab68bc68260985f90d3510496d016
|
4
|
+
data.tar.gz: '08fa8d3c7bdf23231daf2e14332f68be4d2a79fe33195260de1c1b276924c2de'
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: cb6a6d40b42d741a4f4010aa81b9bbfa7e0b330473637036522d0a8d7e2fa983cee353ee0a59c3eacd1a64314d3edb17dfa29ee95adb7d47f08938f2380e822a
|
7
|
+
data.tar.gz: 1e2f6b9ac9b996cbb368612dfb22d3adc03c89201d3d1931ca7920baf58090769160ded784c5094a3cfd1043ba22bf93b2926ff6de0075294630a7376179be6b
|
@@ -6,25 +6,23 @@ module ForemanPuppet
|
|
6
6
|
included do
|
7
7
|
prepend PatchMethods
|
8
8
|
|
9
|
-
|
10
|
-
|
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
|
-
|
14
|
-
|
15
|
-
|
12
|
+
apipie_update_methods([:index]) do
|
13
|
+
param :puppetclass_id, String, desc: N_('ID of Puppetclass')
|
14
|
+
end
|
16
15
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
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
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
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
|
3
|
-
module
|
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
|
-
|
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
|
|
data/app/controllers/concerns/foreman_puppet/extensions/api_template_combinations_controller.rb
CHANGED
@@ -4,7 +4,29 @@ module ForemanPuppet
|
|
4
4
|
extend ActiveSupport::Concern
|
5
5
|
|
6
6
|
included do
|
7
|
-
if
|
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
|
-
|
10
|
-
|
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
|
-
|
14
|
-
|
15
|
-
|
12
|
+
apipie_update_methods([:index]) do
|
13
|
+
param :environment_id, String, desc: N_('ID of puppet environment')
|
14
|
+
end
|
16
15
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
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
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
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'
|
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
|
@@ -14,7 +14,12 @@ module ForemanPuppet
|
|
14
14
|
module PatchedClassMethods
|
15
15
|
def host_params_filter
|
16
16
|
super.tap do |filter|
|
17
|
-
|
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: {})
|
18
23
|
end
|
19
24
|
end
|
20
25
|
end
|
@@ -22,54 +27,40 @@ module ForemanPuppet
|
|
22
27
|
module PatchedMethods
|
23
28
|
def host_params(*attrs)
|
24
29
|
params = super(*attrs)
|
25
|
-
process_deprecated_puppet_params!(params)
|
26
|
-
params
|
27
|
-
end
|
28
|
-
end
|
29
30
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
config_groups: [], config_group_ids: [], config_group_names: [],
|
34
|
-
puppetclasses: [], puppetclass_ids: [], puppetclass_names: []
|
35
|
-
|
36
|
-
# TODO: bring to core - this is what facets should do, but does not
|
37
|
-
filter.permit(puppet_attributes: {})
|
31
|
+
process_deprecated_environment_params!(params)
|
32
|
+
process_deprecated_attributes!(params)
|
33
|
+
params
|
38
34
|
end
|
39
|
-
end
|
40
35
|
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
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)
|
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)
|
50
40
|
|
51
|
-
|
52
|
-
|
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_*]')
|
53
43
|
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
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
|
48
|
+
end
|
59
49
|
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
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)
|
65
55
|
|
66
|
-
|
67
|
-
|
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}_*]")
|
68
58
|
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
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
|
73
64
|
end
|
74
65
|
end
|
75
66
|
end
|
@@ -14,7 +14,12 @@ module ForemanPuppet
|
|
14
14
|
module PatchedClassMethods
|
15
15
|
def hostgroup_params_filter
|
16
16
|
super.tap do |filter|
|
17
|
-
|
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: {})
|
18
23
|
end
|
19
24
|
end
|
20
25
|
end
|
@@ -22,56 +27,36 @@ module ForemanPuppet
|
|
22
27
|
module PatchedMethods
|
23
28
|
def hostgroup_params(*attrs)
|
24
29
|
params = super(*attrs)
|
25
|
-
process_deprecated_hostgroup_puppet_params!(params)
|
26
|
-
params
|
27
|
-
end
|
28
|
-
end
|
29
30
|
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
config_group_ids: [], config_group_names: [],
|
34
|
-
puppetclass_ids: [], puppetclass_names: []
|
35
|
-
|
36
|
-
# TODO: bring to core - this is what facets should do, but does not
|
37
|
-
filter.permit(puppet_attributes: {})
|
31
|
+
process_deprecated_hostgroup_environment_params!(params)
|
32
|
+
process_deprecated_hostgroup_attributes!(params)
|
33
|
+
params
|
38
34
|
end
|
39
|
-
end
|
40
35
|
|
41
|
-
|
42
|
-
process_deprecated_hostgroup_environment_params!(params, top_level_hash)
|
43
|
-
process_deprecated_hostgroup_attributes!(params, top_level_hash)
|
44
|
-
end
|
45
|
-
|
46
|
-
def process_deprecated_hostgroup_environment_params!(params, top_level_hash = 'hostgroup')
|
47
|
-
env_id = env_name = nil
|
48
|
-
if ForemanPuppet.extracted_from_core?
|
36
|
+
def process_deprecated_hostgroup_environment_params!(params)
|
49
37
|
env_id = params.delete(:environment_id)
|
50
38
|
env_name = params.delete(:environment_name)
|
51
|
-
else
|
52
|
-
env_id = params[:environment_id]
|
53
|
-
env_name = params[:environment_name]
|
54
|
-
end
|
55
39
|
|
56
|
-
|
57
|
-
|
40
|
+
return unless env_id || env_name
|
41
|
+
::Foreman::Deprecation.api_deprecation_warning('param hostgroup[environment_*] has been deprecated in favor of hostgroup[puppet_attributes][environment_*]')
|
58
42
|
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
43
|
+
params[:puppet_attributes] ||= {}
|
44
|
+
params[:puppet_attributes][:environment_id] ||= env_id if env_id
|
45
|
+
params[:puppet_attributes][:environment_name] ||= env_name if env_name
|
46
|
+
end
|
63
47
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
48
|
+
def process_deprecated_hostgroup_attributes!(params)
|
49
|
+
%w[puppetclass config_group].each do |relation|
|
50
|
+
ids = params.delete("#{relation}_ids")
|
51
|
+
names = params.delete("#{relation}_names")
|
68
52
|
|
69
|
-
|
70
|
-
|
53
|
+
next unless ids || names
|
54
|
+
::Foreman::Deprecation.api_deprecation_warning("param hostgroup[#{relation}_*] has been deprecated in favor of hostgroup[puppet_attributes][#{relation}_*]")
|
71
55
|
|
72
|
-
|
73
|
-
|
74
|
-
|
56
|
+
params[:puppet_attributes] ||= {}
|
57
|
+
params[:puppet_attributes]["#{relation}_ids".to_sym] ||= ids if ids
|
58
|
+
params[:puppet_attributes]["#{relation}_names".to_sym] ||= names if names
|
59
|
+
end
|
75
60
|
end
|
76
61
|
end
|
77
62
|
end
|
@@ -14,7 +14,7 @@ module ForemanPuppet
|
|
14
14
|
|
15
15
|
helper ForemanPuppet::PuppetclassLookupKeysHelper
|
16
16
|
|
17
|
-
# TODO:
|
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: {})
|
@@ -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
|
7
|
-
overview_fields_provider :puppet_host_overview_fields
|
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
|
-
|
12
|
-
|
13
|
-
|
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
|
6
|
+
include ForemanPuppet::Extensions::HostCommon
|
7
7
|
|
8
8
|
included do
|
9
9
|
prepend PrependedMethods
|
10
10
|
|
11
|
-
|
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
|
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
|
-
|
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
|
-
|
8
|
-
|
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
|
-
|
10
|
+
scoped_search relation: :environments, on: :name, rename: :environment, complete_value: true
|
12
11
|
|
13
|
-
|
14
|
-
|
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
|
-
|
8
|
-
belongs_to :environment, class_name: 'ForemanPuppet::Environment'
|
7
|
+
belongs_to :environment, class_name: 'ForemanPuppet::Environment'
|
9
8
|
|
10
|
-
|
9
|
+
validates :environment_id, uniqueness: { scope: %i[hostgroup_id provisioning_template_id] }
|
11
10
|
|
12
|
-
|
13
|
-
|
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,8 +48,6 @@ 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
|
-
|
53
51
|
# and helpers
|
54
52
|
def parent_facet_id
|
55
53
|
parent_facet&.id
|
@@ -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
|
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
|