File: create_policy.rb

package info (click to toggle)
ruby-fog-aws 3.18.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 8,140 kB
  • sloc: ruby: 73,328; javascript: 14; makefile: 9; sh: 4
file content (71 lines) | stat: -rw-r--r-- 2,463 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
module Fog
  module AWS
    class IAM
      class Real
        require 'fog/aws/parsers/iam/single_policy'

        # Creates a managed policy
        #
        # ==== Parameters
        # * policy_name<~String>: name of policy document
        # * policy_document<~Hash>: policy document, see: http://docs.amazonwebservices.com/IAM/latest/UserGuide/PoliciesOverview.html
        # * path <~String>: path of the policy
        # * description <~String>: description for the policy
        # ==== Returns
        # * response<~Excon::Response>:
        #   * body<~Hash>:
        #     * 'RequestId'<~String> - Id of the request
        #     * 'Policy'<~Hash>:
        #       * Arn
        #       * AttachmentCount
        #       * CreateDate
        #       * DefaultVersionId
        #       * Description
        #       * IsAttachable
        #       * Path
        #       * PolicyId
        #       * PolicyName
        #       * UpdateDate
        # ==== See Also
        # http://docs.aws.amazon.com/IAM/latest/APIReference/API_CreatePolicy.html
        #
        def create_policy(policy_name, policy_document, path=nil, description=nil)
          request({
            'Action'          => 'CreatePolicy',
            'PolicyName'      => policy_name,
            'PolicyDocument'  => Fog::JSON.encode(policy_document),
            'Path'            => path,
            'Description'     => description,
            :parser           => Fog::Parsers::AWS::IAM::SinglePolicy.new
          }.reject {|_, value| value.nil?})
        end
      end

      class Mock
        def create_policy(policy_name, policy_document, path="/", description=nil)
          response = Excon::Response.new

          arn = "arn:aws:iam:#{Fog::AWS::Mock.owner_id}:policy/#{policy_name}"

          policy = {
            "Arn"              => arn,
            "AttachmentCount"  => 0,
            "CreateDate"       => Time.now.utc,
            "DefaultVersionId" => "v1",
            "Description"      => description,
            "IsAttachable"     => true,
            "Path"             => path,
            "PolicyId"         => Fog::Mock.random_hex(21),
            "PolicyName"       => policy_name,
            "UpdateDate"       => Time.now.utc,
          }

          self.data[:managed_policies][arn] = policy

          response.body = {"RequestId" => Fog::AWS::Mock.request_id, "Policy" => policy}
          response
        end
      end
    end
  end
end