NAME
App::GroupSecret::File - Reading and writing groupsecret keyfiles
VERSION
version 0.300
SYNOPSIS
use App::GroupSecret::File;
my $file = App::GroupSecret::File->new('path/to/keyfile.yml');
print "File version: " . $file->version, "\n";
$file->add_key('path/to/key_rsa.pub');
$file->save;
DESCRIPTION
This module provides a programmatic way to manage keyfiles.
See groupsecret for the command-line interface.
ATTRIBUTES
filepath
Get the filepath of the keyfile.
METHODS
new
$file = App::GroupSecret::File->new($filepath);
Construct a new keyfile object.
info
$info = $file->info;
Get a raw hashref with the contents of the keyfile.
init
$info = $file->init;
Get a hashref representing an empty keyfile, used for initializing a new keyfile.
load
$info = $file->load;
$info = $file->load($filepath);
Load (or reload) the contents of a keyfile.
save
$file->save;
$file->save($filepath);
Save the keyfile to disk.
check
$file->check;
$file->check($info);
Check the file format of a keyfile to make sure this module can understand it.
keys
$keys = $file->keys;
Get a hashref of the keys from a keyfile.
secret
$secret = $file->secret;
Get the secret from a keyfile as an encrypted string.
version
$version = $file->version
Get the file format version.
add_key
$file->add_key($filepath);
Add a key to the keyfile.
delete_key
$file->delete_key($fingerprint);
Delete a key from the keyfile.
decrypt_secret
$secret = $file->decrypt_secret(passphrase => $passphrase);
$secret = $file->decrypt_secret(private_key => $private_key);
Get the decrypted secret.
decrypt_secret_passphrase
$passphrase = $file->decrypt_secret_passphrase($private_key);
Get the decrypted secret passphrase.
encrypt_secret
$file->encrypt_secret($secret, $passphrase);
Set the secret by encrypting it with a 256-bit passphrase.
Passphrase must be 32 bytes.
encrypt_secret_passphrase
$file->encrypt_secret_passphrase($passphrase);
Set the passphrase by encrypting it with each key in the keyfile.
find_public_key
$filepath = $file->find_public_key($key);
Get a path to the public key file for a key.
format_key
$str = $file->format_key($key);
Get a one-line summary of a key. Format is "<fingerprint> <comment>".
FILE FORMAT
Keyfiles are YAML documents that contains this structure:
---
keys:
FINGERPRINT:
comment: COMMENT
content: ssh-rsa ...
filename: FILENAME
secret_passphrase: PASSPHRASE...
type: rsa
secret: SECRET...
version: 1
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/chazmcgarvey/groupsecret/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHOR
Charles McGarvey <chazmcgarvey@brokenzipper.com>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2017 by Charles McGarvey.
This is free software, licensed under:
The MIT (X11) License