aboutsummaryrefslogtreecommitdiff
path: root/javascript/olm_pre.js
blob: 5e8ed12954c43f07e96338e6c1b2c90cc9962cda (plain)
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
var olm_exports = {};
var get_random_values;

if (typeof(window) !== 'undefined') {
    // We're in a browser (directly, via browserify, or via webpack).
    get_random_values = function(buf) {
        window.crypto.getRandomValues(buf);
    };
} else if (module["exports"]) {
    // We're running in node.
    var nodeCrypto = require("crypto");
    get_random_values = function(buf) {
        // [''] syntax needed here rather than '.' to prevent
        // closure compiler from mangling the import(!)
        var bytes = nodeCrypto['randomBytes'](buf.length);
        buf.set(bytes);
    };
    process = global["process"];
} else {
    throw new Error("Cannot find global to attach library to");
}

/* applications should define OLM_OPTIONS in the environment to override
 * emscripten module settings (we still need to (re) declare the variable
 * otherwise the closure compiler becomes sad).
 */
var OLM_OPTIONS;
if (typeof(OLM_OPTIONS) !== 'undefined') {
    for (var olm_option_key in OLM_OPTIONS) {
        if (OLM_OPTIONS.hasOwnProperty(olm_option_key)) {
            Module[olm_option_key] = OLM_OPTIONS[olm_option_key];
        }
    }
}

/* The 'length' argument to Pointer_stringify doesn't work if the input
 * includes characters >= 128, which makes Pointer_stringify unreliable. We
 * could use it on strings which are known to be ascii, but that seems
 * dangerous. Instead we add a NULL character to all of our strings and just
 * use UTF8ToString.
 */
var NULL_BYTE_PADDING_LENGTH = 1;