@things-factory/integration-accounting 9.0.0-beta.27 → 9.0.0-beta.29

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.
Files changed (191) hide show
  1. package/dist-server/controllers/accounting-api/decorators.d.ts +1 -0
  2. package/dist-server/controllers/accounting-api/decorators.js +33 -0
  3. package/dist-server/controllers/accounting-api/decorators.js.map +1 -0
  4. package/dist-server/controllers/accounting-api/index.d.ts +25 -0
  5. package/dist-server/controllers/accounting-api/index.js +124 -0
  6. package/dist-server/controllers/accounting-api/index.js.map +1 -0
  7. package/dist-server/controllers/index.d.ts +2 -0
  8. package/dist-server/controllers/index.js +6 -0
  9. package/dist-server/controllers/index.js.map +1 -0
  10. package/dist-server/controllers/xero/apis/contact/get-contact.d.ts +19 -0
  11. package/dist-server/controllers/xero/apis/contact/get-contact.js +32 -0
  12. package/dist-server/controllers/xero/apis/contact/get-contact.js.map +1 -0
  13. package/dist-server/controllers/xero/apis/contact/get-contacts.d.ts +8 -0
  14. package/dist-server/controllers/xero/apis/contact/get-contacts.js +18 -0
  15. package/dist-server/controllers/xero/apis/contact/get-contacts.js.map +1 -0
  16. package/dist-server/controllers/xero/apis/contact/index.d.ts +2 -0
  17. package/dist-server/controllers/xero/apis/contact/index.js +6 -0
  18. package/dist-server/controllers/xero/apis/contact/index.js.map +1 -0
  19. package/dist-server/controllers/xero/apis/index.d.ts +4 -0
  20. package/dist-server/controllers/xero/apis/index.js +8 -0
  21. package/dist-server/controllers/xero/apis/index.js.map +1 -0
  22. package/dist-server/controllers/xero/apis/invoice/create-invoice.d.ts +6 -0
  23. package/dist-server/controllers/xero/apis/invoice/create-invoice.js +16 -0
  24. package/dist-server/controllers/xero/apis/invoice/create-invoice.js.map +1 -0
  25. package/dist-server/controllers/xero/apis/invoice/get-invoice.d.ts +10 -0
  26. package/dist-server/controllers/xero/apis/invoice/get-invoice.js +18 -0
  27. package/dist-server/controllers/xero/apis/invoice/get-invoice.js.map +1 -0
  28. package/dist-server/controllers/xero/apis/invoice/get-invoices.d.ts +10 -0
  29. package/dist-server/controllers/xero/apis/invoice/get-invoices.js +59 -0
  30. package/dist-server/controllers/xero/apis/invoice/get-invoices.js.map +1 -0
  31. package/dist-server/controllers/xero/apis/invoice/index.d.ts +4 -0
  32. package/dist-server/controllers/xero/apis/invoice/index.js +8 -0
  33. package/dist-server/controllers/xero/apis/invoice/index.js.map +1 -0
  34. package/dist-server/controllers/xero/apis/invoice/update-invoice.d.ts +6 -0
  35. package/dist-server/controllers/xero/apis/invoice/update-invoice.js +16 -0
  36. package/dist-server/controllers/xero/apis/invoice/update-invoice.js.map +1 -0
  37. package/dist-server/controllers/xero/apis/item/create-item.d.ts +16 -0
  38. package/dist-server/controllers/xero/apis/item/create-item.js +32 -0
  39. package/dist-server/controllers/xero/apis/item/create-item.js.map +1 -0
  40. package/dist-server/controllers/xero/apis/item/delete-item.d.ts +11 -0
  41. package/dist-server/controllers/xero/apis/item/delete-item.js +21 -0
  42. package/dist-server/controllers/xero/apis/item/delete-item.js.map +1 -0
  43. package/dist-server/controllers/xero/apis/item/get-item.d.ts +10 -0
  44. package/dist-server/controllers/xero/apis/item/get-item.js +34 -0
  45. package/dist-server/controllers/xero/apis/item/get-item.js.map +1 -0
  46. package/dist-server/controllers/xero/apis/item/get-items.d.ts +8 -0
  47. package/dist-server/controllers/xero/apis/item/get-items.js +32 -0
  48. package/dist-server/controllers/xero/apis/item/get-items.js.map +1 -0
  49. package/dist-server/controllers/xero/apis/item/index.d.ts +6 -0
  50. package/dist-server/controllers/xero/apis/item/index.js +10 -0
  51. package/dist-server/controllers/xero/apis/item/index.js.map +1 -0
  52. package/dist-server/controllers/xero/apis/item/update-item.d.ts +14 -0
  53. package/dist-server/controllers/xero/apis/item/update-item.js +30 -0
  54. package/dist-server/controllers/xero/apis/item/update-item.js.map +1 -0
  55. package/dist-server/controllers/xero/apis/item/update-items.d.ts +10 -0
  56. package/dist-server/controllers/xero/apis/item/update-items.js +36 -0
  57. package/dist-server/controllers/xero/apis/item/update-items.js.map +1 -0
  58. package/dist-server/controllers/xero/apis/purchase-order/get-purchase-orders.d.ts +8 -0
  59. package/dist-server/controllers/xero/apis/purchase-order/get-purchase-orders.js +56 -0
  60. package/dist-server/controllers/xero/apis/purchase-order/get-purchase-orders.js.map +1 -0
  61. package/dist-server/controllers/xero/apis/purchase-order/index.d.ts +1 -0
  62. package/dist-server/controllers/xero/apis/purchase-order/index.js +5 -0
  63. package/dist-server/controllers/xero/apis/purchase-order/index.js.map +1 -0
  64. package/dist-server/controllers/xero/index.d.ts +1 -0
  65. package/dist-server/controllers/xero/index.js +9 -0
  66. package/dist-server/controllers/xero/index.js.map +1 -0
  67. package/dist-server/controllers/xero/platform-action.d.ts +6 -0
  68. package/dist-server/controllers/xero/platform-action.js +49 -0
  69. package/dist-server/controllers/xero/platform-action.js.map +1 -0
  70. package/dist-server/controllers/xero/xero.d.ts +18 -0
  71. package/dist-server/controllers/xero/xero.js +155 -0
  72. package/dist-server/controllers/xero/xero.js.map +1 -0
  73. package/dist-server/engine/connector/accounting-connector.d.ts +8 -0
  74. package/dist-server/engine/connector/accounting-connector.js +28 -0
  75. package/dist-server/engine/connector/accounting-connector.js.map +1 -0
  76. package/dist-server/engine/connector/index.d.ts +1 -0
  77. package/dist-server/engine/connector/index.js +4 -0
  78. package/dist-server/engine/connector/index.js.map +1 -0
  79. package/dist-server/engine/index.d.ts +2 -0
  80. package/dist-server/engine/index.js +5 -0
  81. package/dist-server/engine/index.js.map +1 -0
  82. package/dist-server/engine/task/accounting-api.d.ts +1 -0
  83. package/dist-server/engine/task/accounting-api.js +54 -0
  84. package/dist-server/engine/task/accounting-api.js.map +1 -0
  85. package/dist-server/engine/task/index.d.ts +1 -0
  86. package/dist-server/engine/task/index.js +4 -0
  87. package/dist-server/engine/task/index.js.map +1 -0
  88. package/dist-server/entities/account.d.ts +23 -0
  89. package/dist-server/entities/account.js +113 -0
  90. package/dist-server/entities/account.js.map +1 -0
  91. package/dist-server/entities/index.d.ts +3 -0
  92. package/dist-server/entities/index.js +7 -0
  93. package/dist-server/entities/index.js.map +1 -0
  94. package/dist-server/graphql/index.d.ts +6 -0
  95. package/dist-server/graphql/index.js +11 -0
  96. package/dist-server/graphql/index.js.map +1 -0
  97. package/dist-server/graphql/resolvers/accounting/account.d.ts +6 -0
  98. package/dist-server/graphql/resolvers/accounting/account.js +15 -0
  99. package/dist-server/graphql/resolvers/accounting/account.js.map +1 -0
  100. package/dist-server/graphql/resolvers/accounting/accounts.d.ts +8 -0
  101. package/dist-server/graphql/resolvers/accounting/accounts.js +14 -0
  102. package/dist-server/graphql/resolvers/accounting/accounts.js.map +1 -0
  103. package/dist-server/graphql/resolvers/accounting/create-account.d.ts +5 -0
  104. package/dist-server/graphql/resolvers/accounting/create-account.js +13 -0
  105. package/dist-server/graphql/resolvers/accounting/create-account.js.map +1 -0
  106. package/dist-server/graphql/resolvers/accounting/delete-account.d.ts +5 -0
  107. package/dist-server/graphql/resolvers/accounting/delete-account.js +16 -0
  108. package/dist-server/graphql/resolvers/accounting/delete-account.js.map +1 -0
  109. package/dist-server/graphql/resolvers/accounting/delete-accounts.d.ts +5 -0
  110. package/dist-server/graphql/resolvers/accounting/delete-accounts.js +20 -0
  111. package/dist-server/graphql/resolvers/accounting/delete-accounts.js.map +1 -0
  112. package/dist-server/graphql/resolvers/accounting/index.d.ts +25 -0
  113. package/dist-server/graphql/resolvers/accounting/index.js +15 -0
  114. package/dist-server/graphql/resolvers/accounting/index.js.map +1 -0
  115. package/dist-server/graphql/resolvers/accounting/update-account.d.ts +6 -0
  116. package/dist-server/graphql/resolvers/accounting/update-account.js +15 -0
  117. package/dist-server/graphql/resolvers/accounting/update-account.js.map +1 -0
  118. package/dist-server/graphql/resolvers/accounting/update-multiple-accounts.d.ts +5 -0
  119. package/dist-server/graphql/resolvers/accounting/update-multiple-accounts.js +30 -0
  120. package/dist-server/graphql/resolvers/accounting/update-multiple-accounts.js.map +1 -0
  121. package/dist-server/graphql/resolvers/accounting/xero/deactivate-xero-account.d.ts +5 -0
  122. package/dist-server/graphql/resolvers/accounting/xero/deactivate-xero-account.js +51 -0
  123. package/dist-server/graphql/resolvers/accounting/xero/deactivate-xero-account.js.map +1 -0
  124. package/dist-server/graphql/resolvers/accounting/xero/get-xero-auth-url.d.ts +6 -0
  125. package/dist-server/graphql/resolvers/accounting/xero/get-xero-auth-url.js +31 -0
  126. package/dist-server/graphql/resolvers/accounting/xero/get-xero-auth-url.js.map +1 -0
  127. package/dist-server/graphql/resolvers/accounting/xero/index.d.ts +13 -0
  128. package/dist-server/graphql/resolvers/accounting/xero/index.js +9 -0
  129. package/dist-server/graphql/resolvers/accounting/xero/index.js.map +1 -0
  130. package/dist-server/graphql/resolvers/accounting/xero/refresh-xero-access-token.d.ts +5 -0
  131. package/dist-server/graphql/resolvers/accounting/xero/refresh-xero-access-token.js +51 -0
  132. package/dist-server/graphql/resolvers/accounting/xero/refresh-xero-access-token.js.map +1 -0
  133. package/dist-server/graphql/resolvers/accounting-api/accounting-invoice.d.ts +20 -0
  134. package/dist-server/graphql/resolvers/accounting-api/accounting-invoice.js +32 -0
  135. package/dist-server/graphql/resolvers/accounting-api/accounting-invoice.js.map +1 -0
  136. package/dist-server/graphql/resolvers/accounting-api/accounting-item.d.ts +24 -0
  137. package/dist-server/graphql/resolvers/accounting-api/accounting-item.js +36 -0
  138. package/dist-server/graphql/resolvers/accounting-api/accounting-item.js.map +1 -0
  139. package/dist-server/graphql/resolvers/accounting-api/accounting-purchase-order.d.ts +6 -0
  140. package/dist-server/graphql/resolvers/accounting-api/accounting-purchase-order.js +16 -0
  141. package/dist-server/graphql/resolvers/accounting-api/accounting-purchase-order.js.map +1 -0
  142. package/dist-server/graphql/resolvers/accounting-api/index.d.ts +44 -0
  143. package/dist-server/graphql/resolvers/accounting-api/index.js +9 -0
  144. package/dist-server/graphql/resolvers/accounting-api/index.js.map +1 -0
  145. package/dist-server/graphql/resolvers/index.d.ts +25 -0
  146. package/dist-server/graphql/resolvers/index.js +8 -0
  147. package/dist-server/graphql/resolvers/index.js.map +1 -0
  148. package/dist-server/graphql/types/accounting/account-list.d.ts +1 -0
  149. package/dist-server/graphql/types/accounting/account-list.js +12 -0
  150. package/dist-server/graphql/types/accounting/account-list.js.map +1 -0
  151. package/dist-server/graphql/types/accounting/account-patch.d.ts +1 -0
  152. package/dist-server/graphql/types/accounting/account-patch.js +18 -0
  153. package/dist-server/graphql/types/accounting/account-patch.js.map +1 -0
  154. package/dist-server/graphql/types/accounting/account.d.ts +1 -0
  155. package/dist-server/graphql/types/accounting/account.js +29 -0
  156. package/dist-server/graphql/types/accounting/account.js.map +1 -0
  157. package/dist-server/graphql/types/accounting/index.d.ts +3 -0
  158. package/dist-server/graphql/types/accounting/index.js +45 -0
  159. package/dist-server/graphql/types/accounting/index.js.map +1 -0
  160. package/dist-server/graphql/types/accounting/new-account.d.ts +1 -0
  161. package/dist-server/graphql/types/accounting/new-account.js +16 -0
  162. package/dist-server/graphql/types/accounting/new-account.js.map +1 -0
  163. package/dist-server/graphql/types/accounting-api/invoice.d.ts +3 -0
  164. package/dist-server/graphql/types/accounting-api/invoice.js +63 -0
  165. package/dist-server/graphql/types/accounting-api/invoice.js.map +1 -0
  166. package/dist-server/graphql/types/accounting-api/item.d.ts +3 -0
  167. package/dist-server/graphql/types/accounting-api/item.js +63 -0
  168. package/dist-server/graphql/types/accounting-api/item.js.map +1 -0
  169. package/dist-server/graphql/types/accounting-api/purchase-order.d.ts +2 -0
  170. package/dist-server/graphql/types/accounting-api/purchase-order.js +34 -0
  171. package/dist-server/graphql/types/accounting-api/purchase-order.js.map +1 -0
  172. package/dist-server/graphql/types/index.d.ts +3 -0
  173. package/dist-server/graphql/types/index.js +12 -0
  174. package/dist-server/graphql/types/index.js.map +1 -0
  175. package/dist-server/index.d.ts +6 -0
  176. package/dist-server/index.js +11 -0
  177. package/dist-server/index.js.map +1 -0
  178. package/dist-server/migrations/index.d.ts +1 -0
  179. package/dist-server/migrations/index.js +12 -0
  180. package/dist-server/migrations/index.js.map +1 -0
  181. package/dist-server/routers/xero-private-router.d.ts +1 -0
  182. package/dist-server/routers/xero-private-router.js +17 -0
  183. package/dist-server/routers/xero-private-router.js.map +1 -0
  184. package/dist-server/routers/xero-router.d.ts +1 -0
  185. package/dist-server/routers/xero-router.js +109 -0
  186. package/dist-server/routers/xero-router.js.map +1 -0
  187. package/dist-server/routes.d.ts +1 -0
  188. package/dist-server/routes.js +11 -0
  189. package/dist-server/routes.js.map +1 -0
  190. package/dist-server/tsconfig.tsbuildinfo +1 -0
  191. package/package.json +13 -13
