Class: OpsWorks::Permission

Inherits:
Resource show all
Defined in:
lib/opsworks/permission.rb

Instance Attribute Summary collapse

Attributes inherited from Resource

#client

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from Resource

account, #initialize

Constructor Details

This class inherits a constructor from OpsWorks::Resource

Instance Attribute Details

#iam_user_arnObject

Returns the value of attribute iam_user_arn.



3
4
5
# File 'lib/opsworks/permission.rb', line 3

def iam_user_arn
  @iam_user_arn
end

#idObject

Returns the value of attribute id.



3
4
5
# File 'lib/opsworks/permission.rb', line 3

def id
  @id
end

#sshObject

Returns the value of attribute ssh.



3
4
5
# File 'lib/opsworks/permission.rb', line 3

def ssh
  @ssh
end

#stack_idObject

Returns the value of attribute stack_id.



3
4
5
# File 'lib/opsworks/permission.rb', line 3

def stack_id
  @stack_id
end

#sudoObject

Returns the value of attribute sudo.



3
4
5
# File 'lib/opsworks/permission.rb', line 3

def sudo
  @sudo
end

Class Method Details

.from_collection_response(client, response) ⇒ Object



5
6
7
8
9
10
11
12
13
14
15
16
17
# File 'lib/opsworks/permission.rb', line 5

def self.from_collection_response(client, response)
  response.data[:permissions].map do |permission|
    hash = permission.to_h
    new(
      client,
      id: hash[:permission_id],
      stack_id: hash[:stack_id],
      iam_user_arn: hash[:iam_user_arn],
      sudo: hash[:allow_sudo],
      ssh: hash[:allow_ssh]
    )
  end
end

Instance Method Details

#ssh?Boolean

Returns:

  • (Boolean)


23
24
25
# File 'lib/opsworks/permission.rb', line 23

def ssh?
  ssh
end

#sudo?Boolean

Returns:

  • (Boolean)


27
28
29
# File 'lib/opsworks/permission.rb', line 27

def sudo?
  sudo
end

#update(options = {}) ⇒ Object



31
32
33
34
35
36
37
38
39
40
41
42
43
# File 'lib/opsworks/permission.rb', line 31

def update(options = {})
  options[:ssh] = ssh if options[:ssh].nil?
  options[:sudo] = sudo if options[:sudo].nil?

  client.set_permission(
    stack_id: stack_id,
    iam_user_arn: iam_user_arn,
    allow_ssh: options[:ssh],
    allow_sudo: options[:sudo]
  )
  self.ssh = options[:ssh]
  self.sudo = options[:sudo]
end

#userObject



19
20
21
# File 'lib/opsworks/permission.rb', line 19

def user
  iam_user_arn.gsub(%r{^.*user/}, '')
end