home *** CD-ROM | disk | FTP | other *** search
/ PC Professionell 2004 December / PCpro_2004_12.ISO / files / webserver / tsw / TSW_3.4.0.exe / Apache2 / perl / Primitives.pm < prev    next >
Encoding:
Perl POD Document  |  2003-01-08  |  3.5 KB  |  153 lines

  1. #!/usr/bin/perl -sw
  2. ##
  3. ## Crypt::RSA::Primitives -- Cryptography and encoding primitives  
  4. ##                           used by Crypt::RSA.
  5. ##
  6. ## Copyright (c) 2001, Vipul Ved Prakash.  All rights reserved.
  7. ## This code is free software; you can redistribute it and/or modify
  8. ## it under the same terms as Perl itself.
  9. ##
  10. ## $Id: Primitives.pm,v 1.14 2001/06/22 23:27:35 vipul Exp $
  11.  
  12. package Crypt::RSA::Primitives; 
  13. use lib qw(lib);
  14. use strict;
  15. use vars qw(@ISA);
  16. use Crypt::RSA::Errorhandler;
  17. use Crypt::RSA::Debug qw(debug);
  18. use Math::Pari qw(PARI Mod lift);
  19. use Carp;
  20. @ISA = qw(Crypt::RSA::Errorhandler);
  21.  
  22. sub new { 
  23.     return bless {}, shift; 
  24.  
  25.  
  26. sub core_encrypt {
  27.  
  28.     # procedure: 
  29.     # c = (m ** e) mod n 
  30.  
  31.     my ($self, %params) = @_;
  32.     my $key = $params{Key}; 
  33.     $self->error ("Bad key.", \%params, $key) unless $key->check();
  34.     my $plaintext = $params{Message} || $params{Plaintext};
  35.     debug ("pt == $plaintext");
  36.  
  37.     my $e = $key->e; my $n = $key->n;
  38.     return $self->error ("Numeric representation of plaintext is out of bound.", 
  39.                           \$plaintext, $key, \%params) if $plaintext > $n;
  40.     my $c = mod_exp($plaintext, $e, $n);
  41.     debug ("ct == $c");
  42.     $n = undef; $e = undef;
  43.     return $c;
  44.  
  45. }
  46.  
  47.  
  48. sub core_decrypt {
  49.  
  50.     # procedure: 
  51.     # p = (c ** d) mod n
  52.  
  53.  
  54.     my ($self, %params) = @_;
  55.     my $key = $params{Key}; 
  56.     $self->error ("Bad key.") unless $key->check();
  57.  
  58.     my $cyphertext = $params{Cyphertext} || $params{Ciphertext};
  59.     my $n = $key->n;
  60.     return $self->error ("Decryption error.") if $cyphertext > $n;
  61.  
  62.     my $pt;
  63.     if ($key->p && $key->q) {
  64.         my($p, $q, $d) = ($key->p, $key->q, $key->d);
  65.         $key->u (mod_inverse($p, $q)) unless $key->u;
  66.         $key->dp ($d % ($p-1)) unless $key->dp;
  67.         $key->dq ($d % ($q-1)) unless $key->dq;
  68.         my $p2 = mod_exp($cyphertext % $p, $key->dp, $p);
  69.         my $q2 = mod_exp($cyphertext % $q, $key->dq, $q);
  70.         $pt = $p2 + ($p * ((($q2 - $p2) * $key->u) % $q));
  71.     }
  72.     else {
  73.         $pt = mod_exp ($cyphertext, $key->d, $n);
  74.     }
  75.  
  76.     debug ("ct == $cyphertext");
  77.     debug ("pt == $pt");
  78.     return $pt;
  79.  
  80. }
  81.  
  82.  
  83. sub core_sign { 
  84.  
  85.     my ($self, %params) = @_; 
  86.     $params{Cyphertext} = $params{Message} || $params{Plaintext};
  87.     return $self->core_decrypt (%params); 
  88.  
  89.  
  90.  
  91. sub core_verify { 
  92.  
  93.     my ($self, %params) = @_; 
  94.     $params{Plaintext} = $params{Signature};
  95.     return $self->core_encrypt (%params); 
  96.  
  97. }
  98.  
  99.  
  100. sub mod_inverse {
  101.     my($a, $n) = @_;
  102.     my $m = Mod(1, $n);
  103.     lift($m / $a);
  104. }
  105.  
  106.  
  107. sub mod_exp {
  108.     my($a, $exp, $n) = @_;
  109.     my $m = Mod($a, $n);
  110.     lift($m ** $exp);
  111. }
  112.  
  113.  
  114. 1;
  115.  
  116. =head1 NAME
  117.  
  118. Crypt::RSA::Primitives - RSA encryption, decryption, signature and verification primitives. 
  119.  
  120. =head1 SYNOPSIS
  121.  
  122.     my $prim = new Crypt::RSA::Primitives;
  123.     my $ctxt = $prim->core_encrypt (Key => $key, Plaintext => $string); 
  124.     my $ptxt = $prim->core_decrypt (Key => $key, Cyphertext => $ctxt);
  125.     my $sign = $prim->core_sign    (Key => $key, Message => $string); 
  126.     my $vrfy = $prim->core_verify  (Key => $key, Signature => $sig);
  127.  
  128. =head1 DESCRIPTION
  129.  
  130. This module implements RSA encryption, decryption, signature and
  131. verfication primitives. These primitives should only be used in the
  132. context of an encryption or signing scheme. See Crypt::RSA::ES::OAEP(3),
  133. and Crypt::RSA::SS::PSS(3) for the implementation of two such schemes.
  134.  
  135. =head1 ERROR HANDLING
  136.  
  137. See B<ERROR HANDLING> in Crypt::RSA(3) manpage.
  138.  
  139. =head1 AUTHOR
  140.  
  141. Vipul Ved Prakash, E<lt>mail@vipul.netE<gt>
  142.  
  143. =head1 SEE ALSO 
  144.  
  145. Crypt::RSA(3), Crypt::RSA::Key(3), Crypt::RSA::ES::OAEP(3), 
  146. Crypt::RSA::SS::PSS(3)
  147.  
  148. =cut
  149.  
  150.  
  151.