"1911",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "LHV",
        "VK_REC_ID"      => "uid100049",
        "VK_STAMP"       => "67272",
        "VK_REF"         => "672726",
        "VK_MSG"         => "Order nr. 67272",
        "VK_ENCODING"    => "UTF-8",
        "VK_LANG"        => "EST",
        "VK_MAC"         => "ugdwsYG3ZDMX3URxdFRudYmtEMS8CNoTdOQNCre7RHIfy+wBfHSdZYMrmVfgdybj0VC6nMPzuLhpBWzv/BpaaT0B0CEiWQWxuFTd4M4eI35hUs9uFgNxPMctmC5/safhW7c0KLdC7LnSPeN3gaxbPEUMzRLzlBMynd3HrdcKAADwvuPs2eMGtRH3HYzehudtzXOfqKGaZwYs/XdNjDW/6jaAMWkNDZge4mzD8gXuN1ZdQPTo/sC+hmxBSBaQUhn3XTYGGbLVCW2CcjfbaqxrRcj1E4IdDV0zvdGGauuel54vRpFabDMhRWv2U6b/9SwuuEvoCPXlQilRTdEEsnBQfQ==",
        "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"] .      /* 67272 */
        str_pad (mb_strlen($fields["VK_REF"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_REF"] .        /* 672726 */
        str_pad (mb_strlen($fields["VK_MSG"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_MSG"];         /* Order nr. 67272 */
/* $data = "0041911003008003LHV009uid10004900567272006672726015Order nr. 67272"; */
// 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: