summaryrefslogtreecommitdiff
path: root/includes/external/school/node_modules/abab/lib/btoa.js
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
committerMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
commit3d1cd02f27518f1a04374c7c8320cd5d82ede6e9 (patch)
tree75be5fba4368472fb11c8015aee026b2b9a71888 /includes/external/school/node_modules/abab/lib/btoa.js
parent8cc1f13c17fa2fb5a4410542d39e650e02945634 (diff)
downloadpluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.gz
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.bz2
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.zip
Updated 40 files, added 37 files, deleted 1103 files and renamed 3905 files (automated)
Diffstat (limited to 'includes/external/school/node_modules/abab/lib/btoa.js')
-rw-r--r--includes/external/school/node_modules/abab/lib/btoa.js62
1 files changed, 62 insertions, 0 deletions
diff --git a/includes/external/school/node_modules/abab/lib/btoa.js b/includes/external/school/node_modules/abab/lib/btoa.js
new file mode 100644
index 0000000..8d385d7
--- /dev/null
+++ b/includes/external/school/node_modules/abab/lib/btoa.js
@@ -0,0 +1,62 @@
+"use strict";
+
+/**
+ * btoa() as defined by the HTML and Infra specs, which mostly just references
+ * RFC 4648.
+ */
+function btoa(s) {
+ if (arguments.length === 0) {
+ throw new TypeError("1 argument required, but only 0 present.");
+ }
+
+ let i;
+ // String conversion as required by Web IDL.
+ s = `${s}`;
+ // "The btoa() method must throw an "InvalidCharacterError" DOMException if
+ // data contains any character whose code point is greater than U+00FF."
+ for (i = 0; i < s.length; i++) {
+ if (s.charCodeAt(i) > 255) {
+ return null;
+ }
+ }
+ let out = "";
+ for (i = 0; i < s.length; i += 3) {
+ const groupsOfSix = [undefined, undefined, undefined, undefined];
+ groupsOfSix[0] = s.charCodeAt(i) >> 2;
+ groupsOfSix[1] = (s.charCodeAt(i) & 0x03) << 4;
+ if (s.length > i + 1) {
+ groupsOfSix[1] |= s.charCodeAt(i + 1) >> 4;
+ groupsOfSix[2] = (s.charCodeAt(i + 1) & 0x0f) << 2;
+ }
+ if (s.length > i + 2) {
+ groupsOfSix[2] |= s.charCodeAt(i + 2) >> 6;
+ groupsOfSix[3] = s.charCodeAt(i + 2) & 0x3f;
+ }
+ for (let j = 0; j < groupsOfSix.length; j++) {
+ if (typeof groupsOfSix[j] === "undefined") {
+ out += "=";
+ } else {
+ out += btoaLookup(groupsOfSix[j]);
+ }
+ }
+ }
+ return out;
+}
+
+/**
+ * Lookup table for btoa(), which converts a six-bit number into the
+ * corresponding ASCII character.
+ */
+const keystr =
+ "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
+
+function btoaLookup(index) {
+ if (index >= 0 && index < 64) {
+ return keystr[index];
+ }
+
+ // Throw INVALID_CHARACTER_ERR exception here -- won't be hit in the tests.
+ return undefined;
+}
+
+module.exports = btoa;