mirror of
https://github.com/pezkuwichain/pezkuwi-ui.git
synced 2026-04-23 00:18:02 +00:00
83 lines
1.9 KiB
TypeScript
83 lines
1.9 KiB
TypeScript
// Copyright 2017-2021 @polkadot/react-qr authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import { isString, u8aConcat, u8aToU8a } from '@polkadot/util';
|
|
import { decodeAddress } from '@polkadot/util-crypto';
|
|
|
|
import { ADDRESS_PREFIX, CRYPTO_SR25519, FRAME_SIZE, SUBSTRATE_ID } from './constants';
|
|
|
|
const MULTIPART = new Uint8Array([0]);
|
|
|
|
export function encodeNumber (value: number): Uint8Array {
|
|
return new Uint8Array([value >> 8, value & 0xff]);
|
|
}
|
|
|
|
export function encodeString (value: string): Uint8Array {
|
|
const u8a = new Uint8Array(value.length);
|
|
|
|
for (let i = 0; i < value.length; i++) {
|
|
u8a[i] = value.charCodeAt(i);
|
|
}
|
|
|
|
return u8a;
|
|
}
|
|
|
|
export function decodeString (value: Uint8Array): string {
|
|
return value.reduce((str, code): string => {
|
|
return str + String.fromCharCode(code);
|
|
}, '');
|
|
}
|
|
|
|
export function createAddressPayload (address: string, genesisHash: string): Uint8Array {
|
|
return encodeString(`${ADDRESS_PREFIX}:${address}:${genesisHash}`);
|
|
}
|
|
|
|
export function createSignPayload (address: string, cmd: number, payload: string | Uint8Array, genesisHash: string | Uint8Array): Uint8Array {
|
|
return u8aConcat(
|
|
SUBSTRATE_ID,
|
|
CRYPTO_SR25519,
|
|
new Uint8Array([cmd]),
|
|
decodeAddress(address),
|
|
u8aToU8a(payload),
|
|
u8aToU8a(genesisHash)
|
|
);
|
|
}
|
|
|
|
export function createFrames (input: Uint8Array): Uint8Array[] {
|
|
const frames = [];
|
|
let idx = 0;
|
|
|
|
while (idx < input.length) {
|
|
frames.push(input.subarray(idx, idx + FRAME_SIZE));
|
|
|
|
idx += FRAME_SIZE;
|
|
}
|
|
|
|
return frames.map((frame, index: number): Uint8Array =>
|
|
u8aConcat(
|
|
MULTIPART,
|
|
encodeNumber(frames.length),
|
|
encodeNumber(index),
|
|
frame
|
|
)
|
|
);
|
|
}
|
|
|
|
export function createImgSize (size?: string | number): Record<string, string> {
|
|
if (!size) {
|
|
return {
|
|
height: 'auto',
|
|
width: '100%'
|
|
};
|
|
}
|
|
|
|
const height = isString(size)
|
|
? size
|
|
: `${size}px`;
|
|
|
|
return {
|
|
height,
|
|
width: height
|
|
};
|
|
}
|