GET
/
quickbooks-desktop
/
price-levels
import Conductor from 'conductor-node';

const client = new Conductor({
  apiKey: process.env['CONDUCTOR_SECRET_KEY'], // This is the default and can be omitted
});

async function main() {
  const priceLevels = await client.qbd.priceLevels.list({ conductorEndUserId: 'end_usr_1234567abcdefg' });

  console.log(priceLevels.data);
}

main();
{
  "objectType": "list",
  "url": "/v1/quickbooks-desktop/price-levels",
  "data": [
    {
      "id": "80000001-1234567890",
      "objectType": "qbd_price_level",
      "createdAt": "2021-10-01T17:34:56.000Z",
      "updatedAt": "2021-10-01T20:45:30.000Z",
      "revisionNumber": "1721172183",
      "name": "Wholesale 20% Discount",
      "isActive": true,
      "priceLevelType": "fixed_percentage",
      "fixedPercentage": "-10.0",
      "perItemPriceLevels": [
        {
          "item": {
            "id": "80000001-1234567890",
            "fullName": "Widget A"
          },
          "customPrice": "19.99",
          "customPricePercent": "15.0"
        }
      ],
      "currency": {
        "id": "80000001-1234567890",
        "fullName": "USD"
      }
    }
  ]
}

Authorizations

Authorization
string
header
required

Your Conductor secret key using Bearer auth (e.g., "Authorization: Bearer {{YOUR_SECRET_KEY}}").

Headers

Conductor-End-User-Id
string
required

The ID of the EndUser to receive this request (e.g., "Conductor-End-User-Id: {{END_USER_ID}}").

Example:

"end_usr_1234567abcdefg"

Query Parameters

ids
string[]

Filter for specific price levels by their QuickBooks-assigned unique identifier(s).

IMPORTANT: If you include this parameter, QuickBooks will ignore all other query parameters for this request.

NOTE: If any of the values you specify in this parameter are not found, the request will return an error.

Example:
["80000001-1234567890"]
names
string[]

Filter for specific price levels by their name(s), case-insensitive. Like id, name is a unique identifier for a price level.

IMPORTANT: If you include this parameter, QuickBooks will ignore all other query parameters for this request.

NOTE: If any of the values you specify in this parameter are not found, the request will return an error.

Example:
["Wholesale 20% Discount"]
limit
integer

The maximum number of objects to return.

IMPORTANT: QuickBooks Desktop does not support cursor-based pagination for price levels. This parameter will limit the response size, but you cannot fetch subsequent results using a cursor. For pagination, use the name-range parameters instead (e.g., nameFrom=A&nameTo=B).

When this parameter is omitted, the endpoint returns all price levels without limit, unlike paginated endpoints which default to 150 records. This is acceptable because price levels typically have low record counts.

Required range: x >= 1
Example:

10

status
enum<string>
default:active

Filter for price levels that are active, inactive, or both.

Available options:
active,
all,
inactive
Example:

"active"

updatedAfter
string

Filter for price levels updated on or after this date and time, in ISO 8601 format (YYYY-MM-DDTHH:mm:ss). If you only provide a date (YYYY-MM-DD), the time is assumed to be 00:00:00 of that day.

Example:

"2021-01-01T12:34:56.000Z"

updatedBefore
string

Filter for price levels updated on or before this date and time, in ISO 8601 format (YYYY-MM-DDTHH:mm:ss). If you only provide a date (YYYY-MM-DD), the time is assumed to be 23:59:59 of that day.

Example:

"2021-02-01T12:34:56.000Z"

nameContains
string

Filter for price levels whose name contains this substring, case-insensitive. NOTE: If you use this parameter, you cannot also use nameStartsWith or nameEndsWith.

Example:

"ABC"

nameStartsWith
string

Filter for price levels whose name starts with this substring, case-insensitive. NOTE: If you use this parameter, you cannot also use nameContains or nameEndsWith.

Example:

"ABC"

nameEndsWith
string

Filter for price levels whose name ends with this substring, case-insensitive. NOTE: If you use this parameter, you cannot also use nameContains or nameStartsWith.

Example:

"ABC"

nameFrom
string

Filter for price levels whose name is alphabetically greater than or equal to this value.

Example:

"A"

nameTo
string

Filter for price levels whose name is alphabetically less than or equal to this value.

Example:

"Z"

itemIds
string[]

Filter for price levels containing these items.

Example:
["80000001-1234567890"]
currencyIds
string[]

Filter for price levels in these currencies.

Example:
["80000001-1234567890"]

Response

200 - application/json
Returns a list of price levels.
objectType
string
required

The type of object. This value is always "list".

Allowed value: "list"
Example:

"list"

url
string
required

The endpoint URL where this list can be accessed.

Example:

"/v1/quickbooks-desktop/price-levels"

data
object[]
required

The array of price levels.