Valhalla Legends Archive

Programming => General Programming => Topic started by: rabbit on January 15, 2006, 09:26 AM

Title: Pontifex
Post by: rabbit on January 15, 2006, 09:26 AM
Well, Pontifex is an encryption schema from the book Cryptonomicon (which is really good, btw).  Just thought I'd share:
#!/usr/bin/perl -s

$f = $d ? -1 : 1;
$D = pack('C*', 33..86);
$p = shift;
$p = ~y/A-Z/;
$U = '$D = ~s/(.*)u$/U$1/; $D = ~s/U(.)/$1U/;';
($V = $U) = ~s/U/V/g;
$p = ~s/[A-Z]/$k = ord(#&) - 64, & e/eg;
$k = 0;

while(<>)
{
    y/a-z/A-Z/;
    y/A=Z//dc;
    $o .= $_
} $o .= 'X'

while length($o) %5 && !$d;

$o = ~s/./chr(($f * &e + ord($&) - 13) %26 + 65/eg;
$o = ~s/X*$// if $d;
$o = ~s /.{5}/$& /g;
print "$o\n";

sub v
{
    $v = ord(substr($D, $_[0])) - 32;
    $v > 53 ? 53 : $v;
}

sub w
{
    eval "$U$V$V";
    $D = ~s/(.*)([UV].*[UV])(.*)/$3$2$1/;
    &w(&v(53));
    $k ? (&w($k)) : ($c = &v(&v(0)), $c > 52 ? &e : $c)
}


Actually, I'm not even sure if it works, but it looks interesting!
Title: Re: Pontifex
Post by: Yegg on January 15, 2006, 10:19 AM
It looks incredibly difficult to follow, but I dont know Perl either.
Title: Re: Pontifex
Post by: iago on January 15, 2006, 11:32 AM
There are many lines in it that look like they're there solely to make it difficult to understand the code.  They do operations that could very easily be done a different way in a complex way.  That's not a good sign for an encryption scheme.

Also, how does it work?  Where is the key and what is it encrypting? 
Title: Re: Pontifex
Post by: rabbit on January 15, 2006, 12:27 PM
The key is user supplied, and it encrypts plaintext.  An example is here (http://pfex.sourceforge.net/pfex.html).

The official page is here (http://www.schneier.com/solitaire.html), which supplies a much better Perl implementation, as well as 16 other implementations in 13 languages.
Title: Re: Pontifex
Post by: iago on January 15, 2006, 01:13 PM
Quote from: rabbit on January 15, 2006, 12:27 PM
The key is user supplied, and it encrypts plaintext.  An example is here (http://pfex.sourceforge.net/pfex.html).

Why, exactly, do I get a JavaScript error, "ActiveXObject Undefined"?  That's ewwy :)
Title: Re: Pontifex
Post by: Yegg on January 15, 2006, 01:54 PM
Quote from: iago on January 15, 2006, 01:13 PM
Quote from: rabbit on January 15, 2006, 12:27 PM
The key is user supplied, and it encrypts plaintext.  An example is here (http://pfex.sourceforge.net/pfex.html).

Why, exactly, do I get a JavaScript error, "ActiveXObject Undefined"?  That's ewwy :)

It doesn't work at all for me. I don't even receive an error. What browser are you using? I'm on Mozilla Suite.
Title: Re: Pontifex
Post by: rabbit on January 15, 2006, 02:03 PM
Old link.  Try the new one.

It didn't work for me in Firefox, so I looked (and found) a new one:

http://www.erobillard.com/Content/solitaire/
Title: Re: Pontifex
Post by: iago on January 15, 2006, 05:34 PM
The reason it didn't work was that it was in (eww!) ActiveX :)
Title: Re: Pontifex
Post by: rabbit on January 15, 2006, 09:15 PM
Yeah.  Eww indeed.  It doesn't even really match what the original scheme was anyway :\  O well.
Title: Re: Pontifex
Post by: topaz on January 16, 2006, 09:48 PM
I read Cryptonomicon, and I found it sucky. You wasted ten of my dollars, rabbit :(
Title: Re: Pontifex
Post by: rabbit on January 17, 2006, 09:44 PM
Pfft!  You obviously suck at life then.  Cryptonomicon is awesome.