NAME

    Short::URL - Encodes and Decodes short urls by using Bijection

SYNOPSIS

        use Short::URL;
        
        #use default alphabet
        my $su = Short::URL->new;
    
        my $encoded = $su->encode(10000);
        my $short_url = "http://www.example.com/$encoded";
    
        print "Encoded: $encoded\n"; #prints cP6
        print "Short url: $short_url\n"; #prints http://www.example.com/cP6
    
        my $decoded = $su->decode('cP6');
    
        print "Decoded: $decoded\n"; #prints 10000
    
        #set new alphabet
        $su->alphabet([qw/1 2 3 a b c/]);
    
        #or when you create the Short::URL object
        my $su = Short::URL->new(alphabet => [qw/1 2 3 a b c/]);
    
        #have an 'offset'. Meaning if you pass in integer $i, you get unique string for $i + offset
        $su->offset(10000);
    
        #or
        my $su = Short::URL->new(offset => 10000);
    
        my $encoded_with_offset = $su->encode(0);
    
        print "Encoded with offset: $encoded_with_offset\n"; #prints unique string for 10000, 'cP6'
    
        my $decoded_with_offset = $su->decode('cP6');
    
        print "Decoded with offset: $decoded_with_offset\n"; #prints 0
    
        #use shuffled alphabet
        $su->use_shuffled_alphabet(1);
    
        #or
        my $su = Short::URL->new(use_shuffled_alphabet => 1);
    
        my $encoded_with_shuffled_alphabet = $su->encode(10000);
    
        print "Encoded with shuffled alphabet: $encoded_with_shuffled_alphabet"; #prints 'dlu'
    
        my $decoded_with_shuffled_alphabet = $su->decode('dlu');
    
        print "Decoded with shuffled alphabet: $decoded_with_shuffled_alphabet"; #prints 10000
    
        #use no naughty words
        $su->no_vowels(1);
    
        #or
        my $su = Short::URL->new(no_vowels => 1);
    
        my $clean_encoded = $su->encode(7465182);
    
        print "My clean word: $clean_encoded\n"; #prints 'ccgZn', instead of 'F_ck', where '_' is replaced with 'u'
     

DESCRIPTION

    Short::URL can be used to help generate short, unique character string
    urls. It uses Bijection <http://en.wikipedia.org/wiki/Bijection> to
    create a one-to-one mapping from integers to strings over your
    alphabet, and from strings over your alphabet back to the original
    integer. An integer primary key in your database would be a good
    example of an integer you could use to generate a unique character
    string that maps uniquely to that row.

METHODS

 alphabet

        $su->alphabet([qw/1 2 3 a b c/]);

    The alphabet that will be used for creating strings when mapping an
    integer to a string. The default alphabet is:

       [qw/a b c d e f g h i j k l m n o p q r s t u v w x y z A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 0 1 2 3 4 5 6 7 8 9/]

    All lower case letters, upper case letters, and digits 0-9.

 encode

        my $encoded = $su->encode(1);

    Takes an integer and encodes it into a unique string over your
    alphabet.

 decode

        my $decoded = $su->decode('b');

    Takes a string made from your alphabet and returns the corresponding
    integer that it maps to.

 offset

        $su->offset(10000);
        my $encoded_with_offset = $su->encode(0);
         
        print "Encoded with offset: $encoded_with_offset\n"; #prints unique string for 10000, 'cP6' instead of 'a'
         
        my $decoded_with_offset = $su->decode('cP6');
         
        print "Decoded with offset: $decoded_with_offset\n"; #prints 0 instead of 10000

    "offset" allows you to shift all integers that you encode forward by a
    certain integer. Likewise, whenever you are decoding strings it will
    return the integer for that string by substracting your offset from
    what the original number would have been. Offset can be useful if you
    don't want people to know you have a small number of items by starting
    with a larger offset, or if you want them to have less of an idea what
    ids really correspond to what strings. When used in combination with
    "use_shuffled_alphabet", it is a lot harder to track what string would
    correspond to what id in your database, or how many ids you have in
    total.

 use_shuffled_alphabet

        $su->use_shuffled_alphabet(1);
    
        my $encoded_with_shuffled_alphabet = $su->encode(10000);
    
        print "Encoded with shuffled alphabet: $encoded_with_shuffled_alphabet"; #prints 'dlu'

    Setting "use_shuffled_alphabet" to 1 means that instead of using the
    more common alphabet used for this algorithm that is stored in
    "alphabet", Short::URL will use a shuffled alphabet. Note, this
    shuffled alphabet will be the same every time, so encoding and decoding
    will work even with the use_shuffled_alphabet set to 1 even in
    different sessions of using Short::URL. This can be useful if for some
    reason you don't want people to know how many ids you have in your
    database. With the more standard alphabet it's clear when you are going
    up by one between strings, and thus also how many ids you have. When
    used in combination with "offset", it is a lot harder to track what
    string would correspond to what id in your databse, or how many ids you
    have in total. Below is the shuffled alphabet that is used:

        [qw/G w d A t H J 0 P o W C 6 3 y K 8 L u 7 X E O a e q 1 9 D c F x Z 5 M T N l z r i s j h B 4 b I f V Y Q g n S 2 m U k p v R/]

    This is just a shuffled version of "alphabet". The default for
    "use_shuffled_alphabet" is undef.

 no_vowels

    As pointed out here
    <http://stackoverflow.com/questions/742013/how-to-code-a-url-shortener/742047#comment25208796_742047>,
    there is the possibility of creating naughty words. For instance:

        my $encoded = $su->encode(7465182);
    
        print "Encoded naughty: $encoded\n"; #prints F_ck, where '_' is replaced with 'u'

    If you want to avoid this, you can set "no_vowels" to 1:

        $su->no_vowels(1);
    
        #or
        my $su = Short::URL->new(no_vowels => 1);

    This uses a separate alphabet with no vowels in it (aeiou), so that no
    naughty words can be formed. If you also have "use_shuffled_alphabet"
    set to 1, that will still be respected. Short::URL will just use a
    clean version of the shuffled alphabet listed under
    "use_shuffled_alphabet". Below are the two clean alphabets:

        #clean_alphabet
        [qw/b c d f g h j k l m n p q r s t v w x y z B C D F G H J K L M N P Q R S T V W X Y Z 0 1 2 3 4 5 6 7 8 9/]
    
        #clean_shuffled_alphabet
        [qw/G w d t H J 0 P W C 6 3 y K 8 L 7 X q 1 9 D c F x Z 5 M T N l z r s j h B 4 b f V Y Q g n S 2 m k p v R/]

 croak_on_error

    This method sets whether you want Short::URL to Carp on an error.

        #enable
        $su->croak_on_error(1);
    
        #disable
        $su->croak_on_error(0);

    Default is 1. If "croak_on_error" is set to false and there is an
    error, then "encode" or "decode" will return a negative number.

AUTHOR

    Adam Hopkins <srchulo@cpan.org>

COPYRIGHT

    Copyright 2019- Adam Hopkins

LICENSE

    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.

SEE ALSO

      * http://stackoverflow.com/a/742047/834140

      * https://gist.github.com/zumbojo/1073996