Skip to main content

VFX Address Creation

Summary:

The purpose of this document is to teach you how a VFX address is created. This will walk you through from the starting step to the very end which is a human readable address.

How to create an VFX Address

The correct way to create a VFX address is to use well tested, opensource, peer reviewed wallet software. The manually handling keys can and has resulted in fund loss over and over again. Unlike other centralized systems, losses in VFX are usually unrecoverable. Please proceed at your own risk.

Here is a brief overview of how address generation works, for informational purposes:

  • Having a private ECDSA key

    18e14a7b6a307f426a94f8114701e7c8e774e7f9a47e2c2035db29a206321725

  1. Take the corresponding public key generated with it and add '04' hex identifier. VFX private keys are created from Ecdsa multiplication of (curve.G, secret, curve.N, curve.A, curve.P). In code it appears as this:

    multiply(Point p, BigInteger n, BigInteger N, BigInteger A, BigIntegerP)

    Fast way to multiply point and scalar in elliptic curves

    • param p: First Point to multiply

    • param n: Scalar to multiply

    • param N: Order of the elliptic curve

    • param P: Prime number in the module of the equation Y\^2 = X \^ 3 + A \* X + B(mod p)

    • param A: Coefficient of the first-order term of the equation Y \^ 2 = X \^ 3 + A \* X + B(mod p)

    • return: Point that represents the sum of First and Second Point

    This can be seen in code under EllipticCurve->Math

    Please note many ECDSA libraries out there handle public keys this way, so you may not have to do the above jacobian math.

    \[04\*\*added\]50863ad64a87ae8a2fe83c1af1a8403cb53f53e486d8511dad8a04887e5b23522cd470243453a299fa9e77237716103abc11a1df38855ed6f2ee187e9c582ba6 =
    0450863ad64a87ae8a2fe83c1af1a8403cb53f53e486d8511dad8a04887e5b23522cd470243453a299fa9e77237716103abc11a1df38855ed6f2ee187e9c582ba6
  2. Perform SHA-256 hashing on the public key from step 1.

    600ffe422b4e00731a59557a5cca46cc183944191006324a447bdb2d98d4b408

  3. Perform RIPEMD-160 hashing on the result of SHA-256 from step 2.

    010966776006953d5567439e5e39f86a0d273bee

  4. Add version byte in front of RIPEMD-160 hash (0x3C for Main Network) from step 3.

    3c010966776006953d5567439e5e39f86a0d273bee

    (note that below steps are the Base58Check encoding, which has multiple library options available implementing it)

  5. Perform SHA-256 hash on the extended RIPEMD-160 result from step 4.

    24295fdd7e8c04bbc84f1e5151b4afa3380f900a5da58533a647c36fdc2d4cfd

  6. Perform SHA-256 hash on the result of the previous SHA-256 hash from step 5.

    3699e7d4f297550311c32721b57c801f873d07ef5a886cbd07146f478178b362

  7. Take the first 4 bytes of the second SHA-256 hash. This is the address checksum from step 6.

    3699e7d4

  8. Add the 4 checksum bytes from stage 7 at the end of extended RIPEMD-160 hash from stage 4. This is the 25-byte binary VFX Address.

    3c010966776006953d5567439e5e39f86a0d273bee3699e7d4

  9. Convert the result from a byte string into a base58 string using Base58Check encoding from step 8.

    R9Ng1rDS2YgB7R2bJMU3RKzVXSriXLRsBR