Crypt-ZCert
view release on metacpan or search on metacpan
lib/Crypt/ZCert.pm view on Meta::CPAN
my $pubkey = $secdata->{curve}->{'public-key'};
my $seckey = $secdata->{curve}->{'secret-key'};
unless ($pubkey && $seckey) {
confess "Invalid ZCert; ".
"expected 'curve' section containing 'public-key' & 'secret-key'"
}
$self->_set_public_key_z85($pubkey);
$self->_set_secret_key_z85($seckey);
$self->metadata->set(%{ $secdata->{metadata} })
if $secdata->{metadata} and keys %{ $secdata->{metadata} };
}
sub generate_keypair {
my ($self) = blessed $_[0] ? $_[0] : $_[0]->new;
my ($pub, $sec) = (
FFI::Raw::memptr(41), FFI::Raw::memptr(41)
);
if ( $self->_zmq_curve_keypair->($pub, $sec) == -1 ) {
my $errno = $self->_zmq_errno->();
my $errstr = $self->_zmq_strerr->($errno);
confess "libzmq zmq_curve_keypair failed: $errstr ($errno)"
}
hash(
public => $pub->tostr,
secret => $sec->tostr,
)->inflate
}
sub export_zcert {
my ($self) = @_;
my $data = +{
curve => +{ 'public-key' => $self->public_key_z85 },
metadata => $self->metadata,
};
my $public = encode_zpl $data;
$data->{curve}->{'secret-key'} = $self->secret_key_z85;
my $secret = encode_zpl $data;
hash(
public => $public,
secret => $secret,
)->inflate
}
sub commit {
my ($self) = @_;
confess "commit() called but no public_file / secret_file set"
unless $self->has_public_file
and $self->public_file
and $self->secret_file;
my $zcert = $self->export_zcert;
$self->public_file->spew( $zcert->public );
$self->secret_file->spew( $zcert->secret );
$self->secret_file->chmod(0600) if $self->adjust_permissions;
$self
}
print
qq[<OvrLrdQ> only copy of keys to decrypt inside encrypted duplicity backup\n],
qq[<Schroedingers_hat> Yo dawg, I herd you liked encryption so I put yo keys],
qq[ in yo encrypted file so you can decrypt while....damnit.\n]
unless caller; 1;
=pod
=for Pod::Coverage BUILD has_\w+_file
=head1 NAME
Crypt::ZCert - Manage ZeroMQ 4+ ZCert CURVE keys and certificates
=head1 SYNOPSIS
use Crypt::ZCert;
my $zcert = Crypt::ZCert->new(
public_file => "/foo/mycert",
# Optionally specify a secret file;
# defaults to "${public_file}_secret":
secret_file => "/foo/sekrit",
);
# Loaded from existing 'secret_file' if present,
# generated via libzmq's zmq_curve_keypair(3) if not:
my $pubkey = $zcert->public_key;
my $seckey = $zcert->secret_key;
# ... or as the original Z85:
my $pub_z85 = $zcert->public_key_z85;
my $sec_z85 = $zcert->secret_key_z85;
# Alter metadata:
$zcert->metadata->set(foo => 'bar');
# Commit certificate to disk
# (as '/foo/mycert', '/foo/mycert_secret' pair)
# Without '->new(adjust_permissions => 0)', _secret becomes chmod 0600:
$zcert->commit;
# Retrieve a public/secret ZCert file pair (as ZPL) without writing:
my $certdata = $zcert->export_zcert;
my $pubdata = $certdata->public;
my $secdata = $certdata->secret;
# Retrieve a newly-generated key pair (no certificate):
my $keypair = Crypt::ZCert->new->generate_keypair;
my $pub_z85 = $keypair->public;
my $sec_z85 = $keypair->secret;
=head1 DESCRIPTION
A module for managing ZeroMQ "ZCert" certificates and calling
L<zmq_curve_keypair(3)> from L<libzmq|http://www.zeromq.org> to generate CURVE
keys.
=head2 ZCerts
ZCert files are C<ZPL> format (see L<Text::ZPL>) with two subsections,
C<curve> and C<metadata>. The C<curve> section specifies C<public-key> and
C<secret-key> names whose values are C<Z85>-encoded (see L<Convert::Z85>) CURVE
keys.
On disk, the certificate is stored as two files; a L</public_file> (containing
only the public key) and a L</secret_file> (containing both keys).
Also see: L<http://czmq.zeromq.org/manual:zcert>
=head2 ATTRIBUTES
=head3 public_file
The path to the public ZCert.
Coerced to a L<Path::Tiny>.
Predicate: C<has_public_file>
=head3 secret_file
The path to the secret ZCert; defaults to appending '_secret' to
L</public_file>.
Coerced to a L<Path::Tiny>.
Predicate: C<has_secret_file>
=head3 adjust_permissions
If boolean true, C<chmod> will be used to attempt to set the L</secret_file>'s
permissions to C<0600> after writing.
=head3 ignore_existing
If boolean true, any existing L</public_file> / L</secret_file> will not be
read; calling a L</commit> will cause a forcible key regeneration and rewrite
of the existing certificate files.
(Obviously, this should be used with caution.)
=head3 public_key
The public key, as a binary string.
If none is specified at construction-time and no L</secret_file> exists, a new
key pair is generated via L<zmq_curve_keypair(3)> and L</secret_key> is set
appropriately.
=head3 secret_key
The secret key, as a binary string.
If none is specified at construction-time and no L</secret_file> exists, a new
key pair is generated via L<zmq_curve_keypair(3)> and L</public_key> is set
appropriately.
=head3 public_key_z85
The L</public_key>, as a C<Z85>-encoded ASCII string (see L<Convert::Z85>).
=head3 secret_key_z85
The L</secret_key>, as a C<Z85>-encoded ASCII string (see L<Convert::Z85>).
=head3 metadata
# Get value:
my $foo = $zcert->metadata->get('foo');
# Iterate over metadata:
my $iter = $zcert->metadata->iter;
while ( my ($key, $val) = $iter->() ) {
print "$key -> $val\n";
}
# Update metadata & write to disk:
$zcert->metadata->set(foo => 'bar');
$zcert->commit;
The certificate metadata, as a L<List::Objects::WithUtils::Hash>.
If the object is constructed from an existing L</public_file> /
L</secret_file>, metadata key/value pairs in the loaded file will override
key/value pairs that were previously set in a passed C<metadata> hash.
=head3 zmq_soname
The C<libzmq> dynamic library name; by default, the newest available library
is chosen.
( run in 0.992 second using v1.01-cache-2.11-cpan-cdf2f3d4e48 )