mirror of
https://github.com/PrivateBin/PrivateBin.git
synced 2026-04-02 19:05:03 -04:00
227 lines
7.1 KiB
JavaScript
227 lines
7.1 KiB
JavaScript
'use strict';
|
|
|
|
// testing prerequisites
|
|
global.assert = require('assert');
|
|
global.jsc = require('jsverify');
|
|
global.jsdom = require('jsdom-global');
|
|
// initial DOM environment created by jsdom-global
|
|
let currentCleanup = global.jsdom();
|
|
|
|
// wrap cleanup so that calling it recreates a fresh jsdom environment
|
|
global.cleanup = function (...args) {
|
|
// remove previous environment
|
|
if (typeof currentCleanup === 'function') {
|
|
currentCleanup();
|
|
}
|
|
|
|
// create a new jsdom environment
|
|
currentCleanup = global.jsdom(...args);
|
|
|
|
// Make sure window and document are available in global scope for module loading
|
|
// jsdom-global sets them, but we need to ensure they're accessible
|
|
if (typeof window === 'undefined') {
|
|
throw new Error('jsdom-global failed to set up window');
|
|
}
|
|
if (typeof document === 'undefined') {
|
|
throw new Error('jsdom-global failed to set up document');
|
|
}
|
|
|
|
// Clear module cache to ensure modules are re-evaluated with new jsdom environment
|
|
delete require.cache[require.resolve('./privatebin')];
|
|
delete require.cache[require.resolve('./legacy')];
|
|
require('./privatebin');
|
|
if (typeof PrivateBin === 'undefined') {
|
|
throw new Error('PrivateBin module did not load correctly');
|
|
}
|
|
|
|
// also re-export the PrivateBin namespace if available
|
|
if (typeof window !== 'undefined' && window.PrivateBin) {
|
|
global.PrivateBin = window.PrivateBin;
|
|
if (global.$) {
|
|
global.$.PrivateBin = window.PrivateBin;
|
|
}
|
|
}
|
|
|
|
return global.cleanup;
|
|
};
|
|
global.fs = require('fs');
|
|
global.WebCrypto = require('@peculiar/webcrypto').Crypto;
|
|
|
|
// application libraries to test
|
|
global.$ = global.jQuery = require('./jquery-3.7.1');
|
|
global.zlib = require('./zlib-1.3.1-2').zlib;
|
|
require('./prettify');
|
|
global.prettyPrint = window.PR ? window.PR.prettyPrint : function() {};
|
|
global.prettyPrintOne = window.PR ? window.PR.prettyPrintOne : function() {};
|
|
global.showdown = require('./showdown-2.1.0');
|
|
global.DOMPurify = require('./purify-3.3.0');
|
|
global.baseX = require('./base-x-5.0.1').baseX;
|
|
global.Legacy = require('./legacy').Legacy;
|
|
require('./privatebin');
|
|
|
|
// provide global access to the namespace so tests can reference it directly
|
|
if (typeof window !== 'undefined' && window.PrivateBin) {
|
|
global.PrivateBin = window.PrivateBin;
|
|
// keep the old jQuery alias around just in case some tests still use it
|
|
if (global.$) {
|
|
global.$.PrivateBin = window.PrivateBin;
|
|
}
|
|
}
|
|
|
|
// internal variables
|
|
var a2zString = ['a','b','c','d','e','f','g','h','i','j','k','l','m',
|
|
'n','o','p','q','r','s','t','u','v','w','x','y','z'],
|
|
digitString = ['0','1','2','3','4','5','6','7','8','9'],
|
|
alnumString = a2zString.concat(digitString),
|
|
hexString = digitString.concat(['a','b','c','d','e','f']),
|
|
queryString = alnumString.concat(['+','%','&','.','*','-','_']),
|
|
hashString = queryString.concat(['!']),
|
|
base64String = alnumString.concat(['+','/','=']).concat(
|
|
a2zString.map(function(c) {
|
|
return c.toUpperCase();
|
|
})
|
|
),
|
|
schemas = ['ftp','http','https'],
|
|
supportedLanguages = ['ar', 'bg', 'ca', 'co', 'cs', 'de', 'el', 'es', 'et', 'fi', 'fr', 'he', 'hu', 'id', 'it', 'ja', 'jbo', 'lt', 'no', 'nl', 'pl', 'pt', 'oc', 'ru', 'sk', 'sl', 'th', 'tr', 'uk', 'zh'],
|
|
mimeTypes = ['image/png', 'application/octet-stream'],
|
|
formats = ['plaintext', 'markdown', 'syntaxhighlighting'],
|
|
mimeFile = fs.createReadStream('/etc/mime.types'),
|
|
mimeLine = '';
|
|
|
|
// populate mime types from environment
|
|
mimeFile.on('data', function(data) {
|
|
mimeLine += data;
|
|
var index = mimeLine.indexOf('\n');
|
|
while (index > -1) {
|
|
var line = mimeLine.substring(0, index);
|
|
mimeLine = mimeLine.substring(index + 1);
|
|
parseMime(line);
|
|
index = mimeLine.indexOf('\n');
|
|
}
|
|
});
|
|
|
|
mimeFile.on('end', function() {
|
|
if (mimeLine.length > 0) {
|
|
parseMime(mimeLine);
|
|
}
|
|
});
|
|
|
|
function parseMime(line) {
|
|
// ignore comments
|
|
var index = line.indexOf('#');
|
|
if (index > -1) {
|
|
line = line.substring(0, index);
|
|
}
|
|
|
|
// ignore bits after tabs
|
|
index = line.indexOf('\t');
|
|
if (index > -1) {
|
|
line = line.substring(0, index);
|
|
}
|
|
if (line.length > 0) {
|
|
mimeTypes.push(line);
|
|
}
|
|
}
|
|
|
|
// common testing helper functions
|
|
// as of jsDOM 22 the base64 functions provided in the DOM are more restrictive
|
|
// than browser implementation and throw when being passed invalid unicode
|
|
// codepoints - as we use these in the encryption with binary data, we need
|
|
// these to be character encoding agnostic
|
|
exports.atob = function(encoded) {
|
|
return Buffer.from(encoded, 'base64').toString('binary');
|
|
};
|
|
exports.btoa = function(text) {
|
|
return Buffer.from(text, 'binary').toString('base64');
|
|
};
|
|
|
|
// provides random lowercase characters from a to z
|
|
exports.jscA2zString = function() {
|
|
return jsc.elements(a2zString);
|
|
};
|
|
|
|
// provides random lowercase alpha numeric characters (a to z and 0 to 9)
|
|
exports.jscAlnumString = function() {
|
|
return jsc.elements(alnumString);
|
|
};
|
|
|
|
//provides random characters allowed in hexadecimal notation
|
|
exports.jscHexString = function() {
|
|
return jsc.elements(hexString);
|
|
};
|
|
|
|
// provides random characters allowed in GET queries
|
|
exports.jscQueryString = function() {
|
|
return jsc.elements(queryString);
|
|
};
|
|
|
|
// provides random characters allowed in hash queries
|
|
exports.jscHashString = function() {
|
|
return jsc.elements(hashString);
|
|
};
|
|
|
|
// provides random characters allowed in base64 encoded strings
|
|
exports.jscBase64String = function() {
|
|
return jsc.elements(base64String);
|
|
};
|
|
|
|
// provides a random URL schema supported by the whatwg-url library
|
|
exports.jscSchemas = function(withFtp = true) {
|
|
return jsc.elements(withFtp ? schemas : schemas.slice(1));
|
|
};
|
|
|
|
// provides a random supported language string
|
|
exports.jscSupportedLanguages = function() {
|
|
return jsc.elements(supportedLanguages);
|
|
};
|
|
|
|
// provides a random mime type
|
|
exports.jscMimeTypes = function() {
|
|
return jsc.elements(mimeTypes);
|
|
};
|
|
|
|
// provides a random PrivateBin document formatter
|
|
exports.jscFormats = function() {
|
|
return jsc.elements(formats);
|
|
};
|
|
|
|
// provides random URLs
|
|
exports.jscUrl = function(withFragment = true, withQuery = true) {
|
|
let url = {
|
|
schema: exports.jscSchemas(),
|
|
address: jsc.nearray(exports.jscA2zString()),
|
|
};
|
|
if (withFragment) {
|
|
url.fragment = jsc.string;
|
|
}
|
|
if(withQuery) {
|
|
url.query = jsc.array(exports.jscQueryString());
|
|
}
|
|
return jsc.record(url);
|
|
};
|
|
|
|
exports.urlToString = function (url) {
|
|
return url.schema + '://' + url.address.join('') + '/' + (url.query ? '?' +
|
|
encodeURI(url.query.join('').replace(/^&+|&+$/gm,'')) : '') +
|
|
(url.fragment ? '#' + encodeURI(url.fragment) : '');
|
|
};
|
|
|
|
exports.enableClipboard = function () {
|
|
navigator.clipboard = (function () {
|
|
let savedText = "";
|
|
|
|
async function writeText(text) {
|
|
savedText = text;
|
|
};
|
|
|
|
async function readText() {
|
|
return savedText;
|
|
};
|
|
|
|
return {
|
|
writeText,
|
|
readText,
|
|
};
|
|
})();
|
|
};
|