QbModels 1.0.2
See the version list below for details.
dotnet add package QbModels --version 1.0.2
NuGet\Install-Package QbModels -Version 1.0.2
<PackageReference Include="QbModels" Version="1.0.2" />
paket add QbModels --version 1.0.2
#r "nuget: QbModels, 1.0.2"
// Install QbModels as a Cake Addin #addin nuget:?package=QbModels&version=1.0.2 // Install QbModels as a Cake Tool #tool nuget:?package=QbModels&version=1.0.2
QBXML-Object-Models
Quickbooks C# object models to generate QBXML without writing XML code
This is part of a personal pet project I've been working on to help update and improve my C# coding skills and experience. This dll allows me to generate the QBXML to call Quickbooks Desktop API without having to write XML code using the QbModels namespace. This is done using 100% .netstandard2.1 calls. There are no custom DLLs or other libraries used to generate the QBXML and/or process the results. <br /><br/> For example, the following C# code:
using QbModels;
#region Create customer query request with a maximum of 50 responses
CustomerQueryRq customerRq = new() { MaxReturned = 50, Iterator = "Start" };
Console.WriteLine(customerRq.ToString());
#endregion
Produces the following output:
<?xml version="1.0" encoding="utf-16"?>
<?qbxml version="13.0"?>
<QBXML>
<QBXMLMsgsRq onError="stopOnError">
<CustomerQueryRq iterator="Start">
<MaxReturned>50</MaxReturned>
</CustomerQueryRq>
</QBXMLMsgsRq>
</QBXML>
As of v1.1.10 (or 1.0.2 if you got this from NuGet), I've refactored all the views to convert the response QBXML into a C# class object through the constructor (no more need to call the ToView extension) with the added benefit of reducing the dll size. The class object can then be accessed and manipulated with LINQ or standard C# code. The dll includes over 55 object views (ie QbAccountsView, QbInvoicesView, QbCustomersView, QbVendorsView, etc) that will convert the QBXML response into a C# object that can be accessed via C#.
AccountQueryRq accountsRq = new();
string qbRs = QB.ExecuteQbRequest(accountsRq); // QB.ExecuteQbRequest is from my personal class library and returns the QBXML from the RP Processor
QbAccountsView accounts = new(qbRs);
if(accounts.StatusCode == "0" && accounts.Accounts.Count > 0)
{
AccountRetDto account = accounts.Accounts.FirstOrDefault(a => a.AccountType == "AccountsPayable");
AccountRetDto bank = accounts.Accounts.FirstOrDefault(a => a.AccountType == "Bank");
}
I've also added a couple of validation extensions using DataAnnotations and custom ValidationAttributes to be able to call IsEntityValid() and/or GetErrorsList() on the object. This will help to notify you if your data is not valid. This is not 100% but will warn you of a lot of different potential errors in your requests. Also; these methods are optional and regardless of the results of the IsEntityValid, the .ToString() method will output the QBXML. Personally, I use them during development to see where I may have added bad or incomplete data.
if(customerRq.IsEntityValid())
{
...Your code here
}
else
{
foreach(string s in customerRq.GetErrorsList())
{
...Your code here
}
}
I have objects for the majority of QBXML calls but have only used and tested a few since that's all I need. While it is not complete, I am continuing to make updates and changes. Have completed the majority of the Unit Tests for generating the QBXML as well as sending the QBXML to the request processor. I have covered the majority of QBXML requests in my unit testing but there are still bugs to be found. If you do use this, please report these bugs so that I can look into why it's not working. Look at the included unit test code I uploaded for testing the InvoiceQueryRq/InvoiceAddRq/InvoiceModRq QBXML calls to see how I use the dll to generate the QBXML and then convert the QBXML result string back into a C# object (in this case QbInvoicesView).
Another note, I changed the target framework from netcoreapp3.1 to netstandard2.1. This should make it more compatible with any projects you incorporate this into. Theoretically; since this is straight dotNet code and objects, this should also be compatible with VB but I haven't programmed in VB in many years so I haven't tested.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.1
- Microsoft.CSharp (>= 4.7.0)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.ComponentModel.Composition (>= 6.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.2.13 | 318 | 2/20/2024 |
1.2.13-beta01 | 101 | 2/20/2024 |
1.2.12 | 129 | 2/19/2024 |
1.2.11 | 150 | 2/16/2024 |
1.2.11-beta01 | 100 | 2/16/2024 |
1.2.10 | 116 | 1/30/2024 |
1.2.9 | 104 | 1/30/2024 |
1.2.9-beta-01 | 90 | 1/29/2024 |
1.2.7 | 169 | 12/29/2023 |
1.2.6 | 122 | 12/22/2023 |
1.2.5 | 124 | 12/21/2023 |
1.2.1 | 1,452 | 5/19/2022 |
1.2.0 | 451 | 4/18/2022 |
1.0.5 | 411 | 4/12/2022 |
1.0.4 | 410 | 4/10/2022 |
1.0.3 | 433 | 4/7/2022 |
1.0.2 | 442 | 4/3/2022 |
1.0.1 | 409 | 3/31/2022 |
1.0.0 | 414 | 3/30/2022 |