Software /
code /
verse
File
util/random.lua @ 389:bf3a4fcdcb76
libs.hashes: Wrap LuaCrypto with fallback to util.sha1
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Tue, 25 Aug 2015 15:45:23 +0200 |
parent | 388:d963c8a5d89c |
child | 401:7be4ebefd1f4 |
line wrap: on
line source
-- Prosody IM -- Copyright (C) 2008-2014 Matthew Wild -- Copyright (C) 2008-2014 Waqas Hussain -- -- This project is MIT/X11 licensed. Please see the -- COPYING file in the source package for more information. -- local tostring = tostring; local os_time = os.time; local os_clock = os.clock; local ceil = math.ceil; local H = require "util.hashes".sha1; local last_uniq_time = 0; local function uniq_time() local new_uniq_time = os_time(); if last_uniq_time >= new_uniq_time then new_uniq_time = last_uniq_time + 1; end last_uniq_time = new_uniq_time; return new_uniq_time; end local function new_random(x) return H(x..os_clock()..tostring({})); end local buffer = new_random(uniq_time()); local function seed(x) buffer = new_random(buffer..x); end local function bytes(n) if #buffer < n+4 then seed(uniq_time()); end local r = buffer:sub(1, n); buffer = buffer:sub(n+1); return r; end return { seed = seed; bytes = bytes; };