2020-08-22 19:53:59 +03:00
|
|
|
import { bytesToHex, bytesFromHex, bufferConcats } from "./bin_utils";
|
2020-04-14 18:46:31 +03:00
|
|
|
// @ts-ignore
|
|
|
|
import {SecureRandom} from 'jsbn';
|
|
|
|
|
|
|
|
export const secureRandom = new SecureRandom();
|
2020-02-06 22:43:07 +07:00
|
|
|
|
|
|
|
Object.defineProperty(Uint8Array.prototype, 'hex', {
|
|
|
|
get: function(): string {
|
|
|
|
return bytesToHex([...this]);
|
|
|
|
},
|
2020-04-08 18:46:43 +03:00
|
|
|
|
2020-02-06 22:43:07 +07:00
|
|
|
set: function(str: string) {
|
|
|
|
this.set(bytesFromHex(str));
|
|
|
|
},
|
|
|
|
enumerable: true,
|
|
|
|
configurable: true
|
|
|
|
});
|
|
|
|
|
|
|
|
Uint8Array.prototype.randomize = function() {
|
2020-04-14 18:46:31 +03:00
|
|
|
secureRandom.nextBytes(this);
|
2020-02-06 22:43:07 +07:00
|
|
|
return this;
|
|
|
|
};
|
|
|
|
|
|
|
|
Uint8Array.prototype.concat = function(...args: Array<Uint8Array | ArrayBuffer | number[]>) {
|
|
|
|
return bufferConcats(this, ...args);
|
|
|
|
};
|
|
|
|
|
2020-04-19 00:55:20 +03:00
|
|
|
Uint8Array.prototype.toString = function() {
|
|
|
|
return String.fromCharCode.apply(null, [...this]);
|
|
|
|
};
|
|
|
|
|
2020-05-18 04:21:58 +03:00
|
|
|
Uint8Array.prototype.toJSON = function() {
|
|
|
|
return [...this];
|
|
|
|
};
|
|
|
|
|
2020-02-22 23:00:17 +07:00
|
|
|
Array.prototype.forEachReverse = function<T>(callback: (value: T, index?: number, array?: Array<T>) => void) {
|
|
|
|
let length = this.length;
|
|
|
|
for(var i = length - 1; i >= 0; --i) {
|
|
|
|
callback(this[i], i, this);
|
|
|
|
}
|
|
|
|
};
|
2020-02-06 22:43:07 +07:00
|
|
|
|
2020-03-02 00:26:25 +07:00
|
|
|
Array.prototype.findAndSplice = function<T>(verify: (value: T, index?: number, array?: Array<T>) => boolean) {
|
|
|
|
let index = this.findIndex(verify);
|
|
|
|
return index !== -1 ? this.splice(index, 1)[0] : undefined;
|
|
|
|
};
|
|
|
|
|
|
|
|
String.prototype.toHHMMSS = function(leadZero = false) {
|
2020-08-22 19:53:59 +03:00
|
|
|
const sec_num = parseInt(this + '', 10);
|
|
|
|
const hours = Math.floor(sec_num / 3600);
|
2020-03-02 00:26:25 +07:00
|
|
|
let minutes: any = Math.floor((sec_num - (hours * 3600)) / 60);
|
|
|
|
let seconds: any = sec_num - (hours * 3600) - (minutes * 60);
|
|
|
|
|
2020-08-22 19:53:59 +03:00
|
|
|
if(hours) leadZero = true;
|
2020-03-02 00:26:25 +07:00
|
|
|
if(minutes < 10) minutes = leadZero ? "0" + minutes : minutes;
|
|
|
|
if(seconds < 10) seconds = "0" + seconds;
|
2020-08-22 19:53:59 +03:00
|
|
|
return (hours ? /* ('0' + hours).slice(-2) */hours + ':' : '') + minutes + ':' + seconds;
|
|
|
|
};
|
2020-03-02 00:26:25 +07:00
|
|
|
|
2020-02-06 22:43:07 +07:00
|
|
|
declare global {
|
|
|
|
interface Uint8Array {
|
|
|
|
hex: string;
|
|
|
|
randomize: () => Uint8Array,
|
2020-04-19 00:55:20 +03:00
|
|
|
concat: (...args: Array<Uint8Array | ArrayBuffer | number[]>) => Uint8Array,
|
2020-05-18 04:21:58 +03:00
|
|
|
toString: () => string,
|
|
|
|
toJSON: () => number[],
|
2020-02-06 22:43:07 +07:00
|
|
|
}
|
2020-04-08 18:46:43 +03:00
|
|
|
|
2020-02-22 23:00:17 +07:00
|
|
|
interface Array<T> {
|
|
|
|
forEachReverse(callback: (value: T, index?: number, array?: Array<T>) => void): void;
|
2020-03-02 00:26:25 +07:00
|
|
|
findAndSplice(verify: (value: T, index?: number, array?: Array<T>) => boolean): T;
|
|
|
|
}
|
2020-04-08 18:46:43 +03:00
|
|
|
|
2020-03-02 00:26:25 +07:00
|
|
|
interface String {
|
|
|
|
toHHMMSS(leadZero?: boolean): string;
|
2020-02-22 23:00:17 +07:00
|
|
|
}
|
2020-02-06 22:43:07 +07:00
|
|
|
}
|