Class: GeoEngineer::Resources::AwsIamPolicy

Inherits:
GeoEngineer::Resource show all
Defined in:
lib/geoengineer/resources/aws_iam_policy.rb

Overview

AwsIamPolicy aws_iam_policy terrform resource,

Terraform Docs

Constant Summary

Constants inherited from GeoEngineer::Resource

GeoEngineer::Resource::DEFAULT_PROVIDER

Constants included from HasValidations

HasValidations::MAX_POLICY_LENGTH

Instance Attribute Summary

Attributes inherited from GeoEngineer::Resource

#environment, #id, #project, #template, #type

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from GeoEngineer::Resource

_deep_symbolize_keys, #_find_remote_resource, _ignore_remote_resource?, #_json_file, #_normalize_json, _resources_to_ignore, build, #build_individual_remote_resource, clear_remote_resource_cache, #depends_on, #duplicate, #duplicate_resource, #fetch_provider, fetch_remote_resources, #find_remote_as_individual?, #for_resource, #in_project, #initialize, #matched_remote_resource, #merge_parent_tags, #merge_tags, #new?, #remote_resource, #remote_resource_params, #reset, #setup_tags_if_needed, #short_id, #short_name, #short_type, #terraform_name, #to_id_or_ref, #to_ref, #to_s, #to_terraform, #to_terraform_json, type_from_class_name, #validate_has_tag, #validate_required_subresource, #validate_subresource_required_attributes

Methods included from HasLifecycle

#execute_lifecycle, included

Methods included from HasValidations

#errors, included, #validate_at_least_one_present, #validate_cidr_block, #validate_only_one_present, #validate_policy_length, #validate_required_attributes

Methods included from HasSubResources

#assign_block, #attribute_missing, #delete_all_subresources, #delete_subresources_where, #subresources

Methods included from HasAttributes

#[], #[]=, #assign_attribute, #assign_block, #attribute_missing, #attribute_procs, #attributes, #delete, #eager_load_attributes, #method_missing, #reset_attributes, #retrieve_attribute, #terraform_attribute_ref, #terraform_attributes, #timeout

Constructor Details

This class inherits a constructor from GeoEngineer::Resource

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class HasAttributes

Class Method Details

._all_remote_policies(provider) ⇒ Object


47
48
49
50
51
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 47

def self._all_remote_policies(provider)
  AwsClients.iam(provider)
            .list_policies({ scope: "Local" })
            .each.map(&:policies).flatten.map(&:to_h)
end

._fetch_remote_resources(provider) ⇒ Object


53
54
55
56
57
58
59
60
61
62
63
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 53

def self._fetch_remote_resources(provider)
  _all_remote_policies(provider).map(&:to_h).map do |policy|
    {
      _terraform_id: policy[:arn],
      _geo_id: policy[:policy_name],
      arn: policy[:arn],
      default_version_id: policy[:default_version_id],
      name: policy[:policy_name]
    }
  end
end

Instance Method Details

#_get_policy_document(arn, version_id) ⇒ Object


41
42
43
44
45
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 41

def _get_policy_document(arn, version_id)
  response = AwsClients.iam.get_policy_version({ policy_arn: arn,
                                                 version_id: version_id })
  URI.decode(response.policy_version.document)
end

#_policy_file(path, binding_obj = nil) ⇒ Object


37
38
39
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 37

def _policy_file(path, binding_obj = nil)
  _json_file(:policy, path, binding_obj)
end

#support_tags?Boolean

Returns:

  • (Boolean)

33
34
35
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 33

def support_tags?
  false
end

#to_terraform_stateObject


17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# File 'lib/geoengineer/resources/aws_iam_policy.rb', line 17

def to_terraform_state
  arn = NullObject.maybe(remote_resource).arn
  default_version_id = NullObject.maybe(remote_resource).default_version_id

  policy = _get_policy_document(arn, default_version_id)

  tfstate = super

  attributes = { 'policy' => policy }
  attributes['arn'] = arn if arn

  tfstate[:primary][:attributes] = attributes

  tfstate
end