From b209452751ced99128b16920e50df095e6520959 Mon Sep 17 00:00:00 2001 From: Vignesh Kennadi Date: Wed, 25 Sep 2024 16:47:28 +0530 Subject: [PATCH] Replaced byte content type by binary for octet-stream --- docs/v4/accounting/index.html | 1288 ++- docs/v4/appstore/index.html | 9 +- docs/v4/assets/index.html | 38 +- docs/v4/payroll-au/index.html | 31 +- docs/v4/payroll-nz/index.html | 329 +- docs/v4/payroll-uk/index.html | 207 +- .../com/xero/api/client/AccountingApi.java | 7024 +++++------------ .../com/xero/models/payrollnz/Employee.java | 7 +- .../com/xero/models/payrollnz/Employment.java | 11 +- .../com/xero/models/payrolluk/Employee.java | 11 +- .../com/xero/models/payrolluk/Employment.java | 10 +- 11 files changed, 3550 insertions(+), 5415 deletions(-) diff --git a/docs/v4/accounting/index.html b/docs/v4/accounting/index.html index 9667a9f0..5f020aa0 100644 --- a/docs/v4/accounting/index.html +++ b/docs/v4/accounting/index.html @@ -7212,7 +7212,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Account" }, - "example" : "{ \"Code\":\"123456\", \"Name\":\"Foobar\", \"Type\":\"EXPENSE\", \"Description\":\"Hello World\" }" + "example" : { + "Code" : "123456", + "Name" : "Foobar", + "Type" : "EXPENSE", + "Description" : "Hello World" + } } }, "required" : true @@ -7263,14 +7268,9 @@

Usage and SDK Samples

UUID accountID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createAccountAttachmentByFileName(accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createAccountAttachmentByFileName(accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createAccountAttachmentByFileName"); @@ -7408,7 +7408,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -7425,7 +7425,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -7477,14 +7477,9 @@

Usage and SDK Samples

UUID bankTransactionID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createBankTransactionAttachmentByFileName(accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createBankTransactionAttachmentByFileName(accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createBankTransactionAttachmentByFileName"); @@ -7622,7 +7617,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -7639,7 +7634,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -7831,7 +7826,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -8007,7 +8006,23 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BankTransactions" }, - "example" : "{ bankTransactions: [{ type: BankTransaction.TypeEnum.SPEND, contact: { contactID: \"00000000-0000-0000-0000-000000000000\" }, lineItems: [{ description: \"Foobar\", quantity: 1.0, unitAmount: 20.0, accountCode: \"000\" } ], bankAccount: { code: \"000\" }}]}" + "example" : { + "bankTransactions" : [ { + "type" : "BankTransaction.TypeEnum.SPEND", + "contact" : { + "contactID" : "00000000-0000-0000-0000-000000000000" + }, + "lineItems" : [ { + "description" : "Foobar", + "quantity" : 1.0, + "unitAmount" : 20.0, + "accountCode" : "000" + } ], + "bankAccount" : { + "code" : "000" + } + } ] + } } }, "required" : true @@ -8218,7 +8233,50 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BankTransfers" }, - "example" : "{ \"BankTransfers\": [ { \"FromBankAccount\": { \"Code\": \"090\", \"Name\": \"My Savings\", \"AccountID\": \"00000000-0000-0000-0000-000000000000\", \"Type\": \"BANK\", \"BankAccountNumber\": \"123455\", \"Status\": \"ACTIVE\", \"BankAccountType\": \"BANK\", \"CurrencyCode\": \"USD\", \"TaxType\": \"NONE\", \"EnablePaymentsToAccount\": false, \"ShowInExpenseClaims\": false, \"Class\": \"ASSET\", \"ReportingCode\": \"ASS\", \"ReportingCodeName\": \"Assets\", \"HasAttachments\": false, \"UpdatedDateUTC\": \"2016-10-17T13:45:33.993-07:00\" }, \"ToBankAccount\": { \"Code\": \"088\", \"Name\": \"Business Wells Fargo\", \"AccountID\": \"00000000-0000-0000-0000-000000000000\", \"Type\": \"BANK\", \"BankAccountNumber\": \"123455\", \"Status\": \"ACTIVE\", \"BankAccountType\": \"BANK\", \"CurrencyCode\": \"USD\", \"TaxType\": \"NONE\", \"EnablePaymentsToAccount\": false, \"ShowInExpenseClaims\": false, \"Class\": \"ASSET\", \"ReportingCode\": \"ASS\", \"ReportingCodeName\": \"Assets\", \"HasAttachments\": false, \"UpdatedDateUTC\": \"2016-06-03T08:31:14.517-07:00\" }, \"Amount\": \"50.00\", \"FromIsReconciled\": true, \"ToIsReconciled\": true, \"Reference\": \"Sub 098801\" } ] }" + "example" : { + "BankTransfers" : [ { + "FromBankAccount" : { + "Code" : "090", + "Name" : "My Savings", + "AccountID" : "00000000-0000-0000-0000-000000000000", + "Type" : "BANK", + "BankAccountNumber" : "123455", + "Status" : "ACTIVE", + "BankAccountType" : "BANK", + "CurrencyCode" : "USD", + "TaxType" : "NONE", + "EnablePaymentsToAccount" : false, + "ShowInExpenseClaims" : false, + "Class" : "ASSET", + "ReportingCode" : "ASS", + "ReportingCodeName" : "Assets", + "HasAttachments" : false, + "UpdatedDateUTC" : "2016-10-17T13:45:33.993-07:00" + }, + "ToBankAccount" : { + "Code" : "088", + "Name" : "Business Wells Fargo", + "AccountID" : "00000000-0000-0000-0000-000000000000", + "Type" : "BANK", + "BankAccountNumber" : "123455", + "Status" : "ACTIVE", + "BankAccountType" : "BANK", + "CurrencyCode" : "USD", + "TaxType" : "NONE", + "EnablePaymentsToAccount" : false, + "ShowInExpenseClaims" : false, + "Class" : "ASSET", + "ReportingCode" : "ASS", + "ReportingCodeName" : "Assets", + "HasAttachments" : false, + "UpdatedDateUTC" : "2016-06-03T08:31:14.517-07:00" + }, + "Amount" : "50.00", + "FromIsReconciled" : true, + "ToIsReconciled" : true, + "Reference" : "Sub 098801" + } ] + } } }, "required" : true @@ -8269,14 +8327,9 @@

Usage and SDK Samples

UUID bankTransferID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createBankTransferAttachmentByFileName(accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createBankTransferAttachmentByFileName(accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createBankTransferAttachmentByFileName"); @@ -8414,7 +8467,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -8431,7 +8484,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -8623,7 +8676,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -8802,7 +8859,28 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BatchPayments" }, - "example" : "{ \"BatchPayments\": [ { \"Account\": { \"AccountID\": \"00000000-0000-0000-0000-000000000000\" }, \"Reference\": \"ref\", \"Date\": \"2018-08-01\", \"Payments\": [ { \"Account\": { \"Code\": \"001\" }, \"Date\": \"2019-12-31\", \"Amount\": 500, \"Invoice\": { \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\", \"LineItems\": [], \"Contact\": {}, \"Type\": \"ACCPAY\" } } ] } ] }" + "example" : { + "BatchPayments" : [ { + "Account" : { + "AccountID" : "00000000-0000-0000-0000-000000000000" + }, + "Reference" : "ref", + "Date" : "2018-08-01", + "Payments" : [ { + "Account" : { + "Code" : "001" + }, + "Date" : "2019-12-31", + "Amount" : 500, + "Invoice" : { + "InvoiceID" : "00000000-0000-0000-0000-000000000000", + "LineItems" : [ ], + "Contact" : { }, + "Type" : "ACCPAY" + } + } ] + } ] + } } }, "required" : true @@ -9020,7 +9098,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -9214,7 +9296,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaymentServices" }, - "example" : "{ \"PaymentServices\": [ { \"PaymentServiceID\": \"54b3b4f6-0443-4fba-bcd1-61ec0c35ca55\", \"PaymentServiceName\": \"PayUpNow\", \"PaymentServiceUrl\": \"https://www.payupnow.com/\", \"PaymentServiceType\": \"Custom\", \"PayNowText\": \"Time To Pay\" } ] }" + "example" : { + "PaymentServices" : [ { + "PaymentServiceID" : "54b3b4f6-0443-4fba-bcd1-61ec0c35ca55", + "PaymentServiceName" : "PayUpNow", + "PaymentServiceUrl" : "https://www.payupnow.com/", + "PaymentServiceType" : "Custom", + "PayNowText" : "Time To Pay" + } ] + } } }, "required" : true @@ -9265,14 +9355,9 @@

Usage and SDK Samples

UUID contactID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createContactAttachmentByFileName(accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createContactAttachmentByFileName(accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createContactAttachmentByFileName"); @@ -9410,7 +9495,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -9427,7 +9512,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -9584,7 +9669,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ContactGroups" }, - "example" : "{ \"ContactGroups\": [{ \"Name\": \"VIPs\" }]}" + "example" : { + "ContactGroups" : [ { + "Name" : "VIPs" + } ] + } } }, "required" : true @@ -9775,7 +9864,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Contacts" }, - "example" : "{ \"Contacts\": [ { \"ContactID\": \"a3675fc4-f8dd-4f03-ba5b-f1870566bcd7\" }, { \"ContactID\": \"4e1753b9-018a-4775-b6aa-1bc7871cfee3\" } ] }" + "example" : { + "Contacts" : [ { + "ContactID" : "a3675fc4-f8dd-4f03-ba5b-f1870566bcd7" + }, { + "ContactID" : "4e1753b9-018a-4775-b6aa-1bc7871cfee3" + } ] + } } }, "required" : true @@ -9966,7 +10061,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -10132,7 +10231,66 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Contacts" }, - "example" : "{ \"Contacts\": [ { \"ContactID\": \"3ff6d40c-af9a-40a3-89ce-3c1556a25591\", \"ContactStatus\": \"ACTIVE\", \"Name\": \"Foo9987\", \"EmailAddress\": \"sid32476@blah.com\", \"BankAccountDetails\": \"\", \"Addresses\": [ { \"AddressType\": \"STREET\", \"City\": \"\", \"Region\": \"\", \"PostalCode\": \"\", \"Country\": \"\" }, { \"AddressType\": \"POBOX\", \"City\": \"\", \"Region\": \"\", \"PostalCode\": \"\", \"Country\": \"\" } ], \"Phones\": [ { \"PhoneType\": \"DEFAULT\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"DDI\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"FAX\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"MOBILE\", \"PhoneNumber\": \"555-1212\", \"PhoneAreaCode\": \"415\", \"PhoneCountryCode\": \"\" } ], \"UpdatedDateUTC\": \"/Date(1551399321043+0000)/\", \"ContactGroups\": [], \"IsSupplier\": false, \"IsCustomer\": false, \"SalesTrackingCategories\": [], \"PurchasesTrackingCategories\": [], \"PaymentTerms\": { \"Bills\": { \"Day\": 15, \"Type\": \"OFCURRENTMONTH\" }, \"Sales\": { \"Day\": 10, \"Type\": \"DAYSAFTERBILLMONTH\" } }, \"ContactPersons\": [] } ] }" + "example" : { + "Contacts" : [ { + "ContactID" : "3ff6d40c-af9a-40a3-89ce-3c1556a25591", + "ContactStatus" : "ACTIVE", + "Name" : "Foo9987", + "EmailAddress" : "sid32476@blah.com", + "BankAccountDetails" : "", + "Addresses" : [ { + "AddressType" : "STREET", + "City" : "", + "Region" : "", + "PostalCode" : "", + "Country" : "" + }, { + "AddressType" : "POBOX", + "City" : "", + "Region" : "", + "PostalCode" : "", + "Country" : "" + } ], + "Phones" : [ { + "PhoneType" : "DEFAULT", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "DDI", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "FAX", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "MOBILE", + "PhoneNumber" : "555-1212", + "PhoneAreaCode" : "415", + "PhoneCountryCode" : "" + } ], + "UpdatedDateUTC" : "/Date(1551399321043+0000)/", + "ContactGroups" : [ ], + "IsSupplier" : false, + "IsCustomer" : false, + "SalesTrackingCategories" : [ ], + "PurchasesTrackingCategories" : [ ], + "PaymentTerms" : { + "Bills" : { + "Day" : 15, + "Type" : "OFCURRENTMONTH" + }, + "Sales" : { + "Day" : 10, + "Type" : "DAYSAFTERBILLMONTH" + } + }, + "ContactPersons" : [ ] + } ] + } } }, "required" : true @@ -10357,7 +10515,16 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Allocations" }, - "example" : "{ \"Allocations\": [ { \"Invoice\": { \"LineItems\": [], \"InvoiceID\": \"c45720a1-ade3-4a38-a064-d15489be6841\" }, \"Amount\": 1, \"Date\": \"2019-03-05\" } ] }" + "example" : { + "Allocations" : [ { + "Invoice" : { + "LineItems" : [ ], + "InvoiceID" : "c45720a1-ade3-4a38-a064-d15489be6841" + }, + "Amount" : 1, + "Date" : "2019-03-05" + } ] + } } }, "required" : true @@ -10436,14 +10603,9 @@

Usage and SDK Samples

String fileName = 'xero-dev.jpg'; Boolean includeOnline = true; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createCreditNoteAttachmentByFileName(accessToken, xeroTenantId, creditNoteID, fileName, body, includeOnline, idempotencyKey, mimeType); + Attachments result = apiInstance.createCreditNoteAttachmentByFileName(accessToken, xeroTenantId, creditNoteID, fileName, body, includeOnline, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createCreditNoteAttachmentByFileName"); @@ -10581,7 +10743,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -10598,7 +10760,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -10817,7 +10979,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -10991,7 +11157,21 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/CreditNotes" }, - "example" : "{ \"CreditNotes\":[ { \"Type\":\"ACCPAYCREDIT\", \"Contact\":{ \"ContactID\":\"430fa14a-f945-44d3-9f97-5df5e28441b8\" }, \"Date\":\"2019-01-05\", \"LineItems\":[ { \"Description\":\"Foobar\", \"Quantity\":2.0, \"UnitAmount\":20.0, \"AccountCode\":\"400\" } ] } ] }" + "example" : { + "CreditNotes" : [ { + "Type" : "ACCPAYCREDIT", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8" + }, + "Date" : "2019-01-05", + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 2.0, + "UnitAmount" : 20.0, + "AccountCode" : "400" + } ] + } ] + } } }, "required" : true @@ -11192,7 +11372,10 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Currency" }, - "example" : "{ \"Code\": \"USD\", \"Description\": \"United States Dollar\" }" + "example" : { + "Code" : "USD", + "Description" : "United States Dollar" + } } }, "required" : true @@ -11350,7 +11533,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employees" }, - "example" : "{ \"Employees\": [ { \"FirstName\": \"Nick\", \"LastName\": \"Fury\", \"ExternalLink\": { \"Url\": \"http://twitter.com/#!/search/Nick+Fury\" } } ] }" + "example" : { + "Employees" : [ { + "FirstName" : "Nick", + "LastName" : "Fury", + "ExternalLink" : { + "Url" : "http://twitter.com/#!/search/Nick+Fury" + } + } ] + } } }, "required" : true @@ -11568,7 +11759,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -11737,7 +11932,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ExpenseClaims" }, - "example" : "{ \"ExpenseClaims\": [ { \"Status\": \"SUBMITTED\", \"User\": { \"UserID\": \"d1164823-0ac1-41ad-987b-b4e30fe0b273\" }, \"Receipts\": [ { \"Lineitems\": [], \"ReceiptID\": \"dc1c7f6d-0a4c-402f-acac-551d62ce5816\" } ] } ] }" + "example" : { + "ExpenseClaims" : [ { + "Status" : "SUBMITTED", + "User" : { + "UserID" : "d1164823-0ac1-41ad-987b-b4e30fe0b273" + }, + "Receipts" : [ { + "Lineitems" : [ ], + "ReceiptID" : "dc1c7f6d-0a4c-402f-acac-551d62ce5816" + } ] + } ] + } } }, "required" : true @@ -11789,14 +11995,9 @@

Usage and SDK Samples

String fileName = 'xero-dev.jpg'; Boolean includeOnline = true; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createInvoiceAttachmentByFileName(accessToken, xeroTenantId, invoiceID, fileName, body, includeOnline, idempotencyKey, mimeType); + Attachments result = apiInstance.createInvoiceAttachmentByFileName(accessToken, xeroTenantId, invoiceID, fileName, body, includeOnline, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createInvoiceAttachmentByFileName"); @@ -11934,7 +12135,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -11951,7 +12152,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -12170,7 +12371,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -12356,7 +12561,26 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Invoices" }, - "example" : "{ \"Invoices\": [ { \"Type\": \"ACCREC\", \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\" }, \"LineItems\": [ { \"Description\": \"Acme Tires\", \"Quantity\": 2, \"UnitAmount\": 20, \"AccountCode\": \"200\", \"TaxType\": \"NONE\", \"LineAmount\": 40 } ], \"Date\": \"2019-03-11\", \"DueDate\": \"2018-12-10\", \"Reference\": \"Website Design\", \"Status\": \"AUTHORISED\" } ] }" + "example" : { + "Invoices" : [ { + "Type" : "ACCREC", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8" + }, + "LineItems" : [ { + "Description" : "Acme Tires", + "Quantity" : 2, + "UnitAmount" : 20, + "AccountCode" : "200", + "TaxType" : "NONE", + "LineAmount" : 40 + } ], + "Date" : "2019-03-11", + "DueDate" : "2018-12-10", + "Reference" : "Website Design", + "Status" : "AUTHORISED" + } ] + } } }, "required" : true @@ -12594,7 +12818,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -12759,7 +12987,17 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Items" }, - "example" : "{ \"Items\": [ { \"Code\": \"code123\", \"Name\": \"Item Name XYZ\", \"Description\": \"Foobar\", \"InventoryAssetAccountCode\": \"140\", \"PurchaseDetails\": { \"COGSAccountCode\": \"500\" } } ] }" + "example" : { + "Items" : [ { + "Code" : "code123", + "Name" : "Item Name XYZ", + "Description" : "Foobar", + "InventoryAssetAccountCode" : "140", + "PurchaseDetails" : { + "COGSAccountCode" : "500" + } + } ] + } } }, "required" : true @@ -12960,7 +13198,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/LinkedTransaction" }, - "example" : "{ \"LinkedTransactions\": [ { \"SourceTransactionID\": \"a848644a-f20f-4630-98c3-386bd7505631\", \"SourceLineItemID\": \"b0df260d-3cc8-4ced-9bd6-41924f624ed3\" } ] }" + "example" : { + "LinkedTransactions" : [ { + "SourceTransactionID" : "a848644a-f20f-4630-98c3-386bd7505631", + "SourceLineItemID" : "b0df260d-3cc8-4ced-9bd6-41924f624ed3" + } ] + } } }, "required" : true @@ -13011,14 +13254,9 @@

Usage and SDK Samples

UUID manualJournalID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createManualJournalAttachmentByFileName(accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createManualJournalAttachmentByFileName(accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createManualJournalAttachmentByFileName"); @@ -13156,7 +13394,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -13173,7 +13411,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -13365,7 +13603,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -13539,7 +13781,25 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ManualJournals" }, - "example" : "{ \"ManualJournals\": [ { \"Narration\": \"Journal Desc\", \"JournalLines\": [ { \"LineAmount\": 100, \"AccountCode\": \"400\", \"Description\": \"Money Movement\" }, { \"LineAmount\": -100, \"AccountCode\": \"400\", \"Description\": \"Prepayment of things\", \"Tracking\": [ { \"Name\": \"North\", \"Option\": \"Region\" } ] } ], \"Date\": \"2019-03-14\" } ] }" + "example" : { + "ManualJournals" : [ { + "Narration" : "Journal Desc", + "JournalLines" : [ { + "LineAmount" : 100, + "AccountCode" : "400", + "Description" : "Money Movement" + }, { + "LineAmount" : -100, + "AccountCode" : "400", + "Description" : "Prepayment of things", + "Tracking" : [ { + "Name" : "North", + "Option" : "Region" + } ] + } ], + "Date" : "2019-03-14" + } ] + } } }, "required" : true @@ -13764,7 +14024,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Allocations" }, - "example" : "{ \"Allocations\": [ { \"Invoice\": { \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\", \"LineItems\": [], \"Contact\": {}, \"Type\": \"ACCPAY\" }, \"Amount\": 10.00, \"Date\": \"2019-03-12\" } ] }" + "example" : { + "Allocations" : [ { + "Invoice" : { + "InvoiceID" : "00000000-0000-0000-0000-000000000000", + "LineItems" : [ ], + "Contact" : { }, + "Type" : "ACCPAY" + }, + "Amount" : 10.0, + "Date" : "2019-03-12" + } ] + } } }, "required" : true @@ -13982,7 +14253,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -14148,7 +14423,19 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Payment" }, - "example" : "{ \"Payments\": [ { \"Invoice\": { \"LineItems\": [], \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\" }, \"Account\": { \"Code\": \"970\" }, \"Date\": \"2019-03-12\", \"Amount\": 1 } ] }" + "example" : { + "Payments" : [ { + "Invoice" : { + "LineItems" : [ ], + "InvoiceID" : "00000000-0000-0000-0000-000000000000" + }, + "Account" : { + "Code" : "970" + }, + "Date" : "2019-03-12", + "Amount" : 1 + } ] + } } }, "required" : true @@ -14339,7 +14626,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -14497,7 +14788,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaymentServices" }, - "example" : "{ \"PaymentServices\": [ { \"PaymentServiceName\": \"PayUpNow\", \"PaymentServiceUrl\": \"https://www.payupnow.com/\", \"PayNowText\": \"Time To Pay\" } ] }" + "example" : { + "PaymentServices" : [ { + "PaymentServiceName" : "PayUpNow", + "PaymentServiceUrl" : "https://www.payupnow.com/", + "PayNowText" : "Time To Pay" + } ] + } } }, "required" : true @@ -14664,7 +14961,19 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Payments" }, - "example" : "{ \"Payments\": [ { \"Invoice\": { \"LineItems\": [], \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\" }, \"Account\": { \"Code\": \"970\" }, \"Date\": \"2019-03-12\", \"Amount\": 1 } ] }" + "example" : { + "Payments" : [ { + "Invoice" : { + "LineItems" : [ ], + "InvoiceID" : "00000000-0000-0000-0000-000000000000" + }, + "Account" : { + "Code" : "970" + }, + "Date" : "2019-03-12", + "Amount" : 1 + } ] + } } }, "required" : true @@ -14889,7 +15198,16 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Allocations" }, - "example" : "{ \"Allocations\": [ { \"Invoice\": { \"LineItems\": [], \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\" }, \"Amount\": 1, \"Date\": \"2019-01-10\" } ] }" + "example" : { + "Allocations" : [ { + "Invoice" : { + "LineItems" : [ ], + "InvoiceID" : "00000000-0000-0000-0000-000000000000" + }, + "Amount" : 1, + "Date" : "2019-01-10" + } ] + } } }, "required" : true @@ -15107,7 +15425,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -15158,14 +15480,9 @@

Usage and SDK Samples

UUID purchaseOrderID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createPurchaseOrderAttachmentByFileName(accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createPurchaseOrderAttachmentByFileName(accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createPurchaseOrderAttachmentByFileName"); @@ -15303,7 +15620,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -15320,7 +15637,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -15512,7 +15829,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -15684,7 +16005,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PurchaseOrders" }, - "example" : "{ \"PurchaseOrders\": [ { \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"LineItems\": [ { \"Description\": \"Foobar\", \"Quantity\": 1, \"UnitAmount\": 20, \"AccountCode\": \"710\" } ], \"Date\": \"2019-03-13\" } ] }" + "example" : { + "PurchaseOrders" : [ { + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 1, + "UnitAmount" : 20, + "AccountCode" : "710" + } ], + "Date" : "2019-03-13" + } ] + } } }, "required" : true @@ -15762,14 +16096,9 @@

Usage and SDK Samples

UUID quoteID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createQuoteAttachmentByFileName(accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createQuoteAttachmentByFileName(accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createQuoteAttachmentByFileName"); @@ -15907,7 +16236,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -15924,7 +16253,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -16116,7 +16445,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -16288,7 +16621,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Quotes" }, - "example" : "{ \"Quotes\": [ { \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"LineItems\": [ { \"Description\": \"Foobar\", \"Quantity\": 1, \"UnitAmount\": 20, \"AccountCode\": \"12775\" } ], \"Date\": \"2020-02-01\" } ] }" + "example" : { + "Quotes" : [ { + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 1, + "UnitAmount" : 20, + "AccountCode" : "12775" + } ], + "Date" : "2020-02-01" + } ] + } } }, "required" : true @@ -16491,7 +16837,26 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Receipts" }, - "example" : "{ \"Receipts\": [ { \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"Lineitems\": [ { \"Description\": \"Foobar\", \"Quantity\": 2, \"UnitAmount\": 20, \"AccountCode\": \"400\", \"TaxType\": \"NONE\", \"LineAmount\": 40 } ], \"User\": { \"UserID\": \"00000000-0000-0000-0000-000000000000\" }, \"LineAmountTypes\": \"NoTax\", \"Status\": \"DRAFT\" } ] }" + "example" : { + "Receipts" : [ { + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "Lineitems" : [ { + "Description" : "Foobar", + "Quantity" : 2, + "UnitAmount" : 20, + "AccountCode" : "400", + "TaxType" : "NONE", + "LineAmount" : 40 + } ], + "User" : { + "UserID" : "00000000-0000-0000-0000-000000000000" + }, + "LineAmountTypes" : "NoTax", + "Status" : "DRAFT" + } ] + } } }, "required" : true @@ -16569,14 +16934,9 @@

Usage and SDK Samples

UUID receiptID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createReceiptAttachmentByFileName(accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createReceiptAttachmentByFileName(accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createReceiptAttachmentByFileName"); @@ -16714,7 +17074,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -16731,7 +17091,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -16923,7 +17283,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -16974,14 +17338,9 @@

Usage and SDK Samples

UUID repeatingInvoiceID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.createRepeatingInvoiceAttachmentByFileName(accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.createRepeatingInvoiceAttachmentByFileName(accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#createRepeatingInvoiceAttachmentByFileName"); @@ -17119,7 +17478,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -17136,7 +17495,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -17328,7 +17687,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/HistoryRecords" }, - "example" : "{ \"HistoryRecords\": [ { \"Details\": \"Hello World\" } ] }" + "example" : { + "HistoryRecords" : [ { + "Details" : "Hello World" + } ] + } } }, "required" : true @@ -17479,7 +17842,42 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/RepeatingInvoices" }, - "example" : "{ \"RepeatingInvoices\": [ { \"Schedule\": { \"Period\": 1, \"Unit\": \"MONTHLY\", \"DueDate\": 10, \"DueDateType\": \"OFFOLLOWINGMONTH\", \"StartDate\": \"\\/Date(1555286400000+0000)\\/\" }, \"Type\": \"ACCREC\", \"Reference\": \"[Week]\", \"ApprovedForSending\": false, \"SendCopy\": false, \"MarkAsSent\": false, \"IncludePDF\": false, \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\", \"Name\": \"Liam Gallagher\" }, \"Status\": \"AUTHORISED\", \"LineAmountTypes\": \"Exclusive\", \"LineItems\": [ { \"Description\": \"Guitars Fender Strat\", \"UnitAmount\": 5000.00, \"TaxType\": \"OUTPUT2\", \"TaxAmount\": 750.00, \"LineAmount\": 5000.00, \"AccountCode\": \"200\", \"Tracking\": [], \"Quantity\": 1.0000, \"LineItemID\": \"13a8353c-d2af-4d5b-920c-438449f08900\", \"DiscountEnteredAsPercent\": true } ], \"CurrencyCode\": \"NZD\" } ] }" + "example" : { + "RepeatingInvoices" : [ { + "Schedule" : { + "Period" : 1, + "Unit" : "MONTHLY", + "DueDate" : 10, + "DueDateType" : "OFFOLLOWINGMONTH", + "StartDate" : "/Date(1555286400000+0000)/" + }, + "Type" : "ACCREC", + "Reference" : "[Week]", + "ApprovedForSending" : false, + "SendCopy" : false, + "MarkAsSent" : false, + "IncludePDF" : false, + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8", + "Name" : "Liam Gallagher" + }, + "Status" : "AUTHORISED", + "LineAmountTypes" : "Exclusive", + "LineItems" : [ { + "Description" : "Guitars Fender Strat", + "UnitAmount" : 5000.0, + "TaxType" : "OUTPUT2", + "TaxAmount" : 750.0, + "LineAmount" : 5000.0, + "AccountCode" : "200", + "Tracking" : [ ], + "Quantity" : 1.0, + "LineItemID" : "13a8353c-d2af-4d5b-920c-438449f08900", + "DiscountEnteredAsPercent" : true + } ], + "CurrencyCode" : "NZD" + } ] + } } }, "required" : true @@ -17670,7 +18068,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TaxRates" }, - "example" : "{ \"TaxRates\": [ { \"Name\": \"CA State Tax\", \"TaxComponents\": [ { \"Name\": \"State Tax\", \"Rate\": 2.25 } ] } ] }" + "example" : { + "TaxRates" : [ { + "Name" : "CA State Tax", + "TaxComponents" : [ { + "Name" : "State Tax", + "Rate" : 2.25 + } ] + } ] + } } }, "required" : true @@ -17823,7 +18229,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TrackingCategory" }, - "example" : "{ name: \"FooBar\" }" + "example" : { + "name" : "FooBar" + } } }, "required" : true @@ -18011,7 +18419,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TrackingOption" }, - "example" : "{ name: \" Bar\" }" + "example" : { + "name" : " Bar" + } } }, "required" : true @@ -18291,7 +18701,10 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BatchPaymentDelete" }, - "example" : "{ \"BatchPaymentID\": \"9bf296e9-0748-4d29-a3dc-24dde1098030\", \"Status\":\"DELETED\" }" + "example" : { + "BatchPaymentID" : "9bf296e9-0748-4d29-a3dc-24dde1098030", + "Status" : "DELETED" + } } }, "required" : true @@ -18475,7 +18888,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BatchPaymentDeleteByUrlParam" }, - "example" : "{ \"Status\":\"DELETED\" }" + "example" : { + "Status" : "DELETED" + } } }, "required" : true @@ -19504,7 +19919,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaymentDelete" }, - "example" : "{ \"Payments\":[ { \"Status\":\"DELETED\" } ] }" + "example" : { + "Payments" : [ { + "Status" : "DELETED" + } ] + } } }, "required" : true @@ -20126,7 +20545,7 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/RequestEmpty" }, - "example" : "{}" + "example" : { } } }, "required" : true @@ -40660,7 +41079,33 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Setup" }, - "example" : "{ \"ConversionDate\": {}, \"ConversionBalances\": [], \"Accounts\": [ { \"Code\": \"200\", \"Name\": \"Sales\", \"Type\": \"SALES\", \"ReportingCode\": \"REV.TRA.GOO\" }, { \"Code\": \"400\", \"Name\": \"Advertising\", \"Type\": \"OVERHEADS\", \"ReportingCode\": \"EXP\" }, { \"Code\": \"610\", \"Name\": \"Accounts Receivable\", \"Type\": \"CURRENT\", \"SystemAccount\": \"DEBTORS\", \"ReportingCode\": \"ASS.CUR.REC.TRA\" }, { \"Code\": \"800\", \"Name\": \"Accounts Payable\", \"Type\": \"CURRLIAB\", \"SystemAccount\": \"CREDITORS\", \"ReportingCode\": \"LIA.CUR.PAY\" } ] }" + "example" : { + "ConversionDate" : { }, + "ConversionBalances" : [ ], + "Accounts" : [ { + "Code" : "200", + "Name" : "Sales", + "Type" : "SALES", + "ReportingCode" : "REV.TRA.GOO" + }, { + "Code" : "400", + "Name" : "Advertising", + "Type" : "OVERHEADS", + "ReportingCode" : "EXP" + }, { + "Code" : "610", + "Name" : "Accounts Receivable", + "Type" : "CURRENT", + "SystemAccount" : "DEBTORS", + "ReportingCode" : "ASS.CUR.REC.TRA" + }, { + "Code" : "800", + "Name" : "Accounts Payable", + "Type" : "CURRLIAB", + "SystemAccount" : "CREDITORS", + "ReportingCode" : "LIA.CUR.PAY" + } ] + } } }, "required" : true @@ -40855,7 +41300,22 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Accounts" }, - "example" : "{ \"Accounts\":[ { \"Code\":\"123456\", \"Name\":\"BarFoo\", \"AccountID\":\"99ce6032-0678-4aa0-8148-240c75fee33a\", \"Type\":\"EXPENSE\", \"Description\":\"GoodBye World\", \"TaxType\":\"INPUT\", \"EnablePaymentsToAccount\":false, \"ShowInExpenseClaims\":false, \"Class\":\"EXPENSE\", \"ReportingCode\":\"EXP\", \"ReportingCodeName\":\"Expense\", \"UpdatedDateUTC\":\"2019-02-21T16:29:47.96-08:00\" } ] }" + "example" : { + "Accounts" : [ { + "Code" : "123456", + "Name" : "BarFoo", + "AccountID" : "99ce6032-0678-4aa0-8148-240c75fee33a", + "Type" : "EXPENSE", + "Description" : "GoodBye World", + "TaxType" : "INPUT", + "EnablePaymentsToAccount" : false, + "ShowInExpenseClaims" : false, + "Class" : "EXPENSE", + "ReportingCode" : "EXP", + "ReportingCodeName" : "Expense", + "UpdatedDateUTC" : "2019-02-21T16:29:47.96-08:00" + } ] + } } }, "required" : true @@ -40906,14 +41366,9 @@

Usage and SDK Samples

UUID accountID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateAccountAttachmentByFileName(accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateAccountAttachmentByFileName(accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateAccountAttachmentByFileName"); @@ -41051,7 +41506,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -41068,7 +41523,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -41279,7 +41734,77 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BankTransactions" }, - "example" : "{ \"BankTransactions\": [ { \"Type\": \"SPEND\", \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\", \"ContactStatus\": \"ACTIVE\", \"Name\": \"Buzz Lightyear\", \"FirstName\": \"Buzz\", \"LastName\": \"Lightyear\", \"EmailAddress\": \"buzz.Lightyear@email.com\", \"ContactPersons\": [], \"BankAccountDetails\": \"\", \"Addresses\": [ { \"AddressType\": \"STREET\", \"City\": \"\", \"Region\": \"\", \"PostalCode\": \"\", \"Country\": \"\" }, { \"AddressType\": \"POBOX\", \"AddressLine1\": \"\", \"AddressLine2\": \"\", \"AddressLine3\": \"\", \"AddressLine4\": \"\", \"City\": \"Palo Alto\", \"Region\": \"CA\", \"PostalCode\": \"94020\", \"Country\": \"United States\" } ], \"Phones\": [ { \"PhoneType\": \"DEFAULT\", \"PhoneNumber\": \"847-1294\", \"PhoneAreaCode\": \"(626)\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"DDI\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"FAX\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" }, { \"PhoneType\": \"MOBILE\", \"PhoneNumber\": \"\", \"PhoneAreaCode\": \"\", \"PhoneCountryCode\": \"\" } ], \"UpdatedDateUTC\": \"2017-08-21T13:49:04.227-07:00\", \"ContactGroups\": [] }, \"Lineitems\": [], \"BankAccount\": { \"Code\": \"088\", \"Name\": \"Business Wells Fargo\", \"AccountID\": \"00000000-0000-0000-0000-000000000000\" }, \"IsReconciled\": false, \"Date\": \"2019-02-25\", \"Reference\": \"You just updated\", \"CurrencyCode\": \"USD\", \"CurrencyRate\": 1, \"Status\": \"AUTHORISED\", \"LineAmountTypes\": \"Inclusive\", \"TotalTax\": 1.74, \"BankTransactionID\": \"00000000-0000-0000-0000-000000000000\", \"UpdatedDateUTC\": \"2019-02-26T12:39:27.813-08:00\" } ] }" + "example" : { + "BankTransactions" : [ { + "Type" : "SPEND", + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000", + "ContactStatus" : "ACTIVE", + "Name" : "Buzz Lightyear", + "FirstName" : "Buzz", + "LastName" : "Lightyear", + "EmailAddress" : "buzz.Lightyear@email.com", + "ContactPersons" : [ ], + "BankAccountDetails" : "", + "Addresses" : [ { + "AddressType" : "STREET", + "City" : "", + "Region" : "", + "PostalCode" : "", + "Country" : "" + }, { + "AddressType" : "POBOX", + "AddressLine1" : "", + "AddressLine2" : "", + "AddressLine3" : "", + "AddressLine4" : "", + "City" : "Palo Alto", + "Region" : "CA", + "PostalCode" : "94020", + "Country" : "United States" + } ], + "Phones" : [ { + "PhoneType" : "DEFAULT", + "PhoneNumber" : "847-1294", + "PhoneAreaCode" : "(626)", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "DDI", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "FAX", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + }, { + "PhoneType" : "MOBILE", + "PhoneNumber" : "", + "PhoneAreaCode" : "", + "PhoneCountryCode" : "" + } ], + "UpdatedDateUTC" : "2017-08-21T13:49:04.227-07:00", + "ContactGroups" : [ ] + }, + "Lineitems" : [ ], + "BankAccount" : { + "Code" : "088", + "Name" : "Business Wells Fargo", + "AccountID" : "00000000-0000-0000-0000-000000000000" + }, + "IsReconciled" : false, + "Date" : "2019-02-25", + "Reference" : "You just updated", + "CurrencyCode" : "USD", + "CurrencyRate" : 1, + "Status" : "AUTHORISED", + "LineAmountTypes" : "Inclusive", + "TotalTax" : 1.74, + "BankTransactionID" : "00000000-0000-0000-0000-000000000000", + "UpdatedDateUTC" : "2019-02-26T12:39:27.813-08:00" + } ] + } } }, "required" : true @@ -41357,14 +41882,9 @@

Usage and SDK Samples

UUID bankTransactionID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateBankTransactionAttachmentByFileName(accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateBankTransactionAttachmentByFileName(accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateBankTransactionAttachmentByFileName"); @@ -41502,7 +42022,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -41519,7 +42039,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -41571,14 +42091,9 @@

Usage and SDK Samples

UUID bankTransferID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateBankTransferAttachmentByFileName(accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateBankTransferAttachmentByFileName(accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateBankTransferAttachmentByFileName"); @@ -41716,7 +42231,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -41733,7 +42248,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -41926,7 +42441,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Contacts" }, - "example" : "{ \"Contacts\": [{ \"ContactID\": \"00000000-0000-0000-0000-000000000000\", \"Name\": \"Thanos\" }]}" + "example" : { + "Contacts" : [ { + "ContactID" : "00000000-0000-0000-0000-000000000000", + "Name" : "Thanos" + } ] + } } }, "required" : true @@ -41977,14 +42497,9 @@

Usage and SDK Samples

UUID contactID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateContactAttachmentByFileName(accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateContactAttachmentByFileName(accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateContactAttachmentByFileName"); @@ -42122,7 +42637,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -42139,7 +42654,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -42331,7 +42846,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ContactGroups" }, - "example" : "{ \"ContactGroups\":[ { \"Name\":\"Suppliers\" } ] }" + "example" : { + "ContactGroups" : [ { + "Name" : "Suppliers" + } ] + } } }, "required" : true @@ -42541,7 +43060,24 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/CreditNotes" }, - "example" : "{ \"CreditNotes\": [ { \"Type\": \"ACCPAYCREDIT\", \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\" }, \"Date\": \"2019-01-05\", \"Status\": \"AUTHORISED\", \"Reference\": \"HelloWorld\", \"SentToContact\": true, \"LineItems\": [ { \"Description\": \"Foobar\", \"Quantity\": 2, \"UnitAmount\": 20, \"AccountCode\": \"400\" } ] } ] }" + "example" : { + "CreditNotes" : [ { + "Type" : "ACCPAYCREDIT", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8" + }, + "Date" : "2019-01-05", + "Status" : "AUTHORISED", + "Reference" : "HelloWorld", + "SentToContact" : true, + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 2, + "UnitAmount" : 20, + "AccountCode" : "400" + } ] + } ] + } } }, "required" : true @@ -42619,14 +43155,9 @@

Usage and SDK Samples

UUID creditNoteID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateCreditNoteAttachmentByFileName(accessToken, xeroTenantId, creditNoteID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateCreditNoteAttachmentByFileName(accessToken, xeroTenantId, creditNoteID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateCreditNoteAttachmentByFileName"); @@ -42764,7 +43295,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -42781,7 +43312,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -42985,7 +43516,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ExpenseClaims" }, - "example" : "{ \"ExpenseClaims\": [ { \"Status\": \"SUBMITTED\", \"User\": { \"UserID\": \"d1164823-0ac1-41ad-987b-b4e30fe0b273\" }, \"Receipts\": [ { \"Lineitems\": [], \"ReceiptID\": \"dc1c7f6d-0a4c-402f-acac-551d62ce5816\" } ] } ] }" + "example" : { + "ExpenseClaims" : [ { + "Status" : "SUBMITTED", + "User" : { + "UserID" : "d1164823-0ac1-41ad-987b-b4e30fe0b273" + }, + "Receipts" : [ { + "Lineitems" : [ ], + "ReceiptID" : "dc1c7f6d-0a4c-402f-acac-551d62ce5816" + } ] + } ] + } } }, "required" : true @@ -43176,7 +43718,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Invoices" }, - "example" : "{ \"Invoices\": [{ Reference: \"May the force be with you\", \"InvoiceID\": \"00000000-0000-0000-0000-000000000000\", \"LineItems\": [], \"Contact\": {}, \"Type\": \"ACCPAY\" }]}" + "example" : { + "Invoices" : [ { + "Reference" : "May the force be with you", + "InvoiceID" : "00000000-0000-0000-0000-000000000000", + "LineItems" : [ ], + "Contact" : { }, + "Type" : "ACCPAY" + } ] + } } }, "required" : true @@ -43254,14 +43804,9 @@

Usage and SDK Samples

UUID invoiceID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateInvoiceAttachmentByFileName(accessToken, xeroTenantId, invoiceID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateInvoiceAttachmentByFileName(accessToken, xeroTenantId, invoiceID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateInvoiceAttachmentByFileName"); @@ -43399,7 +43944,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -43416,7 +43961,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -43609,7 +44154,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Items" }, - "example" : "{ \"Items\": [ { \"Code\": \"ItemCode123\", \"Description\": \"Description 123\" } ] }" + "example" : { + "Items" : [ { + "Code" : "ItemCode123", + "Description" : "Description 123" + } ] + } } }, "required" : true @@ -43827,7 +44377,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/LinkedTransactions" }, - "example" : "{ \"LinkedTransactions\": [ { \"SourceTransactionID\": \"00000000-0000-0000-0000-000000000000\", \"SourceLineItemID\": \"00000000-0000-0000-0000-000000000000\" } ] }" + "example" : { + "LinkedTransactions" : [ { + "SourceTransactionID" : "00000000-0000-0000-0000-000000000000", + "SourceLineItemID" : "00000000-0000-0000-0000-000000000000" + } ] + } } }, "required" : true @@ -44034,7 +44589,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ManualJournals" }, - "example" : "{ \"ManualJournals\": [ { \"Narration\": \"Hello Xero\", \"ManualJournalID\": \"00000000-0000-0000-0000-000000000000\", \"JournalLines\": [] } ] }" + "example" : { + "ManualJournals" : [ { + "Narration" : "Hello Xero", + "ManualJournalID" : "00000000-0000-0000-0000-000000000000", + "JournalLines" : [ ] + } ] + } } }, "required" : true @@ -44085,14 +44646,9 @@

Usage and SDK Samples

UUID manualJournalID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateManualJournalAttachmentByFileName(accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateManualJournalAttachmentByFileName(accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateManualJournalAttachmentByFileName"); @@ -44230,7 +44786,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -44247,7 +44803,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -44423,7 +44979,23 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/BankTransactions" }, - "example" : "{ \"BankTransactions\": [ { \"Type\": \"SPEND\", \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"Lineitems\": [ { \"Description\": \"Foobar\", \"Quantity\": 1, \"UnitAmount\": 20, \"AccountCode\": \"400\" } ], \"BankAccount\": { \"Code\": \"088\" } } ] }" + "example" : { + "BankTransactions" : [ { + "Type" : "SPEND", + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "Lineitems" : [ { + "Description" : "Foobar", + "Quantity" : 1, + "UnitAmount" : 20, + "AccountCode" : "400" + } ], + "BankAccount" : { + "Code" : "088" + } + } ] + } } }, "required" : true @@ -44635,7 +45207,27 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Contacts" }, - "example" : "{ \"Contacts\": [ { \"Name\": \"Bruce Banner\", \"EmailAddress\": \"hulk@avengers.com\", \"Phones\": [ { \"PhoneType\": \"MOBILE\", \"PhoneNumber\": \"555-1212\", \"PhoneAreaCode\": \"415\" } ], \"PaymentTerms\": { \"Bills\": { \"Day\": 15, \"Type\": \"OFCURRENTMONTH\" }, \"Sales\": { \"Day\": 10, \"Type\": \"DAYSAFTERBILLMONTH\" } } } ] }" + "example" : { + "Contacts" : [ { + "Name" : "Bruce Banner", + "EmailAddress" : "hulk@avengers.com", + "Phones" : [ { + "PhoneType" : "MOBILE", + "PhoneNumber" : "555-1212", + "PhoneAreaCode" : "415" + } ], + "PaymentTerms" : { + "Bills" : { + "Day" : 15, + "Type" : "OFCURRENTMONTH" + }, + "Sales" : { + "Day" : 10, + "Type" : "DAYSAFTERBILLMONTH" + } + } + } ] + } } }, "required" : true @@ -44836,7 +45428,23 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/CreditNotes" }, - "example" : "{ \"CreditNotes\":[ { \"Type\":\"ACCPAYCREDIT\", \"Contact\":{ \"ContactID\":\"430fa14a-f945-44d3-9f97-5df5e28441b8\" }, \"Date\":\"2019-01-05\", \"Status\":\"AUTHORISED\", \"Reference\": \"HelloWorld\", \"LineItems\":[ { \"Description\":\"Foobar\", \"Quantity\":2.0, \"UnitAmount\":20.0, \"AccountCode\":\"400\" } ] } ] }" + "example" : { + "CreditNotes" : [ { + "Type" : "ACCPAYCREDIT", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8" + }, + "Date" : "2019-01-05", + "Status" : "AUTHORISED", + "Reference" : "HelloWorld", + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 2.0, + "UnitAmount" : 20.0, + "AccountCode" : "400" + } ] + } ] + } } }, "required" : true @@ -45041,7 +45649,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employees" }, - "example" : "{ \"Employees\": [ { \"FirstName\": \"Nick\", \"LastName\": \"Fury\", \"ExternalLink\": { \"Url\": \"http://twitter.com/#!/search/Nick+Fury\" } } ] }" + "example" : { + "Employees" : [ { + "FirstName" : "Nick", + "LastName" : "Fury", + "ExternalLink" : { + "Url" : "http://twitter.com/#!/search/Nick+Fury" + } + } ] + } } }, "required" : true @@ -45245,7 +45861,26 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Invoices" }, - "example" : "{ \"Invoices\": [ { \"Type\": \"ACCREC\", \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\" }, \"LineItems\": [ { \"Description\": \"Acme Tires\", \"Quantity\": 2, \"UnitAmount\": 20, \"AccountCode\": \"200\", \"TaxType\": \"NONE\", \"LineAmount\": 40 } ], \"Date\": \"2019-03-11\", \"DueDate\": \"2018-12-10\", \"Reference\": \"Website Design\", \"Status\": \"AUTHORISED\" } ] }" + "example" : { + "Invoices" : [ { + "Type" : "ACCREC", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8" + }, + "LineItems" : [ { + "Description" : "Acme Tires", + "Quantity" : 2, + "UnitAmount" : 20, + "AccountCode" : "200", + "TaxType" : "NONE", + "LineAmount" : 40 + } ], + "Date" : "2019-03-11", + "DueDate" : "2018-12-10", + "Reference" : "Website Design", + "Status" : "AUTHORISED" + } ] + } } }, "required" : true @@ -45451,7 +46086,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Items" }, - "example" : "{ \"Items\": [ { \"Code\": \"ItemCode123\", \"Name\": \"ItemName XYZ\", \"Description\": \"Item Description ABC\" } ] }" + "example" : { + "Items" : [ { + "Code" : "ItemCode123", + "Name" : "ItemName XYZ", + "Description" : "Item Description ABC" + } ] + } } }, "required" : true @@ -45672,7 +46313,25 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/ManualJournals" }, - "example" : "{ \"ManualJournals\": [ { \"Narration\": \"Journal Desc\", \"JournalLines\": [ { \"LineAmount\": 100, \"AccountCode\": \"400\", \"Description\": \"Money Movement\" }, { \"LineAmount\": -100, \"AccountCode\": \"400\", \"Description\": \"Prepayment of things\", \"Tracking\": [ { \"Name\": \"North\", \"Option\": \"Region\" } ] } ], \"Date\": \"2019-03-14\" } ] }" + "example" : { + "ManualJournals" : [ { + "Narration" : "Journal Desc", + "JournalLines" : [ { + "LineAmount" : 100, + "AccountCode" : "400", + "Description" : "Money Movement" + }, { + "LineAmount" : -100, + "AccountCode" : "400", + "Description" : "Prepayment of things", + "Tracking" : [ { + "Name" : "North", + "Option" : "Region" + } ] + } ], + "Date" : "2019-03-14" + } ] + } } }, "required" : true @@ -45870,7 +46529,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PurchaseOrders" }, - "example" : "{ \"PurchaseOrders\": [ { \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"LineItems\": [ { \"Description\": \"Foobar\", \"Quantity\": 1, \"UnitAmount\": 20, \"AccountCode\": \"710\" } ], \"Date\": \"2019-03-13\" } ] }" + "example" : { + "PurchaseOrders" : [ { + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 1, + "UnitAmount" : 20, + "AccountCode" : "710" + } ], + "Date" : "2019-03-13" + } ] + } } }, "required" : true @@ -46068,7 +46740,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Quotes" }, - "example" : "{ \"Quotes\": [ { \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"LineItems\": [ { \"Description\": \"Foobar\", \"Quantity\": 1, \"UnitAmount\": 20, \"AccountCode\": \"12775\" } ], \"Date\": \"2020-02-01\" } ] }" + "example" : { + "Quotes" : [ { + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "LineItems" : [ { + "Description" : "Foobar", + "Quantity" : 1, + "UnitAmount" : 20, + "AccountCode" : "12775" + } ], + "Date" : "2020-02-01" + } ] + } } }, "required" : true @@ -46246,7 +46931,42 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/RepeatingInvoices" }, - "example" : "{ \"RepeatingInvoices\": [ { \"Schedule\": { \"Period\": 1, \"Unit\": \"MONTHLY\", \"DueDate\": 10, \"DueDateType\": \"OFFOLLOWINGMONTH\", \"StartDate\": \"\\/Date(1555286400000+0000)\\/\" }, \"Type\": \"ACCREC\", \"Reference\": \"[Week]\", \"ApprovedForSending\": false, \"SendCopy\": false, \"MarkAsSent\": false, \"IncludePDF\": false, \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\", \"Name\": \"Liam Gallagher\" }, \"Status\": \"AUTHORISED\", \"LineAmountTypes\": \"Exclusive\", \"LineItems\": [ { \"Description\": \"Guitars Fender Strat\", \"UnitAmount\": 5000.00, \"TaxType\": \"OUTPUT2\", \"TaxAmount\": 750.00, \"LineAmount\": 5000.00, \"AccountCode\": \"200\", \"Tracking\": [], \"Quantity\": 1.0000, \"LineItemID\": \"13a8353c-d2af-4d5b-920c-438449f08900\", \"DiscountEnteredAsPercent\": true } ], \"CurrencyCode\": \"NZD\" } ] }" + "example" : { + "RepeatingInvoices" : [ { + "Schedule" : { + "Period" : 1, + "Unit" : "MONTHLY", + "DueDate" : 10, + "DueDateType" : "OFFOLLOWINGMONTH", + "StartDate" : "/Date(1555286400000+0000)/" + }, + "Type" : "ACCREC", + "Reference" : "[Week]", + "ApprovedForSending" : false, + "SendCopy" : false, + "MarkAsSent" : false, + "IncludePDF" : false, + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8", + "Name" : "Liam Gallagher" + }, + "Status" : "AUTHORISED", + "LineAmountTypes" : "Exclusive", + "LineItems" : [ { + "Description" : "Guitars Fender Strat", + "UnitAmount" : 5000.0, + "TaxType" : "OUTPUT2", + "TaxAmount" : 750.0, + "LineAmount" : 5000.0, + "AccountCode" : "200", + "Tracking" : [ ], + "Quantity" : 1.0, + "LineItemID" : "13a8353c-d2af-4d5b-920c-438449f08900", + "DiscountEnteredAsPercent" : true + } ], + "CurrencyCode" : "NZD" + } ] + } } }, "required" : true @@ -46463,7 +47183,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PurchaseOrders" }, - "example" : "{ \"PurchaseOrders\": [ { \"AttentionTo\": \"Peter Parker\", \"LineItems\": [], \"Contact\": {} } ] }" + "example" : { + "PurchaseOrders" : [ { + "AttentionTo" : "Peter Parker", + "LineItems" : [ ], + "Contact" : { } + } ] + } } }, "required" : true @@ -46514,14 +47240,9 @@

Usage and SDK Samples

UUID purchaseOrderID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updatePurchaseOrderAttachmentByFileName(accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updatePurchaseOrderAttachmentByFileName(accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updatePurchaseOrderAttachmentByFileName"); @@ -46659,7 +47380,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -46676,7 +47397,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -46873,7 +47594,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Quotes" }, - "example" : "{ \"Quotes\": [ { \"Reference\": \"I am an update\", \"Contact\": { \"ContactID\": \"00000000-0000-0000-0000-000000000000\" }, \"Date\": \"2020-02-01\" } ] }" + "example" : { + "Quotes" : [ { + "Reference" : "I am an update", + "Contact" : { + "ContactID" : "00000000-0000-0000-0000-000000000000" + }, + "Date" : "2020-02-01" + } ] + } } }, "required" : true @@ -46924,14 +47653,9 @@

Usage and SDK Samples

UUID quoteID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateQuoteAttachmentByFileName(accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateQuoteAttachmentByFileName(accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateQuoteAttachmentByFileName"); @@ -47069,7 +47793,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -47086,7 +47810,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -47284,7 +48008,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Receipts" }, - "example" : "{ \"Receipts\": [ { \"Lineitems\": [], \"User\": { \"UserID\": \"00000000-0000-0000-0000-000000000000\" }, \"Reference\": \"Foobar\" } ] }" + "example" : { + "Receipts" : [ { + "Lineitems" : [ ], + "User" : { + "UserID" : "00000000-0000-0000-0000-000000000000" + }, + "Reference" : "Foobar" + } ] + } } }, "required" : true @@ -47362,14 +48094,9 @@

Usage and SDK Samples

UUID receiptID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateReceiptAttachmentByFileName(accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateReceiptAttachmentByFileName(accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateReceiptAttachmentByFileName"); @@ -47507,7 +48234,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -47524,7 +48251,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -47709,7 +48436,53 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/RepeatingInvoices" }, - "example" : "{ \"Schedule\": { \"Period\": 1, \"Unit\": \"MONTHLY\", \"DueDate\": 10, \"DueDateType\": \"OFFOLLOWINGMONTH\", \"StartDate\": \"\\/Date(1555286400000+0000)\\/\", \"EndDate\": \"\\/Date(1569801600000+0000)\\/\", \"NextScheduledDate\": \"\\/Date(1555286400000+0000)\\/\" }, \"RepeatingInvoiceID\": \"428c0d75-909f-4b04-8403-a48dc27283b0\", \"Type\": \"ACCREC\", \"Reference\": \"[Week]\", \"HasAttachments\": true, \"ApprovedForSending\": false, \"SendCopy\": false, \"MarkAsSent\": false, \"IncludePDF\": false, \"ID\": \"428c0d75-909f-4b04-8403-a48dc27283b0\", \"Contact\": { \"ContactID\": \"430fa14a-f945-44d3-9f97-5df5e28441b8\", \"Name\": \"Liam Gallagher\", \"Addresses\": [], \"Phones\": [], \"ContactGroups\": [], \"ContactPersons\": [], \"HasValidationErrors\": false }, \"Status\": \"DELETED\", \"LineAmountTypes\": \"Exclusive\", \"LineItems\": [ { \"Description\": \"Guitars Fender Strat\", \"UnitAmount\": 5000.00, \"TaxType\": \"OUTPUT2\", \"TaxAmount\": 750.00, \"LineAmount\": 5000.00, \"AccountCode\": \"200\", \"Tracking\": [], \"Quantity\": 1.0000, \"LineItemID\": \"13a8353c-d2af-4d5b-920c-438449f08900\", \"DiscountEnteredAsPercent\": true } ], \"SubTotal\": 5000.00, \"TotalTax\": 750.00, \"Total\": 5750.00, \"CurrencyCode\": \"NZD\" }" + "example" : { + "Schedule" : { + "Period" : 1, + "Unit" : "MONTHLY", + "DueDate" : 10, + "DueDateType" : "OFFOLLOWINGMONTH", + "StartDate" : "/Date(1555286400000+0000)/", + "EndDate" : "/Date(1569801600000+0000)/", + "NextScheduledDate" : "/Date(1555286400000+0000)/" + }, + "RepeatingInvoiceID" : "428c0d75-909f-4b04-8403-a48dc27283b0", + "Type" : "ACCREC", + "Reference" : "[Week]", + "HasAttachments" : true, + "ApprovedForSending" : false, + "SendCopy" : false, + "MarkAsSent" : false, + "IncludePDF" : false, + "ID" : "428c0d75-909f-4b04-8403-a48dc27283b0", + "Contact" : { + "ContactID" : "430fa14a-f945-44d3-9f97-5df5e28441b8", + "Name" : "Liam Gallagher", + "Addresses" : [ ], + "Phones" : [ ], + "ContactGroups" : [ ], + "ContactPersons" : [ ], + "HasValidationErrors" : false + }, + "Status" : "DELETED", + "LineAmountTypes" : "Exclusive", + "LineItems" : [ { + "Description" : "Guitars Fender Strat", + "UnitAmount" : 5000.0, + "TaxType" : "OUTPUT2", + "TaxAmount" : 750.0, + "LineAmount" : 5000.0, + "AccountCode" : "200", + "Tracking" : [ ], + "Quantity" : 1.0, + "LineItemID" : "13a8353c-d2af-4d5b-920c-438449f08900", + "DiscountEnteredAsPercent" : true + } ], + "SubTotal" : 5000.0, + "TotalTax" : 750.0, + "Total" : 5750.0, + "CurrencyCode" : "NZD" + } } }, "required" : true @@ -47760,14 +48533,9 @@

Usage and SDK Samples

UUID repeatingInvoiceID = '00000000-0000-0000-0000-000000000000'; String fileName = 'xero-dev.jpg'; String idempotencyKey = 'KEY_VALUE'; - - File input = new File("/path/to/local/xero-dev.jpg"); - java.nio.file.Path inputPath = input.toPath(); - byte[] body = FileUtils.readFileToByteArray(input); - String mimeType = Files.probeContentType(inputPath); try { - Attachments result = apiInstance.updateRepeatingInvoiceAttachmentByFileName(accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey, mimeType); + Attachments result = apiInstance.updateRepeatingInvoiceAttachmentByFileName(accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey); System.out.println(result); } catch (XeroException e) { System.err.println("Exception when calling AccountingApi#updateRepeatingInvoiceAttachmentByFileName"); @@ -47905,7 +48673,7 @@

Parameters

- byte[] + File
Byte array of file in body of request @@ -47922,7 +48690,7 @@

Parameters

"application/octet-stream" : { "schema" : { "type" : "string", - "format" : "byte" + "format" : "binary" } } }, @@ -48086,7 +48854,17 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TaxRates" }, - "example" : "{ \"TaxRates\": [ { \"Name\": \"State Tax NY\", \"TaxComponents\": [ { \"Name\": \"State Tax\", \"Rate\": 2.25 } ], \"Status\": \"DELETED\", \"ReportTaxType\": \"INPUT\" } ] }" + "example" : { + "TaxRates" : [ { + "Name" : "State Tax NY", + "TaxComponents" : [ { + "Name" : "State Tax", + "Rate" : 2.25 + } ], + "Status" : "DELETED", + "ReportTaxType" : "INPUT" + } ] + } } }, "required" : true @@ -48273,7 +49051,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TrackingCategory" }, - "example" : "{ \"Name\": \"Avengers\" }" + "example" : { + "Name" : "Avengers" + } } }, "required" : true @@ -48488,7 +49268,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TrackingOption" }, - "example" : "{ name: \"Vision\" }" + "example" : { + "name" : "Vision" + } } }, "required" : true diff --git a/docs/v4/appstore/index.html b/docs/v4/appstore/index.html index 3f39be5d..6408b41d 100644 --- a/docs/v4/appstore/index.html +++ b/docs/v4/appstore/index.html @@ -1640,7 +1640,10 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/CreateUsageRecord" }, - "example" : "{ \"timestamp\": \"2022-01-21T13:01:00\", \"quantity\": 10 }" + "example" : { + "timestamp" : "2022-01-21T13:01:00", + "quantity" : 10 + } } }, "required" : true @@ -1857,7 +1860,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/UpdateUsageRecord" }, - "example" : "{ \"quantity\": 10 }" + "example" : { + "quantity" : 10 + } } }, "required" : true diff --git a/docs/v4/assets/index.html b/docs/v4/assets/index.html index d22ba9b3..6204e671 100644 --- a/docs/v4/assets/index.html +++ b/docs/v4/assets/index.html @@ -1028,7 +1028,6 @@ }; defs["BookDepreciationDetail"] = { "title" : "", - "required" : [ "name" ], "properties" : { "currentCapitalGain" : { "type" : "number", @@ -1082,7 +1081,6 @@ }; defs["BookDepreciationSetting"] = { "title" : "", - "required" : [ "name" ], "properties" : { "depreciationMethod" : { "type" : "string", @@ -1571,7 +1569,28 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Asset" }, - "example" : "{ \"assetName\":\"Computer74863\", \"assetNumber\":\"123477544\", \"purchaseDate\":\"2020-01-01\", \"purchasePrice\":100.0, \"disposalPrice\":23.23, \"assetStatus\":\"Draft\", \"bookDepreciationSetting\":{ \"depreciationMethod\":\"StraightLine\", \"averagingMethod\":\"ActualDays\", \"depreciationRate\":0.5, \"depreciationCalculationMethod\":\"None\" }, \"bookDepreciationDetail\":{ \"currentCapitalGain\":5.32, \"currentGainLoss\":3.88, \"depreciationStartDate\":\"2020-01-02\", \"costLimit\":100.0, \"currentAccumDepreciationAmount\":2.25 }, \"AccountingBookValue\":99.5 }" + "example" : { + "assetName" : "Computer74863", + "assetNumber" : "123477544", + "purchaseDate" : "2020-01-01", + "purchasePrice" : 100.0, + "disposalPrice" : 23.23, + "assetStatus" : "Draft", + "bookDepreciationSetting" : { + "depreciationMethod" : "StraightLine", + "averagingMethod" : "ActualDays", + "depreciationRate" : 0.5, + "depreciationCalculationMethod" : "None" + }, + "bookDepreciationDetail" : { + "currentCapitalGain" : 5.32, + "currentGainLoss" : 3.88, + "depreciationStartDate" : "2020-01-02", + "costLimit" : 100.0, + "currentAccumDepreciationAmount" : 2.25 + }, + "AccountingBookValue" : 99.5 + } } }, "required" : true @@ -1734,7 +1753,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/AssetType" }, - "example" : "{ \"assetTypeName\":\"Machinery11004\", \"fixedAssetAccountId\":\"3d8d063a-c148-4bb8-8b3c-a5e2ad3b1e82\", \"depreciationExpenseAccountId\":\"d1602f69-f900-4616-8d34-90af393fa368\", \"accumulatedDepreciationAccountId\":\"9195cadd-8645-41e6-9f67-7bcd421defe8\", \"bookDepreciationSetting\":{ \"depreciationMethod\":\"DiminishingValue100\", \"averagingMethod\":\"ActualDays\", \"depreciationRate\":0.05, \"depreciationCalculationMethod\":\"None\" } }" + "example" : { + "assetTypeName" : "Machinery11004", + "fixedAssetAccountId" : "3d8d063a-c148-4bb8-8b3c-a5e2ad3b1e82", + "depreciationExpenseAccountId" : "d1602f69-f900-4616-8d34-90af393fa368", + "accumulatedDepreciationAccountId" : "9195cadd-8645-41e6-9f67-7bcd421defe8", + "bookDepreciationSetting" : { + "depreciationMethod" : "DiminishingValue100", + "averagingMethod" : "ActualDays", + "depreciationRate" : 0.05, + "depreciationCalculationMethod" : "None" + } + } } }, "required" : true diff --git a/docs/v4/payroll-au/index.html b/docs/v4/payroll-au/index.html index f588e5d2..62bdacfa 100644 --- a/docs/v4/payroll-au/index.html +++ b/docs/v4/payroll-au/index.html @@ -4181,7 +4181,25 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayItem" }, - "example" : "{ \"EarningsRates\": [ { \"Name\": \"MyRate\", \"AccountCode\": \"400\", \"TypeOfUnits\": \"4.00\", \"IsExemptFromTax\": true, \"IsExemptFromSuper\": true, \"IsReportableAsW1\": false, \"AllowanceContributesToAnnualLeaveRate\": false, \"AllowanceContributesToOvertimeRate\": false, \"EarningsType\": \"ORDINARYTIMEEARNINGS\", \"EarningsRateID\": \"1fa4e226-b711-46ba-a8a7-4344c9c5fb87\", \"RateType\": \"MULTIPLE\", \"RatePerUnit\": \"10.0\", \"Multiplier\": 1.5, \"Amount\": 5, \"EmploymentTerminationPaymentType\": \"O\" } ] }" + "example" : { + "EarningsRates" : [ { + "Name" : "MyRate", + "AccountCode" : "400", + "TypeOfUnits" : "4.00", + "IsExemptFromTax" : true, + "IsExemptFromSuper" : true, + "IsReportableAsW1" : false, + "AllowanceContributesToAnnualLeaveRate" : false, + "AllowanceContributesToOvertimeRate" : false, + "EarningsType" : "ORDINARYTIMEEARNINGS", + "EarningsRateID" : "1fa4e226-b711-46ba-a8a7-4344c9c5fb87", + "RateType" : "MULTIPLE", + "RatePerUnit" : "10.0", + "Multiplier" : 1.5, + "Amount" : 5, + "EmploymentTerminationPaymentType" : "O" + } ] + } } }, "required" : true @@ -8453,7 +8471,16 @@

Parameters

"$ref" : "#/components/schemas/PayslipLines" } }, - "example" : "{ \"Payslip\": { \"EmployeeID\": \"cdfb8371-0b21-4b8a-8903-1024df6c391e\", \"DeductionLines\": [ { \"DeductionTypeID\": \"727af5e8-b347-4ae7-85fc-9b82266d0aec\", \"CalculationType\": \"FIXEDAMOUNT\", \"NumberOfUnits\": 10 } ] } }" + "example" : { + "Payslip" : { + "EmployeeID" : "cdfb8371-0b21-4b8a-8903-1024df6c391e", + "DeductionLines" : [ { + "DeductionTypeID" : "727af5e8-b347-4ae7-85fc-9b82266d0aec", + "CalculationType" : "FIXEDAMOUNT", + "NumberOfUnits" : 10 + } ] + } + } } }, "required" : true diff --git a/docs/v4/payroll-nz/index.html b/docs/v4/payroll-nz/index.html index c5906753..a23f62bf 100644 --- a/docs/v4/payroll-nz/index.html +++ b/docs/v4/payroll-nz/index.html @@ -1046,7 +1046,7 @@ }; defs["Deduction"] = { "title" : "", - "required" : [ "calculationType", "deductionCategory", "deductionName", "liabilityAccountId" ], + "required" : [ "deductionCategory", "deductionName", "liabilityAccountId" ], "type" : "object", "properties" : { "deductionId" : { @@ -1420,7 +1420,7 @@ }; defs["Employee"] = { "title" : "", - "required" : [ "Address", "DateOfBirth", "FirstName", "LastName" ], + "required" : [ "address", "dateOfBirth", "firstName", "lastName" ], "type" : "object", "properties" : { "employeeID" : { @@ -2426,7 +2426,7 @@ }; defs["Employment"] = { "title" : "", - "required" : [ "EngagementType", "PayrollCalendarID", "StartDate" ], + "required" : [ "engagementType", "payrollCalendarID", "startDate" ], "type" : "object", "properties" : { "payrollCalendarID" : { @@ -4555,7 +4555,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Deduction" }, - "example" : "{ \"deductionName\": \"My new deduction\", \"deductionCategory\": \"NzOther\", \"liabilityAccountId\": \"568f2e9a-0870-46cc-8678-f83f132ed4e3\" }" + "example" : { + "deductionName" : "My new deduction", + "deductionCategory" : "NzOther", + "liabilityAccountId" : "568f2e9a-0870-46cc-8678-f83f132ed4e3" + } } }, "required" : true @@ -4709,7 +4713,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EarningsRate" }, - "example" : "{ \"name\": \"My Earnings Rate\", \"earningsType\": \"RegularEarnings\", \"rateType\": \"RatePerUnit\", \"typeOfUnits\": \"hours\", \"expenseAccountID\": \"e4eb36f6-97e3-4427-a394-dd4e1b355c2e\" }" + "example" : { + "name" : "My Earnings Rate", + "earningsType" : "RegularEarnings", + "rateType" : "RatePerUnit", + "typeOfUnits" : "hours", + "expenseAccountID" : "e4eb36f6-97e3-4427-a394-dd4e1b355c2e" + } } }, "required" : true @@ -4871,7 +4881,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employee" }, - "example" : "{ \"title\": \"Mr\", \"firstName\": \"Mike\", \"lastName\": \"Johntzxzpxhmkgson\", \"dateOfBirth\": \"2000-01-01\", \"address\": { \"addressLine1\": \"101 Green St\", \"city\": \"San Francisco\", \"postCode\": \"4351\", \"countryName\": \"United Kingdom\" }, \"email\": \"83139@starkindustries.com\", \"gender\": \"M\" }" + "example" : { + "title" : "Mr", + "firstName" : "Mike", + "lastName" : "Johntzxzpxhmkgson", + "dateOfBirth" : "2000-01-01", + "address" : { + "addressLine1" : "101 Green St", + "city" : "San Francisco", + "postCode" : "4351", + "countryName" : "United Kingdom" + }, + "email" : "83139@starkindustries.com", + "gender" : "M" + } } }, "required" : true @@ -5066,7 +5089,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EarningsTemplate" }, - "example" : "{ \"ratePerUnit\": 20, \"numberOfUnits\": 8, \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"name\": \"My New One\" }" + "example" : { + "ratePerUnit" : 20, + "numberOfUnits" : 8, + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "name" : "My New One" + } } }, "required" : true @@ -5259,7 +5287,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeave" }, - "example" : "{ \"leaveTypeID\": \"b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4\", \"description\": \"Creating a Description\", \"startDate\": \"2020-04-24\", \"endDate\": \"2020-04-26\" }" + "example" : { + "leaveTypeID" : "b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4", + "description" : "Creating a Description", + "startDate" : "2020-04-24", + "endDate" : "2020-04-26" + } } }, "required" : true @@ -5456,7 +5489,16 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeaveSetup" }, - "example" : "{ \"holidayPayOpeningBalance\": 10, \"annualLeaveOpeningBalance\": 100, \"sickLeaveHoursToAccrueAnnually\": 20, \"sickLeaveToAccrueAnnually\": 20, \"sickLeaveOpeningBalance\": 10, \"sickLeaveScheduleOfAccrual\": \"OnAnniversaryDate\", \"sickLeaveAnniversaryDate\": \"2023-12-31\", \"annualLeaveAnniversaryDate\": \"2023-12-31\" }" + "example" : { + "holidayPayOpeningBalance" : 10, + "annualLeaveOpeningBalance" : 100, + "sickLeaveHoursToAccrueAnnually" : 20, + "sickLeaveToAccrueAnnually" : 20, + "sickLeaveOpeningBalance" : 10, + "sickLeaveScheduleOfAccrual" : "OnAnniversaryDate", + "sickLeaveAnniversaryDate" : "2023-12-31", + "annualLeaveAnniversaryDate" : "2023-12-31" + } } }, "required" : true @@ -5646,7 +5688,17 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeaveType" }, - "example" : "{ \"leaveTypeID\": \"35da97ae-05b9-427f-9a98-69157ba42cec\", \"scheduleOfAccrual\": \"AnnuallyAfter6Months\", \"hoursAccruedAnnually\": 10, \"unitsAccruedAnnually\": 10, \"typeOfUnitsToAccrue\": \"Hours\", \"openingBalanceTypeOfUnits\": \"Hours\" \"maximumToAccrue\": 80, \"openingBalance\": 100, \"rateAccruedHourly\": 3.5 }" + "example" : { + "leaveTypeID" : "35da97ae-05b9-427f-9a98-69157ba42cec", + "scheduleOfAccrual" : "AnnuallyAfter6Months", + "hoursAccruedAnnually" : 10, + "unitsAccruedAnnually" : 10, + "typeOfUnitsToAccrue" : "Hours", + "openingBalanceTypeOfUnits" : "Hours", + "maximumToAccrue" : 80, + "openingBalance" : 100, + "rateAccruedHourly" : 3.5 + } } }, "required" : true @@ -6035,7 +6087,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaymentMethod" }, - "example" : "" + "example" : { + "bankAccounts" : [ { + "accountName" : "Casual Worker", + "accountNumber" : "0607050201419000", + "sortCode" : null, + "particulars" : null, + "code" : null, + "dollarAmount" : null, + "reference" : "", + "calculationType" : "Balance" + } ] + } } }, "required" : true @@ -6225,7 +6288,17 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/SalaryAndWage" }, - "example" : "{ \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnitsPerWeek\": 2, \"ratePerUnit\": 10, \"numberOfUnitsPerDay\": 2, \"daysPerWeek\": 1, \"effectiveFrom\": \"2020-05-01\", \"annualSalary\": 100, \"status\": \"Active\", \"paymentType\": \"Salary\" }" + "example" : { + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnitsPerWeek" : 2, + "ratePerUnit" : 10, + "numberOfUnitsPerDay" : 2, + "daysPerWeek" : 1, + "effectiveFrom" : "2020-05-01", + "annualSalary" : 100, + "status" : "Active", + "paymentType" : "Salary" + } } }, "required" : true @@ -6419,7 +6492,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeWorkingPatternWithWorkingWeeksRequest" }, - "example" : "{ \"effectiveFrom\": \"2020-01-01T00:00:00\", \"workingWeeks\": [ { \"monday\": 0.0, \"tuesday\": 3.0000, \"wednesday\": 0.0, \"thursday\": 0.0, \"friday\": 0.0, \"saturday\": 0.0, \"sunday\": 0.0 } ] }" + "example" : { + "effectiveFrom" : "2020-01-01T00:00:00", + "workingWeeks" : [ { + "monday" : 0.0, + "tuesday" : 3.0, + "wednesday" : 0.0, + "thursday" : 0.0, + "friday" : 0.0, + "saturday" : 0.0, + "sunday" : 0.0 + } ] + } } }, "required" : true @@ -6610,7 +6694,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employment" }, - "example" : "{ \"payrollCalendarID\": \"9aa56064-990f-4ad3-a189-d966d8f6a030\", \"startDate\": \"2020-09-02\", \"engagementType\": \"FixedTerm\", \"fixedTermEndDate\": \"2026-01-01\" }" + "example" : { + "payrollCalendarID" : "9aa56064-990f-4ad3-a189-d966d8f6a030", + "startDate" : "2020-09-02", + "engagementType" : "FixedTerm", + "fixedTermEndDate" : "2026-01-01" + } } }, "required" : true @@ -6764,7 +6853,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/LeaveType" }, - "example" : "{ \"name\": \"My wqwhhiktun Leave\", \"isPaidLeave\": false, \"showOnPayslip\": true }" + "example" : { + "name" : "My wqwhhiktun Leave", + "isPaidLeave" : false, + "showOnPayslip" : true + } } }, "required" : true @@ -7112,7 +7205,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayRun" }, - "example" : "{ \"payrollCalendarID\": \"9aa56064-990f-4ad3-a189-d966d8f6a030\", \"periodStartDate\": \"2020-09-08\", \"periodEndDate\": \"2020-09-15\", \"paymentDate\": \"2020-09-20\", \"payRunStatus\": \"Draft\", \"payRunType\": \"Scheduled\", \"calendarType\": \"Weekly\" }" + "example" : { + "payrollCalendarID" : "9aa56064-990f-4ad3-a189-d966d8f6a030", + "periodStartDate" : "2020-09-08", + "periodEndDate" : "2020-09-15", + "paymentDate" : "2020-09-20", + "payRunStatus" : "Draft", + "payRunType" : "Scheduled", + "calendarType" : "Weekly" + } } }, "required" : true @@ -7268,7 +7369,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayRunCalendar" }, - "example" : "{ \"name\": \"My Weekly Cal\", \"calendarType\": \"Weekly\", \"periodStartDate\": \"2020-05-01\", \"paymentDate\": \"2020-05-15\" }" + "example" : { + "name" : "My Weekly Cal", + "calendarType" : "Weekly", + "periodStartDate" : "2020-05-01", + "paymentDate" : "2020-05-15" + } } }, "required" : true @@ -7423,7 +7529,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Reimbursement" }, - "example" : "{ \"name\": \"My new Reimburse\", \"accountID\": \"fa5cdc43-643b-4ad8-b4ac-3ffe0d0f4488\", \"reimbursementCategory\": \"GSTInclusive\", \"calculationType\": \"FixedAmount\" }" + "example" : { + "name" : "My new Reimburse", + "accountID" : "fa5cdc43-643b-4ad8-b4ac-3ffe0d0f4488", + "reimbursementCategory" : "GSTInclusive", + "calculationType" : "FixedAmount" + } } }, "required" : true @@ -7580,7 +7691,14 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Benefit" }, - "example" : "{ \"name\": \"SidSaver\", \"category\": \"Other\", \"liabilityAccountId\": \"568f2e9a-0870-46cc-8678-f83f132ed4e3\", \"expenseAccountId\": \"e4eb36f6-97e3-4427-a394-dd4e1b355c2e\", \"CalculationTypeNZ\": \"FixedAmount\", \"standardAmount\": 10 }" + "example" : { + "name" : "SidSaver", + "category" : "Other", + "liabilityAccountId" : "568f2e9a-0870-46cc-8678-f83f132ed4e3", + "expenseAccountId" : "e4eb36f6-97e3-4427-a394-dd4e1b355c2e", + "CalculationTypeNZ" : "FixedAmount", + "standardAmount" : 10 + } } }, "required" : true @@ -7737,7 +7855,21 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Timesheet" }, - "example" : "{ \"payrollCalendarID\": \"9aa56064-990f-4ad3-a189-d966d8f6a030\", \"employeeID\": \"68342973-c405-4b86-b5d3-d7b877c27995\", \"startDate\": \"2020-04-13\", \"endDate\": \"2020-04-19\", \"timesheetLines\": [ { \"date\": \"2020-04-13\", \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnits\": 8 }, { \"date\": \"2020-04-15\", \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnits\": 6 } ] }" + "example" : { + "payrollCalendarID" : "9aa56064-990f-4ad3-a189-d966d8f6a030", + "employeeID" : "68342973-c405-4b86-b5d3-d7b877c27995", + "startDate" : "2020-04-13", + "endDate" : "2020-04-19", + "timesheetLines" : [ { + "date" : "2020-04-13", + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnits" : 8 + }, { + "date" : "2020-04-15", + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnits" : 6 + } ] + } } }, "required" : true @@ -7929,7 +8061,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TimesheetLine" }, - "example" : "{ \"date\": \"2020-08-03\", \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnits\": 1 }" + "example" : { + "date" : "2020-08-03", + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnits" : 1 + } } }, "required" : true @@ -14116,7 +14252,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employee" }, - "example" : "{ \"title\": \"Mr\", \"firstName\": \"Tony\", \"lastName\": \"Starkgtrzgquusrson\", \"dateOfBirth\": \"1999-01-01\", \"address\": { \"addressLine1\": \"101 Green St\", \"city\": \"San Francisco\", \"postCode\": \"4432\", \"countryName\": \"United Kingdom\" }, \"email\": \"58315@starkindustries.com\", \"gender\": \"M\" }" + "example" : { + "title" : "Mr", + "firstName" : "Tony", + "lastName" : "Starkgtrzgquusrson", + "dateOfBirth" : "1999-01-01", + "address" : { + "addressLine1" : "101 Green St", + "city" : "San Francisco", + "postCode" : "4432", + "countryName" : "United Kingdom" + }, + "email" : "58315@starkindustries.com", + "gender" : "M" + } } }, "required" : true @@ -14339,7 +14488,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EarningsTemplate" }, - "example" : "{ \"ratePerUnit\": 25, \"numberOfUnits\": 4, \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\" }" + "example" : { + "ratePerUnit" : 25, + "numberOfUnits" : 4, + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5" + } } }, "required" : true @@ -14558,7 +14711,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeave" }, - "example" : "{ \"leaveTypeID\": \"b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4\", \"description\": \"Creating a Description\", \"startDate\": \"2020-04-24\", \"endDate\": \"2020-04-26\", \"periods\": [ { \"periodStartDate\": \"2020-04-20\", \"periodEndDate\": \"2020-04-26\", \"numberOfUnits\": 1, \"periodStatus\": \"Approved\" } ] }" + "example" : { + "leaveTypeID" : "b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4", + "description" : "Creating a Description", + "startDate" : "2020-04-24", + "endDate" : "2020-04-26", + "periods" : [ { + "periodStartDate" : "2020-04-20", + "periodEndDate" : "2020-04-26", + "numberOfUnits" : 1, + "periodStatus" : "Approved" + } ] + } } }, "required" : true @@ -14776,7 +14940,17 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/SalaryAndWage" }, - "example" : "{ \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnitsPerWeek\": 3, \"ratePerUnit\": 11, \"numberOfUnitsPerDay\": 3, \"daysPerWeek\": 1, \"effectiveFrom\": \"2020-05-15\", \"annualSalary\": 101, \"status\": \"Active\", \"paymentType\": \"Salary\" }" + "example" : { + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnitsPerWeek" : 3, + "ratePerUnit" : 11, + "numberOfUnitsPerDay" : 3, + "daysPerWeek" : 1, + "effectiveFrom" : "2020-05-15", + "annualSalary" : 101, + "status" : "Active", + "paymentType" : "Salary" + } } }, "required" : true @@ -14975,7 +15149,24 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeTax" }, - "example" : "" + "example" : { + "irdNumber" : "111111111", + "taxCode" : "M", + "esctRatePercentage" : 17.5, + "isEligibleForKiwiSaver" : true, + "hasSpecialStudentLoanRate" : false, + "specialStudentLoanRatePercentage" : null, + "specialTaxRatePercentage" : null, + "kiwiSaverContributions" : "MakeContributions", + "kiwiSaverOptOutDate" : null, + "kiwiSaverContributionHolidayEndDate" : null, + "kiwiSaverEmployeeContributionRatePercentage" : 3, + "kiwiSaverEmployerContributionRatePercentage" : 3, + "kiwiSaverEmployerSalarySacrificeContributionRatePercentage" : 0, + "hasStudentLoanBalance" : false, + "studentLoanBalance" : null, + "studentLoanAsAt" : null + } } }, "required" : true @@ -15166,7 +15357,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayRun" }, - "example" : "{ \"paymentDate\": \"2019-07-01\" }" + "example" : { + "paymentDate" : "2019-07-01" + } } }, "required" : true @@ -15364,7 +15557,81 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaySlip" }, - "example" : "{ \"earningsLines\": [ { \"earningsLineID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"displayName\": \"Ordinary Time\", \"ratePerUnit\": 25, \"numberOfUnits\": 0, \"amount\": 0, \"isLinkedToTimesheet\": false, \"isSystemGenerated\": true }, { \"earningsLineID\": \"65b83d94-f20f-45e1-85ae-387fcf460c26\", \"earningsRateID\": \"65b83d94-f20f-45e1-85ae-387fcf460c26\", \"displayName\": \"Salary\", \"ratePerUnit\": 0, \"numberOfUnits\": 8, \"amount\": 0, \"isLinkedToTimesheet\": false, \"isSystemGenerated\": false } ], \"leaveEarningsLines\": [ { \"earningsLineID\": \"0441497f-5dc7-4cd3-a90d-f2e07e21b2a6\", \"earningsRateID\": \"39b3560a-5d2f-4538-924a-4349dc86396e\", \"displayName\": \"Holiday Pay\", \"fixedAmount\": 268.8, \"amount\": 268.8, \"isLinkedToTimesheet\": false, \"isSystemGenerated\": true } ], \"deductionLines\": [ { \"deductionTypeID\": \"a3760fe4-68a4-4e38-8326-fe616af7dc74\", \"amount\": 100 } ], \"leaveAccrualLines\": [ { \"leaveTypeID\": \"0441497f-5dc7-4cd3-a90d-f2e07e21b2a6\", \"numberOfUnits\": 268.8 }, { \"leaveTypeID\": \"b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4\", \"numberOfUnits\": 0 }, { \"leaveTypeID\": \"f2f994cf-1899-46f3-ad4f-5d92d78c3719\", \"numberOfUnits\": 0 }, { \"leaveTypeID\": \"34129765-11cb-4d8c-b568-84a2219beda3\", \"numberOfUnits\": 0 } ], \"superannuationLines\": [ { \"superannuationTypeID\": \"563273ea-0dae-4f82-86a4-e0db77c008ea\", \"displayName\": \"KiwiSaver\", \"amount\": 108.86, \"fixedAmount\": 3, \"percentage\": 3, \"manualAdjustment\": false } ], \"employeeTaxLines\": [ { \"taxLineID\": \"1084146b-e890-489c-aed3-06de80f63d84\", \"amount\": 1057.22, \"globalTaxTypeID\": \"11\", \"manualAdjustment\": false } ], \"employerTaxLines\": [ { \"taxLineID\": \"6f9eb8cd-0f4a-440b-939c-bdb0f6ad694c\", \"amount\": 18.9, \"globalTaxTypeID\": \"10\", \"manualAdjustment\": false } ], \"statutoryDeductionLines\": [ { \"statutoryDeductionTypeID\": \"b5efd8d1-0c93-4a14-a314-b5cba4a4e6b3\", \"amount\": 108.86 } ], \"grossEarningsHistory\": { \"daysPaid\": 3, \"unpaidWeeks\": 0 } }" + "example" : { + "earningsLines" : [ { + "earningsLineID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "displayName" : "Ordinary Time", + "ratePerUnit" : 25, + "numberOfUnits" : 0, + "amount" : 0, + "isLinkedToTimesheet" : false, + "isSystemGenerated" : true + }, { + "earningsLineID" : "65b83d94-f20f-45e1-85ae-387fcf460c26", + "earningsRateID" : "65b83d94-f20f-45e1-85ae-387fcf460c26", + "displayName" : "Salary", + "ratePerUnit" : 0, + "numberOfUnits" : 8, + "amount" : 0, + "isLinkedToTimesheet" : false, + "isSystemGenerated" : false + } ], + "leaveEarningsLines" : [ { + "earningsLineID" : "0441497f-5dc7-4cd3-a90d-f2e07e21b2a6", + "earningsRateID" : "39b3560a-5d2f-4538-924a-4349dc86396e", + "displayName" : "Holiday Pay", + "fixedAmount" : 268.8, + "amount" : 268.8, + "isLinkedToTimesheet" : false, + "isSystemGenerated" : true + } ], + "deductionLines" : [ { + "deductionTypeID" : "a3760fe4-68a4-4e38-8326-fe616af7dc74", + "amount" : 100 + } ], + "leaveAccrualLines" : [ { + "leaveTypeID" : "0441497f-5dc7-4cd3-a90d-f2e07e21b2a6", + "numberOfUnits" : 268.8 + }, { + "leaveTypeID" : "b0b1b79e-2a25-46c2-ad08-ca25ef48d7e4", + "numberOfUnits" : 0 + }, { + "leaveTypeID" : "f2f994cf-1899-46f3-ad4f-5d92d78c3719", + "numberOfUnits" : 0 + }, { + "leaveTypeID" : "34129765-11cb-4d8c-b568-84a2219beda3", + "numberOfUnits" : 0 + } ], + "superannuationLines" : [ { + "superannuationTypeID" : "563273ea-0dae-4f82-86a4-e0db77c008ea", + "displayName" : "KiwiSaver", + "amount" : 108.86, + "fixedAmount" : 3, + "percentage" : 3, + "manualAdjustment" : false + } ], + "employeeTaxLines" : [ { + "taxLineID" : "1084146b-e890-489c-aed3-06de80f63d84", + "amount" : 1057.22, + "globalTaxTypeID" : "11", + "manualAdjustment" : false + } ], + "employerTaxLines" : [ { + "taxLineID" : "6f9eb8cd-0f4a-440b-939c-bdb0f6ad694c", + "amount" : 18.9, + "globalTaxTypeID" : "10", + "manualAdjustment" : false + } ], + "statutoryDeductionLines" : [ { + "statutoryDeductionTypeID" : "b5efd8d1-0c93-4a14-a314-b5cba4a4e6b3", + "amount" : 108.86 + } ], + "grossEarningsHistory" : { + "daysPaid" : 3, + "unpaidWeeks" : 0 + } + } } }, "required" : true @@ -15584,7 +15851,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TimesheetLine" }, - "example" : "{ \"date\": \"2020-08-04\", \"earningsRateID\": \"f9d8f5b5-9049-47f4-8541-35e200f750a5\", \"numberOfUnits\": 2 }" + "example" : { + "date" : "2020-08-04", + "earningsRateID" : "f9d8f5b5-9049-47f4-8541-35e200f750a5", + "numberOfUnits" : 2 + } } }, "required" : true diff --git a/docs/v4/payroll-uk/index.html b/docs/v4/payroll-uk/index.html index e55f2b57..525b190f 100644 --- a/docs/v4/payroll-uk/index.html +++ b/docs/v4/payroll-uk/index.html @@ -1512,7 +1512,7 @@ }; defs["Employee"] = { "title" : "", - "required" : [ "Address", "DateOfBirth", "FirstName", "Gender", "LastName", "Title" ], + "required" : [ "address", "dateOfBirth", "firstName", "gender", "lastName", "title" ], "type" : "object", "properties" : { "employeeID" : { @@ -2260,7 +2260,7 @@ }; defs["Employment"] = { "title" : "", - "required" : [ "EmployeeNumber", "NICategory", "PayrollCalendarID", "StartDate" ], + "required" : [ "employeeNumber", "niCategory", "payrollCalendarID", "startDate" ], "type" : "object", "properties" : { "payrollCalendarID" : { @@ -4036,7 +4036,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Benefit" }, - "example" : "{ \"name\": \"My Big Bennie\", \"category\": \"StakeholderPension\", \"liabilityAccountId\": \"e0faa299-ca0d-4b0a-9e32-0dfabdf9179a\", \"expenseAccountId\": \"4b03500d-32fd-4616-8d70-e1e56e0519c6\", \"standardAmount\": 50, \"percentage\": 25, \"calculationType\": \"PercentageOfGross\" }" + "example" : { + "name" : "My Big Bennie", + "category" : "StakeholderPension", + "liabilityAccountId" : "e0faa299-ca0d-4b0a-9e32-0dfabdf9179a", + "expenseAccountId" : "4b03500d-32fd-4616-8d70-e1e56e0519c6", + "standardAmount" : 50, + "percentage" : 25, + "calculationType" : "PercentageOfGross" + } } }, "required" : true @@ -4191,7 +4199,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Deduction" }, - "example" : "{ \"deductionName\": \"My new deduction\", \"deductionCategory\": \"SalarySacrifice\", \"liabilityAccountId\": \"e0faa299-ca0d-4b0a-9e32-0dfabdf9179a\", \"calculationType\": \"FixedAmount\" }" + "example" : { + "deductionName" : "My new deduction", + "deductionCategory" : "SalarySacrifice", + "liabilityAccountId" : "e0faa299-ca0d-4b0a-9e32-0dfabdf9179a", + "calculationType" : "FixedAmount" + } } }, "required" : true @@ -4346,7 +4359,13 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EarningsRate" }, - "example" : "{ \"name\": \"My Earnings Rate\", \"earningsType\": \"RegularEarnings\", \"rateType\": \"RatePerUnit\", \"typeOfUnits\": \"hours\", \"expenseAccountID\": \"4b03500d-32fd-4616-8d70-e1e56e0519c6\" }" + "example" : { + "name" : "My Earnings Rate", + "earningsType" : "RegularEarnings", + "rateType" : "RatePerUnit", + "typeOfUnits" : "hours", + "expenseAccountID" : "4b03500d-32fd-4616-8d70-e1e56e0519c6" + } } }, "required" : true @@ -4508,7 +4527,20 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employee" }, - "example" : "{ \"title\":\"Mr\", \"firstName\":\"Mike\", \"lastName\":\"Fancy\", \"dateOfBirth\":\"1999-01-01T00:00:00\", \"gender\":\"M\", \"email\":\"mike@starkindustries.com\", \"isOffPayrollWorker\": false, \"address\": { \"addressLine1\": \"171 Midsummer\", \"city\": \"Milton Keyness\", \"postCode\": \"MK9 1EB\" } }" + "example" : { + "title" : "Mr", + "firstName" : "Mike", + "lastName" : "Fancy", + "dateOfBirth" : "1999-01-01T00:00:00", + "gender" : "M", + "email" : "mike@starkindustries.com", + "isOffPayrollWorker" : false, + "address" : { + "addressLine1" : "171 Midsummer", + "city" : "Milton Keyness", + "postCode" : "MK9 1EB" + } + } } }, "required" : true @@ -4893,7 +4925,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeave" }, - "example" : "{ \"leaveTypeID\": \"1d2778ee-86ea-45c0-bbf8-1045485f6b3f\", \"description\": \"Creating a Description\", \"startDate\": \"2020-03-24\", \"endDate\": \"2020-03-26\" }" + "example" : { + "leaveTypeID" : "1d2778ee-86ea-45c0-bbf8-1045485f6b3f", + "description" : "Creating a Description", + "startDate" : "2020-03-24", + "endDate" : "2020-03-26" + } } }, "required" : true @@ -5083,7 +5120,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeaveType" }, - "example" : "{ \"leaveTypeID\": \"4918f233-bd31-43f9-9633-bcc6de1178f2\", \"scheduleOfAccrual\": \"BeginningOfCalendarYear\", \"hoursAccruedAnnually\": 10 }" + "example" : { + "leaveTypeID" : "4918f233-bd31-43f9-9633-bcc6de1178f2", + "scheduleOfAccrual" : "BeginningOfCalendarYear", + "hoursAccruedAnnually" : 10 + } } }, "required" : true @@ -5274,7 +5315,14 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeOpeningBalances" }, - "example" : "{ \"statutoryAdoptionPay\": 10, \"statutoryMaternityPay\": 10, \"statutoryPaternityPay\": 10, \"statutorySharedParentalPay\": 10, \"statutorySickPay\": 10, \"priorEmployeeNumber\": 10 }" + "example" : { + "statutoryAdoptionPay" : 10, + "statutoryMaternityPay" : 10, + "statutoryPaternityPay" : 10, + "statutorySharedParentalPay" : 10, + "statutorySickPay" : 10, + "priorEmployeeNumber" : 10 + } } }, "required" : true @@ -5469,7 +5517,14 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PaymentMethod" }, - "example" : "{ \"paymentMethod\": \"Electronically\", \"bankAccounts\": [ { \"accountName\": \"Sid BofA\", \"accountNumber\": \"24987654\", \"sortCode\": \"287654\" } ] }" + "example" : { + "paymentMethod" : "Electronically", + "bankAccounts" : [ { + "accountName" : "Sid BofA", + "accountNumber" : "24987654", + "sortCode" : "287654" + } ] + } } }, "required" : true @@ -5660,7 +5715,16 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/SalaryAndWage" }, - "example" : "{ \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnitsPerWeek\": 2, \"ratePerUnit\": 10, \"numberOfUnitsPerDay\": 2, \"effectiveFrom\": \"2020-05-01\", \"annualSalary\": 100, \"status\": \"ACTIVE\", \"paymentType\": \"Salary\" }" + "example" : { + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnitsPerWeek" : 2, + "ratePerUnit" : 10, + "numberOfUnitsPerDay" : 2, + "effectiveFrom" : "2020-05-01", + "annualSalary" : 100, + "status" : "ACTIVE", + "paymentType" : "Salary" + } } }, "required" : true @@ -5817,7 +5881,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeStatutorySickLeave" }, - "example" : "{ \"employeeID\": \"aad6b292-7b94-408b-93f6-e489867e3fb0\", \"leaveTypeID\": \"aab78802-e9d3-4bbd-bc87-df858054988f\", \"startDate\": \"2020-04-21\", \"endDate\": \"2020-04-24\", \"workPattern\": [ \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\" ], \"isPregnancyRelated\": false, \"sufficientNotice\": true }" + "example" : { + "employeeID" : "aad6b292-7b94-408b-93f6-e489867e3fb0", + "leaveTypeID" : "aab78802-e9d3-4bbd-bc87-df858054988f", + "startDate" : "2020-04-21", + "endDate" : "2020-04-24", + "workPattern" : [ "Monday", "Tuesday", "Wednesday", "Thursday", "Friday" ], + "isPregnancyRelated" : false, + "sufficientNotice" : true + } } }, "required" : true @@ -6006,7 +6078,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employment" }, - "example" : "{ \"PayrollCalendarID\": \"216d80e6-af55-47b1-b718-9457c3f5d2fe\", \"StartDate\": \"2020-04-01\", \"EmployeeNumber\": \"123ABC\", \"NICategory\": \"A\" }" + "example" : { + "PayrollCalendarID" : "216d80e6-af55-47b1-b718-9457c3f5d2fe", + "StartDate" : "2020-04-01", + "EmployeeNumber" : "123ABC", + "NICategory" : "A" + } } }, "required" : true @@ -6160,7 +6237,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/LeaveType" }, - "example" : "{ \"name\": \"My opebvwbfxf Leave\", \"isPaidLeave\": false, \"showOnPayslip\": true }" + "example" : { + "name" : "My opebvwbfxf Leave", + "isPaidLeave" : false, + "showOnPayslip" : true + } } }, "required" : true @@ -6511,7 +6592,12 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayRunCalendar" }, - "example" : "{ \"name\": \"My Weekly Cal\", \"calendarType\": \"Weekly\", \"periodStartDate\": \"2020-05-01\", \"paymentDate\": \"2020-05-15\" }" + "example" : { + "name" : "My Weekly Cal", + "calendarType" : "Weekly", + "periodStartDate" : "2020-05-01", + "paymentDate" : "2020-05-15" + } } }, "required" : true @@ -6664,7 +6750,10 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Reimbursement" }, - "example" : "{ \"name\": \"My new Reimburse\", \"accountID\": \"9ee28149-32a9-4661-8eab-a28738696983\" }" + "example" : { + "name" : "My new Reimburse", + "accountID" : "9ee28149-32a9-4661-8eab-a28738696983" + } } }, "required" : true @@ -6821,7 +6910,21 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Timesheet" }, - "example" : "{ \"payrollCalendarID\": \"216d80e6-af55-47b1-b718-9457c3f5d2fe\", \"employeeID\": \"aad6b292-7b94-408b-93f6-e489867e3fb0\", \"startDate\": \"2020-04-13\", \"endDate\": \"2020-04-19\", \"timesheetLines\": [ { \"date\": \"2020-04-13\", \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnits\": 8 }, { \"date\": \"2020-04-15\", \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnits\": 6 } ] }" + "example" : { + "payrollCalendarID" : "216d80e6-af55-47b1-b718-9457c3f5d2fe", + "employeeID" : "aad6b292-7b94-408b-93f6-e489867e3fb0", + "startDate" : "2020-04-13", + "endDate" : "2020-04-19", + "timesheetLines" : [ { + "date" : "2020-04-13", + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnits" : 8 + }, { + "date" : "2020-04-15", + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnits" : 6 + } ] + } } }, "required" : true @@ -7013,7 +7116,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TimesheetLine" }, - "example" : "{ \"date\": \"2020-04-14\", \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnits\": 1 }" + "example" : { + "date" : "2020-04-14", + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnits" : 1 + } } }, "required" : true @@ -13387,7 +13494,21 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/Employee" }, - "example" : "{ \"title\": \"Mr.\", \"firstName\": \"TestDataUK\", \"lastName\": \"Tester\", \"dateOfBirth\": \"1992-11-22T00:00:00\", \"gender\": \"M\", \"email\": \"tester@gmail.com\", \"phoneNumber\": \"0400123456\", \"isOffPayrollWorker\": false, \"address\": { \"addressLine1\": \"171 Midsummer\", \"city\": \"Milton Keyness\", \"postCode\": \"MK9 1EB\" } }" + "example" : { + "title" : "Mr.", + "firstName" : "TestDataUK", + "lastName" : "Tester", + "dateOfBirth" : "1992-11-22T00:00:00", + "gender" : "M", + "email" : "tester@gmail.com", + "phoneNumber" : "0400123456", + "isOffPayrollWorker" : false, + "address" : { + "addressLine1" : "171 Midsummer", + "city" : "Milton Keyness", + "postCode" : "MK9 1EB" + } + } } }, "required" : true @@ -13610,7 +13731,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EarningsTemplate" }, - "example" : "{ \"ratePerUnit\": 30, \"numberOfUnits\": 4, \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\" }" + "example" : { + "ratePerUnit" : 30, + "numberOfUnits" : 4, + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27" + } } }, "required" : true @@ -13829,7 +13954,18 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeLeave" }, - "example" : "{ \"leaveTypeID\": \"ed08dffe-788e-4b24-9630-f0fa2f4d164c\", \"description\": \"Creating a Description\", \"startDate\": \"2020-04-24\", \"endDate\": \"2020-04-26\", \"periods\": [ { \"periodStartDate\": \"2020-04-20\", \"periodEndDate\": \"2020-04-26\", \"numberOfUnits\": 1, \"periodStatus\": \"Approved\" } ] }" + "example" : { + "leaveTypeID" : "ed08dffe-788e-4b24-9630-f0fa2f4d164c", + "description" : "Creating a Description", + "startDate" : "2020-04-24", + "endDate" : "2020-04-26", + "periods" : [ { + "periodStartDate" : "2020-04-20", + "periodEndDate" : "2020-04-26", + "numberOfUnits" : 1, + "periodStatus" : "Approved" + } ] + } } }, "required" : true @@ -14020,7 +14156,14 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/EmployeeOpeningBalances" }, - "example" : "{ \"statutoryAdoptionPay\": 20, \"statutoryMaternityPay\": 20, \"statutoryPaternityPay\": 20, \"statutorySharedParentalPay\": 20, \"statutorySickPay\": 20, \"priorEmployeeNumber\": 20 }" + "example" : { + "statutoryAdoptionPay" : 20, + "statutoryMaternityPay" : 20, + "statutoryPaternityPay" : 20, + "statutorySharedParentalPay" : 20, + "statutorySickPay" : 20, + "priorEmployeeNumber" : 20 + } } }, "required" : true @@ -14239,7 +14382,15 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/SalaryAndWage" }, - "example" : "{ \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnitsPerWeek\": 3, \"ratePerUnit\": 11, \"effectiveFrom\": \"2020-05-15\", \"annualSalary\": 101, \"status\": \"ACTIVE\", \"paymentType\": \"Salary\" }" + "example" : { + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnitsPerWeek" : 3, + "ratePerUnit" : 11, + "effectiveFrom" : "2020-05-15", + "annualSalary" : 101, + "status" : "ACTIVE", + "paymentType" : "Salary" + } } }, "required" : true @@ -14430,7 +14581,9 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/PayRun" }, - "example" : "{ \"paymentDate\": \"2020-05-01\" }" + "example" : { + "paymentDate" : "2020-05-01" + } } }, "required" : true @@ -14650,7 +14803,11 @@