@@ -0,0 +1,8 @@
1
+ import { Connector } from '@things-factory/integration-base';
2
+ export declare class AccountingConnector implements Connector {
3
+ ready(connectionConfigs: any): Promise<void>;
4
+ connect(connection: any): Promise<void>;
5
+ disconnect(connection: any): Promise<void>;
6
+ get parameterSpec(): any[];
7
+ get taskPrefixes(): string[];
8
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccountingConnector = void 0;
4
+ const integration_base_1 = require("@things-factory/integration-base");
5
+ class AccountingConnector {
6
+ async ready(connectionConfigs) {
7
+ await Promise.all(connectionConfigs.map(this.connect));
8
+ integration_base_1.ConnectionManager.logger.info('accounting-connector connections are ready');
9
+ }
10
+ async connect(connection) {
11
+ const { domain, name, endpoint } = connection;
12
+ integration_base_1.ConnectionManager.addConnectionInstance(connection, Object.assign({}, connection));
13
+ integration_base_1.ConnectionManager.logger.info(`accounting-connector connection(${name}:${connection.endpoint}) is connected`);
14
+ }
15
+ async disconnect(connection) {
16
+ integration_base_1.ConnectionManager.removeConnectionInstance(connection);
17
+ integration_base_1.ConnectionManager.logger.info(`accounting-connector connection(${connection.name}) is disconnected`);
18
+ }
19
+ get parameterSpec() {
20
+ return [];
21
+ }
22
+ get taskPrefixes() {
23
+ return ['accounting'];
24
+ }
25
+ }
26
+ exports.AccountingConnector = AccountingConnector;
27
+ integration_base_1.ConnectionManager.registerConnector('accounting-connector', new AccountingConnector());
28
+ //# sourceMappingURL=accounting-connector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"accounting-connector.js","sourceRoot":"","sources":["../../../server/engine/connector/accounting-connector.ts"],"names":[],"mappings":";;;AAAA,uEAA+E;AAE/E,MAAa,mBAAmB;IAC9B,KAAK,CAAC,KAAK,CAAC,iBAAiB;QAC3B,MAAM,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;QAEtD,oCAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAA;IAC7E,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,UAAU;QACtB,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAA;QAE7C,oCAAiB,CAAC,qBAAqB,CAAC,UAAU,oBAAO,UAAU,EAAG,CAAA;QAEtE,oCAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,mCAAmC,IAAI,IAAI,UAAU,CAAC,QAAQ,gBAAgB,CAAC,CAAA;IAC/G,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,UAAU;QACzB,oCAAiB,CAAC,wBAAwB,CAAC,UAAU,CAAC,CAAA;QAEtD,oCAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,mCAAmC,UAAU,CAAC,IAAI,mBAAmB,CAAC,CAAA;IACtG,CAAC;IAED,IAAI,aAAa;QACf,OAAO,EAAE,CAAA;IACX,CAAC;IAED,IAAI,YAAY;QACd,OAAO,CAAC,YAAY,CAAC,CAAA;IACvB,CAAC;CACF;AA5BD,kDA4BC;AAED,oCAAiB,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,IAAI,mBAAmB,EAAE,CAAC,CAAA","sourcesContent":["import { ConnectionManager, Connector } from '@things-factory/integration-base'\n\nexport class AccountingConnector implements Connector {\n async ready(connectionConfigs) {\n await Promise.all(connectionConfigs.map(this.connect))\n\n ConnectionManager.logger.info('accounting-connector connections are ready')\n }\n\n async connect(connection) {\n const { domain, name, endpoint } = connection\n\n ConnectionManager.addConnectionInstance(connection, { ...connection })\n\n ConnectionManager.logger.info(`accounting-connector connection(${name}:${connection.endpoint}) is connected`)\n }\n\n async disconnect(connection) {\n ConnectionManager.removeConnectionInstance(connection)\n\n ConnectionManager.logger.info(`accounting-connector connection(${connection.name}) is disconnected`)\n }\n\n get parameterSpec() {\n return []\n }\n\n get taskPrefixes() {\n return ['accounting']\n }\n}\n\nConnectionManager.registerConnector('accounting-connector', new AccountingConnector())\n"]}
@@ -0,0 +1 @@
1
+ import './accounting-connector';
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./accounting-connector");
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/engine/connector/index.ts"],"names":[],"mappings":";;AAAA,kCAA+B","sourcesContent":["import './accounting-connector'\n"]}
@@ -0,0 +1,2 @@
1
+ import './connector/index.js';
2
+ import './task/index.js';
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./connector/index.js");
4
+ require("./task/index.js");
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/engine/index.ts"],"names":[],"mappings":";;AAAA,gCAA6B;AAC7B,2BAAwB","sourcesContent":["import './connector/index.js'\nimport './task/index.js'\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const integration_base_1 = require("@things-factory/integration-base");
4
+ const shell_1 = require("@things-factory/shell");
5
+ const utils_1 = require("@things-factory/utils");
6
+ const accounting_api_1 = require("../../controllers/accounting-api");
7
+ const entities_1 = require("../../entities");
8
+ async function AccountingAPI(step, { logger, data, domain }) {
9
+ var { connection, params: { account: name, api, accessor } } = step;
10
+ var client = integration_base_1.ConnectionManager.getConnectionInstanceByName(domain, connection) || {};
11
+ if (!client) {
12
+ throw new Error(`no connection : ${connection}`);
13
+ }
14
+ if (!api) {
15
+ throw new Error(`no api defined`);
16
+ }
17
+ const repository = (0, shell_1.getRepository)(entities_1.Account);
18
+ const account = await repository.findOne({
19
+ where: { domain: { id: domain.id }, name }
20
+ });
21
+ if (!account) {
22
+ throw new Error(`no account defined`);
23
+ }
24
+ var result = await accounting_api_1.AccountingAPI[api](account, accessor ? (0, utils_1.access)(accessor, data) : {});
25
+ return {
26
+ data: result
27
+ };
28
+ }
29
+ AccountingAPI.parameterSpec = [
30
+ {
31
+ type: 'entity-selector',
32
+ name: 'account',
33
+ label: 'account',
34
+ property: {
35
+ queryName: 'accounts',
36
+ valueKey: 'name'
37
+ }
38
+ },
39
+ {
40
+ type: 'select',
41
+ name: 'api',
42
+ label: 'api',
43
+ property: {
44
+ options: ['', 'getAccountingInvoices']
45
+ }
46
+ },
47
+ {
48
+ type: 'string',
49
+ name: 'accessor',
50
+ label: 'accessor'
51
+ }
52
+ ];
53
+ integration_base_1.TaskRegistry.registerTaskHandler('accounting-api', AccountingAPI);
54
+ //# sourceMappingURL=accounting-api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"accounting-api.js","sourceRoot":"","sources":["../../../server/engine/task/accounting-api.ts"],"names":[],"mappings":";;AAAA,uEAAkF;AAClF,iDAAqD;AACrD,iDAA8C;AAE9C,qEAAuE;AACvE,6CAAwC;AAExC,KAAK,UAAU,aAAa,CAAC,IAAI,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE;IACzD,IAAI,EACF,UAAU,EACV,MAAM,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,EACzC,GAAG,IAAI,CAAA;IAER,IAAI,MAAM,GAAG,oCAAiB,CAAC,2BAA2B,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,EAAE,CAAA;IACpF,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,mBAAmB,UAAU,EAAE,CAAC,CAAA;IAClD,CAAC;IAED,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAA;IACnC,CAAC;IAED,MAAM,UAAU,GAAG,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAA;IACzC,MAAM,OAAO,GAAY,MAAM,UAAU,CAAC,OAAO,CAAC;QAChD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE;KAC3C,CAAC,CAAA;IAEF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;IACvC,CAAC;IAED,IAAI,MAAM,GAAG,MAAM,8BAAG,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAA,cAAM,EAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;IAE5E,OAAO;QACL,IAAI,EAAE,MAAM;KACb,CAAA;AACH,CAAC;AAED,aAAa,CAAC,aAAa,GAAG;IAC5B;QACE,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,SAAS;QAChB,QAAQ,EAAE;YACR,SAAS,EAAE,UAAU;YACrB,QAAQ,EAAE,MAAM;SACjB;KACF;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,KAAK;QACZ,QAAQ,EAAE;YACR,OAAO,EAAE,CAAC,EAAE,EAAE,uBAAuB,CAAC;SACvC;KACF;IACD;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,UAAU;KAClB;CACF,CAAA;AAED,+BAAY,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAA","sourcesContent":["import { ConnectionManager, TaskRegistry } from '@things-factory/integration-base'\nimport { getRepository } from '@things-factory/shell'\nimport { access } from '@things-factory/utils'\n\nimport { AccountingAPI as API } from '../../controllers/accounting-api'\nimport { Account } from '../../entities'\n\nasync function AccountingAPI(step, { logger, data, domain }) {\n var {\n connection,\n params: { account: name, api, accessor }\n } = step\n\n var client = ConnectionManager.getConnectionInstanceByName(domain, connection) || {}\n if (!client) {\n throw new Error(`no connection : ${connection}`)\n }\n\n if (!api) {\n throw new Error(`no api defined`)\n }\n\n const repository = getRepository(Account)\n const account: Account = await repository.findOne({\n where: { domain: { id: domain.id }, name }\n })\n\n if (!account) {\n throw new Error(`no account defined`)\n }\n\n var result = await API[api](account, accessor ? access(accessor, data) : {})\n\n return {\n data: result\n }\n}\n\nAccountingAPI.parameterSpec = [\n {\n type: 'entity-selector',\n name: 'account',\n label: 'account',\n property: {\n queryName: 'accounts',\n valueKey: 'name'\n }\n },\n {\n type: 'select',\n name: 'api',\n label: 'api',\n property: {\n options: ['', 'getAccountingInvoices']\n }\n },\n {\n type: 'string',\n name: 'accessor',\n label: 'accessor'\n }\n]\n\nTaskRegistry.registerTaskHandler('accounting-api', AccountingAPI)\n"]}
@@ -0,0 +1 @@
1
+ import './accounting-api';
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./accounting-api");
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/engine/task/index.ts"],"names":[],"mappings":";;AAAA,4BAAyB","sourcesContent":["import './accounting-api'\n"]}
@@ -0,0 +1,23 @@
1
+ import { User } from '@things-factory/auth-base';
2
+ import { Domain } from '@things-factory/shell';
3
+ export declare class Account {
4
+ id: string;
5
+ domain: Domain;
6
+ platform: string;
7
+ accountId: string;
8
+ countryCode: string;
9
+ status: string;
10
+ name: string;
11
+ accessInfo: string;
12
+ accessToken: string;
13
+ trackedInventory: Boolean;
14
+ refreshToken: string;
15
+ expiresIn: Date;
16
+ tokenType: string;
17
+ accountInfo: string;
18
+ description: string;
19
+ createdAt: Date;
20
+ updatedAt: Date;
21
+ creator: User;
22
+ updater: User;
23
+ }
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Account = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const auth_base_1 = require("@things-factory/auth-base");
6
+ const shell_1 = require("@things-factory/shell");
7
+ const typeorm_1 = require("typeorm");
8
+ let Account = class Account {
9
+ };
10
+ exports.Account = Account;
11
+ tslib_1.__decorate([
12
+ (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
13
+ tslib_1.__metadata("design:type", String)
14
+ ], Account.prototype, "id", void 0);
15
+ tslib_1.__decorate([
16
+ (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
17
+ tslib_1.__metadata("design:type", shell_1.Domain)
18
+ ], Account.prototype, "domain", void 0);
19
+ tslib_1.__decorate([
20
+ (0, typeorm_1.Column)(),
21
+ tslib_1.__metadata("design:type", String)
22
+ ], Account.prototype, "platform", void 0);
23
+ tslib_1.__decorate([
24
+ (0, typeorm_1.Column)({
25
+ nullable: true
26
+ }),
27
+ tslib_1.__metadata("design:type", String)
28
+ ], Account.prototype, "accountId", void 0);
29
+ tslib_1.__decorate([
30
+ (0, typeorm_1.Column)(),
31
+ tslib_1.__metadata("design:type", String)
32
+ ], Account.prototype, "countryCode", void 0);
33
+ tslib_1.__decorate([
34
+ (0, typeorm_1.Column)({
35
+ nullable: true
36
+ }),
37
+ tslib_1.__metadata("design:type", String)
38
+ ], Account.prototype, "status", void 0);
39
+ tslib_1.__decorate([
40
+ (0, typeorm_1.Column)(),
41
+ tslib_1.__metadata("design:type", String)
42
+ ], Account.prototype, "name", void 0);
43
+ tslib_1.__decorate([
44
+ (0, typeorm_1.Column)({
45
+ nullable: true
46
+ }),
47
+ tslib_1.__metadata("design:type", String)
48
+ ], Account.prototype, "accessInfo", void 0);
49
+ tslib_1.__decorate([
50
+ (0, typeorm_1.Column)({
51
+ nullable: true
52
+ }),
53
+ tslib_1.__metadata("design:type", String)
54
+ ], Account.prototype, "accessToken", void 0);
55
+ tslib_1.__decorate([
56
+ (0, typeorm_1.Column)({ default: false, nullable: true }),
57
+ tslib_1.__metadata("design:type", Boolean)
58
+ ], Account.prototype, "trackedInventory", void 0);
59
+ tslib_1.__decorate([
60
+ (0, typeorm_1.Column)({
61
+ nullable: true
62
+ }),
63
+ tslib_1.__metadata("design:type", String)
64
+ ], Account.prototype, "refreshToken", void 0);
65
+ tslib_1.__decorate([
66
+ (0, typeorm_1.Column)({
67
+ nullable: true
68
+ }),
69
+ tslib_1.__metadata("design:type", Date)
70
+ ], Account.prototype, "expiresIn", void 0);
71
+ tslib_1.__decorate([
72
+ (0, typeorm_1.Column)({
73
+ nullable: true
74
+ }),
75
+ tslib_1.__metadata("design:type", String)
76
+ ], Account.prototype, "tokenType", void 0);
77
+ tslib_1.__decorate([
78
+ (0, typeorm_1.Column)({
79
+ nullable: true
80
+ }),
81
+ tslib_1.__metadata("design:type", String)
82
+ ], Account.prototype, "accountInfo", void 0);
83
+ tslib_1.__decorate([
84
+ (0, typeorm_1.Column)({
85
+ nullable: true
86
+ }),
87
+ tslib_1.__metadata("design:type", String)
88
+ ], Account.prototype, "description", void 0);
89
+ tslib_1.__decorate([
90
+ (0, typeorm_1.CreateDateColumn)(),
91
+ tslib_1.__metadata("design:type", Date)
92
+ ], Account.prototype, "createdAt", void 0);
93
+ tslib_1.__decorate([
94
+ (0, typeorm_1.UpdateDateColumn)(),
95
+ tslib_1.__metadata("design:type", Date)
96
+ ], Account.prototype, "updatedAt", void 0);
97
+ tslib_1.__decorate([
98
+ (0, typeorm_1.ManyToOne)(type => auth_base_1.User, {
99
+ nullable: true
100
+ }),
101
+ tslib_1.__metadata("design:type", auth_base_1.User)
102
+ ], Account.prototype, "creator", void 0);
103
+ tslib_1.__decorate([
104
+ (0, typeorm_1.ManyToOne)(type => auth_base_1.User, {
105
+ nullable: true
106
+ }),
107
+ tslib_1.__metadata("design:type", auth_base_1.User)
108
+ ], Account.prototype, "updater", void 0);
109
+ exports.Account = Account = tslib_1.__decorate([
110
+ (0, typeorm_1.Entity)(),
111
+ (0, typeorm_1.Index)('ix_account_0', (account) => [account.domain, account.name], { unique: true })
112
+ ], Account);
113
+ //# sourceMappingURL=account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account.js","sourceRoot":"","sources":["../../server/entities/account.ts"],"names":[],"mappings":";;;;AAAA,yDAAgD;AAChD,iDAA8C;AAC9C,qCAAsH;AAI/G,IAAM,OAAO,GAAb,MAAM,OAAO;CA+EnB,CAAA;AA/EY,0BAAO;AAElB;IADC,IAAA,gCAAsB,EAAC,MAAM,CAAC;;mCACrB;AAGV;IADC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;sCAClB,cAAM;uCAAA;AAGd;IADC,IAAA,gBAAM,GAAE;;yCACO;AAKhB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;0CACe;AAGjB;IADC,IAAA,gBAAM,GAAE;;4CACU;AAKnB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;uCACY;AAGd;IADC,IAAA,gBAAM,GAAE;;qCACG;AAKZ;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;2CACgB;AAKlB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;4CACiB;AAGnB;IADC,IAAA,gBAAM,EAAC,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACzB,OAAO;iDAAA;AAKzB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;6CACkB;AAKpB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;sCACS,IAAI;0CAAA;AAKf;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;0CACe;AAKjB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;4CACiB;AAKnB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;;4CACiB;AAGnB;IADC,IAAA,0BAAgB,GAAE;sCACR,IAAI;0CAAA;AAGf;IADC,IAAA,0BAAgB,GAAE;sCACR,IAAI;0CAAA;AAKf;IAHC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;sCACO,gBAAI;wCAAA;AAKb;IAHC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE;QACvB,QAAQ,EAAE,IAAI;KACf,CAAC;sCACO,gBAAI;wCAAA;kBA9EF,OAAO;IAFnB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,cAAc,EAAE,CAAC,OAAgB,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;GACjF,OAAO,CA+EnB","sourcesContent":["import { User } from '@things-factory/auth-base'\nimport { Domain } from '@things-factory/shell'\nimport { Column, CreateDateColumn, Entity, Index, ManyToOne, PrimaryGeneratedColumn, UpdateDateColumn } from 'typeorm'\n\n@Entity()\n@Index('ix_account_0', (account: Account) => [account.domain, account.name], { unique: true })\nexport class Account {\n @PrimaryGeneratedColumn('uuid')\n id: string\n\n @ManyToOne(type => Domain)\n domain: Domain\n\n @Column()\n platform: string\n\n @Column({\n nullable: true\n })\n accountId: string\n\n @Column()\n countryCode: string\n\n @Column({\n nullable: true\n })\n status: string\n\n @Column()\n name: string\n\n @Column({\n nullable: true\n })\n accessInfo: string\n\n @Column({\n nullable: true\n })\n accessToken: string\n\n @Column({ default: false, nullable: true })\n trackedInventory: Boolean\n\n @Column({\n nullable: true\n })\n refreshToken: string\n\n @Column({\n nullable: true\n })\n expiresIn: Date\n\n @Column({\n nullable: true\n })\n tokenType: string\n\n @Column({\n nullable: true\n })\n accountInfo: string\n\n @Column({\n nullable: true\n })\n description: string\n\n @CreateDateColumn()\n createdAt: Date\n\n @UpdateDateColumn()\n updatedAt: Date\n\n @ManyToOne(type => User, {\n nullable: true\n })\n creator: User\n\n @ManyToOne(type => User, {\n nullable: true\n })\n updater: User\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { Account } from './account';
2
+ export declare const entities: (typeof Account)[];
3
+ export { Account };
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Account = exports.entities = void 0;
4
+ const account_1 = require("./account");
5
+ Object.defineProperty(exports, "Account", { enumerable: true, get: function () { return account_1.Account; } });
6
+ exports.entities = [account_1.Account];
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/entities/index.ts"],"names":[],"mappings":";;;AAAA,uCAAmC;AAI1B,wFAJA,iBAAO,OAIA;AAFH,QAAA,QAAQ,GAAG,CAAC,iBAAO,CAAC,CAAA","sourcesContent":["import { Account } from './account'\n\nexport const entities = [Account]\n\nexport { Account }\n"]}
@@ -0,0 +1,6 @@
1
+ import * as typeDefs from './types';
2
+ import * as resolvers from './resolvers';
3
+ export declare const schema: {
4
+ typeDefs: typeof typeDefs;
5
+ resolvers: typeof resolvers;
6
+ };
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.schema = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const typeDefs = tslib_1.__importStar(require("./types"));
6
+ const resolvers = tslib_1.__importStar(require("./resolvers"));
7
+ exports.schema = {
8
+ typeDefs,
9
+ resolvers
10
+ };
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/graphql/index.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AACnC,+DAAwC;AAE3B,QAAA,MAAM,GAAG;IACpB,QAAQ;IACR,SAAS;CACV,CAAA","sourcesContent":["import * as typeDefs from './types'\nimport * as resolvers from './resolvers'\n\nexport const schema = {\n typeDefs,\n resolvers\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import { Account } from '../../../entities';
2
+ export declare const accountResolver: {
3
+ account(_: any, { id }: {
4
+ id: any;
5
+ }, context: ResolverContext): Promise<Account>;
6
+ };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.accountResolver = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const entities_1 = require("../../../entities");
6
+ exports.accountResolver = {
7
+ async account(_, { id }, context) {
8
+ const repository = (0, shell_1.getRepository)(entities_1.Account);
9
+ return await (0, shell_1.getRepository)(entities_1.Account).findOne({
10
+ where: { domain: { id: context.state.domain.id }, id },
11
+ relations: ['domain', 'creator', 'updater']
12
+ });
13
+ }
14
+ };
15
+ //# sourceMappingURL=account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/account.ts"],"names":[],"mappings":";;;AAAA,iDAAqD;AAErD,gDAA2C;AAE9B,QAAA,eAAe,GAAG;IAC7B,KAAK,CAAC,OAAO,CAAC,CAAM,EAAE,EAAE,EAAE,EAAE,EAAE,OAAwB;QACpD,MAAM,UAAU,GAAG,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAA;QAEzC,OAAO,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,OAAO,CAAC;YAC1C,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;YACtD,SAAS,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC;SAC5C,CAAC,CAAA;IACJ,CAAC;CACF,CAAA","sourcesContent":["import { getRepository } from '@things-factory/shell'\n\nimport { Account } from '../../../entities'\n\nexport const accountResolver = {\n async account(_: any, { id }, context: ResolverContext) {\n const repository = getRepository(Account)\n\n return await getRepository(Account).findOne({\n where: { domain: { id: context.state.domain.id }, id },\n relations: ['domain', 'creator', 'updater']\n })\n }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ import { ListParam } from '@things-factory/shell';
2
+ import { Account } from '../../../entities';
3
+ export declare const accountsResolver: {
4
+ accounts(_: any, params: ListParam, context: ResolverContext): Promise<{
5
+ items: Account[];
6
+ total: number;
7
+ }>;
8
+ };
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.accountsResolver = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const entities_1 = require("../../../entities");
6
+ exports.accountsResolver = {
7
+ async accounts(_, params, context) {
8
+ const { domain } = context.state;
9
+ const convertedParams = (0, shell_1.convertListParams)(params, { domain });
10
+ const [items, total] = await (0, shell_1.getRepository)(entities_1.Account).findAndCount(Object.assign(Object.assign({}, convertedParams), { relations: ['domain', 'creator', 'updater'] }));
11
+ return { items, total };
12
+ }
13
+ };
14
+ //# sourceMappingURL=accounts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"accounts.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/accounts.ts"],"names":[],"mappings":";;;AAAA,iDAAmF;AAEnF,gDAA2C;AAE9B,QAAA,gBAAgB,GAAG;IAC9B,KAAK,CAAC,QAAQ,CAAC,CAAM,EAAE,MAAiB,EAAE,OAAwB;QAChE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAChC,MAAM,eAAe,GAAG,IAAA,yBAAiB,EAAC,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAA;QAC7D,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,YAAY,iCAC3D,eAAe,KAClB,SAAS,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,CAAC,IAC3C,CAAA;QACF,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAA;IACzB,CAAC;CACF,CAAA","sourcesContent":["import { convertListParams, getRepository, ListParam } from '@things-factory/shell'\n\nimport { Account } from '../../../entities'\n\nexport const accountsResolver = {\n async accounts(_: any, params: ListParam, context: ResolverContext) {\n const { domain } = context.state\n const convertedParams = convertListParams(params, { domain })\n const [items, total] = await getRepository(Account).findAndCount({\n ...convertedParams,\n relations: ['domain', 'creator', 'updater']\n })\n return { items, total }\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export declare const createAccount: {
2
+ createAccount(_: any, { account }: {
3
+ account: any;
4
+ }, context: ResolverContext): Promise<any>;
5
+ };
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createAccount = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const controllers_1 = require("../../../controllers");
6
+ const entities_1 = require("../../../entities");
7
+ exports.createAccount = {
8
+ async createAccount(_, { account }, context) {
9
+ const { domain, user } = context.state;
10
+ return await (0, shell_1.getRepository)(entities_1.Account).save(Object.assign(Object.assign({ status: controllers_1.ACCOUNTING_STATUS.INACTIVE }, account), { domain, creator: user, updater: user }));
11
+ }
12
+ };
13
+ //# sourceMappingURL=create-account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-account.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/create-account.ts"],"names":[],"mappings":";;;AAAA,iDAAqD;AAErD,sDAAwD;AACxD,gDAA2C;AAE9B,QAAA,aAAa,GAAG;IAC3B,KAAK,CAAC,aAAa,CAAC,CAAM,EAAE,EAAE,OAAO,EAAE,EAAE,OAAwB;QAC/D,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEtC,OAAO,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,IAAI,+BACtC,MAAM,EAAE,+BAAiB,CAAC,QAAQ,IAC/B,OAAO,KACV,MAAM,EACN,OAAO,EAAE,IAAI,EACb,OAAO,EAAE,IAAI,IACb,CAAA;IACJ,CAAC;CACF,CAAA","sourcesContent":["import { getRepository } from '@things-factory/shell'\n\nimport { ACCOUNTING_STATUS } from '../../../controllers'\nimport { Account } from '../../../entities'\n\nexport const createAccount = {\n async createAccount(_: any, { account }, context: ResolverContext) {\n const { domain, user } = context.state\n\n return await getRepository(Account).save({\n status: ACCOUNTING_STATUS.INACTIVE,\n ...account,\n domain,\n creator: user,\n updater: user\n })\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export declare const deleteAccount: {
2
+ deleteAccount(_: any, { id }: {
3
+ id: any;
4
+ }, context: ResolverContext): Promise<boolean>;
5
+ };
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deleteAccount = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const controllers_1 = require("../../../controllers");
6
+ const entities_1 = require("../../../entities");
7
+ exports.deleteAccount = {
8
+ async deleteAccount(_, { id }, context) {
9
+ const foundAccount = await (0, shell_1.getRepository)(entities_1.Account).findOne({
10
+ where: { domain: { id: context.state.domain.id }, id }
11
+ });
12
+ await (0, shell_1.getRepository)(entities_1.Account).save(Object.assign(Object.assign({}, foundAccount), { status: controllers_1.ACCOUNTING_STATUS.TERMINATED, updater: context.state.user }));
13
+ return true;
14
+ }
15
+ };
16
+ //# sourceMappingURL=delete-account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete-account.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/delete-account.ts"],"names":[],"mappings":";;;AAAA,iDAAqD;AAErD,sDAAwD;AACxD,gDAA2C;AAE9B,QAAA,aAAa,GAAG;IAC3B,KAAK,CAAC,aAAa,CAAC,CAAM,EAAE,EAAE,EAAE,EAAE,EAAE,OAAwB;QAC1D,MAAM,YAAY,GAAY,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,OAAO,CAAC;YACjE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;SACvD,CAAC,CAAA;QAEF,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,IAAI,iCAC5B,YAAY,KACf,MAAM,EAAE,+BAAiB,CAAC,UAAU,EACpC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;QAEF,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA","sourcesContent":["import { getRepository } from '@things-factory/shell'\n\nimport { ACCOUNTING_STATUS } from '../../../controllers'\nimport { Account } from '../../../entities'\n\nexport const deleteAccount = {\n async deleteAccount(_: any, { id }, context: ResolverContext) {\n const foundAccount: Account = await getRepository(Account).findOne({\n where: { domain: { id: context.state.domain.id }, id }\n })\n\n await getRepository(Account).save({\n ...foundAccount,\n status: ACCOUNTING_STATUS.TERMINATED,\n updater: context.state.user\n })\n\n return true\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export declare const deleteAccounts: {
2
+ deleteAccounts(_: any, { ids }: {
3
+ ids: any;
4
+ }, context: ResolverContext): Promise<boolean>;
5
+ };
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.deleteAccounts = void 0;
4
+ const typeorm_1 = require("typeorm");
5
+ const shell_1 = require("@things-factory/shell");
6
+ const controllers_1 = require("../../../controllers");
7
+ const entities_1 = require("../../../entities");
8
+ exports.deleteAccounts = {
9
+ async deleteAccounts(_, { ids }, context) {
10
+ let foundAccounts = await (0, shell_1.getRepository)(entities_1.Account).find({
11
+ where: { domain: { id: context.state.domain.id }, id: (0, typeorm_1.In)(ids) }
12
+ });
13
+ const updatedAccount = foundAccounts.map((account) => {
14
+ return Object.assign(Object.assign({}, account), { status: controllers_1.ACCOUNTING_STATUS.TERMINATED, updater: context.state.user });
15
+ });
16
+ await (0, shell_1.getRepository)(entities_1.Account).save(updatedAccount);
17
+ return true;
18
+ }
19
+ };
20
+ //# sourceMappingURL=delete-accounts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete-accounts.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/delete-accounts.ts"],"names":[],"mappings":";;;AAAA,qCAA4B;AAE5B,iDAAqD;AAErD,sDAAwD;AACxD,gDAA2C;AAE9B,QAAA,cAAc,GAAG;IAC5B,KAAK,CAAC,cAAc,CAAC,CAAM,EAAE,EAAE,GAAG,EAAE,EAAE,OAAwB;QAC5D,IAAI,aAAa,GAAc,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,IAAI,CAAC;YAC/D,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,IAAA,YAAE,EAAC,GAAG,CAAC,EAAE;SAChE,CAAC,CAAA;QAEF,MAAM,cAAc,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,OAAgB,EAAE,EAAE;YAC5D,uCACK,OAAO,KACV,MAAM,EAAE,+BAAiB,CAAC,UAAU,EACpC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC5B;QACH,CAAC,CAAC,CAAA;QAEF,MAAM,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QACjD,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA","sourcesContent":["import { In } from 'typeorm'\n\nimport { getRepository } from '@things-factory/shell'\n\nimport { ACCOUNTING_STATUS } from '../../../controllers'\nimport { Account } from '../../../entities'\n\nexport const deleteAccounts = {\n async deleteAccounts(_: any, { ids }, context: ResolverContext) {\n let foundAccounts: Account[] = await getRepository(Account).find({\n where: { domain: { id: context.state.domain.id }, id: In(ids) }\n })\n\n const updatedAccount = foundAccounts.map((account: Account) => {\n return {\n ...account,\n status: ACCOUNTING_STATUS.TERMINATED,\n updater: context.state.user\n }\n })\n\n await getRepository(Account).save(updatedAccount)\n return true\n }\n}\n"]}
@@ -0,0 +1,25 @@
1
+ export declare const Query: any;
2
+ export declare const Mutation: {
3
+ deactivateXeroAccount(_: any, { id }: {
4
+ id: any;
5
+ }, context: ResolverContext): Promise<any>;
6
+ refreshXeroAccessToken(_: any, { id }: {
7
+ id: any;
8
+ }, context: ResolverContext): Promise<any>;
9
+ deleteAccounts(_: any, { ids }: {
10
+ ids: any;
11
+ }, context: ResolverContext): Promise<boolean>;
12
+ deleteAccount(_: any, { id }: {
13
+ id: any;
14
+ }, context: ResolverContext): Promise<boolean>;
15
+ createAccount(_: any, { account }: {
16
+ account: any;
17
+ }, context: ResolverContext): Promise<any>;
18
+ updateMultipleAccount(_: any, { patches }: {
19
+ patches: any;
20
+ }, context: ResolverContext): Promise<any[]>;
21
+ updateAccount(_: any, { name, patch }: {
22
+ name: any;
23
+ patch: any;
24
+ }, context: ResolverContext): Promise<any>;
25
+ };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Mutation = exports.Query = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const account_1 = require("./account");
6
+ const accounts_1 = require("./accounts");
7
+ const update_multiple_accounts_1 = require("./update-multiple-accounts");
8
+ const update_account_1 = require("./update-account");
9
+ const create_account_1 = require("./create-account");
10
+ const delete_account_1 = require("./delete-account");
11
+ const delete_accounts_1 = require("./delete-accounts");
12
+ const Xero = tslib_1.__importStar(require("./xero"));
13
+ exports.Query = Object.assign(Object.assign(Object.assign({}, accounts_1.accountsResolver), account_1.accountResolver), Xero.Query);
14
+ exports.Mutation = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, update_account_1.updateAccount), update_multiple_accounts_1.updateMultipleAccount), create_account_1.createAccount), delete_account_1.deleteAccount), delete_accounts_1.deleteAccounts), Xero.Mutation);
15
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/index.ts"],"names":[],"mappings":";;;;AAAA,uCAA2C;AAC3C,yCAA6C;AAE7C,yEAAkE;AAClE,qDAAgD;AAChD,qDAAgD;AAChD,qDAAgD;AAChD,uDAAkD;AAElD,qDAA8B;AAEjB,QAAA,KAAK,GAAG,8CAChB,2BAAgB,GAChB,yBAAe,GACf,IAAI,CAAC,KAAK,CACP,CAAA;AAEK,QAAA,QAAQ,2FAChB,8BAAa,GACb,gDAAqB,GACrB,8BAAa,GACb,8BAAa,GACb,gCAAc,GACd,IAAI,CAAC,QAAQ,EACjB","sourcesContent":["import { accountResolver } from './account'\nimport { accountsResolver } from './accounts'\n\nimport { updateMultipleAccount } from './update-multiple-accounts'\nimport { updateAccount } from './update-account'\nimport { createAccount } from './create-account'\nimport { deleteAccount } from './delete-account'\nimport { deleteAccounts } from './delete-accounts'\n\nimport * as Xero from './xero'\n\nexport const Query = {\n ...accountsResolver,\n ...accountResolver,\n ...Xero.Query\n} as any\n\nexport const Mutation = {\n ...updateAccount,\n ...updateMultipleAccount,\n ...createAccount,\n ...deleteAccount,\n ...deleteAccounts,\n ...Xero.Mutation\n}\n"]}
@@ -0,0 +1,6 @@
1
+ export declare const updateAccount: {
2
+ updateAccount(_: any, { name, patch }: {
3
+ name: any;
4
+ patch: any;
5
+ }, context: ResolverContext): Promise<any>;
6
+ };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.updateAccount = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const entities_1 = require("../../../entities");
6
+ exports.updateAccount = {
7
+ async updateAccount(_, { name, patch }, context) {
8
+ const repository = (0, shell_1.getRepository)(entities_1.Account);
9
+ const account = await repository.findOne({
10
+ where: { domain: { id: context.state.domain.id }, name }
11
+ });
12
+ return await repository.save(Object.assign(Object.assign(Object.assign({}, account), patch), { updater: context.state.user }));
13
+ }
14
+ };
15
+ //# sourceMappingURL=update-account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-account.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/update-account.ts"],"names":[],"mappings":";;;AAAA,iDAAqD;AAErD,gDAA2C;AAE9B,QAAA,aAAa,GAAG;IAC3B,KAAK,CAAC,aAAa,CAAC,CAAM,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,OAAwB;QACnE,MAAM,UAAU,GAAG,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAA;QACzC,MAAM,OAAO,GAAQ,MAAM,UAAU,CAAC,OAAO,CAAC;YAC5C,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE;SACzD,CAAC,CAAA;QAEF,OAAO,MAAM,UAAU,CAAC,IAAI,+CACvB,OAAO,GACP,KAAK,KACR,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;IACJ,CAAC;CACF,CAAA","sourcesContent":["import { getRepository } from '@things-factory/shell'\n\nimport { Account } from '../../../entities'\n\nexport const updateAccount = {\n async updateAccount(_: any, { name, patch }, context: ResolverContext) {\n const repository = getRepository(Account)\n const account: any = await repository.findOne({\n where: { domain: { id: context.state.domain.id }, name }\n })\n\n return await repository.save({\n ...account,\n ...patch,\n updater: context.state.user\n })\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export declare const updateMultipleAccount: {
2
+ updateMultipleAccount(_: any, { patches }: {
3
+ patches: any;
4
+ }, context: ResolverContext): Promise<any[]>;
5
+ };
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.updateMultipleAccount = void 0;
4
+ const shell_1 = require("@things-factory/shell");
5
+ const entities_1 = require("../../../entities");
6
+ exports.updateMultipleAccount = {
7
+ async updateMultipleAccount(_, { patches }, context) {
8
+ let results = [];
9
+ const _createRecords = patches.filter((patch) => patch.cuFlag.toUpperCase() === '+');
10
+ const _updateRecords = patches.filter((patch) => patch.cuFlag.toUpperCase() === 'M');
11
+ const accountRepo = (0, shell_1.getRepository)(entities_1.Account);
12
+ if (_createRecords.length > 0) {
13
+ for (let i = 0; i < _createRecords.length; i++) {
14
+ const newRecord = _createRecords[i];
15
+ const result = await accountRepo.save(Object.assign(Object.assign({}, newRecord), { domain: context.state.domain, creator: context.state.user, updater: context.state.user }));
16
+ results.push(Object.assign(Object.assign({}, result), { cuFlag: '+' }));
17
+ }
18
+ }
19
+ if (_updateRecords.length > 0) {
20
+ for (let i = 0; i < _updateRecords.length; i++) {
21
+ const newRecord = _updateRecords[i];
22
+ const account = await accountRepo.findOneBy({ id: newRecord.id });
23
+ const result = await accountRepo.save(Object.assign(Object.assign(Object.assign({}, account), newRecord), { updater: context.state.user }));
24
+ results.push(Object.assign(Object.assign({}, result), { cuFlag: 'M' }));
25
+ }
26
+ }
27
+ return results;
28
+ }
29
+ };
30
+ //# sourceMappingURL=update-multiple-accounts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-multiple-accounts.js","sourceRoot":"","sources":["../../../../server/graphql/resolvers/accounting/update-multiple-accounts.ts"],"names":[],"mappings":";;;AAAA,iDAAqD;AAErD,gDAA2C;AAE9B,QAAA,qBAAqB,GAAG;IACnC,KAAK,CAAC,qBAAqB,CAAC,CAAM,EAAE,EAAE,OAAO,EAAE,EAAE,OAAwB;QACvE,IAAI,OAAO,GAAG,EAAE,CAAA;QAChB,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAA;QACzF,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAA;QACzF,MAAM,WAAW,GAAG,IAAA,qBAAa,EAAC,kBAAO,CAAC,CAAA;QAE1C,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/C,MAAM,SAAS,GAAG,cAAc,CAAC,CAAC,CAAC,CAAA;gBAEnC,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,IAAI,iCAChC,SAAS,KACZ,MAAM,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,EAC5B,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,EAC3B,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;gBAEF,OAAO,CAAC,IAAI,iCAAM,MAAM,KAAE,MAAM,EAAE,GAAG,IAAG,CAAA;YAC1C,CAAC;QACH,CAAC;QAED,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC/C,MAAM,SAAS,GAAG,cAAc,CAAC,CAAC,CAAC,CAAA;gBACnC,MAAM,OAAO,GAAY,MAAM,WAAW,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,EAAE,CAAC,CAAA;gBAE1E,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,IAAI,+CAChC,OAAO,GACP,SAAS,KACZ,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,IAC3B,CAAA;gBAEF,OAAO,CAAC,IAAI,iCAAM,MAAM,KAAE,MAAM,EAAE,GAAG,IAAG,CAAA;YAC1C,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAA;IAChB,CAAC;CACF,CAAA","sourcesContent":["import { getRepository } from '@things-factory/shell'\n\nimport { Account } from '../../../entities'\n\nexport const updateMultipleAccount = {\n async updateMultipleAccount(_: any, { patches }, context: ResolverContext) {\n let results = []\n const _createRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === '+')\n const _updateRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === 'M')\n const accountRepo = getRepository(Account)\n\n if (_createRecords.length > 0) {\n for (let i = 0; i < _createRecords.length; i++) {\n const newRecord = _createRecords[i]\n\n const result = await accountRepo.save({\n ...newRecord,\n domain: context.state.domain,\n creator: context.state.user,\n updater: context.state.user\n })\n\n results.push({ ...result, cuFlag: '+' })\n }\n }\n\n if (_updateRecords.length > 0) {\n for (let i = 0; i < _updateRecords.length; i++) {\n const newRecord = _updateRecords[i]\n const account: Account = await accountRepo.findOneBy({ id: newRecord.id })\n\n const result = await accountRepo.save({\n ...account,\n ...newRecord,\n updater: context.state.user\n })\n\n results.push({ ...result, cuFlag: 'M' })\n }\n }\n\n return results\n }\n}\n"]}