All files / src/metadata address.ts

92% Statements 46/50
50% Branches 1/2
33.33% Functions 1/3
92% Lines 46/50

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 511x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 36x 36x 36x 36x 1x 1x 1x 1x 1x 1x 1x     1x 1x 1x 1x 1x 1x 1x     1x  
import { Field, PublicKey, Poseidon } from "o1js";
export { MinaAddress };
 
/**
/**
 * The `MinaAddress` class represents a Mina address in the form of a Merkle tree. The address is converted to its
 * hash and stored as a leaf in the Merkle tree. The root of the tree can be used as a compact representation
 * of the address data in cryptographic proofs.
 */
class MinaAddress {
  /**
   * The original address.
   */
  readonly address: PublicKey;
  /**
   * The hash of the address.
   */
  readonly hash: Field;
 
  /**
   * Constructs a new `MinaAddress` instance by creating a Merkle tree from the given address.
   * The address is converted to its hash and stored as a leaf in the tree.
   *
   * @param address - The address to be represented.
   * @throws Will throw an error if the address is not a valid Mina address.
   */
  constructor(address: PublicKey | string) {
    this.address =
      typeof address === "string" ? PublicKey.fromBase58(address) : address;
    this.hash = Poseidon.hashPacked(PublicKey, this.address);
  }
 
  /**
   * Returns the original address.
   *
   * @returns The public key.
   */
  public toPublicKey(): PublicKey {
    return this.address;
  }
 
  /**
   * Returns the base58 representation of the address.
   *
   * @returns The base58 representation of the address.
   */
  public toString(): string {
    return this.address.toBase58();
  }
}