-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathentropy-pool.lua
68 lines (52 loc) · 1.62 KB
/
entropy-pool.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
EntropyPool = {}
EntropyPool.__index = EntropyPool
---Create a new `EntropyPool`
---@param size number size of the `EntropyPool`
---@return table
function EntropyPool:new(size)
local obj = {}
setmetatable(obj, EntropyPool)
obj.pool = ByteList:new(size)
obj.size = size
obj.cursor = 1
return obj
end
---Add entropy to the `EntropyPool`
---@param bytes table bytes to add
function EntropyPool:add(bytes)
assert(getmetatable(bytes) == ByteList, "param must be ByteList")
for i = 1, bytes:length() do
local result = self.pool:get(self.cursor) ~ bytes:get(i)
self.pool:set(self.cursor, result)
self.cursor = self.cursor % self.size + 1
end
end
---Returns random bytes from the `EntropyPool`
---@param size number number of random bytes
---@return table
function EntropyPool:random(size, generator)
local result = ByteList:new(size)
local offset = 0
--TEMP
local digestSize = ConvertHexToByteList(generator("00")).size
while offset < size do
local slice = self.pool:slice(self.cursor, self.cursor + digestSize)
local hashHex = generator(slice:toHex())
local hashBytes = ConvertHexToByteList(hashHex)
local bytesToCopy = math.min(hashBytes:length(), size - offset)
for i = 1, bytesToCopy do
result:set(offset + i, hashBytes:get(i))
end
offset = offset + bytesToCopy
self:add(hashBytes)
end
return result;
end
function EntropyPool:randomUInt32(generator)
local result = 0
local bytes = self:random(4, generator)
for i = 1, bytes:length() do
result = result + (bytes:get(i) << (8*(i-1)))
end
return result
end