PHP WebShell

Текущая директория: /opt/BitGoJS/node_modules/avalanche/tests/apis/evm

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

import { KeyChain, KeyPair } from "../../../src/apis/avm/keychain"
import { Avalanche } from "../../../src/index"
import { Buffer } from "buffer/"
import createHash from "create-hash"
import BinTools from "../../../src/utils/bintools"

const bintools: BinTools = BinTools.getInstance()
const alias: string = "C"
const hrp: string = "tests"

describe("EVMKeyPair", (): void => {
  const networkID: number = 1337
  const ip: string = "127.0.0.1"
  const port: number = 9650
  const protocol: string = "https"
  const avalanche: Avalanche = new Avalanche(
    ip,
    port,
    protocol,
    networkID,
    undefined,
    undefined,
    undefined,
    true
  )

  test("human readable part", (): void => {
    let hrp: string = avalanche.getHRP()
    let networkID: number = avalanche.getNetworkID()
    expect(hrp).toBe("custom")
    expect(networkID).toBe(1337)

    avalanche.setNetworkID(2)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("cascade")
    expect(networkID).toBe(2)

    avalanche.setNetworkID(3)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("denali")
    expect(networkID).toBe(3)

    avalanche.setNetworkID(4)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("everest")
    expect(networkID).toBe(4)

    avalanche.setNetworkID(0)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("custom")
    expect(networkID).toBe(0)

    avalanche.setNetworkID(1)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("avax")
    expect(networkID).toBe(1)

    avalanche.setNetworkID(12345)
    hrp = avalanche.getHRP()
    networkID = avalanche.getNetworkID()
    expect(hrp).toBe("local")
    expect(networkID).toBe(12345)
  })

  test("repeatable 1", (): void => {
    const kp: KeyPair = new KeyPair(hrp, alias)
    kp.importKey(
      Buffer.from(
        "ef9bf2d4436491c153967c9709dd8e82795bdb9b5ad44ee22c2903005d1cf676",
        "hex"
      )
    )
    expect(kp.getPublicKey().toString("hex")).toBe(
      "033fad3644deb20d7a210d12757092312451c112d04773cee2699fbb59dc8bb2ef"
    )

    const msg: Buffer = Buffer.from(
      createHash("sha256").update(Buffer.from("09090909", "hex")).digest("hex"),
      "hex"
    )
    const sig: Buffer = kp.sign(msg)

    expect(sig.length).toBe(65)
    expect(kp.verify(msg, sig)).toBe(true)
    expect(kp.recover(msg, sig).toString("hex")).toBe(
      kp.getPublicKey().toString("hex")
    )
  })

  test("repeatable 2", (): void => {
    const kp: KeyPair = new KeyPair(hrp, alias)
    kp.importKey(
      Buffer.from(
        "17c692d4a99d12f629d9f0ff92ec0dba15c9a83e85487b085c1a3018286995c6",
        "hex"
      )
    )
    expect(kp.getPublicKey().toString("hex")).toBe(
      "02486553b276cfe7abf0efbcd8d173e55db9c03da020c33d0b219df24124da18ee"
    )

    const msg: Buffer = Buffer.from(
      createHash("sha256").update(Buffer.from("09090909", "hex")).digest("hex"),
      "hex"
    )
    const sig: Buffer = kp.sign(msg)

    expect(sig.length).toBe(65)
    expect(kp.verify(msg, sig)).toBe(true)
    expect(kp.recover(msg, sig).toString("hex")).toBe(
      kp.getPublicKey().toString("hex")
    )
  })

  test("repeatable 3", (): void => {
    const kp: KeyPair = new KeyPair(hrp, alias)
    kp.importKey(
      Buffer.from(
        "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
        "hex"
      )
    )
    expect(kp.getPublicKey().toString("hex")).toBe(
      "031475b91d4fcf52979f1cf107f058088cc2bea6edd51915790f27185a7586e2f2"
    )

    const msg: Buffer = Buffer.from(
      createHash("sha256").update(Buffer.from("09090909", "hex")).digest("hex"),
      "hex"
    )
    const sig: Buffer = kp.sign(msg)

    expect(sig.length).toBe(65)
    expect(kp.verify(msg, sig)).toBe(true)
    expect(kp.recover(msg, sig).toString("hex")).toBe(
      kp.getPublicKey().toString("hex")
    )
  })

  test("Creation Empty", (): void => {
    const kp: KeyPair = new KeyPair(hrp, alias)
    expect(kp.getPrivateKey()).not.toBeUndefined()
    expect(kp.getAddress()).not.toBeUndefined()
    expect(kp.getPrivateKeyString()).not.toBeUndefined()
    expect(kp.getPublicKey()).not.toBeUndefined()
    expect(kp.getPublicKeyString()).not.toBeUndefined()
    const msg: Buffer = Buffer.from(
      createHash("sha256").update(Buffer.from("09090909", "hex")).digest("hex"),
      "hex"
    )
    const sig: Buffer = kp.sign(msg)

    expect(sig.length).toBe(65)
    expect(kp.verify(msg, sig)).toBe(true)
    expect(kp.recover(msg, sig).toString("hex")).toBe(
      kp.getPublicKey().toString("hex")
    )
  })
})

