org.bitcoinj.core.Base58 Java Examples

The following examples show how to use org.bitcoinj.core.Base58. You can vote up the ones you like or vote down the ones you don't like, and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: Utils.java    From evt4j with MIT License 7 votes vote down vote up
@NotNull
public static String base58Check(byte[] key, @Nullable String keyType) {
    byte[] check = key;

    if (keyType != null) {
        check = ArrayUtils.addAll(key, keyType.getBytes());
    }

    byte[] hash = ripemd160(check);
    byte[] concat = ArrayUtils.addAll(key, ArrayUtils.subarray(hash, 0, 4));
    return Base58.encode(concat);
}
 
Example #2
Source File: EOSSign.java    From token-core-android with Apache License 2.0 7 votes vote down vote up
private static String serialEOSSignature(byte[] data) {
  byte[] toHash = ByteUtil.concat(data, "K1".getBytes());
  RIPEMD160Digest digest = new RIPEMD160Digest();
  digest.update(toHash, 0, toHash.length);
  byte[] out = new byte[20];
  digest.doFinal(out, 0);
  byte[] checksumBytes = Arrays.copyOfRange(out, 0, 4);
  data = ByteUtil.concat(data, checksumBytes);
  return "SIG_K1_" + Base58.encode(data);
}
 
Example #3
Source File: types.java    From AndroidWallet with GNU General Public License v3.0 6 votes vote down vote up
@Override
public String toString() {
    byte[] data = new byte[key_data.length + 1 + 4];
    data[0] = (byte) 0x80;
    System.arraycopy(key_data, 0, data, 1, key_data.length);

    SHA256Digest digest = new SHA256Digest();
    digest.update(data, 0, key_data.length + 1);
    byte[] out = new byte[32];
    digest.doFinal(out, 0);

    digest.update(out, 0, out.length);
    digest.doFinal(out, 0);

    System.arraycopy(out, 0, data, key_data.length + 1, 4);
    return Base58.encode(data);
}
 
Example #4
Source File: ContractBuilder.java    From guarda-android-wallets with GNU General Public License v3.0 6 votes vote down vote up
private String convertParameter(ContractMethodParameter parameter) {
    String _value = parameter.getValue();
    if (!parameterIsArray(parameter)) {
        if (parameter.getType().contains(TYPE_INT)) {
            return appendNumericPattern(convertToByteCode(new BigInteger(_value)));
        } else if (parameter.getType().contains(TYPE_STRING)) {
            return getStringOffset(parameter);
        } else if (parameter.getType().contains(TYPE_ADDRESS) && _value.length() == 34) {
            byte[] decode = Base58.decode(_value);
            String toHexString = Hex.toHexString(decode);
            String substring = toHexString.substring(2, 42);
            return appendAddressPattern(substring);
        } else if (parameter.getType().contains(TYPE_ADDRESS)) {
            return getStringOffset(parameter);
        } else if (parameter.getType().contains(TYPE_BOOL)) {
            return appendBoolean(_value);
        }
    } else {
        return getStringOffset(parameter);
    }
    return "";
}
 
Example #5
Source File: EOSWalletTest.java    From token-core-android with Apache License 2.0 6 votes vote down vote up
@Test
public void generatePrvPubKey() {

  byte[] prvWIF = Base58.decode(WIF);
  // have omitted the checksum verification
  prvWIF = Arrays.copyOfRange(prvWIF, 1, prvWIF.length - 4);

  // use the privateKey to calculate the compressed public key directly
  ECKey ecKey = ECKey.fromPrivate(new BigInteger(1, prvWIF));
  byte[] pubKeyData = ecKey.getPubKey();
  RIPEMD160Digest digest = new RIPEMD160Digest();
  digest.update(pubKeyData, 0, pubKeyData.length);
  byte[] out = new byte[20];
  digest.doFinal(out, 0);
  byte[] checksumBytes = Arrays.copyOfRange(out, 0, 4);

  pubKeyData = ByteUtil.concat(pubKeyData, checksumBytes);
  String eosPK = "EOS" + Base58.encode(pubKeyData);
  Assert.assertEquals(PUBLIC_KEY, eosPK);
}
 
Example #6
Source File: types.java    From AndroidWallet with GNU General Public License v3.0 6 votes vote down vote up
public public_key_type(String strBase58) throws NoSuchAlgorithmException {
    String strPrefix = GRAPHENE_ADDRESS_PREFIX;
    byte[] byteKeyData = Base58.decode(strBase58.substring(strPrefix.length()));
    binary_key binaryKey = new binary_key(byteKeyData);

    RIPEMD160Digest digest = new RIPEMD160Digest();
    digest.update(binaryKey.data, 0, binaryKey.data.length);
    byte[] out = new byte[20];
    digest.doFinal(out, 0);

    byte[] byteOut = new byte[4];
    System.arraycopy(out, 0, byteOut, 0, byteOut.length);
    int nByteOut = ByteBuffer.wrap(byteOut).getInt();

    if (nByteOut != binaryKey.check) {
        throw new RuntimeException("Public key is not valid");
    }
    key_data = binaryKey.data;
}
 
Example #7
Source File: types.java    From AndroidWallet with GNU General Public License v3.0 6 votes vote down vote up
@Override
public String toString() {
    RIPEMD160Digest dig = new RIPEMD160Digest();
    dig.update(key_data, 0, key_data.length);
    byte[] out = new byte[20];
    dig.doFinal(out, 0);

    byte[] byteKeyData = new byte[37];
    System.arraycopy(key_data, 0, byteKeyData, 0, key_data.length);
    System.arraycopy(out, 0, byteKeyData, key_data.length, byteKeyData.length - key_data.length);

    String strResult = GRAPHENE_ADDRESS_PREFIX;
    strResult += Base58.encode(byteKeyData);

    return strResult;
}
 
Example #8
Source File: types.java    From AndroidWallet with GNU General Public License v3.0 5 votes vote down vote up
public private_key_type(String strBase58) throws KeyInvalideException, AddressFormatException {
    byte wif_bytes[] = Base58.decode(strBase58);

    if (wif_bytes.length < key_data.length) {
        throw new KeyInvalideException("Private key is not valid");
    }
    System.arraycopy(wif_bytes, 1, key_data, 0, key_data.length);
    SHA256Digest digest = new SHA256Digest();
    digest.update(wif_bytes, 0, wif_bytes.length - 4);
    byte[] hashCheck = new byte[32];
    digest.doFinal(hashCheck, 0);

    byte[] hashCheck2 = new byte[32];
    digest.update(hashCheck, 0, hashCheck.length);
    digest.doFinal(hashCheck2, 0);

    byte check[] = new byte[4];
    System.arraycopy(wif_bytes, wif_bytes.length - check.length, check, 0, check.length);

    byte[] check1 = new byte[4];
    byte[] check2 = new byte[4];
    System.arraycopy(hashCheck, 0, check1, 0, check1.length);
    System.arraycopy(hashCheck2, 0, check2, 0, check2.length);
    if (!Arrays.equals(check1, check) && !Arrays.equals(check2, check)) {
        throw new KeyInvalideException("Private key is not valid");
    }
}
 
Example #9
Source File: ZenCash.java    From bisq-assets with GNU Affero General Public License v3.0 5 votes vote down vote up
@Override
public AddressValidationResult validate(String address) {
    byte[] byteAddress;
    try {
        // Get the non Base58 form of the address and the bytecode of the first two bytes
        byteAddress = Base58.decodeChecked(address);
    } catch (AddressFormatException e) {
        // Unhandled Exception (probably a checksum error)
        return AddressValidationResult.invalidAddress(e);
    }
    int version0 = byteAddress[0] & 0xFF;
    int version1 = byteAddress[1] & 0xFF;

    // We only support public ("zn" (0x20,0x89), "t1" (0x1C,0xB8))
    // and multisig ("zs" (0x20,0x96), "t3" (0x1C,0xBD)) addresses

    // Fail for private addresses
    if (version0 == 0x16 && version1 == 0x9A)
        // Address starts with "zc"
        return AddressValidationResult.invalidAddress("", "validation.altcoin.zAddressesNotSupported");

    if (version0 == 0x1C && (version1 == 0xB8 || version1 == 0xBD))
        // "t1" or "t3" address
        return AddressValidationResult.validAddress();

    if (version0 == 0x20 && (version1 == 0x89 || version1 == 0x96))
        // "zn" or "zs" address
        return AddressValidationResult.validAddress();

    // Unknown Type
    return AddressValidationResult.invalidStructure();
}
 
Example #10
Source File: Utils.java    From evt4j with MIT License 5 votes vote down vote up
public static byte[] base58CheckDecode(String key, @Nullable String keyType) throws Base58CheckException {
    byte[] decoded;

    try {
        // base58 decode
        decoded = Base58.decode(key);
    } catch (AddressFormatException ex) {
        throw new Base58CheckException(ex.getMessage(), ex);
    }
    // split the byte slice
    byte[] data = ArrayUtils.subarray(decoded, 0, decoded.length - 4);
    byte[] checksum = ArrayUtils.subarray(decoded, decoded.length - 4, decoded.length);

    if (keyType != null) {
        data = ArrayUtils.addAll(data, keyType.getBytes());
    }

    // ripemd160 input, sign 4 bytes to compare
    byte[] hash = ripemd160(data);

    // if pass, return data, otherwise throw ex
    // compare two checksum
    boolean isEqual = true;

    for (int i = 0; i < checksum.length; i++) {
        if (hash[i] != checksum[i]) {
            isEqual = false;
        }
    }

    if (!isEqual) {
        throw new Base58CheckException();
    }

    if (keyType != null) {
        return ArrayUtils.subarray(data, 0, data.length - keyType.getBytes().length);
    }

    return data;
}
 
Example #11
Source File: EOSKey.java    From token-core-android with Apache License 2.0 5 votes vote down vote up
public String getPublicKeyAsHex() {
  ECKey ecKey = ECKey.fromPrivate(bytes);
  byte[] pubKeyData = ecKey.getPubKey();
  RIPEMD160Digest digest = new RIPEMD160Digest();
  digest.update(pubKeyData, 0, pubKeyData.length);
  byte[] out = new byte[20];
  digest.doFinal(out, 0);
  byte[] checksumBytes = Arrays.copyOfRange(out, 0, 4);

  pubKeyData = ByteUtil.concat(pubKeyData, checksumBytes);
  return "EOS" + Base58.encode(pubKeyData);
}
 
Example #12
Source File: Horizen.java    From bisq with GNU Affero General Public License v3.0 5 votes vote down vote up
@Override
public AddressValidationResult validate(String address) {
    byte[] byteAddress;
    try {
        // Get the non Base58 form of the address and the bytecode of the first two bytes
        byteAddress = Base58.decodeChecked(address);
    } catch (AddressFormatException e) {
        // Unhandled Exception (probably a checksum error)
        return AddressValidationResult.invalidAddress(e);
    }
    int version0 = byteAddress[0] & 0xFF;
    int version1 = byteAddress[1] & 0xFF;

    // We only support public ("zn" (0x20,0x89), "t1" (0x1C,0xB8))
    // and multisig ("zs" (0x20,0x96), "t3" (0x1C,0xBD)) addresses

    // Fail for private addresses
    if (version0 == 0x16 && version1 == 0x9A)
        // Address starts with "zc"
        return AddressValidationResult.invalidAddress("", "validation.altcoin.zAddressesNotSupported");

    if (version0 == 0x1C && (version1 == 0xB8 || version1 == 0xBD))
        // "t1" or "t3" address
        return AddressValidationResult.validAddress();

    if (version0 == 0x20 && (version1 == 0x89 || version1 == 0x96))
        // "zn" or "zs" address
        return AddressValidationResult.validAddress();

    // Unknown Type
    return AddressValidationResult.invalidStructure();
}
 
Example #13
Source File: EOSFormatter.java    From eosio-java with MIT License 5 votes vote down vote up
/**
 * Base58 encodes a private key after calculating and appending the checksum.
 *
 * @param pemKey -  Private key as byte[] to encode
 * @param keyType - input key type
 * @return Base58 encoded private key as byte[]
 * @throws Base58ManipulationError it private key encoding fails.
 */
