Sample code for 30+ languages & platforms
Perl

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 Perl Downloads

Perl
use chilkat();

$success = 0;

# 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
$pubkey = chilkat::CkPublicKey->new();
$success = $pubkey->LoadFromFile("qa_data/pem/eway_publickey.pem");
if ($success == 0) {
    print $pubkey->lastErrorText() . "\r\n";
    exit;
}

# Encrypt the password using the RSA public key provided by eway..
$password = "my_wepgst_password";
$rsa = chilkat::CkRsa->new();
$rsa->put_Charset("utf-8");
$rsa->put_EncodingMode("base64");

$success = $rsa->UsePublicKey($pubkey);
if ($success == 0) {
    print $rsa->lastErrorText() . "\r\n";
    exit;
}

# Returns the encrypted password as base64 (because the EncodingMode = "base64")
$encPassword = $rsa->encryptStringENC($password,0);
if ($rsa->get_LastMethodSuccess() == 0) {
    print $rsa->lastErrorText() . "\r\n";
    exit;
}

# 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.
$prng = chilkat::CkPrng->new();
# Generate a random string containing some numbers, uppercase, and lowercase.
$app_key = $prng->randomString(32,1,1,1);

print "app_key = " . $app_key . "\r\n";

# RSA encrypt the app_key.
$encAppKey = $rsa->encryptStringENC($app_key,0);
if ($rsa->get_LastMethodSuccess() == 0) {
    print $rsa->lastErrorText() . "\r\n";
    exit;
}

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

$http = chilkat::CkHttp->new();

# 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...
$resp = chilkat::CkHttpResponse->new();
$success = $http->HttpJson("POST","http://ewb.wepgst.com/api/Authenticate",$jsonBody,"application/json",$resp);
if ($success == 0) {
    print $http->lastErrorText() . "\r\n";
    exit;
}

$respStatusCode = $resp->get_StatusCode();
print "response status code =" . $respStatusCode . "\r\n";
print "response body:" . "\r\n";
print $resp->bodyStr() . "\r\n";

if ($respStatusCode != 200) {
    print "Failed in some unknown way." . "\r\n";
    exit;
}

# 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.
$json = chilkat::CkJsonObject->new();
$json->Load($resp->bodyStr());

$status = $json->IntOf("status");
print "status = " . $status . "\r\n";

if ($status != 1) {
    # Failed.  Base64 decode the error
    # {"status":"0","error":"eyJlcnJvckNvZGVzIjoiMTA4In0="}
    # For an invalid password, the error is: {"errorCodes":"108"}
    $sbError = chilkat::CkStringBuilder->new();
    $json->StringOfSb("error",$sbError);
    $sbError->Decode("base64","utf-8");
    print "error: " . $sbError->getAsString() . "\r\n";
    exit;
}

# At this point, we know the request was entirely successful.
$authToken = $json->stringOf("authtoken");

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

$bdSek = chilkat::CkBinData->new();
$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.
$jsonEwayAuth = chilkat::CkJsonObject->new();
$jsonEwayAuth->UpdateString("authToken",$authToken);
$jsonEwayAuth->UpdateString("decryptedSek",$bdSek->getEncoded("base64"));
$jsonEwayAuth->put_EmitCompact(0);

$fac = chilkat::CkFileAccess->new();
$fac->WriteEntireTextFile("qa_data/tokens/ewayAuth.json",$jsonEwayAuth->emit(),"utf-8",0);

print "Saved:" . "\r\n";
print $jsonEwayAuth->emit() . "\r\n";

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