.\" Automatically generated by Pod::Man v1.37, Pod::Parser v1.37 .\" .\" Standard preamble: .\" ======================================================================== .de Sh \" Subsection heading .br .if t .Sp .ne 5 .PP \fB\\$1\fR .PP .. .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. | will give a .\" real vertical bar. \*(C+ will give a nicer C++. Capital omega is used to .\" do unbreakable dashes and therefore won't be available. \*(C` and \*(C' .\" expand to `' in nroff, nothing in troff, for use with C<>. .tr \(*W-|\(bv\*(Tr .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' 'br\} .\" .\" If the F register is turned on, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . nr % 0 . rr F .\} .\" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .hy 0 .if n .na .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "Crypt::RSA::SS::PSS 3" .TH Crypt::RSA::SS::PSS 3 "2009-06-06" "perl v5.8.8" "User Contributed Perl Documentation" .SH "NAME" Crypt::RSA::SS::PSS \- Probabilistic Signature Scheme based on RSA. .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 1 \& my $pss = new Crypt::RSA::SS::PSS; .Ve .PP .Vb 4 \& my $signature = $pss->sign ( \& Message => $message, \& Key => $private, \& ) || die $pss->errstr; .Ve .PP .Vb 5 \& my $verify = $pss->verify ( \& Message => $message, \& Key => $key, \& Signature => $signature, \& ) || die $pss->errstr; .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" \&\s-1PSS\s0 (Probabilistic Signature Scheme) is a provably secure method of creating digital signatures with \s-1RSA\s0. \*(L"Provable\*(R" means that the difficulty of forging signatures can be directly related to inverting the \s-1RSA\s0 function. \*(L"Probabilistic\*(R" alludes to the randomly generated salt value included in the signature to enhance security. For more details on \s-1PSS\s0, see [4] & [13]. .SH "METHODS" .IX Header "METHODS" .Sh "\fB\fP\f(BInew()\fP\fB\fP" .IX Subsection "new()" Constructor. .Sh "\fB\fP\f(BIversion()\fP\fB\fP" .IX Subsection "version()" Returns the version number of the module. .Sh "\fB\fP\f(BIsign()\fP\fB\fP" .IX Subsection "sign()" Computes a \s-1PSS\s0 signature on a message with the private key of the signer. In scalar context, \fIsign()\fR returns the computed signature. In array context, it returns the signature and the random salt. The signature can verified with \fIverify()\fR or \fIverify_with_salt()\fR. \fIsign()\fR takes a hash argument with the following mandatory keys: .IP "\fBMessage\fR" 4 .IX Item "Message" Message to be signed, a string of arbitrary length. .IP "\fBKey\fR" 4 .IX Item "Key" Private key of the signer, a Crypt::RSA::Key::Private object. .Sh "\fB\fP\f(BIverify()\fP\fB\fP" .IX Subsection "verify()" Verifies a signature generated with \fIsign()\fR. The salt is recovered from the signature and need not be passed. Returns a true value on success and false on failure. \f(CW$self\fR\->errstr is set to \*(L"Invalid signature.\*(R" or appropriate error on failure. \fIverify()\fR takes a hash argument with the following mandatory keys: .IP "\fBKey\fR" 4 .IX Item "Key" Public key of the signer, a Crypt::RSA::Key::Public object. .IP "\fBMessage\fR" 4 .IX Item "Message" The original signed message, a string of arbitrary length. .IP "\fBSignature\fR" 4 .IX Item "Signature" Signature computed with \fIsign()\fR, a string. .IP "\fBVersion\fR" 4 .IX Item "Version" Version of the module that was used for creating the Signature. This is an optional argument. When present, \fIverify()\fR will ensure before proceeding that the installed version of the module can successfully verify the Signature. .Sh "\fB\fP\f(BIverify_with_salt()\fP\fB\fP" .IX Subsection "verify_with_salt()" Verifies a signature given the salt. Takes the same arguments as \fIverify()\fR in addition to \fBSalt\fR, which is a 20\-byte string returned by \fIsign()\fR in array context. .SH "ERROR HANDLING" .IX Header "ERROR HANDLING" See \s-1ERROR\s0 \s-1HANDLING\s0 in \fICrypt::RSA\fR\|(3) manpage. .SH "BIBLIOGRAPHY" .IX Header "BIBLIOGRAPHY" See \s-1BIBLIOGRAPHY\s0 in \fICrypt::RSA\fR\|(3) manpage. .SH "AUTHOR" .IX Header "AUTHOR" Vipul Ved Prakash, .SH "SEE ALSO" .IX Header "SEE ALSO" \&\fICrypt::RSA\fR\|(3), \fICrypt::RSA::Primitives\fR\|(3), \fICrypt::RSA::Keys\fR\|(3), \&\fICrypt::RSA::EME::OAEP\fR\|(3)