"1911",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "LHV",
        "VK_REC_ID"      => "uid100049",
        "VK_STAMP"       => "66342",
        "VK_REF"         => "663421",
        "VK_MSG"         => "Order nr. 66342",
        "VK_ENCODING"    => "UTF-8",
        "VK_LANG"        => "EST",
        "VK_MAC"         => "UzbIEUfibrs8Jdwe38thB0qhqk270SLiDlGatCXrlDFH6Cc2Hq3BoIsyOcqlmOPkICnMBms7LsiwKICw9YndSZy9a2gz8//7zTdh7nL3mWQLx2Wz/sbIaPAgxhXBx1UgtaMhqKtUN7MBCP9RspdniBqwSN6hAPo1zINE2InvFC1ojivKgYwjz2bl9lotK9SVgozRFZYGVFJ3byYjIoSUDq+PhyVVTL/nD7JKEm8LEfMWnRZBI/Jl/n76un9jFosF4Op0+024L/KSTZHXx4RbkPNqwZGXcX3IbKYcdDq8Bo3gljOtL6nzJMEd92hqWkg+SZMM1Pw2Z2cs4hNNx3YexQ==",
        "VK_AUTO"        => "N"
);
// STEP 3. Generate data to be verified
// ====================================
// Data to be verified is in the form of XXXYYYYY where XXX is 3 char
// zero padded length of the value and YYY the value itself
// NB! LHV expects symbol count, not byte count with UTF-8,
// so use `mb_strlen` instead of `strlen` to detect the length of a string
$data = str_pad (mb_strlen($fields["VK_SERVICE"], "UTF-8"),   3, "0", STR_PAD_LEFT) . $fields["VK_SERVICE"] .    /* 1911 */
        str_pad (mb_strlen($fields["VK_VERSION"], "UTF-8"),   3, "0", STR_PAD_LEFT) . $fields["VK_VERSION"] .    /* 008 */
        str_pad (mb_strlen($fields["VK_SND_ID"], "UTF-8"),    3, "0", STR_PAD_LEFT) . $fields["VK_SND_ID"] .     /* LHV */
        str_pad (mb_strlen($fields["VK_REC_ID"], "UTF-8"),    3, "0", STR_PAD_LEFT) . $fields["VK_REC_ID"] .     /* uid100049 */
        str_pad (mb_strlen($fields["VK_STAMP"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_STAMP"] .      /* 66342 */
        str_pad (mb_strlen($fields["VK_REF"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_REF"] .        /* 663421 */
        str_pad (mb_strlen($fields["VK_MSG"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_MSG"];         /* Order nr. 66342 */
/* $data = "0041911003008003LHV009uid10004900566342006663421015Order nr. 66342"; */
// STEP 4. Verify the data with RSA-SHA1
// =====================================
if (openssl_verify ($data, base64_decode($fields["VK_MAC"]), $public_key) !== 1) {
    $signatureVerified = false;
}else{
    $signatureVerified = true;
}
// STEP 5. Display output of the received payment
// ==============================================
?>
    Payment results
    Payment: 
    Signature: