All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.knowm.xchange.bitcoinde.service.BitcoindeDigest Maven / Gradle / Ivy

package org.knowm.xchange.bitcoinde.service;

import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import javax.crypto.Mac;
import org.knowm.xchange.service.BaseParamsDigest;
import si.mazi.rescu.RestInvocation;

/**
 * @author kaiserfr
 */
public class BitcoindeDigest extends BaseParamsDigest {
  private final String apiKey;

  /**
   * Constructor
   *
   * @param secretKeyBase64
   * @param apiKey
   * @throws IllegalArgumentException if key is invalid (cannot be base-64-decoded or the decoded
   *     key is invalid).
   */
  private BitcoindeDigest(String secretKeyBase64, String apiKey) {
    super(secretKeyBase64, HMAC_SHA_256);
    this.apiKey = apiKey;
  }

  public static BitcoindeDigest createInstance(String secretKeyBase64, String apiKey) {

    return secretKeyBase64 == null ? null : new BitcoindeDigest(secretKeyBase64, apiKey);
  }

  @Override
  public String digestParams(RestInvocation restInvocation) {

    // Step 1: concatenate URL with query string
    String completeURL = restInvocation.getInvocationUrl();

    // Step 2: create md5-Hash of the POST-Parameters for the HMAC-data
    String httpMethod = restInvocation.getHttpMethod();
    String requestBody = restInvocation.getRequestBody();

    String md5;
    if ("POST".equals(httpMethod)) {
      md5 = getMD5(requestBody);
    } else {
      md5 = "d41d8cd98f00b204e9800998ecf8427e"; // no post params for GET methods
    }

    // Step 3: concat HMAC-input

    // http_method+'#'+uri+'#'+api_key+'#'+nonce+'#'+post_parameter_md5_hashed_url_encoded_query_string
    String nonce = restInvocation.getHttpHeadersFromParams().get("X-API-NONCE");
    String hmac_data = String.format("%s#%s#%s#%s#%s", httpMethod, completeURL, apiKey, nonce, md5);

    // Step 3: Create actual sha256-HMAC
    Mac mac256 = getMac();
    mac256.update(hmac_data.getBytes());

    return String.format("%064x", new BigInteger(1, mac256.doFinal()));
  }

  private String getMD5(String original) {
    MessageDigest md = null;
    try {
      md = MessageDigest.getInstance("MD5");
    } catch (NoSuchAlgorithmException e) {
      e.printStackTrace();
    }
    md.update(original.getBytes());
    byte[] digest = md.digest();
    StringBuffer sb = new StringBuffer();
    for (byte b : digest) {
      sb.append(String.format("%02x", b & 0xff));
    }
    return sb.toString();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy