Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Swift) Hungary NAV Manage Invoice RequestDemonstrates the manageInvoice 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
func chilkatTest() { // 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"?> // <ManageInvoiceRequest xmlns="http://schemas.nav.gov.hu/OSA/2.0/api"> // <header> // <requestId>RID181837288942</requestId> // <timestamp>2019-09-11T12:44:55.442Z</timestamp> // <requestVersion>2.0</requestVersion> // <headerVersion>1.0</headerVersion> // </header> // <user> // <login>lwilsmn0uqdxe6u</login> // <passwordHash>2F43840A882CFDB7DB0FEC07D419D030D864B47B6B541DC280EF81B937B7A176E33C052B0D26638CC18A7A2C08D8D311733078A774BF43F6CA57FE8CD74DC28E</passwordHash> // <taxNumber>11111111</taxNumber> // <requestSignature>E4D191A48EE8828A1E84C1F841A2B4E1699ECB49C4CDA1DC7A057765FD935872219644CC2B5A93B8A344404E4FD8ECA4902B5DBCF993E768DC558B0F0281E775</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>b1aca173-d9e8-4561-9237-0511eed99eaa2P0ZHLXBRI2U</exchangeToken> // <invoiceOperations> // <compressedContent>false</compressedContent> // <invoiceOperation> // <index>1</index> // <invoiceOperation>CREATE</invoiceOperation> // <invoiceData>base64 contents of invoiceData1 XML file</invoiceData> // </invoiceOperation> // <invoiceOperation> // <index>2</index> // <invoiceOperation>CREATE</invoiceOperation> // <invoiceData>base64 contents of invoiceData2 XML file</invoiceData> // </invoiceOperation> // <invoiceOperation> // <index>3</index> // <invoiceOperation>CREATE</invoiceOperation> // <invoiceData>base64 contents of invoiceData3 XML file</invoiceData> // </invoiceOperation> // </invoiceOperations> // </ManageInvoiceRequest> // var success: Bool // First load the invoiceData for the 3 XML invoice files we'll be sending. let bdInvoiceData1 = CkoBinData()! let bdInvoiceData2 = CkoBinData()! let bdInvoiceData3 = CkoBinData()! success = bdInvoiceData1.loadFile("qa_data/nav_invoicing/invoiceData1.xml") success = bdInvoiceData2.loadFile("qa_data/nav_invoicing/invoiceData2.xml") success = bdInvoiceData3.loadFile("qa_data/nav_invoicing/invoiceData3.xml") if success == false { print("Failed to load invoice data.") return } let crypt = CkoCrypt2()! let dtNow = CkoDateTime()! dtNow.setFromCurrentSystemTime() print("\(dtNow.getAsTimestamp(false)!)") // The hash algorithm for the password is SHA512 (not SHA3-512). crypt.hashAlgorithm = "sha512" crypt.encodingMode = "hex" var myPassword: String? = "my-password" var passwordHash: String? = crypt.hashStringENC(myPassword) // Generate a random request ID like "RID215118906689" let prng = CkoPrng()! let sbRequestId = CkoStringBuilder()! sbRequestId.append("RID") sbRequestId.append(prng.randomString(12, bDigits: true, bLower: false, bUpper: false)) print("generated requestId = \(sbRequestId.getAsString()!)") // Calculate the requestSignature crypt.hashAlgorithm = "sha3-512" var signatureKey: String? = "ce-8f5e-215119fa7dd621DLMRHRLH2S" let sbFinalHashBase = CkoStringBuilder()! // First append the timestamp because we are going to remove certain chars/parts. sbFinalHashBase.append(dtNow.getAsTimestamp(false)) var numReplaced: Int = sbFinalHashBase.replace("Z", replacement: "").intValue numReplaced = sbFinalHashBase.replace("-", replacement: "").intValue numReplaced = sbFinalHashBase.replace(":", replacement: "").intValue numReplaced = sbFinalHashBase.replace("T", replacement: "").intValue // Prepend the requestId and append the signatureKey sbFinalHashBase.prepend(sbRequestId.getAsString()) sbFinalHashBase.append(signatureKey) // Calculate each index hash and add it to the sbFinalHashBase let sbHashBase = CkoStringBuilder()! sbHashBase.append("CREATE") sbHashBase.append(bdInvoiceData1.getEncoded("base64")) var indexHash: String? = crypt.hashStringENC(sbHashBase.getAsString()) sbFinalHashBase.append(indexHash) sbHashBase.clear() sbHashBase.append("CREATE") sbHashBase.append(bdInvoiceData2.getEncoded("base64")) indexHash = crypt.hashStringENC(sbHashBase.getAsString()) sbFinalHashBase.append(indexHash) sbHashBase.clear() sbHashBase.append("CREATE") sbHashBase.append(bdInvoiceData3.getEncoded("base64")) indexHash = crypt.hashStringENC(sbHashBase.getAsString()) sbFinalHashBase.append(indexHash) // Get our request signature (using sha3-512 because our HashAlgorithm was set to "sha3-512" up above...) var requestSignature: String? = crypt.hashStringENC(sbFinalHashBase.getAsString()) // Load our recently obtained exchange token. // See Hungary NAV Invoicing Token Exchange Sample Code let xmlExchangeToken = CkoXml()! success = xmlExchangeToken.loadFile("qa_data/tokens/nav_exchange_token.xml") if success == false { print("\(xmlExchangeToken.lastErrorText!)") return } // 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.. var encodedEncryptedExchangeToken: String? = xmlExchangeToken.getChildContent("encodedExchangeToken") // Decode to binary. let bdExchangeToken = CkoBinData()! bdExchangeToken.appendEncoded(encodedEncryptedExchangeToken, encoding: "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", encoding: "ascii") crypt.decryptBd(bdExchangeToken) var exchangeToken: String? = bdExchangeToken.getString("utf-8") print("exchange token = \(exchangeToken!)") // Now build the XML.. let xml = CkoXml()! xml.tag = "ManageInvoiceRequest" xml.addAttribute("xmlns", value: "http://schemas.nav.gov.hu/OSA/2.0/api") xml.updateChildContent("header|requestId", value: sbRequestId.getAsString()) xml.updateChildContent("header|timestamp", value: dtNow.getAsTimestamp(false)) xml.updateChildContent("header|requestVersion", value: "2.0") xml.updateChildContent("header|headerVersion", value: "1.0") xml.updateChildContent("user|login", value: "lwilsmn0uqdxe6u") xml.updateChildContent("user|passwordHash", value: passwordHash) xml.updateChildContent("user|taxNumber", value: "11111111") xml.updateChildContent("user|requestSignature", value: requestSignature) xml.updateChildContent("software|softwareId", value: "123456789123456789") xml.updateChildContent("software|softwareName", value: "string") xml.updateChildContent("software|softwareOperation", value: "LOCAL_SOFTWARE") xml.updateChildContent("software|softwareMainVersion", value: "string") xml.updateChildContent("software|softwareDevName", value: "string") xml.updateChildContent("software|softwareDevContact", value: "string") xml.updateChildContent("software|softwareDevCountryCode", value: "HU") xml.updateChildContent("software|softwareDevTaxNumber", value: "string") xml.updateChildContent("exchangeToken", value: exchangeToken) xml.updateChildContent("invoiceOperations|compressedContent", value: "false") xml.updateChildContent("invoiceOperations|invoiceOperation|index", value: "1") xml.updateChildContent("invoiceOperations|invoiceOperation|invoiceOperation", value: "CREATE") xml.updateChildContent("invoiceOperations|invoiceOperation|invoiceData", value: bdInvoiceData1.getEncoded("base64")) xml.updateChildContent("invoiceOperations|invoiceOperation[1]|index", value: "2") xml.updateChildContent("invoiceOperations|invoiceOperation[1]|invoiceOperation", value: "CREATE") xml.updateChildContent("invoiceOperations|invoiceOperation[1]|invoiceData", value: bdInvoiceData2.getEncoded("base64")) xml.updateChildContent("invoiceOperations|invoiceOperation[2]|index", value: "3") xml.updateChildContent("invoiceOperations|invoiceOperation[2]|invoiceOperation", value: "CREATE") xml.updateChildContent("invoiceOperations|invoiceOperation[2]|invoiceData", value: bdInvoiceData3.getEncoded("base64")) // POST the XML to https://api-test.onlineszamla.nav.gov.hu/invoiceService/v2/manageInvoice let http = CkoHttp()! http.accept = "application/xml" http.setRequestHeader("Content-Type", value: "application/xml") var endpoint: String? = "https://api-test.onlineszamla.nav.gov.hu/invoiceService/v2/manageInvoice" var resp: CkoHttpResponse? = http.postXml(endpoint, xmlDoc: xml.getXml(), charset: "utf-8") if http.lastMethodSuccess == false { print("\(http.lastErrorText!)") return } print("Response status code = \(resp!.statusCode.intValue)") let respXml = CkoXml()! respXml.load(resp!.bodyStr) print("Response body:") print("\(respXml.getXml()!)") resp = nil // The result looks like this: // <?xml version="1.0" encoding="UTF-8" standalone="yes"?> // <ManageInvoiceResponse xmlns="http://schemas.nav.gov.hu/OSA/2.0/api" xmlns:ns2="http://schemas.nav.gov.hu/OSA/2.0/data"> // <header> // <requestId>RID871830318143</requestId> // <timestamp>2020-03-25T15:51:25Z</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>2WT9GFSKFUU1V4XP</transactionId> // </ManageInvoiceResponse> // Use this online tool to generate parsing code from sample XML: // Generate Parsing Code from XML var ManageInvoiceResponse_xmlns: String? = respXml.getAttrValue("xmlns") var ManageInvoiceResponse_xmlns_ns2: String? = respXml.getAttrValue("xmlns:ns2") var requestId: String? = respXml.getChildContent("header|requestId") var timestamp: String? = respXml.getChildContent("header|timestamp") var requestVersion: String? = respXml.getChildContent("header|requestVersion") var headerVersion: String? = respXml.getChildContent("header|headerVersion") var funcCode: String? = respXml.getChildContent("result|funcCode") var softwareId: String? = respXml.getChildContent("software|softwareId") var softwareName: String? = respXml.getChildContent("software|softwareName") var softwareOperation: String? = respXml.getChildContent("software|softwareOperation") var softwareMainVersion: String? = respXml.getChildContent("software|softwareMainVersion") var softwareDevName: String? = respXml.getChildContent("software|softwareDevName") var softwareDevContact: String? = respXml.getChildContent("software|softwareDevContact") var softwareDevCountryCode: String? = respXml.getChildContent("software|softwareDevCountryCode") var softwareDevTaxNumber: String? = respXml.getChildContent("software|softwareDevTaxNumber") var transactionId: String? = respXml.getChildContent("transactionId") } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.