Class: Security::Keychain
- Inherits:
-
Object
- Object
- Security::Keychain
- Defined in:
- lib/security/keychain.rb
Overview
:nodoc:
Constant Summary collapse
- DOMAINS =
%i[user system common dynamic].freeze
Instance Attribute Summary collapse
-
#filename ⇒ Object
readonly
Returns the value of attribute filename.
Class Method Summary collapse
- .create(filename, password) ⇒ Object
- .default_keychain ⇒ Object
- .list(domain = :user) ⇒ Object
- .lock ⇒ Object
- .login_keychain ⇒ Object
- .unlock(password) ⇒ Object
Instance Method Summary collapse
- #delete ⇒ Object
- #info ⇒ Object
-
#initialize(filename) ⇒ Keychain
constructor
A new instance of Keychain.
- #lock ⇒ Object
- #unlock(password) ⇒ Object
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
#filename ⇒ Object (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
33 34 35 |
# File 'lib/security/keychain.rb', line 33 def create(filename, password) raise NotImplementedError end |
.default_keychain ⇒ Object
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 |
.lock ⇒ Object
43 44 45 |
# File 'lib/security/keychain.rb', line 43 def lock system %(security lock-keychain -a) end |
.login_keychain ⇒ Object
55 56 57 |
# File 'lib/security/keychain.rb', line 55 def login_keychain 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
#delete ⇒ Object
28 29 30 |
# File 'lib/security/keychain.rb', line 28 def delete system %(security delete-keychain #{@filename.shellescape}) end |
#info ⇒ Object
16 17 18 |
# File 'lib/security/keychain.rb', line 16 def info system %(security show-keychain-info #{@filename.shellescape}) end |
#lock ⇒ Object
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 |