in reply to Re: Re: Crypt::OpenPGP PassphraseCallback example please
in thread Crypt::OpenPGP PassphraseCallback example please

I think the examples given are a bit misleading; the key part is the definition of the PassphraseCallback argument in the docs, in particular the last part:

    In either case, the callback routine should return the
    passphrase, a scalar string.

The various examples sometimes leave off the final call to _prompt(), and since it is an undocumented internal routine it isn't obvious that this is doing the guts of the work: showing a prompt, setting noecho, getting the text from the user's input, and returning the resulting string.

I'd suggest looking at the code for _prompt() in the module (it's in the top-level Crypt/OpenPGP.pm) to see what needs doing, and then (probably) avoid using ths undocumented interface directly by copying what you need out of there.

Here's some similar code I use in a less critical situation, which copes with the possibility that Term::Readkey isn't installed by letting the password be entered unhidden:

sub getpass { my $prompt = shift; local $| = 1; print "$prompt: "; eval { require Term::ReadKey }; my $haveterm = !$@; Term::ReadKey::ReadMode(2) if $haveterm; # turn on noecho my $pass = <STDIN>; chomp $pass; Term::ReadKey::ReadMode(0) if $haveterm; # restore print "\n"; return $pass; }

Hugo

Replies are listed 'Best First'.
Re: Re: Re: Re: Crypt::OpenPGP PassphraseCallback example please
by boat73 (Scribe) on Mar 17, 2004 at 13:59 UTC
    This is a big help but I have another question. In reading more it looks like PassphraseCallback is used only when you want a user to enter the passphrase. If I wan't to hard code the passphrase into my script shouldn't this code work? Or is Passphrase only used for symetric? When I run it I get the following error

    decryption failed: Seckey unlock failed: Bad checksum

    $pgp = Crypt::OpenPGP->new ( "SecRing" => 'test.private' )or die Crypt::OpenPGP->errstr; my $plaintext = $pgp->decrypt( "Data" => $crypt, "Passphrase" => 'password' );<br> die "decryption failed: ", $pgp->errstr unless $plaintext; print "PLAINTEXT IS $plaintext\n";


    Thanks boat73