Parameters

"schema" : { "$ref" : "#/components/schemas/TimesheetLine" }, - "example" : "{ \"date\": \"2020-04-14\", \"earningsRateID\": \"87f5b43a-cf51-4b74-92de-94c819e82d27\", \"numberOfUnits\": 2 }" + "example" : { + "date" : "2020-04-14", + "earningsRateID" : "87f5b43a-cf51-4b74-92de-94c819e82d27", + "numberOfUnits" : 2 + } } }, "required" : true diff --git a/src/main/java/com/xero/api/client/AccountingApi.java b/src/main/java/com/xero/api/client/AccountingApi.java index e4d8488e..79d49f7c 100644 --- a/src/main/java/com/xero/api/client/AccountingApi.java +++ b/src/main/java/com/xero/api/client/AccountingApi.java @@ -15,8 +15,6 @@ import com.fasterxml.jackson.core.type.TypeReference; import com.google.api.client.auth.oauth2.BearerToken; import com.google.api.client.auth.oauth2.Credential; -import com.google.api.client.http.ByteArrayContent; -import com.google.api.client.http.FileContent; import com.google.api.client.http.GenericUrl; import com.google.api.client.http.HttpContent; import com.google.api.client.http.HttpHeaders; @@ -279,144 +277,6 @@ public HttpResponse createAccountForHttpResponse( .execute(); } - // Overload params for createAccountAttachmentByFileName to allow byte[] or File type to be passed - // as body - /** - * Creates an attachment on a specific account - * - *

200 - Success - return response of type Attachments array of Attachment - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param accountID Unique identifier for Account object - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API - */ - public Attachments createAccountAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID accountID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createAccountAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey, mimeType); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createAccountAttachmentByFileName -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates an attachment on a specific account - * - *

200 - Success - return response of type Attachments array of Attachment - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param accountID Unique identifier for Account object - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public HttpResponse createAccountAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID accountID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createAccountAttachmentByFileName"); - } // verify the required parameter 'accountID' is set - if (accountID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accountID' when calling" - + " createAccountAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createAccountAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling createAccountAttachmentByFileName"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createAccountAttachmentByFileName"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("AccountID", accountID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Accounts/{AccountID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - ByteArrayContent content = null; - - content = new ByteArrayContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - /** * Creates an attachment on a specific account * @@ -544,10 +404,10 @@ public HttpResponse createAccountAttachmentByFileNameForHttpResponse( if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -560,8 +420,6 @@ public HttpResponse createAccountAttachmentByFileNameForHttpResponse( .execute(); } - // Overload params for createBankTransactionAttachmentByFileName to allow byte[] or File type to - // be passed as body /** * Creates an attachment for a specific bank transaction by filename * @@ -575,31 +433,23 @@ public HttpResponse createAccountAttachmentByFileNameForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createBankTransactionAttachmentByFileName( String accessToken, String xeroTenantId, UUID bankTransactionID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createBankTransactionAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - bankTransactionID, - fileName, - body, - idempotencyKey, - mimeType); + accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -610,7 +460,18 @@ public Attachments createBankTransactionAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -630,19 +491,17 @@ public Attachments createBankTransactionAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createBankTransactionAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID bankTransactionID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -691,9 +550,9 @@ public HttpResponse createBankTransactionAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -707,42 +566,41 @@ public HttpResponse createBankTransactionAttachmentByFileNameForHttpResponse( } /** - * Creates an attachment for a specific bank transaction by filename + * Creates a history record for a specific bank transactions * - *

