Software /
code /
prosody
File
util/uuid.lua @ 7076:ad9e683b8f0b
util.uuid: Open /dev/urandom read-only, make seed() a noop
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 10 Jan 2016 23:21:34 +0100 |
parent | 7057:c633e1338554 |
child | 7078:ec17115e3721 |
line wrap: on
line source
-- Prosody IM -- Copyright (C) 2008-2010 Matthew Wild -- Copyright (C) 2008-2010 Waqas Hussain -- -- This project is MIT/X11 licensed. Please see the -- COPYING file in the source package for more information. -- local error = error; local round_up = math.ceil; local urandom, urandom_err = io.open("/dev/urandom", "r"); module "uuid" local function get_nibbles(n) local binary_random = urandom:read(round_up(n/2)); local hex_random = binary_random:gsub(".", function (x) return ("%02x"):format(x:byte()) end); return hex_random:sub(1, n); end local function get_twobits() return ("%x"):format(urandom:read(1):byte() % 4 + 8); end function generate() if not urandom then error("Unable to obtain a secure random number generator, please see https://prosody.im/doc/random ("..urandom_err..")"); end -- generate RFC 4122 complaint UUIDs (version 4 - random) return get_nibbles(8).."-"..get_nibbles(4).."-4"..get_nibbles(3).."-"..(get_twobits())..get_nibbles(3).."-"..get_nibbles(12); end function seed() end return _M;