Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual Basic 6.0) Hungary NAV Manage Annulment RequestDemonstrates the manageAnnulment request for the Hungarian NAV Online Invoicing System REST API v2.0. Note: This example requires Chilkat v9.5.0.83 or greater. For more information, see https://onlineszamla.nav.gov.hu/api/files/container/download/Online%20Szamla_Interfesz%20specifik%C3%A1ci%C3%B3_EN_v2.0.pdf
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' Build the following XML: ' Use this online tool to generate code from sample XML: ' Generate Code to Create XML ' <?xml version="1.0" encoding="UTF-8"?> ' <ManageAnnulmentRequest xmlns="http://schemas.nav.gov.hu/OSA/2.0/api"> ' <header> ' <requestId>RID338592103413</requestId> ' <timestamp>2019-09-11T13:37:09.385Z</timestamp> ' <requestVersion>2.0</requestVersion> ' <headerVersion>1.0</headerVersion> ' </header> ' <user> ' <login>lwilsmn0uqdxe6u</login> ' <passwordHash>2F43840A882CFDB7DB0 ... F6CA57FE8CD74DC28E</passwordHash> ' <taxNumber>11111111</taxNumber> ' <requestSignature>A297E3BD9 ... 1959ADFAF5</requestSignature> ' </user> ' <software> ' <softwareId>123456789123456789</softwareId> ' <softwareName>string</softwareName> ' <softwareOperation>LOCAL_SOFTWARE</softwareOperation> ' <softwareMainVersion>string</softwareMainVersion> ' <softwareDevName>string</softwareDevName> ' <softwareDevContact>string</softwareDevContact> ' <softwareDevCountryCode>HU</softwareDevCountryCode> ' <softwareDevTaxNumber>string</softwareDevTaxNumber> ' </software> ' <exchangeToken>dbd03076-3a9b-4312-bbbb-0cee3a6472572P11CS49ASIL</exchangeToken> ' <annulmentOperations> ' <annulmentOperation> ' <index>1</index> ' <annulmentOperation>ANNUL</annulmentOperation> ' <invoiceAnnulment>PD94bWwgdm ... ubnVsbWVudD4=</invoiceAnnulment> ' </annulmentOperation> ' </annulmentOperations> ' </ManageAnnulmentRequest> Dim success As Long Dim crypt As New ChilkatCrypt2 Dim dtNow As New CkDateTime success = dtNow.SetFromCurrentSystemTime() Debug.Print dtNow.GetAsTimestamp(0) ' The hash algorithm for the password is SHA512 (not SHA3-512). crypt.HashAlgorithm = "sha512" crypt.EncodingMode = "hex" Dim myPassword As String myPassword = "my-password" Dim passwordHash As String passwordHash = crypt.HashStringENC(myPassword) ' Generate a random request ID like "RID215118906689" Dim prng As New ChilkatPrng Dim sbRequestId As New ChilkatStringBuilder success = sbRequestId.Append("RID") success = sbRequestId.Append(prng.RandomString(12,1,0,0)) Debug.Print "generated requestId = " & sbRequestId.GetAsString() ' Calculate the requestSignature crypt.HashAlgorithm = "sha3-512" Dim signatureKey As String signatureKey = "ce-8f5e-215119fa7dd621DLMRHRLH2S" Dim sbFinalHashBase As New ChilkatStringBuilder ' First append the timestamp because we are going to remove certain chars/parts. success = sbFinalHashBase.Append(dtNow.GetAsTimestamp(0)) Dim numReplaced As Long numReplaced = sbFinalHashBase.Replace("Z","") numReplaced = sbFinalHashBase.Replace("-","") numReplaced = sbFinalHashBase.Replace(":","") numReplaced = sbFinalHashBase.Replace("T","") ' Prepend the requestId and append the signatureKey success = sbFinalHashBase.Prepend(sbRequestId.GetAsString()) success = sbFinalHashBase.Append(signatureKey) ' Calculate first (and only) index hash. Dim invoiceOperation As String invoiceOperation = "ANNUL" Dim invoiceData As String invoiceData = "PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9InllcyI/Pg0KPEludm9pY2VBbm51bG1lbnQgeG1sbnM9Imh0dHA6Ly9zY2hlbWFzLm5hdi5nb3YuaHUvT1NBLzIuMC9hbm51bCI+DQoJCTxhbm51bG1lbnRSZWZlcmVuY2U+MjIyMjIyMjI8L2FubnVsbWVudFJlZmVyZW5jZT4NCgkJPGFubnVsbWVudFRpbWVzdGFtcD4yMDE4LTA2LTE4VDA5OjEwOjQ1LjMwOVo8L2FubnVsbWVudFRpbWVzdGFtcD4NCgkJPGFubnVsbWVudENvZGU+RVJSQVRJQ19EQVRBPC9hbm51bG1lbnRDb2RlPg0KCQk8YW5udWxtZW50UmVhc29uPmNyZWF0ZSBzemFtbGEgYW5udWw8L2FubnVsbWVudFJlYXNvbj4NCjwvSW52b2ljZUFubnVsbWVudD4=" Dim sbHashBase As New ChilkatStringBuilder success = sbHashBase.Append(invoiceOperation) success = sbHashBase.Append(invoiceData) Dim firstHash As String firstHash = crypt.HashStringENC(sbHashBase.GetAsString()) ' Append the index hash to the final hash base. success = sbFinalHashBase.Append(firstHash) ' Get our request signature (using sha3-512 because our HashAlgorithm was set to "sha3-512" up above...) Dim requestSignature As String requestSignature = crypt.HashStringENC(sbFinalHashBase.GetAsString()) ' Load our recently obtained exchange token. ' See Hungary NAV Invoicing Token Exchange Sample Code Dim xmlExchangeToken As New ChilkatXml success = xmlExchangeToken.LoadXmlFile("qa_data/tokens/nav_exchange_token.xml") If (success = 0) Then Debug.Print xmlExchangeToken.LastErrorText Exit Sub End If ' Get the base64 encoded/encrypted exchange token. ' IMPORTANT: Make sure to use the exchange token before it expires. ' If it expired, then get a new one.. Dim encodedEncryptedExchangeToken As String encodedEncryptedExchangeToken = xmlExchangeToken.GetChildContent("encodedExchangeToken") ' Decode to binary. Dim bdExchangeToken As New ChilkatBinData success = bdExchangeToken.AppendEncoded(encodedEncryptedExchangeToken,"base64") ' Decrypt using your 16-digit replacement key: crypt.CryptAlgorithm = "aes" crypt.CipherMode = "ecb" crypt.KeyLength = 128 crypt.EncodingMode = "base64" ' Pass your 16-digit replacement key here: crypt.SetEncodedKey "99952BBAAAAA8XYZ","ascii" success = crypt.DecryptBd(bdExchangeToken) Dim exchangeToken As String exchangeToken = bdExchangeToken.GetString("utf-8") Debug.Print "exchange token = " & exchangeToken ' Now build the XML.. Dim xml As New ChilkatXml xml.Tag = "ManageAnnulmentRequest" success = xml.AddAttribute("xmlns","http://schemas.nav.gov.hu/OSA/2.0/api") xml.UpdateChildContent "header|requestId",sbRequestId.GetAsString() xml.UpdateChildContent "header|timestamp",dtNow.GetAsTimestamp(0) xml.UpdateChildContent "header|requestVersion","2.0" xml.UpdateChildContent "header|headerVersion","1.0" xml.UpdateChildContent "user|login","lwilsmn0uqdxe6u" xml.UpdateChildContent "user|passwordHash",passwordHash xml.UpdateChildContent "user|taxNumber","11111111" xml.UpdateChildContent "user|requestSignature",requestSignature xml.UpdateChildContent "software|softwareId","123456789123456789" xml.UpdateChildContent "software|softwareName","string" xml.UpdateChildContent "software|softwareOperation","LOCAL_SOFTWARE" xml.UpdateChildContent "software|softwareMainVersion","string" xml.UpdateChildContent "software|softwareDevName","string" xml.UpdateChildContent "software|softwareDevContact","string" xml.UpdateChildContent "software|softwareDevCountryCode","HU" xml.UpdateChildContent "software|softwareDevTaxNumber","string" xml.UpdateChildContent "exchangeToken",exchangeToken xml.UpdateChildContent "annulmentOperations|annulmentOperation|index","1" xml.UpdateChildContent "annulmentOperations|annulmentOperation|annulmentOperation",invoiceOperation xml.UpdateChildContent "annulmentOperations|annulmentOperation|invoiceAnnulment",invoiceData ' POST the XML to https://api-test.onlineszamla.nav.gov.hu/invoiceService/v2/manageAnnulment Dim http As New ChilkatHttp http.Accept = "application/xml" http.SetRequestHeader "Content-Type","application/xml" Dim endpoint As String endpoint = "https://api-test.onlineszamla.nav.gov.hu/invoiceService/v2/manageAnnulment" Dim resp As ChilkatHttpResponse Set resp = http.PostXml(endpoint,xml.GetXml(),"utf-8") If (http.LastMethodSuccess = 0) Then Debug.Print http.LastErrorText Exit Sub End If Debug.Print "Response status code = " & resp.StatusCode Dim respXml As New ChilkatXml success = respXml.LoadXml(resp.BodyStr) Debug.Print "Response body:" Debug.Print respXml.GetXml() ' The result looks like this: ' <?xml version="1.0" encoding="UTF-8" standalone="yes"?> ' <ManageAnnulmentResponse xmlns="http://schemas.nav.gov.hu/OSA/2.0/api" xmlns:ns2="http://schemas.nav.gov.hu/OSA/2.0/data"> ' <header> ' <requestId>RID465317110495</requestId> ' <timestamp>2020-03-25T15:08:40Z</timestamp> ' <requestVersion>2.0</requestVersion> ' <headerVersion>1.0</headerVersion> ' </header> ' <result> ' <funcCode>OK</funcCode> ' </result> ' <software> ' <softwareId>123456789123456789</softwareId> ' <softwareName>string</softwareName> ' <softwareOperation>LOCAL_SOFTWARE</softwareOperation> ' <softwareMainVersion>string</softwareMainVersion> ' <softwareDevName>string</softwareDevName> ' <softwareDevContact>string</softwareDevContact> ' <softwareDevCountryCode>HU</softwareDevCountryCode> ' <softwareDevTaxNumber>string</softwareDevTaxNumber> ' </software> ' <transactionId>2WT6XG9LQ0U9VQNA</transactionId> ' </ManageAnnulmentResponse> ' Use this online tool to generate parsing code from sample XML: ' Generate Parsing Code from XML Dim ManageAnnulmentResponse_xmlns As String ManageAnnulmentResponse_xmlns = respXml.GetAttrValue("xmlns") Dim ManageAnnulmentResponse_xmlns_ns2 As String ManageAnnulmentResponse_xmlns_ns2 = respXml.GetAttrValue("xmlns:ns2") Dim requestId As String requestId = respXml.GetChildContent("header|requestId") Dim timestamp As String timestamp = respXml.GetChildContent("header|timestamp") Dim requestVersion As String requestVersion = respXml.GetChildContent("header|requestVersion") Dim headerVersion As String headerVersion = respXml.GetChildContent("header|headerVersion") Dim funcCode As String funcCode = respXml.GetChildContent("result|funcCode") Dim softwareId As String softwareId = respXml.GetChildContent("software|softwareId") Dim softwareName As String softwareName = respXml.GetChildContent("software|softwareName") Dim softwareOperation As String softwareOperation = respXml.GetChildContent("software|softwareOperation") Dim softwareMainVersion As String softwareMainVersion = respXml.GetChildContent("software|softwareMainVersion") Dim softwareDevName As String softwareDevName = respXml.GetChildContent("software|softwareDevName") Dim softwareDevContact As String softwareDevContact = respXml.GetChildContent("software|softwareDevContact") Dim softwareDevCountryCode As String softwareDevCountryCode = respXml.GetChildContent("software|softwareDevCountryCode") Dim softwareDevTaxNumber As String softwareDevTaxNumber = respXml.GetChildContent("software|softwareDevTaxNumber") Dim transactionId As String transactionId = respXml.GetChildContent("transactionId") |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.