# uuid-random [![MIT Licence](https://img.shields.io/badge/License-MIT-informational)](LICENSE.txt) [![Stable](https://img.shields.io/badge/Stable-1.3.0-brightgreen)](https://github.com/jchook/uuid-random/releases) Generate RFC-4122 compliant [random UUIDs](https://en.wikipedia.org/wiki/Universally_unique_identifier#Version_4_.28random.29) (version 4) with better [statistical dispersion](https://en.wikipedia.org/wiki/Statistical_dispersion) than `Math.random()`. ## Install ```sh npm i uuid-random ``` Or download the [latest release](https://github.com/jchook/uuid-random/releases). ## Features * Tiny (0.6k minified + gzipped) * Uses [cryptographic randomness](http://caniuse.com/#feat=getrandomvalues) when possible * Very fast! ## Compatability Compatible with almost all versions of: - Node - Babel - TypeScript - Web browsers ## Performance The included `benchmark.js` as well as [independent benchmarks](https://github.com/aarondcohen/benchmark-guid) rank this library as the _fastest_ pure JS UUID v4 generator available with cryptographically secure PRNG— almost **20x faster** than the most popular library (using latest NodeJS). | npm package | performance | |-----------------|-----------------| | portable-uuid | 354k ops/sec | | uuid | 474k ops/sec | | id128 | 6.0M ops/sec | | **uuid-random** (this) | **9.7M ops/sec** | *Results above generated on a 4.20GHz Intel i7-7700K with Node v12.18.0* ## Why use UUID? **U**niversally **U**nique **ID**entifiers transcend many constraints of traditional incremental integer IDs, especially in distributed systems. In UUID version 4, we essentially generate a random 128-bit value. We do trade guaranteed uniqueness for __extremely__ probable uniqueness (you would need to do-loop `uuid()` at max speed for 73,067 years for a 50% chance of **one** collision). But for that slight cost, we may now generate valid, unique, persistent IDs on any node of a distributed system (e.g. intermittently offline or high-latency clients). _Note, if you plan to use UUIDs for a new project, depending on your requirements, you may consider a more recent standard that addresses some of the shortcomings of UUID, such as [flake-id](https://github.com/T-PWK/flake-idgen), [nanoid](https://github.com/ai/nanoid), [cuid](https://github.com/ericelliott/cuid), or [ulid](https://github.com/ulid/spec)._ ## Example Usage ### Babel ```javascript import uuid from 'uuid-random'; uuid(); // 'f32dc9ae-7ca8-44ca-8f25-f258f7331c55' ``` ### Node ```javascript var uuid = require('uuid-random'); uuid(); // '0b99b82f-62cf-4275-88b3-de039020f14e' ``` ### Browser ```html ``` ### Validate a UUID v4 String ```javascript uuid.test('0b99b82f-62cf-4275-88b3-de039020f14e'); // true ``` ### Generate Binary UUIDs ```javascript uuid.bin(); // ``` ## Contributing Feel free to [open an issue](https://github.com/jchook/uuid-random/issues) or submit a [pull request](https://github.com/jchook/uuid-random/pulls). ## License MIT.