aboutsummaryrefslogtreecommitdiff
path: root/src/crypto/emscLoader.js
blob: 59437da4241bc332b261ad1910b37c3a81698ffd (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
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/*
 This file is part of TALER
 (C) 2017 Inria and GNUnet e.V.

 TALER is free software; you can redistribute it and/or modify it under the
 terms of the GNU General Public License as published by the Free Software
 Foundation; either version 3, or (at your option) any later version.

 TALER is distributed in the hope that it will be useful, but WITHOUT ANY
 WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
 A PARTICULAR PURPOSE.  See the GNU General Public License for more details.

 You should have received a copy of the GNU General Public License along with
 TALER; see the file COPYING.  If not, see <http://www.gnu.org/licenses/>
 */


// @ts-nocheck


/**
 * This module loads the emscripten library, and is written in unchecked
 * JavaScript since it needs to do environment detection and dynamically select
 * the right way to load the library.
 */

let cachedLib = undefined;

/**
 * Load the taler emscripten lib.
 *
 * If in a WebWorker, importScripts is used.  Inside a browser, the module must
 * be globally available.  Inside node, require is used.
 */
export function getLib() {
  console.log("in getLib");
  if (cachedLib) {
    console.log("lib is cached");
    return Promise.resolve({ lib: cachedLib });
  }
  if (typeof require !== "undefined") {
    // Make sure that TypeScript doesn't try
    // to check the taler-emscripten-lib.
    const indirectRequire = require;
    const g = global;
    // unavoidable hack, so that emscripten detects
    // the environment as node even though importScripts
    // is present.
    const savedImportScripts = g.importScripts;
    delete g.importScripts;
    // Assume that the code is run from the build/ directory.
    const lib = indirectRequire("../../../emscripten/taler-emscripten-lib.js");
    g.importScripts = savedImportScripts;
    if (lib) {
      cachedLib = lib;
      return Promise.resolve({ lib: cachedLib });
    }
    // When we're running as a webpack bundle, the above require might
    // have failed and returned 'undefined', so we try other ways to import.
  }

  if (typeof importScripts !== "undefined") {
    self.TalerEmscriptenLib = {};
    importScripts('/emscripten/taler-emscripten-lib.js')
    if (!self.TalerEmscriptenLib) {
      throw Error("can't import taler emscripten lib");
    }
    const locateFile = (path, scriptDir) => {
      console.log("locating file", "path", path, "scriptDir", scriptDir);
      // This is quite hacky and assumes that our scriptDir is dist/
      return scriptDir + "../emscripten/" + path;
    };
    console.log("instantiating TalerEmscriptenLib");
    const lib = self.TalerEmscriptenLib({ locateFile });
    cachedLib = lib;
    return new Promise((resolve, reject) => {
      lib.then(mod => {
        console.log("emscripten module fully loaded");
        resolve({ lib: mod });
      });
    });
  }

  // Last resort, we don't have require, we're not running in a webworker.
  // Maybe we're on a normal browser page, in this case TalerEmscriptenLib
  // must be included in a script tag on the page.

  if (typeof window !== "undefined") {
    if (window.TalerEmscriptenLib) {
      return Promise.resolve(TalerEmscriptenLib);
    }
    throw Error("Looks like running in browser, but TalerEmscriptenLib is not defined");
  }
  throw Error("Running in unsupported environment");
}