@NotNull
public static String encodePrivateKey(@NotNull byte[] pemKey,
        @NotNull AlgorithmEmployed keyType) throws Base58ManipulationError {
    byte[] checkSum;
    String base58Key = "";

    switch (keyType) {
        case SECP256R1:
            checkSum = extractCheckSumRIPEMD160(pemKey,
                    SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
            break;
        case PRIME256V1:
            checkSum = extractCheckSumRIPEMD160(pemKey,
                    SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
            break;
        case SECP256K1:
            pemKey = Bytes.concat(new byte[]{((Integer) EOS_SECP256K1_HEADER_BYTE).byteValue()},
                    pemKey);
            checkSum = extractCheckSumSha256x2(pemKey);
            break;
        default:
            throw new Base58ManipulationError(ErrorConstants.CHECKSUM_GENERATION_ERROR);

    }

    base58Key = Base58.encode(Bytes.concat(pemKey, checkSum));

    if (base58Key.isEmpty()) {
        throw new Base58ManipulationError(ErrorConstants.BASE58_ENCODING_ERROR);
    } else {
        return base58Key;
    }

}
 
Example #14
Source File: Mile.java    From bisq with GNU Affero General Public License v3.0 5 votes vote down vote up
@Override
public AddressValidationResult validate(String address) {
    byte[] decoded;

    try {
        decoded = Base58.decode(address);
    } catch (AddressFormatException e) {
        return AddressValidationResult.invalidAddress(e.getMessage());
    }
    if (decoded.length != 32 + 4)
        return AddressValidationResult.invalidAddress("Invalid address");

    byte[] data = Arrays.copyOfRange(decoded, 0, decoded.length - 4);
    byte[] addrChecksum = Arrays.copyOfRange(decoded, decoded.length - 4, decoded.length);

    Checksum checksum = new CRC32();
    checksum.update(data, 0, data.length);
    long checksumValue = checksum.getValue();

    if ((byte)(checksumValue & 0xff) != addrChecksum[0] ||
            (byte)((checksumValue >> 8) & 0xff) != addrChecksum[1] ||
            (byte)((checksumValue >> 16) & 0xff) != addrChecksum[2] ||
            (byte)((checksumValue >> 24) & 0xff) != addrChecksum[3])
    {
        return AddressValidationResult.invalidAddress("Invalid address checksum");
    }

    return AddressValidationResult.validAddress();
}
 
Example #15
Source File: Ergo.java    From bisq with GNU Affero General Public License v3.0 5 votes vote down vote up
@Override
public AddressValidationResult validate(String address) {
    try {
        byte[] decoded  = Base58.decode(address);
        if (decoded.length < 4) {
            return AddressValidationResult.invalidAddress("Input too short: " + decoded.length);
        }
        if (decoded[0] != 1 && decoded[0] != 2 && decoded[0] != 3) {
            return AddressValidationResult.invalidAddress("Invalid prefix");
        }
    } catch (AddressFormatException e) {
        return AddressValidationResult.invalidAddress(e);
    }
    return AddressValidationResult.validAddress();
}
 
Example #16
Source File: MultiChainAddressGenerator.java    From polling-station-app with GNU Lesser General Public License v3.0 4 votes vote down vote up
/**
 * Converts a given public key to a valid MultiChain address.
 * See {@link <a href="http://www.multichain.com/developers/address-key-format/">MultiChain Documentation</a>}
 * @param pubKey byte array containing the public key
 * @return String representing the corresponding address.
 */
public static String getPublicAddress(String[] version, String addressChecksum, byte[] pubKey) {
    //Step 3
    MessageDigest digest;
    try {
        digest = MessageDigest.getInstance("SHA-256");
        digest.reset();
        byte[] hash = digest.digest(pubKey);

        //Step 4
        RIPEMD160Digest ripemd = new RIPEMD160Digest();
        ripemd.update(hash, 0, hash.length);
        byte[] out = new byte[20];
        ripemd.doFinal(out, 0);
        String hashStr = Util.byteArrayToHexString(out);

        //Step 5
        String step5 = "";
        if (BuildConfig.DEBUG && version.length != 4) throw new AssertionError("Version length != 4");
        for (int i = 0; i < 4; i++) { //Assumes version.length == 4
            step5 += version[i] + hashStr.substring((i*10),(i*10)+10);
        }
        digest.reset();

        //Step 6
        byte[] step6 = digest.digest(Util.hexStringToByteArray(step5));
        digest.reset();

        //Step 7
        byte[] step7 = digest.digest(step6);
        digest.reset();

        //Step 8
        byte[] checksum = new byte[]{ step7[0],step7[1],step7[2],step7[3] };

        //Step 9
        byte[] byteAddressChecksum = Util.hexStringToByteArray(addressChecksum);
        byte[] xor = new byte[4];
        for (int i = 0; i < 4; i++) {
            int xorvalue = (int)checksum[i] ^ (int)byteAddressChecksum[i];
            xor[i] = (byte)(0xff & xorvalue);
        }

        //Step 10
        String addressbytes = step5 + Util.byteArrayToHexString(xor);

        //Step 11
        String address = Base58.encode(Util.hexStringToByteArray(addressbytes));
        return address;
    } catch (NoSuchAlgorithmException e1) {
        e1.printStackTrace();
        return null;
    }
}
 
Example #17
Source File: Util.java    From zencash-swing-wallet-ui with MIT License 4 votes vote down vote up
public static String wifToHex(String wifKey) throws Exception {
        byte[] bytes = Base58.decode(wifKey);
        String pk = Util.encodeHexArray(bytes);
        pk = pk.substring(2, pk.length() - 10);
        return pk;
}
 
Example #18
Source File: BIP32Test.java    From GreenBits with GNU General Public License v3.0 4 votes vote down vote up
private String testEncode(String what) {
    return HEX.encode(Base58.decodeChecked(what));
}
 
Example #19
Source File: Multihash.java    From token-core-android with Apache License 2.0 4 votes vote down vote up
public static Multihash fromBase58(String base58) {
  return new Multihash(Base58.decode(base58));
}
 
Example #20
Source File: BIP32Test.java    From green_android with GNU General Public License v3.0 4 votes vote down vote up
private String testEncode(String what) {
    return HEX.encode(Base58.decodeChecked(what));
}
 
Example #21
Source File: IdentityKeystore.java    From token-core-android with Apache License 2.0 4 votes vote down vote up
public IdentityKeystore(Metadata metadata, List<String> mnemonicCodes, String password) {
  MnemonicUtil.validateMnemonics(mnemonicCodes);

  DeterministicSeed seed = new DeterministicSeed(mnemonicCodes, null, "", 0L);

  DeterministicKey masterPrivateKey = HDKeyDerivation.createMasterPrivateKey(seed.getSeedBytes());
  byte[] masterKey = masterPrivateKey.getPrivKeyBytes();

  String salt = metadata.isMainNet() ? "Automatic Backup Key Mainnet" : "Automatic Backup Key Testnet";
  byte[] backupKey = Hash.hmacSHA256(masterKey, salt.getBytes(Charset.forName("ASCII")));
  byte[] authenticationKey = Hash.hmacSHA256(backupKey, "Authentication Key".getBytes(Charset.forName("UTF-8")));
  ECKey authKey = ECKey.fromPrivate(authenticationKey);

  NetworkParameters networkParameters = metadata.isMainNet() ? MainNetParams.get() : TestNet3Params.get();

  String aPubHashHex = NumericUtil.bytesToHex(authKey.getPubKeyHash());
  int networkHeader = networkParameters.getAddressHeader();
  int version = 2;
  // this magic hex will start with 'im' after base58check
  String magicHex = "0fdc0c";
  String fullIdentifier = String.format("%s%02x%02x%s", magicHex, (byte) networkHeader, (byte) version, aPubHashHex);
  byte[] fullIdentifierBytes = NumericUtil.hexToBytes(fullIdentifier);
  byte[] checksumBytes = Arrays.copyOfRange(Sha256Hash.hashTwice(fullIdentifierBytes), 0, 4);
  byte[] identifierWithChecksum = ByteUtil.concat(fullIdentifierBytes, checksumBytes);
  this.identifier = Base58.encode(identifierWithChecksum);

  byte[] encKeyFullBytes = Hash.hmacSHA256(backupKey, "Encryption Key".getBytes(Charset.forName("UTF-8")));
  this.encKey = NumericUtil.bytesToHex(encKeyFullBytes);

  ECKey ecKey = ECKey.fromPrivate(encKeyFullBytes, false);
  this.ipfsId = new Multihash(Multihash.Type.sha2_256, Hash.sha256(ecKey.getPubKey())).toBase58();
  Crypto crypto = Crypto.createPBKDF2CryptoWithKDFCached(password, masterPrivateKey.serializePrivB58(networkParameters).getBytes(Charset.forName("UTF-8")));

  this.encAuthKey = crypto.deriveEncPair(password, authenticationKey);
  this.encMnemonic = crypto.deriveEncPair(password, Joiner.on(" ").join(mnemonicCodes).getBytes());
  crypto.clearCachedDerivedKey();
  metadata.setTimestamp(DateUtil.getUTCTime());

  metadata.setSegWit(null);
  this.metadata = metadata;
  this.crypto = crypto;

  this.version = VERSION;
  this.walletIDs = new ArrayList<>();
}
 
Example #22
Source File: EOSFormatter.java    From eosio-java with MIT License 4 votes vote down vote up
/**
 * This method converts a signature to a EOS compliant form.  The signature to be converted must
 * be an The ECDSA signature that is a DER encoded ASN.1 sequence of two integer fields (see
 * ECDSA-Sig-Value in rfc3279 section 2.2.3).
 *
 * The DER encoded ECDSA signature follows the following format: Byte 1 - Sequence (Should be
 * 30) Byte 2 - Signature length Byte 3 - R Marker (0x02) Byte 4 - R length Bytes 5 to 37 or 38-
 * R Byte After R - S Marker (0x02) Byte After S Marker - S Length Bytes After S Length - S
 * (always 32-33 bytes) Byte Final - Hash Type
 *
 * @param signatureDER ECDSA DER encoded signature as byte array
 * @param signableTransaction Transaction in signable format
 * @param publicKeyPEM public key in PEM format
 * @return EOS format of signature
 * @throws EOSFormatterError if DER conversion to EOS format fails.
 */
@NotNull
public static String convertDERSignatureToEOSFormat(@NotNull byte[] signatureDER,
        @NotNull byte[] signableTransaction, @NotNull String publicKeyPEM)
        throws EOSFormatterError {
    String eosFormattedSignature = "";

    try (ASN1InputStream asn1InputStream = new ASN1InputStream(signatureDER)) {

        PEMProcessor publicKey = new PEMProcessor(publicKeyPEM);
        AlgorithmEmployed algorithmEmployed = publicKey.getAlgorithm();
        byte[] keyData = publicKey.getKeyData();
        DLSequence sequence = (DLSequence) asn1InputStream.readObject();
        BigInteger r = ((ASN1Integer) sequence.getObjectAt(0)).getPositiveValue();
        BigInteger s = ((ASN1Integer) sequence.getObjectAt(1)).getPositiveValue();

        s = checkAndHandleLowS(s, algorithmEmployed);

        /*
        Get recovery ID.  This is the index of the public key (0-3) that represents the
        expected public key used to sign the transaction.
         */
        int recoverId = getRecoveryId(r, s, Sha256Hash.of(signableTransaction), keyData,
                algorithmEmployed);

        if (recoverId < 0) {
            throw new IllegalStateException(
                    ErrorConstants.COULD_NOT_RECOVER_PUBLIC_KEY_FROM_SIG);
        }

        //Add RecoveryID + 27 + 4 to create the header byte
        recoverId += VALUE_TO_ADD_TO_SIGNATURE_HEADER;
        byte headerByte = ((Integer) recoverId).byteValue();



        byte[] decodedSignature = Bytes
                .concat(new byte[]{headerByte}, org.bitcoinj.core.Utils.bigIntegerToBytes(r,EXPECTED_R_OR_S_LENGTH), org.bitcoinj.core.Utils.bigIntegerToBytes(s,EXPECTED_R_OR_S_LENGTH));
        if (algorithmEmployed.equals(AlgorithmEmployed.SECP256K1) &&
                !isCanonical(decodedSignature)) {
            throw new IllegalArgumentException(ErrorConstants.NON_CANONICAL_SIGNATURE);
        }

        //Add checksum to signature
        byte[] signatureWithCheckSum;
        String signaturePrefix;
        switch (algorithmEmployed) {
            case SECP256R1:
                signatureWithCheckSum = addCheckSumToSignature(decodedSignature,
                        SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                signaturePrefix = PATTERN_STRING_EOS_PREFIX_SIG_R1;
                break;
            case SECP256K1:
                signatureWithCheckSum = addCheckSumToSignature(decodedSignature,
                        SECP256K1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                signaturePrefix = PATTERN_STRING_EOS_PREFIX_SIG_K1;
                break;
            default:
                throw new EOSFormatterError(ErrorConstants.UNSUPPORTED_ALGORITHM);

        }

        //Base58 encode signature and add pertinent EOS prefix
        eosFormattedSignature = signaturePrefix.concat(Base58.encode(signatureWithCheckSum));

    } catch (Exception e) {
        throw new EOSFormatterError(ErrorConstants.SIGNATURE_FORMATTING_ERROR, e);
    }

    return eosFormattedSignature;
}
 
Example #23
Source File: Multihash.java    From token-core-android with Apache License 2.0 4 votes vote down vote up
public String toBase58() {
  return Base58.encode(toBytes());
}
 
Example #24
Source File: BIP32Test.java    From bcm-android with GNU General Public License v3.0 4 votes vote down vote up
private String testEncode(String what) {
    return HEX.encode(Base58.decodeChecked(what));
}
 
Example #25
Source File: BIP38PrivateKeyTest.java    From bcm-android with GNU General Public License v3.0 4 votes vote down vote up
@Test(expected = AddressFormatException.InvalidDataLength.class)
public void fromBase58_invalidLength() {
    String base58 = Base58.encodeChecked(1, new byte[16]);
    BIP38PrivateKey.fromBase58(null, base58);
}
 
Example #26
Source File: EOSFormatter.java    From eosio-java with MIT License 4 votes vote down vote up
/**
 * Base58 decodes a public key and validates checksum.
 *
 * @param strKey Base58 encoded public key in string format.
 * @param keyPrefix EOS specific key type prefix (i.e. PUB_R1_, PUB_K1_, or EOS).
 * @return Base58 decoded public key as byte[]
 * @throws Base58ManipulationError if public key decoding fails.
 */
@NotNull
public static byte[] decodePublicKey(@NotNull String strKey, String keyPrefix)
        throws Base58ManipulationError {
    if (strKey.isEmpty()) {
        throw new IllegalArgumentException("Input key to decode can't be empty.");
    }

    byte[] decodedKey = null;

    try {
        byte[] base58Decoded = Base58.decode(strKey);
        byte[] firstCheckSum = Arrays
                .copyOfRange(base58Decoded, base58Decoded.length - CHECKSUM_BYTES,
                        base58Decoded.length);
        decodedKey = Arrays
                .copyOfRange(base58Decoded, 0, base58Decoded.length - CHECKSUM_BYTES);

        switch (keyPrefix) {
            case PATTERN_STRING_EOS_PREFIX_PUB_R1:
                if (invalidRipeMD160CheckSum(decodedKey, firstCheckSum,
                        SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes())) {
                    throw new IllegalArgumentException(
                            ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;

            case PATTERN_STRING_EOS_PREFIX_PUB_K1:
                if (invalidRipeMD160CheckSum(decodedKey, firstCheckSum,
                        SECP256K1_CHECKSUM_VALIDATION_SUFFIX.getBytes())) {
                    throw new IllegalArgumentException(
                            ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;

            case PATTERN_STRING_EOS_PREFIX_EOS:
                if (invalidRipeMD160CheckSum(decodedKey, firstCheckSum,
                        LEGACY_CHECKSUM_VALIDATION_SUFFIX.getBytes())) {
                    throw new IllegalArgumentException(
                            ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;

            default:
                break;
        }

    } catch (Exception ex) {
        throw new Base58ManipulationError(ErrorConstants.BASE58_DECODING_ERROR, ex);
    }

    return decodedKey;
}
 
Example #27
Source File: EOSFormatter.java    From eosio-java with MIT License 4 votes vote down vote up
/**
 * Encoding PEM public key to EOS format.
 *
 * @param pemKey -  PEM key as byte[] to encode
 * @param keyType - Algorithm type used to create key
 * @param isLegacy - If the developer prefers a legacy version of a secp256k1 key that uses an
 * "EOS" prefix.
 * @return - EOS format of public key
 * @throws Base58ManipulationError if public key encoding fails.
 */
@NotNull
public static String encodePublicKey(@NotNull byte[] pemKey, @NotNull AlgorithmEmployed keyType,
        boolean isLegacy)
        throws Base58ManipulationError {
    String base58Key = "";
    if (pemKey.length == 0) {
        throw new IllegalArgumentException(ErrorConstants.PUBLIC_KEY_IS_EMPTY);
    }

    try {
        byte[] checkSum;
        switch (keyType) {
            case SECP256K1:
                if (isLegacy) {
                    checkSum = extractCheckSumRIPEMD160(pemKey,
                            LEGACY_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                } else {
                    checkSum = extractCheckSumRIPEMD160(pemKey,
                            SECP256K1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                }
                break;
            case SECP256R1:
                checkSum = extractCheckSumRIPEMD160(pemKey,
                        SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                break;
            default:
                throw new Base58ManipulationError(ErrorConstants.UNSUPPORTED_ALGORITHM);

        }

        base58Key = Base58.encode(Bytes.concat(pemKey, checkSum));

        if (base58Key.equals("")) {
            throw new Base58ManipulationError(ErrorConstants.BASE58_ENCODING_ERROR);
        }

    } catch (Exception ex) {
        throw new Base58ManipulationError(ErrorConstants.BASE58_ENCODING_ERROR, ex);
    }

    //Add prefix
    StringBuilder builder = new StringBuilder(base58Key);
    switch (keyType) {
        case SECP256K1:
            if (isLegacy) {
                builder.insert(0, PATTERN_STRING_EOS_PREFIX_EOS);
            } else {
                builder.insert(0, PATTERN_STRING_EOS_PREFIX_PUB_K1);
            }
            break;
        case SECP256R1:
            builder.insert(0, PATTERN_STRING_EOS_PREFIX_PUB_R1);
            break;
        default:
            break;
    }
    base58Key = builder.toString();

    return base58Key;
}
 
Example #28
Source File: EOSFormatter.java    From eosio-java with MIT License 4 votes vote down vote up
/**
 * This method Base58 decodes the private key and validates its checksum.
 *
 * @param strKey Base58 value of the key
 * @param keyType key type
 * @return Base58 decoded key minus checksum
 * @throws Base58ManipulationError if private key decoding fails.
 */
@NotNull
private static byte[] decodePrivateKey(@NotNull String strKey, AlgorithmEmployed keyType)
        throws Base58ManipulationError {
    if (strKey.isEmpty()) {
        throw new IllegalArgumentException(ErrorConstants.BASE58_EMPTY_KEY);
    }

    byte[] decodedKey;

    try {
        byte[] base58Decoded = Base58.decode(strKey);
        byte[] firstCheckSum = Arrays
                .copyOfRange(base58Decoded, base58Decoded.length - CHECKSUM_BYTES,
                        base58Decoded.length);
        decodedKey = Arrays
                .copyOfRange(base58Decoded, 0, base58Decoded.length - CHECKSUM_BYTES);

        switch (keyType) {
            case SECP256R1:
                byte[] secp256r1Suffix = SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX
                        .getBytes();
                if (invalidRipeMD160CheckSum(decodedKey, firstCheckSum, secp256r1Suffix)) {
                    throw new IllegalArgumentException(ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;
            case PRIME256V1:
                byte[] prime256v1Suffix = SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX
                        .getBytes();
                if (invalidRipeMD160CheckSum(decodedKey, firstCheckSum, prime256v1Suffix)) {
                    throw new IllegalArgumentException(ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;
            case SECP256K1:
                if (invalidSha256x2CheckSum(decodedKey, firstCheckSum)) {
                    throw new IllegalArgumentException(ErrorConstants.BASE58_INVALID_CHECKSUM);
                }
                break;
            default:
                throw new Base58ManipulationError(ErrorConstants.UNSUPPORTED_ALGORITHM);

        }

        // trim 0x80 out if the key size is more than 32 bytes
        // this code apply for key has more than 32 byte and non R1 key
        if (decodedKey.length > STANDARD_KEY_LENGTH && keyType != AlgorithmEmployed.SECP256R1) {
            // Slice out the first byte
            decodedKey = Arrays.copyOfRange(decodedKey, 1, decodedKey.length);
            if (decodedKey.length > STANDARD_KEY_LENGTH
                    && decodedKey[STANDARD_KEY_LENGTH] == ((Integer) 1).byteValue()) {
                // Slice out last byte
                decodedKey = Arrays.copyOfRange(decodedKey, 0, decodedKey.length - 1);
            }
        }
    } catch (Exception ex) {
        throw new Base58ManipulationError(ErrorConstants.BASE58_DECODING_ERROR, ex);
    }

    return decodedKey;
}
 
Example #29
Source File: EOSFormatter.java    From eosio-java with MIT License 4 votes vote down vote up
/**
 * This method converts a signature to a EOS compliant form.  The signature to be converted must
 * be an The ECDSA signature that is a DER encoded ASN.1 sequence of two integer fields (see
 * ECDSA-Sig-Value in rfc3279 section 2.2.3).  This method should be used when only the R and S
 * values of the signature are available.
 *
 * The DER encoded ECDSA signature follows the following format: Byte 1 - Sequence (Should be
 * 30) Byte 2 - Signature length Byte 3 - R Marker (0x02) Byte 4 - R length Bytes 5 to 37 or 38-
 * R Byte After R - S Marker (0x02) Byte After S Marker - S Length Bytes After S Length - S
 * (always 32-33 bytes) Byte Final - Hash Type
 *
 * @param signatureR R value as BigInteger in string format
 * @param signatureS S value as BigInteger in string format
 * @param signableTransaction Transaction in signable format
 * @param publicKeyPEM Public Key used to sign in PEM format
 * @return EOS format of signature
 * @throws EOSFormatterError if conversion to EOS format fails.
 */
@NotNull
public static String convertRawRandSofSignatureToEOSFormat(@NotNull String signatureR,
        String signatureS,
        @NotNull byte[] signableTransaction, @NotNull String publicKeyPEM)
        throws EOSFormatterError {
    String eosFormattedSignature = "";

    try {
        PEMProcessor publicKey = new PEMProcessor(publicKeyPEM);
        AlgorithmEmployed algorithmEmployed = publicKey.getAlgorithm();
        byte[] keyData = publicKey.getKeyData();

        BigInteger r = new BigInteger(signatureR);
        BigInteger s = new BigInteger(signatureS);

        s = checkAndHandleLowS(s, algorithmEmployed);

        /*
        Get recovery ID.  This is the index of the public key (0-3) that represents the
        expected public key used to sign the transaction.
         */
        int recoverId = getRecoveryId(r, s, Sha256Hash.of(signableTransaction), keyData,
                algorithmEmployed);

        if (recoverId < 0) {
            throw new IllegalStateException(
                    ErrorConstants.COULD_NOT_RECOVER_PUBLIC_KEY_FROM_SIG);
        }

        //Add RecoveryID + 27 + 4 to create the header byte
        recoverId += VALUE_TO_ADD_TO_SIGNATURE_HEADER;
        byte headerByte = ((Integer) recoverId).byteValue();

        byte[] decodedSignature = Bytes
                .concat(new byte[]{headerByte}, org.bitcoinj.core.Utils.bigIntegerToBytes(r,EXPECTED_R_OR_S_LENGTH), org.bitcoinj.core.Utils.bigIntegerToBytes(s,EXPECTED_R_OR_S_LENGTH));
        if (algorithmEmployed.equals(AlgorithmEmployed.SECP256K1) &&
                !isCanonical(decodedSignature)) {
            throw new EosFormatterSignatureIsNotCanonicalError(ErrorConstants.NON_CANONICAL_SIGNATURE);
        }

        //Add checksum to signature
        byte[] signatureWithCheckSum;
        String signaturePrefix;
        switch (algorithmEmployed) {
            case SECP256R1:
                signatureWithCheckSum = addCheckSumToSignature(decodedSignature,
                        SECP256R1_AND_PRIME256V1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                signaturePrefix = PATTERN_STRING_EOS_PREFIX_SIG_R1;
                break;
            case SECP256K1:
                signatureWithCheckSum = addCheckSumToSignature(decodedSignature,
                        SECP256K1_CHECKSUM_VALIDATION_SUFFIX.getBytes());
                signaturePrefix = PATTERN_STRING_EOS_PREFIX_SIG_K1;
                break;
            default:
                throw new EOSFormatterError(ErrorConstants.UNSUPPORTED_ALGORITHM);

        }

        //Base58 encode signature and add pertinent EOS prefix
        eosFormattedSignature = signaturePrefix.concat(Base58.encode(signatureWithCheckSum));

    } catch (Exception e) {
        throw new EOSFormatterError(ErrorConstants.SIGNATURE_FORMATTING_ERROR, e);
    }

    return eosFormattedSignature;
}