conductor-node 8.6.6 → 9.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -17,7 +17,7 @@ Execute _any_ read or write [QuickBooks Desktop API](https://developer.intuit.co
17
17
  ## Requirements
18
18
 
19
19
  1. A Conductor API key from Danny.
20
- 2. A running version of QuickBooks Desktop connected to Conductor. See our [guide to connecting QuickBooks Desktop to Conductor](https://www.notion.so/conductor-io/QBWC-Setup-Connect-QBD-to-Conductor-with-QB-Web-Connector-fb01b86f938e445ead178e3a1a994d78).
20
+ 2. A running version of QuickBooks Desktop connected to Conductor. See our [guide to connecting QuickBooks Desktop to Conductor](https://conductor-io.notion.site/QuickBooks-Desktop-integration-setup-86f6325f747d4447b95d27b59ad89ef5).
21
21
 
22
22
  ## Installation
23
23
 
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "conductor-node",
3
- "version": "8.6.6",
3
+ "version": "9.0.1",
4
4
  "description": "Easily integrate with the entire QuickBooks Desktop API with fully-typed async TypeScript",
5
5
  "author": "Danny Nemer <hi@DannyNemer.com>",
6
6
  "license": "MIT",
@@ -16,10 +16,11 @@
16
16
  "delete-compiled-tests": "rm -rf `find ./dist -type d -name __tests__` ./dist/src/utils/testing.*",
17
17
  "postpack": "rm -rf dist",
18
18
  "clean": "rm -rf dist package conductor-node-*.tgz tsconfig.tsbuildinfo",
19
- "gen:graphql": "yarn graphql-codegen --config ./src/graphql/codegenConfig.ts",
19
+ "gen:graphql": "yarn graphql-codegen --config=./src/graphql/codegenConfig.ts",
20
20
  "diff": "yarn pack && npm diff --diff=conductor-node@latest --diff=conductor-node-v$(node -p \"require('./package.json').version\").tgz && yarn clean",
21
21
  "prepublishOnly": "yarn test",
22
- "test": "yarn --cwd ../.. test ./packages/client"
22
+ "test": "yarn --cwd=../../ test ./packages/client",
23
+ "jest": "yarn --cwd=../../ jest"
23
24
  },
24
25
  "engines": {
25
26
  "node": ">=16"
@@ -1,4 +1,4 @@
1
- import type { GraphqlCreateIntegrationConnectionInput, GraphqlCreateIntegrationConnectionMutation, GraphqlGetConnectionStatusQuery, GraphqlGetConnectionStatusQueryVariables, GraphqlGetIntegrationConnectionQuery, GraphqlGetIntegrationConnectionQueryVariables, GraphqlGetIntegrationConnectionsQuery, GraphqlPingIntegrationConnectionMutation, GraphqlPingIntegrationConnectionMutationVariables } from "./graphql/__generated__/operationTypes";
1
+ import type { GraphqlCreateIntegrationConnectionInput, GraphqlCreateIntegrationConnectionMutation, GraphqlGetIntegrationConnectionQuery, GraphqlGetIntegrationConnectionQueryVariables, GraphqlGetIntegrationConnectionsQuery, GraphqlPingIntegrationConnectionMutation, GraphqlPingIntegrationConnectionMutationVariables } from "./graphql/__generated__/operationTypes";
2
2
  import QbdIntegration from "./integrations/qbd/QbdIntegration";
3
3
  import { getServerUrlForEnvironment } from "./utils";
4
4
  export interface ClientOptions {
@@ -25,25 +25,6 @@ export default class Client {
25
25
  * @returns The integration-connections.
26
26
  */
27
27
  getIntegrationConnections(): Promise<GraphqlGetIntegrationConnectionsQuery["integrationConnections"]>;
28
- /**
29
- * Checks whether we can successfully connect to the end-user's QBD instance.
30
- *
31
- * Unlike `lastHeartbeatAt`, which only checks if QBWC is running (i.e., is
32
- * the user's computer on), this check fails if the user's computer is on but
33
- * QBD is not running, the wrong company file is open, or there is a modal
34
- * dialog open in QBD.
35
- *
36
- * @param integrationConnectionId The ID of the integration-connection.
37
- * @returns The result object with the following properties:
38
- * - isConnected: Whether we can connect to the end-user's QBD.
39
- * - error: If `isConnected=false`, this will be an object with the following
40
- * properties:
41
- * - error.code - The unique error code.
42
- * - error.developerMessage - The technical error message for the developer.
43
- * - error.endUserMessage - The user-friendly error message to display to
44
- * the the end-user.
45
- */
46
- getConnectionStatus(integrationConnectionId: GraphqlGetConnectionStatusQueryVariables["integrationConnectionId"]): Promise<GraphqlGetConnectionStatusQuery["integrationConnection"]["connectionStatus"]>;
47
28
  /**
48
29
  * Creates a new integration-connection.
49
30
  *
@@ -41,29 +41,6 @@ class Client {
41
41
  .getIntegrationConnections()
42
42
  .then((result) => result.integrationConnections);
43
43
  }
44
- /**
45
- * Checks whether we can successfully connect to the end-user's QBD instance.
46
- *
47
- * Unlike `lastHeartbeatAt`, which only checks if QBWC is running (i.e., is
48
- * the user's computer on), this check fails if the user's computer is on but
49
- * QBD is not running, the wrong company file is open, or there is a modal
50
- * dialog open in QBD.
51
- *
52
- * @param integrationConnectionId The ID of the integration-connection.
53
- * @returns The result object with the following properties:
54
- * - isConnected: Whether we can connect to the end-user's QBD.
55
- * - error: If `isConnected=false`, this will be an object with the following
56
- * properties:
57
- * - error.code - The unique error code.
58
- * - error.developerMessage - The technical error message for the developer.
59
- * - error.endUserMessage - The user-friendly error message to display to
60
- * the the end-user.
61
- */
62
- async getConnectionStatus(integrationConnectionId) {
63
- return this.graphqlOperations
64
- .getConnectionStatus({ integrationConnectionId })
65
- .then((result) => result.integrationConnection.connectionStatus);
66
- }
67
44
  /**
68
45
  * Creates a new integration-connection.
69
46
  *
@@ -10,7 +10,7 @@ export interface ConductorErrorOptions {
10
10
  /**
11
11
  * The raw GraphQL error that Conductor's API returns.
12
12
  */
13
- export interface ConductorRawGraphqlError {
13
+ export interface ConductorGraphqlError {
14
14
  readonly message: string;
15
15
  readonly extensions: Omit<ConductorErrorOptions, "httpStatusCode" | "message">;
16
16
  }
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.generateConductorErrorFromType = exports.ConductorUnknownError = exports.ConductorInternalError = exports.ConductorConnectionError = exports.ConductorAuthenticationError = exports.ConductorInvalidRequestError = exports.ConductorIntegrationError = exports.ConductorError = exports.DEFAULT_END_USER_MESSAGE = void 0;
4
4
  /* eslint-disable max-classes-per-file -- Use one module for all error classes. */
5
+ // Matches server-side default value.
5
6
  exports.DEFAULT_END_USER_MESSAGE = "An internal server error occurred. Please try again later.";
6
7
  /**
7
8
  * The base error from which all other more specific Conductor errors derive.
@@ -36,9 +36,6 @@ export type GraphqlSendIntegrationRequestInput = {
36
36
  integrationConnectionId: Scalars["ID"];
37
37
  requestObject: Scalars["JSONObject"];
38
38
  };
39
- export type GraphqlSetUpIntegrationConnectionInput = {
40
- integrationConnectionId: Scalars["ID"];
41
- };
42
39
  export type GraphqlIntegrationConnectionFragment = {
43
40
  id: string;
44
41
  integrationKey: string;
@@ -47,11 +44,6 @@ export type GraphqlIntegrationConnectionFragment = {
47
44
  endUserCompanyName: string;
48
45
  lastHeartbeatAt: Date | null;
49
46
  };
50
- export type GraphqlUserErrorFragment = {
51
- code: string;
52
- developerMessage: string;
53
- endUserMessage: string;
54
- };
55
47
  export type GraphqlGetIntegrationConnectionQueryVariables = Exact<{
56
48
  integrationConnectionId: Scalars["ID"];
57
49
  }>;
@@ -78,21 +70,6 @@ export type GraphqlGetIntegrationConnectionsQuery = {
78
70
  lastHeartbeatAt: Date | null;
79
71
  }>;
80
72
  };
81
- export type GraphqlGetConnectionStatusQueryVariables = Exact<{
82
- integrationConnectionId: Scalars["ID"];
83
- }>;
84
- export type GraphqlGetConnectionStatusQuery = {
85
- integrationConnection: {
86
- connectionStatus: {
87
- isConnected: boolean;
88
- error: {
89
- code: string;
90
- developerMessage: string;
91
- endUserMessage: string;
92
- } | null;
93
- };
94
- };
95
- };
96
73
  export type GraphqlCreateIntegrationConnectionMutationVariables = Exact<{
97
74
  input: GraphqlCreateIntegrationConnectionInput;
98
75
  }>;
@@ -125,10 +102,8 @@ export type GraphqlSendIntegrationRequestMutation = {
125
102
  };
126
103
  };
127
104
  export declare const IntegrationConnectionFragmentDoc = "\n fragment IntegrationConnection on IntegrationConnection {\n id\n integrationKey\n endUserSourceId\n endUserEmail\n endUserCompanyName\n lastHeartbeatAt\n}\n ";
128
- export declare const UserErrorFragmentDoc = "\n fragment UserError on UserError {\n code\n developerMessage\n endUserMessage\n}\n ";
129
105
  export declare const GetIntegrationConnectionDocument: string;
130
106
  export declare const GetIntegrationConnectionsDocument: string;
131
- export declare const GetConnectionStatusDocument: string;
132
107
  export declare const CreateIntegrationConnectionDocument: string;
133
108
  export declare const PingIntegrationConnectionDocument = "\n mutation pingIntegrationConnection($input: PingIntegrationConnectionInput!) {\n pingIntegrationConnection(input: $input) {\n duration\n }\n}\n ";
134
109
  export declare const SendIntegrationRequestDocument = "\n mutation sendIntegrationRequest($input: SendIntegrationRequestInput!) {\n sendIntegrationRequest(input: $input) {\n response\n }\n}\n ";
@@ -136,7 +111,6 @@ export type SdkFunctionWrapper = <T>(action: (requestHeaders?: Record<string, st
136
111
  export declare function getSdk(client: GraphQLClient, withWrapper?: SdkFunctionWrapper): {
137
112
  getIntegrationConnection(variables: GraphqlGetIntegrationConnectionQueryVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlGetIntegrationConnectionQuery>;
138
113
  getIntegrationConnections(variables?: GraphqlGetIntegrationConnectionsQueryVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlGetIntegrationConnectionsQuery>;
139
- getConnectionStatus(variables: GraphqlGetConnectionStatusQueryVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlGetConnectionStatusQuery>;
140
114
  createIntegrationConnection(variables: GraphqlCreateIntegrationConnectionMutationVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlCreateIntegrationConnectionMutation>;
141
115
  pingIntegrationConnection(variables: GraphqlPingIntegrationConnectionMutationVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlPingIntegrationConnectionMutation>;
142
116
  sendIntegrationRequest(variables: GraphqlSendIntegrationRequestMutationVariables, requestHeaders?: (Record<string, string> | Dom.Headers | string[][]) | undefined): Promise<GraphqlSendIntegrationRequestMutation>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getSdk = exports.SendIntegrationRequestDocument = exports.PingIntegrationConnectionDocument = exports.CreateIntegrationConnectionDocument = exports.GetConnectionStatusDocument = exports.GetIntegrationConnectionsDocument = exports.GetIntegrationConnectionDocument = exports.UserErrorFragmentDoc = exports.IntegrationConnectionFragmentDoc = void 0;
3
+ exports.getSdk = exports.SendIntegrationRequestDocument = exports.PingIntegrationConnectionDocument = exports.CreateIntegrationConnectionDocument = exports.GetIntegrationConnectionsDocument = exports.GetIntegrationConnectionDocument = exports.IntegrationConnectionFragmentDoc = void 0;
4
4
  exports.IntegrationConnectionFragmentDoc = `
5
5
  fragment IntegrationConnection on IntegrationConnection {
6
6
  id
@@ -11,13 +11,6 @@ exports.IntegrationConnectionFragmentDoc = `
11
11
  lastHeartbeatAt
12
12
  }
13
13
  `;
14
- exports.UserErrorFragmentDoc = `
15
- fragment UserError on UserError {
16
- code
17
- developerMessage
18
- endUserMessage
19
- }
20
- `;
21
14
  exports.GetIntegrationConnectionDocument = `
22
15
  query getIntegrationConnection($integrationConnectionId: ID!) {
23
16
  integrationConnection(id: $integrationConnectionId) {
@@ -32,18 +25,6 @@ exports.GetIntegrationConnectionsDocument = `
32
25
  }
33
26
  }
34
27
  ${exports.IntegrationConnectionFragmentDoc}`;
35
- exports.GetConnectionStatusDocument = `
36
- query getConnectionStatus($integrationConnectionId: ID!) {
37
- integrationConnection(id: $integrationConnectionId) {
38
- connectionStatus {
39
- isConnected
40
- error {
41
- ...UserError
42
- }
43
- }
44
- }
45
- }
46
- ${exports.UserErrorFragmentDoc}`;
47
28
  exports.CreateIntegrationConnectionDocument = `
48
29
  mutation createIntegrationConnection($input: CreateIntegrationConnectionInput!) {
49
30
  createIntegrationConnection(input: $input) {
@@ -76,9 +57,6 @@ function getSdk(client, withWrapper = defaultWrapper) {
76
57
  getIntegrationConnections(variables, requestHeaders) {
77
58
  return withWrapper((wrappedRequestHeaders) => client.request(exports.GetIntegrationConnectionsDocument, variables, { ...requestHeaders, ...wrappedRequestHeaders }), "getIntegrationConnections", "query");
78
59
  },
79
- getConnectionStatus(variables, requestHeaders) {
80
- return withWrapper((wrappedRequestHeaders) => client.request(exports.GetConnectionStatusDocument, variables, { ...requestHeaders, ...wrappedRequestHeaders }), "getConnectionStatus", "query");
81
- },
82
60
  createIntegrationConnection(variables, requestHeaders) {
83
61
  return withWrapper((wrappedRequestHeaders) => client.request(exports.CreateIntegrationConnectionDocument, variables, { ...requestHeaders, ...wrappedRequestHeaders }), "createIntegrationConnection", "mutation");
84
62
  },
@@ -944,5 +944,5 @@ export default class QbdIntegration extends BaseIntegration {
944
944
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop
945
945
  */
946
946
  sendRequest(integrationConnectionId: string, requestObject: object): Promise<object>;
947
- private sendRequestBase;
947
+ private sendRequestWrapper;
948
948
  }
@@ -3,6 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
+ const errors_1 = require("../../errors");
6
7
  const BaseIntegration_1 = __importDefault(require("../../integrations/BaseIntegration"));
7
8
  class QbdIntegration extends BaseIntegration_1.default {
8
9
  account = {
@@ -13,13 +14,13 @@ class QbdIntegration extends BaseIntegration_1.default {
13
14
  *
14
15
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/AccountAdd
15
16
  */
16
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { AccountAddRq: { AccountAdd: params } }, "AccountAddRs", "AccountRet"),
17
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { AccountAddRq: { AccountAdd: params } }, "AccountAddRs", "AccountRet"),
17
18
  /**
18
19
  * Modifies an account.
19
20
  *
20
21
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/AccountMod
21
22
  */
22
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { AccountModRq: { AccountMod: params } }, "AccountModRs", "AccountRet"),
23
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { AccountModRq: { AccountMod: params } }, "AccountModRs", "AccountRet"),
23
24
  /**
24
25
  * `AccountQuery` is a list query that returns data for all accounts that
25
26
  * match the provided filter criteria. Notice that it returns only data
@@ -30,7 +31,7 @@ class QbdIntegration extends BaseIntegration_1.default {
30
31
  *
31
32
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/AccountQuery
32
33
  */
33
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { AccountQueryRq: params }, "AccountQueryRs", "AccountRet"),
34
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { AccountQueryRq: params }, "AccountQueryRs", "AccountRet"),
34
35
  };
35
36
  bill = {
36
37
  /**
@@ -85,7 +86,7 @@ class QbdIntegration extends BaseIntegration_1.default {
85
86
  *
86
87
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillAdd
87
88
  */
88
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillAddRq: { BillAdd: params } }, "BillAddRs", "BillRet"),
89
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillAddRq: { BillAdd: params } }, "BillAddRs", "BillRet"),
89
90
  /**
90
91
  * Edit an existing Bill, similar to editing a Bill in the Enter Bills form
91
92
  * in the QuickBooks UI.
@@ -121,7 +122,7 @@ class QbdIntegration extends BaseIntegration_1.default {
121
122
  *
122
123
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillMod
123
124
  */