200 - Success - return response of Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createBankTransactionAttachmentByFileName( + public HistoryRecords createBankTransactionHistoryRecord( String accessToken, String xeroTenantId, UUID bankTransactionID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createBankTransactionAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); + createBankTransactionHistoryRecordForHttpResponse( + accessToken, xeroTenantId, bankTransactionID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createBankTransactionAttachmentByFileName -------------------"); + + " : createBankTransactionHistoryRecord -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -752,9 +610,9 @@ public Attachments createBankTransactionAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -765,80 +623,72 @@ public Attachments createBankTransactionAttachmentByFileName( } /** - * Creates an attachment for a specific bank transaction by filename + * Creates a history record for a specific bank transactions * - *

200 - Success - return response of Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createBankTransactionAttachmentByFileNameForHttpResponse( + public HttpResponse createBankTransactionHistoryRecordForHttpResponse( String accessToken, String xeroTenantId, UUID bankTransactionID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " createBankTransactionAttachmentByFileName"); + + " createBankTransactionHistoryRecord"); } // verify the required parameter 'bankTransactionID' is set if (bankTransactionID == null) { throw new IllegalArgumentException( "Missing the required parameter 'bankTransactionID' when calling" - + " createBankTransactionAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createBankTransactionAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " createBankTransactionHistoryRecord"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createBankTransactionAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling" + + " createBankTransactionHistoryRecord"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " createBankTransactionAttachmentByFileName"); + + " createBankTransactionHistoryRecord"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("BankTransactionID", bankTransactionID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() - + "/BankTransactions/{BankTransactionID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/BankTransactions/{BankTransactionID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -852,41 +702,46 @@ public HttpResponse createBankTransactionAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific bank transactions + * Creates one or more spent or received money transaction * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type BankTransactions array with new + * BankTransaction * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * @param bankTransactions BankTransactions with an array of BankTransaction objects in body of * request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return BankTransactions * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createBankTransactionHistoryRecord( + public BankTransactions createBankTransactions( String accessToken, String xeroTenantId, - UUID bankTransactionID, - HistoryRecords historyRecords, + BankTransactions bankTransactions, + Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createBankTransactionHistoryRecordForHttpResponse( - accessToken, xeroTenantId, bankTransactionID, historyRecords, idempotencyKey); + createBankTransactionsForHttpResponse( + accessToken, xeroTenantId, bankTransactions, summarizeErrors, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createBankTransactionHistoryRecord -------------------"); + + " : createBankTransactions -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -896,150 +751,9 @@ public HistoryRecords createBankTransactionHistoryRecord( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); + handler.validationError("BankTransactions", object.getMessage(), e); } - handler.validationError("HistoryRecords", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a history record for a specific bank transactions - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createBankTransactionHistoryRecordForHttpResponse( - String accessToken, - String xeroTenantId, - UUID bankTransactionID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createBankTransactionHistoryRecord"); - } // verify the required parameter 'bankTransactionID' is set - if (bankTransactionID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransactionID' when calling" - + " createBankTransactionHistoryRecord"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling" - + " createBankTransactionHistoryRecord"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createBankTransactionHistoryRecord"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("BankTransactionID", bankTransactionID); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/BankTransactions/{BankTransactionID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates one or more spent or received money transaction - * - *

200 - Success - return response of type BankTransactions array with new - * BankTransaction - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactions BankTransactions with an array of BankTransaction objects in body of - * request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return BankTransactions - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public BankTransactions createBankTransactions( - String accessToken, - String xeroTenantId, - BankTransactions bankTransactions, - Boolean summarizeErrors, - Integer unitdp, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createBankTransactionsForHttpResponse( - accessToken, xeroTenantId, bankTransactions, summarizeErrors, unitdp, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createBankTransactions -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("BankTransactions", object.getMessage(), e); - } - handler.validationError("BankTransactions", object, e); + handler.validationError("BankTransactions", object, e); } else { handler.execute(e); } @@ -1269,8 +983,6 @@ public HttpResponse createBankTransferForHttpResponse( .execute(); } - // Overload params for createBankTransferAttachmentByFileName to allow byte[] or File type to be - // passed as body /** * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank * Transfer @@ -1283,25 +995,23 @@ public HttpResponse createBankTransferForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createBankTransferAttachmentByFileName( String accessToken, String xeroTenantId, UUID bankTransferID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createBankTransferAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -1312,7 +1022,18 @@ public Attachments createBankTransferAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -1331,19 +1052,17 @@ public Attachments createBankTransferAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createBankTransferAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID bankTransferID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -1391,9 +1110,9 @@ public HttpResponse createBankTransferAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -1407,41 +1126,41 @@ public HttpResponse createBankTransferAttachmentByFileNameForHttpResponse( } /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer + * Creates a history record for a specific bank transfer + * + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createBankTransferAttachmentByFileName( + public HistoryRecords createBankTransferHistoryRecord( String accessToken, String xeroTenantId, UUID bankTransferID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createBankTransferAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); + createBankTransferHistoryRecordForHttpResponse( + accessToken, xeroTenantId, bankTransferID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createBankTransferAttachmentByFileName -------------------"); + + " : createBankTransferHistoryRecord -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -1451,9 +1170,9 @@ public Attachments createBankTransferAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -1464,78 +1183,71 @@ public Attachments createBankTransferAttachmentByFileName( } /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer + * Creates a history record for a specific bank transfer + * + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createBankTransferAttachmentByFileNameForHttpResponse( + public HttpResponse createBankTransferHistoryRecordForHttpResponse( String accessToken, String xeroTenantId, UUID bankTransferID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " createBankTransferAttachmentByFileName"); + + " createBankTransferHistoryRecord"); } // verify the required parameter 'bankTransferID' is set if (bankTransferID == null) { throw new IllegalArgumentException( "Missing the required parameter 'bankTransferID' when calling" - + " createBankTransferAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createBankTransferAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " createBankTransferHistoryRecord"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createBankTransferAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling" + + " createBankTransferHistoryRecord"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " createBankTransferAttachmentByFileName"); + + " createBankTransferHistoryRecord"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("BankTransferID", bankTransferID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -1549,166 +1261,31 @@ public HttpResponse createBankTransferAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific bank transfer + * Creates one or many batch payments for invoices * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type BatchPayments array of BatchPayment objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param batchPayments BatchPayments with an array of Payments in body of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return BatchPayments * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createBankTransferHistoryRecord( + public BatchPayments createBatchPayment( String accessToken, String xeroTenantId, - UUID bankTransferID, - HistoryRecords historyRecords, + BatchPayments batchPayments, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createBankTransferHistoryRecordForHttpResponse( - accessToken, xeroTenantId, bankTransferID, historyRecords, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createBankTransferHistoryRecord -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); - } - handler.validationError("HistoryRecords", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a history record for a specific bank transfer - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createBankTransferHistoryRecordForHttpResponse( - String accessToken, - String xeroTenantId, - UUID bankTransferID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createBankTransferHistoryRecord"); - } // verify the required parameter 'bankTransferID' is set - if (bankTransferID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransferID' when calling" - + " createBankTransferHistoryRecord"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling" - + " createBankTransferHistoryRecord"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createBankTransferHistoryRecord"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("BankTransferID", bankTransferID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates one or many batch payments for invoices - * - *

200 - Success - return response of type BatchPayments array of BatchPayment objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param batchPayments BatchPayments with an array of Payments in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return BatchPayments - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public BatchPayments createBatchPayment( - String accessToken, - String xeroTenantId, - BatchPayments batchPayments, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = createBatchPaymentForHttpResponse( accessToken, xeroTenantId, batchPayments, summarizeErrors, idempotencyKey); @@ -2096,8 +1673,6 @@ public HttpResponse createBrandingThemePaymentServicesForHttpResponse( .execute(); } - // Overload params for createContactAttachmentByFileName to allow byte[] or File type to be passed - // as body /** * 200 - Success - return response of type Attachments array with an newly created * Attachment @@ -2110,25 +1685,23 @@ public HttpResponse createBrandingThemePaymentServicesForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createContactAttachmentByFileName( String accessToken, String xeroTenantId, UUID contactID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createContactAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -2139,7 +1712,18 @@ public Attachments createContactAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -2158,19 +1742,17 @@ public Attachments createContactAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createContactAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID contactID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -2217,9 +1799,9 @@ public HttpResponse createContactAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -2233,41 +1815,36 @@ public HttpResponse createContactAttachmentByFileNameForHttpResponse( } /** - * 200 - Success - return response of type Attachments array with an newly created - * Attachment + * Creates a contact group * - *

400 - A failed request due to validation error + *

200 - Success - return response of type Contact Groups array of newly created Contact + * Group + * + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param contactGroups ContactGroups with an array of names in request body * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return ContactGroups * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createContactAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID contactID, - String fileName, - File body, - String idempotencyKey) + public ContactGroups createContactGroup( + String accessToken, String xeroTenantId, ContactGroups contactGroups, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createContactAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); + createContactGroupForHttpResponse( + accessToken, xeroTenantId, contactGroups, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createContactAttachmentByFileName -------------------"); + + " : createContactGroup -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -2277,9 +1854,9 @@ public Attachments createContactAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("ContactGroups", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("ContactGroups", object, e); } else { handler.execute(e); } @@ -2290,77 +1867,53 @@ public Attachments createContactAttachmentByFileName( } /** - * 200 - Success - return response of type Attachments array with an newly created - * Attachment + * Creates a contact group * - *

400 - A failed request due to validation error + *

200 - Success - return response of type Contact Groups array of newly created Contact + * Group + * + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param contactGroups ContactGroups with an array of names in request body * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createContactAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID contactID, - String fileName, - File body, - String idempotencyKey) + public HttpResponse createContactGroupForHttpResponse( + String accessToken, String xeroTenantId, ContactGroups contactGroups, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createContactAttachmentByFileName"); - } // verify the required parameter 'contactID' is set - if (contactID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'contactID' when calling" - + " createContactAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createContactAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'xeroTenantId' when calling createContactGroup"); + } // verify the required parameter 'contactGroups' is set + if (contactGroups == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling createContactAttachmentByFileName"); + "Missing the required parameter 'contactGroups' when calling createContactGroup"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createContactAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createContactGroup"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ContactID", contactID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Contacts/{ContactID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/ContactGroups"); + String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(contactGroups); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -2374,121 +1927,9 @@ public HttpResponse createContactAttachmentByFileNameForHttpResponse( } /** - * Creates a contact group + * Creates contacts to a specific contact group * - *

200 - Success - return response of type Contact Groups array of newly created Contact - * Group - * - *

400 - Validation Error - some data was incorrect returns response of type Error - * - * @param xeroTenantId Xero identifier for Tenant - * @param contactGroups ContactGroups with an array of names in request body - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return ContactGroups - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public ContactGroups createContactGroup( - String accessToken, String xeroTenantId, ContactGroups contactGroups, String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createContactGroupForHttpResponse( - accessToken, xeroTenantId, contactGroups, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createContactGroup -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ContactGroups", object.getMessage(), e); - } - handler.validationError("ContactGroups", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a contact group - * - *

200 - Success - return response of type Contact Groups array of newly created Contact - * Group - * - *

400 - Validation Error - some data was incorrect returns response of type Error - * - * @param xeroTenantId Xero identifier for Tenant - * @param contactGroups ContactGroups with an array of names in request body - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createContactGroupForHttpResponse( - String accessToken, String xeroTenantId, ContactGroups contactGroups, String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createContactGroup"); - } // verify the required parameter 'contactGroups' is set - if (contactGroups == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'contactGroups' when calling createContactGroup"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createContactGroup"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/ContactGroups"); - String url = uriBuilder.build().toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(contactGroups); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates contacts to a specific contact group - * - *

200 - Success - return response of type Contacts array of added Contacts + *

200 - Success - return response of type Contacts array of added Contacts * *

400 - A failed request due to validation error * @@ -3052,8 +2493,6 @@ public HttpResponse createCreditNoteAllocationForHttpResponse( .execute(); } - // Overload params for createCreditNoteAttachmentByFileName to allow byte[] or File type to be - // passed as body /** * Creates an attachment for a specific credit note * @@ -3070,20 +2509,18 @@ public HttpResponse createCreditNoteAllocationForHttpResponse( * invoice * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createCreditNoteAttachmentByFileName( String accessToken, String xeroTenantId, UUID creditNoteID, String fileName, - byte[] body, + File body, Boolean includeOnline, - String idempotencyKey, - String mimeType) + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; @@ -3095,8 +2532,7 @@ public Attachments createCreditNoteAttachmentByFileName( fileName, body, includeOnline, - idempotencyKey, - mimeType); + idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -3107,7 +2543,18 @@ public Attachments createCreditNoteAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -3130,20 +2577,18 @@ public Attachments createCreditNoteAttachmentByFileName( * invoice * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createCreditNoteAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID creditNoteID, String fileName, - byte[] body, + File body, Boolean includeOnline, - String idempotencyKey, - String mimeType) + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -3211,9 +2656,9 @@ public HttpResponse createCreditNoteAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -3227,52 +2672,41 @@ public HttpResponse createCreditNoteAttachmentByFileNameForHttpResponse( } /** - * Creates an attachment for a specific credit note + * Retrieves history records of a specific credit note * - *

200 - Success - return response of type Attachments array with newly created - * Attachment for specific Credit Note + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param creditNoteID Unique identifier for a Credit Note - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param includeOnline Allows an attachment to be seen by the end customer within their online - * invoice + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createCreditNoteAttachmentByFileName( + public HistoryRecords createCreditNoteHistory( String accessToken, String xeroTenantId, UUID creditNoteID, - String fileName, - File body, - Boolean includeOnline, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createCreditNoteAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - creditNoteID, - fileName, - body, - includeOnline, - idempotencyKey); + createCreditNoteHistoryForHttpResponse( + accessToken, xeroTenantId, creditNoteID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createCreditNoteAttachmentByFileName -------------------"); + + " : createCreditNoteHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -3282,9 +2716,9 @@ public Attachments createCreditNoteAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -3295,103 +2729,67 @@ public Attachments createCreditNoteAttachmentByFileName( } /** - * Creates an attachment for a specific credit note + * Retrieves history records of a specific credit note * - *

200 - Success - return response of type Attachments array with newly created - * Attachment for specific Credit Note + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param creditNoteID Unique identifier for a Credit Note - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param includeOnline Allows an attachment to be seen by the end customer within their online - * invoice + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createCreditNoteAttachmentByFileNameForHttpResponse( + public HttpResponse createCreditNoteHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID creditNoteID, - String fileName, - File body, - Boolean includeOnline, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createCreditNoteAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling createCreditNoteHistory"); } // verify the required parameter 'creditNoteID' is set if (creditNoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'creditNoteID' when calling" - + " createCreditNoteAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createCreditNoteAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'creditNoteID' when calling createCreditNoteHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createCreditNoteAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling createCreditNoteHistory"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createCreditNoteAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createCreditNoteHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("CreditNoteID", creditNoteID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/Attachments/{FileName}"); - if (includeOnline != null) { - String key = "IncludeOnline"; - Object value = includeOnline; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } + UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -3405,157 +2803,26 @@ public HttpResponse createCreditNoteAttachmentByFileNameForHttpResponse( } /** - * Retrieves history records of a specific credit note + * Creates a new credit note * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type Credit Notes array of newly created + * CreditNote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param creditNotes Credit Notes with array of CreditNote object in body of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return CreditNotes * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createCreditNoteHistory( - String accessToken, - String xeroTenantId, - UUID creditNoteID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createCreditNoteHistoryForHttpResponse( - accessToken, xeroTenantId, creditNoteID, historyRecords, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createCreditNoteHistory -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); - } - handler.validationError("HistoryRecords", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Retrieves history records of a specific credit note - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createCreditNoteHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID creditNoteID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createCreditNoteHistory"); - } // verify the required parameter 'creditNoteID' is set - if (creditNoteID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'creditNoteID' when calling createCreditNoteHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling createCreditNoteHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createCreditNoteHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("CreditNoteID", creditNoteID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates a new credit note - * - *

200 - Success - return response of type Credit Notes array of newly created - * CreditNote - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param creditNotes Credit Notes with array of CreditNote object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return CreditNotes - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public CreditNotes createCreditNotes( + public CreditNotes createCreditNotes( String accessToken, String xeroTenantId, CreditNotes creditNotes, @@ -4193,8 +3460,6 @@ public HttpResponse createExpenseClaimsForHttpResponse( .execute(); } - // Overload params for createInvoiceAttachmentByFileName to allow byte[] or File type to be passed - // as body /** * Creates an attachment for a specific invoice or purchase bill by filename * @@ -4211,33 +3476,24 @@ public HttpResponse createExpenseClaimsForHttpResponse( * invoice * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createInvoiceAttachmentByFileName( String accessToken, String xeroTenantId, UUID invoiceID, String fileName, - byte[] body, + File body, Boolean includeOnline, - String idempotencyKey, - String mimeType) + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createInvoiceAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - invoiceID, - fileName, - body, - includeOnline, - idempotencyKey, - mimeType); + accessToken, xeroTenantId, invoiceID, fileName, body, includeOnline, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -4248,7 +3504,18 @@ public Attachments createInvoiceAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -4271,20 +3538,18 @@ public Attachments createInvoiceAttachmentByFileName( * invoice * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createInvoiceAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID invoiceID, String fileName, - byte[] body, + File body, Boolean includeOnline, - String idempotencyKey, - String mimeType) + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -4351,9 +3616,9 @@ public HttpResponse createInvoiceAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -4367,46 +3632,41 @@ public HttpResponse createInvoiceAttachmentByFileNameForHttpResponse( } /** - * Creates an attachment for a specific invoice or purchase bill by filename + * Creates a history record for a specific invoice * - *

200 - Success - return response of type Attachments array with newly created - * Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param invoiceID Unique identifier for an Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param includeOnline Allows an attachment to be seen by the end customer within their online - * invoice + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createInvoiceAttachmentByFileName( + public HistoryRecords createInvoiceHistory( String accessToken, String xeroTenantId, UUID invoiceID, - String fileName, - File body, - Boolean includeOnline, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createInvoiceAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, invoiceID, fileName, body, includeOnline, idempotencyKey); + createInvoiceHistoryForHttpResponse( + accessToken, xeroTenantId, invoiceID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createInvoiceAttachmentByFileName -------------------"); + + " : createInvoiceHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -4416,9 +3676,9 @@ public Attachments createInvoiceAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -4429,230 +3689,64 @@ public Attachments createInvoiceAttachmentByFileName( } /** - * Creates an attachment for a specific invoice or purchase bill by filename + * Creates a history record for a specific invoice * - *

200 - Success - return response of type Attachments array with newly created - * Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param invoiceID Unique identifier for an Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param includeOnline Allows an attachment to be seen by the end customer within their online - * invoice + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createInvoiceAttachmentByFileNameForHttpResponse( + public HttpResponse createInvoiceHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID invoiceID, - String fileName, - File body, - Boolean includeOnline, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createInvoiceAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling createInvoiceHistory"); } // verify the required parameter 'invoiceID' is set if (invoiceID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'invoiceID' when calling" - + " createInvoiceAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createInvoiceAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'invoiceID' when calling createInvoiceHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling createInvoiceAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling createInvoiceHistory"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createInvoiceAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createInvoiceHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("InvoiceID", invoiceID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Invoices/{InvoiceID}/Attachments/{FileName}"); - if (includeOnline != null) { - String key = "IncludeOnline"; - Object value = includeOnline; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } + UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices/{InvoiceID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); - HttpContent content = null; - content = new FileContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates a history record for a specific invoice - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public HistoryRecords createInvoiceHistory( - String accessToken, - String xeroTenantId, - UUID invoiceID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createInvoiceHistoryForHttpResponse( - accessToken, xeroTenantId, invoiceID, historyRecords, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createInvoiceHistory -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); - } - handler.validationError("HistoryRecords", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a history record for a specific invoice - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createInvoiceHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID invoiceID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createInvoiceHistory"); - } // verify the required parameter 'invoiceID' is set - if (invoiceID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'invoiceID' when calling createInvoiceHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling createInvoiceHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createInvoiceHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("InvoiceID", invoiceID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices/{InvoiceID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - + HttpContent content = null; content = apiClient.new JacksonJsonHttpContent(historyRecords); @@ -5249,8 +4343,6 @@ public HttpResponse createLinkedTransactionForHttpResponse( .execute(); } - // Overload params for createManualJournalAttachmentByFileName to allow byte[] or File type to be - // passed as body /** * Creates a specific attachment for a specific manual journal by file name * @@ -5265,25 +4357,23 @@ public HttpResponse createLinkedTransactionForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createManualJournalAttachmentByFileName( String accessToken, String xeroTenantId, UUID manualJournalID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createManualJournalAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -5294,7 +4384,18 @@ public Attachments createManualJournalAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -5315,19 +4416,17 @@ public Attachments createManualJournalAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createManualJournalAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID manualJournalID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -5375,9 +4474,9 @@ public HttpResponse createManualJournalAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -5391,43 +4490,41 @@ public HttpResponse createManualJournalAttachmentByFileNameForHttpResponse( } /** - * Creates a specific attachment for a specific manual journal by file name + * Creates a history record for a specific manual journal * - *

200 - Success - return response of type Attachments array with a newly created - * Attachment for a ManualJournals + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createManualJournalAttachmentByFileName( + public HistoryRecords createManualJournalHistoryRecord( String accessToken, String xeroTenantId, UUID manualJournalID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createManualJournalAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); + createManualJournalHistoryRecordForHttpResponse( + accessToken, xeroTenantId, manualJournalID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createManualJournalAttachmentByFileName -------------------"); + + " : createManualJournalHistoryRecord -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -5437,9 +4534,9 @@ public Attachments createManualJournalAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -5450,80 +4547,71 @@ public Attachments createManualJournalAttachmentByFileName( } /** - * Creates a specific attachment for a specific manual journal by file name + * Creates a history record for a specific manual journal * - *

200 - Success - return response of type Attachments array with a newly created - * Attachment for a ManualJournals + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createManualJournalAttachmentByFileNameForHttpResponse( + public HttpResponse createManualJournalHistoryRecordForHttpResponse( String accessToken, String xeroTenantId, UUID manualJournalID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " createManualJournalAttachmentByFileName"); + + " createManualJournalHistoryRecord"); } // verify the required parameter 'manualJournalID' is set if (manualJournalID == null) { throw new IllegalArgumentException( "Missing the required parameter 'manualJournalID' when calling" - + " createManualJournalAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createManualJournalAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " createManualJournalHistoryRecord"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createManualJournalAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling" + + " createManualJournalHistoryRecord"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " createManualJournalAttachmentByFileName"); + + " createManualJournalHistoryRecord"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("ManualJournalID", manualJournalID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -5537,41 +4625,42 @@ public HttpResponse createManualJournalAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific manual journal + * Creates one or more manual journals * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type ManualJournals array with newly created + * ManualJournal * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param manualJournals ManualJournals array with ManualJournal object in body of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return ManualJournals * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createManualJournalHistoryRecord( + public ManualJournals createManualJournals( String accessToken, String xeroTenantId, - UUID manualJournalID, - HistoryRecords historyRecords, + ManualJournals manualJournals, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createManualJournalHistoryRecordForHttpResponse( - accessToken, xeroTenantId, manualJournalID, historyRecords, idempotencyKey); + createManualJournalsForHttpResponse( + accessToken, xeroTenantId, manualJournals, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createManualJournalHistoryRecord -------------------"); + + " : createManualJournals -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -5581,9 +4670,9 @@ public HistoryRecords createManualJournalHistoryRecord( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); + handler.validationError("ManualJournals", object.getMessage(), e); } - handler.validationError("HistoryRecords", object, e); + handler.validationError("ManualJournals", object, e); } else { handler.execute(e); } @@ -5594,143 +4683,7 @@ public HistoryRecords createManualJournalHistoryRecord( } /** - * Creates a history record for a specific manual journal - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createManualJournalHistoryRecordForHttpResponse( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createManualJournalHistoryRecord"); - } // verify the required parameter 'manualJournalID' is set - if (manualJournalID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'manualJournalID' when calling" - + " createManualJournalHistoryRecord"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling" - + " createManualJournalHistoryRecord"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createManualJournalHistoryRecord"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ManualJournalID", manualJournalID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates one or more manual journals - * - *

200 - Success - return response of type ManualJournals array with newly created - * ManualJournal - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournals ManualJournals array with ManualJournal object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return ManualJournals - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public ManualJournals createManualJournals( - String accessToken, - String xeroTenantId, - ManualJournals manualJournals, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createManualJournalsForHttpResponse( - accessToken, xeroTenantId, manualJournals, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createManualJournals -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ManualJournals", object.getMessage(), e); - } - handler.validationError("ManualJournals", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates one or more manual journals + * Creates one or more manual journals * *

200 - Success - return response of type ManualJournals array with newly created * ManualJournal @@ -6909,8 +5862,6 @@ public HttpResponse createPrepaymentHistoryForHttpResponse( .execute(); } - // Overload params for createPurchaseOrderAttachmentByFileName to allow byte[] or File type to be - // passed as body /** * Creates attachment for a specific purchase order * @@ -6924,25 +5875,23 @@ public HttpResponse createPrepaymentHistoryForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createPurchaseOrderAttachmentByFileName( String accessToken, String xeroTenantId, UUID purchaseOrderID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createPurchaseOrderAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -6953,7 +5902,18 @@ public Attachments createPurchaseOrderAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -6973,19 +5933,17 @@ public Attachments createPurchaseOrderAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createPurchaseOrderAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID purchaseOrderID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -7033,9 +5991,9 @@ public HttpResponse createPurchaseOrderAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -7049,42 +6007,41 @@ public HttpResponse createPurchaseOrderAttachmentByFileNameForHttpResponse( } /** - * Creates attachment for a specific purchase order + * Creates a history record for a specific purchase orders * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createPurchaseOrderAttachmentByFileName( + public HistoryRecords createPurchaseOrderHistory( String accessToken, String xeroTenantId, UUID purchaseOrderID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createPurchaseOrderAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); + createPurchaseOrderHistoryForHttpResponse( + accessToken, xeroTenantId, purchaseOrderID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createPurchaseOrderAttachmentByFileName -------------------"); + + " : createPurchaseOrderHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -7094,9 +6051,9 @@ public Attachments createPurchaseOrderAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -7107,79 +6064,69 @@ public Attachments createPurchaseOrderAttachmentByFileName( } /** - * Creates attachment for a specific purchase order + * Creates a history record for a specific purchase orders * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createPurchaseOrderAttachmentByFileNameForHttpResponse( + public HttpResponse createPurchaseOrderHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID purchaseOrderID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createPurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling createPurchaseOrderHistory"); } // verify the required parameter 'purchaseOrderID' is set if (purchaseOrderID == null) { throw new IllegalArgumentException( "Missing the required parameter 'purchaseOrderID' when calling" - + " createPurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createPurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " createPurchaseOrderHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createPurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling" + + " createPurchaseOrderHistory"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createPurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createPurchaseOrderHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("PurchaseOrderID", purchaseOrderID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -7193,41 +6140,42 @@ public HttpResponse createPurchaseOrderAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific purchase orders + * Creates one or more purchase orders * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type PurchaseOrder array for specified + * PurchaseOrder * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param purchaseOrders PurchaseOrders with an array of PurchaseOrder object in body of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return PurchaseOrders * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createPurchaseOrderHistory( + public PurchaseOrders createPurchaseOrders( String accessToken, String xeroTenantId, - UUID purchaseOrderID, - HistoryRecords historyRecords, + PurchaseOrders purchaseOrders, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createPurchaseOrderHistoryForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, historyRecords, idempotencyKey); + createPurchaseOrdersForHttpResponse( + accessToken, xeroTenantId, purchaseOrders, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createPurchaseOrderHistory -------------------"); + + " : createPurchaseOrders -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -7237,141 +6185,7 @@ public HistoryRecords createPurchaseOrderHistory( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); - } - handler.validationError("HistoryRecords", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a history record for a specific purchase orders - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createPurchaseOrderHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID purchaseOrderID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createPurchaseOrderHistory"); - } // verify the required parameter 'purchaseOrderID' is set - if (purchaseOrderID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrderID' when calling" - + " createPurchaseOrderHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling" - + " createPurchaseOrderHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createPurchaseOrderHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("PurchaseOrderID", purchaseOrderID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates one or more purchase orders - * - *

200 - Success - return response of type PurchaseOrder array for specified - * PurchaseOrder - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrders PurchaseOrders with an array of PurchaseOrder object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return PurchaseOrders - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public PurchaseOrders createPurchaseOrders( - String accessToken, - String xeroTenantId, - PurchaseOrders purchaseOrders, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createPurchaseOrdersForHttpResponse( - accessToken, xeroTenantId, purchaseOrders, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createPurchaseOrders -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("PurchaseOrders", object.getMessage(), e); + handler.validationError("PurchaseOrders", object.getMessage(), e); } handler.validationError("PurchaseOrders", object, e); } else { @@ -7469,8 +6283,6 @@ public HttpResponse createPurchaseOrdersForHttpResponse( .execute(); } - // Overload params for createQuoteAttachmentByFileName to allow byte[] or File type to be passed - // as body /** * Creates attachment for a specific quote * @@ -7484,25 +6296,23 @@ public HttpResponse createPurchaseOrdersForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createQuoteAttachmentByFileName( String accessToken, String xeroTenantId, UUID quoteID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createQuoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -7513,7 +6323,18 @@ public Attachments createQuoteAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -7533,19 +6354,17 @@ public Attachments createQuoteAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createQuoteAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID quoteID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -7589,9 +6408,9 @@ public HttpResponse createQuoteAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -7605,42 +6424,41 @@ public HttpResponse createQuoteAttachmentByFileNameForHttpResponse( } /** - * Creates attachment for a specific quote + * Creates a history record for a specific quote * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param quoteID Unique identifier for an Quote - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createQuoteAttachmentByFileName( + public HistoryRecords createQuoteHistory( String accessToken, String xeroTenantId, UUID quoteID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createQuoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); + createQuoteHistoryForHttpResponse( + accessToken, xeroTenantId, quoteID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createQuoteAttachmentByFileName -------------------"); + + " : createQuoteHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -7650,9 +6468,9 @@ public Attachments createQuoteAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -7663,75 +6481,67 @@ public Attachments createQuoteAttachmentByFileName( } /** - * Creates attachment for a specific quote + * Creates a history record for a specific quote * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param quoteID Unique identifier for an Quote - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createQuoteAttachmentByFileNameForHttpResponse( + public HttpResponse createQuoteHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID quoteID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createQuoteAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling createQuoteHistory"); } // verify the required parameter 'quoteID' is set if (quoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quoteID' when calling createQuoteAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling createQuoteAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'quoteID' when calling createQuoteHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling createQuoteAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling createQuoteHistory"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createQuoteAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createQuoteHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("QuoteID", quoteID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -7745,41 +6555,41 @@ public HttpResponse createQuoteAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific quote + * Create one or more quotes * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type Quotes with array with newly created Quote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param quotes Quotes with an array of Quote object in body of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return Quotes * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createQuoteHistory( + public Quotes createQuotes( String accessToken, String xeroTenantId, - UUID quoteID, - HistoryRecords historyRecords, + Quotes quotes, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createQuoteHistoryForHttpResponse( - accessToken, xeroTenantId, quoteID, historyRecords, idempotencyKey); + createQuotesForHttpResponse( + accessToken, xeroTenantId, quotes, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createQuoteHistory -------------------"); + + " : createQuotes -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -7789,9 +6599,9 @@ public HistoryRecords createQuoteHistory( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); + handler.validationError("Quotes", object.getMessage(), e); } - handler.validationError("HistoryRecords", object, e); + handler.validationError("Quotes", object, e); } else { handler.execute(e); } @@ -7802,138 +6612,7 @@ public HistoryRecords createQuoteHistory( } /** - * Creates a history record for a specific quote - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createQuoteHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID quoteID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createQuoteHistory"); - } // verify the required parameter 'quoteID' is set - if (quoteID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'quoteID' when calling createQuoteHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling createQuoteHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createQuoteHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("QuoteID", quoteID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Create one or more quotes - * - *

200 - Success - return response of type Quotes with array with newly created Quote - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param quotes Quotes with an array of Quote object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return Quotes - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public Quotes createQuotes( - String accessToken, - String xeroTenantId, - Quotes quotes, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createQuotesForHttpResponse( - accessToken, xeroTenantId, quotes, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createQuotes -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Quotes", object.getMessage(), e); - } - handler.validationError("Quotes", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Create one or more quotes + * Create one or more quotes * *

200 - Success - return response of type Quotes with array with newly created Quote * @@ -8158,8 +6837,6 @@ public HttpResponse createReceiptForHttpResponse( .execute(); } - // Overload params for createReceiptAttachmentByFileName to allow byte[] or File type to be passed - // as body /** * Creates an attachment on a specific expense claim receipts by file name * @@ -8174,25 +6851,23 @@ public HttpResponse createReceiptForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments createReceiptAttachmentByFileName( String accessToken, String xeroTenantId, UUID receiptID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = createReceiptAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -8203,7 +6878,18 @@ public Attachments createReceiptAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -8224,19 +6910,17 @@ public Attachments createReceiptAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createReceiptAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID receiptID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -8283,9 +6967,9 @@ public HttpResponse createReceiptAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -8299,43 +6983,42 @@ public HttpResponse createReceiptAttachmentByFileNameForHttpResponse( } /** - * Creates an attachment on a specific expense claim receipts by file name + * Creates a history record for a specific receipt * - *

200 - Success - return response of type Attachments array with newly created - * Attachment for a specified Receipt + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * - *

400 - A failed request due to validation error + *

400 - Unsupported - return response incorrect exception, API is not able to create + * HistoryRecord for Receipts * * @param xeroTenantId Xero identifier for Tenant * @param receiptID Unique identifier for a Receipt - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createReceiptAttachmentByFileName( + public HistoryRecords createReceiptHistory( String accessToken, String xeroTenantId, UUID receiptID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createReceiptAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey); + createReceiptHistoryForHttpResponse( + accessToken, xeroTenantId, receiptID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createReceiptAttachmentByFileName -------------------"); + + " : createReceiptHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -8345,9 +7028,9 @@ public Attachments createReceiptAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -8358,79 +7041,68 @@ public Attachments createReceiptAttachmentByFileName( } /** - * Creates an attachment on a specific expense claim receipts by file name + * Creates a history record for a specific receipt * - *

200 - Success - return response of type Attachments array with newly created - * Attachment for a specified Receipt + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * - *

400 - A failed request due to validation error + *

400 - Unsupported - return response incorrect exception, API is not able to create + * HistoryRecord for Receipts * * @param xeroTenantId Xero identifier for Tenant * @param receiptID Unique identifier for a Receipt - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createReceiptAttachmentByFileNameForHttpResponse( + public HttpResponse createReceiptHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID receiptID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createReceiptAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling createReceiptHistory"); } // verify the required parameter 'receiptID' is set if (receiptID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'receiptID' when calling" - + " createReceiptAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createReceiptAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'receiptID' when calling createReceiptHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling createReceiptAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling createReceiptHistory"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createReceiptAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling createReceiptHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("ReceiptID", receiptID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Receipts/{ReceiptID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/Receipts/{ReceiptID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -8444,42 +7116,43 @@ public HttpResponse createReceiptAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific receipt + * Creates an attachment from a specific repeating invoices by file name * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type Attachments array with updated Attachment for + * a specified Repeating Invoice * - *

400 - Unsupported - return response incorrect exception, API is not able to create - * HistoryRecord for Receipts + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param receiptID Unique identifier for a Receipt - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param repeatingInvoiceID Unique identifier for a Repeating Invoice + * @param fileName Name of the attachment + * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return Attachments * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createReceiptHistory( + public Attachments createRepeatingInvoiceAttachmentByFileName( String accessToken, String xeroTenantId, - UUID receiptID, - HistoryRecords historyRecords, + UUID repeatingInvoiceID, + String fileName, + File body, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createReceiptHistoryForHttpResponse( - accessToken, xeroTenantId, receiptID, historyRecords, idempotencyKey); + createRepeatingInvoiceAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createReceiptHistory -------------------"); + + " : createRepeatingInvoiceAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -8489,9 +7162,9 @@ public HistoryRecords createReceiptHistory( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); + handler.validationError("Attachments", object.getMessage(), e); } - handler.validationError("HistoryRecords", object, e); + handler.validationError("Attachments", object, e); } else { handler.execute(e); } @@ -8501,139 +7174,6 @@ public HistoryRecords createReceiptHistory( return null; } - /** - * Creates a history record for a specific receipt - * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects - * - *

400 - Unsupported - return response incorrect exception, API is not able to create - * HistoryRecord for Receipts - * - * @param xeroTenantId Xero identifier for Tenant - * @param receiptID Unique identifier for a Receipt - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createReceiptHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID receiptID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling createReceiptHistory"); - } // verify the required parameter 'receiptID' is set - if (receiptID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'receiptID' when calling createReceiptHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling createReceiptHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling createReceiptHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ReceiptID", receiptID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Receipts/{ReceiptID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - // Overload params for createRepeatingInvoiceAttachmentByFileName to allow byte[] or File type to - // be passed as body - /** - * Creates an attachment from a specific repeating invoices by file name - * - *

200 - Success - return response of type Attachments array with updated Attachment for - * a specified Repeating Invoice - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API - */ - public Attachments createRepeatingInvoiceAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID repeatingInvoiceID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createRepeatingInvoiceAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - repeatingInvoiceID, - fileName, - body, - idempotencyKey, - mimeType); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createRepeatingInvoiceAttachmentByFileName -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - /** * Creates an attachment from a specific repeating invoices by file name * @@ -8648,19 +7188,17 @@ public Attachments createRepeatingInvoiceAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse createRepeatingInvoiceAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID repeatingInvoiceID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -8709,9 +7247,9 @@ public HttpResponse createRepeatingInvoiceAttachmentByFileNameForHttpResponse( logger.debug("PUT " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -8725,43 +7263,41 @@ public HttpResponse createRepeatingInvoiceAttachmentByFileNameForHttpResponse( } /** - * Creates an attachment from a specific repeating invoices by file name + * Creates a history record for a specific repeating invoice * - *

200 - Success - return response of type Attachments array with updated Attachment for - * a specified Repeating Invoice + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return HistoryRecords * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments createRepeatingInvoiceAttachmentByFileName( + public HistoryRecords createRepeatingInvoiceHistory( String accessToken, String xeroTenantId, UUID repeatingInvoiceID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createRepeatingInvoiceAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, repeatingInvoiceID, fileName, body, idempotencyKey); + createRepeatingInvoiceHistoryForHttpResponse( + accessToken, xeroTenantId, repeatingInvoiceID, historyRecords, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createRepeatingInvoiceAttachmentByFileName -------------------"); + + " : createRepeatingInvoiceHistory -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -8771,9 +7307,9 @@ public Attachments createRepeatingInvoiceAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("HistoryRecords", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("HistoryRecords", object, e); } else { handler.execute(e); } @@ -8784,81 +7320,72 @@ public Attachments createRepeatingInvoiceAttachmentByFileName( } /** - * Creates an attachment from a specific repeating invoices by file name + * Creates a history record for a specific repeating invoice * - *

200 - Success - return response of type Attachments array with updated Attachment for - * a specified Repeating Invoice + *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of + * request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createRepeatingInvoiceAttachmentByFileNameForHttpResponse( + public HttpResponse createRepeatingInvoiceHistoryForHttpResponse( String accessToken, String xeroTenantId, UUID repeatingInvoiceID, - String fileName, - File body, + HistoryRecords historyRecords, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " createRepeatingInvoiceAttachmentByFileName"); + + " createRepeatingInvoiceHistory"); } // verify the required parameter 'repeatingInvoiceID' is set if (repeatingInvoiceID == null) { throw new IllegalArgumentException( "Missing the required parameter 'repeatingInvoiceID' when calling" - + " createRepeatingInvoiceAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " createRepeatingInvoiceAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " createRepeatingInvoiceHistory"); + } // verify the required parameter 'historyRecords' is set + if (historyRecords == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " createRepeatingInvoiceAttachmentByFileName"); + "Missing the required parameter 'historyRecords' when calling" + + " createRepeatingInvoiceHistory"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " createRepeatingInvoiceAttachmentByFileName"); + + " createRepeatingInvoiceHistory"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("RepeatingInvoiceID", repeatingInvoiceID); - uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() - + "/RepeatingInvoices/{RepeatingInvoiceID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/RepeatingInvoices/{RepeatingInvoiceID}/History"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("PUT " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(historyRecords); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -8872,41 +7399,43 @@ public HttpResponse createRepeatingInvoiceAttachmentByFileNameForHttpResponse( } /** - * Creates a history record for a specific repeating invoice + * Creates one or more repeating invoice templates * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type RepeatingInvoices array with newly created + * RepeatingInvoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body + * of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return HistoryRecords + * @return RepeatingInvoices * @throws IOException if an error occurs while attempting to invoke the API * */ - public HistoryRecords createRepeatingInvoiceHistory( + public RepeatingInvoices createRepeatingInvoices( String accessToken, String xeroTenantId, - UUID repeatingInvoiceID, - HistoryRecords historyRecords, + RepeatingInvoices repeatingInvoices, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - createRepeatingInvoiceHistoryForHttpResponse( - accessToken, xeroTenantId, repeatingInvoiceID, historyRecords, idempotencyKey); + createRepeatingInvoicesForHttpResponse( + accessToken, xeroTenantId, repeatingInvoices, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : createRepeatingInvoiceHistory -------------------"); + + " : createRepeatingInvoices -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -8916,9 +7445,9 @@ public HistoryRecords createRepeatingInvoiceHistory( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("HistoryRecords", object.getMessage(), e); + handler.validationError("RepeatingInvoices", object.getMessage(), e); } - handler.validationError("HistoryRecords", object, e); + handler.validationError("RepeatingInvoices", object, e); } else { handler.execute(e); } @@ -8929,163 +7458,25 @@ public HistoryRecords createRepeatingInvoiceHistory( } /** - * Creates a history record for a specific repeating invoice + * Creates one or more repeating invoice templates * - *

200 - Success - return response of type HistoryRecords array of HistoryRecord objects + *

200 - Success - return response of type RepeatingInvoices array with newly created + * RepeatingInvoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param historyRecords HistoryRecords containing an array of HistoryRecord objects in body of - * request + * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body + * of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse createRepeatingInvoiceHistoryForHttpResponse( - String accessToken, - String xeroTenantId, - UUID repeatingInvoiceID, - HistoryRecords historyRecords, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " createRepeatingInvoiceHistory"); - } // verify the required parameter 'repeatingInvoiceID' is set - if (repeatingInvoiceID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'repeatingInvoiceID' when calling" - + " createRepeatingInvoiceHistory"); - } // verify the required parameter 'historyRecords' is set - if (historyRecords == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'historyRecords' when calling" - + " createRepeatingInvoiceHistory"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " createRepeatingInvoiceHistory"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("RepeatingInvoiceID", repeatingInvoiceID); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/RepeatingInvoices/{RepeatingInvoiceID}/History"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("PUT " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(historyRecords); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.PUT, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates one or more repeating invoice templates - * - *

200 - Success - return response of type RepeatingInvoices array with newly created - * RepeatingInvoice - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body - * of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return RepeatingInvoices - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public RepeatingInvoices createRepeatingInvoices( - String accessToken, - String xeroTenantId, - RepeatingInvoices repeatingInvoices, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - createRepeatingInvoicesForHttpResponse( - accessToken, xeroTenantId, repeatingInvoices, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : createRepeatingInvoices -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("RepeatingInvoices", object.getMessage(), e); - } - handler.validationError("RepeatingInvoices", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates one or more repeating invoice templates - * - *

200 - Success - return response of type RepeatingInvoices array with newly created - * RepeatingInvoice - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body - * of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse createRepeatingInvoicesForHttpResponse( + public HttpResponse createRepeatingInvoicesForHttpResponse( String accessToken, String xeroTenantId, RepeatingInvoices repeatingInvoices, @@ -26749,8 +25140,6 @@ public HttpResponse updateAccountForHttpResponse( .execute(); } - // Overload params for updateAccountAttachmentByFileName to allow byte[] or File type to be passed - // as body /** * Updates attachment on a specific account by filename * @@ -26764,25 +25153,23 @@ public HttpResponse updateAccountForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments updateAccountAttachmentByFileName( String accessToken, String xeroTenantId, UUID accountID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = updateAccountAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey, mimeType); + accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -26793,7 +25180,18 @@ public Attachments updateAccountAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -26813,19 +25211,17 @@ public Attachments updateAccountAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse updateAccountAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID accountID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -26872,9 +25268,9 @@ public HttpResponse updateAccountAttachmentByFileNameForHttpResponse( logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -26888,42 +25284,49 @@ public HttpResponse updateAccountAttachmentByFileNameForHttpResponse( } /** - * Updates attachment on a specific account by filename + * Updates a single spent or received money transaction * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type BankTransactions array with updated + * BankTransaction * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param accountID Unique identifier for Account object - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param bankTransactionID Xero generated unique identifier for a bank transaction + * @param bankTransactions The bankTransactions parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return BankTransactions * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateAccountAttachmentByFileName( + public BankTransactions updateBankTransaction( String accessToken, String xeroTenantId, - UUID accountID, - String fileName, - File body, + UUID bankTransactionID, + BankTransactions bankTransactions, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateAccountAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, accountID, fileName, body, idempotencyKey); + updateBankTransactionForHttpResponse( + accessToken, + xeroTenantId, + bankTransactionID, + bankTransactions, + unitdp, + idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateAccountAttachmentByFileName -------------------"); + + " : updateBankTransaction -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -26933,9 +25336,9 @@ public Attachments updateAccountAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("BankTransactions", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("BankTransactions", object, e); } else { handler.execute(e); } @@ -26946,208 +25349,58 @@ public Attachments updateAccountAttachmentByFileName( } /** - * Updates attachment on a specific account by filename + * Updates a single spent or received money transaction * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type BankTransactions array with updated + * BankTransaction * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param accountID Unique identifier for Account object - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param bankTransactionID Xero generated unique identifier for a bank transaction + * @param bankTransactions The bankTransactions parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateAccountAttachmentByFileNameForHttpResponse( + public HttpResponse updateBankTransactionForHttpResponse( String accessToken, String xeroTenantId, - UUID accountID, - String fileName, - File body, + UUID bankTransactionID, + BankTransactions bankTransactions, + Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateAccountAttachmentByFileName"); - } // verify the required parameter 'accountID' is set - if (accountID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accountID' when calling" - + " updateAccountAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { + "Missing the required parameter 'xeroTenantId' when calling updateBankTransaction"); + } // verify the required parameter 'bankTransactionID' is set + if (bankTransactionID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateAccountAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'bankTransactionID' when calling updateBankTransaction"); + } // verify the required parameter 'bankTransactions' is set + if (bankTransactions == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateAccountAttachmentByFileName"); + "Missing the required parameter 'bankTransactions' when calling updateBankTransaction"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateAccountAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateBankTransaction"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("AccountID", accountID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Accounts/{AccountID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); - HttpContent content = null; - content = new FileContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates a single spent or received money transaction - * - *

200 - Success - return response of type BankTransactions array with updated - * BankTransaction - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param bankTransactions The bankTransactions parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return BankTransactions - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public BankTransactions updateBankTransaction( - String accessToken, - String xeroTenantId, - UUID bankTransactionID, - BankTransactions bankTransactions, - Integer unitdp, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateBankTransactionForHttpResponse( - accessToken, - xeroTenantId, - bankTransactionID, - bankTransactions, - unitdp, - idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateBankTransaction -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("BankTransactions", object.getMessage(), e); - } - handler.validationError("BankTransactions", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a single spent or received money transaction - * - *

200 - Success - return response of type BankTransactions array with updated - * BankTransaction - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction - * @param bankTransactions The bankTransactions parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateBankTransactionForHttpResponse( - String accessToken, - String xeroTenantId, - UUID bankTransactionID, - BankTransactions bankTransactions, - Integer unitdp, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateBankTransaction"); - } // verify the required parameter 'bankTransactionID' is set - if (bankTransactionID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransactionID' when calling updateBankTransaction"); - } // verify the required parameter 'bankTransactions' is set - if (bankTransactions == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransactions' when calling updateBankTransaction"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateBankTransaction"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("BankTransactionID", bankTransactionID); + uriVariables.put("BankTransactionID", bankTransactionID); UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/BankTransactions/{BankTransactionID}"); @@ -27192,8 +25445,6 @@ public HttpResponse updateBankTransactionForHttpResponse( .execute(); } - // Overload params for updateBankTransactionAttachmentByFileName to allow byte[] or File type to - // be passed as body /** * Updates a specific attachment from a specific bank transaction by filename * @@ -27207,31 +25458,23 @@ public HttpResponse updateBankTransactionForHttpResponse( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ public Attachments updateBankTransactionAttachmentByFileName( String accessToken, String xeroTenantId, UUID bankTransactionID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = updateBankTransactionAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - bankTransactionID, - fileName, - body, - idempotencyKey, - mimeType); + accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { @@ -27242,7 +25485,18 @@ public Attachments updateBankTransactionAttachmentByFileName( logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -27262,19 +25516,17 @@ public Attachments updateBankTransactionAttachmentByFileName( * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, UUID bankTransactionID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { @@ -27323,9 +25575,9 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -27339,14 +25591,13 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( } /** - * Updates a specific attachment from a specific bank transaction by filename - * - *

200 - Success - return response of Attachments array of Attachment + * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank + * Transfer * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction + * @param bankTransferID Xero generated unique identifier for a bank transfer * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -27355,10 +25606,10 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( * @return Attachments * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateBankTransactionAttachmentByFileName( + public Attachments updateBankTransferAttachmentByFileName( String accessToken, String xeroTenantId, - UUID bankTransactionID, + UUID bankTransferID, String fileName, File body, String idempotencyKey) @@ -27366,15 +25617,15 @@ public Attachments updateBankTransactionAttachmentByFileName( try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateBankTransactionAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransactionID, fileName, body, idempotencyKey); + updateBankTransferAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateBankTransactionAttachmentByFileName -------------------"); + + " : updateBankTransferAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -27397,14 +25648,13 @@ public Attachments updateBankTransactionAttachmentByFileName( } /** - * Updates a specific attachment from a specific bank transaction by filename - * - *

200 - Success - return response of Attachments array of Attachment + * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank + * Transfer * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactionID Xero generated unique identifier for a bank transaction + * @param bankTransferID Xero generated unique identifier for a bank transfer * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -27413,10 +25663,10 @@ public Attachments updateBankTransactionAttachmentByFileName( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( + public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID bankTransactionID, + UUID bankTransferID, String fileName, File body, String idempotencyKey) @@ -27425,27 +25675,27 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateBankTransactionAttachmentByFileName"); - } // verify the required parameter 'bankTransactionID' is set - if (bankTransactionID == null) { + + " updateBankTransferAttachmentByFileName"); + } // verify the required parameter 'bankTransferID' is set + if (bankTransferID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'bankTransactionID' when calling" - + " updateBankTransactionAttachmentByFileName"); + "Missing the required parameter 'bankTransferID' when calling" + + " updateBankTransferAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( "Missing the required parameter 'fileName' when calling" - + " updateBankTransactionAttachmentByFileName"); + + " updateBankTransferAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( "Missing the required parameter 'body' when calling" - + " updateBankTransactionAttachmentByFileName"); + + " updateBankTransferAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateBankTransactionAttachmentByFileName"); + + " updateBankTransferAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -27455,22 +25705,21 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("BankTransactionID", bankTransactionID); + uriVariables.put("BankTransferID", bankTransferID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() - + "/BankTransactions/{BankTransactionID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -27483,131 +25732,122 @@ public HttpResponse updateBankTransactionAttachmentByFileNameForHttpResponse( .execute(); } - // Overload params for updateBankTransferAttachmentByFileName to allow byte[] or File type to be - // passed as body /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer + * Updates a specific contact in a Xero organisation + * + *

200 - Success - return response of type Contacts array with an updated Contact * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param contactID Unique identifier for a Contact + * @param contacts an array of Contacts containing single Contact object with properties to update * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @return Contacts + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateBankTransferAttachmentByFileName( + public Contacts updateContact( String accessToken, String xeroTenantId, - UUID bankTransferID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + UUID contactID, + Contacts contacts, + String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateBankTransferAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey, mimeType); + updateContactForHttpResponse( + accessToken, xeroTenantId, contactID, contacts, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateBankTransferAttachmentByFileName -------------------"); + + " : updateContact -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer - * - *

400 - A failed request due to validation error + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Contacts", object.getMessage(), e); + } + handler.validationError("Contacts", object, e); + } else { + handler.execute(e); + } + } catch (IOException ioe) { + throw ioe; + } + return null; + } + + /** + * Updates a specific contact in a Xero organisation + * + *

200 - Success - return response of type Contacts array with an updated Contact + * + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param contactID Unique identifier for a Contact + * @param contacts an array of Contacts containing single Contact object with properties to update * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( + public HttpResponse updateContactForHttpResponse( String accessToken, String xeroTenantId, - UUID bankTransferID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + UUID contactID, + Contacts contacts, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateBankTransferAttachmentByFileName"); - } // verify the required parameter 'bankTransferID' is set - if (bankTransferID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransferID' when calling" - + " updateBankTransferAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { + "Missing the required parameter 'xeroTenantId' when calling updateContact"); + } // verify the required parameter 'contactID' is set + if (contactID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateBankTransferAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'contactID' when calling updateContact"); + } // verify the required parameter 'contacts' is set + if (contacts == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateBankTransferAttachmentByFileName"); + "Missing the required parameter 'contacts' when calling updateContact"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateBankTransferAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateContact"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("BankTransferID", bankTransferID); - uriVariables.put("FileName", fileName); + uriVariables.put("ContactID", contactID); - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/Attachments/{FileName}"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Contacts/{ContactID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(contacts); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -27621,13 +25861,12 @@ public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( } /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer + * 200 - Success - return response of type Attachments array with an updated Attachment * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer + * @param contactID Unique identifier for a Contact * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -27636,10 +25875,10 @@ public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( * @return Attachments * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateBankTransferAttachmentByFileName( + public Attachments updateContactAttachmentByFileName( String accessToken, String xeroTenantId, - UUID bankTransferID, + UUID contactID, String fileName, File body, String idempotencyKey) @@ -27647,15 +25886,15 @@ public Attachments updateBankTransferAttachmentByFileName( try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateBankTransferAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, bankTransferID, fileName, body, idempotencyKey); + updateContactAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateBankTransferAttachmentByFileName -------------------"); + + " : updateContactAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -27678,13 +25917,12 @@ public Attachments updateBankTransferAttachmentByFileName( } /** - * 200 - Success - return response of Attachments array of 0 to N Attachment for a Bank - * Transfer + * 200 - Success - return response of type Attachments array with an updated Attachment * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param bankTransferID Xero generated unique identifier for a bank transfer + * @param contactID Unique identifier for a Contact * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -27693,10 +25931,10 @@ public Attachments updateBankTransferAttachmentByFileName( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( + public HttpResponse updateContactAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID bankTransferID, + UUID contactID, String fileName, File body, String idempotencyKey) @@ -27705,27 +25943,26 @@ public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateBankTransferAttachmentByFileName"); - } // verify the required parameter 'bankTransferID' is set - if (bankTransferID == null) { + + " updateContactAttachmentByFileName"); + } // verify the required parameter 'contactID' is set + if (contactID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'bankTransferID' when calling" - + " updateBankTransferAttachmentByFileName"); + "Missing the required parameter 'contactID' when calling" + + " updateContactAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( "Missing the required parameter 'fileName' when calling" - + " updateBankTransferAttachmentByFileName"); + + " updateContactAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateBankTransferAttachmentByFileName"); + "Missing the required parameter 'body' when calling updateContactAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateBankTransferAttachmentByFileName"); + + " updateContactAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -27735,21 +25972,21 @@ public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("BankTransferID", bankTransferID); + uriVariables.put("ContactID", contactID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() + "/BankTransfers/{BankTransferID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/Contacts/{ContactID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -27763,40 +26000,40 @@ public HttpResponse updateBankTransferAttachmentByFileNameForHttpResponse( } /** - * Updates a specific contact in a Xero organisation + * Updates a specific contact group * - *

200 - Success - return response of type Contacts array with an updated Contact + *

200 - Success - return response of type Contact Groups array of updated Contact Group * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param contacts an array of Contacts containing single Contact object with properties to update + * @param contactGroupID Unique identifier for a Contact Group + * @param contactGroups an array of Contact groups with Name of specific group to update * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Contacts + * @return ContactGroups * @throws IOException if an error occurs while attempting to invoke the API * */ - public Contacts updateContact( + public ContactGroups updateContactGroup( String accessToken, String xeroTenantId, - UUID contactID, - Contacts contacts, + UUID contactGroupID, + ContactGroups contactGroups, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateContactForHttpResponse( - accessToken, xeroTenantId, contactID, contacts, idempotencyKey); + updateContactGroupForHttpResponse( + accessToken, xeroTenantId, contactGroupID, contactGroups, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateContact -------------------"); + + " : updateContactGroup -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -27806,9 +26043,9 @@ public Contacts updateContact( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Contacts", object.getMessage(), e); + handler.validationError("ContactGroups", object.getMessage(), e); } - handler.validationError("Contacts", object, e); + handler.validationError("ContactGroups", object, e); } else { handler.execute(e); } @@ -27819,44 +26056,44 @@ public Contacts updateContact( } /** - * Updates a specific contact in a Xero organisation + * Updates a specific contact group * - *

200 - Success - return response of type Contacts array with an updated Contact + *

200 - Success - return response of type Contact Groups array of updated Contact Group * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param contacts an array of Contacts containing single Contact object with properties to update + * @param contactGroupID Unique identifier for a Contact Group + * @param contactGroups an array of Contact groups with Name of specific group to update * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateContactForHttpResponse( + public HttpResponse updateContactGroupForHttpResponse( String accessToken, String xeroTenantId, - UUID contactID, - Contacts contacts, + UUID contactGroupID, + ContactGroups contactGroups, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateContact"); - } // verify the required parameter 'contactID' is set - if (contactID == null) { + "Missing the required parameter 'xeroTenantId' when calling updateContactGroup"); + } // verify the required parameter 'contactGroupID' is set + if (contactGroupID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'contactID' when calling updateContact"); - } // verify the required parameter 'contacts' is set - if (contacts == null) { + "Missing the required parameter 'contactGroupID' when calling updateContactGroup"); + } // verify the required parameter 'contactGroups' is set + if (contactGroups == null) { throw new IllegalArgumentException( - "Missing the required parameter 'contacts' when calling updateContact"); + "Missing the required parameter 'contactGroups' when calling updateContactGroup"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateContact"); + "Missing the required parameter 'accessToken' when calling updateContactGroup"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -27866,9 +26103,10 @@ public HttpResponse updateContactForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("ContactID", contactID); + uriVariables.put("ContactGroupID", contactGroupID); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Contacts/{ContactID}"); + UriBuilder uriBuilder = + UriBuilder.fromUri(apiClient.getBasePath() + "/ContactGroups/{ContactGroupID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -27876,7 +26114,7 @@ public HttpResponse updateContactForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(contacts); + content = apiClient.new JacksonJsonHttpContent(contactGroups); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -27890,49 +26128,59 @@ public HttpResponse updateContactForHttpResponse( .execute(); } - // Overload params for updateContactAttachmentByFileName to allow byte[] or File type to be passed - // as body /** - * 200 - Success - return response of type Attachments array with an updated Attachment + * Updates a specific credit note + * + *

200 - Success - return response of type Credit Notes array with updated CreditNote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param creditNoteID Unique identifier for a Credit Note + * @param creditNotes an array of Credit Notes containing credit note details to update + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @return CreditNotes + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateContactAttachmentByFileName( + public CreditNotes updateCreditNote( String accessToken, String xeroTenantId, - UUID contactID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + UUID creditNoteID, + CreditNotes creditNotes, + Integer unitdp, + String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateContactAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey, mimeType); + updateCreditNoteForHttpResponse( + accessToken, xeroTenantId, creditNoteID, creditNotes, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateContactAttachmentByFileName -------------------"); + + " : updateCreditNote -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("CreditNotes", object.getMessage(), e); + } + handler.validationError("CreditNotes", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -27940,78 +26188,89 @@ public Attachments updateContactAttachmentByFileName( } /** - * 200 - Success - return response of type Attachments array with an updated Attachment + * Updates a specific credit note + * + *

200 - Success - return response of type Credit Notes array with updated CreditNote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param creditNoteID Unique identifier for a Credit Note + * @param creditNotes an array of Credit Notes containing credit note details to update + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateContactAttachmentByFileNameForHttpResponse( + public HttpResponse updateCreditNoteForHttpResponse( String accessToken, String xeroTenantId, - UUID contactID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + UUID creditNoteID, + CreditNotes creditNotes, + Integer unitdp, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateContactAttachmentByFileName"); - } // verify the required parameter 'contactID' is set - if (contactID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'contactID' when calling" - + " updateContactAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { + "Missing the required parameter 'xeroTenantId' when calling updateCreditNote"); + } // verify the required parameter 'creditNoteID' is set + if (creditNoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateContactAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'creditNoteID' when calling updateCreditNote"); + } // verify the required parameter 'creditNotes' is set + if (creditNotes == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateContactAttachmentByFileName"); + "Missing the required parameter 'creditNotes' when calling updateCreditNote"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateContactAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateCreditNote"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("ContactID", contactID); - uriVariables.put("FileName", fileName); + uriVariables.put("CreditNoteID", creditNoteID); UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Contacts/{ContactID}/Attachments/{FileName}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}"); + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(creditNotes); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -28025,12 +26284,15 @@ public HttpResponse updateContactAttachmentByFileNameForHttpResponse( } /** - * 200 - Success - return response of type Attachments array with an updated Attachment + * Updates attachments on a specific credit note by file name + * + *

200 - Success - return response of type Attachments array with updated Attachment for + * specific Credit Note * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact + * @param creditNoteID Unique identifier for a Credit Note * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -28039,10 +26301,10 @@ public HttpResponse updateContactAttachmentByFileNameForHttpResponse( * @return Attachments * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateContactAttachmentByFileName( + public Attachments updateCreditNoteAttachmentByFileName( String accessToken, String xeroTenantId, - UUID contactID, + UUID creditNoteID, String fileName, File body, String idempotencyKey) @@ -28050,15 +26312,15 @@ public Attachments updateContactAttachmentByFileName( try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateContactAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, contactID, fileName, body, idempotencyKey); + updateCreditNoteAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, creditNoteID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateContactAttachmentByFileName -------------------"); + + " : updateCreditNoteAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28081,12 +26343,15 @@ public Attachments updateContactAttachmentByFileName( } /** - * 200 - Success - return response of type Attachments array with an updated Attachment + * Updates attachments on a specific credit note by file name + * + *

200 - Success - return response of type Attachments array with updated Attachment for + * specific Credit Note * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactID Unique identifier for a Contact + * @param creditNoteID Unique identifier for a Credit Note * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -28095,10 +26360,10 @@ public Attachments updateContactAttachmentByFileName( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateContactAttachmentByFileNameForHttpResponse( + public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID contactID, + UUID creditNoteID, String fileName, File body, String idempotencyKey) @@ -28107,26 +26372,27 @@ public HttpResponse updateContactAttachmentByFileNameForHttpResponse( if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateContactAttachmentByFileName"); - } // verify the required parameter 'contactID' is set - if (contactID == null) { + + " updateCreditNoteAttachmentByFileName"); + } // verify the required parameter 'creditNoteID' is set + if (creditNoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'contactID' when calling" - + " updateContactAttachmentByFileName"); + "Missing the required parameter 'creditNoteID' when calling" + + " updateCreditNoteAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( "Missing the required parameter 'fileName' when calling" - + " updateContactAttachmentByFileName"); + + " updateCreditNoteAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateContactAttachmentByFileName"); + "Missing the required parameter 'body' when calling" + + " updateCreditNoteAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateContactAttachmentByFileName"); + + " updateCreditNoteAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28136,21 +26402,21 @@ public HttpResponse updateContactAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("ContactID", contactID); + uriVariables.put("CreditNoteID", creditNoteID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() + "/Contacts/{ContactID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -28164,40 +26430,40 @@ public HttpResponse updateContactAttachmentByFileNameForHttpResponse( } /** - * Updates a specific contact group + * Updates a specific expense claims * - *

200 - Success - return response of type Contact Groups array of updated Contact Group + *

200 - Success - return response of type ExpenseClaims array with updated ExpenseClaim * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactGroupID Unique identifier for a Contact Group - * @param contactGroups an array of Contact groups with Name of specific group to update + * @param expenseClaimID Unique identifier for a ExpenseClaim + * @param expenseClaims The expenseClaims parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return ContactGroups + * @return ExpenseClaims * @throws IOException if an error occurs while attempting to invoke the API * */ - public ContactGroups updateContactGroup( + public ExpenseClaims updateExpenseClaim( String accessToken, String xeroTenantId, - UUID contactGroupID, - ContactGroups contactGroups, + UUID expenseClaimID, + ExpenseClaims expenseClaims, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateContactGroupForHttpResponse( - accessToken, xeroTenantId, contactGroupID, contactGroups, idempotencyKey); + updateExpenseClaimForHttpResponse( + accessToken, xeroTenantId, expenseClaimID, expenseClaims, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateContactGroup -------------------"); + + " : updateExpenseClaim -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28207,9 +26473,9 @@ public ContactGroups updateContactGroup( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ContactGroups", object.getMessage(), e); + handler.validationError("ExpenseClaims", object.getMessage(), e); } - handler.validationError("ContactGroups", object, e); + handler.validationError("ExpenseClaims", object, e); } else { handler.execute(e); } @@ -28220,44 +26486,44 @@ public ContactGroups updateContactGroup( } /** - * Updates a specific contact group + * Updates a specific expense claims * - *

200 - Success - return response of type Contact Groups array of updated Contact Group + *

200 - Success - return response of type ExpenseClaims array with updated ExpenseClaim * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param contactGroupID Unique identifier for a Contact Group - * @param contactGroups an array of Contact groups with Name of specific group to update + * @param expenseClaimID Unique identifier for a ExpenseClaim + * @param expenseClaims The expenseClaims parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateContactGroupForHttpResponse( + public HttpResponse updateExpenseClaimForHttpResponse( String accessToken, String xeroTenantId, - UUID contactGroupID, - ContactGroups contactGroups, + UUID expenseClaimID, + ExpenseClaims expenseClaims, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateContactGroup"); - } // verify the required parameter 'contactGroupID' is set - if (contactGroupID == null) { + "Missing the required parameter 'xeroTenantId' when calling updateExpenseClaim"); + } // verify the required parameter 'expenseClaimID' is set + if (expenseClaimID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'contactGroupID' when calling updateContactGroup"); - } // verify the required parameter 'contactGroups' is set - if (contactGroups == null) { + "Missing the required parameter 'expenseClaimID' when calling updateExpenseClaim"); + } // verify the required parameter 'expenseClaims' is set + if (expenseClaims == null) { throw new IllegalArgumentException( - "Missing the required parameter 'contactGroups' when calling updateContactGroup"); + "Missing the required parameter 'expenseClaims' when calling updateExpenseClaim"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateContactGroup"); + "Missing the required parameter 'accessToken' when calling updateExpenseClaim"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28267,10 +26533,10 @@ public HttpResponse updateContactGroupForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("ContactGroupID", contactGroupID); + uriVariables.put("ExpenseClaimID", expenseClaimID); UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/ContactGroups/{ContactGroupID}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/ExpenseClaims/{ExpenseClaimID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -28278,7 +26544,7 @@ public HttpResponse updateContactGroupForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(contactGroups); + content = apiClient.new JacksonJsonHttpContent(expenseClaims); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -28293,43 +26559,43 @@ public HttpResponse updateContactGroupForHttpResponse( } /** - * Updates a specific credit note + * Updates a specific sales invoices or purchase bills * - *

200 - Success - return response of type Credit Notes array with updated CreditNote + *

200 - Success - return response of type Invoices array with updated Invoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param creditNotes an array of Credit Notes containing credit note details to update + * @param invoiceID Unique identifier for an Invoice + * @param invoices The invoices parameter * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return CreditNotes + * @return Invoices * @throws IOException if an error occurs while attempting to invoke the API * */ - public CreditNotes updateCreditNote( + public Invoices updateInvoice( String accessToken, String xeroTenantId, - UUID creditNoteID, - CreditNotes creditNotes, + UUID invoiceID, + Invoices invoices, Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateCreditNoteForHttpResponse( - accessToken, xeroTenantId, creditNoteID, creditNotes, unitdp, idempotencyKey); + updateInvoiceForHttpResponse( + accessToken, xeroTenantId, invoiceID, invoices, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateCreditNote -------------------"); + + " : updateInvoice -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28339,9 +26605,9 @@ public CreditNotes updateCreditNote( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("CreditNotes", object.getMessage(), e); + handler.validationError("Invoices", object.getMessage(), e); } - handler.validationError("CreditNotes", object, e); + handler.validationError("Invoices", object, e); } else { handler.execute(e); } @@ -28352,15 +26618,15 @@ public CreditNotes updateCreditNote( } /** - * Updates a specific credit note + * Updates a specific sales invoices or purchase bills * - *

200 - Success - return response of type Credit Notes array with updated CreditNote + *

200 - Success - return response of type Invoices array with updated Invoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param creditNotes an array of Credit Notes containing credit note details to update + * @param invoiceID Unique identifier for an Invoice + * @param invoices The invoices parameter * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -28369,30 +26635,30 @@ public CreditNotes updateCreditNote( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateCreditNoteForHttpResponse( + public HttpResponse updateInvoiceForHttpResponse( String accessToken, String xeroTenantId, - UUID creditNoteID, - CreditNotes creditNotes, + UUID invoiceID, + Invoices invoices, Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateCreditNote"); - } // verify the required parameter 'creditNoteID' is set - if (creditNoteID == null) { + "Missing the required parameter 'xeroTenantId' when calling updateInvoice"); + } // verify the required parameter 'invoiceID' is set + if (invoiceID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'creditNoteID' when calling updateCreditNote"); - } // verify the required parameter 'creditNotes' is set - if (creditNotes == null) { + "Missing the required parameter 'invoiceID' when calling updateInvoice"); + } // verify the required parameter 'invoices' is set + if (invoices == null) { throw new IllegalArgumentException( - "Missing the required parameter 'creditNotes' when calling updateCreditNote"); + "Missing the required parameter 'invoices' when calling updateInvoice"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateCreditNote"); + "Missing the required parameter 'accessToken' when calling updateInvoice"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28402,10 +26668,9 @@ public HttpResponse updateCreditNoteForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("CreditNoteID", creditNoteID); + uriVariables.put("InvoiceID", invoiceID); - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices/{InvoiceID}"); if (unitdp != null) { String key = "unitdp"; Object value = unitdp; @@ -28433,7 +26698,7 @@ public HttpResponse updateCreditNoteForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(creditNotes); + content = apiClient.new JacksonJsonHttpContent(invoices); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -28447,111 +26712,113 @@ public HttpResponse updateCreditNoteForHttpResponse( .execute(); } - // Overload params for updateCreditNoteAttachmentByFileName to allow byte[] or File type to be - // passed as body /** - * Updates attachments on a specific credit note by file name + * Updates an attachment from a specific invoices or purchase bill by filename * - *

200 - Success - return response of type Attachments array with updated Attachment for - * specific Credit Note + *

200 - Success - return response of type Attachments array with updated Attachment * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note + * @param invoiceID Unique identifier for an Invoice * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateCreditNoteAttachmentByFileName( + public Attachments updateInvoiceAttachmentByFileName( String accessToken, String xeroTenantId, - UUID creditNoteID, + UUID invoiceID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateCreditNoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, creditNoteID, fileName, body, idempotencyKey, mimeType); + updateInvoiceAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, invoiceID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateCreditNoteAttachmentByFileName -------------------"); + + " : updateInvoiceAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates attachments on a specific credit note by file name + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } + } catch (IOException ioe) { + throw ioe; + } + return null; + } + + /** + * Updates an attachment from a specific invoices or purchase bill by filename * - *

200 - Success - return response of type Attachments array with updated Attachment for - * specific Credit Note + *

200 - Success - return response of type Attachments array with updated Attachment * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note + * @param invoiceID Unique identifier for an Invoice * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( + public HttpResponse updateInvoiceAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID creditNoteID, + UUID invoiceID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateCreditNoteAttachmentByFileName"); - } // verify the required parameter 'creditNoteID' is set - if (creditNoteID == null) { + + " updateInvoiceAttachmentByFileName"); + } // verify the required parameter 'invoiceID' is set + if (invoiceID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'creditNoteID' when calling" - + " updateCreditNoteAttachmentByFileName"); + "Missing the required parameter 'invoiceID' when calling" + + " updateInvoiceAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( "Missing the required parameter 'fileName' when calling" - + " updateCreditNoteAttachmentByFileName"); + + " updateInvoiceAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateCreditNoteAttachmentByFileName"); + "Missing the required parameter 'body' when calling updateInvoiceAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateCreditNoteAttachmentByFileName"); + + " updateInvoiceAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28561,21 +26828,21 @@ public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("CreditNoteID", creditNoteID); + uriVariables.put("InvoiceID", invoiceID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/Invoices/{InvoiceID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -28589,43 +26856,43 @@ public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( } /** - * Updates attachments on a specific credit note by file name + * Updates a specific item * - *

200 - Success - return response of type Attachments array with updated Attachment for - * specific Credit Note + *

200 - Success - return response of type Items array with updated Item * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param itemID Unique identifier for an Item + * @param items The items parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return Items * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateCreditNoteAttachmentByFileName( + public Items updateItem( String accessToken, String xeroTenantId, - UUID creditNoteID, - String fileName, - File body, + UUID itemID, + Items items, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateCreditNoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, creditNoteID, fileName, body, idempotencyKey); + updateItemForHttpResponse( + accessToken, xeroTenantId, itemID, items, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateCreditNoteAttachmentByFileName -------------------"); + + " : updateItem -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28635,9 +26902,9 @@ public Attachments updateCreditNoteAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("Items", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("Items", object, e); } else { handler.execute(e); } @@ -28648,80 +26915,88 @@ public Attachments updateCreditNoteAttachmentByFileName( } /** - * Updates attachments on a specific credit note by file name + * Updates a specific item * - *

200 - Success - return response of type Attachments array with updated Attachment for - * specific Credit Note + *

200 - Success - return response of type Items array with updated Item * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param creditNoteID Unique identifier for a Credit Note - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param itemID Unique identifier for an Item + * @param items The items parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( + public HttpResponse updateItemForHttpResponse( String accessToken, String xeroTenantId, - UUID creditNoteID, - String fileName, - File body, + UUID itemID, + Items items, + Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateCreditNoteAttachmentByFileName"); - } // verify the required parameter 'creditNoteID' is set - if (creditNoteID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'creditNoteID' when calling" - + " updateCreditNoteAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { + "Missing the required parameter 'xeroTenantId' when calling updateItem"); + } // verify the required parameter 'itemID' is set + if (itemID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateCreditNoteAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'itemID' when calling updateItem"); + } // verify the required parameter 'items' is set + if (items == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateCreditNoteAttachmentByFileName"); + "Missing the required parameter 'items' when calling updateItem"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateCreditNoteAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateItem"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("CreditNoteID", creditNoteID); - uriVariables.put("FileName", fileName); + uriVariables.put("ItemID", itemID); - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/CreditNotes/{CreditNoteID}/Attachments/{FileName}"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Items/{ItemID}"); + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(items); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -28735,40 +27010,42 @@ public HttpResponse updateCreditNoteAttachmentByFileNameForHttpResponse( } /** - * Updates a specific expense claims + * Updates a specific linked transactions (billable expenses) * - *

200 - Success - return response of type ExpenseClaims array with updated ExpenseClaim + *

200 - Success - return response of type LinkedTransactions array with updated + * LinkedTransaction * - *

400 - A failed request due to validation error + *

400 - Success - return response of type LinkedTransactions array with updated + * LinkedTransaction * * @param xeroTenantId Xero identifier for Tenant - * @param expenseClaimID Unique identifier for a ExpenseClaim - * @param expenseClaims The expenseClaims parameter + * @param linkedTransactionID Unique identifier for a LinkedTransaction + * @param linkedTransactions The linkedTransactions parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return ExpenseClaims + * @return LinkedTransactions * @throws IOException if an error occurs while attempting to invoke the API * */ - public ExpenseClaims updateExpenseClaim( + public LinkedTransactions updateLinkedTransaction( String accessToken, String xeroTenantId, - UUID expenseClaimID, - ExpenseClaims expenseClaims, + UUID linkedTransactionID, + LinkedTransactions linkedTransactions, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateExpenseClaimForHttpResponse( - accessToken, xeroTenantId, expenseClaimID, expenseClaims, idempotencyKey); + updateLinkedTransactionForHttpResponse( + accessToken, xeroTenantId, linkedTransactionID, linkedTransactions, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateExpenseClaim -------------------"); + + " : updateLinkedTransaction -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28778,9 +27055,9 @@ public ExpenseClaims updateExpenseClaim( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ExpenseClaims", object.getMessage(), e); + handler.validationError("LinkedTransactions", object.getMessage(), e); } - handler.validationError("ExpenseClaims", object, e); + handler.validationError("LinkedTransactions", object, e); } else { handler.execute(e); } @@ -28791,44 +27068,48 @@ public ExpenseClaims updateExpenseClaim( } /** - * Updates a specific expense claims + * Updates a specific linked transactions (billable expenses) * - *

200 - Success - return response of type ExpenseClaims array with updated ExpenseClaim + *

200 - Success - return response of type LinkedTransactions array with updated + * LinkedTransaction * - *

400 - A failed request due to validation error + *

400 - Success - return response of type LinkedTransactions array with updated + * LinkedTransaction * * @param xeroTenantId Xero identifier for Tenant - * @param expenseClaimID Unique identifier for a ExpenseClaim - * @param expenseClaims The expenseClaims parameter + * @param linkedTransactionID Unique identifier for a LinkedTransaction + * @param linkedTransactions The linkedTransactions parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateExpenseClaimForHttpResponse( + public HttpResponse updateLinkedTransactionForHttpResponse( String accessToken, String xeroTenantId, - UUID expenseClaimID, - ExpenseClaims expenseClaims, + UUID linkedTransactionID, + LinkedTransactions linkedTransactions, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateExpenseClaim"); - } // verify the required parameter 'expenseClaimID' is set - if (expenseClaimID == null) { + "Missing the required parameter 'xeroTenantId' when calling updateLinkedTransaction"); + } // verify the required parameter 'linkedTransactionID' is set + if (linkedTransactionID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'expenseClaimID' when calling updateExpenseClaim"); - } // verify the required parameter 'expenseClaims' is set - if (expenseClaims == null) { + "Missing the required parameter 'linkedTransactionID' when calling" + + " updateLinkedTransaction"); + } // verify the required parameter 'linkedTransactions' is set + if (linkedTransactions == null) { throw new IllegalArgumentException( - "Missing the required parameter 'expenseClaims' when calling updateExpenseClaim"); + "Missing the required parameter 'linkedTransactions' when calling" + + " updateLinkedTransaction"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateExpenseClaim"); + "Missing the required parameter 'accessToken' when calling updateLinkedTransaction"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28838,10 +27119,10 @@ public HttpResponse updateExpenseClaimForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("ExpenseClaimID", expenseClaimID); + uriVariables.put("LinkedTransactionID", linkedTransactionID); UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/ExpenseClaims/{ExpenseClaimID}"); + UriBuilder.fromUri(apiClient.getBasePath() + "/LinkedTransactions/{LinkedTransactionID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -28849,7 +27130,7 @@ public HttpResponse updateExpenseClaimForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(expenseClaims); + content = apiClient.new JacksonJsonHttpContent(linkedTransactions); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -28864,43 +27145,41 @@ public HttpResponse updateExpenseClaimForHttpResponse( } /** - * Updates a specific sales invoices or purchase bills + * Updates a specific manual journal * - *

200 - Success - return response of type Invoices array with updated Invoice + *

200 - Success - return response of type ManualJournals array with an updated + * ManualJournal * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param invoices The invoices parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts + * @param manualJournalID Unique identifier for a ManualJournal + * @param manualJournals The manualJournals parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Invoices + * @return ManualJournals * @throws IOException if an error occurs while attempting to invoke the API * */ - public Invoices updateInvoice( + public ManualJournals updateManualJournal( String accessToken, String xeroTenantId, - UUID invoiceID, - Invoices invoices, - Integer unitdp, + UUID manualJournalID, + ManualJournals manualJournals, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateInvoiceForHttpResponse( - accessToken, xeroTenantId, invoiceID, invoices, unitdp, idempotencyKey); + updateManualJournalForHttpResponse( + accessToken, xeroTenantId, manualJournalID, manualJournals, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateInvoice -------------------"); + + " : updateManualJournal -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -28910,9 +27189,9 @@ public Invoices updateInvoice( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Invoices", object.getMessage(), e); + handler.validationError("ManualJournals", object.getMessage(), e); } - handler.validationError("Invoices", object, e); + handler.validationError("ManualJournals", object, e); } else { handler.execute(e); } @@ -28923,47 +27202,45 @@ public Invoices updateInvoice( } /** - * Updates a specific sales invoices or purchase bills + * Updates a specific manual journal * - *

200 - Success - return response of type Invoices array with updated Invoice + *

200 - Success - return response of type ManualJournals array with an updated + * ManualJournal * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param invoices The invoices parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts + * @param manualJournalID Unique identifier for a ManualJournal + * @param manualJournals The manualJournals parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateInvoiceForHttpResponse( + public HttpResponse updateManualJournalForHttpResponse( String accessToken, String xeroTenantId, - UUID invoiceID, - Invoices invoices, - Integer unitdp, + UUID manualJournalID, + ManualJournals manualJournals, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateInvoice"); - } // verify the required parameter 'invoiceID' is set - if (invoiceID == null) { + "Missing the required parameter 'xeroTenantId' when calling updateManualJournal"); + } // verify the required parameter 'manualJournalID' is set + if (manualJournalID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'invoiceID' when calling updateInvoice"); - } // verify the required parameter 'invoices' is set - if (invoices == null) { + "Missing the required parameter 'manualJournalID' when calling updateManualJournal"); + } // verify the required parameter 'manualJournals' is set + if (manualJournals == null) { throw new IllegalArgumentException( - "Missing the required parameter 'invoices' when calling updateInvoice"); + "Missing the required parameter 'manualJournals' when calling updateManualJournal"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateInvoice"); + "Missing the required parameter 'accessToken' when calling updateManualJournal"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -28973,29 +27250,10 @@ public HttpResponse updateInvoiceForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("InvoiceID", invoiceID); + uriVariables.put("ManualJournalID", manualJournalID); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices/{InvoiceID}"); - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } + UriBuilder uriBuilder = + UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -29003,7 +27261,7 @@ public HttpResponse updateInvoiceForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(invoices); + content = apiClient.new JacksonJsonHttpContent(manualJournals); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -29017,51 +27275,59 @@ public HttpResponse updateInvoiceForHttpResponse( .execute(); } - // Overload params for updateInvoiceAttachmentByFileName to allow byte[] or File type to be passed - // as body /** - * Updates an attachment from a specific invoices or purchase bill by filename + * Updates a specific attachment from a specific manual journal by file name * - *

200 - Success - return response of type Attachments array with updated Attachment + *

200 - Success - return response of type Attachments array with an update Attachment + * for a ManualJournals * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice + * @param manualJournalID Unique identifier for a ManualJournal * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateInvoiceAttachmentByFileName( + public Attachments updateManualJournalAttachmentByFileName( String accessToken, String xeroTenantId, - UUID invoiceID, + UUID manualJournalID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateInvoiceAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, invoiceID, fileName, body, idempotencyKey, mimeType); + updateManualJournalAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateInvoiceAttachmentByFileName -------------------"); + + " : updateManualJournalAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -29069,56 +27335,56 @@ public Attachments updateInvoiceAttachmentByFileName( } /** - * Updates an attachment from a specific invoices or purchase bill by filename + * Updates a specific attachment from a specific manual journal by file name * - *

200 - Success - return response of type Attachments array with updated Attachment + *

200 - Success - return response of type Attachments array with an update Attachment + * for a ManualJournals * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice + * @param manualJournalID Unique identifier for a ManualJournal * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateInvoiceAttachmentByFileNameForHttpResponse( + public HttpResponse updateManualJournalAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID invoiceID, + UUID manualJournalID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateInvoiceAttachmentByFileName"); - } // verify the required parameter 'invoiceID' is set - if (invoiceID == null) { + + " updateManualJournalAttachmentByFileName"); + } // verify the required parameter 'manualJournalID' is set + if (manualJournalID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'invoiceID' when calling" - + " updateInvoiceAttachmentByFileName"); + "Missing the required parameter 'manualJournalID' when calling" + + " updateManualJournalAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( "Missing the required parameter 'fileName' when calling" - + " updateInvoiceAttachmentByFileName"); + + " updateManualJournalAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateInvoiceAttachmentByFileName"); + "Missing the required parameter 'body' when calling" + + " updateManualJournalAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateInvoiceAttachmentByFileName"); + + " updateManualJournalAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -29128,21 +27394,21 @@ public HttpResponse updateInvoiceAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("InvoiceID", invoiceID); + uriVariables.put("ManualJournalID", manualJournalID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = UriBuilder.fromUri( - apiClient.getBasePath() + "/Invoices/{InvoiceID}/Attachments/{FileName}"); + apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -29156,42 +27422,45 @@ public HttpResponse updateInvoiceAttachmentByFileNameForHttpResponse( } /** - * Updates an attachment from a specific invoices or purchase bill by filename + * Updates or creates one or more spent or received money transaction * - *

200 - Success - return response of type Attachments array with updated Attachment + *

200 - Success - return response of type BankTransactions array with new + * BankTransaction * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param bankTransactions The bankTransactions parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return BankTransactions * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateInvoiceAttachmentByFileName( + public BankTransactions updateOrCreateBankTransactions( String accessToken, String xeroTenantId, - UUID invoiceID, - String fileName, - File body, + BankTransactions bankTransactions, + Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateInvoiceAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, invoiceID, fileName, body, idempotencyKey); + updateOrCreateBankTransactionsForHttpResponse( + accessToken, xeroTenantId, bankTransactions, summarizeErrors, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateInvoiceAttachmentByFileName -------------------"); + + " : updateOrCreateBankTransactions -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -29201,9 +27470,9 @@ public Attachments updateInvoiceAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("BankTransactions", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("BankTransactions", object, e); } else { handler.execute(e); } @@ -29214,1221 +27483,56 @@ public Attachments updateInvoiceAttachmentByFileName( } /** - * Updates an attachment from a specific invoices or purchase bill by filename + * Updates or creates one or more spent or received money transaction * - *

200 - Success - return response of type Attachments array with updated Attachment + *

200 - Success - return response of type BankTransactions array with new + * BankTransaction * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param invoiceID Unique identifier for an Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param bankTransactions The bankTransactions parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateInvoiceAttachmentByFileNameForHttpResponse( + public HttpResponse updateOrCreateBankTransactionsForHttpResponse( String accessToken, String xeroTenantId, - UUID invoiceID, - String fileName, - File body, + BankTransactions bankTransactions, + Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateInvoiceAttachmentByFileName"); - } // verify the required parameter 'invoiceID' is set - if (invoiceID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'invoiceID' when calling" - + " updateInvoiceAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateInvoiceAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " updateOrCreateBankTransactions"); + } // verify the required parameter 'bankTransactions' is set + if (bankTransactions == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateInvoiceAttachmentByFileName"); + "Missing the required parameter 'bankTransactions' when calling" + + " updateOrCreateBankTransactions"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateInvoiceAttachmentByFileName"); + + " updateOrCreateBankTransactions"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("InvoiceID", invoiceID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Invoices/{InvoiceID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); - HttpContent content = null; - content = new FileContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates a specific item - * - *

200 - Success - return response of type Items array with updated Item - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param itemID Unique identifier for an Item - * @param items The items parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return Items - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public Items updateItem( - String accessToken, - String xeroTenantId, - UUID itemID, - Items items, - Integer unitdp, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateItemForHttpResponse( - accessToken, xeroTenantId, itemID, items, unitdp, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateItem -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Items", object.getMessage(), e); - } - handler.validationError("Items", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific item - * - *

200 - Success - return response of type Items array with updated Item - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param itemID Unique identifier for an Item - * @param items The items parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateItemForHttpResponse( - String accessToken, - String xeroTenantId, - UUID itemID, - Items items, - Integer unitdp, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateItem"); - } // verify the required parameter 'itemID' is set - if (itemID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'itemID' when calling updateItem"); - } // verify the required parameter 'items' is set - if (items == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'items' when calling updateItem"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateItem"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ItemID", itemID); - - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Items/{ItemID}"); - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(items); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates a specific linked transactions (billable expenses) - * - *

200 - Success - return response of type LinkedTransactions array with updated - * LinkedTransaction - * - *

400 - Success - return response of type LinkedTransactions array with updated - * LinkedTransaction - * - * @param xeroTenantId Xero identifier for Tenant - * @param linkedTransactionID Unique identifier for a LinkedTransaction - * @param linkedTransactions The linkedTransactions parameter - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return LinkedTransactions - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public LinkedTransactions updateLinkedTransaction( - String accessToken, - String xeroTenantId, - UUID linkedTransactionID, - LinkedTransactions linkedTransactions, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateLinkedTransactionForHttpResponse( - accessToken, xeroTenantId, linkedTransactionID, linkedTransactions, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateLinkedTransaction -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("LinkedTransactions", object.getMessage(), e); - } - handler.validationError("LinkedTransactions", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific linked transactions (billable expenses) - * - *

200 - Success - return response of type LinkedTransactions array with updated - * LinkedTransaction - * - *

400 - Success - return response of type LinkedTransactions array with updated - * LinkedTransaction - * - * @param xeroTenantId Xero identifier for Tenant - * @param linkedTransactionID Unique identifier for a LinkedTransaction - * @param linkedTransactions The linkedTransactions parameter - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateLinkedTransactionForHttpResponse( - String accessToken, - String xeroTenantId, - UUID linkedTransactionID, - LinkedTransactions linkedTransactions, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateLinkedTransaction"); - } // verify the required parameter 'linkedTransactionID' is set - if (linkedTransactionID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'linkedTransactionID' when calling" - + " updateLinkedTransaction"); - } // verify the required parameter 'linkedTransactions' is set - if (linkedTransactions == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'linkedTransactions' when calling" - + " updateLinkedTransaction"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateLinkedTransaction"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("LinkedTransactionID", linkedTransactionID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/LinkedTransactions/{LinkedTransactionID}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(linkedTransactions); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates a specific manual journal - * - *

200 - Success - return response of type ManualJournals array with an updated - * ManualJournal - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param manualJournals The manualJournals parameter - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return ManualJournals - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public ManualJournals updateManualJournal( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - ManualJournals manualJournals, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateManualJournalForHttpResponse( - accessToken, xeroTenantId, manualJournalID, manualJournals, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateManualJournal -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ManualJournals", object.getMessage(), e); - } - handler.validationError("ManualJournals", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific manual journal - * - *

200 - Success - return response of type ManualJournals array with an updated - * ManualJournal - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param manualJournals The manualJournals parameter - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateManualJournalForHttpResponse( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - ManualJournals manualJournals, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateManualJournal"); - } // verify the required parameter 'manualJournalID' is set - if (manualJournalID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'manualJournalID' when calling updateManualJournal"); - } // verify the required parameter 'manualJournals' is set - if (manualJournals == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'manualJournals' when calling updateManualJournal"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateManualJournal"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ManualJournalID", manualJournalID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(manualJournals); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - // Overload params for updateManualJournalAttachmentByFileName to allow byte[] or File type to be - // passed as body - /** - * Updates a specific attachment from a specific manual journal by file name - * - *

200 - Success - return response of type Attachments array with an update Attachment - * for a ManualJournals - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API - */ - public Attachments updateManualJournalAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateManualJournalAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey, mimeType); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateManualJournalAttachmentByFileName -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific attachment from a specific manual journal by file name - * - *

200 - Success - return response of type Attachments array with an update Attachment - * for a ManualJournals - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public HttpResponse updateManualJournalAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'manualJournalID' is set - if (manualJournalID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'manualJournalID' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateManualJournalAttachmentByFileName"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateManualJournalAttachmentByFileName"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ManualJournalID", manualJournalID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - ByteArrayContent content = null; - - content = new ByteArrayContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates a specific attachment from a specific manual journal by file name - * - *

200 - Success - return response of type Attachments array with an update Attachment - * for a ManualJournals - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public Attachments updateManualJournalAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - String fileName, - File body, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateManualJournalAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, manualJournalID, fileName, body, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateManualJournalAttachmentByFileName -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); - } - handler.validationError("Attachments", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific attachment from a specific manual journal by file name - * - *

200 - Success - return response of type Attachments array with an update Attachment - * for a ManualJournals - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param manualJournalID Unique identifier for a ManualJournal - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateManualJournalAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID manualJournalID, - String fileName, - File body, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'manualJournalID' is set - if (manualJournalID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'manualJournalID' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateManualJournalAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateManualJournalAttachmentByFileName"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateManualJournalAttachmentByFileName"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ManualJournalID", manualJournalID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/ManualJournals/{ManualJournalID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); - HttpContent content = null; - content = new FileContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates or creates one or more spent or received money transaction - * - *

200 - Success - return response of type BankTransactions array with new - * BankTransaction - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactions The bankTransactions parameter - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return BankTransactions - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public BankTransactions updateOrCreateBankTransactions( - String accessToken, - String xeroTenantId, - BankTransactions bankTransactions, - Boolean summarizeErrors, - Integer unitdp, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateOrCreateBankTransactionsForHttpResponse( - accessToken, xeroTenantId, bankTransactions, summarizeErrors, unitdp, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateOrCreateBankTransactions -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("BankTransactions", object.getMessage(), e); - } - handler.validationError("BankTransactions", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates or creates one or more spent or received money transaction - * - *

200 - Success - return response of type BankTransactions array with new - * BankTransaction - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param bankTransactions The bankTransactions parameter - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateOrCreateBankTransactionsForHttpResponse( - String accessToken, - String xeroTenantId, - BankTransactions bankTransactions, - Boolean summarizeErrors, - Integer unitdp, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateOrCreateBankTransactions"); - } // verify the required parameter 'bankTransactions' is set - if (bankTransactions == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'bankTransactions' when calling" - + " updateOrCreateBankTransactions"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateOrCreateBankTransactions"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/BankTransactions"); - if (summarizeErrors != null) { - String key = "summarizeErrors"; - Object value = summarizeErrors; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - String url = uriBuilder.build().toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(bankTransactions); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates or creates one or more contacts in a Xero organisation - * - *

200 - Success - return response of type Contacts array with newly created Contact - * - *

400 - Validation Error - some data was incorrect returns response of type Error - * - * @param xeroTenantId Xero identifier for Tenant - * @param contacts The contacts parameter - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return Contacts - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public Contacts updateOrCreateContacts( - String accessToken, - String xeroTenantId, - Contacts contacts, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateOrCreateContactsForHttpResponse( - accessToken, xeroTenantId, contacts, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateOrCreateContacts -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Contacts", object.getMessage(), e); - } - handler.validationError("Contacts", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates or creates one or more contacts in a Xero organisation - * - *

200 - Success - return response of type Contacts array with newly created Contact - * - *

400 - Validation Error - some data was incorrect returns response of type Error - * - * @param xeroTenantId Xero identifier for Tenant - * @param contacts The contacts parameter - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateOrCreateContactsForHttpResponse( - String accessToken, - String xeroTenantId, - Contacts contacts, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateContacts"); - } // verify the required parameter 'contacts' is set - if (contacts == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'contacts' when calling updateOrCreateContacts"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateContacts"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Contacts"); - if (summarizeErrors != null) { - String key = "summarizeErrors"; - Object value = summarizeErrors; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - String url = uriBuilder.build().toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(contacts); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Updates or creates one or more credit notes - * - *

200 - Success - return response of type Credit Notes array of newly created - * CreditNote - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param creditNotes an array of Credit Notes with a single CreditNote object. - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return CreditNotes - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public CreditNotes updateOrCreateCreditNotes( - String accessToken, - String xeroTenantId, - CreditNotes creditNotes, - Boolean summarizeErrors, - Integer unitdp, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateOrCreateCreditNotesForHttpResponse( - accessToken, xeroTenantId, creditNotes, summarizeErrors, unitdp, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateOrCreateCreditNotes -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("CreditNotes", object.getMessage(), e); - } - handler.validationError("CreditNotes", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates or creates one or more credit notes - * - *

200 - Success - return response of type Credit Notes array of newly created - * CreditNote - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param creditNotes an array of Credit Notes with a single CreditNote object. - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateOrCreateCreditNotesForHttpResponse( - String accessToken, - String xeroTenantId, - CreditNotes creditNotes, - Boolean summarizeErrors, - Integer unitdp, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateCreditNotes"); - } // verify the required parameter 'creditNotes' is set - if (creditNotes == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'creditNotes' when calling updateOrCreateCreditNotes"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateCreditNotes"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/BankTransactions"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -30444,156 +27548,14 @@ public HttpResponse updateOrCreateCreditNotesForHttpResponse( uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); } } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } - String url = uriBuilder.build().toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(creditNotes); - - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - - /** - * Creates a single new employees used in Xero payrun - * - *

200 - Success - return response of type Employees array with new Employee - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param employees Employees with array of Employee object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return Employees - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public Employees updateOrCreateEmployees( - String accessToken, - String xeroTenantId, - Employees employees, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateOrCreateEmployeesForHttpResponse( - accessToken, xeroTenantId, employees, summarizeErrors, idempotencyKey); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateOrCreateEmployees -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - if (e.getStatusCode() == 400) { - TypeReference errorTypeRef = - new TypeReference() {}; - com.xero.models.accounting.Error object = - apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); - if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Employees", object.getMessage(), e); - } - handler.validationError("Employees", object, e); - } else { - handler.execute(e); - } - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Creates a single new employees used in Xero payrun - * - *

200 - Success - return response of type Employees array with new Employee - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param employees Employees with array of Employee object in body of request - * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any - * with validation errors - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API - */ - public HttpResponse updateOrCreateEmployeesForHttpResponse( - String accessToken, - String xeroTenantId, - Employees employees, - Boolean summarizeErrors, - String idempotencyKey) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateEmployees"); - } // verify the required parameter 'employees' is set - if (employees == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'employees' when calling updateOrCreateEmployees"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateEmployees"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Employees"); - if (summarizeErrors != null) { - String key = "summarizeErrors"; - Object value = summarizeErrors; + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; if (value instanceof Collection) { List valueList = new ArrayList<>((Collection) value); if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { @@ -30618,7 +27580,7 @@ public HttpResponse updateOrCreateEmployeesForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(employees); + content = apiClient.new JacksonJsonHttpContent(bankTransactions); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -30633,44 +27595,41 @@ public HttpResponse updateOrCreateEmployeesForHttpResponse( } /** - * Updates or creates one or more sales invoices or purchase bills + * Updates or creates one or more contacts in a Xero organisation * - *

200 - Success - return response of type Invoices array with newly created Invoice + *

200 - Success - return response of type Contacts array with newly created Contact * - *

400 - A failed request due to validation error + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param invoices The invoices parameter + * @param contacts The contacts parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Invoices + * @return Contacts * @throws IOException if an error occurs while attempting to invoke the API * */ - public Invoices updateOrCreateInvoices( + public Contacts updateOrCreateContacts( String accessToken, String xeroTenantId, - Invoices invoices, + Contacts contacts, Boolean summarizeErrors, - Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreateInvoicesForHttpResponse( - accessToken, xeroTenantId, invoices, summarizeErrors, unitdp, idempotencyKey); + updateOrCreateContactsForHttpResponse( + accessToken, xeroTenantId, contacts, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreateInvoices -------------------"); + + " : updateOrCreateContacts -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -30680,9 +27639,9 @@ public Invoices updateOrCreateInvoices( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Invoices", object.getMessage(), e); + handler.validationError("Contacts", object.getMessage(), e); } - handler.validationError("Invoices", object, e); + handler.validationError("Contacts", object, e); } else { handler.execute(e); } @@ -30693,44 +27652,41 @@ public Invoices updateOrCreateInvoices( } /** - * Updates or creates one or more sales invoices or purchase bills + * Updates or creates one or more contacts in a Xero organisation * - *

200 - Success - return response of type Invoices array with newly created Invoice + *

200 - Success - return response of type Contacts array with newly created Contact * - *

400 - A failed request due to validation error + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param invoices The invoices parameter + * @param contacts The contacts parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreateInvoicesForHttpResponse( + public HttpResponse updateOrCreateContactsForHttpResponse( String accessToken, String xeroTenantId, - Invoices invoices, + Contacts contacts, Boolean summarizeErrors, - Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateInvoices"); - } // verify the required parameter 'invoices' is set - if (invoices == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateContacts"); + } // verify the required parameter 'contacts' is set + if (contacts == null) { throw new IllegalArgumentException( - "Missing the required parameter 'invoices' when calling updateOrCreateInvoices"); + "Missing the required parameter 'contacts' when calling updateOrCreateContacts"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateInvoices"); + "Missing the required parameter 'accessToken' when calling updateOrCreateContacts"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -30738,7 +27694,7 @@ public HttpResponse updateOrCreateInvoicesForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Contacts"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -30759,26 +27715,6 @@ public HttpResponse updateOrCreateInvoicesForHttpResponse( uriBuilder = uriBuilder.queryParam(key, value); } } - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -30786,7 +27722,7 @@ public HttpResponse updateOrCreateInvoicesForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(invoices); + content = apiClient.new JacksonJsonHttpContent(contacts); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -30801,14 +27737,15 @@ public HttpResponse updateOrCreateInvoicesForHttpResponse( } /** - * Updates or creates one or more items + * Updates or creates one or more credit notes * - *

200 - Success - return response of type Items array with newly created Item + *

200 - Success - return response of type Credit Notes array of newly created + * CreditNote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param items The items parameter + * @param creditNotes an array of Credit Notes with a single CreditNote object. * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal @@ -30816,29 +27753,29 @@ public HttpResponse updateOrCreateInvoicesForHttpResponse( * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Items + * @return CreditNotes * @throws IOException if an error occurs while attempting to invoke the API * */ - public Items updateOrCreateItems( + public CreditNotes updateOrCreateCreditNotes( String accessToken, String xeroTenantId, - Items items, + CreditNotes creditNotes, Boolean summarizeErrors, Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreateItemsForHttpResponse( - accessToken, xeroTenantId, items, summarizeErrors, unitdp, idempotencyKey); + updateOrCreateCreditNotesForHttpResponse( + accessToken, xeroTenantId, creditNotes, summarizeErrors, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreateItems -------------------"); + + " : updateOrCreateCreditNotes -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -30848,9 +27785,9 @@ public Items updateOrCreateItems( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Items", object.getMessage(), e); + handler.validationError("CreditNotes", object.getMessage(), e); } - handler.validationError("Items", object, e); + handler.validationError("CreditNotes", object, e); } else { handler.execute(e); } @@ -30861,14 +27798,15 @@ public Items updateOrCreateItems( } /** - * Updates or creates one or more items + * Updates or creates one or more credit notes * - *

200 - Success - return response of type Items array with newly created Item + *

200 - Success - return response of type Credit Notes array of newly created + * CreditNote * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param items The items parameter + * @param creditNotes an array of Credit Notes with a single CreditNote object. * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal @@ -30879,10 +27817,10 @@ public Items updateOrCreateItems( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreateItemsForHttpResponse( + public HttpResponse updateOrCreateCreditNotesForHttpResponse( String accessToken, String xeroTenantId, - Items items, + CreditNotes creditNotes, Boolean summarizeErrors, Integer unitdp, String idempotencyKey) @@ -30890,15 +27828,15 @@ public HttpResponse updateOrCreateItemsForHttpResponse( // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateItems"); - } // verify the required parameter 'items' is set - if (items == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateCreditNotes"); + } // verify the required parameter 'creditNotes' is set + if (creditNotes == null) { throw new IllegalArgumentException( - "Missing the required parameter 'items' when calling updateOrCreateItems"); + "Missing the required parameter 'creditNotes' when calling updateOrCreateCreditNotes"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateItems"); + "Missing the required parameter 'accessToken' when calling updateOrCreateCreditNotes"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -30906,7 +27844,7 @@ public HttpResponse updateOrCreateItemsForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Items"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/CreditNotes"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -30954,7 +27892,7 @@ public HttpResponse updateOrCreateItemsForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(items); + content = apiClient.new JacksonJsonHttpContent(creditNotes); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -30969,42 +27907,41 @@ public HttpResponse updateOrCreateItemsForHttpResponse( } /** - * Updates or creates a single manual journal + * Creates a single new employees used in Xero payrun * - *

200 - Success - return response of type ManualJournals array with newly created - * ManualJournal + *

200 - Success - return response of type Employees array with new Employee * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param manualJournals ManualJournals array with ManualJournal object in body of request + * @param employees Employees with array of Employee object in body of request * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return ManualJournals + * @return Employees * @throws IOException if an error occurs while attempting to invoke the API * */ - public ManualJournals updateOrCreateManualJournals( + public Employees updateOrCreateEmployees( String accessToken, String xeroTenantId, - ManualJournals manualJournals, + Employees employees, Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreateManualJournalsForHttpResponse( - accessToken, xeroTenantId, manualJournals, summarizeErrors, idempotencyKey); + updateOrCreateEmployeesForHttpResponse( + accessToken, xeroTenantId, employees, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreateManualJournals -------------------"); + + " : updateOrCreateEmployees -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31014,9 +27951,9 @@ public ManualJournals updateOrCreateManualJournals( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("ManualJournals", object.getMessage(), e); + handler.validationError("Employees", object.getMessage(), e); } - handler.validationError("ManualJournals", object, e); + handler.validationError("Employees", object, e); } else { handler.execute(e); } @@ -31027,15 +27964,14 @@ public ManualJournals updateOrCreateManualJournals( } /** - * Updates or creates a single manual journal + * Creates a single new employees used in Xero payrun * - *

200 - Success - return response of type ManualJournals array with newly created - * ManualJournal + *

200 - Success - return response of type Employees array with new Employee * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param manualJournals ManualJournals array with ManualJournal object in body of request + * @param employees Employees with array of Employee object in body of request * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -31044,27 +27980,25 @@ public ManualJournals updateOrCreateManualJournals( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreateManualJournalsForHttpResponse( + public HttpResponse updateOrCreateEmployeesForHttpResponse( String accessToken, String xeroTenantId, - ManualJournals manualJournals, + Employees employees, Boolean summarizeErrors, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateOrCreateManualJournals"); - } // verify the required parameter 'manualJournals' is set - if (manualJournals == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateEmployees"); + } // verify the required parameter 'employees' is set + if (employees == null) { throw new IllegalArgumentException( - "Missing the required parameter 'manualJournals' when calling" - + " updateOrCreateManualJournals"); + "Missing the required parameter 'employees' when calling updateOrCreateEmployees"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateManualJournals"); + "Missing the required parameter 'accessToken' when calling updateOrCreateEmployees"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -31072,7 +28006,7 @@ public HttpResponse updateOrCreateManualJournalsForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Employees"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -31100,7 +28034,7 @@ public HttpResponse updateOrCreateManualJournalsForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(manualJournals); + content = apiClient.new JacksonJsonHttpContent(employees); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -31115,42 +28049,44 @@ public HttpResponse updateOrCreateManualJournalsForHttpResponse( } /** - * Updates or creates one or more purchase orders + * Updates or creates one or more sales invoices or purchase bills * - *

200 - Success - return response of type PurchaseOrder array for specified - * PurchaseOrder + *

200 - Success - return response of type Invoices array with newly created Invoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrders The purchaseOrders parameter + * @param invoices The invoices parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return PurchaseOrders + * @return Invoices * @throws IOException if an error occurs while attempting to invoke the API * */ - public PurchaseOrders updateOrCreatePurchaseOrders( + public Invoices updateOrCreateInvoices( String accessToken, String xeroTenantId, - PurchaseOrders purchaseOrders, + Invoices invoices, Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreatePurchaseOrdersForHttpResponse( - accessToken, xeroTenantId, purchaseOrders, summarizeErrors, idempotencyKey); + updateOrCreateInvoicesForHttpResponse( + accessToken, xeroTenantId, invoices, summarizeErrors, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreatePurchaseOrders -------------------"); + + " : updateOrCreateInvoices -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31160,9 +28096,9 @@ public PurchaseOrders updateOrCreatePurchaseOrders( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("PurchaseOrders", object.getMessage(), e); + handler.validationError("Invoices", object.getMessage(), e); } - handler.validationError("PurchaseOrders", object, e); + handler.validationError("Invoices", object, e); } else { handler.execute(e); } @@ -31173,44 +28109,44 @@ public PurchaseOrders updateOrCreatePurchaseOrders( } /** - * Updates or creates one or more purchase orders + * Updates or creates one or more sales invoices or purchase bills * - *

200 - Success - return response of type PurchaseOrder array for specified - * PurchaseOrder + *

200 - Success - return response of type Invoices array with newly created Invoice * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrders The purchaseOrders parameter + * @param invoices The invoices parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( + public HttpResponse updateOrCreateInvoicesForHttpResponse( String accessToken, String xeroTenantId, - PurchaseOrders purchaseOrders, + Invoices invoices, Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateOrCreatePurchaseOrders"); - } // verify the required parameter 'purchaseOrders' is set - if (purchaseOrders == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateInvoices"); + } // verify the required parameter 'invoices' is set + if (invoices == null) { throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrders' when calling" - + " updateOrCreatePurchaseOrders"); + "Missing the required parameter 'invoices' when calling updateOrCreateInvoices"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreatePurchaseOrders"); + "Missing the required parameter 'accessToken' when calling updateOrCreateInvoices"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -31218,7 +28154,7 @@ public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Invoices"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -31239,6 +28175,26 @@ public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( uriBuilder = uriBuilder.queryParam(key, value); } } + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -31246,7 +28202,7 @@ public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(purchaseOrders); + content = apiClient.new JacksonJsonHttpContent(invoices); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -31261,41 +28217,44 @@ public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( } /** - * Updates or creates one or more quotes + * Updates or creates one or more items * - *

200 - Success - return response of type Quotes array with updated or created Quote + *

200 - Success - return response of type Items array with newly created Item * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param quotes The quotes parameter + * @param items The items parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Quotes + * @return Items * @throws IOException if an error occurs while attempting to invoke the API * */ - public Quotes updateOrCreateQuotes( + public Items updateOrCreateItems( String accessToken, String xeroTenantId, - Quotes quotes, + Items items, Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreateQuotesForHttpResponse( - accessToken, xeroTenantId, quotes, summarizeErrors, idempotencyKey); + updateOrCreateItemsForHttpResponse( + accessToken, xeroTenantId, items, summarizeErrors, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreateQuotes -------------------"); + + " : updateOrCreateItems -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31305,9 +28264,9 @@ public Quotes updateOrCreateQuotes( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Quotes", object.getMessage(), e); + handler.validationError("Items", object.getMessage(), e); } - handler.validationError("Quotes", object, e); + handler.validationError("Items", object, e); } else { handler.execute(e); } @@ -31318,41 +28277,44 @@ public Quotes updateOrCreateQuotes( } /** - * Updates or creates one or more quotes + * Updates or creates one or more items * - *

200 - Success - return response of type Quotes array with updated or created Quote + *

200 - Success - return response of type Items array with newly created Item * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param quotes The quotes parameter + * @param items The items parameter * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreateQuotesForHttpResponse( + public HttpResponse updateOrCreateItemsForHttpResponse( String accessToken, String xeroTenantId, - Quotes quotes, + Items items, Boolean summarizeErrors, + Integer unitdp, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateOrCreateQuotes"); - } // verify the required parameter 'quotes' is set - if (quotes == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateItems"); + } // verify the required parameter 'items' is set + if (items == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quotes' when calling updateOrCreateQuotes"); + "Missing the required parameter 'items' when calling updateOrCreateItems"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateOrCreateQuotes"); + "Missing the required parameter 'accessToken' when calling updateOrCreateItems"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -31360,7 +28322,7 @@ public HttpResponse updateOrCreateQuotesForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Items"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -31381,6 +28343,26 @@ public HttpResponse updateOrCreateQuotesForHttpResponse( uriBuilder = uriBuilder.queryParam(key, value); } } + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -31388,7 +28370,7 @@ public HttpResponse updateOrCreateQuotesForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(quotes); + content = apiClient.new JacksonJsonHttpContent(items); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -31403,43 +28385,42 @@ public HttpResponse updateOrCreateQuotesForHttpResponse( } /** - * Creates or deletes one or more repeating invoice templates + * Updates or creates a single manual journal * - *

200 - Success - return response of type RepeatingInvoices array with newly created - * RepeatingInvoice + *

200 - Success - return response of type ManualJournals array with newly created + * ManualJournal * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body - * of request + * @param manualJournals ManualJournals array with ManualJournal object in body of request * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return RepeatingInvoices + * @return ManualJournals * @throws IOException if an error occurs while attempting to invoke the API * */ - public RepeatingInvoices updateOrCreateRepeatingInvoices( + public ManualJournals updateOrCreateManualJournals( String accessToken, String xeroTenantId, - RepeatingInvoices repeatingInvoices, + ManualJournals manualJournals, Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateOrCreateRepeatingInvoicesForHttpResponse( - accessToken, xeroTenantId, repeatingInvoices, summarizeErrors, idempotencyKey); + updateOrCreateManualJournalsForHttpResponse( + accessToken, xeroTenantId, manualJournals, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateOrCreateRepeatingInvoices -------------------"); + + " : updateOrCreateManualJournals -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31449,9 +28430,9 @@ public RepeatingInvoices updateOrCreateRepeatingInvoices( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("RepeatingInvoices", object.getMessage(), e); + handler.validationError("ManualJournals", object.getMessage(), e); } - handler.validationError("RepeatingInvoices", object, e); + handler.validationError("ManualJournals", object, e); } else { handler.execute(e); } @@ -31462,16 +28443,15 @@ public RepeatingInvoices updateOrCreateRepeatingInvoices( } /** - * Creates or deletes one or more repeating invoice templates + * Updates or creates a single manual journal * - *

200 - Success - return response of type RepeatingInvoices array with newly created - * RepeatingInvoice + *

200 - Success - return response of type ManualJournals array with newly created + * ManualJournal * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body - * of request + * @param manualJournals ManualJournals array with ManualJournal object in body of request * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate @@ -31480,10 +28460,10 @@ public RepeatingInvoices updateOrCreateRepeatingInvoices( * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( + public HttpResponse updateOrCreateManualJournalsForHttpResponse( String accessToken, String xeroTenantId, - RepeatingInvoices repeatingInvoices, + ManualJournals manualJournals, Boolean summarizeErrors, String idempotencyKey) throws IOException { @@ -31491,17 +28471,16 @@ public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateOrCreateRepeatingInvoices"); - } // verify the required parameter 'repeatingInvoices' is set - if (repeatingInvoices == null) { + + " updateOrCreateManualJournals"); + } // verify the required parameter 'manualJournals' is set + if (manualJournals == null) { throw new IllegalArgumentException( - "Missing the required parameter 'repeatingInvoices' when calling" - + " updateOrCreateRepeatingInvoices"); + "Missing the required parameter 'manualJournals' when calling" + + " updateOrCreateManualJournals"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateOrCreateRepeatingInvoices"); + "Missing the required parameter 'accessToken' when calling updateOrCreateManualJournals"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -31509,7 +28488,7 @@ public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/RepeatingInvoices"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/ManualJournals"); if (summarizeErrors != null) { String key = "summarizeErrors"; Object value = summarizeErrors; @@ -31537,7 +28516,7 @@ public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(repeatingInvoices); + content = apiClient.new JacksonJsonHttpContent(manualJournals); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -31552,40 +28531,42 @@ public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( } /** - * Updates a specific purchase order + * Updates or creates one or more purchase orders * - *

200 - Success - return response of type PurchaseOrder array for updated PurchaseOrder + *

200 - Success - return response of type PurchaseOrder array for specified + * PurchaseOrder * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order * @param purchaseOrders The purchaseOrders parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return PurchaseOrders * @throws IOException if an error occurs while attempting to invoke the API * */ - public PurchaseOrders updatePurchaseOrder( + public PurchaseOrders updateOrCreatePurchaseOrders( String accessToken, String xeroTenantId, - UUID purchaseOrderID, PurchaseOrders purchaseOrders, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updatePurchaseOrderForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, purchaseOrders, idempotencyKey); + updateOrCreatePurchaseOrdersForHttpResponse( + accessToken, xeroTenantId, purchaseOrders, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updatePurchaseOrder -------------------"); + + " : updateOrCreatePurchaseOrders -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31608,44 +28589,44 @@ public PurchaseOrders updatePurchaseOrder( } /** - * Updates a specific purchase order + * Updates or creates one or more purchase orders * - *

200 - Success - return response of type PurchaseOrder array for updated PurchaseOrder + *

200 - Success - return response of type PurchaseOrder array for specified + * PurchaseOrder * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order * @param purchaseOrders The purchaseOrders parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updatePurchaseOrderForHttpResponse( + public HttpResponse updateOrCreatePurchaseOrdersForHttpResponse( String accessToken, String xeroTenantId, - UUID purchaseOrderID, PurchaseOrders purchaseOrders, + Boolean summarizeErrors, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updatePurchaseOrder"); - } // verify the required parameter 'purchaseOrderID' is set - if (purchaseOrderID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrderID' when calling updatePurchaseOrder"); + "Missing the required parameter 'xeroTenantId' when calling" + + " updateOrCreatePurchaseOrders"); } // verify the required parameter 'purchaseOrders' is set if (purchaseOrders == null) { throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrders' when calling updatePurchaseOrder"); + "Missing the required parameter 'purchaseOrders' when calling" + + " updateOrCreatePurchaseOrders"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updatePurchaseOrder"); + "Missing the required parameter 'accessToken' when calling updateOrCreatePurchaseOrders"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -31653,13 +28634,28 @@ public HttpResponse updatePurchaseOrderForHttpResponse( headers.setAccept("application/json"); headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("PurchaseOrderID", purchaseOrderID); - - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders"); + if (summarizeErrors != null) { + String key = "summarizeErrors"; + Object value = summarizeErrors; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } + String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); @@ -31680,51 +28676,57 @@ public HttpResponse updatePurchaseOrderForHttpResponse( .execute(); } - // Overload params for updatePurchaseOrderAttachmentByFileName to allow byte[] or File type to be - // passed as body /** - * Updates a specific attachment for a specific purchase order by filename + * Updates or creates one or more quotes * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type Quotes array with updated or created Quote * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param quotes The quotes parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @return Quotes + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updatePurchaseOrderAttachmentByFileName( + public Quotes updateOrCreateQuotes( String accessToken, String xeroTenantId, - UUID purchaseOrderID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + Quotes quotes, + Boolean summarizeErrors, + String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updatePurchaseOrderAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey, mimeType); + updateOrCreateQuotesForHttpResponse( + accessToken, xeroTenantId, quotes, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updatePurchaseOrderAttachmentByFileName -------------------"); + + " : updateOrCreateQuotes -------------------"); logger.debug(e.toString()); } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Quotes", object.getMessage(), e); + } + handler.validationError("Quotes", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -31732,81 +28734,78 @@ public Attachments updatePurchaseOrderAttachmentByFileName( } /** - * Updates a specific attachment for a specific purchase order by filename + * Updates or creates one or more quotes * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type Quotes array with updated or created Quote * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param quotes The quotes parameter + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updatePurchaseOrderAttachmentByFileNameForHttpResponse( + public HttpResponse updateOrCreateQuotesForHttpResponse( String accessToken, String xeroTenantId, - UUID purchaseOrderID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + Quotes quotes, + Boolean summarizeErrors, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'purchaseOrderID' is set - if (purchaseOrderID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrderID' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'xeroTenantId' when calling updateOrCreateQuotes"); + } // verify the required parameter 'quotes' is set + if (quotes == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updatePurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'quotes' when calling updateOrCreateQuotes"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updatePurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateOrCreateQuotes"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("PurchaseOrderID", purchaseOrderID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes"); + if (summarizeErrors != null) { + String key = "summarizeErrors"; + Object value = summarizeErrors; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } + String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(quotes); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -31820,42 +28819,43 @@ public HttpResponse updatePurchaseOrderAttachmentByFileNameForHttpResponse( } /** - * Updates a specific attachment for a specific purchase order by filename + * Creates or deletes one or more repeating invoice templates * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type RepeatingInvoices array with newly created + * RepeatingInvoice * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body + * of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return RepeatingInvoices * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updatePurchaseOrderAttachmentByFileName( + public RepeatingInvoices updateOrCreateRepeatingInvoices( String accessToken, String xeroTenantId, - UUID purchaseOrderID, - String fileName, - File body, + RepeatingInvoices repeatingInvoices, + Boolean summarizeErrors, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updatePurchaseOrderAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); + updateOrCreateRepeatingInvoicesForHttpResponse( + accessToken, xeroTenantId, repeatingInvoices, summarizeErrors, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updatePurchaseOrderAttachmentByFileName -------------------"); + + " : updateOrCreateRepeatingInvoices -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -31865,9 +28865,9 @@ public Attachments updatePurchaseOrderAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("RepeatingInvoices", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("RepeatingInvoices", object, e); } else { handler.execute(e); } @@ -31878,79 +28878,83 @@ public Attachments updatePurchaseOrderAttachmentByFileName( } /** - * Updates a specific attachment for a specific purchase order by filename + * Creates or deletes one or more repeating invoice templates * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type RepeatingInvoices array with newly created + * RepeatingInvoice * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param purchaseOrderID Unique identifier for an Purchase Order - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param repeatingInvoices RepeatingInvoices with an array of repeating invoice objects in body + * of request + * @param summarizeErrors If false return 200 OK and mix of successfully created objects and any + * with validation errors * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updatePurchaseOrderAttachmentByFileNameForHttpResponse( + public HttpResponse updateOrCreateRepeatingInvoicesForHttpResponse( String accessToken, String xeroTenantId, - UUID purchaseOrderID, - String fileName, - File body, + RepeatingInvoices repeatingInvoices, + Boolean summarizeErrors, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'purchaseOrderID' is set - if (purchaseOrderID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'purchaseOrderID' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updatePurchaseOrderAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + + " updateOrCreateRepeatingInvoices"); + } // verify the required parameter 'repeatingInvoices' is set + if (repeatingInvoices == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updatePurchaseOrderAttachmentByFileName"); + "Missing the required parameter 'repeatingInvoices' when calling" + + " updateOrCreateRepeatingInvoices"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updatePurchaseOrderAttachmentByFileName"); + + " updateOrCreateRepeatingInvoices"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("PurchaseOrderID", purchaseOrderID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/RepeatingInvoices"); + if (summarizeErrors != null) { + String key = "summarizeErrors"; + Object value = summarizeErrors; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } + String url = uriBuilder.build().toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(repeatingInvoices); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -31964,35 +28968,40 @@ public HttpResponse updatePurchaseOrderAttachmentByFileNameForHttpResponse( } /** - * Updates a specific quote + * Updates a specific purchase order * - *

200 - Success - return response of type Quotes array with updated Quote + *

200 - Success - return response of type PurchaseOrder array for updated PurchaseOrder * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote - * @param quotes The quotes parameter + * @param purchaseOrderID Unique identifier for an Purchase Order + * @param purchaseOrders The purchaseOrders parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Quotes + * @return PurchaseOrders * @throws IOException if an error occurs while attempting to invoke the API * */ - public Quotes updateQuote( - String accessToken, String xeroTenantId, UUID quoteID, Quotes quotes, String idempotencyKey) + public PurchaseOrders updatePurchaseOrder( + String accessToken, + String xeroTenantId, + UUID purchaseOrderID, + PurchaseOrders purchaseOrders, + String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateQuoteForHttpResponse(accessToken, xeroTenantId, quoteID, quotes, idempotencyKey); + updatePurchaseOrderForHttpResponse( + accessToken, xeroTenantId, purchaseOrderID, purchaseOrders, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateQuote -------------------"); + + " : updatePurchaseOrder -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -32002,9 +29011,9 @@ public Quotes updateQuote( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Quotes", object.getMessage(), e); + handler.validationError("PurchaseOrders", object.getMessage(), e); } - handler.validationError("Quotes", object, e); + handler.validationError("PurchaseOrders", object, e); } else { handler.execute(e); } @@ -32015,40 +29024,44 @@ public Quotes updateQuote( } /** - * Updates a specific quote + * Updates a specific purchase order * - *

200 - Success - return response of type Quotes array with updated Quote + *

200 - Success - return response of type PurchaseOrder array for updated PurchaseOrder * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote - * @param quotes The quotes parameter + * @param purchaseOrderID Unique identifier for an Purchase Order + * @param purchaseOrders The purchaseOrders parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateQuoteForHttpResponse( - String accessToken, String xeroTenantId, UUID quoteID, Quotes quotes, String idempotencyKey) + public HttpResponse updatePurchaseOrderForHttpResponse( + String accessToken, + String xeroTenantId, + UUID purchaseOrderID, + PurchaseOrders purchaseOrders, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateQuote"); - } // verify the required parameter 'quoteID' is set - if (quoteID == null) { + "Missing the required parameter 'xeroTenantId' when calling updatePurchaseOrder"); + } // verify the required parameter 'purchaseOrderID' is set + if (purchaseOrderID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quoteID' when calling updateQuote"); - } // verify the required parameter 'quotes' is set - if (quotes == null) { + "Missing the required parameter 'purchaseOrderID' when calling updatePurchaseOrder"); + } // verify the required parameter 'purchaseOrders' is set + if (purchaseOrders == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quotes' when calling updateQuote"); + "Missing the required parameter 'purchaseOrders' when calling updatePurchaseOrder"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateQuote"); + "Missing the required parameter 'accessToken' when calling updatePurchaseOrder"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -32058,9 +29071,10 @@ public HttpResponse updateQuoteForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("QuoteID", quoteID); + uriVariables.put("PurchaseOrderID", purchaseOrderID); - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}"); + UriBuilder uriBuilder = + UriBuilder.fromUri(apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -32068,7 +29082,7 @@ public HttpResponse updateQuoteForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(quotes); + content = apiClient.new JacksonJsonHttpContent(purchaseOrders); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -32082,51 +29096,58 @@ public HttpResponse updateQuoteForHttpResponse( .execute(); } - // Overload params for updateQuoteAttachmentByFileName to allow byte[] or File type to be passed - // as body /** - * Updates a specific attachment from a specific quote by filename + * Updates a specific attachment for a specific purchase order by filename * *

200 - Success - return response of type Attachments array of Attachment * *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote + * @param purchaseOrderID Unique identifier for an Purchase Order * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateQuoteAttachmentByFileName( + public Attachments updatePurchaseOrderAttachmentByFileName( String accessToken, String xeroTenantId, - UUID quoteID, + UUID purchaseOrderID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { try { TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateQuoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey, mimeType); + updatePurchaseOrderAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, purchaseOrderID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateQuoteAttachmentByFileName -------------------"); + + " : updatePurchaseOrderAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Attachments", object.getMessage(), e); + } + handler.validationError("Attachments", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -32134,54 +29155,55 @@ public Attachments updateQuoteAttachmentByFileName( } /** - * Updates a specific attachment from a specific quote by filename + * Updates a specific attachment for a specific purchase order by filename * *

200 - Success - return response of type Attachments array of Attachment * *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param quoteID Unique identifier for an Quote + * @param purchaseOrderID Unique identifier for an Purchase Order * @param fileName Name of the attachment * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( + public HttpResponse updatePurchaseOrderAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID quoteID, + UUID purchaseOrderID, String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + File body, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( "Missing the required parameter 'xeroTenantId' when calling" - + " updateQuoteAttachmentByFileName"); - } // verify the required parameter 'quoteID' is set - if (quoteID == null) { + + " updatePurchaseOrderAttachmentByFileName"); + } // verify the required parameter 'purchaseOrderID' is set + if (purchaseOrderID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quoteID' when calling updateQuoteAttachmentByFileName"); + "Missing the required parameter 'purchaseOrderID' when calling" + + " updatePurchaseOrderAttachmentByFileName"); } // verify the required parameter 'fileName' is set if (fileName == null) { throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling updateQuoteAttachmentByFileName"); + "Missing the required parameter 'fileName' when calling" + + " updatePurchaseOrderAttachmentByFileName"); } // verify the required parameter 'body' is set if (body == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateQuoteAttachmentByFileName"); + "Missing the required parameter 'body' when calling" + + " updatePurchaseOrderAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( "Missing the required parameter 'accessToken' when calling" - + " updateQuoteAttachmentByFileName"); + + " updatePurchaseOrderAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); @@ -32191,20 +29213,21 @@ public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); - uriVariables.put("QuoteID", quoteID); + uriVariables.put("PurchaseOrderID", purchaseOrderID); uriVariables.put("FileName", fileName); UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/Attachments/{FileName}"); + UriBuilder.fromUri( + apiClient.getBasePath() + "/PurchaseOrders/{PurchaseOrderID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(body); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -32218,42 +29241,35 @@ public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( } /** - * Updates a specific attachment from a specific quote by filename + * Updates a specific quote * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type Quotes array with updated Quote * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param quoteID Unique identifier for an Quote - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param quotes The quotes parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Attachments + * @return Quotes * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateQuoteAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID quoteID, - String fileName, - File body, - String idempotencyKey) + public Quotes updateQuote( + String accessToken, String xeroTenantId, UUID quoteID, Quotes quotes, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateQuoteAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); + updateQuoteForHttpResponse(accessToken, xeroTenantId, quoteID, quotes, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateQuoteAttachmentByFileName -------------------"); + + " : updateQuote -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -32263,9 +29279,9 @@ public Attachments updateQuoteAttachmentByFileName( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Attachments", object.getMessage(), e); + handler.validationError("Quotes", object.getMessage(), e); } - handler.validationError("Attachments", object, e); + handler.validationError("Quotes", object, e); } else { handler.execute(e); } @@ -32276,75 +29292,61 @@ public Attachments updateQuoteAttachmentByFileName( } /** - * Updates a specific attachment from a specific quote by filename + * Updates a specific quote * - *

200 - Success - return response of type Attachments array of Attachment + *

200 - Success - return response of type Quotes array with updated Quote * - *

400 - Validation Error - some data was incorrect returns response of type Error + *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param quoteID Unique identifier for an Quote - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param quotes The quotes parameter * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID quoteID, - String fileName, - File body, - String idempotencyKey) + public HttpResponse updateQuoteForHttpResponse( + String accessToken, String xeroTenantId, UUID quoteID, Quotes quotes, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateQuoteAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling updateQuote"); } // verify the required parameter 'quoteID' is set if (quoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'quoteID' when calling updateQuoteAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling updateQuoteAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'quoteID' when calling updateQuote"); + } // verify the required parameter 'quotes' is set + if (quotes == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateQuoteAttachmentByFileName"); + "Missing the required parameter 'quotes' when calling updateQuote"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateQuoteAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateQuote"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("QuoteID", quoteID); - uriVariables.put("FileName", fileName); - UriBuilder uriBuilder = - UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/Attachments/{FileName}"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(quotes); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -32358,43 +29360,42 @@ public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( } /** - * Updates a specific draft expense claim receipts + * Updates a specific attachment from a specific quote by filename * - *

200 - Success - return response of type Receipts array for updated Receipt + *

200 - Success - return response of type Attachments array of Attachment * - *

400 - A failed request due to validation error + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param receiptID Unique identifier for a Receipt - * @param receipts The receipts parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts + * @param quoteID Unique identifier for an Quote + * @param fileName Name of the attachment + * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request - * @return Receipts + * @return Attachments * @throws IOException if an error occurs while attempting to invoke the API * */ - public Receipts updateReceipt( + public Attachments updateQuoteAttachmentByFileName( String accessToken, String xeroTenantId, - UUID receiptID, - Receipts receipts, - Integer unitdp, + UUID quoteID, + String fileName, + File body, String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateReceiptForHttpResponse( - accessToken, xeroTenantId, receiptID, receipts, unitdp, idempotencyKey); + updateQuoteAttachmentByFileNameForHttpResponse( + accessToken, xeroTenantId, quoteID, fileName, body, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateReceipt -------------------"); + + " : updateQuoteAttachmentByFileName -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); @@ -32404,9 +29405,9 @@ public Receipts updateReceipt( com.xero.models.accounting.Error object = apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); if (object.getElements() == null || object.getElements().isEmpty()) { - handler.validationError("Receipts", object.getMessage(), e); + handler.validationError("Attachments", object.getMessage(), e); } - handler.validationError("Receipts", object, e); + handler.validationError("Attachments", object, e); } else { handler.execute(e); } @@ -32417,79 +29418,66 @@ public Receipts updateReceipt( } /** - * Updates a specific draft expense claim receipts + * Updates a specific attachment from a specific quote by filename * - *

200 - Success - return response of type Receipts array for updated Receipt + *

200 - Success - return response of type Attachments array of Attachment * - *

400 - A failed request due to validation error + *

400 - Validation Error - some data was incorrect returns response of type Error * * @param xeroTenantId Xero identifier for Tenant - * @param receiptID Unique identifier for a Receipt - * @param receipts The receipts parameter - * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal - * places for unit amounts + * @param quoteID Unique identifier for an Quote + * @param fileName Name of the attachment + * @param body Byte array of file in body of request * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. * @param accessToken Authorization token for user set in header of each request * @return HttpResponse * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateReceiptForHttpResponse( + public HttpResponse updateQuoteAttachmentByFileNameForHttpResponse( String accessToken, String xeroTenantId, - UUID receiptID, - Receipts receipts, - Integer unitdp, + UUID quoteID, + String fileName, + File body, String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling updateReceipt"); - } // verify the required parameter 'receiptID' is set - if (receiptID == null) { + "Missing the required parameter 'xeroTenantId' when calling" + + " updateQuoteAttachmentByFileName"); + } // verify the required parameter 'quoteID' is set + if (quoteID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'receiptID' when calling updateReceipt"); - } // verify the required parameter 'receipts' is set - if (receipts == null) { + "Missing the required parameter 'quoteID' when calling updateQuoteAttachmentByFileName"); + } // verify the required parameter 'fileName' is set + if (fileName == null) { throw new IllegalArgumentException( - "Missing the required parameter 'receipts' when calling updateReceipt"); + "Missing the required parameter 'fileName' when calling updateQuoteAttachmentByFileName"); + } // verify the required parameter 'body' is set + if (body == null) { + throw new IllegalArgumentException( + "Missing the required parameter 'body' when calling updateQuoteAttachmentByFileName"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling updateReceipt"); + "Missing the required parameter 'accessToken' when calling" + + " updateQuoteAttachmentByFileName"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/json"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("ReceiptID", receiptID); - - UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Receipts/{ReceiptID}"); - if (unitdp != null) { - String key = "unitdp"; - Object value = unitdp; - if (value instanceof Collection) { - List valueList = new ArrayList<>((Collection) value); - if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { - List list = new ArrayList(); - for (int i = 0; i < valueList.size(); i++) { - list.add(valueList.get(i).toString()); - } - uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); - } else { - uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); - } - } else if (value instanceof Object[]) { - uriBuilder = uriBuilder.queryParam(key, (Object[]) value); - } else { - uriBuilder = uriBuilder.queryParam(key, value); - } - } + headers.set("Idempotency-Key", idempotencyKey); + headers.setAccept("application/json"); + headers.setContentType("application/octet-stream"); + headers.setUserAgent(this.getUserAgent()); + // create a map of path variables + final Map uriVariables = new HashMap(); + uriVariables.put("QuoteID", quoteID); + uriVariables.put("FileName", fileName); + + UriBuilder uriBuilder = + UriBuilder.fromUri(apiClient.getBasePath() + "/Quotes/{QuoteID}/Attachments/{FileName}"); String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { @@ -32497,7 +29485,7 @@ public HttpResponse updateReceiptForHttpResponse( } HttpContent content = null; - content = apiClient.new JacksonJsonHttpContent(receipts); + content = apiClient.new JacksonJsonHttpContent(body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); @@ -32511,52 +29499,59 @@ public HttpResponse updateReceiptForHttpResponse( .execute(); } - // Overload params for updateReceiptAttachmentByFileName to allow byte[] or File type to be passed - // as body /** - * Updates a specific attachment on a specific expense claim receipts by file name + * Updates a specific draft expense claim receipts * - *

200 - Success - return response of type Attachments array with updated Attachment for - * a specified Receipt + *

200 - Success - return response of type Receipts array for updated Receipt * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param receiptID Unique identifier for a Receipt - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param receipts The receipts parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API + * @return Receipts + * @throws IOException if an error occurs while attempting to invoke the API * */ - public Attachments updateReceiptAttachmentByFileName( + public Receipts updateReceipt( String accessToken, String xeroTenantId, UUID receiptID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + Receipts receipts, + Integer unitdp, + String idempotencyKey) throws IOException { try { - TypeReference typeRef = new TypeReference() {}; + TypeReference typeRef = new TypeReference() {}; HttpResponse response = - updateReceiptAttachmentByFileNameForHttpResponse( - accessToken, xeroTenantId, receiptID, fileName, body, idempotencyKey, mimeType); + updateReceiptForHttpResponse( + accessToken, xeroTenantId, receiptID, receipts, unitdp, idempotencyKey); return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); } catch (HttpResponseException e) { if (logger.isDebugEnabled()) { logger.debug( "------------------ HttpResponseException " + e.getStatusCode() - + " : updateReceiptAttachmentByFileName -------------------"); + + " : updateReceipt -------------------"); logger.debug(e.toString()); } XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); + if (e.getStatusCode() == 400) { + TypeReference errorTypeRef = + new TypeReference() {}; + com.xero.models.accounting.Error object = + apiClient.getObjectMapper().readValue(e.getContent(), errorTypeRef); + if (object.getElements() == null || object.getElements().isEmpty()) { + handler.validationError("Receipts", object.getMessage(), e); + } + handler.validationError("Receipts", object, e); + } else { + handler.execute(e); + } } catch (IOException ioe) { throw ioe; } @@ -32564,81 +29559,88 @@ public Attachments updateReceiptAttachmentByFileName( } /** - * Updates a specific attachment on a specific expense claim receipts by file name + * Updates a specific draft expense claim receipts * - *

200 - Success - return response of type Attachments array with updated Attachment for - * a specified Receipt + *

200 - Success - return response of type Receipts array for updated Receipt * *

400 - A failed request due to validation error * * @param xeroTenantId Xero identifier for Tenant * @param receiptID Unique identifier for a Receipt - * @param fileName Name of the attachment - * @param body Byte array of file in body of request + * @param receipts The receipts parameter + * @param unitdp e.g. unitdp=4 – (Unit Decimal Places) You can opt in to use four decimal + * places for unit amounts * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate * processing. 128 character max. - * @param mimeType The type of file being attached * @param accessToken Authorization token for user set in header of each request * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * + * @throws IOException if an error occurs while attempting to invoke the API */ - public HttpResponse updateReceiptAttachmentByFileNameForHttpResponse( + public HttpResponse updateReceiptForHttpResponse( String accessToken, String xeroTenantId, UUID receiptID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) + Receipts receipts, + Integer unitdp, + String idempotencyKey) throws IOException { // verify the required parameter 'xeroTenantId' is set if (xeroTenantId == null) { throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateReceiptAttachmentByFileName"); + "Missing the required parameter 'xeroTenantId' when calling updateReceipt"); } // verify the required parameter 'receiptID' is set if (receiptID == null) { throw new IllegalArgumentException( - "Missing the required parameter 'receiptID' when calling" - + " updateReceiptAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateReceiptAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { + "Missing the required parameter 'receiptID' when calling updateReceipt"); + } // verify the required parameter 'receipts' is set + if (receipts == null) { throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling updateReceiptAttachmentByFileName"); + "Missing the required parameter 'receipts' when calling updateReceipt"); } if (accessToken == null) { throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateReceiptAttachmentByFileName"); + "Missing the required parameter 'accessToken' when calling updateReceipt"); } HttpHeaders headers = new HttpHeaders(); headers.set("xero-tenant-id", xeroTenantId); headers.set("Idempotency-Key", idempotencyKey); headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); + headers.setContentType("application/json"); headers.setUserAgent(this.getUserAgent()); // create a map of path variables final Map uriVariables = new HashMap(); uriVariables.put("ReceiptID", receiptID); - uriVariables.put("FileName", fileName); - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() + "/Receipts/{ReceiptID}/Attachments/{FileName}"); + UriBuilder uriBuilder = UriBuilder.fromUri(apiClient.getBasePath() + "/Receipts/{ReceiptID}"); + if (unitdp != null) { + String key = "unitdp"; + Object value = unitdp; + if (value instanceof Collection) { + List valueList = new ArrayList<>((Collection) value); + if (!valueList.isEmpty() && valueList.get(0) instanceof UUID) { + List list = new ArrayList(); + for (int i = 0; i < valueList.size(); i++) { + list.add(valueList.get(i).toString()); + } + uriBuilder = uriBuilder.queryParam(key, String.join(",", list)); + } else { + uriBuilder = uriBuilder.queryParam(key, String.join(",", valueList)); + } + } else if (value instanceof Object[]) { + uriBuilder = uriBuilder.queryParam(key, (Object[]) value); + } else { + uriBuilder = uriBuilder.queryParam(key, value); + } + } String url = uriBuilder.buildFromMap(uriVariables).toString(); GenericUrl genericUrl = new GenericUrl(url); if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - ByteArrayContent content = null; + HttpContent content = null; + content = apiClient.new JacksonJsonHttpContent(receipts); - content = new ByteArrayContent(mimeType, body); Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -32780,10 +29782,10 @@ public HttpResponse updateReceiptAttachmentByFileNameForHttpResponse( if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); @@ -32926,154 +29928,6 @@ public HttpResponse updateRepeatingInvoiceForHttpResponse( .execute(); } - // Overload params for updateRepeatingInvoiceAttachmentByFileName to allow byte[] or File type to - // be passed as body - /** - * Updates a specific attachment from a specific repeating invoices by file name - * - *

200 - Success - return response of type Attachments array with specified Attachment - * for a specified Repeating Invoice - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return Attachments - * @throws IOException if an error occurs while attempting to invoke the API - */ - public Attachments updateRepeatingInvoiceAttachmentByFileName( - String accessToken, - String xeroTenantId, - UUID repeatingInvoiceID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - try { - TypeReference typeRef = new TypeReference() {}; - HttpResponse response = - updateRepeatingInvoiceAttachmentByFileNameForHttpResponse( - accessToken, - xeroTenantId, - repeatingInvoiceID, - fileName, - body, - idempotencyKey, - mimeType); - return apiClient.getObjectMapper().readValue(response.getContent(), typeRef); - } catch (HttpResponseException e) { - if (logger.isDebugEnabled()) { - logger.debug( - "------------------ HttpResponseException " - + e.getStatusCode() - + " : updateRepeatingInvoiceAttachmentByFileName -------------------"); - logger.debug(e.toString()); - } - XeroApiExceptionHandler handler = new XeroApiExceptionHandler(); - handler.execute(e); - } catch (IOException ioe) { - throw ioe; - } - return null; - } - - /** - * Updates a specific attachment from a specific repeating invoices by file name - * - *

200 - Success - return response of type Attachments array with specified Attachment - * for a specified Repeating Invoice - * - *

400 - A failed request due to validation error - * - * @param xeroTenantId Xero identifier for Tenant - * @param repeatingInvoiceID Unique identifier for a Repeating Invoice - * @param fileName Name of the attachment - * @param body Byte array of file in body of request - * @param idempotencyKey This allows you to safely retry requests without the risk of duplicate - * processing. 128 character max. - * @param mimeType The type of file being attached - * @param accessToken Authorization token for user set in header of each request - * @return HttpResponse - * @throws IOException if an error occurs while attempting to invoke the API * - */ - public HttpResponse updateRepeatingInvoiceAttachmentByFileNameForHttpResponse( - String accessToken, - String xeroTenantId, - UUID repeatingInvoiceID, - String fileName, - byte[] body, - String idempotencyKey, - String mimeType) - throws IOException { - // verify the required parameter 'xeroTenantId' is set - if (xeroTenantId == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'xeroTenantId' when calling" - + " updateRepeatingInvoiceAttachmentByFileName"); - } // verify the required parameter 'repeatingInvoiceID' is set - if (repeatingInvoiceID == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'repeatingInvoiceID' when calling" - + " updateRepeatingInvoiceAttachmentByFileName"); - } // verify the required parameter 'fileName' is set - if (fileName == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'fileName' when calling" - + " updateRepeatingInvoiceAttachmentByFileName"); - } // verify the required parameter 'body' is set - if (body == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'body' when calling" - + " updateRepeatingInvoiceAttachmentByFileName"); - } - if (accessToken == null) { - throw new IllegalArgumentException( - "Missing the required parameter 'accessToken' when calling" - + " updateRepeatingInvoiceAttachmentByFileName"); - } - HttpHeaders headers = new HttpHeaders(); - headers.set("xero-tenant-id", xeroTenantId); - headers.set("Idempotency-Key", idempotencyKey); - headers.setAccept("application/json"); - headers.setContentType("application/octet-stream"); - headers.setUserAgent(this.getUserAgent()); - // create a map of path variables - final Map uriVariables = new HashMap(); - uriVariables.put("RepeatingInvoiceID", repeatingInvoiceID); - uriVariables.put("FileName", fileName); - - UriBuilder uriBuilder = - UriBuilder.fromUri( - apiClient.getBasePath() - + "/RepeatingInvoices/{RepeatingInvoiceID}/Attachments/{FileName}"); - String url = uriBuilder.buildFromMap(uriVariables).toString(); - GenericUrl genericUrl = new GenericUrl(url); - if (logger.isDebugEnabled()) { - logger.debug("POST " + genericUrl.toString()); - } - - ByteArrayContent content = null; - - content = new ByteArrayContent(mimeType, body); - Credential credential = - new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); - HttpTransport transport = apiClient.getHttpTransport(); - HttpRequestFactory requestFactory = transport.createRequestFactory(credential); - return requestFactory - .buildRequest(HttpMethods.POST, genericUrl, content) - .setHeaders(headers) - .setConnectTimeout(apiClient.getConnectionTimeout()) - .setReadTimeout(apiClient.getReadTimeout()) - .execute(); - } - /** * Updates a specific attachment from a specific repeating invoices by file name * @@ -33205,10 +30059,10 @@ public HttpResponse updateRepeatingInvoiceAttachmentByFileNameForHttpResponse( if (logger.isDebugEnabled()) { logger.debug("POST " + genericUrl.toString()); } - java.nio.file.Path bodyPath = body.toPath(); - String mimeType = java.nio.file.Files.probeContentType(bodyPath); + HttpContent content = null; - content = new FileContent(mimeType, body); + content = apiClient.new JacksonJsonHttpContent(body); + Credential credential = new Credential(BearerToken.authorizationHeaderAccessMethod()).setAccessToken(accessToken); HttpTransport transport = apiClient.getHttpTransport(); diff --git a/src/main/java/com/xero/models/payrollnz/Employee.java b/src/main/java/com/xero/models/payrollnz/Employee.java index 50d4c3cc..551bd7aa 100644 --- a/src/main/java/com/xero/models/payrollnz/Employee.java +++ b/src/main/java/com/xero/models/payrollnz/Employee.java @@ -212,7 +212,7 @@ public Employee firstName(String firstName) { * * @return firstName */ - @ApiModelProperty(example = "Karen", value = "First name of employee") + @ApiModelProperty(example = "Karen", required = true, value = "First name of employee") /** * First name of employee * @@ -247,7 +247,7 @@ public Employee lastName(String lastName) { * * @return lastName */ - @ApiModelProperty(example = "Jones", value = "Last name of employee") + @ApiModelProperty(example = "Jones", required = true, value = "Last name of employee") /** * Last name of employee * @@ -284,6 +284,7 @@ public Employee dateOfBirth(LocalDate dateOfBirth) { */ @ApiModelProperty( example = "Wed Jan 02 00:00:00 UTC 2019", + required = true, value = "Date of birth of the employee (YYYY-MM-DD)") /** * Date of birth of the employee (YYYY-MM-DD) @@ -319,7 +320,7 @@ public Employee address(Address address) { * * @return address */ - @ApiModelProperty(value = "") + @ApiModelProperty(required = true, value = "") /** * address * diff --git a/src/main/java/com/xero/models/payrollnz/Employment.java b/src/main/java/com/xero/models/payrollnz/Employment.java index 073a135a..60f641ac 100644 --- a/src/main/java/com/xero/models/payrollnz/Employment.java +++ b/src/main/java/com/xero/models/payrollnz/Employment.java @@ -52,7 +52,9 @@ public Employment payrollCalendarID(UUID payrollCalendarID) { * * @return payrollCalendarID */ - @ApiModelProperty(value = "Xero unique identifier for the payroll calendar of the employee") + @ApiModelProperty( + required = true, + value = "Xero unique identifier for the payroll calendar of the employee") /** * Xero unique identifier for the payroll calendar of the employee * @@ -125,7 +127,7 @@ public Employment startDate(LocalDate startDate) { * * @return startDate */ - @ApiModelProperty(value = "Start date of the employment (YYYY-MM-DD)") + @ApiModelProperty(required = true, value = "Start date of the employment (YYYY-MM-DD)") /** * Start date of the employment (YYYY-MM-DD) * @@ -160,7 +162,10 @@ public Employment engagementType(String engagementType) { * * @return engagementType */ - @ApiModelProperty(example = "Permanent", value = "Engagement type of the employee") + @ApiModelProperty( + example = "Permanent", + required = true, + value = "Engagement type of the employee") /** * Engagement type of the employee * diff --git a/src/main/java/com/xero/models/payrolluk/Employee.java b/src/main/java/com/xero/models/payrolluk/Employee.java index 392b266e..7a419905 100644 --- a/src/main/java/com/xero/models/payrolluk/Employee.java +++ b/src/main/java/com/xero/models/payrolluk/Employee.java @@ -174,7 +174,7 @@ public Employee title(String title) { * * @return title */ - @ApiModelProperty(example = "Mrs", value = "Title of the employee") + @ApiModelProperty(example = "Mrs", required = true, value = "Title of the employee") /** * Title of the employee * @@ -209,7 +209,7 @@ public Employee firstName(String firstName) { * * @return firstName */ - @ApiModelProperty(example = "Karen", value = "First name of employee") + @ApiModelProperty(example = "Karen", required = true, value = "First name of employee") /** * First name of employee * @@ -244,7 +244,7 @@ public Employee lastName(String lastName) { * * @return lastName */ - @ApiModelProperty(example = "Jones", value = "Last name of employee") + @ApiModelProperty(example = "Jones", required = true, value = "Last name of employee") /** * Last name of employee * @@ -281,6 +281,7 @@ public Employee dateOfBirth(LocalDate dateOfBirth) { */ @ApiModelProperty( example = "Wed Jan 02 00:00:00 UTC 2019", + required = true, value = "Date of birth of the employee (YYYY-MM-DD)") /** * Date of birth of the employee (YYYY-MM-DD) @@ -316,7 +317,7 @@ public Employee address(Address address) { * * @return address */ - @ApiModelProperty(value = "") + @ApiModelProperty(required = true, value = "") /** * address * @@ -386,7 +387,7 @@ public Employee gender(GenderEnum gender) { * * @return gender */ - @ApiModelProperty(example = "F", value = "The employee’s gender") + @ApiModelProperty(example = "F", required = true, value = "The employee’s gender") /** * The employee’s gender * diff --git a/src/main/java/com/xero/models/payrolluk/Employment.java b/src/main/java/com/xero/models/payrolluk/Employment.java index a4861f9b..d96155af 100644 --- a/src/main/java/com/xero/models/payrolluk/Employment.java +++ b/src/main/java/com/xero/models/payrolluk/Employment.java @@ -133,7 +133,9 @@ public Employment payrollCalendarID(UUID payrollCalendarID) { * * @return payrollCalendarID */ - @ApiModelProperty(value = "Xero unique identifier for the payroll calendar of the employee") + @ApiModelProperty( + required = true, + value = "Xero unique identifier for the payroll calendar of the employee") /** * Xero unique identifier for the payroll calendar of the employee * @@ -168,7 +170,7 @@ public Employment startDate(LocalDate startDate) { * * @return startDate */ - @ApiModelProperty(value = "Start date of the employment (YYYY-MM-DD)") + @ApiModelProperty(required = true, value = "Start date of the employment (YYYY-MM-DD)") /** * Start date of the employment (YYYY-MM-DD) * @@ -203,7 +205,7 @@ public Employment employeeNumber(String employeeNumber) { * * @return employeeNumber */ - @ApiModelProperty(example = "7", value = "The employment number of the employee") + @ApiModelProperty(example = "7", required = true, value = "The employment number of the employee") /** * The employment number of the employee * @@ -238,7 +240,7 @@ public Employment niCategory(NiCategoryEnum niCategory) { * * @return niCategory */ - @ApiModelProperty(example = "A", value = "The NI Category of the employee") + @ApiModelProperty(example = "A", required = true, value = "The NI Category of the employee") /** * The NI Category of the employee *