NAME
Passwd::Keyring::Secret - Password storage implementation using the GObject-based Secret library.
VERSION
Version 1.00
SYNOPSIS
Passwd::Keyring
compliant implementation that is using the GObject-based Secret library to provide secure storage for passwords and similar sensitive data.
use Passwd::Keyring::Secret;
my $keyring = Passwd::Keyring::Secret->new(
app => "blahblah scraper",
group => "Johnny web scrapers"
);
my $username = "John"; # or get from .ini, or from .argv ...
my $password = $keyring->get_password($username, "blahblah.com");
unless ($password)
{
$password = <somehow interactively prompt for password>;
# securely save password for future use
$keyring->set_password($username, $password, "blahblah.com");
}
login_somewhere_using($username, $password);
if (password_was_wrong)
{
$keyring->clear_password($username, "blahblah.com");
}
Note: see Passwd::Keyring::Auto::KeyringAPI for detailed comments on keyring method semantics (this document is installed with the Passwd::Keyring::Auto package).
METHODS
new(app => 'app name', group => 'passwords folder', ...)
Initializes the processing. Croaks if keyring for a given alias name or the Secret service itself does not seem to be available.
Handled named parameters:
- app - symbolic application name (not used at the moment, but may be used as comment and in prompts in the future, so set sensibly)
- group - name for the password group (will be visible in Seahorse, so can be used by the user to manage passwords; different group means different password set; a few apps may share the same group if they need to use the same password set)
- alias (optional) - alias name of the keyring (the default keyring will be used if undefined; use "session"
to store passwords in the session keyring which doesn't get stored across login sessions)
set_password($username, $password, $realm)
Stores password identified by given realm for given user.
get_password($username, $realm)
Looks up previously stored password for given user and given realm. Returns undef
if such a password could not be found.
clear_password($username, $realm)
Removes password matching given user and given realm (if present). Returns whether a password was removed.
is_persistent()
Returns whether this keyring actually saves passwords persistently (true unless initial parameter alias
was set to "session"
).
INSTALLATION
Run the following commands to install this module:
./Build.PL
./Build
./Build test
./Build install
SUPPORT
After installation, you can find the documentation for this module using the perldoc command:
perldoc Passwd::Keyring::Secret
You can also look for information at
https://search.cpan.org/~uhle/Passwd-Keyring-Secret/.
The source code is tracked at
https://gitlab.com/uhle/Passwd-Keyring-Secret.
BUGS
Please report any bugs or feature requests to the issue tracker at https://gitlab.com/uhle/Passwd-Keyring-Secret/-/issues.
AUTHOR
Thomas Uhle <uhle@cpan.org>
COPYRIGHT AND LICENSE
Copyright (c) 2020-2021 Thomas Uhle. All rights reserved.
This module is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0 as published by the Perl Foundation.
See https://www.perlfoundation.org/artistic-license-20.html for more information.