NAME
String::FriendlyID - A slightly modified perl port of Will Hardy's "Friendly ID" (http://www.djangosnippets.org/snippets/1249/)
VERSION
Version 0.01
SYNOPSIS
use String::FriendlyID;
my $fid = String::FriendlyID->new();
# or set a size
# my $fid = String::FriendlyID->new( size => 9999 )
# or set a select chars to be used
# my $fid = String::FriendlyID->new( valid_chars => [ qw/A B C D 1 2 3/ ] )
# or set both
# my $fid = String::FriendlyID->new(
# valid_chars => [ qw/E F G H 4 5 6 7 8 9/ ],
# size => 9999,
# );
my $some_string = '12345';
my $friendly_id = $fid->encode($some_string);
SIGNIFICANCE / USES
Original Usage (excerpt from Will Hardy's pydoc)
"Description: Invoice numbers like "0000004" are unprofessional in that they expose how many sales a system has made, and can be used to monitor the rate of sales over a given time. They are also harder for customers to read back to you, especially if they are 10 digits long. These functions convert an integer (from eg an ID AutoField) to a short unique string. This is done simply using a perfect hash function and converting the result into a string of user friendly characters."
Other Uses
URL Shortening
use String::FriendlyID; my $domain = 'http://shorter.url/'; my $fid = String::FriendlyID->new(); my $some_url = 'http://somedomain.com/with/a/very/long/url/i/dont/know/why/'; my $short_code = $fid->encode($some_url); my $short_url = join( '/', $domain, $short_code );
Unique Coupon / Promo Code
use String::FriendlyID; my $nickname = 'Atan'; my $phone_number = '09177654321'; my $unique_identifier = join( '-', $nickname, $phone_number ); my $coupon_code_generator_tied_to_id = String::FriendlyID->new(); my $coupon_code = $coupon_code_generator_tied_to_id->encode( $unique_identifier ); store_in_coupon_db($coupon_code);
ATTRIBUTES
valid_chars
Default: [ qw/3 4 5 6 7 8 9 A C D E F G H J K L Q R S T U V W X Y/ ]
Alpha numeric characters, only uppercase, no confusing values (eg 1/I,0/O,Z/2) Remove some letters if you prefer more numbers in your strings You may wish to remove letters that sound similar, to avoid confusion when a customer calls on the phone (B/P, M/N, 3/C/D/E/G/T/V)
size
Default: 999999999999
Keep this small for shorter strings, but big enough to avoid changing it later.
period
Automatically find a suitable period to use. Factors are best, because they will have 1 left over when dividing SIZE+1. This only needs to be run once, on import.
SUBROUTINES/METHODS
friendly_number
Convert a base 10 number to a base X string. Characters from valid_chars are chosen, to convert the number to eg base 24, if there are 24 characters to choose from. Use valid chars to choose characters that are friendly, avoiding ones that could be confused in print or over the phone.
perfect_hash
Translate a string to another unique string, using a perfect hash function. Only meaningful where 0 <= num <= SIZE.
encode
Encode a simple number, using a perfect hash and converting to a more user friendly string of characters.
AUTHOR
Jonathan D. Gutierrez, <atanation at cpan.org>
BUGS
Please report any bugs or feature requests to bug-friendlyid at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=String-FriendlyID. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc String::FriendlyID
You can also look for information at:
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
ACKNOWLEDGEMENTS
Thanks to Will Hardy (http://www.djangosnippets.org/snippets/1249/) and his Friendly ID
LICENSE AND COPYRIGHT
Copyright 2010 Jonathan D. Gutierrez.
This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.
See http://dev.perl.org/licenses/ for more information.