Class: Security::Keychain

Inherits:
Object
  • Object
show all
Defined in:
lib/security/keychain.rb

Overview

:nodoc:

Constant Summary collapse

DOMAINS =
%i[user system common dynamic].freeze

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(filename) ⇒ Keychain

Returns a new instance of Keychain.



12
13
14
# File 'lib/security/keychain.rb', line 12

def initialize(filename)
  @filename = filename
end

Instance Attribute Details

#filenameObject (readonly)

Returns the value of attribute filename.



10
11
12
# File 'lib/security/keychain.rb', line 10

def filename
  @filename
end

Class Method Details

.create(filename, password) ⇒ Object

Raises:

  • (NotImplementedError)


33
34
35
# File 'lib/security/keychain.rb', line 33

def create(filename, password)
  raise NotImplementedError
end

.default_keychainObject



51
52
53
# File 'lib/security/keychain.rb', line 51

def default_keychain
  keychains_from_output(`security default-keychain`).first
end

.list(domain = :user) ⇒ Object



37
38
39
40
41
# File 'lib/security/keychain.rb', line 37

def list(domain = :user)
  raise ArgumentError "Invalid domain #{domain}, expected one of: #{DOMAINS}" unless DOMAINS.include?(domain)

  keychains_from_output(`security list-keychains -d #{domain}`)
end

.lockObject



43
44
45
# File 'lib/security/keychain.rb', line 43

def lock
  system %(security lock-keychain -a)
end

.login_keychainObject



55
56
57
# File 'lib/security/keychain.rb', line 55

def 
  keychains_from_output(`security login-keychain`).first
end

.unlock(password) ⇒ Object



47
48
49
# File 'lib/security/keychain.rb', line 47

def unlock(password)
  system %(security unlock-keychain -p #{password.shellescape})
end

Instance Method Details

#deleteObject



28
29
30
# File 'lib/security/keychain.rb', line 28

def delete
  system %(security delete-keychain #{@filename.shellescape})
end

#infoObject



16
17
18
# File 'lib/security/keychain.rb', line 16

def info
  system %(security show-keychain-info #{@filename.shellescape})
end

#lockObject



20
21
22
# File 'lib/security/keychain.rb', line 20

def lock
  system %(security lock-keychain #{@filename.shellescape})
end

#unlock(password) ⇒ Object



24
25
26
# File 'lib/security/keychain.rb', line 24

def unlock(password)
  system %(security unlock-keychain -p #{password.shellescape} #{@filename.shellescape})
end