VendorQuery

Queries for the specified vendor or set of vendors.


Request

Response

XMLOps

VB.NET

C#

Tag Type Max length Implementation Required

IVendorQuery

Queries for the specified vendor or set of vendors.
       

metaData

This is used in a query to cause a count of query objects to be returned. You can specify that the count of query objects is to be returned with the returned objects, or you can specify that only a count and no data is returned. (The default is that no count is returned.) A common use of this feature is to specify a count with no data in order to determine how many objects to expect from the actual query. If you don’t want a query to return a count, either don’t use this feature, or specify the value NoMetaData. If you want only a count, specify the value MetaDataOnly. If you want data and a count, specify MetaDataAndResponseData. You should be aware that the count returned via this setting is not guaranteed to be exact: it could be off slightly due to new object creation or deletions.
IQBENmetaDataType   4.0 us.png  

iterator

The iterator attribute provided with most query types also allows you to break down query results in smaller and more manageable chunks of data. An iterator results in responses that contain only the specified number of objects. Iterators are only valid for the application that starts them, and they are only valid for the current QuickBooks session.
IQBENiteratorType   5.0 us.png  

iteratorID

Returned in the response in the first iteration and supplied in subsequent iterations, this identifies which iteration is to be used in the query continuing the iteration. Required because many different iterations may be currently in use.
IQBUUIDType   5.0 us.png  

ORVendorListQuery

IORVendorListQuery      

ListIDList

One or more ListID values. Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IBSTRList      

FullNameList

A list of one or more FullName values. FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IBSTRList      

VendorListFilter

The IVendorListFilter group object allows you to search for vendors based on whether they’re active, when their record was last modified, their name, and their total balance.
IVendorListFilter      

MaxReturned

Limits the number of objects that a query returns. (To get a count of how many objects could possibly be returned, use the metaData query attribute.) If you include a MaxReturned value, it must be at least 1.
IQBIntType      

ActiveStatus

Used in filters to select list objects based on whether or not they are currently enabled for use by QuickBooks. The default value is asActiveOnly, which selects only list objects that are active.
IQBENActiveStatusType      

FromModifiedDate

Selects objects modified on or after this date. See the note below regarding QBFC usage.For desktop versions of QuickBooks, the FromModifiedDate and ToModifiedDate must be between 1970-01-01 and 2038-01-19T03:14:07 (2038-01-18T19:14:07-08:00 PST). (The time portion of the field was not supported in qbXML version 1.0 or 1.1.) Also, for desktop versions of QuickBooks, if FromModifiedDate includes a date but not a time (for example, if you set FromModifiedDate to 2003-02-14), the time is assumed to be zero (2003-02-14T00:00:00). If you omit FromModifiedDate, it will be set to 1970-01-01T00:00:00 (1969-12-31T16:00:00-08:00 PST).For QBOE, the FromModifiedDate and ToModifiedDate must be between 1900-01-01T00:00:00 and 9999-12-31T00:00:00. If FromModifiedDate includes a date but not a time (for example, if you set FromModifiedDate to 2003-02-14), the time is assumed to be zero (2003-02-14T00:00:00). If you omit FromModifiedDate, it will be set to 1900-01-01T00:00:00.Note: When specifying this in QBFC, you need to supply the parameter asDateOnly, which is a Boolean. If asDateOnly is true, the date value will be represented as a date only (without a time). If asDateOnly is false, the date value will be represented as date and time, padded with zeros if necessary, and set to the beginning of the day if no time is provided. The asDateOnly parameter is especially useful in the ToModifiedDate field of a query: If asDateOnly is set to true in the ToModifiedDate field of a query, then the query includes elements modified up to the end of the day. If asDateOnly is false, the query includes elements modified up to the specified time (or up to the beginning of the day if no time is included).
IQBDateTimeType      

ToModifiedDate

Selects objects modified on or before this date. See the note below on QBFC usage.For desktop versions of QuickBooks, the ToModifiedDate and FromModifiedDate must be between 01/01/1970 and 2038-01-19T03:14:07 (2038-01-18T19:14:07-08:00 PST). (Note that the time portion of the field was not supported in qbXML version 1.0 or 1.1.) If ToModifiedDate includes a date but not a time (for example, if you set ToModifiedDate to 2003-02-14), the time is assumed to be the end of the day (2003-02-14T23:59:59). If you omit ToModifiedDate altogether, it will be set to 2038-01-19T03:14:07 (2038-01-18T19:14:07-08:00 PST).For QBOE, the ToModifiedDate and FromModifiedDate must be between 01/01/1900 and 9999-12-31T00:00:00. If ToModifiedDate includes a date but not a time (for example, if you set ToModifiedDate to 2003-02-14), the time is assumed to be the end of the day (2003-02-14T23:59:59). If you omit ToModifiedDate altogether, it will be set to 9999-12-31T00:00:00.Note: When specifying this in QBFC, you need to supply the parameter asDateOnly, which is a Boolean. If asDateOnly is true, the date value will be represented as a date only (without a time). If asDateOnly is false, the date value will be represented as date and time, padded with zeros if necessary, and set to the beginning of the day if no time is provided. The asDateOnly parameter is especially useful in the ToModifiedDate field of a query: If asDateOnly is set to true in the ToModifiedDate field of a query, then the query includes elements modified up to the end of the day. If asDateOnly is false, the query includes elements modified up to the specified time (or up to the beginning of the day if no time is included).
IQBDateTimeType      

ORNameFilter

IORNameFilter      

NameFilter

Filters according to the object’s Name.
INameFilter      

MatchCriterion

The criterion to match.
IQBENMatchCriterionType     Y

Name

The string to match.
IQBStringType     Y

NameRangeFilter

Filters according to the object’s Name.
INameRangeFilter      

FromName

The first name or item in the search range. If FromName is omitted, the range will begin with first name on the list.
IQBStringType      

ToName

The final name or item in the search range. If ToName is omitted, the range will end with last name on the list.
IQBStringType      

TotalBalanceFilter

Filters according to total balance. Total balance includes the balance for all subaccounts; for example, a customer’s TotalBalance would include all the jobs for that customer.
ITotalBalanceFilter      

Operator

Indicates whether to filter for amounts that are less than, equal to or less than, exactly equal to, greater than, or equal to or greater than the given Amount.
IQBENOperatorType     Y

Amount

The monetary amount to which Operator refers.
IQBAmountType     Y

CurrencyFilter

Filters by the specified currency.
ICurrencyFilter   8.0  

ORCurrencyFilter

IORCurrencyFilter     Y

ListIDList

One or more ListID values. Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IBSTRList      

FullNameList

A list of one or more FullName values. FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IBSTRList 64 chars    

ClassFilter

Filter according to class.
IClassFilter   12.0  

ORClassFilter

IORClassFilter     Y

ListIDList

One or more ListID values. Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IBSTRList      

FullNameList

A list of one or more FullName values. FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IBSTRList      

ListIDWithChildren

Allows you to filter for data that relates to the specified object and its descendants.
IQBIDType      

FullNameWithChildren

Allows you to filter for data that relates to the specified object and its descendants. For names that do not have children, FullNameWithChildren is exactly the same as FullName.
IQBStringType      

IncludeRetElementList

You use this if you want to limit the data that will be returned in the response. In this list, you specify the name of each top-level element or aggregate that you want to be returned in the response to the request. You cannot specify fields within an aggregate, for example, you cannot specify a City within an Address: you must specify Address and will get the entire address. The names specified in the list are not parsed, so you must be especially careful to supply valid names, properly cased. No error is returned in the status code if you specify an invalid name. Notice that if you want to return custom data or private data extensions, you must specify the DataExtRet element and you must supply the OwnerID set to either a value of 0 (custom data) or the GUID for the private data.
IBSTRList 50 chars 4.0  

OwnerIDList

Zero or more OwnerID values. OwnerID refers to the owner of a data extension:If OwnerID is 0, this is a public data extension, also known as a custom field. Custom fields appear in the QuickBooks UI.If OwnerID is a GUID, for example {6B063959-81B0-4622-85D6-F548C8CCB517}, this field is a private data extension defined by an integrated application. Private data extensions do not appear in the QuickBooks UI. Note that OwnerID values are not case-sensitive, meaning that if you enter an OwnerID value with lower-case letters, the value will be saved and returned with upper-case letters. When you share a private data extension with another application, the other application must know both the OwnerID and the DataExtName, as these together form a data extension’s unique name.
IGUIDList   2.0  
Tag Type Max length Implementation Required

IResponse

Queries for the specified vendor or set of vendors.
       

StatusCode

A number that corresponds to a statusSeverity and statusMessage. Five status codes relate directly to signon messages: 2000, 2010, 2020, 2030, and 2040. For details about these and other statusCode values that can be returned, see the statusCode table on the Error Codes page.
IQBIntType     Y

StatusSeverity

One of the following values: INFO The request was completed, and the results are consistent with what your application expected. WARNING The request was completed, but the results might not be consistent with what you expected. ERROR The request was not completed. No data will appear in the server’s response after the statusMessage.
IQBStringType     Y

StatusMessage

A user-readable explanation of the success or error condition that is indicated by the statusCode. For details about the statusMessage values that can be returned, see the “Explanation” column of the statusCode table on the Error Codes page.
IQBStringType     Y

retCount

The retCount is returned in a query if in the query request you specified the metaData attribute with a value of MetaDataOnly (in which case the retCount is the only data returned in the query response) or MetaDataAndResponseData (the query response contains object data AND the approximate count). The retCount value contains the approximate count of the objects that could be expected to be returned from the query. A common use of this feature is to specify a count with no data in order to determine how many objects to expect from the actual query. You should be aware that the count returned in retCount is not guaranteed to be exact: it could be off slightly due to new object creation or deletions.
IQBIntType   4.0 us.png Y

iteratorRemainingCount

This attribute is provided in the response in a query using iterators, indicating the number of objects remaining in the iteration. This can help you specify a MaxReturn value tailored to the number of objects still to be iterated through in your query.
IQBIntType   5.0 us.png Y

iteratorID

Returned in the response in the first iteration and supplied in subsequent iterations, this identifies which iteration is to be used in the query continuing the iteration. Required because many different iterations may be currently in use.
IQBUUIDType   5.0 us.png Y

Detail

IVendorRetList      

(List

of IVendorRet Objects)
       

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType     Y

TimeCreated

Time the object was created.
IQBDateTimeType     Y

TimeModified

Time the object was last modified.
IQBDateTimeType     Y

EditSequence

A number that the server generates and assigns to this object. Every time the object is changed, the server will change its EditSequence value. When you try to modify a list object, you must provide its EditSequence. The server compares the EditSequence you provide with the EditSequence in memory to make sure you are dealing with the latest copy of the object. If you are not, the server will reject the request and return an error. Because EditSequence is only used to check whether two objects match, there is no reason to interpret its value.
IQBStringType 16 chars   Y

Name

The case-insensitive name of a list object, not including the names of its ancestors. Name must be unique, unless it is the Name of a “hierarchical” list object. List objects in different hierarchies can have duplicate names because their FullNames will still be unique. For example, two objects could both have the Name kitchen, but they could have unique FullNames, such as Job12:kitchen and Baker:kitchen. For built-in currencies, Name is the internationally accepted currency name and is not editable.
IQBStringType 41 chars   Y

IsActive

If IsActive is true, this object is currently enabled for use by QuickBooks. The default value is true.
IQBBoolType      

ClassRef

Classes can be used to separate transactions into meaningful categories. (For example, transactions could be classified according to department, business location, or type of work.) In QuickBooks, class tracking is off by default. A ClassRef aggregate refers to one of these named classes. For example, in a TimeTracking message, ClassRef refers to the QuickBooks class into which the timed activity falls. If a ClassRef aggregate includes both FullName and ListID, FullName will be ignored. In an InvoiceAdd request, if you specify a ClassRef for the whole invoice, that same ClassRef is automatically used in the line items. If you want to clear that (that is, have NO ClassRef for the line item, you can clear it in the line item by simply not specifying it in the line item.
IQBBaseRef   12.0  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   12.0  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 159 chars 12.0  

IsTaxAgency

Is the current entity a tax agency.
IQBBoolType   6.0 CA.png uk.png  

CompanyName

The name of the QuickBooks user’s business, as specified in QuickBooks. CompanyName and Address are used on invoices, checks, and other forms. (LegalCompanyName and LegalAddress, on the other hand, are used on a company’s tax forms and pay stubs.)
IQBStringType 41 chars    

Salutation

A formal reference, such as Mr. or Dr., that precedes a name.
IQBStringType 15 chars    

FirstName

The first name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 25 chars    

MiddleName

The middle name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 5 chars    

LastName

The last name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 25 chars    

JobTitle

The job title of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 41 chars 12.0  

VendorAddress

If an address request fails, some combination of address fields might be too long.
IAddress      

Addr1

The first line of an address.
IQBStringType 41 chars    

Addr2

The second line of an address (if a second line is needed).
IQBStringType 41 chars    

Addr3

The third line of an address (if a third line is needed).
IQBStringType 41 chars    

Addr4

The fourth line of an address (if a fourth line is needed).
IQBStringType 41 chars 2.0  

Addr5

The fifth line of an address (if a fifth line is needed).
IQBStringType 41 chars 6.0  

City

The city name in an address.
IQBStringType 31 chars    

State

The state name in an address.
IQBStringType 21 chars    

PostalCode

The postal code in an address.
IQBStringType 13 chars    

Country

The country name in an address, or, in returned Host information (HostRet or HostInfo), the country for which this edition of QuickBooks was designed. (Possible values are US, CA, UK, and AU.)
IQBStringType 31 chars    

Note

In a BillAddress or ShipAddress aggregate, the Note field value is written at the bottom of the address in the form in which it appears, such as the invoice form.
IQBStringType 41 chars 6.0  

VendorAddressBlock

The address expressed as an address block of Addr1 through Addr5, depending on the number of lines in the original request that created the address.
IAddressBlock   6.0  

Addr1

The first line of an address.
IQBStringType 41 chars    

Addr2

The second line of an address (if a second line is needed).
IQBStringType 41 chars    

Addr3

The third line of an address (if a third line is needed).
IQBStringType 41 chars    

Addr4

The fourth line of an address (if a fourth line is needed).
IQBStringType 41 chars    

Addr5

The fifth line of an address (if a fifth line is needed).
IQBStringType 41 chars    

ShipAddress

Whatever address you specify in this aggregate must not result in an address greater than 5 lines, otherwise you’ll get a runtime error, because QuickBooks doesn’t support addresses more than 5 lines. There are two ways to specify an address within this aggregate: Using Addr1 through Addr3 along with the other possible aggregate elements, such as City, State, Postalcode.Using Addr1, Addr2, Addr3, Addr4, and Addr5 to fully specify the address. If you use this so called “address block” approach, you cannot use any other address elements, such as City, State, etc. (Note: this approach is not valid for EmployeeAdd/Mod/Query) If you use the address block approach above, the lines Addr1…Addr5 are each printed as a separate line on the transaction, and the values are returned in the Ret object under the aggregate ShipAddressBlock or BillAddressBlock.
IAddress   11.0  

Addr1

The first line of an address.
IQBStringType 41 chars    

Addr2

The second line of an address (if a second line is needed).
IQBStringType 41 chars    

Addr3

The third line of an address (if a third line is needed).
IQBStringType 41 chars    

Addr4

The fourth line of an address (if a fourth line is needed).
IQBStringType 41 chars 2.0  

Addr5

The fifth line of an address (if a fifth line is needed).
IQBStringType 41 chars 6.0  

City

The city name in an address.
IQBStringType 31 chars    

State

The state name in an address.
IQBStringType 21 chars    

PostalCode

The postal code in an address.
IQBStringType 13 chars    

Country

The country name in an address, or, in returned Host information (HostRet or HostInfo), the country for which this edition of QuickBooks was designed. (Possible values are US, CA, UK, and AU.)
IQBStringType 31 chars    

Note

In a BillAddress or ShipAddress aggregate, the Note field value is written at the bottom of the address in the form in which it appears, such as the invoice form.
IQBStringType 41 chars 6.0  

Phone

The telephone number.
IQBStringType 21 chars    

AltPhone

A telephone number given as an alternative to Phone.
IQBStringType 21 chars    

Fax

Fax number.
IQBStringType 21 chars    

Email

E-mail address.
IQBStringType 1023 chars    

Cc

Email address that would be carbon copied or CC.
IQBStringType 1023 chars 12.0  

Contact

The name of a contact person for a customer or vendor.
IQBStringType 41 chars    

AltContact

The name of an alternate contact person for a vendor, customer, or “other name” entry.
IQBStringType 41 chars    

AdditionalContactRefList

List of additional contacts.
IQBBaseRefList   12.0  

(List

of IQBBaseRef Objects)
       

ContactName

The name of the contact.
IQBStringType 40 chars   Y

ContactValue

The value of the contact field.
IQBStringType 255 chars   Y

ContactsRetList

A list of contact records.
IContactsRetList   12.0  

(List

of IContactsRet Objects)
       

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType     Y

TimeCreated

Time the object was created.
IQBDateTimeType     Y

TimeModified

Time the object was last modified.
IQBDateTimeType     Y

EditSequence

A number that the server generates and assigns to this object. Every time the object is changed, the server will change its EditSequence value. When you try to modify a list object, you must provide its EditSequence. The server compares the EditSequence you provide with the EditSequence in memory to make sure you are dealing with the latest copy of the object. If you are not, the server will reject the request and return an error. Because EditSequence is only used to check whether two objects match, there is no reason to interpret its value.
IQBStringType 16 chars   Y

Contact

The name of a contact person for a customer or vendor.
IQBStringType 41 chars    

Salutation

A formal reference, such as Mr. or Dr., that precedes a name.
IQBStringType 15 chars    

FirstName

The first name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 25 chars   Y

MiddleName

The middle name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 5 chars    

LastName

The last name of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 25 chars    

JobTitle

The job title of a customer, vendor, employee, or person on the “other names” list.
IQBStringType 41 chars    

AdditionalContactRefList

List of additional contacts.
IQBBaseRefList      

(List

of IQBBaseRef Objects)
       

ContactName

The name of the contact.
IQBStringType 40 chars   Y

ContactValue

The value of the contact field.
IQBStringType 255 chars   Y

NameOnCheck

The vendor’s name as it will appear on checks sent to the vendor. (Corresponds in the QuickBooks user interface to the “Print on Check as” field of the Edit Vendor and New Vendor windows.)
IQBStringType 41 chars    

AccountNumber

Account numbers appear in the QuickBooks chart of accounts, Account fields, and reports and graphs. If the IsUsingAccountNumber preference is false (that is, if the QuickBooks user has the account numbers Preference turned off), you can still set account numbers through the SDK, but the numbers will not be visible in the user interface.
IQBStringType 99 chars    

Notes

Additional information about this vendor.
IQBStringType 4095 chars    

AdditionalNotesRetList

List of notes.
IAdditionalNotesRetList   12.0  

(List

of IAdditionalNotesRet Objects)
       

NoteID

The ID of the note.
IQBIntType     Y

Date

The date the note was updated.
IQBDateType     Y

Note

In a BillAddress or ShipAddress aggregate, the Note field value is written at the bottom of the address in the form in which it appears, such as the invoice form.
IQBStringType 4095 chars   Y

VendorTypeRef

Vendor types allow business owners to categorize vendors in ways that are meaningful for their businesses. For example, a vendor type might indicate which industry a vendor represents, or which part of the country a vendor is in. A VendorTypeRef aggregate refers to one of the types on the VendorType list. In a request, if a VendorTypeRef aggregate includes both FullName and ListID, FullName will be ignored.
IQBBaseRef      

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType      

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 159 chars    

TermsRef

Refers to the payment terms associated with this entity. (This will be an item on the DateDrivenTerms or StandardTerms list.) If a TermsRef aggregate includes both FullName and ListID, FullName will be ignored.
IQBBaseRef      

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType      

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 31 chars    

CreditLimit

Set and returned as a positive number that indicates a customer’s or vendor’s credit limit. If no value has been defined, there is no credit limit.
IQBAmountType      

VendorTaxIdent

A character string that identifies a vendor.
IQBStringType 15 chars    

IsVendorEligibleFor1099

If IsVendorEligibleFor1099 is set to true, VendorTaxIdent and VendorAddress are required in a vendor add request message. Otherwise, VendorTaxIdent and VendorAddress are optional.
IQBBoolType   us.png  

Balance

A positive number indicates money owed to this vendor.
IQBAmountType      

BillingRateRef

Billing rates are used to override the service item rate in a time transaction (TimeTrackingAdd) based on the employee or vendor performing the work. Billing rates are assigned to an employee or a vendor to specify overrides to service items.
IQBBaseRef   6.0  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   6.0  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 31 chars 6.0  

ExternalGUID

Allows for the attachment of a user defined GUID value.
IQBGUIDType   8.0  

SalesTaxCodeRef

Each item on a sales form is assigned a sales-tax code that indicates whether the item is taxable or non-taxable, and why. Two general codes, which can be modified but not deleted, appear on the sales-tax code list by default:Non-taxable (Name = NON; Desc = Non-Taxable; IsTaxable = false)Taxable (Name = TAX; Desc = Taxable; IsTaxable = true) A sales-tax code can be deleted only if it is no longer associated with any customer, item, or transaction. If the “Do You Charge Sales Tax?” preference within QuickBooks is set to No, QuickBooks will assign the default non-taxable sales-tax code to all sales. A SalesTaxCodeRef aggregate refers to a sales-tax code on the list. In a request, if a SalesTaxCodeRef aggregate includes both FullName and ListID, FullName will be ignored. In a Customer message, SalesTaxCodeRef refers to the sales-tax code that will be used for items related to this customer. In an ItemInventory message, SalesTaxCodeRef refers to the type of sales tax that will be charged for this item, if it is a taxable item and if sales tax is set up within QuickBooks.
IQBBaseRef   8.0 CA.png uk.png  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   8.0 CA.png uk.png  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 3 chars 8.0 CA.png uk.png  

SalesTaxCountry

The country that sales tax is collected for.
IQBENSalesTaxCountryType   8.0 CA.png uk.png  

IsSalesTaxAgency

Indicates whether the entity is a sales tax agency.
IQBBoolType   8.0 CA.png uk.png  

SalesTaxReturnRef

Sales tax return information.
IQBBaseRef   8.0 CA.png uk.png  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   8.0 CA.png uk.png  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType   8.0 CA.png uk.png  

TaxRegistrationNumber

The tax registration number used in CA and UK.
IQBStringType 30 chars 8.0 CA.png uk.png  

ReportingPeriod

Vendor reporting period for CA or UK. This can be monthly or quarterly.
IQBENReportingPeriodType   8.0 CA.png uk.png  

IsTaxTrackedOnPurchases

This flag is used for CA or UK and whether tax is tracked on purchases.
IQBBoolType   8.0 CA.png uk.png  

TaxOnPurchasesAccountRef

Account used for taxes on purchases in CA or UK.
IQBBaseRef   8.0 CA.png uk.png  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   8.0 CA.png uk.png  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 159 chars 8.0 CA.png uk.png  

IsTaxTrackedOnSales

This flag is used for CA or UK and whether tax is tracked on sales.
IQBBoolType   8.0 CA.png uk.png  

TaxOnSalesAccountRef

Account used for taxes on sales in CA or UK.
IQBBaseRef   8.0 CA.png uk.png  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   8.0 CA.png uk.png  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 159 chars 8.0 CA.png uk.png  

IsTaxOnTax

For vendor in CA or UK, is there tax charged on top of tax.
IQBBoolType   8.0 CA.png uk.png  

PrefillAccountRefList

Expense account to prefill when you enter bills for this vendor.
IQBBaseRefList   8.0  

(List

of IQBBaseRef Objects)
       

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType      

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 159 chars    

CurrencyRef

The currency object contains all of the information needed by QuickBooks to display and use. For built-in currencies, the name and currency code values are internationally accepted values and thus are not editable. The comma format is editable, as is the IsActive status. For user-defined currencies, every value in the object is editable including name and currency code. When used with PriceLevels, the CurrencyRef should only be used with “per item” price levels.
IQBBaseRef   8.0  

ListID

Along with FullName, ListID is a way to identify a list object. When a list object is added to QuickBooks through the SDK or through the QuickBooks user interface, the server assigns it a ListID. A ListID is not unique across lists, but it is unique across each particular type of list. For example, two customers could not have the same ListID, and a customer could not have the same ListID as an employee (because Customer and Employee are both name lists). But a customer could have the same ListID as a non-inventory item.
IQBIDType   8.0  

FullName

FullName (along with ListID) is a way to identify a list object. The FullName is the name prefixed by the names of each ancestor, for example Jones:Kitchen:Cabinets. FullName values are not case-sensitive.
IQBStringType 64 chars 8.0  

DataExtRetList

A list of IDataExtRet objects, each of which represents a field that has been added to QuickBooks as a data extension.
IDataExtRetList   2.0  

(List

of IDataExtRet Objects)
       

OwnerID

OwnerID refers to the owner of a data extension, and must be 0 or a valid GUID. (Custom fields, which are visible in the QuickBooks UI, always have an OwnerID of 0. ) Usually you would keep your application’s GUID confidential to prevent other applications from accessing your data extensions. But if you want to share data extensions with another application, the applications need to use the same GUID. In this case, each application could use two GUIDs, one for shared data extensions and one for confidential data extensions. (An application can have any number of GUIDs.) When you share a data extension with another application, the other application must know both the OwnerID and the DataExtName, as these together form a data extension’s unique name.
IQBGUIDType      

DataExtName

The name of the data extension. If this is a custom field, DataExtName will be visible as a label in the QuickBooks user interface. Also because OwnerID and DataExtName together make the data extension unique, and because custom fields all have the same OwnerID of zero, the DataExtName must be a unique value among existing custom fields. In contrast, the DataExtName for private data extensions must be unique only for the specified OwnerID GUID.
IQBStringType 31 chars   Y

DataExtType

The field’s data type, which corresponds to a qbXML data type. In an IDataExtDefAdd request object, if this is a custom field, DataExtType must be detSTR255TYPE.
IQBENDataExtTypeType     Y

DataExtValue

The data in this field. The maximum length of DataExtValue will depend on the DataExtType of this data extension. For example, if DataExtType is STR255TYPE, the maximum length of DataExtValue is 255 characters. If DataExtType is STR1024TYPE, the maximum size of DataExtValue is 1KB.
IQBStringType     Y

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
<?xml version="1.0" encoding="utf-8"?>
<?qbxml version="16.0"?>
<QBXML>
        <QBXMLMsgsRq onError="stopOnError">
                <VendorQueryRq metaData="ENUMTYPE" iterator="ENUMTYPE" iteratorID="UUIDTYPE">
                        <!-- BEGIN OR -->
                                <ListID >IDTYPE</ListID> <!-- optional, may repeat -->
                        <!-- OR -->
                                <FullName >STRTYPE</FullName> <!-- optional, may repeat -->
                        <!-- OR -->
                                <MaxReturned >INTTYPE</MaxReturned> <!-- optional -->
                                <!-- ActiveStatus may have one of the following values: ActiveOnly [DEFAULT], InactiveOnly, All -->
                                <ActiveStatus >ENUMTYPE</ActiveStatus> <!-- optional -->
                                <FromModifiedDate >DATETIMETYPE</FromModifiedDate> <!-- optional -->
                                <ToModifiedDate >DATETIMETYPE</ToModifiedDate> <!-- optional -->
                                <!-- BEGIN OR -->
                                        <NameFilter> <!-- optional -->
                                                <!-- MatchCriterion may have one of the following values: StartsWith, Contains, EndsWith -->
                                                <MatchCriterion >ENUMTYPE</MatchCriterion> <!-- required -->
                                                <Name >STRTYPE</Name> <!-- required -->
                                        </NameFilter>
                                <!-- OR -->
                                        <NameRangeFilter> <!-- optional -->
                                                <FromName >STRTYPE</FromName> <!-- optional -->
                                                <ToName >STRTYPE</ToName> <!-- optional -->
                                        </NameRangeFilter>
                                <!-- END OR -->
                                <TotalBalanceFilter> <!-- optional -->
                                        <!-- Operator may have one of the following values: LessThan, LessThanEqual, Equal, GreaterThan, GreaterThanEqual -->
                                        <Operator >ENUMTYPE</Operator> <!-- required -->
                                        <Amount >AMTTYPE</Amount> <!-- required -->
                                </TotalBalanceFilter>
                                <CurrencyFilter> <!-- optional -->
                                        <!-- BEGIN OR -->
                                                <ListID >IDTYPE</ListID> <!-- optional, may repeat -->
                                        <!-- OR -->
                                                <FullName >STRTYPE</FullName> <!-- optional, may repeat -->
                                        <!-- END OR -->
                                </CurrencyFilter>
                                <ClassFilter> <!-- optional -->
                                        <!-- BEGIN OR -->
                                                <ListID >IDTYPE</ListID> <!-- optional, may repeat -->
                                        <!-- OR -->
                                                <FullName >STRTYPE</FullName> <!-- optional, may repeat -->
                                        <!-- OR -->
                                                <ListIDWithChildren >IDTYPE</ListIDWithChildren> <!-- optional -->
                                        <!-- OR -->
                                                <FullNameWithChildren >STRTYPE</FullNameWithChildren> <!-- optional -->
                                        <!-- END OR -->
                                </ClassFilter>
                        <!-- END OR -->
                        <IncludeRetElement >STRTYPE</IncludeRetElement> <!-- optional, may repeat -->
                        <OwnerID >GUIDTYPE</OwnerID> <!-- optional, may repeat -->
                </VendorQueryRq>

                <VendorQueryRs statusCode="INTTYPE" statusSeverity="STRTYPE" statusMessage="STRTYPE" retCount="INTTYPE" iteratorRemainingCount="INTTYPE" iteratorID="UUIDTYPE">
                        <VendorRet> <!-- optional, may repeat -->
                                <ListID >IDTYPE</ListID> <!-- required -->
                                <TimeCreated >DATETIMETYPE</TimeCreated> <!-- required -->
                                <TimeModified >DATETIMETYPE</TimeModified> <!-- required -->
                                <EditSequence >STRTYPE</EditSequence> <!-- required -->
                                <Name >STRTYPE</Name> <!-- required -->
                                <IsActive >BOOLTYPE</IsActive> <!-- optional -->
                                <ClassRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </ClassRef>
                                <IsTaxAgency >BOOLTYPE</IsTaxAgency> <!-- optional -->
                                <CompanyName >STRTYPE</CompanyName> <!-- optional -->
                                <Salutation >STRTYPE</Salutation> <!-- optional -->
                                <FirstName >STRTYPE</FirstName> <!-- optional -->
                                <MiddleName >STRTYPE</MiddleName> <!-- optional -->
                                <LastName >STRTYPE</LastName> <!-- optional -->
                                <JobTitle >STRTYPE</JobTitle> <!-- optional -->
                                <VendorAddress> <!-- optional -->
                                        <Addr1 >STRTYPE</Addr1> <!-- optional -->
                                        <Addr2 >STRTYPE</Addr2> <!-- optional -->
                                        <Addr3 >STRTYPE</Addr3> <!-- optional -->
                                        <Addr4 >STRTYPE</Addr4> <!-- optional -->
                                        <Addr5 >STRTYPE</Addr5> <!-- optional -->
                                        <City >STRTYPE</City> <!-- optional -->
                                        <State >STRTYPE</State> <!-- optional -->
                                        <PostalCode >STRTYPE</PostalCode> <!-- optional -->
                                        <Country >STRTYPE</Country> <!-- optional -->
                                        <Note >STRTYPE</Note> <!-- optional -->
                                </VendorAddress>
                                <VendorAddressBlock> <!-- optional -->
                                        <Addr1 >STRTYPE</Addr1> <!-- optional -->
                                        <Addr2 >STRTYPE</Addr2> <!-- optional -->
                                        <Addr3 >STRTYPE</Addr3> <!-- optional -->
                                        <Addr4 >STRTYPE</Addr4> <!-- optional -->
                                        <Addr5 >STRTYPE</Addr5> <!-- optional -->
                                </VendorAddressBlock>
                                <ShipAddress> <!-- optional -->
                                        <Addr1 >STRTYPE</Addr1> <!-- optional -->
                                        <Addr2 >STRTYPE</Addr2> <!-- optional -->
                                        <Addr3 >STRTYPE</Addr3> <!-- optional -->
                                        <Addr4 >STRTYPE</Addr4> <!-- optional -->
                                        <Addr5 >STRTYPE</Addr5> <!-- optional -->
                                        <City >STRTYPE</City> <!-- optional -->
                                        <State >STRTYPE</State> <!-- optional -->
                                        <PostalCode >STRTYPE</PostalCode> <!-- optional -->
                                        <Country >STRTYPE</Country> <!-- optional -->
                                        <Note >STRTYPE</Note> <!-- optional -->
                                </ShipAddress>
                                <Phone >STRTYPE</Phone> <!-- optional -->
                                <AltPhone >STRTYPE</AltPhone> <!-- optional -->
                                <Fax >STRTYPE</Fax> <!-- optional -->
                                <Email >STRTYPE</Email> <!-- optional -->
                                <Cc >STRTYPE</Cc> <!-- optional -->
                                <Contact >STRTYPE</Contact> <!-- optional -->
                                <AltContact >STRTYPE</AltContact> <!-- optional -->
                                <AdditionalContactRef> <!-- must occur 0 - 8 times -->
                                        <ContactName >STRTYPE</ContactName> <!-- required -->
                                        <ContactValue >STRTYPE</ContactValue> <!-- required -->
                                </AdditionalContactRef>
                                <ContactsRet> <!-- optional, may repeat -->
                                        <ListID >IDTYPE</ListID> <!-- required -->
                                        <TimeCreated >DATETIMETYPE</TimeCreated> <!-- required -->
                                        <TimeModified >DATETIMETYPE</TimeModified> <!-- required -->
                                        <EditSequence >STRTYPE</EditSequence> <!-- required -->
                                        <Contact >STRTYPE</Contact> <!-- optional -->
                                        <Salutation >STRTYPE</Salutation> <!-- optional -->
                                        <FirstName >STRTYPE</FirstName> <!-- required -->
                                        <MiddleName >STRTYPE</MiddleName> <!-- optional -->
                                        <LastName >STRTYPE</LastName> <!-- optional -->
                                        <JobTitle >STRTYPE</JobTitle> <!-- optional -->
                                        <AdditionalContactRef> <!-- must occur 0 - 5 times -->
                                                <ContactName >STRTYPE</ContactName> <!-- required -->
                                                <ContactValue >STRTYPE</ContactValue> <!-- required -->
                                        </AdditionalContactRef>
                                </ContactsRet>
                                <NameOnCheck >STRTYPE</NameOnCheck> <!-- optional -->
                                <AccountNumber >STRTYPE</AccountNumber> <!-- optional -->
                                <Notes >STRTYPE</Notes> <!-- optional -->
                                <AdditionalNotesRet> <!-- optional, may repeat -->
                                        <NoteID >INTTYPE</NoteID> <!-- required -->
                                        <Date >DATETYPE</Date> <!-- required -->
                                        <Note >STRTYPE</Note> <!-- required -->
                                </AdditionalNotesRet>
                                <VendorTypeRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </VendorTypeRef>
                                <TermsRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </TermsRef>
                                <CreditLimit >AMTTYPE</CreditLimit> <!-- optional -->
                                <VendorTaxIdent >STRTYPE</VendorTaxIdent> <!-- optional -->
                                <IsVendorEligibleFor1099 >BOOLTYPE</IsVendorEligibleFor1099> <!-- optional -->
                                <Balance >AMTTYPE</Balance> <!-- optional -->
                                <BillingRateRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </BillingRateRef>
                                <ExternalGUID >GUIDTYPE</ExternalGUID> <!-- optional -->
                                <SalesTaxCodeRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </SalesTaxCodeRef>
                                <!-- SalesTaxCountry may have one of the following values: Australia, Canada [DEFAULT], UK, US -->
                                <SalesTaxCountry >ENUMTYPE</SalesTaxCountry> <!-- optional -->
                                <IsSalesTaxAgency >BOOLTYPE</IsSalesTaxAgency> <!-- optional -->
                                <SalesTaxReturnRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </SalesTaxReturnRef>
                                <TaxRegistrationNumber >STRTYPE</TaxRegistrationNumber> <!-- optional -->
                                <!-- ReportingPeriod may have one of the following values: Monthly, Quarterly [DEFAULT] -->
                                <ReportingPeriod >ENUMTYPE</ReportingPeriod> <!-- optional -->
                                <IsTaxTrackedOnPurchases >BOOLTYPE</IsTaxTrackedOnPurchases> <!-- optional -->
                                <TaxOnPurchasesAccountRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </TaxOnPurchasesAccountRef>
                                <IsTaxTrackedOnSales >BOOLTYPE</IsTaxTrackedOnSales> <!-- optional -->
                                <TaxOnSalesAccountRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </TaxOnSalesAccountRef>
                                <IsTaxOnTax >BOOLTYPE</IsTaxOnTax> <!-- optional -->
                                <PrefillAccountRef> <!-- must occur 0 - 3 times -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </PrefillAccountRef>
                                <CurrencyRef> <!-- optional -->
                                        <ListID >IDTYPE</ListID> <!-- optional -->
                                        <FullName >STRTYPE</FullName> <!-- optional -->
                                </CurrencyRef>
                                <DataExtRet> <!-- optional, may repeat -->
                                        <OwnerID >GUIDTYPE</OwnerID> <!-- optional -->
                                        <DataExtName >STRTYPE</DataExtName> <!-- required -->
                                        <!-- DataExtType may have one of the following values: AMTTYPE, DATETIMETYPE, INTTYPE, PERCENTTYPE, PRICETYPE, QUANTYPE, STR1024TYPE, STR255TYPE -->
                                        <DataExtType >ENUMTYPE</DataExtType> <!-- required -->
                                        <DataExtValue >STRTYPE</DataExtValue> <!-- required -->
                                </DataExtRet>
                        </VendorRet>
                </VendorQueryRs>
        </QBXMLMsgsRq>
</QBXML>

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
'The following sample code is generated as an illustration of
'Creating requests and parsing responses ONLY
'This code is NOT intended to show best practices or ideal code
'Use at your most careful discretion

imports System
imports System.Net
imports System.Drawing
imports System.Collections
imports System.ComponentModel
imports System.Windows.Forms
imports System.Data
imports System.IO
imports Interop.QBFC16

Module com.intuit.idn.samples
        Public Class Sample
                Public Sub  DoVendorQuery()
                        Dim sessionBegun as Boolean
                        sessionBegun = False
                        Dim connectionOpen as Boolean
                        connectionOpen = False
                        Dim sessionManager as QBSessionManager
                        sessionManager = nothing

                        Try
                                'Create the session Manager object
                                sessionManager = new QBSessionManager

                                'Create the message set request object to hold our request
                                Dim requestMsgSet as IMsgSetRequest
                                requestMsgSet = sessionManager.CreateMsgSetRequest("US",16,0)
                                requestMsgSet.Attributes.OnError = ENRqOnError.roeContinue

                                BuildVendorQueryRq(requestMsgSet)

                                'Connect to QuickBooks and begin a session
                                sessionManager.OpenConnection("","Sample Code from OSR")
                                connectionOpen = True
                                sessionManager.BeginSession("", ENOpenMode.omDontCare)
                                sessionBegun = True

                                'Send the request and get the response from QuickBooks
                                Dim responseMsgSet as IMsgSetResponse
                                responseMsgSet = sessionManager.DoRequests(requestMsgSet)

                                'End the session and close the connection to QuickBooks
                                sessionManager.EndSession()
                                sessionBegun = False
                                sessionManager.CloseConnection()
                                connectionOpen = False

                                WalkVendorQueryRs(responseMsgSet)
                        Catch e as Exception
                                MessageBox.Show(e.Message, "Error")
                                if (sessionBegun) then
                                        sessionManager.EndSession()
                                End If
                                if (connectionOpen) then
                                        sessionManager.CloseConnection()
                                End If
                        End Try
                End Sub
                Public Sub BuildVendorQueryRq(requestMsgSet as IMsgSetRequest)
                        Dim VendorQueryRq as IVendorQuery
                        VendorQueryRq= requestMsgSet.AppendVendorQueryRq()
                        Dim ORVendorListQueryElementType24498 as String
                        ORVendorListQueryElementType24498 = "ListIDList"
                        if (ORVendorListQueryElementType24498 == "ListIDList") then
                                'Set field value for ListIDList
                                'May create more than one of these if needed
                                VendorQueryRq.ORVendorListQuery.ListIDList.Add("200000-1011023419")
                        End If
                        if (ORVendorListQueryElementType24498 == "FullNameList") then
                                'Set field value for FullNameList
                                'May create more than one of these if needed
                                VendorQueryRq.ORVendorListQuery.FullNameList.Add("ab")
                        End If
                        if (ORVendorListQueryElementType24498 == "VendorListFilter") then
                                'Set field value for MaxReturned
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.MaxReturned.SetValue(6)
                                'Set field value for ActiveStatus
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.ActiveStatus.SetValue(ENActiveStatus.asActiveOnly [DEFAULT])
                                'Set field value for FromModifiedDate
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.FromModifiedDate.SetValue(DateTime.Parse("12/15/2007 12:15:12"),false)
                                'Set field value for ToModifiedDate
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.ToModifiedDate.SetValue(DateTime.Parse("12/15/2007 12:15:12"),false)
                                Dim ORNameFilterElementType24499 as String
                                ORNameFilterElementType24499 = "NameFilter"
                                if (ORNameFilterElementType24499 == "NameFilter") then
                                        'Set field value for MatchCriterion
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameFilter.MatchCriterion.SetValue(ENMatchCriterion.mcStartsWith)
                                        'Set field value for Name
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameFilter.Name.SetValue("ab")
                                End If
                                if (ORNameFilterElementType24499 == "NameRangeFilter") then
                                        'Set field value for FromName
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameRangeFilter.FromName.SetValue("ab")
                                        'Set field value for ToName
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameRangeFilter.ToName.SetValue("ab")
                                End If
                                'Set field value for Operator
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.TotalBalanceFilter.Operator.SetValue(ENOperator.oLessThan)
                                'Set field value for Amount
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.TotalBalanceFilter.Amount.SetValue(10.01)
                                Dim ORCurrencyFilterElementType24500 as String
                                ORCurrencyFilterElementType24500 = "ListIDList"
                                if (ORCurrencyFilterElementType24500 == "ListIDList") then
                                        'Set field value for ListIDList
                                        'May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.CurrencyFilter.ORCurrencyFilter.ListIDList.Add("200000-1011023419")
                                End If
                                if (ORCurrencyFilterElementType24500 == "FullNameList") then
                                        'Set field value for FullNameList
                                        'May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.CurrencyFilter.ORCurrencyFilter.FullNameList.Add("ab")
                                End If
                                Dim ORClassFilterElementType24501 as String
                                ORClassFilterElementType24501 = "ListIDList"
                                if (ORClassFilterElementType24501 == "ListIDList") then
                                        'Set field value for ListIDList
                                        'May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.ListIDList.Add("200000-1011023419")
                                End If
                                if (ORClassFilterElementType24501 == "FullNameList") then
                                        'Set field value for FullNameList
                                        'May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.FullNameList.Add("ab")
                                End If
                                if (ORClassFilterElementType24501 == "ListIDWithChildren") then
                                        'Set field value for ListIDWithChildren
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.ListIDWithChildren.SetValue("200000-1011023419")
                                End If
                                if (ORClassFilterElementType24501 == "FullNameWithChildren") then
                                        'Set field value for FullNameWithChildren
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.FullNameWithChildren.SetValue("ab")
                                End If
                        End If
                        'Set field value for IncludeRetElementList
                        'May create more than one of these if needed
                        VendorQueryRq.IncludeRetElementList.Add("ab")
                        'Set field value for OwnerIDList
                        'May create more than one of these if needed
                        VendorQueryRq.OwnerIDList.Add(System.Guid.NewGuid().ToString())
                End Sub




                Public Sub WalkVendorQueryRs( responseMsgSet as IMsgSetResponse)
                        if (responseMsgSet is nothing) then
                                Exit Sub
                        End If

                        Dim responseList as IResponseList
                        responseList = responseMsgSet.ResponseList
                        if (responseList is nothing) then
                                Exit Sub
                        End If

                        'if we sent only one request, there is only one response, we'll walk the list for this sample
                        for j=0 to responseList.Count-1
                                Dim response as IResponse
                                response = responseList.GetAt(j)
                                'check the status code of the response, 0=ok, >0 is warning
                                if (response.StatusCode >= 0) then
                                        'the request-specific response is in the details, make sure we have some
                                        if (not response.Detail is nothing) then
                                                'make sure the response is the type we're expecting
                                                Dim responseType as ENResponseType
                                                responseType = CType(response.Type.GetValue(),ENResponseType)
                                                if (responseType == ENResponseType.rtVendorQueryRs) then
                                                        'upcast to more specific type here, this is safe because we checked with response.Type check above
                                                        Dim VendorRet as IVendorRetList
                                                        VendorRet = CType(response.Detail,IVendorRetList)
                                                        WalkVendorRet(VendorRet)
                                                End If
                                        End If
                                End If
                        Next j
                End Sub




                Public Sub WalkVendorRet(VendorRet as IVendorRetList)
                        if (VendorRet is nothing) then
                                Exit Sub
                        End If

                        'Go through all the elements of IVendorRetList
                        'Get value of ListID
                        Dim ListID24502 as String
                        ListID24502 = VendorRet.ListID.GetValue()
                        'Get value of TimeCreated
                        Dim TimeCreated24503 as DateTime
                        TimeCreated24503 = VendorRet.TimeCreated.GetValue()
                        'Get value of TimeModified
                        Dim TimeModified24504 as DateTime
                        TimeModified24504 = VendorRet.TimeModified.GetValue()
                        'Get value of EditSequence
                        Dim EditSequence24505 as String
                        EditSequence24505 = VendorRet.EditSequence.GetValue()
                        'Get value of Name
                        Dim Name24506 as String
                        Name24506 = VendorRet.Name.GetValue()
                        'Get value of IsActive
                        if ( not VendorRet.IsActive is nothing) then
                                Dim IsActive24507 as Boolean
                                IsActive24507 = VendorRet.IsActive.GetValue()
                        End If
                        if (not VendorRet.ClassRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.ClassRef.ListID is nothing) then
                                        Dim ListID24508 as String
                                        ListID24508 = VendorRet.ClassRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.ClassRef.FullName is nothing) then
                                        Dim FullName24509 as String
                                        FullName24509 = VendorRet.ClassRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of IsTaxAgency
                        if ( not VendorRet.IsTaxAgency is nothing) then
                                Dim IsTaxAgency24510 as Boolean
                                IsTaxAgency24510 = VendorRet.IsTaxAgency.GetValue()
                        End If
                        'Get value of CompanyName
                        if ( not VendorRet.CompanyName is nothing) then
                                Dim CompanyName24511 as String
                                CompanyName24511 = VendorRet.CompanyName.GetValue()
                        End If
                        'Get value of Salutation
                        if ( not VendorRet.Salutation is nothing) then
                                Dim Salutation24512 as String
                                Salutation24512 = VendorRet.Salutation.GetValue()
                        End If
                        'Get value of FirstName
                        if ( not VendorRet.FirstName is nothing) then
                                Dim FirstName24513 as String
                                FirstName24513 = VendorRet.FirstName.GetValue()
                        End If
                        'Get value of MiddleName
                        if ( not VendorRet.MiddleName is nothing) then
                                Dim MiddleName24514 as String
                                MiddleName24514 = VendorRet.MiddleName.GetValue()
                        End If
                        'Get value of LastName
                        if ( not VendorRet.LastName is nothing) then
                                Dim LastName24515 as String
                                LastName24515 = VendorRet.LastName.GetValue()
                        End If
                        'Get value of JobTitle
                        if ( not VendorRet.JobTitle is nothing) then
                                Dim JobTitle24516 as String
                                JobTitle24516 = VendorRet.JobTitle.GetValue()
                        End If
                        if (not VendorRet.VendorAddress. is nothing) then
                                'Get value of Addr1
                                if ( not VendorRet.VendorAddress.Addr1 is nothing) then
                                        Dim Addr124517 as String
                                        Addr124517 = VendorRet.VendorAddress.Addr1.GetValue()
                                End If
                                'Get value of Addr2
                                if ( not VendorRet.VendorAddress.Addr2 is nothing) then
                                        Dim Addr224518 as String
                                        Addr224518 = VendorRet.VendorAddress.Addr2.GetValue()
                                End If
                                'Get value of Addr3
                                if ( not VendorRet.VendorAddress.Addr3 is nothing) then
                                        Dim Addr324519 as String
                                        Addr324519 = VendorRet.VendorAddress.Addr3.GetValue()
                                End If
                                'Get value of Addr4
                                if ( not VendorRet.VendorAddress.Addr4 is nothing) then
                                        Dim Addr424520 as String
                                        Addr424520 = VendorRet.VendorAddress.Addr4.GetValue()
                                End If
                                'Get value of Addr5
                                if ( not VendorRet.VendorAddress.Addr5 is nothing) then
                                        Dim Addr524521 as String
                                        Addr524521 = VendorRet.VendorAddress.Addr5.GetValue()
                                End If
                                'Get value of City
                                if ( not VendorRet.VendorAddress.City is nothing) then
                                        Dim City24522 as String
                                        City24522 = VendorRet.VendorAddress.City.GetValue()
                                End If
                                'Get value of State
                                if ( not VendorRet.VendorAddress.State is nothing) then
                                        Dim State24523 as String
                                        State24523 = VendorRet.VendorAddress.State.GetValue()
                                End If
                                'Get value of PostalCode
                                if ( not VendorRet.VendorAddress.PostalCode is nothing) then
                                        Dim PostalCode24524 as String
                                        PostalCode24524 = VendorRet.VendorAddress.PostalCode.GetValue()
                                End If
                                'Get value of Country
                                if ( not VendorRet.VendorAddress.Country is nothing) then
                                        Dim Country24525 as String
                                        Country24525 = VendorRet.VendorAddress.Country.GetValue()
                                End If
                                'Get value of Note
                                if ( not VendorRet.VendorAddress.Note is nothing) then
                                        Dim Note24526 as String
                                        Note24526 = VendorRet.VendorAddress.Note.GetValue()
                                End If
                        End If
                        if (not VendorRet.VendorAddressBlock. is nothing) then
                                'Get value of Addr1
                                if ( not VendorRet.VendorAddressBlock.Addr1 is nothing) then
                                        Dim Addr124527 as String
                                        Addr124527 = VendorRet.VendorAddressBlock.Addr1.GetValue()
                                End If
                                'Get value of Addr2
                                if ( not VendorRet.VendorAddressBlock.Addr2 is nothing) then
                                        Dim Addr224528 as String
                                        Addr224528 = VendorRet.VendorAddressBlock.Addr2.GetValue()
                                End If
                                'Get value of Addr3
                                if ( not VendorRet.VendorAddressBlock.Addr3 is nothing) then
                                        Dim Addr324529 as String
                                        Addr324529 = VendorRet.VendorAddressBlock.Addr3.GetValue()
                                End If
                                'Get value of Addr4
                                if ( not VendorRet.VendorAddressBlock.Addr4 is nothing) then
                                        Dim Addr424530 as String
                                        Addr424530 = VendorRet.VendorAddressBlock.Addr4.GetValue()
                                End If
                                'Get value of Addr5
                                if ( not VendorRet.VendorAddressBlock.Addr5 is nothing) then
                                        Dim Addr524531 as String
                                        Addr524531 = VendorRet.VendorAddressBlock.Addr5.GetValue()
                                End If
                        End If
                        if (not VendorRet.ShipAddress. is nothing) then
                                'Get value of Addr1
                                if ( not VendorRet.ShipAddress.Addr1 is nothing) then
                                        Dim Addr124532 as String
                                        Addr124532 = VendorRet.ShipAddress.Addr1.GetValue()
                                End If
                                'Get value of Addr2
                                if ( not VendorRet.ShipAddress.Addr2 is nothing) then
                                        Dim Addr224533 as String
                                        Addr224533 = VendorRet.ShipAddress.Addr2.GetValue()
                                End If
                                'Get value of Addr3
                                if ( not VendorRet.ShipAddress.Addr3 is nothing) then
                                        Dim Addr324534 as String
                                        Addr324534 = VendorRet.ShipAddress.Addr3.GetValue()
                                End If
                                'Get value of Addr4
                                if ( not VendorRet.ShipAddress.Addr4 is nothing) then
                                        Dim Addr424535 as String
                                        Addr424535 = VendorRet.ShipAddress.Addr4.GetValue()
                                End If
                                'Get value of Addr5
                                if ( not VendorRet.ShipAddress.Addr5 is nothing) then
                                        Dim Addr524536 as String
                                        Addr524536 = VendorRet.ShipAddress.Addr5.GetValue()
                                End If
                                'Get value of City
                                if ( not VendorRet.ShipAddress.City is nothing) then
                                        Dim City24537 as String
                                        City24537 = VendorRet.ShipAddress.City.GetValue()
                                End If
                                'Get value of State
                                if ( not VendorRet.ShipAddress.State is nothing) then
                                        Dim State24538 as String
                                        State24538 = VendorRet.ShipAddress.State.GetValue()
                                End If
                                'Get value of PostalCode
                                if ( not VendorRet.ShipAddress.PostalCode is nothing) then
                                        Dim PostalCode24539 as String
                                        PostalCode24539 = VendorRet.ShipAddress.PostalCode.GetValue()
                                End If
                                'Get value of Country
                                if ( not VendorRet.ShipAddress.Country is nothing) then
                                        Dim Country24540 as String
                                        Country24540 = VendorRet.ShipAddress.Country.GetValue()
                                End If
                                'Get value of Note
                                if ( not VendorRet.ShipAddress.Note is nothing) then
                                        Dim Note24541 as String
                                        Note24541 = VendorRet.ShipAddress.Note.GetValue()
                                End If
                        End If
                        'Get value of Phone
                        if ( not VendorRet.Phone is nothing) then
                                Dim Phone24542 as String
                                Phone24542 = VendorRet.Phone.GetValue()
                        End If
                        'Get value of AltPhone
                        if ( not VendorRet.AltPhone is nothing) then
                                Dim AltPhone24543 as String
                                AltPhone24543 = VendorRet.AltPhone.GetValue()
                        End If
                        'Get value of Fax
                        if ( not VendorRet.Fax is nothing) then
                                Dim Fax24544 as String
                                Fax24544 = VendorRet.Fax.GetValue()
                        End If
                        'Get value of Email
                        if ( not VendorRet.Email is nothing) then
                                Dim Email24545 as String
                                Email24545 = VendorRet.Email.GetValue()
                        End If
                        'Get value of Cc
                        if ( not VendorRet.Cc is nothing) then
                                Dim Cc24546 as String
                                Cc24546 = VendorRet.Cc.GetValue()
                        End If
                        'Get value of Contact
                        if ( not VendorRet.Contact is nothing) then
                                Dim Contact24547 as String
                                Contact24547 = VendorRet.Contact.GetValue()
                        End If
                        'Get value of AltContact
                        if ( not VendorRet.AltContact is nothing) then
                                Dim AltContact24548 as String
                                AltContact24548 = VendorRet.AltContact.GetValue()
                        End If
                        if (not VendorRet.AdditionalContactRefList is nothing)
                                Dim i24549 as Integer
                                for i24549 = 0  to VendorRet.AdditionalContactRefList.Count - 1
                                        Dim QBBaseRef as IQBBaseRef
                                        QBBaseRef = VendorRet.AdditionalContactRefList.GetAt(i24549)
                                        'Get value of ContactName
                                        Dim ContactName24550 as String
                                        ContactName24550 = QBBaseRefContactName.GetValue()
                                        'Get value of ContactValue
                                        Dim ContactValue24551 as String
                                        ContactValue24551 = QBBaseRefContactValue.GetValue()
                                Next i24549
                        End If
                        if (not VendorRet.ContactsRetList is nothing)
                                Dim i24552 as Integer
                                for i24552 = 0  to VendorRet.ContactsRetList.Count - 1
                                        Dim ContactsRet as IContactsRet
                                        ContactsRet = VendorRet.ContactsRetList.GetAt(i24552)
                                        'Get value of ListID
                                        Dim ListID24553 as String
                                        ListID24553 = ContactsRetListID.GetValue()
                                        'Get value of TimeCreated
                                        Dim TimeCreated24554 as DateTime
                                        TimeCreated24554 = ContactsRetTimeCreated.GetValue()
                                        'Get value of TimeModified
                                        Dim TimeModified24555 as DateTime
                                        TimeModified24555 = ContactsRetTimeModified.GetValue()
                                        'Get value of EditSequence
                                        Dim EditSequence24556 as String
                                        EditSequence24556 = ContactsRetEditSequence.GetValue()
                                        'Get value of Contact
                                        if ( not ContactsRetContact is nothing) then
                                                Dim Contact24557 as String
                                                Contact24557 = ContactsRetContact.GetValue()
                                        End If
                                        'Get value of Salutation
                                        if ( not ContactsRetSalutation is nothing) then
                                                Dim Salutation24558 as String
                                                Salutation24558 = ContactsRetSalutation.GetValue()
                                        End If
                                        'Get value of FirstName
                                        Dim FirstName24559 as String
                                        FirstName24559 = ContactsRetFirstName.GetValue()
                                        'Get value of MiddleName
                                        if ( not ContactsRetMiddleName is nothing) then
                                                Dim MiddleName24560 as String
                                                MiddleName24560 = ContactsRetMiddleName.GetValue()
                                        End If
                                        'Get value of LastName
                                        if ( not ContactsRetLastName is nothing) then
                                                Dim LastName24561 as String
                                                LastName24561 = ContactsRetLastName.GetValue()
                                        End If
                                        'Get value of JobTitle
                                        if ( not ContactsRetJobTitle is nothing) then
                                                Dim JobTitle24562 as String
                                                JobTitle24562 = ContactsRetJobTitle.GetValue()
                                        End If
                                        if (not ContactsRetAdditionalContactRefList is nothing)
                                                Dim i24563 as Integer
                                                for i24563 = 0  to ContactsRetAdditionalContactRefList.Count - 1
                                                        Dim QBBaseRef as IQBBaseRef
                                                        QBBaseRef = ContactsRetAdditionalContactRefList.GetAt(i24563)
                                                        'Get value of ContactName
                                                        Dim ContactName24564 as String
                                                        ContactName24564 = QBBaseRefContactName.GetValue()
                                                        'Get value of ContactValue
                                                        Dim ContactValue24565 as String
                                                        ContactValue24565 = QBBaseRefContactValue.GetValue()
                                                Next i24563
                                        End If
                                Next i24552
                        End If
                        'Get value of NameOnCheck
                        if ( not VendorRet.NameOnCheck is nothing) then
                                Dim NameOnCheck24566 as String
                                NameOnCheck24566 = VendorRet.NameOnCheck.GetValue()
                        End If
                        'Get value of AccountNumber
                        if ( not VendorRet.AccountNumber is nothing) then
                                Dim AccountNumber24567 as String
                                AccountNumber24567 = VendorRet.AccountNumber.GetValue()
                        End If
                        'Get value of Notes
                        if ( not VendorRet.Notes is nothing) then
                                Dim Notes24568 as String
                                Notes24568 = VendorRet.Notes.GetValue()
                        End If
                        if (not VendorRet.AdditionalNotesRetList is nothing)
                                Dim i24569 as Integer
                                for i24569 = 0  to VendorRet.AdditionalNotesRetList.Count - 1
                                        Dim AdditionalNotesRet as IAdditionalNotesRet
                                        AdditionalNotesRet = VendorRet.AdditionalNotesRetList.GetAt(i24569)
                                        'Get value of NoteID
                                        Dim NoteID24570 as Integer
                                        NoteID24570 = AdditionalNotesRetNoteID.GetValue()
                                        'Get value of Date
                                        Dim Date24571 as DateTime
                                        Date24571 = AdditionalNotesRetDate.GetValue()
                                        'Get value of Note
                                        Dim Note24572 as String
                                        Note24572 = AdditionalNotesRetNote.GetValue()
                                Next i24569
                        End If
                        if (not VendorRet.VendorTypeRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.VendorTypeRef.ListID is nothing) then
                                        Dim ListID24573 as String
                                        ListID24573 = VendorRet.VendorTypeRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.VendorTypeRef.FullName is nothing) then
                                        Dim FullName24574 as String
                                        FullName24574 = VendorRet.VendorTypeRef.FullName.GetValue()
                                End If
                        End If
                        if (not VendorRet.TermsRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.TermsRef.ListID is nothing) then
                                        Dim ListID24575 as String
                                        ListID24575 = VendorRet.TermsRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.TermsRef.FullName is nothing) then
                                        Dim FullName24576 as String
                                        FullName24576 = VendorRet.TermsRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of CreditLimit
                        if ( not VendorRet.CreditLimit is nothing) then
                                Dim CreditLimit24577 as Double
                                CreditLimit24577 = VendorRet.CreditLimit.GetValue()
                        End If
                        'Get value of VendorTaxIdent
                        if ( not VendorRet.VendorTaxIdent is nothing) then
                                Dim VendorTaxIdent24578 as String
                                VendorTaxIdent24578 = VendorRet.VendorTaxIdent.GetValue()
                        End If
                        'Get value of IsVendorEligibleFor1099
                        if ( not VendorRet.IsVendorEligibleFor1099 is nothing) then
                                Dim IsVendorEligibleFor109924579 as Boolean
                                IsVendorEligibleFor109924579 = VendorRet.IsVendorEligibleFor1099.GetValue()
                        End If
                        'Get value of Balance
                        if ( not VendorRet.Balance is nothing) then
                                Dim Balance24580 as Double
                                Balance24580 = VendorRet.Balance.GetValue()
                        End If
                        if (not VendorRet.BillingRateRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.BillingRateRef.ListID is nothing) then
                                        Dim ListID24581 as String
                                        ListID24581 = VendorRet.BillingRateRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.BillingRateRef.FullName is nothing) then
                                        Dim FullName24582 as String
                                        FullName24582 = VendorRet.BillingRateRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of ExternalGUID
                        if ( not VendorRet.ExternalGUID is nothing) then
                                Dim ExternalGUID24583 as String
                                ExternalGUID24583 = VendorRet.ExternalGUID.GetValue()
                        End If
                        if (not VendorRet.SalesTaxCodeRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.SalesTaxCodeRef.ListID is nothing) then
                                        Dim ListID24584 as String
                                        ListID24584 = VendorRet.SalesTaxCodeRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.SalesTaxCodeRef.FullName is nothing) then
                                        Dim FullName24585 as String
                                        FullName24585 = VendorRet.SalesTaxCodeRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of SalesTaxCountry
                        if ( not VendorRet.SalesTaxCountry is nothing) then
                                Dim SalesTaxCountry24586 as ENSalesTaxCountry
                                SalesTaxCountry24586 = VendorRet.SalesTaxCountry.GetValue()
                        End If
                        'Get value of IsSalesTaxAgency
                        if ( not VendorRet.IsSalesTaxAgency is nothing) then
                                Dim IsSalesTaxAgency24587 as Boolean
                                IsSalesTaxAgency24587 = VendorRet.IsSalesTaxAgency.GetValue()
                        End If
                        if (not VendorRet.SalesTaxReturnRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.SalesTaxReturnRef.ListID is nothing) then
                                        Dim ListID24588 as String
                                        ListID24588 = VendorRet.SalesTaxReturnRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.SalesTaxReturnRef.FullName is nothing) then
                                        Dim FullName24589 as String
                                        FullName24589 = VendorRet.SalesTaxReturnRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of TaxRegistrationNumber
                        if ( not VendorRet.TaxRegistrationNumber is nothing) then
                                Dim TaxRegistrationNumber24590 as String
                                TaxRegistrationNumber24590 = VendorRet.TaxRegistrationNumber.GetValue()
                        End If
                        'Get value of ReportingPeriod
                        if ( not VendorRet.ReportingPeriod is nothing) then
                                Dim ReportingPeriod24591 as ENReportingPeriod
                                ReportingPeriod24591 = VendorRet.ReportingPeriod.GetValue()
                        End If
                        'Get value of IsTaxTrackedOnPurchases
                        if ( not VendorRet.IsTaxTrackedOnPurchases is nothing) then
                                Dim IsTaxTrackedOnPurchases24592 as Boolean
                                IsTaxTrackedOnPurchases24592 = VendorRet.IsTaxTrackedOnPurchases.GetValue()
                        End If
                        if (not VendorRet.TaxOnPurchasesAccountRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.TaxOnPurchasesAccountRef.ListID is nothing) then
                                        Dim ListID24593 as String
                                        ListID24593 = VendorRet.TaxOnPurchasesAccountRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.TaxOnPurchasesAccountRef.FullName is nothing) then
                                        Dim FullName24594 as String
                                        FullName24594 = VendorRet.TaxOnPurchasesAccountRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of IsTaxTrackedOnSales
                        if ( not VendorRet.IsTaxTrackedOnSales is nothing) then
                                Dim IsTaxTrackedOnSales24595 as Boolean
                                IsTaxTrackedOnSales24595 = VendorRet.IsTaxTrackedOnSales.GetValue()
                        End If
                        if (not VendorRet.TaxOnSalesAccountRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.TaxOnSalesAccountRef.ListID is nothing) then
                                        Dim ListID24596 as String
                                        ListID24596 = VendorRet.TaxOnSalesAccountRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.TaxOnSalesAccountRef.FullName is nothing) then
                                        Dim FullName24597 as String
                                        FullName24597 = VendorRet.TaxOnSalesAccountRef.FullName.GetValue()
                                End If
                        End If
                        'Get value of IsTaxOnTax
                        if ( not VendorRet.IsTaxOnTax is nothing) then
                                Dim IsTaxOnTax24598 as Boolean
                                IsTaxOnTax24598 = VendorRet.IsTaxOnTax.GetValue()
                        End If
                        if (not VendorRet.PrefillAccountRefList is nothing)
                                Dim i24599 as Integer
                                for i24599 = 0  to VendorRet.PrefillAccountRefList.Count - 1
                                        Dim QBBaseRef as IQBBaseRef
                                        QBBaseRef = VendorRet.PrefillAccountRefList.GetAt(i24599)
                                        'Get value of ListID
                                        if ( not QBBaseRefListID is nothing) then
                                                Dim ListID24600 as String
                                                ListID24600 = QBBaseRefListID.GetValue()
                                        End If
                                        'Get value of FullName
                                        if ( not QBBaseRefFullName is nothing) then
                                                Dim FullName24601 as String
                                                FullName24601 = QBBaseRefFullName.GetValue()
                                        End If
                                Next i24599
                        End If
                        if (not VendorRet.CurrencyRef. is nothing) then
                                'Get value of ListID
                                if ( not VendorRet.CurrencyRef.ListID is nothing) then
                                        Dim ListID24602 as String
                                        ListID24602 = VendorRet.CurrencyRef.ListID.GetValue()
                                End If
                                'Get value of FullName
                                if ( not VendorRet.CurrencyRef.FullName is nothing) then
                                        Dim FullName24603 as String
                                        FullName24603 = VendorRet.CurrencyRef.FullName.GetValue()
                                End If
                        End If
                        if (not VendorRet.DataExtRetList is nothing)
                                Dim i24604 as Integer
                                for i24604 = 0  to VendorRet.DataExtRetList.Count - 1
                                        Dim DataExtRet as IDataExtRet
                                        DataExtRet = VendorRet.DataExtRetList.GetAt(i24604)
                                        'Get value of OwnerID
                                        if ( not DataExtRetOwnerID is nothing) then
                                                Dim OwnerID24605 as String
                                                OwnerID24605 = DataExtRetOwnerID.GetValue()
                                        End If
                                        'Get value of DataExtName
                                        Dim DataExtName24606 as String
                                        DataExtName24606 = DataExtRetDataExtName.GetValue()
                                        'Get value of DataExtType
                                        Dim DataExtType24607 as ENDataExtType
                                        DataExtType24607 = DataExtRetDataExtType.GetValue()
                                        'Get value of DataExtValue
                                        Dim DataExtValue24608 as String
                                        DataExtValue24608 = DataExtRetDataExtValue.GetValue()
                                Next i24604
                        End If
                End Sub




        End Class
End Module

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
//The following sample code is generated as an illustration of
//Creating requests and parsing responses ONLY
//This code is NOT intended to show best practices or ideal code
//Use at your most careful discretion

using System;
using System.Net;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.IO;
using Interop.QBFC16;

namespace com.intuit.idn.samples
{
        public class Sample
        {
                public void  DoVendorQuery()
                {
                        bool sessionBegun = false;
                        bool connectionOpen = false;
                        QBSessionManager sessionManager = null;

                        try
                        {
                                //Create the session Manager object
                                sessionManager = new QBSessionManager();

                                //Create the message set request object to hold our request
                                IMsgSetRequest requestMsgSet = sessionManager.CreateMsgSetRequest("US",16,0);
                                requestMsgSet.Attributes.OnError = ENRqOnError.roeContinue;

                                BuildVendorQueryRq(requestMsgSet);

                                //Connect to QuickBooks and begin a session
                                sessionManager.OpenConnection("","Sample Code from OSR");
                                connectionOpen = true;
                                sessionManager.BeginSession("", ENOpenMode.omDontCare);
                                sessionBegun = true;

                                //Send the request and get the response from QuickBooks
                                IMsgSetResponse responseMsgSet = sessionManager.DoRequests(requestMsgSet);

                                //End the session and close the connection to QuickBooks
                                sessionManager.EndSession();
                                sessionBegun = false;
                                sessionManager.CloseConnection();
                                connectionOpen = false;

                                WalkVendorQueryRs(responseMsgSet);
                        }
                        catch (Exception e)
                        {
                                MessageBox.Show(e.Message, "Error");
                                if (sessionBegun)
                                {
                                        sessionManager.EndSession();
                                }
                                if (connectionOpen)
                                {
                                        sessionManager.CloseConnection();
                                }
                        }
                }
                void BuildVendorQueryRq(IMsgSetRequest requestMsgSet)
                {
                        IVendorQuery VendorQueryRq= requestMsgSet.AppendVendorQueryRq();
                        //Set attributes
                        //Set field value for metaData
                        VendorQueryRq.metaData.SetValue("IQBENmetaDataType");
                        //Set field value for iterator
                        VendorQueryRq.iterator.SetValue("IQBENiteratorType");
                        //Set field value for iteratorID
                        VendorQueryRq.iteratorID.SetValue("IQBUUIDType");
                        string ORVendorListQueryElementType24387 = "ListIDList";
                        if (ORVendorListQueryElementType24387 == "ListIDList")
                        {
                                //Set field value for ListIDList
                                //May create more than one of these if needed
                                VendorQueryRq.ORVendorListQuery.ListIDList.Add("200000-1011023419");
                        }
                        if (ORVendorListQueryElementType24387 == "FullNameList")
                        {
                                //Set field value for FullNameList
                                //May create more than one of these if needed
                                VendorQueryRq.ORVendorListQuery.FullNameList.Add("ab");
                        }
                        if (ORVendorListQueryElementType24387 == "VendorListFilter")
                        {
                                //Set field value for MaxReturned
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.MaxReturned.SetValue(6);
                                //Set field value for ActiveStatus
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.ActiveStatus.SetValue(ENActiveStatus.asActiveOnly [DEFAULT]);
                                //Set field value for FromModifiedDate
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.FromModifiedDate.SetValue(DateTime.Parse("12/15/2007 12:15:12"),false);
                                //Set field value for ToModifiedDate
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.ToModifiedDate.SetValue(DateTime.Parse("12/15/2007 12:15:12"),false);
                                string ORNameFilterElementType24388 = "NameFilter";
                                if (ORNameFilterElementType24388 == "NameFilter")
                                {
                                        //Set field value for MatchCriterion
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameFilter.MatchCriterion.SetValue(ENMatchCriterion.mcStartsWith);
                                        //Set field value for Name
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameFilter.Name.SetValue("ab");
                                }
                                if (ORNameFilterElementType24388 == "NameRangeFilter")
                                {
                                        //Set field value for FromName
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameRangeFilter.FromName.SetValue("ab");
                                        //Set field value for ToName
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ORNameFilter.NameRangeFilter.ToName.SetValue("ab");
                                }
                                //Set field value for Operator
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.TotalBalanceFilter.Operator.SetValue(ENOperator.oLessThan);
                                //Set field value for Amount
                                VendorQueryRq.ORVendorListQuery.VendorListFilter.TotalBalanceFilter.Amount.SetValue(10.01);
                                string ORCurrencyFilterElementType24389 = "ListIDList";
                                if (ORCurrencyFilterElementType24389 == "ListIDList")
                                {
                                        //Set field value for ListIDList
                                        //May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.CurrencyFilter.ORCurrencyFilter.ListIDList.Add("200000-1011023419");
                                }
                                if (ORCurrencyFilterElementType24389 == "FullNameList")
                                {
                                        //Set field value for FullNameList
                                        //May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.CurrencyFilter.ORCurrencyFilter.FullNameList.Add("ab");
                                }
                                string ORClassFilterElementType24390 = "ListIDList";
                                if (ORClassFilterElementType24390 == "ListIDList")
                                {
                                        //Set field value for ListIDList
                                        //May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.ListIDList.Add("200000-1011023419");
                                }
                                if (ORClassFilterElementType24390 == "FullNameList")
                                {
                                        //Set field value for FullNameList
                                        //May create more than one of these if needed
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.FullNameList.Add("ab");
                                }
                                if (ORClassFilterElementType24390 == "ListIDWithChildren")
                                {
                                        //Set field value for ListIDWithChildren
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.ListIDWithChildren.SetValue("200000-1011023419");
                                }
                                if (ORClassFilterElementType24390 == "FullNameWithChildren")
                                {
                                        //Set field value for FullNameWithChildren
                                        VendorQueryRq.ORVendorListQuery.VendorListFilter.ClassFilter.ORClassFilter.FullNameWithChildren.SetValue("ab");
                                }
                        }
                        //Set field value for IncludeRetElementList
                        //May create more than one of these if needed
                        VendorQueryRq.IncludeRetElementList.Add("ab");
                        //Set field value for OwnerIDList
                        //May create more than one of these if needed
                        VendorQueryRq.OwnerIDList.Add(Guid.NewGuid().ToString());
                }