describe("EVMKeyChain", (): void => {
  test("importKey from Buffer", (): void => {
    const keybuff: Buffer = Buffer.from(
      "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    const kc: KeyChain = new KeyChain(hrp, alias)
    const kp2: KeyPair = new KeyPair(hrp, alias)
    const addr1: Buffer = kc.importKey(keybuff).getAddress()
    const kp1: KeyPair = kc.getKey(addr1)
    kp2.importKey(keybuff)
    const addr2 = kp1.getAddress()
    expect(addr1.toString("hex")).toBe(addr2.toString("hex"))
    expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString())
    expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString())
    expect(kc.hasKey(addr1)).toBe(true)
  })

  test("importKey from Buffer with leading zeros", (): void => {
    const keybuff: Buffer = Buffer.from(
      "00007d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    expect(keybuff.length).toBe(32)
    const kc: KeyChain = new KeyChain(hrp, alias)
    const kp2: KeyPair = new KeyPair(hrp, alias)
    const addr1: Buffer = kc.importKey(keybuff).getAddress()
    const kp1: KeyPair = kc.getKey(addr1)
    kp2.importKey(keybuff)
    const addr2 = kp1.getAddress()
    expect(addr1.toString("hex")).toBe(addr2.toString("hex"))
    expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString())
    expect(kp1.getPrivateKey().length).toBe(32)
    expect(kp2.getPrivateKey().length).toBe(32)
    expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString())
    expect(kp1.getPublicKey().length).toBe(33)
    expect(kp2.getPublicKey().length).toBe(33)
    expect(kc.hasKey(addr1)).toBe(true)
  })

  test("importKey from serialized string", (): void => {
    const keybuff: Buffer = Buffer.from(
      "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    const kc: KeyChain = new KeyChain(hrp, alias)
    const kp2: KeyPair = new KeyPair(hrp, alias)
    const addr1: Buffer = kc
      .importKey("PrivateKey-" + bintools.cb58Encode(keybuff))
      .getAddress()
    const kp1: KeyPair = kc.getKey(addr1)
    kp2.importKey(keybuff)
    const addr2 = kp1.getAddress()
    expect(addr1.toString("hex")).toBe(addr2.toString("hex"))
    expect(kp1.getPrivateKeyString()).toBe(kp2.getPrivateKeyString())
    expect(kp1.getPublicKeyString()).toBe(kp2.getPublicKeyString())
    expect(kc.hasKey(addr1)).toBe(true)
  })

  test("removeKey via keypair", (): void => {
    const keybuff: Buffer = Buffer.from(
      "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    const kc: KeyChain = new KeyChain(hrp, alias)
    const kp1: KeyPair = new KeyPair(hrp, alias)
    const addr1: Buffer = kc.importKey(keybuff).getAddress()
    kp1.importKey(keybuff)
    expect(kc.hasKey(addr1)).toBe(true)
    kc.removeKey(kp1)
    expect(kc.hasKey(addr1)).toBe(false)
  })

  test("removeKey via string", (): void => {
    const keybuff: Buffer = Buffer.from(
      "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    const kc: KeyChain = new KeyChain(hrp, alias)
    const addr1: Buffer = kc.importKey(keybuff).getAddress()
    expect(kc.hasKey(addr1)).toBe(true)
    kc.removeKey(addr1)
    expect(kc.hasKey(addr1)).toBe(false)
  })

  test("removeKey bad keys", (): void => {
    const keybuff: Buffer = Buffer.from(
      "d0e17d4b31380f96a42b3e9ffc4c1b2a93589a1e51d86d7edc107f602fbc7475",
      "hex"
    )
    const kc: KeyChain = new KeyChain(hrp, alias)
    const addr1: Buffer = kc.importKey(keybuff).getAddress()
    expect(kc.hasKey(addr1)).toBe(true)
    expect(
      kc.removeKey(bintools.cb58Decode("6Y3kysjF9jnHnYkdS9yGAuoHyae2eNmeV"))
    ).toBe(false)
  })
})

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


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