Sample code for 30+ languages & platforms
Java

Get E-way Bill System Access Token

See more HTTP Misc Examples

Sends a request to get an E-way bill system access token.

Chilkat Java Downloads

Java
import com.chilkatsoft.*;

public class ChilkatExample {

  static {
    try {
        System.loadLibrary("chilkat");
    } catch (UnsatisfiedLinkError e) {
      System.err.println("Native code library failed to load.\n" + e);
      System.exit(1);
    }
  }

  public static void main(String argv[])
  {
    boolean success = false;

    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    // First load the public key provided by the E-way bill System
    CkPublicKey pubkey = new CkPublicKey();
    success = pubkey.LoadFromFile("qa_data/pem/eway_publickey.pem");
    if (success == false) {
        System.out.println(pubkey.lastErrorText());
        return;
        }

    // Encrypt the password using the RSA public key provided by eway..
    String password = "my_wepgst_password";
    CkRsa rsa = new CkRsa();
    rsa.put_Charset("utf-8");
    rsa.put_EncodingMode("base64");

    success = rsa.UsePublicKey(pubkey);
    if (success == false) {
        System.out.println(rsa.lastErrorText());
        return;
        }

    // Returns the encrypted password as base64 (because the EncodingMode = "base64")
    String encPassword = rsa.encryptStringENC(password,false);
    if (rsa.get_LastMethodSuccess() == false) {
        System.out.println(rsa.lastErrorText());
        return;
        }

    // Generate a random app_key.  This should be 32 bytes (us-ascii chars)
    // We need 32 bytes because we'll be doing 256-bit AES ECB encryption, and 32 bytes = 256 bits.
    CkPrng prng = new CkPrng();
    // Generate a random string containing some numbers, uppercase, and lowercase.
    String app_key = prng.randomString(32,true,true,true);

    System.out.println("app_key = " + app_key);

    // RSA encrypt the app_key.
    String encAppKey = rsa.encryptStringENC(app_key,false);
    if (rsa.get_LastMethodSuccess() == false) {
        System.out.println(rsa.lastErrorText());
        return;
        }

    // Prepare the JSON body for the HTTP POST that gets the access token.
    CkJsonObject jsonBody = new CkJsonObject();
    jsonBody.UpdateString("action","ACCESSTOKEN");
    // Use your username instead of "09ABDC24212B1FK".
    jsonBody.UpdateString("username","09ABDC24212B1FK");
    jsonBody.UpdateString("password",encPassword);
    jsonBody.UpdateString("app_key",encAppKey);

    CkHttp http = new CkHttp();

    // Add required headers.
    // Use your ewb-user-id instead of "03AEXPR16A9M010"
    http.SetRequestHeader("ewb-user-id","03AEXPR16A9M010");
    // The Gstin should be the same as the username in the jsonBody above.
    http.SetRequestHeader("Gstin","09ABDC24212B1FK");
    http.put_Accept("application/json");

    // POST the JSON...
    CkHttpResponse resp = new CkHttpResponse();
    success = http.HttpJson("POST","http://ewb.wepgst.com/api/Authenticate",jsonBody,"application/json",resp);
    if (success == false) {
        System.out.println(http.lastErrorText());
        return;
        }

    int respStatusCode = resp.get_StatusCode();
    System.out.println("response status code =" + respStatusCode);
    System.out.println("response body:");
    System.out.println(resp.bodyStr());

    if (respStatusCode != 200) {
        System.out.println("Failed in some unknown way.");
        return;
        }

    // When the response status code = 200, we'll have either
    // success response like this:
    //  {"status":"1","authtoken":"...","sek":"..."}
    // 
    // or a failed response like this:
    // 
    // {"status":"0","error":"eyJlcnJvckNvZGVzIjoiMTA4In0="}

    // Load the response body into a JSON object.
    CkJsonObject json = new CkJsonObject();
    json.Load(resp.bodyStr());

    int status = json.IntOf("status");
    System.out.println("status = " + status);

    if (status != 1) {
        // Failed.  Base64 decode the error
        // {"status":"0","error":"eyJlcnJvckNvZGVzIjoiMTA4In0="}
        // For an invalid password, the error is: {"errorCodes":"108"}
        CkStringBuilder sbError = new CkStringBuilder();
        json.StringOfSb("error",sbError);
        sbError.Decode("base64","utf-8");
        System.out.println("error: " + sbError.getAsString());
        return;
        }

    // At this point, we know the request was entirely successful.
    String authToken = json.stringOf("authtoken");

    // Decrypt the sek key using our app_key.
    CkCrypt2 crypt = new CkCrypt2();
    crypt.put_CryptAlgorithm("aes");
    crypt.put_CipherMode("ecb");
    crypt.put_KeyLength(256);
    crypt.SetEncodedKey(app_key,"us-ascii");
    crypt.put_EncodingMode("base64");

    CkBinData bdSek = new CkBinData();
    bdSek.AppendEncoded(json.stringOf("sek"),"base64");
    crypt.DecryptBd(bdSek);

    // bdSek now contains the decrypted symmetric encryption key...
    // We'll use it to encrypt the JSON payloads we send.

    // Let's persist our authtoken and decrypted sek (symmetric encryption key).
    // To send EWAY requests (such as to create an e-way bill), we'll just load 
    // and use these pre-obtained credentials.
    CkJsonObject jsonEwayAuth = new CkJsonObject();
    jsonEwayAuth.UpdateString("authToken",authToken);
    jsonEwayAuth.UpdateString("decryptedSek",bdSek.getEncoded("base64"));
    jsonEwayAuth.put_EmitCompact(false);

    CkFileAccess fac = new CkFileAccess();
    fac.WriteEntireTextFile("qa_data/tokens/ewayAuth.json",jsonEwayAuth.emit(),"utf-8",false);

    System.out.println("Saved:");
    System.out.println(jsonEwayAuth.emit());

    // Sample output:
    // {
    //   "authToken": "IBTeFtxNfVurg71LTzZ2r0xK7",
    //   "decryptedSek": "5g1TyTie7yoslU3DrbYATa7mWyPazlODE7cEh5Vy4Ho="
    // 
  }
}