upgrade base-x to 5.0.1

This commit is contained in:
El RIDO 2025-07-22 10:32:08 +02:00
parent f3e2c53729
commit e50a809855
No known key found for this signature in database
GPG key ID: 0F5C940A6BD81F92
7 changed files with 62 additions and 58 deletions

View file

@ -9,7 +9,7 @@
* CHANGED: Removed support for `privatebin_data`, `privatebin_db` & `zerobin_db` model class configurations, must be replaced with `Filesystem` or `Database` in `cfg/conf.php`, if still present * CHANGED: Removed support for `privatebin_data`, `privatebin_db` & `zerobin_db` model class configurations, must be replaced with `Filesystem` or `Database` in `cfg/conf.php`, if still present
* CHANGED: Removed unused columns in database schema of tables `paste` & `comment` * CHANGED: Removed unused columns in database schema of tables `paste` & `comment`
* CHANGED: Jdenticons are now used as the default icons * CHANGED: Jdenticons are now used as the default icons
* CHANGED: Upgrading libraries to: bootstrap 5.3.7, jdenticon 2.0.0 & kjua 0.10.0 * CHANGED: Upgrading libraries to: base-x 5.0.1, bootstrap 5.3.7, jdenticon 2.0.0 & kjua 0.10.0
* CHANGED: Minimum required PHP version is 7.4, due to a change in the jdenticon library * CHANGED: Minimum required PHP version is 7.4, due to a change in the jdenticon library
* CHANGED: Set bootstrap5 template as default for PrivateBin (#1572) * CHANGED: Set bootstrap5 template as default for PrivateBin (#1572)
* FIXED: Name mismatches in attached files (#1584) * FIXED: Name mismatches in attached files (#1584)

View file

@ -7,23 +7,23 @@
(function(){ (function(){
this.baseX = function base (ALPHABET) { this.baseX = function base (ALPHABET) {
if (ALPHABET.length >= 255) { throw new TypeError('Alphabet too long') } if (ALPHABET.length >= 255) { throw new TypeError('Alphabet too long') }
var BASE_MAP = new Uint8Array(256) const BASE_MAP = new Uint8Array(256)
for (var j = 0; j < BASE_MAP.length; j++) { for (let j = 0; j < BASE_MAP.length; j++) {
BASE_MAP[j] = 255 BASE_MAP[j] = 255
} }
for (var i = 0; i < ALPHABET.length; i++) { for (let i = 0; i < ALPHABET.length; i++) {
var x = ALPHABET.charAt(i) const x = ALPHABET.charAt(i)
var xc = x.charCodeAt(0) const xc = x.charCodeAt(0)
if (BASE_MAP[xc] !== 255) { throw new TypeError(x + ' is ambiguous') } if (BASE_MAP[xc] !== 255) { throw new TypeError(x + ' is ambiguous') }
BASE_MAP[xc] = i BASE_MAP[xc] = i
} }
var BASE = ALPHABET.length const BASE = ALPHABET.length
var LEADER = ALPHABET.charAt(0) const LEADER = ALPHABET.charAt(0)
var FACTOR = Math.log(BASE) / Math.log(256) // log(BASE) / log(256), rounded up const FACTOR = Math.log(BASE) / Math.log(256) // log(BASE) / log(256), rounded up
var iFACTOR = Math.log(256) / Math.log(BASE) // log(256) / log(BASE), rounded up const iFACTOR = Math.log(256) / Math.log(BASE) // log(256) / log(BASE), rounded up
function encode (source) { function encode (source) {
if (source instanceof Uint8Array) { // eslint-disable-next-line no-empty
} else if (ArrayBuffer.isView(source)) { if (source instanceof Uint8Array) { } else if (ArrayBuffer.isView(source)) {
source = new Uint8Array(source.buffer, source.byteOffset, source.byteLength) source = new Uint8Array(source.buffer, source.byteOffset, source.byteLength)
} else if (Array.isArray(source)) { } else if (Array.isArray(source)) {
source = Uint8Array.from(source) source = Uint8Array.from(source)
@ -31,23 +31,23 @@ this.baseX = function base (ALPHABET) {
if (!(source instanceof Uint8Array)) { throw new TypeError('Expected Uint8Array') } if (!(source instanceof Uint8Array)) { throw new TypeError('Expected Uint8Array') }
if (source.length === 0) { return '' } if (source.length === 0) { return '' }
// Skip & count leading zeroes. // Skip & count leading zeroes.
var zeroes = 0 let zeroes = 0
var length = 0 let length = 0
var pbegin = 0 let pbegin = 0
var pend = source.length const pend = source.length
while (pbegin !== pend && source[pbegin] === 0) { while (pbegin !== pend && source[pbegin] === 0) {
pbegin++ pbegin++
zeroes++ zeroes++
} }
// Allocate enough space in big-endian base58 representation. // Allocate enough space in big-endian base58 representation.
var size = ((pend - pbegin) * iFACTOR + 1) >>> 0 const size = ((pend - pbegin) * iFACTOR + 1) >>> 0
var b58 = new Uint8Array(size) const b58 = new Uint8Array(size)
// Process the bytes. // Process the bytes.
while (pbegin !== pend) { while (pbegin !== pend) {
var carry = source[pbegin] let carry = source[pbegin]
// Apply "b58 = b58 * 256 + ch". // Apply "b58 = b58 * 256 + ch".
var i = 0 let i = 0
for (var it1 = size - 1; (carry !== 0 || i < length) && (it1 !== -1); it1--, i++) { for (let it1 = size - 1; (carry !== 0 || i < length) && (it1 !== -1); it1--, i++) {
carry += (256 * b58[it1]) >>> 0 carry += (256 * b58[it1]) >>> 0
b58[it1] = (carry % BASE) >>> 0 b58[it1] = (carry % BASE) >>> 0
carry = (carry / BASE) >>> 0 carry = (carry / BASE) >>> 0
@ -57,37 +57,41 @@ this.baseX = function base (ALPHABET) {
pbegin++ pbegin++
} }
// Skip leading zeroes in base58 result. // Skip leading zeroes in base58 result.
var it2 = size - length let it2 = size - length
while (it2 !== size && b58[it2] === 0) { while (it2 !== size && b58[it2] === 0) {
it2++ it2++
} }
// Translate the result into a string. // Translate the result into a string.
var str = LEADER.repeat(zeroes) let str = LEADER.repeat(zeroes)
for (; it2 < size; ++it2) { str += ALPHABET.charAt(b58[it2]) } for (; it2 < size; ++it2) { str += ALPHABET.charAt(b58[it2]) }
return str return str
} }
function decodeUnsafe (source) { function decodeUnsafe (source) {
if (typeof source !== 'string') { throw new TypeError('Expected String') } if (typeof source !== 'string') { throw new TypeError('Expected String') }
if (source.length === 0) { return new Uint8Array() } if (source.length === 0) { return new Uint8Array() }
var psz = 0 let psz = 0
// Skip and count leading '1's. // Skip and count leading '1's.
var zeroes = 0 let zeroes = 0
var length = 0 let length = 0
while (source[psz] === LEADER) { while (source[psz] === LEADER) {
zeroes++ zeroes++
psz++ psz++
} }
// Allocate enough space in big-endian base256 representation. // Allocate enough space in big-endian base256 representation.
var size = (((source.length - psz) * FACTOR) + 1) >>> 0 // log(58) / log(256), rounded up. const size = (((source.length - psz) * FACTOR) + 1) >>> 0 // log(58) / log(256), rounded up.
var b256 = new Uint8Array(size) const b256 = new Uint8Array(size)
// Process the characters. // Process the characters.
while (source[psz]) { while (psz < source.length) {
// Find code of next character
const charCode = source.charCodeAt(psz)
// Base map can not be indexed using char code
if (charCode > 255) { return }
// Decode character // Decode character
var carry = BASE_MAP[source.charCodeAt(psz)] let carry = BASE_MAP[charCode]
// Invalid character // Invalid character
if (carry === 255) { return } if (carry === 255) { return }
var i = 0 let i = 0
for (var it3 = size - 1; (carry !== 0 || i < length) && (it3 !== -1); it3--, i++) { for (let it3 = size - 1; (carry !== 0 || i < length) && (it3 !== -1); it3--, i++) {
carry += (BASE * b256[it3]) >>> 0 carry += (BASE * b256[it3]) >>> 0
b256[it3] = (carry % 256) >>> 0 b256[it3] = (carry % 256) >>> 0
carry = (carry / 256) >>> 0 carry = (carry / 256) >>> 0
@ -97,26 +101,26 @@ this.baseX = function base (ALPHABET) {
psz++ psz++
} }
// Skip leading zeroes in b256. // Skip leading zeroes in b256.
var it4 = size - length let it4 = size - length
while (it4 !== size && b256[it4] === 0) { while (it4 !== size && b256[it4] === 0) {
it4++ it4++
} }
var vch = new Uint8Array(zeroes + (size - it4)) const vch = new Uint8Array(zeroes + (size - it4))
var j = zeroes let j = zeroes
while (it4 !== size) { while (it4 !== size) {
vch[j++] = b256[it4++] vch[j++] = b256[it4++]
} }
return vch return vch
} }
function decode (string) { function decode (string) {
var buffer = decodeUnsafe(string) const buffer = decodeUnsafe(string)
if (buffer) { return buffer } if (buffer) { return buffer }
throw new Error('Non-base' + BASE + ' character') throw new Error('Non-base' + BASE + ' character')
} }
return { return {
encode: encode, encode,
decodeUnsafe: decodeUnsafe, decodeUnsafe,
decode: decode decode
} }
} }
}).call(this); }).call(this);

View file

@ -16,7 +16,7 @@ global.prettyPrint = window.PR.prettyPrint;
global.prettyPrintOne = window.PR.prettyPrintOne; global.prettyPrintOne = window.PR.prettyPrintOne;
global.showdown = require('./showdown-2.1.0'); global.showdown = require('./showdown-2.1.0');
global.DOMPurify = require('./purify-3.2.6'); global.DOMPurify = require('./purify-3.2.6');
global.baseX = require('./base-x-4.0.0').baseX; global.baseX = require('./base-x-5.0.1').baseX;
global.Legacy = require('./legacy').Legacy; global.Legacy = require('./legacy').Legacy;
require('./privatebin'); require('./privatebin');

View file

@ -10,7 +10,7 @@
* @namespace * @namespace
*/ */
// global Base64, DOMPurify, FileReader, bootstrap, history, navigator, prettyPrint, prettyPrintOne, showdown, kjua // global Base64, DOMPurify, FileReader, baseX, bootstrap, history, navigator, prettyPrint, prettyPrintOne, showdown, kjua
jQuery.fn.draghover = function() { jQuery.fn.draghover = function() {
'use strict'; 'use strict';
@ -985,7 +985,7 @@ jQuery.PrivateBin = (function($) {
* *
* @private * @private
*/ */
let base58 = new baseX('123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'); const base58 = new baseX('123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz');
/** /**
* convert UTF-8 string stored in a DOMString to a standard UTF-16 DOMString * convert UTF-8 string stored in a DOMString to a standard UTF-16 DOMString

View file

@ -108,7 +108,7 @@ class Configuration
), ),
// update this array when adding/changing/removing js files // update this array when adding/changing/removing js files
'sri' => array( 'sri' => array(
'js/base-x-4.0.0.js' => 'sha512-nNPg5IGCwwrveZ8cA/yMGr5HiRS5Ps2H+s0J/mKTPjCPWUgFGGw7M5nqdnPD3VsRwCVysUh3Y8OWjeSKGkEQJQ==', 'js/base-x-5.0.1.js' => 'sha512-FmhlnjIxQyxkkxQmzf0l6IRGsGbgyCdgqPxypFsEtHMF1naRqaLLo6mcyN5rEaT16nKx1PeJ4g7+07D6gnk/Tg==',
'js/bootstrap-3.4.1.js' => 'sha512-oBTprMeNEKCnqfuqKd6sbvFzmFQtlXS3e0C/RGFV0hD6QzhHV+ODfaQbAlmY6/q0ubbwlAM/nCJjkrgA3waLzg==', 'js/bootstrap-3.4.1.js' => 'sha512-oBTprMeNEKCnqfuqKd6sbvFzmFQtlXS3e0C/RGFV0hD6QzhHV+ODfaQbAlmY6/q0ubbwlAM/nCJjkrgA3waLzg==',
'js/bootstrap-5.3.7.js' => 'sha512-UqmrCkPcp6WOB9cC/NB5GB7vQd2/sB70bLpFk0bqHz/WQIFucjAM0vFNI4xp8B7jJ8KIUWPblNAS/M30AHKSzA==', 'js/bootstrap-5.3.7.js' => 'sha512-UqmrCkPcp6WOB9cC/NB5GB7vQd2/sB70bLpFk0bqHz/WQIFucjAM0vFNI4xp8B7jJ8KIUWPblNAS/M30AHKSzA==',
'js/dark-mode-switch.js' => 'sha512-BhY7dNU14aDN5L+muoUmA66x0CkYUWkQT0nxhKBLP/o2d7jE025+dvWJa4OiYffBGEFgmhrD/Sp+QMkxGMTz2g==', 'js/dark-mode-switch.js' => 'sha512-BhY7dNU14aDN5L+muoUmA66x0CkYUWkQT0nxhKBLP/o2d7jE025+dvWJa4OiYffBGEFgmhrD/Sp+QMkxGMTz2g==',
@ -116,7 +116,7 @@ class Configuration
'js/kjua-0.10.0.js' => 'sha512-BYj4xggowR7QD150VLSTRlzH62YPfhpIM+b/1EUEr7RQpdWAGKulxWnOvjFx1FUlba4m6ihpNYuQab51H6XlYg==', 'js/kjua-0.10.0.js' => 'sha512-BYj4xggowR7QD150VLSTRlzH62YPfhpIM+b/1EUEr7RQpdWAGKulxWnOvjFx1FUlba4m6ihpNYuQab51H6XlYg==',
'js/legacy.js' => 'sha512-UxW/TOZKon83n6dk/09GsYKIyeO5LeBHokxyIq+r7KFS5KMBeIB/EM7NrkVYIezwZBaovnyNtY2d9tKFicRlXg==', 'js/legacy.js' => 'sha512-UxW/TOZKon83n6dk/09GsYKIyeO5LeBHokxyIq+r7KFS5KMBeIB/EM7NrkVYIezwZBaovnyNtY2d9tKFicRlXg==',
'js/prettify.js' => 'sha512-puO0Ogy++IoA2Pb9IjSxV1n4+kQkKXYAEUtVzfZpQepyDPyXk8hokiYDS7ybMogYlyyEIwMLpZqVhCkARQWLMg==', 'js/prettify.js' => 'sha512-puO0Ogy++IoA2Pb9IjSxV1n4+kQkKXYAEUtVzfZpQepyDPyXk8hokiYDS7ybMogYlyyEIwMLpZqVhCkARQWLMg==',
'js/privatebin.js' => 'sha512-tMfKTpfpl98pim+FfMzyg7bHHRpcs/raK6zHIDrr5FdJk6u9oj6ldqzN5SAaxwyHPGyPAzk/ozk7w8/2X3X2nA==', 'js/privatebin.js' => 'sha512-tEMoEpNQ36hksIPjp5y8go2RY0oQL9qY3Kzh1BKjOf1y35QIP7klUSHJqDhVkcLTyDc0CoZVEMMxSoMMc7EYCw==',
'js/purify-3.2.6.js' => 'sha512-zqwL4OoBLFx89QPewkz4Lz5CSA2ktU+f31fuECkF0iK3Id5qd3Zpq5dMby8KwHjIEpsUgOqwF58cnmcaNem0EA==', 'js/purify-3.2.6.js' => 'sha512-zqwL4OoBLFx89QPewkz4Lz5CSA2ktU+f31fuECkF0iK3Id5qd3Zpq5dMby8KwHjIEpsUgOqwF58cnmcaNem0EA==',
'js/showdown-2.1.0.js' => 'sha512-WYXZgkTR0u/Y9SVIA4nTTOih0kXMEd8RRV6MLFdL6YU8ymhR528NLlYQt1nlJQbYz4EW+ZsS0fx1awhiQJme1Q==', 'js/showdown-2.1.0.js' => 'sha512-WYXZgkTR0u/Y9SVIA4nTTOih0kXMEd8RRV6MLFdL6YU8ymhR528NLlYQt1nlJQbYz4EW+ZsS0fx1awhiQJme1Q==',
'js/zlib-1.3.1-1.js' => 'sha512-5bU9IIP4PgBrOKLZvGWJD4kgfQrkTz8Z3Iqeu058mbQzW3mCumOU6M3UVbVZU9rrVoVwaW4cZK8U8h5xjF88eQ==', 'js/zlib-1.3.1-1.js' => 'sha512-5bU9IIP4PgBrOKLZvGWJD4kgfQrkTz8Z3Iqeu058mbQzW3mCumOU6M3UVbVZU9rrVoVwaW4cZK8U8h5xjF88eQ==',

View file

@ -51,7 +51,7 @@ if ($QRCODE) :
endif; endif;
?> ?>
<?php $this->_scriptTag('js/zlib-1.3.1-1.js', 'async'); ?> <?php $this->_scriptTag('js/zlib-1.3.1-1.js', 'async'); ?>
<?php $this->_scriptTag('js/base-x-4.0.0.js', 'defer'); ?> <?php $this->_scriptTag('js/base-x-5.0.1.js', 'defer'); ?>
<?php $this->_scriptTag('js/bootstrap-3.4.1.js', 'defer'); ?> <?php $this->_scriptTag('js/bootstrap-3.4.1.js', 'defer'); ?>
<?php <?php
if ($SYNTAXHIGHLIGHTING) : if ($SYNTAXHIGHLIGHTING) :

View file

@ -34,7 +34,7 @@ if ($QRCODE) :
endif; endif;
?> ?>
<?php $this->_scriptTag('js/zlib-1.3.1-1.js', 'defer'); ?> <?php $this->_scriptTag('js/zlib-1.3.1-1.js', 'defer'); ?>
<?php $this->_scriptTag('js/base-x-4.0.0.js', 'defer'); ?> <?php $this->_scriptTag('js/base-x-5.0.1.js', 'defer'); ?>
<?php $this->_scriptTag('js/bootstrap-5.3.7.js', 'async'); ?> <?php $this->_scriptTag('js/bootstrap-5.3.7.js', 'async'); ?>
<?php $this->_scriptTag('js/dark-mode-switch.js', 'defer'); ?> <?php $this->_scriptTag('js/dark-mode-switch.js', 'defer'); ?>
<?php <?php