124
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillModRq: { BillMod: params } }, "BillModRs", "BillRet"),
125
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillModRq: { BillMod: params } }, "BillModRs", "BillRet"),
125
126
  /**
126
127
  * Provides functionality found in the Find/Advanced-Find window to find
127
128
  * bills that are to be paid by check. The Find/Advanced-Find windows can be
@@ -168,7 +169,7 @@ class QbdIntegration extends BaseIntegration_1.default {
168
169
  *
169
170
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillQuery
170
171
  */
171
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillQueryRq: params }, "BillQueryRs", "BillRet"),
172
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillQueryRq: params }, "BillQueryRs", "BillRet"),
172
173
  };
173
174
  billPaymentCheck = {
174
175
  /**
@@ -204,7 +205,7 @@ class QbdIntegration extends BaseIntegration_1.default {
204
205
  *
205
206
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillPaymentCheckAdd
206
207
  */
207
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillPaymentCheckAddRq: { BillPaymentCheckAdd: params } }, "BillPaymentCheckAddRs", "BillPaymentCheckRet"),
208
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillPaymentCheckAddRq: { BillPaymentCheckAdd: params } }, "BillPaymentCheckAddRs", "BillPaymentCheckRet"),
208
209
  /**
209
210
  * Modifies the specified bill payment check.
210
211
  *
@@ -251,7 +252,7 @@ class QbdIntegration extends BaseIntegration_1.default {
251
252
  *
252
253
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillPaymentCheckMod
253
254
  */
254
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillPaymentCheckModRq: { BillPaymentCheckMod: params } }, "BillPaymentCheckModRs", "BillPaymentCheckRet"),
255
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillPaymentCheckModRq: { BillPaymentCheckMod: params } }, "BillPaymentCheckModRs", "BillPaymentCheckRet"),
255
256
  /**
256
257
  * Provides functionality found in the Find/Advanced-Find window to find
257
258
  * bill payments paid by check. The Find/Advanced-Find windows can be
@@ -285,7 +286,7 @@ class QbdIntegration extends BaseIntegration_1.default {
285
286
  *
286
287
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/BillPaymentCheckQuery
287
288
  */
288
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { BillPaymentCheckQueryRq: params }, "BillPaymentCheckQueryRs", "BillPaymentCheckRet"),
289
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { BillPaymentCheckQueryRq: params }, "BillPaymentCheckQueryRs", "BillPaymentCheckRet"),
289
290
  };
290
291
  charge = {
291
292
  /**
@@ -295,7 +296,7 @@ class QbdIntegration extends BaseIntegration_1.default {
295
296
  *
296
297
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ChargeAdd
297
298
  */
298
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ChargeAddRq: { ChargeAdd: params } }, "ChargeAddRs", "ChargeRet"),
299
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ChargeAddRq: { ChargeAdd: params } }, "ChargeAddRs", "ChargeRet"),
299
300
  /**
300
301
  * Modifies the specified charge.
301
302
  *
@@ -313,13 +314,13 @@ class QbdIntegration extends BaseIntegration_1.default {
313
314
  *
314
315
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ChargeMod
315
316
  */
316
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ChargeModRq: { ChargeMod: params } }, "ChargeModRs", "ChargeRet"),
317
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ChargeModRq: { ChargeMod: params } }, "ChargeModRs", "ChargeRet"),
317
318
  /**
318
319
  * Returns information about statement charges.
319
320
  *
320
321
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ChargeQuery
321
322
  */
322
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ChargeQueryRq: params }, "ChargeQueryRs", "ChargeRet"),
323
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ChargeQueryRq: params }, "ChargeQueryRs", "ChargeRet"),
323
324
  };
324
325
  check = {
325
326
  /**
@@ -340,13 +341,13 @@ class QbdIntegration extends BaseIntegration_1.default {
340
341
  *
341
342
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CheckAdd
342
343
  */
343
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CheckAddRq: { CheckAdd: params } }, "CheckAddRs", "CheckRet"),
344
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CheckAddRq: { CheckAdd: params } }, "CheckAddRs", "CheckRet"),
344
345
  /**
345
346
  * Modifies an existing Check. Notice that you cannot use this to modify BillPaymentChecks.
346
347
  *
347
348
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CheckMod
348
349
  */
349
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CheckModRq: { CheckMod: params } }, "CheckModRs", "CheckRet"),
350
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CheckModRq: { CheckMod: params } }, "CheckModRs", "CheckRet"),
350
351
  /**
351
352
  * Returns certain types of checks based on the supplied query criteria.
352
353
  * Note that `BillPaymentChecks`, payroll checks, and liability checks are
@@ -354,7 +355,7 @@ class QbdIntegration extends BaseIntegration_1.default {
354
355
  *
355
356
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CheckQuery
356
357
  */
357
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CheckQueryRq: params }, "CheckQueryRs", "CheckRet"),
358
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CheckQueryRq: params }, "CheckQueryRs", "CheckRet"),
358
359
  };
359
360
  class = {
360
361
  /**
@@ -376,19 +377,19 @@ class QbdIntegration extends BaseIntegration_1.default {
376
377
  *
377
378
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ClassAdd
378
379
  */
379
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ClassAddRq: { ClassAdd: params } }, "ClassAddRs", "ClassRet"),
380
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ClassAddRq: { ClassAdd: params } }, "ClassAddRs", "ClassRet"),
380
381
  /**
381
382
  * Modifies the specified class.
382
383
  *
383
384
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ClassMod
384
385
  */
385
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ClassModRq: { ClassMod: params } }, "ClassModRs", "ClassRet"),
386
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ClassModRq: { ClassMod: params } }, "ClassModRs", "ClassRet"),
386
387
  /**
387
388
  * Queries for existing classes.
388
389
  *
389
390
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ClassQuery
390
391
  */
391
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ClassQueryRq: params }, "ClassQueryRs", "ClassRet"),
392
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ClassQueryRq: params }, "ClassQueryRs", "ClassRet"),
392
393
  };
393
394
  company = {
394
395
  /**
@@ -402,7 +403,7 @@ class QbdIntegration extends BaseIntegration_1.default {
402
403
  *
403
404
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CompanyQuery
404
405
  */
405
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CompanyQueryRq: params }, "CompanyQueryRs", "CompanyRet"),
406
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CompanyQueryRq: params }, "CompanyQueryRs", "CompanyRet"),
406
407
  };
407
408
  customer = {
408
409
  /**
@@ -427,13 +428,13 @@ class QbdIntegration extends BaseIntegration_1.default {
427
428
  *
428
429
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CustomerAdd
429
430
  */
430
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CustomerAddRq: { CustomerAdd: params } }, "CustomerAddRs", "CustomerRet"),
431
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CustomerAddRq: { CustomerAdd: params } }, "CustomerAddRs", "CustomerRet"),
431
432
  /**
432
433
  * Modifies the customer record.
433
434
  *
434
435
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CustomerMod
435
436
  */
436
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CustomerModRq: { CustomerMod: params } }, "CustomerModRs", "CustomerRet"),
437
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CustomerModRq: { CustomerMod: params } }, "CustomerModRs", "CustomerRet"),
437
438
  /**
438
439
  * Returns data for the specified customers.
439
440
  *
@@ -446,7 +447,7 @@ class QbdIntegration extends BaseIntegration_1.default {
446
447
  *
447
448
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/CustomerQuery
448
449
  */
449
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { CustomerQueryRq: params }, "CustomerQueryRs", "CustomerRet"),
450
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { CustomerQueryRq: params }, "CustomerQueryRs", "CustomerRet"),
450
451
  };
451
452
  deposit = {
452
453
  /**
@@ -457,19 +458,19 @@ class QbdIntegration extends BaseIntegration_1.default {
457
458
  *
458
459
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/DepositAdd
459
460
  */
460
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { DepositAddRq: { DepositAdd: params } }, "DepositAddRs", "DepositRet"),
461
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { DepositAddRq: { DepositAdd: params } }, "DepositAddRs", "DepositRet"),
461
462
  /**
462
463
  * Modifies an existing deposit.
463
464
  *
464
465
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/DepositMod
465
466
  */
466
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { DepositModRq: { DepositMod: params } }, "DepositModRs", "DepositRet"),
467
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { DepositModRq: { DepositMod: params } }, "DepositModRs", "DepositRet"),
467
468
  /**
468
469
  * This request searches for deposits that match the supplied filters.
469
470
  *
470
471
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/DepositQuery
471
472
  */
472
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { DepositQueryRq: params }, "DepositQueryRs", "DepositRet"),
473
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { DepositQueryRq: params }, "DepositQueryRs", "DepositRet"),
473
474
  };
474
475
  employee = {
475
476
  /**
@@ -478,19 +479,19 @@ class QbdIntegration extends BaseIntegration_1.default {
478
479
  *
479
480
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EmployeeAdd
480
481
  */
481
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EmployeeAddRq: { EmployeeAdd: params } }, "EmployeeAddRs", "EmployeeRet"),
482
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EmployeeAddRq: { EmployeeAdd: params } }, "EmployeeAddRs", "EmployeeRet"),
482
483
  /**
483
484
  * Modifies an existing employee.
484
485
  *
485
486
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EmployeeMod
486
487
  */
487
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EmployeeModRq: { EmployeeMod: params } }, "EmployeeModRs", "EmployeeRet"),
488
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EmployeeModRq: { EmployeeMod: params } }, "EmployeeModRs", "EmployeeRet"),
488
489
  /**
489
490
  * Returns employee data.
490
491
  *
491
492
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EmployeeQuery
492
493
  */
493
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EmployeeQueryRq: params }, "EmployeeQueryRs", "EmployeeRet"),
494
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EmployeeQueryRq: params }, "EmployeeQueryRs", "EmployeeRet"),
494
495
  };
495
496
  estimate = {
496
497
  /**
@@ -505,7 +506,7 @@ class QbdIntegration extends BaseIntegration_1.default {
505
506
  *
506
507
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EstimateAdd
507
508
  */
508
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EstimateAddRq: { EstimateAdd: params } }, "EstimateAddRs", "EstimateRet"),
509
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EstimateAddRq: { EstimateAdd: params } }, "EstimateAddRs", "EstimateRet"),
509
510
  /**
510
511
  * Modifies the specified estimate.
511
512
  *
@@ -530,13 +531,13 @@ class QbdIntegration extends BaseIntegration_1.default {
530
531
  *
531
532
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EstimateMod
532
533
  */
533
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EstimateModRq: { EstimateMod: params } }, "EstimateModRs", "EstimateRet"),
534
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EstimateModRq: { EstimateMod: params } }, "EstimateModRs", "EstimateRet"),
534
535
  /**
535
536
  * Queries for the specified estimate or set of estimates.
536
537
  *
537
538
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/EstimateQuery
538
539
  */
539
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { EstimateQueryRq: params }, "EstimateQueryRs", "EstimateRet"),
540
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { EstimateQueryRq: params }, "EstimateQueryRs", "EstimateRet"),
540
541
  };
541
542
  invoice = {
542
543
  /**
@@ -562,7 +563,7 @@ class QbdIntegration extends BaseIntegration_1.default {
562
563
  *
563
564
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/InvoiceAdd
564
565
  */
565
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { InvoiceAddRq: { InvoiceAdd: params } }, "InvoiceAddRs", "InvoiceRet"),
566
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { InvoiceAddRq: { InvoiceAdd: params } }, "InvoiceAddRs", "InvoiceRet"),
566
567
  /**
567
568
  * Modifies an existing invoice. If you are modifying existing line items,
568
569
  * supply an `InvoiceLineMod` and `TxnLineID` for each line you want to
@@ -592,13 +593,13 @@ class QbdIntegration extends BaseIntegration_1.default {
592
593
  *
593
594
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/InvoiceMod
594
595
  */
595
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { InvoiceModRq: { InvoiceMod: params } }, "InvoiceModRs", "InvoiceRet"),
596
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { InvoiceModRq: { InvoiceMod: params } }, "InvoiceModRs", "InvoiceRet"),
596
597
  /**
597
598
  * Returns invoice data.
598
599
  *
599
600
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/InvoiceQuery
600
601
  */
601
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { InvoiceQueryRq: params }, "InvoiceQueryRs", "InvoiceRet"),
602
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { InvoiceQueryRq: params }, "InvoiceQueryRs", "InvoiceRet"),
602
603
  };
603
604
  itemInventory = {
604
605
  /**
@@ -615,13 +616,13 @@ class QbdIntegration extends BaseIntegration_1.default {
615
616
  *
616
617
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemInventoryAdd
617
618
  */
618
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemInventoryAddRq: { ItemInventoryAdd: params } }, "ItemInventoryAddRs", "ItemInventoryRet"),
619
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemInventoryAddRq: { ItemInventoryAdd: params } }, "ItemInventoryAddRs", "ItemInventoryRet"),
619
620
  /**
620
621
  * Modifies an inventory item.
621
622
  *
622
623
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemInventoryMod
623
624
  */
624
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemInventoryModRq: { ItemInventoryMod: params } }, "ItemInventoryModRs", "ItemInventoryRet"),
625
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemInventoryModRq: { ItemInventoryMod: params } }, "ItemInventoryModRs", "ItemInventoryRet"),
625
626
  /**
626
627
  * Queries for the specified inventory item or set of items.
627
628
  *
@@ -645,7 +646,7 @@ class QbdIntegration extends BaseIntegration_1.default {
645
646
  *
646
647
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemInventoryQuery
647
648
  */
648
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemInventoryQueryRq: params }, "ItemInventoryQueryRs", "ItemInventoryRet"),
649
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemInventoryQueryRq: params }, "ItemInventoryQueryRs", "ItemInventoryRet"),
649
650
  };
650
651
  itemNonInventory = {
651
652
  /**
@@ -659,7 +660,7 @@ class QbdIntegration extends BaseIntegration_1.default {
659
660
  *
660
661
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemNonInventoryAdd
661
662
  */
662
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemNonInventoryAddRq: { ItemNonInventoryAdd: params } }, "ItemNonInventoryAddRs", "ItemNonInventoryRet"),
663
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemNonInventoryAddRq: { ItemNonInventoryAdd: params } }, "ItemNonInventoryAddRs", "ItemNonInventoryRet"),
663
664
  /**
664
665
  * Modifies a non inventory item.
665
666
  *
@@ -689,13 +690,13 @@ class QbdIntegration extends BaseIntegration_1.default {
689
690
  *
690
691
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemNonInventoryMod
691
692
  */
692
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemNonInventoryModRq: { ItemNonInventoryMod: params } }, "ItemNonInventoryModRs", "ItemNonInventoryRet"),
693
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemNonInventoryModRq: { ItemNonInventoryMod: params } }, "ItemNonInventoryModRs", "ItemNonInventoryRet"),
693
694
  /**
694
695
  * Queries for the specified non-inventory item or set of items.
695
696
  *
696
697
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemNonInventoryQuery
697
698
  */
698
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemNonInventoryQueryRq: params }, "ItemNonInventoryQueryRs", "ItemNonInventoryRet"),
699
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemNonInventoryQueryRq: params }, "ItemNonInventoryQueryRs", "ItemNonInventoryRet"),
699
700
  };
700
701
  itemService = {
701
702
  /**
@@ -712,7 +713,7 @@ class QbdIntegration extends BaseIntegration_1.default {
712
713
  * `ItemServiceRef` and `CustomerRef`.
713
714
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemServiceAdd
714
715
  */
715
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemServiceAddRq: { ItemServiceAdd: params } }, "ItemServiceAddRs", "ItemServiceRet"),
716
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemServiceAddRq: { ItemServiceAdd: params } }, "ItemServiceAddRs", "ItemServiceRet"),
716
717
  /**
717
718
  * Modifies an existing service item.
718
719
  *
@@ -744,13 +745,13 @@ class QbdIntegration extends BaseIntegration_1.default {
744
745
  *
745
746
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemServiceMod
746
747
  */
747
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemServiceModRq: { ItemServiceMod: params } }, "ItemServiceModRs", "ItemServiceRet"),
748
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemServiceModRq: { ItemServiceMod: params } }, "ItemServiceModRs", "ItemServiceRet"),
748
749
  /**
749
750
  * Queries for the specified service item or set of items.
750
751
  *
751
752
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/ItemServiceQuery
752
753
  */
753
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { ItemServiceQueryRq: params }, "ItemServiceQueryRs", "ItemServiceRet"),
754
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { ItemServiceQueryRq: params }, "ItemServiceQueryRs", "ItemServiceRet"),
754
755
  };
755
756
  journalEntry = {
756
757
  /**
@@ -784,7 +785,7 @@ class QbdIntegration extends BaseIntegration_1.default {
784
785
  *
785
786
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/JournalEntryAdd
786
787
  */
787
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { JournalEntryAddRq: { JournalEntryAdd: params } }, "JournalEntryAddRs", "JournalEntryRet"),
788
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { JournalEntryAddRq: { JournalEntryAdd: params } }, "JournalEntryAddRs", "JournalEntryRet"),
788
789
  /**
789
790
  * Modifies a journal entry.
790
791
  *
@@ -794,7 +795,7 @@ class QbdIntegration extends BaseIntegration_1.default {
794
795
  *
795
796
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/JournalEntryMod
796
797
  */
797
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { JournalEntryModRq: { JournalEntryMod: params } }, "JournalEntryModRs", "JournalEntryRet"),
798
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { JournalEntryModRq: { JournalEntryMod: params } }, "JournalEntryModRs", "JournalEntryRet"),
798
799
  /**
799
800
  * In traditional accounting, transactions are entered into the general
800
801
  * journal and categorized exclusively by account. In QuickBooks, most
@@ -819,7 +820,7 @@ class QbdIntegration extends BaseIntegration_1.default {
819
820
  *
820
821
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/JournalEntryQuery
821
822
  */
822
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { JournalEntryQueryRq: params }, "JournalEntryQueryRs", "JournalEntryRet"),
823
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { JournalEntryQueryRq: params }, "JournalEntryQueryRs", "JournalEntryRet"),
823
824
  };
824
825
  timeTracking = {
825
826
  /**
@@ -832,7 +833,7 @@ class QbdIntegration extends BaseIntegration_1.default {
832
833
  *
833
834
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/TimeTrackingQuery
834
835
  */
835
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { TimeTrackingAddRq: { TimeTrackingAdd: params } }, "TimeTrackingAddRs", "TimeTrackingRet"),
836
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { TimeTrackingAddRq: { TimeTrackingAdd: params } }, "TimeTrackingAddRs", "TimeTrackingRet"),
836
837
  /**
837
838
  * Modifies a time tracking transaction.
838
839
  *
@@ -859,7 +860,7 @@ class QbdIntegration extends BaseIntegration_1.default {
859
860
  *
860
861
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/TimeTrackingMod
861
862
  */
862
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { TimeTrackingModRq: { TimeTrackingMod: params } }, "TimeTrackingModRs", "TimeTrackingRet"),
863
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { TimeTrackingModRq: { TimeTrackingMod: params } }, "TimeTrackingModRs", "TimeTrackingRet"),
863
864
  /**
864
865
  * The time-tracking transactions that are returned in this query include
865
866
  * time tracking information that was entered into QuickBooks manually or
@@ -870,7 +871,7 @@ class QbdIntegration extends BaseIntegration_1.default {
870
871
  *
871
872
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/TimeTrackingQuery
872
873
  */
873
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { TimeTrackingQueryRq: params }, "TimeTrackingQueryRs", "TimeTrackingRet"),
874
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { TimeTrackingQueryRq: params }, "TimeTrackingQueryRs", "TimeTrackingRet"),
874
875
  };
