Class: Jets::Resource::Iam::PolicyDocument
- Inherits:
-
Object
- Object
- Jets::Resource::Iam::PolicyDocument
- Extended by:
- Memoist
- Defined in:
- lib/jets/resource/iam/policy_document.rb
Instance Attribute Summary collapse
-
#definitions ⇒ Object
readonly
Returns the value of attribute definitions.
Instance Method Summary collapse
-
#initialize(*definitions) ⇒ PolicyDocument
constructor
A new instance of PolicyDocument.
- #policy_document ⇒ Object
- #standardize(definition) ⇒ Object
Constructor Details
#initialize(*definitions) ⇒ PolicyDocument
Returns a new instance of PolicyDocument.
6 7 8 9 10 11 12 13 14 15 |
# File 'lib/jets/resource/iam/policy_document.rb', line 6 def initialize(*definitions) @definitions = definitions.flatten # empty starting policy that will be altered @policy = { version: "2012-10-17", statement: [] } # https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_elements_sid.html @sid = 0 # counter end |
Instance Attribute Details
#definitions ⇒ Object (readonly)
Returns the value of attribute definitions.
5 6 7 |
# File 'lib/jets/resource/iam/policy_document.rb', line 5 def definitions @definitions end |
Instance Method Details
#policy_document ⇒ Object
17 18 19 20 |
# File 'lib/jets/resource/iam/policy_document.rb', line 17 def policy_document definitions.map { |definition| standardize(definition) } Jets::Pascalize.pascalize(@policy) end |
#standardize(definition) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/jets/resource/iam/policy_document.rb', line 23 def standardize(definition) @sid += 1 case definition when String @policy[:statement] << { sid: "Stmt#{@sid}", action: [definition], effect: "Allow", resource: "*", } when Hash definition = definition.stringify_keys if definition.key?("Version") # special case where we replace the policy entirely @policy = definition else @policy[:statement] << definition end end end |