PHP WebShell

Текущая директория: /opt/BitGoJS/node_modules/c32check/src

Просмотр файла: checksum.ts

import { Buffer } from 'buffer/'
import { c32encode, c32decode, c32normalize, c32 } from './encoding'
import { hashSha256 } from 'cross-sha256'

/**
 * Get the c32check checksum of a hex-encoded string
 * @param {string} dataHex - the hex string
 * @returns {string} the c32 checksum, as a bin-encoded string
 */
function c32checksum(dataHex: string) : string {
  const dataHash = hashSha256(hashSha256(Buffer.from(dataHex, 'hex')))
  const checksum = dataHash.slice(0, 4).toString('hex')
  return checksum
}

/**
 * Encode a hex string as a c32check string.  This is a lot like how
 * base58check works in Bitcoin-land, but this algorithm uses the 
 * z-base-32 alphabet instead of the base58 alphabet.  The algorithm
 * is as follows:
 * * calculate the c32checksum of version + data
 * * c32encode version + data + c32checksum
 * @param {number} version - the version string (between 0 and 31)
 * @param {string} data - the data to encode
 * @returns {string} the c32check representation
 */
export function c32checkEncode(version: number, data: string) : string {
  if (version < 0 || version >= 32) {
    throw new Error('Invalid version (must be between 0 and 31)')
  }
  if (!data.match(/^[0-9a-fA-F]*$/)) {
    throw new Error('Invalid data (not a hex string)')
  }

  data = data.toLowerCase()
  if (data.length % 2 !== 0) {
    data = `0${data}`
  }

  let versionHex = version.toString(16)
  if (versionHex.length === 1) {
    versionHex = `0${versionHex}`
  }

  const checksumHex = c32checksum(`${versionHex}${data}`)
  const c32str = c32encode(`${data}${checksumHex}`)
  return `${c32[version]}${c32str}`
}

/*
 * Decode a c32check string back into its version and data payload.  This is
 * a lot like how base58check works in Bitcoin-land, but this algorithm uses
 * the z-base-32 alphabet instead of the base58 alphabet.  The algorithm
 * is as follows:
 * * extract the version, data, and checksum
 * * verify the checksum matches c32checksum(version + data)
 * * return data
 * @param {string} c32data - the c32check-encoded string
 * @returns {array} [version (number), data (string)].  The returned data 
 * will be a hex string.  Throws an exception if the checksum does not match.
 */
export function c32checkDecode(c32data: string) : [number, string] {
  c32data = c32normalize(c32data)
  const dataHex = c32decode(c32data.slice(1))
  const versionChar = c32data[0]
  const version = c32.indexOf(versionChar)
  const checksum = dataHex.slice(-8)

  let versionHex = version.toString(16)
  if (versionHex.length === 1) {
    versionHex = `0${versionHex}`
  }

  if (c32checksum(`${versionHex}${dataHex.substring(0, dataHex.length - 8)}`) !== checksum) {
    throw new Error('Invalid c32check string: checksum mismatch')
  }

  return [version, dataHex.substring(0, dataHex.length - 8)]
}

Выполнить команду


Для локальной разработки. Не используйте в интернете!