875
876
  purchaseOrder = {
876
877
  /**
@@ -881,7 +882,7 @@ class QbdIntegration extends BaseIntegration_1.default {
881
882
  *
882
883
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/PurchaseOrderQuery
883
884
  */
884
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { PurchaseOrderAddRq: { PurchaseOrderAdd: params } }, "PurchaseOrderAddRs", "PurchaseOrderRet"),
885
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { PurchaseOrderAddRq: { PurchaseOrderAdd: params } }, "PurchaseOrderAddRs", "PurchaseOrderRet"),
885
886
  /**
886
887
  * Modifies a purchase order.
887
888
  *
@@ -905,13 +906,13 @@ class QbdIntegration extends BaseIntegration_1.default {
905
906
  *
906
907
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/PurchaseOrderMod
907
908
  */
908
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { PurchaseOrderModRq: { PurchaseOrderMod: params } }, "PurchaseOrderModRs", "PurchaseOrderRet"),
909
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { PurchaseOrderModRq: { PurchaseOrderMod: params } }, "PurchaseOrderModRs", "PurchaseOrderRet"),
909
910
  /**
910
911
  * Queries for the specified purchase order or set of orders.
911
912
  *
912
913
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/PurchaseOrderQuery
913
914
  */
914
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { PurchaseOrderQueryRq: params }, "PurchaseOrderQueryRs", "PurchaseOrderRet"),
915
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { PurchaseOrderQueryRq: params }, "PurchaseOrderQueryRs", "PurchaseOrderRet"),
915
916
  };
916
917
  vendor = {
917
918
  /**
@@ -927,19 +928,19 @@ class QbdIntegration extends BaseIntegration_1.default {
927
928
  *
928
929
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/VendorAdd
929
930
  */
930
- add: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { VendorAddRq: { VendorAdd: params } }, "VendorAddRs", "VendorRet"),
931
+ add: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { VendorAddRq: { VendorAdd: params } }, "VendorAddRs", "VendorRet"),
931
932
  /**
932
933
  * Modifies a vendor.
933
934
  *
934
935
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/VendorMod
935
936
  */
936
- mod: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { VendorModRq: { VendorMod: params } }, "VendorModRs", "VendorRet"),
937
+ mod: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { VendorModRq: { VendorMod: params } }, "VendorModRs", "VendorRet"),
937
938
  /**
938
939
  * Queries for the specified vendor or set of vendors.
939
940
  *
940
941
  * https://developer.intuit.com/app/developer/qbdesktop/docs/api-reference/qbdesktop/VendorQuery
941
942
  */
942
- query: async (integrationConnectionId, params) => this.sendRequestBase(integrationConnectionId, { VendorQueryRq: params }, "VendorQueryRs", "VendorRet"),
943
+ query: async (integrationConnectionId, params) => this.sendRequestWrapper(integrationConnectionId, { VendorQueryRq: params }, "VendorQueryRs", "VendorRet"),
943
944
  };
944
945
  /**
945
946
  * Send any QBXML request to QuickBooks Desktop.
@@ -953,11 +954,15 @@ class QbdIntegration extends BaseIntegration_1.default {
953
954
  requestObject,
954
955
  });
955
956
  }
956
- async sendRequestBase(integrationConnectionId, params, responseKey, responseBodyKey) {
957
+ async sendRequestWrapper(integrationConnectionId, params, responseKey, responseBodyKey) {
957
958
  const response = (await this.sendRequest(integrationConnectionId, params));
958
959
  const responseBody = response[responseKey]?.[responseBodyKey];
959
960
  if (responseBody === undefined) {
960
- throw new Error("No response");
961
+ throw new errors_1.ConductorIntegrationError({
962
+ message: "No response received from QuickBooks Desktop.",
963
+ endUserMessage: "No response received from QuickBooks Desktop.",
964
+ code: "QBD_NO_RESPONSE",
965
+ });
961
966
  }
962
967
  return responseBody;
963
968
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "conductor-node",
3
- "version": "8.6.6",
3
+ "version": "9.0.1",
4
4
  "description": "Easily integrate with the entire QuickBooks Desktop API with fully-typed async TypeScript",
5
5
  "author": "Danny Nemer <hi@DannyNemer.com>",
6
6
  "license": "MIT",
@@ -16,10 +16,11 @@
16
16
  "delete-compiled-tests": "rm -rf `find ./dist -type d -name __tests__` ./dist/src/utils/testing.*",
17
17
  "postpack": "rm -rf dist",
18
18
  "clean": "rm -rf dist package conductor-node-*.tgz tsconfig.tsbuildinfo",
19
- "gen:graphql": "yarn graphql-codegen --config ./src/graphql/codegenConfig.ts",
19
+ "gen:graphql": "yarn graphql-codegen --config=./src/graphql/codegenConfig.ts",
20
20
  "diff": "yarn pack && npm diff --diff=conductor-node@latest --diff=conductor-node-v$(node -p \"require('./package.json').version\").tgz && yarn clean",
21
21
  "prepublishOnly": "yarn test",
22
- "test": "yarn --cwd ../.. test ./packages/client"
22
+ "test": "yarn --cwd=../../ test ./packages/client",
23
+ "jest": "yarn --cwd=../../ jest"
23
24
  },
24
25
  "engines": {
25
26
  "node": ">=16"