@itentialopensource/adapter-sevone 2.8.3 → 2.10.0

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/CHANGELOG.md CHANGED
@@ -1,4 +1,12 @@
1
1
 
2
+ ## 2.10.0 [02-13-2026]
3
+
4
+ * minor/auto-migrate/20260213-115018
5
+
6
+ See merge request itentialopensource/adapters/adapter-sevone!38
7
+
8
+ ---
9
+
2
10
  ## 2.6.4 [10-15-2024]
3
11
 
4
12
  * Changes made at 2024.10.14_21:38PM
package/PROPERTIES.md CHANGED
@@ -54,7 +54,8 @@ This section defines **all** the properties that are available for the adapter,
54
54
  "healthcheck_on_timeout": false,
55
55
  "return_raw": false,
56
56
  "archiving": false,
57
- "return_request": false
57
+ "return_request": false,
58
+ "keep_alive_interval": 0
58
59
  },
59
60
  "ssl": {
60
61
  "ecdhCurve": "",
@@ -403,6 +404,10 @@ The request section defines properties to help handle requests.
403
404
  <td style="padding:15px">return_request</td>
404
405
  <td style="padding:15px">Optional flag. Default is false. Will return the actual request that is made including headers. This should only be used during debugging issues as there could be credentials in the actual request.</td>
405
406
  </tr>
407
+ <tr>
408
+ <td style="padding:15px">keep_alive_interval</td>
409
+ <td style="padding:15px">Optional. TCP keep-alive interval in seconds for long-lived connections. Set to 0 to disable keep-alive (default). When enabled, minimum value is 30 seconds.</td>
410
+ </tr>
406
411
  </table>
407
412
  <br>
408
413
 
package/TAB2.md CHANGED
@@ -135,7 +135,8 @@ Sample Properties can be used to help you configure the adapter in the Itential
135
135
  "healthcheck_on_timeout": false,
136
136
  "return_raw": false,
137
137
  "archiving": false,
138
- "return_request": false
138
+ "return_request": false,
139
+ "keep_alive_interval": 0
139
140
  },
140
141
  "proxy": {
141
142
  "enabled": false,
package/package.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "@itentialopensource/adapter-sevone",
3
- "version": "2.8.3",
3
+ "version": "2.10.0",
4
4
  "description": "Itential SevOne Adapter",
5
5
  "main": "adapter.js",
6
6
  "systemName": "SevOne",
7
- "wizardVersion": "3.8.0",
8
- "engineVersion": "1.79.2",
7
+ "wizardVersion": "3.12.1",
8
+ "engineVersion": "1.82.5",
9
9
  "adapterType": "http",
10
10
  "scripts": {
11
11
  "preinstall": "node utils/setup.js",
@@ -39,8 +39,8 @@
39
39
  ],
40
40
  "license": "Apache-2.0",
41
41
  "engines": {
42
- "node": ">= 14.0.0",
43
- "npm": ">= 6.0.0"
42
+ "node": ">= 18.18.0",
43
+ "npm": ">= 9.8.1"
44
44
  },
45
45
  "repository": {
46
46
  "type": "git",
@@ -49,14 +49,14 @@
49
49
  "author": "Itential",
50
50
  "homepage": "https://gitlab.com/itentialopensource/adapters/adapter-sevone#readme",
51
51
  "dependencies": {
52
- "@itentialopensource/adapter-utils": "6.0.3",
52
+ "@itentialopensource/adapter-utils": "6.1.14",
53
53
  "acorn": "8.14.1",
54
54
  "ajv": "8.17.1",
55
- "axios": "1.12.2",
55
+ "axios": "1.13.5",
56
56
  "commander": "11.1.0",
57
57
  "fs-extra": "11.3.0",
58
58
  "json-query": "2.2.2",
59
- "mocha": "10.8.2",
59
+ "mocha": "11.3.0",
60
60
  "mocha-param": "2.0.1",
61
61
  "mongodb": "4.17.2",
62
62
  "ping": "0.4.4",
@@ -89,7 +89,7 @@
89
89
  "boolean",
90
90
  "string"
91
91
  ],
92
- "description": "When true the metrics collected by the adapter will be stored in mongo or on the filesystem",
92
+ "description": "When true the metrics collected by the adapter will be stored in mongo or in the adapter. If a full path is provided, metrics will be saved in the path provided.",
93
93
  "default": false
94
94
  },
95
95
  "stub": {
@@ -483,7 +483,7 @@
483
483
  "type": "integer",
484
484
  "description": "How often the healthcheck should run (in milliseconds).",
485
485
  "default": 300000,
486
- "minimum": 60000,
486
+ "minimum": 30000,
487
487
  "maximum": 3600000
488
488
  },
489
489
  "protocol": {
@@ -718,6 +718,13 @@
718
718
  "type": "boolean",
719
719
  "description": "This property turns on returning the response information - need to be carefull in case credentials are in the path",
720
720
  "default": false
721
+ },
722
+ "keep_alive_interval": {
723
+ "type": "integer",
724
+ "description": "TCP keep-alive interval in milliseconds to prevent connection timeout during long-running requests. 0 = disabled (default). Minimum value when enabled is 30000ms (30 seconds). Values below 30000ms will be auto-corrected to 30000ms with a warning.",
725
+ "default": 0,
726
+ "minimum": 0,
727
+ "maximum": 3600000
721
728
  }
722
729
  },
723
730
  "required": [
@@ -1129,7 +1136,7 @@
1129
1136
  },
1130
1137
  "requestFields": {
1131
1138
  "type": "object",
1132
- "description": "The json object with response fields of the call to getDevice",
1139
+ "description": "The json object with request fields of the call to getDevice",
1133
1140
  "additionalProperties": {
1134
1141
  "type": [
1135
1142
  "string",
@@ -1272,7 +1279,7 @@
1272
1279
  },
1273
1280
  "requestFields": {
1274
1281
  "type": "object",
1275
- "description": "The json object with response fields of the call to getDevice",
1282
+ "description": "The json object with request fields of the call to getDevice",
1276
1283
  "additionalProperties": {
1277
1284
  "type": [
1278
1285
  "string",
@@ -1383,7 +1390,7 @@
1383
1390
  },
1384
1391
  "requestFields": {
1385
1392
  "type": "object",
1386
- "description": "The json object with response fields of the call to getDevice",
1393
+ "description": "The json object with request fields of the call to getDevice",
1387
1394
  "additionalProperties": {
1388
1395
  "type": [
1389
1396
  "string",
@@ -1479,7 +1486,7 @@
1479
1486
  },
1480
1487
  "requestFields": {
1481
1488
  "type": "object",
1482
- "description": "The json object with response fields of the call to getDevice",
1489
+ "description": "The json object with request fields of the call to getDevice",
1483
1490
  "additionalProperties": {
1484
1491
  "type": [
1485
1492
  "string",
@@ -1564,7 +1571,7 @@
1564
1571
  },
1565
1572
  "requestFields": {
1566
1573
  "type": "object",
1567
- "description": "The json object with response fields of the call to getDevice",
1574
+ "description": "The json object with request fields of the call to getDevice",
1568
1575
  "additionalProperties": {
1569
1576
  "type": [
1570
1577
  "string",
@@ -1647,12 +1654,12 @@
1647
1654
  "properties": {
1648
1655
  "path": {
1649
1656
  "type": "string",
1650
- "description": "The fully qualified path of the call to getDevice (e.g. /rest/api/device/{deviceid})",
1657
+ "description": "The fully qualified path of the call to populate the cache (e.g. /rest/api/devices)",
1651
1658
  "default": ""
1652
1659
  },
1653
1660
  "method": {
1654
1661
  "type": "string",
1655
- "description": "The method of the call to getDevice",
1662
+ "description": "The method of the call to populate the cache",
1656
1663
  "default": "GET"
1657
1664
  },
1658
1665
  "pagination": {
@@ -1689,7 +1696,7 @@
1689
1696
  },
1690
1697
  "query": {
1691
1698
  "type": "object",
1692
- "description": "The json object with query parameters of the call to getDevice",
1699
+ "description": "The json object with query parameters of the call to populate the cache",
1693
1700
  "additionalProperties": {
1694
1701
  "type": [
1695
1702
  "string",
@@ -1699,7 +1706,7 @@
1699
1706
  },
1700
1707
  "body": {
1701
1708
  "type": "object",
1702
- "description": "The json object with body of the call to getDevice",
1709
+ "description": "The json object with body of the call to populate the cache",
1703
1710
  "additionalProperties": {
1704
1711
  "type": [
1705
1712
  "string",
@@ -1709,7 +1716,7 @@
1709
1716
  },
1710
1717
  "headers": {
1711
1718
  "type": "object",
1712
- "description": "The json object with headers of the call to getDevice",
1719
+ "description": "The json object with headers of the call to populate the cache",
1713
1720
  "additionalProperties": {
1714
1721
  "type": [
1715
1722
  "string",
@@ -1728,7 +1735,7 @@
1728
1735
  },
1729
1736
  "requestFields": {
1730
1737
  "type": "object",
1731
- "description": "The json object with response fields of the call to getDevice",
1738
+ "description": "The json object with request fields of the call to populate the cache",
1732
1739
  "additionalProperties": {
1733
1740
  "type": [
1734
1741
  "string",
@@ -1744,7 +1751,7 @@
1744
1751
  },
1745
1752
  "responseFields": {
1746
1753
  "type": "object",
1747
- "description": "The json object with response fields of the call to getDevice",
1754
+ "description": "The json object with response fields of the call to populate the cache",
1748
1755
  "additionalProperties": {
1749
1756
  "type": [
1750
1757
  "string",
@@ -1785,4 +1792,4 @@
1785
1792
  }
1786
1793
  }
1787
1794
  }
1788
- }
1795
+ }
@@ -0,0 +1,120 @@
1
+ {
2
+ "errors": [],
3
+ "statistics": [
4
+ {
5
+ "owner": "errorJson",
6
+ "description": "New adapter errors available for use",
7
+ "value": 0
8
+ },
9
+ {
10
+ "owner": "errorJson",
11
+ "description": "Adapter errors no longer available for use",
12
+ "value": 0
13
+ },
14
+ {
15
+ "owner": "errorJson",
16
+ "description": "Adapter errors that have been updated (e.g. recommendation changes)",
17
+ "value": 31
18
+ },
19
+ {
20
+ "owner": "packageJson",
21
+ "description": "Number of production dependencies",
22
+ "value": 15
23
+ },
24
+ {
25
+ "owner": "packageJson",
26
+ "description": "Number of development dependencies",
27
+ "value": 6
28
+ },
29
+ {
30
+ "owner": "packageJson",
31
+ "description": "Number of npm scripts",
32
+ "value": 17
33
+ },
34
+ {
35
+ "owner": "packageJson",
36
+ "description": "Runtime Library dependency",
37
+ "value": "6.1.7"
38
+ },
39
+ {
40
+ "owner": "propertiesSchemaJson",
41
+ "description": "Adapter properties defined in the propertiesSchema file",
42
+ "value": 84
43
+ },
44
+ {
45
+ "owner": "markdown",
46
+ "description": "Number of lines in the README.md",
47
+ "value": 345
48
+ },
49
+ {
50
+ "owner": "markdown",
51
+ "description": "Number of lines in the SUMMARY.md",
52
+ "value": 9
53
+ },
54
+ {
55
+ "owner": "markdown",
56
+ "description": "Number of lines in the PROPERTIES.md",
57
+ "value": 682
58
+ },
59
+ {
60
+ "owner": "markdown",
61
+ "description": "Number of lines in the TROUBLESHOOT.md",
62
+ "value": 57
63
+ },
64
+ {
65
+ "owner": "markdown",
66
+ "description": "Number of lines in the ENHANCE.md",
67
+ "value": 70
68
+ },
69
+ {
70
+ "owner": "markdown",
71
+ "description": "Number of lines in the BROKER.md",
72
+ "value": 70
73
+ },
74
+ {
75
+ "owner": "unitTestJS",
76
+ "description": "Number of lines of code in unit tests",
77
+ "value": 13854
78
+ },
79
+ {
80
+ "owner": "unitTestJS",
81
+ "description": "Number of unit tests",
82
+ "value": 893
83
+ },
84
+ {
85
+ "owner": "integrationTestJS",
86
+ "description": "Number of lines of code in integration tests",
87
+ "value": 13590
88
+ },
89
+ {
90
+ "owner": "integrationTestJS",
91
+ "description": "Number of integration tests",
92
+ "value": 409
93
+ },
94
+ {
95
+ "owner": "staticFile",
96
+ "description": "Number of lines of code in adapterBase.js",
97
+ "value": 1527
98
+ },
99
+ {
100
+ "owner": "staticFile",
101
+ "description": "Number of static files added",
102
+ "value": 37
103
+ },
104
+ {
105
+ "owner": "Overall",
106
+ "description": "Total lines of Code",
107
+ "value": 28971
108
+ },
109
+ {
110
+ "owner": "Overall",
111
+ "description": "Total Tests",
112
+ "value": 1302
113
+ },
114
+ {
115
+ "owner": "Overall",
116
+ "description": "Total Files",
117
+ "value": 6
118
+ }
119
+ ]
120
+ }
@@ -0,0 +1,120 @@
1
+ {
2
+ "errors": [],
3
+ "statistics": [
4
+ {
5
+ "owner": "errorJson",
6
+ "description": "New adapter errors available for use",
7
+ "value": 0
8
+ },
9
+ {
10
+ "owner": "errorJson",
11
+ "description": "Adapter errors no longer available for use",
12
+ "value": 0
13
+ },
14
+ {
15
+ "owner": "errorJson",
16
+ "description": "Adapter errors that have been updated (e.g. recommendation changes)",
17
+ "value": 31
18
+ },
19
+ {
20
+ "owner": "packageJson",
21
+ "description": "Number of production dependencies",
22
+ "value": 15
23
+ },
24
+ {
25
+ "owner": "packageJson",
26
+ "description": "Number of development dependencies",
27
+ "value": 6
28
+ },
29
+ {
30
+ "owner": "packageJson",
31
+ "description": "Number of npm scripts",
32
+ "value": 17
33
+ },
34
+ {
35
+ "owner": "packageJson",
36
+ "description": "Runtime Library dependency",
37
+ "value": "6.1.14"
38
+ },
39
+ {
40
+ "owner": "propertiesSchemaJson",
41
+ "description": "Adapter properties defined in the propertiesSchema file",
42
+ "value": 84
43
+ },
44
+ {
45
+ "owner": "markdown",
46
+ "description": "Number of lines in the README.md",
47
+ "value": 345
48
+ },
49
+ {
50
+ "owner": "markdown",
51
+ "description": "Number of lines in the SUMMARY.md",
52
+ "value": 9
53
+ },
54
+ {
55
+ "owner": "markdown",
56
+ "description": "Number of lines in the PROPERTIES.md",
57
+ "value": 682
58
+ },
59
+ {
60
+ "owner": "markdown",
61
+ "description": "Number of lines in the TROUBLESHOOT.md",
62
+ "value": 57
63
+ },
64
+ {
65
+ "owner": "markdown",
66
+ "description": "Number of lines in the ENHANCE.md",
67
+ "value": 70
68
+ },
69
+ {
70
+ "owner": "markdown",
71
+ "description": "Number of lines in the BROKER.md",
72
+ "value": 70
73
+ },
74
+ {
75
+ "owner": "unitTestJS",
76
+ "description": "Number of lines of code in unit tests",
77
+ "value": 13854
78
+ },
79
+ {
80
+ "owner": "unitTestJS",
81
+ "description": "Number of unit tests",
82
+ "value": 893
83
+ },
84
+ {
85
+ "owner": "integrationTestJS",
86
+ "description": "Number of lines of code in integration tests",
87
+ "value": 13590
88
+ },
89
+ {
90
+ "owner": "integrationTestJS",
91
+ "description": "Number of integration tests",
92
+ "value": 409
93
+ },
94
+ {
95
+ "owner": "staticFile",
96
+ "description": "Number of lines of code in adapterBase.js",
97
+ "value": 1527
98
+ },
99
+ {
100
+ "owner": "staticFile",
101
+ "description": "Number of static files added",
102
+ "value": 37
103
+ },
104
+ {
105
+ "owner": "Overall",
106
+ "description": "Total lines of Code",
107
+ "value": 28971
108
+ },
109
+ {
110
+ "owner": "Overall",
111
+ "description": "Total Tests",
112
+ "value": 1302
113
+ },
114
+ {
115
+ "owner": "Overall",
116
+ "description": "Total Files",
117
+ "value": 6
118
+ }
119
+ ]
120
+ }
@@ -81,7 +81,8 @@
81
81
  "healthcheck_on_timeout": false,
82
82
  "return_raw": false,
83
83
  "archiving": false,
84
- "return_request": false
84
+ "return_request": false,
85
+ "keep_alive_interval": 0
85
86
  },
86
87
  "proxy": {
87
88
  "enabled": false,
@@ -270,4 +271,4 @@
270
271
  "brokers": [],
271
272
  "logLevel": "none",
272
273
  "timeout": 60000
273
- }
274
+ }
@@ -280,10 +280,10 @@ describe('[unit] SevOne Adapter Test', () => {
280
280
  assert.notEqual(null, packageDotJson.dependencies);
281
281
  assert.notEqual('', packageDotJson.dependencies);
282
282
  assert.equal('8.17.1', packageDotJson.dependencies.ajv);
283
- assert.equal('1.12.2', packageDotJson.dependencies.axios);
283
+ assert.equal('1.13.5', packageDotJson.dependencies.axios);
284
284
  assert.equal('11.1.0', packageDotJson.dependencies.commander);
285
285
  assert.equal('11.3.0', packageDotJson.dependencies['fs-extra']);
286
- assert.equal('10.8.2', packageDotJson.dependencies.mocha);
286
+ assert.equal('11.3.0', packageDotJson.dependencies.mocha);
287
287
  assert.equal('2.0.1', packageDotJson.dependencies['mocha-param']);
288
288
  assert.equal('0.4.4', packageDotJson.dependencies.ping);
289
289
  assert.equal('1.4.10', packageDotJson.dependencies['readline-sync']);
@@ -19,17 +19,14 @@ function createObjectForFunction(
19
19
  workflow
20
20
  ) {
21
21
  const funcObject = {};
22
- // if the entity path is not set, then the object is not created.
23
- if (entityPath !== undefined) {
24
- funcObject.method_signature = `${funcName}(${funcArgs.join(', ')})`;
25
- funcObject.path = entityPath;
26
- if (description === undefined) {
27
- funcObject.description = '';
28
- funcObject.workflow = 'No';
29
- } else {
30
- funcObject.description = description;
31
- funcObject.workflow = workflow;
32
- }
22
+ funcObject.method_signature = `${funcName}(${funcArgs.join(', ')})`;
23
+ funcObject.path = entityPath !== undefined ? entityPath : '';
24
+ if (description === undefined) {
25
+ funcObject.description = '';
26
+ funcObject.workflow = 'No';
27
+ } else {
28
+ funcObject.description = description;
29
+ funcObject.workflow = workflow;
33
30
  }
34
31
  return funcObject;
35
32
  }
@@ -77,7 +74,8 @@ function readFileUsingLib(filename, descriptionObj, workflowObj, functionList) {
77
74
  // parsing the file to get the function and class declarations.
78
75
  const aFileFuncArgs = acorn.parse(aFile, { ecmaVersion: 2020 });
79
76
 
80
- let callName = 'identifyRequest';
77
+ // Track all method names that can be called (identifyRequest + any proxy methods)
78
+ const allowedCallNames = new Set(['identifyRequest']);
81
79
  // Looping through all the declarations parsed:
82
80
  aFileFuncArgs.body.forEach((e) => {
83
81
  // Getting only the class declaration as it has our required functions.
@@ -103,9 +101,10 @@ function readFileUsingLib(filename, descriptionObj, workflowObj, functionList) {
103
101
  method.value.body.body.forEach((statement) => {
104
102
  recurseCallExpressions(statement, callList);
105
103
  });
104
+ // Find calls to identifyRequest OR any discovered proxy methods
106
105
  const requests = [];
107
106
  for (let i = 0; i < callList.length; i += 1) {
108
- if (callList[i].callee.property && callList[i].callee.property.name === callName) {
107
+ if (callList[i].callee.property && allowedCallNames.has(callList[i].callee.property.name)) {
109
108
  requests.push(callList[i]);
110
109
  }
111
110
  }
@@ -114,34 +113,60 @@ function readFileUsingLib(filename, descriptionObj, workflowObj, functionList) {
114
113
  if (expr.arguments.length < 2) {
115
114
  throw new Error(`Bad inputs in method ${funcName}`);
116
115
  }
117
- const entity = expr.arguments[0].value;
118
- const actionName = expr.arguments[1].value;
119
- if (expr !== undefined && (expr.arguments[0].type !== 'Literal' || expr.arguments[1].type !== 'Literal')) {
120
- const param1 = method.value.params[0];
121
- const param2 = method.value.params[1];
122
- if (param1.type !== 'Identifier' || param2.type !== 'Identifier'
123
- || expr.arguments[0].type !== 'Identifier' || expr.arguments[1].type !== 'Identifier'
124
- || param1.name !== expr.arguments[0].name || param2.name !== expr.arguments[1].name) {
125
- throw new Error(`identifyRequest proxy method ${funcName} unknown format`);
126
- } else if (callName !== 'identifyRequest') {
127
- throw new Error(`MethodDocumentor not yet programmed to handle multiple helper methods: 1) ${callName}, 2) ${funcName}`);
116
+
117
+ const arg0Type = expr.arguments[0].type;
118
+ const arg1Type = expr.arguments[1].type;
119
+
120
+ let entityPath;
121
+
122
+ if (arg0Type === 'Literal' && arg1Type === 'Literal') {
123
+ const entity = expr.arguments[0].value;
124
+ const actionName = expr.arguments[1].value;
125
+ entityPath = getPathFromEntity(entity, actionName);
126
+ } else {
127
+ // Non-standard format: anything that's not both literals
128
+ // Special handling for proxy methods (both args are identifiers matching first 2 params)
129
+ if (arg0Type === 'Identifier' && arg1Type === 'Identifier') {
130
+ const param1 = method.value.params[0];
131
+ const param2 = method.value.params[1];
132
+ const arg0Name = expr.arguments[0].name;
133
+ const arg1Name = expr.arguments[1].name;
134
+
135
+ // Check if this is a valid proxy method
136
+ const isValidProxy = param1 && param2
137
+ && param1.type === 'Identifier' && param2.type === 'Identifier'
138
+ && param1.name === arg0Name && param2.name === arg1Name;
139
+
140
+ // Only process valid proxy methods
141
+ if (isValidProxy) {
142
+ const calledMethod = expr.callee.property.name;
143
+
144
+ // Skip nested proxies (proxies calling other proxies)
145
+ if (calledMethod !== 'identifyRequest') {
146
+ console.log(`Skipping nested proxy method: ${funcName} (calls ${calledMethod})`);
147
+ return;
148
+ }
149
+
150
+ // First-level proxy: calls identifyRequest directly
151
+ // Add this proxy to the set so other methods can call it
152
+ allowedCallNames.add(funcName);
153
+ }
128
154
  }
129
- callName = funcName;
155
+
156
+ // All non-standard formats get documented without path
157
+ entityPath = undefined;
130
158
  }
131
- const entityPath = getPathFromEntity(entity, actionName);
132
159
 
133
160
  // Creating and storing the object for the method.
134
- if (entityPath !== undefined) {
135
- functionList.push(
136
- createObjectForFunction(
137
- funcName,
138
- funcArgs,
139
- entityPath,
140
- descriptionObj[funcName],
141
- workflowObj[funcName]
142
- )
143
- );
144
- }
161
+ functionList.push(
162
+ createObjectForFunction(
163
+ funcName,
164
+ funcArgs,
165
+ entityPath,
166
+ descriptionObj[funcName],
167
+ workflowObj[funcName]
168
+ )
169
+ );
145
170
  }
146
171
  });
147
172
  }