——# $File: //member/autrijus/Module-CryptSource/CryptSource.pm $ $Author: autrijus $
# $Revision: #2 $ $Change: 685 $ $DateTime: 2002/08/17 08:59:09 $
package
Module::CryptSource;
$Module::CryptSource::VERSION
=
'0.02'
;
use
strict;
use
Crypt::Rijndael;
=head1 NAME
Module::CryptSource - Encrypt and Decrypt source for Binary Packagers
=head1 SYNOPSIS
In myprog.pl:
use Module::CryptSource;
Afterwards:
% perl myprog.pl --ensrc
% perlapp -f myprog.pl # or perl2exe
% myprog.exe --desrc
=head1 DESCRIPTION
One of the problems in binary packages such as perlapp or perl2exe is
the difficulty of uncovering the source code. While it can be argued
that obscuring source code may be necessary in some environments, it
could be disastrous when you accidentally lose the source code.
This self-modifying module let you specify a key to encrypted source
code and modules, so you can use that key to retrieve them back.
To use this module, simply put C<use Module::CryptSource;> in all scripts
and modules you wish to encrypt. Run it once with the C<--ensrc> option
before running B<perlapp> or B<perl2exe>, so it can store the modified
F<Module/CryptSource.pm> along with your F<.exe> file; copies of encrypted
source files will be stored in the F<Module/CryptSource.pm> file.
Run the resulting executable with C<--desrc> to decrypt the source files
back.
=head1 CAVEATS
B<Storable>, B<Crypt::Rijndael> and B<Term::ReadKey> are three XS
modules you'll have to install it yourself. It's probably possible
to use B<Crypt::Rijndael_PP> and C<Win32::*> as alternatives, but
I don't have the motivation to investigate yet.
If user enters a wrong decryption key, chances are that the
C<unpack('N/a*')> will report an C<Out of memory!> error.
=cut
my
%Files
;
sub
import
{
return
$Files
{(
caller
)[1]}++
if
($0 !~ /\.exe$/i) and ((
$ARGV
[0] ||
''
) eq
'--ensrc'
);
return
unless
(
$ARGV
[0] ||
''
) eq
'--desrc'
;
local
*FH
;
%Files
= %{+
eval
{thaw(
unpack
(
'N/a*'
, Crypt::Rijndael->new(md5_hex(
ReadMode(2),
(
"Enter the decryption key:"
),
scalar
<STDIN>
))->decrypt(decode_base64(SRC()))))} or
die
"\nDecryption failed!"
};
while
(
my
(
$file
,
$src
) =
each
%Files
) {
"\nDecrypting $file..."
;
chmod
0644,
$file
;
open
FH,
">$file"
or (
warn
(
"Cannot write to $file: $!"
),
next
);
FH
$src
;
close
FH;
}
%Files
= ();
"\n"
;
exit
;
}
INIT {
if
(
%Files
) {
local
*FH
;
my
$src
=
do
{
local
$/;
open
FH, __FILE__; <FH> };
$src
=~ s[
# <!--\n.*\n# -->]["# <!--\n".
encode_base64(Crypt::Rijndael->new(md5_hex(
ReadMode(2),
(
"Enter the encryption key:"
),
scalar
<STDIN>
))->encrypt(
do
{
my
$d
=
pack
(
'N/a*'
, nfreeze({
map
{
"\nEncrypting $_..."
;
local
$/;
open
FH,
$_
;
$_
=> <FH>;
}
keys
%Files
}));
$d
. (
' '
x (-
length
(
$d
) % 16));
})).
".\n# -->"
]es;
die
"Encryption failed: $@"
if
$@;
chmod
0644, __FILE__;
open
FH,
">"
.__FILE__ or
die
$!;
FH
$src
;
close
FH;
"\n"
;
exit
;
} };
.
# -->
1;
__END__
=head1 AUTHORS
Autrijus Tang E<lt>autrijus@autrijus.orgE<gt>
=head1 COPYRIGHT
Copyright 2001, 2002 by Autrijus Tang E<lt>autrijus@autrijus.orgE<gt>.
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
=cut