nanoid.cr
Crystal implementation of original NanoID https://github.com/ai/nanoid
Installation
Add this to your application's shard.yml
:
dependencies:
nanoid:
github: mamantoha/nanoid.cr
Usage
require "nanoid"
Nanoid.generate
uses URL-friendly symbols (A-Za-z0-9_-
) and returns an ID with 21 characters.
Nanoid.generate
# => 3gFI8yZxcfXsXGhB0036l
If you want to reduce ID length (and increase collisions probability), you can pass the length as an argument.
Nanoid.generate(size: 8, alphabet: "1234567890abcdef")
# => 86984b57
Non-secure API is also available.
Nanoid.generate(secure: false)
# => no0MmiInNcBm9jR2_3sGt
Nanoid.generate(size: 10, alphabet: "1234567890abcdef", secure: false)
# => 2793b2351c
Benchmark
Nanoid.simple_generate(21) 0.54 ( 1.84s ) (±16.55%) 256191264 B/op 2.11× slower
Nanoid.complex_generate(21) 0.41 ( 2.44s ) (± 9.10%) 271892005 B/op 2.80× slower
Nanoid.non_secure_generate(21) 1.15 (869.66ms) (±27.32%) 224164459 B/op fastest
UUID v4 0.87 ( 1.15s ) (±19.43%) 0 B/op 1.32× slower
Development
Clone this repository and install dependencies:
shards install
Run tests:
crystal spec
Contributing
- Fork it ( https://github.com/mamantoha/nanoid.cr/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
Contributors
- mamantoha Anton Maminov - creator, maintainer
License
Copyright: 2018 Anton Maminov ([email protected])
This library is distributed under the MIT license. Please see the LICENSE file.