Crypt-XTEA_PP
view release on metacpan or search on metacpan
lib/Crypt/XTEA_PP.pm view on Meta::CPAN
Crypt::XTEA_PP - Pure Perl Implementation of the eXtended Tiny Encryption Algorithm
=head1 VERSION
version 0.0106
=head1 SYNOPSIS
use Crypt::XTEA_PP;
use Crypt::CBC;
my $xtea = Crypt::XTEA_PP->new( $key );
my $cbc = Crypt::CBC->new( -cipher => $xtea );
my $text = 'The quick brown fox jumps over the lazy dog.';
my $cipher_text = $cbc->encrypt( $text );
my $plain_text = $cbc->decrypt( $cipher_text );
=head1 DESCRIPTION
In cryptography, XTEA (eXtended TEA) is a block cipher designed to correct weaknesses in TEA.
The cipher's designers were David Wheeler and Roger Needham of the Cambridge Computer Laboratory,
and the algorithm was presented in an unpublished technical report in 1997 (Needham and Wheeler, 1997).
It is not subject to any patents.
Like TEA, XTEA is a 64-bit block Feistel cipher with a 128-bit key and a suggested 64 rounds.
But in Crypt::XTEA_PP, the recommended value for $rounds is 32.
This module implements XTEA encryption. It supports the Crypt::CBC interface, with the following functions.
=head1 METHODS
=head2 keysize
Returns the maximum XTEA key size, 16 bytes.
=head2 blocksize
Returns the XTEA block size, which is 8 bytes. This function exists so that Crypt::XTEA_PP can work with Crypt::CBC.
=head2 new
my $xtea = Crypt::XTEA_PP->new( $key, $rounds );
This creates a new Crypt::XTEA_PP object with the specified key.
The optional rounds parameter specifies the number of rounds of encryption to perform, and defaults to 32.
=head2 encrypt
lib/Crypt/XTEA_PP.pm view on Meta::CPAN
Encrypts blocksize() bytes of $plain_text and returns the corresponding ciphertext.
=head2 decrypt
$plain_text = $xtea->decrypt($cipher_text);
Decrypts blocksize() bytes of $cipher_text and returns the corresponding plaintext.
=head1 SEE ALSO
L<Crypt::CBC>
=head1 AUTHOR
Kars Wang <jahiy@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Kars Wang.
This is free software; you can redistribute it and/or modify it under
t/002-cbc.t view on Meta::CPAN
use strict;
use warnings;
use utf8;
use Test::More;
eval { require Crypt::CBC; };
plan skip_all => 'Crypt::CBC not installed' if $@;
use_ok( 'Crypt::XTEA_PP' );
my @tests = (
{
key => 'qwertyuiopasdfgh',
plain => 'The quick brown fox jumps over the lazy dog.',
cipher_length => 64,
},
{
key => 'asdfghjklzxcvbnm',
plain => q{O brave new world, That has such people in't.},
cipher_length => 64,
}
);
for my $test (@tests) {
my $xtea = new_ok( 'Crypt::XTEA_PP' => [ $test->{key} ] );
my $cbc = new_ok( 'Crypt::CBC' => [ -cipher => $xtea ] );
my $cipher = $cbc->encrypt($test->{plain});
is( length( $cipher ), $test->{cipher_length}, 'cbc encryption test' );
my $plain = $cbc->decrypt( $cipher );
is( $plain, $test->{plain}, 'cbc decryption test' );
}
done_testing;
( run in 0.628 second using v1.01-cache-2.11-cpan-e1769b4cff6 )