| GnuPG-Interface documentation | Contained in the GnuPG-Interface distribution. |
GnuPG::Key - GnuPG Key Object
# assumes a GnuPG::Interface object in $gnupg my @keys = $gnupg->get_public_keys( 'ftobin' ); # now GnuPG::PublicKey objects are in @keys
GnuPG::Key objects are generally not instantiated on their own, but rather used as a superclass of GnuPG::PublicKey, GnuPG::SecretKey, or GnuPG::SubKey objects.
This methods creates a new object. The optional arguments are initialization of data members.
This returns the commonly-used short, 8 character short hex id of the key.
Returns non-zero only when this Key is identical to the other GnuPG::Key. If $deep is present and non-zero, the key's associated signatures, revocations, and revokers will also be compared.
Number of bits in the key.
They algorithm number that the Key is used for.
The Key Usage flags associated with this key, represented as a string of lower-case letters. Possible values include: (a) authenticate, (c) certify, (e) encrypt, and (s) sign.
A key may have any combination of them in any order. In addition to these letters, the primary key has uppercase versions of the letters to denote the _usable_ capabilities of the entire key, and a potential letter 'D' to indicate a disabled key.
See "key capabilities" DETAILS from the GnuPG sources for more details.
The data of the key. WARNING: this seems to have never been instantiated, and should always be undef.
A list of Math::BigInt objects that correspond to the public key material for the given key (this member is empty on secret keys).
For DSA keys, the values are: prime (p), group order (q), group generator (g), y
For RSA keys, the values are: modulus (n), exponent (e)
For El Gamal keys, the values are: prime (p), group generator (g), y
For more details, see: http://tools.ietf.org/html/rfc4880#page-42
The long hex id of the key. This is not the fingerprint nor the short hex id, which is 8 hex characters.
Formatted date of the key's creation and expiration. If the key has no expiration, expiration_date_string will return undef.
Date of the key's creation and expiration, stored as the number of seconds since midnight 1970-01-01 UTC. If the key has no expiration, expiration_date will return undef.
A GnuPG::Fingerprint object.
A list of GnuPG::Signature objects embodying the signatures on this key. For subkeys, the signatures are usually subkey-binding signatures. For primary keys, the signatures are statements about the key itself.
A list of revocations associated with this key, stored as GnuPG::Signature objects (since revocations are a type of certification as well). Note that a revocation of a primary key has a different semantic meaning than a revocation associated with a subkey.
A list of GnuPG::Revoker objects associated with this key, indicating other keys which are allowed to revoke certifications made by this key.
| GnuPG-Interface documentation | Contained in the GnuPG-Interface distribution. |
# Key.pm # - providing an object-oriented approach to GnuPG keys # # Copyright (C) 2000 Frank J. Tobin <ftobin@cpan.org> # # This module is free software; you can redistribute it and/or modify it # under the same terms as Perl itself. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # # $Id: Key.pm,v 1.10 2001/12/10 01:29:27 ftobin Exp $ # package GnuPG::Key; use Any::Moose; with qw(GnuPG::HashInit); has [ qw( length algo_num hex_id hex_data creation_date expiration_date creation_date_string expiration_date_string fingerprint usage_flags ) ] => ( isa => 'Any', is => 'rw', ); has [ qw( signatures revokers revocations pubkey_data )] => ( isa => 'ArrayRef', is => 'rw', default => sub { [] }, ); sub push_signatures { my $self = shift; push @{ $self->signatures }, @_; } sub push_revocations { my $self = shift; push @{ $self->revocations }, @_; } sub push_revokers { my $self = shift; push @{ $self->revokers }, @_; } sub short_hex_id { my ($self) = @_; return substr $self->hex_id(), -8; } sub compare { my ($self, $other, $deep) = @_; my @string_comparisons = qw( length algo_num hex_id creation_date creation_date_string usage_flags ); my $field; foreach $field (@string_comparisons) { return 0 unless $self->$field eq $other->$field; } my @can_be_undef = qw( hex_data expiration_date expiration_date_string ); foreach $field (@can_be_undef) { return 0 unless (defined $self->$field) == (defined $other->$field); if (defined $self->$field) { return 0 unless $self->$field eq $other->$field; } } my @objs = qw( fingerprint ); foreach $field (@objs) { return 0 unless $self->$field->compare($other->$field, $deep); } if (defined $deep && $deep) { my @lists = qw( signatures revokers revocations ); my $i; foreach my $list (@lists) { return 0 unless @{$self->$list} == @{$other->$list}; for ( $i = 0; $i < scalar(@{$self->$list}); $i++ ) { return 0 unless $self->$list->[$i]->compare($other->$list->[$i], $deep); } } return 0 unless @{$self->pubkey_data} == @{$other->pubkey_data}; for ( $i = 0; $i < scalar(@{$self->pubkey_data}); $i++ ) { return 0 unless (0 == $self->pubkey_data->[$i]->bcmp($other->pubkey_data->[$i])); } } return 1; } __PACKAGE__->meta->make_immutable; 1; __END__