MyNixOS website logo
Description

Generate Short Unique YouTube-Like IDs (Hashes) from Integers.

An R port of the hashids library. hashids generates YouTube-like hashes from integers or vector of integers. Hashes generated from integers are relatively short, unique and non-seqential. hashids can be used to generate unique ids for URLs and hide database row numbers from the user. By default hashids will avoid generating common English cursewords by preventing certain letters being next to each other. hashids are not one-way: it is easy to encode an integer to a hashid and decode a hashid back into an integer.

Build Status

Hashids in R

An R port of the hashids library. hashids generates YouTube-like ids (hashes) from integers or vector of integers. Hashes generated from integers are relatively short, unique and non-sequential and can be used to generate unique ids for URLs and hide database row numbers from the user. By default hashids will avoid generating common English cursewords by preventing certain letters being next to each other.

For example, integers like 1, 2 and 3 will be encoded as strings like NV, 6m and yD respectively. Vectors like c(1, 2, 3, 4) will be encoded as a string like agHLu9hm and c(1, 1, 1, 1) as 2bHEH5HY.

Why should I use Hashids?

  1. Unguessable: incremental numbers encoded to prevent predictability.
  2. Unique: no need to worry about hash collisions.
  3. Customizable: custom alphabet and salt to customize generated hashids.
  4. Two way function: decoding is done as easily as encoding.
  5. Can specify minimum length for hashid.
  6. By default, prevents curse words from being generated.

Why should I NOT use Hashids?

  • hashids is NOT cryptographically secure -- do NOT use to encode passwords.
  • hashids is NOT cryptographically secure -- DO NOT USE TO ENCODE PASSWORDS.
  • hashids is NOT CRYPTOGRAPHICALLY SECURE -- DO NOT USE TO ENCODE PASSWORDS!

Other restrictions

  1. Can only encode integers -- this is to prevent you from doing something stupid. Like encoding sensitive information.
  2. Integers must be non-negative.

Installing

Install using devtools. If you don't have devtools install using install.packages('devtools') from your R session. Install using devtools::install_github('ALShum/hashids-r').

Example

Set your salt, min_length and any other settings using the hashid_settings function -- this will generate a list of important parameters for encoding and decoding:

h = hashid_settings(salt = 'this is my salt', min_length = 5)

Encode requires an integer and the settings as a list of parameters:

encode(1234, h ) #"ABBQA"

encode(c(1, 2, 3, 4), h) #"agHLu9hm"

Decode follows a similar workflow:

decode("ABBQA", h) #1234

decode("agHLu9hm", h) #c(1, 2, 3, 4)

About

hashids was originally written by Ivan Akimov. This version hashids was translated along with some of the unit tests from python version of hashids written by David Aurelio. For more information please go to http://www.hashids.org.

Compatibility

Compatible with version 1.0.* of the javascript version of hashids.

Contact

Does my code suck? Contact me and tell me! @notalexshum on twitter more info about me @ http://www.ALShum.com.

Metadata

Version

0.9.0

License

Unknown

Platforms (77)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-freebsd
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64-windows
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows