zudello-integration-sdk 1.0.27 → 1.0.28
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/package.json +22 -22
- package/src/index.js +75 -73
- package/src/sdk/SAPB1.js +43 -43
- package/src/sdk/submodules/sap-b1/Universal.js +63 -62
- package/src/utils/message.js +20 -0
package/package.json
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
2
|
+
"name": "zudello-integration-sdk",
|
|
3
|
+
"version": "1.0.28",
|
|
4
|
+
"description": "Zudello Integrations SDK",
|
|
5
|
+
"main": "./src/index.js",
|
|
6
|
+
"repository": {
|
|
7
|
+
"type": "git",
|
|
8
|
+
"url": "https://github.com/zudello/integration-sdk.git"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"src"
|
|
12
|
+
],
|
|
13
|
+
"dependencies": {
|
|
14
|
+
"@aws-sdk/client-s3": "^3.658.0",
|
|
15
|
+
"axios": "^1.6.7",
|
|
16
|
+
"circular-json": "^0.5.9",
|
|
17
|
+
"dotenv": "^16.4.5",
|
|
18
|
+
"lodash": "^4.17.21",
|
|
19
|
+
"moment-timezone": "^0.5.45",
|
|
20
|
+
"perf_hooks": "^0.0.1",
|
|
21
|
+
"standard": "^17.1.0"
|
|
22
|
+
},
|
|
23
|
+
"license": "MIT"
|
|
24
24
|
}
|
package/src/index.js
CHANGED
|
@@ -1,80 +1,82 @@
|
|
|
1
|
-
|
|
1
|
+
'use strict'
|
|
2
2
|
|
|
3
|
-
const Auth = require(
|
|
4
|
-
const ZudelloSDK = require(
|
|
5
|
-
const NetsuiteSDK = require(
|
|
6
|
-
const NetsuiteSoapSDK = require(
|
|
7
|
-
const IntacctSDK = require(
|
|
8
|
-
const BusinessCentralSDK = require(
|
|
9
|
-
const ZenotiSDK = require(
|
|
10
|
-
const DearSDK = require(
|
|
11
|
-
const NexviaSDK = require(
|
|
12
|
-
const FoSDK = require(
|
|
13
|
-
const RetailExpressSDK = require(
|
|
14
|
-
const MYOBAcumaticaSDK = require(
|
|
15
|
-
const SybizSDK = require(
|
|
16
|
-
const XeroSDK = require(
|
|
17
|
-
const JobReadySDK = require(
|
|
18
|
-
const X3SDK = require(
|
|
19
|
-
const SAPB1SDK = require(
|
|
20
|
-
const GPSDK = require(
|
|
21
|
-
const EDISDK = require(
|
|
3
|
+
const Auth = require('./sdk/Auth')
|
|
4
|
+
const ZudelloSDK = require('./sdk/Zudello')
|
|
5
|
+
const NetsuiteSDK = require('./sdk/Netsuite')
|
|
6
|
+
const NetsuiteSoapSDK = require('./sdk/NetsuiteSOAP')
|
|
7
|
+
const IntacctSDK = require('./sdk/Intacct')
|
|
8
|
+
const BusinessCentralSDK = require('./sdk/BusinessCentral')
|
|
9
|
+
const ZenotiSDK = require('./sdk/Zenoti')
|
|
10
|
+
const DearSDK = require('./sdk/Dear')
|
|
11
|
+
const NexviaSDK = require('./sdk/Nexvia')
|
|
12
|
+
const FoSDK = require('./sdk/Fo')
|
|
13
|
+
const RetailExpressSDK = require('./sdk/RetailExpress')
|
|
14
|
+
const MYOBAcumaticaSDK = require('./sdk/MYOBAcumatica')
|
|
15
|
+
const SybizSDK = require('./sdk/Sybiz')
|
|
16
|
+
const XeroSDK = require('./sdk/Xero')
|
|
17
|
+
const JobReadySDK = require('./sdk/JobReady')
|
|
18
|
+
const X3SDK = require('./sdk/X3')
|
|
19
|
+
const SAPB1SDK = require('./sdk/SAPB1')
|
|
20
|
+
const GPSDK = require('./sdk/GP')
|
|
21
|
+
const EDISDK = require('./sdk/EDI')
|
|
22
22
|
|
|
23
|
-
const Logger = require(
|
|
24
|
-
const Metadata = require(
|
|
25
|
-
const
|
|
26
|
-
const
|
|
27
|
-
const
|
|
28
|
-
const
|
|
29
|
-
const
|
|
30
|
-
const
|
|
31
|
-
const
|
|
32
|
-
const
|
|
23
|
+
const Logger = require('./utils/logger')
|
|
24
|
+
const Metadata = require('./utils/metadata')
|
|
25
|
+
const Message = require('./utils/message')
|
|
26
|
+
const Tags = require('./utils/tags')
|
|
27
|
+
const Trigger = require('./utils/trigger')
|
|
28
|
+
const Properties = require('./utils/properties')
|
|
29
|
+
const MiscHelper = require('./utils/miscHelper')
|
|
30
|
+
const ModelHelper = require('./utils/modelHelper')
|
|
31
|
+
const DatasetHelper = require('./utils/datasetHelper')
|
|
32
|
+
const FormHelper = require('./utils/formHelper')
|
|
33
|
+
const ResponseHelper = require('./utils/responseHelper')
|
|
33
34
|
const {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
} = require(
|
|
35
|
+
getFileContent,
|
|
36
|
+
uploadFile,
|
|
37
|
+
listFiles,
|
|
38
|
+
deleteFile,
|
|
39
|
+
deleteFiles,
|
|
40
|
+
} = require('./utils/s3Client')
|
|
40
41
|
|
|
41
42
|
const S3Client = {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
43
|
+
getFileContent,
|
|
44
|
+
uploadFile,
|
|
45
|
+
listFiles,
|
|
46
|
+
deleteFile,
|
|
47
|
+
deleteFiles,
|
|
48
|
+
}
|
|
48
49
|
|
|
49
50
|
module.exports = {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
51
|
+
Auth,
|
|
52
|
+
ZudelloSDK,
|
|
53
|
+
NetsuiteSDK,
|
|
54
|
+
NetsuiteSoapSDK,
|
|
55
|
+
IntacctSDK,
|
|
56
|
+
BusinessCentralSDK,
|
|
57
|
+
ZenotiSDK,
|
|
58
|
+
DearSDK,
|
|
59
|
+
NexviaSDK,
|
|
60
|
+
GPSDK,
|
|
61
|
+
SAPB1SDK,
|
|
62
|
+
EDISDK,
|
|
63
|
+
X3SDK,
|
|
64
|
+
FoSDK,
|
|
65
|
+
RetailExpressSDK,
|
|
66
|
+
MYOBAcumaticaSDK,
|
|
67
|
+
SybizSDK,
|
|
68
|
+
XeroSDK,
|
|
69
|
+
JobReadySDK,
|
|
70
|
+
Logger,
|
|
71
|
+
Metadata,
|
|
72
|
+
Message,
|
|
73
|
+
Tags,
|
|
74
|
+
Trigger,
|
|
75
|
+
Properties,
|
|
76
|
+
MiscHelper,
|
|
77
|
+
ModelHelper,
|
|
78
|
+
DatasetHelper,
|
|
79
|
+
FormHelper,
|
|
80
|
+
ResponseHelper,
|
|
81
|
+
S3Client,
|
|
82
|
+
}
|
package/src/sdk/SAPB1.js
CHANGED
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
|
|
1
|
+
'use strict'
|
|
2
2
|
|
|
3
|
-
const BaseSDK = require(
|
|
4
|
-
const UniversalModule = require(
|
|
5
|
-
const PurchaseInvoiceModule = require(
|
|
6
|
-
const PurchaseOrderModule = require(
|
|
7
|
-
const PurchaseCreditModule = require(
|
|
8
|
-
const PurchaseReceiptModule = require(
|
|
9
|
-
const SaleInvoiceModule = require(
|
|
10
|
-
const SaleOrderModule = require(
|
|
11
|
-
const SaleCreditModule = require(
|
|
3
|
+
const BaseSDK = require('./Base')
|
|
4
|
+
const UniversalModule = require('./submodules/sap-b1/Universal')
|
|
5
|
+
const PurchaseInvoiceModule = require('./submodules/sap-b1/purchase/Invoice')
|
|
6
|
+
const PurchaseOrderModule = require('./submodules/sap-b1/purchase/Order')
|
|
7
|
+
const PurchaseCreditModule = require('./submodules/sap-b1/purchase/Credit')
|
|
8
|
+
const PurchaseReceiptModule = require('./submodules/sap-b1/purchase/GoodReceipt')
|
|
9
|
+
const SaleInvoiceModule = require('./submodules/sap-b1/sale/Invoice')
|
|
10
|
+
const SaleOrderModule = require('./submodules/sap-b1/sale/Order')
|
|
11
|
+
const SaleCreditModule = require('./submodules/sap-b1/sale/Credit')
|
|
12
12
|
|
|
13
13
|
class SAPB1SDK extends BaseSDK {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
14
|
+
/**
|
|
15
|
+
* Constructor.
|
|
16
|
+
* @param {class} auth Auth class object with authorized api instance.
|
|
17
|
+
* @param {string} connectionUUID The UUID of the Connection we're working on.
|
|
18
|
+
*/
|
|
19
|
+
constructor(auth, connectionUUID, organizationUUID, apiURL, apiVersion, loggerClass = null) {
|
|
20
|
+
super({
|
|
21
|
+
auth,
|
|
22
|
+
connectionUUID,
|
|
23
|
+
organizationUUID,
|
|
24
|
+
apiURL,
|
|
25
|
+
apiVersion,
|
|
26
|
+
appUUIDKey: 'sapb1',
|
|
27
|
+
integrationName: 'SAPB1',
|
|
28
|
+
loggerClass
|
|
29
|
+
})
|
|
30
30
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
31
|
+
/**
|
|
32
|
+
* Create submodule instances.
|
|
33
|
+
*/
|
|
34
|
+
this.universal = new UniversalModule(this)
|
|
35
|
+
this.purchase = {
|
|
36
|
+
order: new PurchaseOrderModule(this),
|
|
37
|
+
invoice: new PurchaseInvoiceModule(this),
|
|
38
|
+
credit: new PurchaseCreditModule(this),
|
|
39
|
+
receipt: new PurchaseReceiptModule(this)
|
|
40
|
+
}
|
|
41
|
+
this.sale = {
|
|
42
|
+
order: new SaleOrderModule(this),
|
|
43
|
+
invoice: new SaleInvoiceModule(this),
|
|
44
|
+
credit: new SaleCreditModule(this)
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
47
|
}
|
|
48
48
|
|
|
49
|
-
module.exports = SAPB1SDK
|
|
49
|
+
module.exports = SAPB1SDK
|
|
@@ -1,70 +1,71 @@
|
|
|
1
|
-
|
|
1
|
+
'use strict'
|
|
2
2
|
|
|
3
3
|
class UniversalModule {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
4
|
+
/**
|
|
5
|
+
* Constructor.
|
|
6
|
+
* @param {class} parentModule Object of SAP B1 class.
|
|
7
|
+
*/
|
|
8
|
+
constructor(parentModule) {
|
|
9
|
+
this.module = parentModule
|
|
10
|
+
}
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
12
|
+
/**
|
|
13
|
+
* Universal Request By URL and Method.
|
|
14
|
+
* @param {string} url URL of request.
|
|
15
|
+
* @param {string} method Method of request.
|
|
16
|
+
* @param {object} qs Some available filters inside: offset, limit.
|
|
17
|
+
* @param {object} body Some available data inside.
|
|
18
|
+
* @param {boolean} appendLimit Append limit & offset to URL.
|
|
19
|
+
* @returns {object} Universal Request Response.
|
|
20
|
+
*/
|
|
21
|
+
async request({ command = 'fetch_sql', qs = {}, body = {} }) {
|
|
22
|
+
const validateIsEmpty = this.module.validator.isEmpty({ command })
|
|
23
23
|
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
if (!validateIsEmpty.valid) {
|
|
25
|
+
return this.module.responseHandler.error(validateIsEmpty.errors)
|
|
26
|
+
}
|
|
27
27
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
28
|
+
return await this.module.makeRequest(
|
|
29
|
+
'POST',
|
|
30
|
+
`${this.module.apiURL}/zintegrations/action/33067090-da86-4a7e-8ba1-b07107dc5175`,
|
|
31
|
+
{
|
|
32
|
+
mappable_parameters: {
|
|
33
|
+
command: {
|
|
34
|
+
value: command
|
|
35
|
+
},
|
|
36
|
+
qs: {
|
|
37
|
+
isMap: true,
|
|
38
|
+
value: JSON.stringify(qs)
|
|
39
|
+
},
|
|
40
|
+
body: {
|
|
41
|
+
isMap: true,
|
|
42
|
+
value: JSON.stringify(body)
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
_debug: true
|
|
48
|
+
}
|
|
49
|
+
)
|
|
50
|
+
}
|
|
51
51
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
52
|
+
/**
|
|
53
|
+
* Universal List By URL.
|
|
54
|
+
* @param {number} offset Offset of listed data.
|
|
55
|
+
* @param {number} limit Limit of listed data.
|
|
56
|
+
* @returns {object} Universal List Response.
|
|
57
|
+
*/
|
|
58
|
+
async list({ command = 'fetch_sql', qs = {}, body = {}, offset = 0, limit = 10 }) {
|
|
59
|
+
const validateIsEmpty = this.module.validator.isEmpty({ command, sql: body.sql })
|
|
60
|
+
|
|
61
|
+
if (!validateIsEmpty.valid) {
|
|
62
|
+
return this.module.responseHandler.error(validateIsEmpty.errors)
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
body.sql = `${body.sql} OFFSET ${offset} LIMIT ${limit};`
|
|
66
|
+
|
|
67
|
+
return await this.request({ command, qs, body })
|
|
68
|
+
}
|
|
68
69
|
}
|
|
69
70
|
|
|
70
|
-
module.exports = UniversalModule
|
|
71
|
+
module.exports = UniversalModule
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
class Message {
|
|
4
|
+
constructor(apiInstance = null, teamUUID = null) {
|
|
5
|
+
this.apiInstance = apiInstance
|
|
6
|
+
this.teamUUID = teamUUID
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
async send(data = {}) {
|
|
10
|
+
if (!this.apiInstance || !this.teamUUID || !process.env.ZUDELLO_API_URL) {
|
|
11
|
+
return
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
return await this.apiInstance.post(`${process.env.ZUDELLO_API_URL}/message/proceed`, data, {
|
|
15
|
+
'x-team': this.teamUUID
|
|
16
|
+
})
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
module.exports = Message
|