                void WalkVendorQueryRs(IMsgSetResponse responseMsgSet)
                {
                        if (responseMsgSet == null) return;
                        IResponseList responseList = responseMsgSet.ResponseList;
                        if (responseList == null) return;
                        //if we sent only one request, there is only one response, we'll walk the list for this sample
                        for(int i=0; i < responseList.Count; i++)
                        {
                                IResponse response = responseList.GetAt(i);
                                //check the status code of the response, 0=ok, >0 is warning
                                if (response.StatusCode >= 0)
                                {
                                        //the request-specific response is in the details, make sure we have some
                                        if (response.Detail != null)
                                        {
                                                //make sure the response is the type we're expecting
                                                ENResponseType responseType = (ENResponseType)response.Type.GetValue();
                                                if (responseType == ENResponseType.rtVendorQueryRs)
                                                {
                                                        //upcast to more specific type here, this is safe because we checked with response.Type check above
                                                        IVendorRetList VendorRet = (IVendorRetList)response.Detail;
                                                        WalkVendorRet(VendorRet);
                                                }
                                        }
                                }
                        }
                }




                void WalkVendorRet(IVendorRetList VendorRet)
                {
                        if (VendorRet == null) return;
                        //Go through all the elements of IVendorRetList
                        //Get value of ListID
                        string ListID24391 = (string)VendorRet.ListID.GetValue();
                        //Get value of TimeCreated
                        DateTime TimeCreated24392 = (DateTime)VendorRet.TimeCreated.GetValue();
                        //Get value of TimeModified
                        DateTime TimeModified24393 = (DateTime)VendorRet.TimeModified.GetValue();
                        //Get value of EditSequence
                        string EditSequence24394 = (string)VendorRet.EditSequence.GetValue();
                        //Get value of Name
                        string Name24395 = (string)VendorRet.Name.GetValue();
                        //Get value of IsActive
                        if (VendorRet.IsActive != null)
                        {
                                bool IsActive24396 = (bool)VendorRet.IsActive.GetValue();
                        }
                        if (VendorRet.ClassRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.ClassRef.ListID != null)
                                {
                                        string ListID24397 = (string)VendorRet.ClassRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.ClassRef.FullName != null)
                                {
                                        string FullName24398 = (string)VendorRet.ClassRef.FullName.GetValue();
                                }
                        }
                        //Get value of IsTaxAgency
                        if (VendorRet.IsTaxAgency != null)
                        {
                                bool IsTaxAgency24399 = (bool)VendorRet.IsTaxAgency.GetValue();
                        }
                        //Get value of CompanyName
                        if (VendorRet.CompanyName != null)
                        {
                                string CompanyName24400 = (string)VendorRet.CompanyName.GetValue();
                        }
                        //Get value of Salutation
                        if (VendorRet.Salutation != null)
                        {
                                string Salutation24401 = (string)VendorRet.Salutation.GetValue();
                        }
                        //Get value of FirstName
                        if (VendorRet.FirstName != null)
                        {
                                string FirstName24402 = (string)VendorRet.FirstName.GetValue();
                        }
                        //Get value of MiddleName
                        if (VendorRet.MiddleName != null)
                        {
                                string MiddleName24403 = (string)VendorRet.MiddleName.GetValue();
                        }
                        //Get value of LastName
                        if (VendorRet.LastName != null)
                        {
                                string LastName24404 = (string)VendorRet.LastName.GetValue();
                        }
                        //Get value of JobTitle
                        if (VendorRet.JobTitle != null)
                        {
                                string JobTitle24405 = (string)VendorRet.JobTitle.GetValue();
                        }
                        if (VendorRet.VendorAddress != null)
                        {
                                //Get value of Addr1
                                if (VendorRet.VendorAddress.Addr1 != null)
                                {
                                        string Addr124406 = (string)VendorRet.VendorAddress.Addr1.GetValue();
                                }
                                //Get value of Addr2
                                if (VendorRet.VendorAddress.Addr2 != null)
                                {
                                        string Addr224407 = (string)VendorRet.VendorAddress.Addr2.GetValue();
                                }
                                //Get value of Addr3
                                if (VendorRet.VendorAddress.Addr3 != null)
                                {
                                        string Addr324408 = (string)VendorRet.VendorAddress.Addr3.GetValue();
                                }
                                //Get value of Addr4
                                if (VendorRet.VendorAddress.Addr4 != null)
                                {
                                        string Addr424409 = (string)VendorRet.VendorAddress.Addr4.GetValue();
                                }
                                //Get value of Addr5
                                if (VendorRet.VendorAddress.Addr5 != null)
                                {
                                        string Addr524410 = (string)VendorRet.VendorAddress.Addr5.GetValue();
                                }
                                //Get value of City
                                if (VendorRet.VendorAddress.City != null)
                                {
                                        string City24411 = (string)VendorRet.VendorAddress.City.GetValue();
                                }
                                //Get value of State
                                if (VendorRet.VendorAddress.State != null)
                                {
                                        string State24412 = (string)VendorRet.VendorAddress.State.GetValue();
                                }
                                //Get value of PostalCode
                                if (VendorRet.VendorAddress.PostalCode != null)
                                {
                                        string PostalCode24413 = (string)VendorRet.VendorAddress.PostalCode.GetValue();
                                }
                                //Get value of Country
                                if (VendorRet.VendorAddress.Country != null)
                                {
                                        string Country24414 = (string)VendorRet.VendorAddress.Country.GetValue();
                                }
                                //Get value of Note
                                if (VendorRet.VendorAddress.Note != null)
                                {
                                        string Note24415 = (string)VendorRet.VendorAddress.Note.GetValue();
                                }
                        }
                        if (VendorRet.VendorAddressBlock != null)
                        {
                                //Get value of Addr1
                                if (VendorRet.VendorAddressBlock.Addr1 != null)
                                {
                                        string Addr124416 = (string)VendorRet.VendorAddressBlock.Addr1.GetValue();
                                }
                                //Get value of Addr2
                                if (VendorRet.VendorAddressBlock.Addr2 != null)
                                {
                                        string Addr224417 = (string)VendorRet.VendorAddressBlock.Addr2.GetValue();
                                }
                                //Get value of Addr3
                                if (VendorRet.VendorAddressBlock.Addr3 != null)
                                {
                                        string Addr324418 = (string)VendorRet.VendorAddressBlock.Addr3.GetValue();
                                }
                                //Get value of Addr4
                                if (VendorRet.VendorAddressBlock.Addr4 != null)
                                {
                                        string Addr424419 = (string)VendorRet.VendorAddressBlock.Addr4.GetValue();
                                }
                                //Get value of Addr5
                                if (VendorRet.VendorAddressBlock.Addr5 != null)
                                {
                                        string Addr524420 = (string)VendorRet.VendorAddressBlock.Addr5.GetValue();
                                }
                        }
                        if (VendorRet.ShipAddress != null)
                        {
                                //Get value of Addr1
                                if (VendorRet.ShipAddress.Addr1 != null)
                                {
                                        string Addr124421 = (string)VendorRet.ShipAddress.Addr1.GetValue();
                                }
                                //Get value of Addr2
                                if (VendorRet.ShipAddress.Addr2 != null)
                                {
                                        string Addr224422 = (string)VendorRet.ShipAddress.Addr2.GetValue();
                                }
                                //Get value of Addr3
                                if (VendorRet.ShipAddress.Addr3 != null)
                                {
                                        string Addr324423 = (string)VendorRet.ShipAddress.Addr3.GetValue();
                                }
                                //Get value of Addr4
                                if (VendorRet.ShipAddress.Addr4 != null)
                                {
                                        string Addr424424 = (string)VendorRet.ShipAddress.Addr4.GetValue();
                                }
                                //Get value of Addr5
                                if (VendorRet.ShipAddress.Addr5 != null)
                                {
                                        string Addr524425 = (string)VendorRet.ShipAddress.Addr5.GetValue();
                                }
                                //Get value of City
                                if (VendorRet.ShipAddress.City != null)
                                {
                                        string City24426 = (string)VendorRet.ShipAddress.City.GetValue();
                                }
                                //Get value of State
                                if (VendorRet.ShipAddress.State != null)
                                {
                                        string State24427 = (string)VendorRet.ShipAddress.State.GetValue();
                                }
                                //Get value of PostalCode
                                if (VendorRet.ShipAddress.PostalCode != null)
                                {
                                        string PostalCode24428 = (string)VendorRet.ShipAddress.PostalCode.GetValue();
                                }
                                //Get value of Country
                                if (VendorRet.ShipAddress.Country != null)
                                {
                                        string Country24429 = (string)VendorRet.ShipAddress.Country.GetValue();
                                }
                                //Get value of Note
                                if (VendorRet.ShipAddress.Note != null)
                                {
                                        string Note24430 = (string)VendorRet.ShipAddress.Note.GetValue();
                                }
                        }
                        //Get value of Phone
                        if (VendorRet.Phone != null)
                        {
                                string Phone24431 = (string)VendorRet.Phone.GetValue();
                        }
                        //Get value of AltPhone
                        if (VendorRet.AltPhone != null)
                        {
                                string AltPhone24432 = (string)VendorRet.AltPhone.GetValue();
                        }
                        //Get value of Fax
                        if (VendorRet.Fax != null)
                        {
                                string Fax24433 = (string)VendorRet.Fax.GetValue();
                        }
                        //Get value of Email
                        if (VendorRet.Email != null)
                        {
                                string Email24434 = (string)VendorRet.Email.GetValue();
                        }
                        //Get value of Cc
                        if (VendorRet.Cc != null)
                        {
                                string Cc24435 = (string)VendorRet.Cc.GetValue();
                        }
                        //Get value of Contact
                        if (VendorRet.Contact != null)
                        {
                                string Contact24436 = (string)VendorRet.Contact.GetValue();
                        }
                        //Get value of AltContact
                        if (VendorRet.AltContact != null)
                        {
                                string AltContact24437 = (string)VendorRet.AltContact.GetValue();
                        }
                        if (VendorRet.AdditionalContactRefList != null)
                        {
                                for (int i24438 = 0; i24438 < VendorRet.AdditionalContactRefList.Count; i24438++)
                                {
                                        IQBBaseRef QBBaseRef = VendorRet.AdditionalContactRefList.GetAt(i24438);
                                        //Get value of ContactName
                                        string ContactName24439 = (string)QBBaseRef.ContactName.GetValue();
                                        //Get value of ContactValue
                                        string ContactValue24440 = (string)QBBaseRef.ContactValue.GetValue();
                                }
                        }
                        if (VendorRet.ContactsRetList != null)
                        {
                                for (int i24441 = 0; i24441 < VendorRet.ContactsRetList.Count; i24441++)
                                {
                                        IContactsRet ContactsRet = VendorRet.ContactsRetList.GetAt(i24441);
                                        //Get value of ListID
                                        string ListID24442 = (string)ContactsRet.ListID.GetValue();
                                        //Get value of TimeCreated
                                        DateTime TimeCreated24443 = (DateTime)ContactsRet.TimeCreated.GetValue();
                                        //Get value of TimeModified
                                        DateTime TimeModified24444 = (DateTime)ContactsRet.TimeModified.GetValue();
                                        //Get value of EditSequence
                                        string EditSequence24445 = (string)ContactsRet.EditSequence.GetValue();
                                        //Get value of Contact
                                        if (ContactsRet.Contact != null)
                                        {
                                                string Contact24446 = (string)ContactsRet.Contact.GetValue();
                                        }
                                        //Get value of Salutation
                                        if (ContactsRet.Salutation != null)
                                        {
                                                string Salutation24447 = (string)ContactsRet.Salutation.GetValue();
                                        }
                                        //Get value of FirstName
                                        string FirstName24448 = (string)ContactsRet.FirstName.GetValue();
                                        //Get value of MiddleName
                                        if (ContactsRet.MiddleName != null)
                                        {
                                                string MiddleName24449 = (string)ContactsRet.MiddleName.GetValue();
                                        }
                                        //Get value of LastName
                                        if (ContactsRet.LastName != null)
                                        {
                                                string LastName24450 = (string)ContactsRet.LastName.GetValue();
                                        }
                                        //Get value of JobTitle
                                        if (ContactsRet.JobTitle != null)
                                        {
                                                string JobTitle24451 = (string)ContactsRet.JobTitle.GetValue();
                                        }
                                        if (ContactsRet.AdditionalContactRefList != null)
                                        {
                                                for (int i24452 = 0; i24452 < ContactsRet.AdditionalContactRefList.Count; i24452++)
                                                {
                                                        IQBBaseRef QBBaseRef = ContactsRet.AdditionalContactRefList.GetAt(i24452);
                                                        //Get value of ContactName
                                                        string ContactName24453 = (string)QBBaseRef.ContactName.GetValue();
                                                        //Get value of ContactValue
                                                        string ContactValue24454 = (string)QBBaseRef.ContactValue.GetValue();
                                                }
                                        }
                                }
                        }
                        //Get value of NameOnCheck
                        if (VendorRet.NameOnCheck != null)
                        {
                                string NameOnCheck24455 = (string)VendorRet.NameOnCheck.GetValue();
                        }
                        //Get value of AccountNumber
                        if (VendorRet.AccountNumber != null)
                        {
                                string AccountNumber24456 = (string)VendorRet.AccountNumber.GetValue();
                        }
                        //Get value of Notes
                        if (VendorRet.Notes != null)
                        {
                                string Notes24457 = (string)VendorRet.Notes.GetValue();
                        }
                        if (VendorRet.AdditionalNotesRetList != null)
                        {
                                for (int i24458 = 0; i24458 < VendorRet.AdditionalNotesRetList.Count; i24458++)
                                {
                                        IAdditionalNotesRet AdditionalNotesRet = VendorRet.AdditionalNotesRetList.GetAt(i24458);
                                        //Get value of NoteID
                                        int NoteID24459 = (int)AdditionalNotesRet.NoteID.GetValue();
                                        //Get value of Date
                                        DateTime Date24460 = (DateTime)AdditionalNotesRet.Date.GetValue();
                                        //Get value of Note
                                        string Note24461 = (string)AdditionalNotesRet.Note.GetValue();
                                }
                        }
                        if (VendorRet.VendorTypeRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.VendorTypeRef.ListID != null)
                                {
                                        string ListID24462 = (string)VendorRet.VendorTypeRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.VendorTypeRef.FullName != null)
                                {
                                        string FullName24463 = (string)VendorRet.VendorTypeRef.FullName.GetValue();
                                }
                        }
                        if (VendorRet.TermsRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.TermsRef.ListID != null)
                                {
                                        string ListID24464 = (string)VendorRet.TermsRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.TermsRef.FullName != null)
                                {
                                        string FullName24465 = (string)VendorRet.TermsRef.FullName.GetValue();
                                }
                        }
                        //Get value of CreditLimit
                        if (VendorRet.CreditLimit != null)
                        {
                                double CreditLimit24466 = (double)VendorRet.CreditLimit.GetValue();
                        }
                        //Get value of VendorTaxIdent
                        if (VendorRet.VendorTaxIdent != null)
                        {
                                string VendorTaxIdent24467 = (string)VendorRet.VendorTaxIdent.GetValue();
                        }
                        //Get value of IsVendorEligibleFor1099
                        if (VendorRet.IsVendorEligibleFor1099 != null)
                        {
                                bool IsVendorEligibleFor109924468 = (bool)VendorRet.IsVendorEligibleFor1099.GetValue();
                        }
                        //Get value of Balance
                        if (VendorRet.Balance != null)
                        {
                                double Balance24469 = (double)VendorRet.Balance.GetValue();
                        }
                        if (VendorRet.BillingRateRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.BillingRateRef.ListID != null)
                                {
                                        string ListID24470 = (string)VendorRet.BillingRateRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.BillingRateRef.FullName != null)
                                {
                                        string FullName24471 = (string)VendorRet.BillingRateRef.FullName.GetValue();
                                }
                        }
                        //Get value of ExternalGUID
                        if (VendorRet.ExternalGUID != null)
                        {
                                string ExternalGUID24472 = (string)VendorRet.ExternalGUID.GetValue();
                        }
                        if (VendorRet.SalesTaxCodeRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.SalesTaxCodeRef.ListID != null)
                                {
                                        string ListID24473 = (string)VendorRet.SalesTaxCodeRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.SalesTaxCodeRef.FullName != null)
                                {
                                        string FullName24474 = (string)VendorRet.SalesTaxCodeRef.FullName.GetValue();
                                }
                        }
                        //Get value of SalesTaxCountry
                        if (VendorRet.SalesTaxCountry != null)
                        {
                                ENSalesTaxCountry SalesTaxCountry24475 = (ENSalesTaxCountry)VendorRet.SalesTaxCountry.GetValue();
                        }
                        //Get value of IsSalesTaxAgency
                        if (VendorRet.IsSalesTaxAgency != null)
                        {
                                bool IsSalesTaxAgency24476 = (bool)VendorRet.IsSalesTaxAgency.GetValue();
                        }
                        if (VendorRet.SalesTaxReturnRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.SalesTaxReturnRef.ListID != null)
                                {
                                        string ListID24477 = (string)VendorRet.SalesTaxReturnRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.SalesTaxReturnRef.FullName != null)
                                {
                                        string FullName24478 = (string)VendorRet.SalesTaxReturnRef.FullName.GetValue();
                                }
                        }
                        //Get value of TaxRegistrationNumber
                        if (VendorRet.TaxRegistrationNumber != null)
                        {
                                string TaxRegistrationNumber24479 = (string)VendorRet.TaxRegistrationNumber.GetValue();
                        }
                        //Get value of ReportingPeriod
                        if (VendorRet.ReportingPeriod != null)
                        {
                                ENReportingPeriod ReportingPeriod24480 = (ENReportingPeriod)VendorRet.ReportingPeriod.GetValue();
                        }
                        //Get value of IsTaxTrackedOnPurchases
                        if (VendorRet.IsTaxTrackedOnPurchases != null)
                        {
                                bool IsTaxTrackedOnPurchases24481 = (bool)VendorRet.IsTaxTrackedOnPurchases.GetValue();
                        }
                        if (VendorRet.TaxOnPurchasesAccountRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.TaxOnPurchasesAccountRef.ListID != null)
                                {
                                        string ListID24482 = (string)VendorRet.TaxOnPurchasesAccountRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.TaxOnPurchasesAccountRef.FullName != null)
                                {
                                        string FullName24483 = (string)VendorRet.TaxOnPurchasesAccountRef.FullName.GetValue();
                                }
                        }
                        //Get value of IsTaxTrackedOnSales
                        if (VendorRet.IsTaxTrackedOnSales != null)
                        {
                                bool IsTaxTrackedOnSales24484 = (bool)VendorRet.IsTaxTrackedOnSales.GetValue();
                        }
                        if (VendorRet.TaxOnSalesAccountRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.TaxOnSalesAccountRef.ListID != null)
                                {
                                        string ListID24485 = (string)VendorRet.TaxOnSalesAccountRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.TaxOnSalesAccountRef.FullName != null)
                                {
                                        string FullName24486 = (string)VendorRet.TaxOnSalesAccountRef.FullName.GetValue();
                                }
                        }
                        //Get value of IsTaxOnTax
                        if (VendorRet.IsTaxOnTax != null)
                        {
                                bool IsTaxOnTax24487 = (bool)VendorRet.IsTaxOnTax.GetValue();
                        }
                        if (VendorRet.PrefillAccountRefList != null)
                        {
                                for (int i24488 = 0; i24488 < VendorRet.PrefillAccountRefList.Count; i24488++)
                                {
                                        IQBBaseRef QBBaseRef = VendorRet.PrefillAccountRefList.GetAt(i24488);
                                        //Get value of ListID
                                        if (QBBaseRef.ListID != null)
                                        {
                                                string ListID24489 = (string)QBBaseRef.ListID.GetValue();
                                        }
                                        //Get value of FullName
                                        if (QBBaseRef.FullName != null)
                                        {
                                                string FullName24490 = (string)QBBaseRef.FullName.GetValue();
                                        }
                                }
                        }
                        if (VendorRet.CurrencyRef != null)
                        {
                                //Get value of ListID
                                if (VendorRet.CurrencyRef.ListID != null)
                                {
                                        string ListID24491 = (string)VendorRet.CurrencyRef.ListID.GetValue();
                                }
                                //Get value of FullName
                                if (VendorRet.CurrencyRef.FullName != null)
                                {
                                        string FullName24492 = (string)VendorRet.CurrencyRef.FullName.GetValue();
                                }
                        }
                        if (VendorRet.DataExtRetList != null)
                        {
                                for (int i24493 = 0; i24493 < VendorRet.DataExtRetList.Count; i24493++)
                                {
                                        IDataExtRet DataExtRet = VendorRet.DataExtRetList.GetAt(i24493);
                                        //Get value of OwnerID
                                        if (DataExtRet.OwnerID != null)
                                        {
                                                string OwnerID24494 = (string)DataExtRet.OwnerID.GetValue();
                                        }
                                        //Get value of DataExtName
                                        string DataExtName24495 = (string)DataExtRet.DataExtName.GetValue();
                                        //Get value of DataExtType
                                        ENDataExtType DataExtType24496 = (ENDataExtType)DataExtRet.DataExtType.GetValue();
                                        //Get value of DataExtValue
                                        string DataExtValue24497 = (string)DataExtRet.DataExtValue.GetValue();
                                }
                        }
                }




        }
}