aboutsummaryrefslogtreecommitdiffstats
path: root/util
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2017-03-31 19:01:42 +0200
committerKim Alvefur <zash@zash.se>2017-03-31 19:01:42 +0200
commit7eb36daf82fa0db2544118d950bed17b0c6faa93 (patch)
treebee3cc0bc75de8d1aa4fb7ea7ca6571c449ac139 /util
parentf389cff7eaeff6492874a0808bb8bf1ec9fb78fd (diff)
parentd36a5333ea6c3d3d7806450f836dd132848f667b (diff)
downloadprosody-7eb36daf82fa0db2544118d950bed17b0c6faa93.tar.gz
prosody-7eb36daf82fa0db2544118d950bed17b0c6faa93.zip
Merge 0.10->trunk
Diffstat (limited to 'util')
-rw-r--r--util/array.lua12
-rw-r--r--util/id.lua26
2 files changed, 38 insertions, 0 deletions
diff --git a/util/array.lua b/util/array.lua
index 05fa97ca..150b4355 100644
--- a/util/array.lua
+++ b/util/array.lua
@@ -92,6 +92,18 @@ function array_base.sort(outa, ina, ...)
return outa;
end
+function array_base.unique(outa, ina)
+ local seen = {};
+ return array_base.filter(outa, ina, function (item)
+ if seen[item] then
+ return false;
+ else
+ seen[item] = true;
+ return true;
+ end
+ end);
+end
+
function array_base.pluck(outa, ina, key)
for i = 1, #ina do
outa[i] = ina[i][key];
diff --git a/util/id.lua b/util/id.lua
new file mode 100644
index 00000000..731355fa
--- /dev/null
+++ b/util/id.lua
@@ -0,0 +1,26 @@
+-- Prosody IM
+-- Copyright (C) 2008-2017 Matthew Wild
+-- Copyright (C) 2008-2017 Waqas Hussain
+-- Copyright (C) 2008-2017 Kim Alvefur
+--
+-- This project is MIT/X11 licensed. Please see the
+-- COPYING file in the source package for more information.
+--
+
+local s_gsub = string.gsub;
+local random_bytes = require "util.random".bytes;
+local base64_encode = require "util.encodings".base64.encode;
+
+local b64url = { ["+"] = "-", ["/"] = "_", ["="] = "" };
+local function b64url_random(len)
+ return (s_gsub(base64_encode(random_bytes(len)), "[+/=]", b64url));
+end
+
+return {
+ short = function () return b64url_random(6); end;
+ medium = function () return b64url_random(12); end;
+ long = function () return b64url_random(24); end;
+ custom = function (size)
+ return function () return b64url_random(size); end;
+ end;
+}