@numends/abap-client 0.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 +96 -0
- package/dist/abap-object-utils.d.ts +31 -0
- package/dist/abap-object-utils.js +113 -0
- package/dist/abap-object-utils.js.map +1 -0
- package/dist/config.d.ts +62 -0
- package/dist/config.js +117 -0
- package/dist/config.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +100 -0
- package/dist/index.js.map +1 -0
- package/dist/lock-manager.d.ts +25 -0
- package/dist/lock-manager.js +92 -0
- package/dist/lock-manager.js.map +1 -0
- package/dist/sap-client.d.ts +39 -0
- package/dist/sap-client.js +241 -0
- package/dist/sap-client.js.map +1 -0
- package/dist/websocket-client.d.ts +26 -0
- package/dist/websocket-client.js +461 -0
- package/dist/websocket-client.js.map +1 -0
- package/dist/xml-utils.d.ts +11 -0
- package/dist/xml-utils.js +109 -0
- package/dist/xml-utils.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lock Manager
|
|
3
|
+
* Manages ABAP object locks to avoid re-locking during multi-step operations
|
|
4
|
+
*/
|
|
5
|
+
import { CONFIG } from './config.js';
|
|
6
|
+
export class LockManager {
|
|
7
|
+
locks = new Map();
|
|
8
|
+
lockTTL;
|
|
9
|
+
constructor() {
|
|
10
|
+
this.lockTTL = CONFIG.LOCK?.ttlMs || 30 * 60 * 1000;
|
|
11
|
+
}
|
|
12
|
+
buildKey(objectName, objectType, suffix = '') {
|
|
13
|
+
return suffix
|
|
14
|
+
? `${objectName.toUpperCase()}:${objectType.toUpperCase()}:${suffix.toUpperCase()}`
|
|
15
|
+
: `${objectName.toUpperCase()}:${objectType.toUpperCase()}`;
|
|
16
|
+
}
|
|
17
|
+
getLock(objectName, objectType, suffix = '') {
|
|
18
|
+
const key = this.buildKey(objectName, objectType, suffix);
|
|
19
|
+
const lock = this.locks.get(key);
|
|
20
|
+
if (!lock) {
|
|
21
|
+
return null;
|
|
22
|
+
}
|
|
23
|
+
const age = Date.now() - lock.timestamp;
|
|
24
|
+
if (age > this.lockTTL) {
|
|
25
|
+
console.log(` โฐ Lock expired for ${key} (age: ${Math.round(age / 1000 / 60)}min)`);
|
|
26
|
+
this.locks.delete(key);
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
console.log(` ๐ Found cached lock for ${key} (age: ${Math.round(age / 1000)}s)`);
|
|
30
|
+
this.printLockTable('GET_LOCK (cache hit)');
|
|
31
|
+
return lock;
|
|
32
|
+
}
|
|
33
|
+
saveLock(objectName, objectType, lockHandle, transportRequest, suffix = '') {
|
|
34
|
+
const key = this.buildKey(objectName, objectType, suffix);
|
|
35
|
+
this.locks.set(key, {
|
|
36
|
+
lockHandle,
|
|
37
|
+
transportRequest,
|
|
38
|
+
timestamp: Date.now()
|
|
39
|
+
});
|
|
40
|
+
console.log(` ๐ Lock cached for ${key}`);
|
|
41
|
+
console.log(` lockHandle: ${lockHandle}`);
|
|
42
|
+
console.log(` transportRequest: ${transportRequest || '(empty)'}`);
|
|
43
|
+
this.printLockTable('SAVE_LOCK');
|
|
44
|
+
}
|
|
45
|
+
clearLock(objectName, objectType, suffix = '') {
|
|
46
|
+
const key = this.buildKey(objectName, objectType, suffix);
|
|
47
|
+
const deleted = this.locks.delete(key);
|
|
48
|
+
if (deleted) {
|
|
49
|
+
console.log(` ๐๏ธ Lock cleared for ${key}`);
|
|
50
|
+
this.printLockTable('CLEAR_LOCK');
|
|
51
|
+
}
|
|
52
|
+
return deleted;
|
|
53
|
+
}
|
|
54
|
+
clearAll() {
|
|
55
|
+
const count = this.locks.size;
|
|
56
|
+
this.locks.clear();
|
|
57
|
+
if (count > 0) {
|
|
58
|
+
console.log(` ๐งน All locks cleared (${count} lock(s))`);
|
|
59
|
+
this.printLockTable('CLEAR_ALL');
|
|
60
|
+
}
|
|
61
|
+
return count;
|
|
62
|
+
}
|
|
63
|
+
getStats() {
|
|
64
|
+
return {
|
|
65
|
+
activeLocks: this.locks.size,
|
|
66
|
+
locks: Array.from(this.locks.keys())
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
printLockTable(operation = '') {
|
|
70
|
+
console.log('');
|
|
71
|
+
console.log(' โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ');
|
|
72
|
+
console.log(' โ ๐ LOCK TABLE ' + (operation ? '(after ' + operation + ')' : '') + ' - ' + this.locks.size + ' active lock(s)');
|
|
73
|
+
console.log(' โ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ');
|
|
74
|
+
if (this.locks.size === 0) {
|
|
75
|
+
console.log(' โ (empty - no locks cached)');
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
let idx = 1;
|
|
79
|
+
for (const [key, lock] of this.locks) {
|
|
80
|
+
const age = Math.round((Date.now() - lock.timestamp) / 1000);
|
|
81
|
+
console.log(' โ [' + idx + '] ' + key);
|
|
82
|
+
console.log(' โ Handle: ' + lock.lockHandle);
|
|
83
|
+
console.log(' โ Transport: ' + (lock.transportRequest || '(none)'));
|
|
84
|
+
console.log(' โ Age: ' + age + 's');
|
|
85
|
+
idx++;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
console.log(' โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ');
|
|
89
|
+
console.log('');
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=lock-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock-manager.js","sourceRoot":"","sources":["../src/lock-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SAP HTTP Client
|
|
3
|
+
* Handles HTTP communication with SAP ADT REST API
|
|
4
|
+
*/
|
|
5
|
+
import { type SapActiveConfig } from './config.js';
|
|
6
|
+
import type { Callspec } from './abap-object-utils.js';
|
|
7
|
+
export interface CallspecResult {
|
|
8
|
+
success: boolean;
|
|
9
|
+
status?: number;
|
|
10
|
+
statusText?: string;
|
|
11
|
+
headers?: Record<string, string>;
|
|
12
|
+
data?: {
|
|
13
|
+
raw: unknown;
|
|
14
|
+
lockHandle?: string;
|
|
15
|
+
transportRequest?: string;
|
|
16
|
+
[key: string]: unknown;
|
|
17
|
+
};
|
|
18
|
+
error?: string;
|
|
19
|
+
errorDetails?: string[];
|
|
20
|
+
validationError?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare class SAPClient {
|
|
23
|
+
private config;
|
|
24
|
+
csrfToken: string | null;
|
|
25
|
+
private cookies;
|
|
26
|
+
private client;
|
|
27
|
+
constructor(config?: SapActiveConfig);
|
|
28
|
+
executeCallspec(callspec: Callspec): Promise<CallspecResult>;
|
|
29
|
+
private extractDataFromResponse;
|
|
30
|
+
private logRequest;
|
|
31
|
+
private logResponse;
|
|
32
|
+
fetchCsrfToken(): Promise<void>;
|
|
33
|
+
clearSession(): void;
|
|
34
|
+
ping(): Promise<{
|
|
35
|
+
success: boolean;
|
|
36
|
+
status?: number;
|
|
37
|
+
error?: string;
|
|
38
|
+
}>;
|
|
39
|
+
}
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SAP HTTP Client
|
|
3
|
+
* Handles HTTP communication with SAP ADT REST API
|
|
4
|
+
*/
|
|
5
|
+
import axios from 'axios';
|
|
6
|
+
import https from 'https';
|
|
7
|
+
import { CONFIG } from './config.js';
|
|
8
|
+
import { parseSAPResponse } from './xml-utils.js';
|
|
9
|
+
export class SAPClient {
|
|
10
|
+
config;
|
|
11
|
+
csrfToken = null;
|
|
12
|
+
cookies = new Map();
|
|
13
|
+
client;
|
|
14
|
+
constructor(config = CONFIG.SAP) {
|
|
15
|
+
this.config = config;
|
|
16
|
+
this.client = axios.create({
|
|
17
|
+
baseURL: config.baseUrl,
|
|
18
|
+
headers: {
|
|
19
|
+
'sap-client': config.client,
|
|
20
|
+
'sap-language': config.language,
|
|
21
|
+
'Accept': 'application/xml,text/plain,*/*',
|
|
22
|
+
'X-sap-adt-sessiontype': 'stateful'
|
|
23
|
+
},
|
|
24
|
+
httpsAgent: new https.Agent({
|
|
25
|
+
rejectUnauthorized: false
|
|
26
|
+
}),
|
|
27
|
+
auth: {
|
|
28
|
+
username: config.username,
|
|
29
|
+
password: config.password
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
this.client.interceptors.response.use((response) => {
|
|
33
|
+
const setCookie = response.headers['set-cookie'];
|
|
34
|
+
if (setCookie) {
|
|
35
|
+
setCookie.forEach((cookieString) => {
|
|
36
|
+
const cookieValue = cookieString.split(';')[0];
|
|
37
|
+
const cookieName = cookieValue.split('=')[0];
|
|
38
|
+
this.cookies.set(cookieName, cookieValue);
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
if (response.headers['x-csrf-token']) {
|
|
42
|
+
this.csrfToken = response.headers['x-csrf-token'];
|
|
43
|
+
console.log(` [KEY] CSRF token obtained: ${this.csrfToken.substring(0, 15)}...`);
|
|
44
|
+
}
|
|
45
|
+
return response;
|
|
46
|
+
}, (error) => {
|
|
47
|
+
if (error.response?.status === 401 || error.response?.status === 403) {
|
|
48
|
+
console.error(` [WARN] Session error (${error.response.status}) - clearing session...`);
|
|
49
|
+
this.clearSession();
|
|
50
|
+
}
|
|
51
|
+
return Promise.reject(error);
|
|
52
|
+
});
|
|
53
|
+
this.client.interceptors.request.use((request) => {
|
|
54
|
+
if (this.cookies.size > 0) {
|
|
55
|
+
request.headers['Cookie'] = Array.from(this.cookies.values()).join('; ');
|
|
56
|
+
}
|
|
57
|
+
return request;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
async executeCallspec(callspec) {
|
|
61
|
+
const { method, url, headers, body, extract_from_response } = callspec;
|
|
62
|
+
const finalHeaders = { ...headers };
|
|
63
|
+
let finalBody = body;
|
|
64
|
+
if (typeof finalBody === 'string') {
|
|
65
|
+
finalBody = finalBody.replace(/<SAP_USERNAME>/g, this.config.username.toUpperCase());
|
|
66
|
+
finalBody = finalBody.replace(/<SAP_LANGUAGE>/g, this.config.language || 'EN');
|
|
67
|
+
}
|
|
68
|
+
if (finalHeaders['X-CSRF-Token'] === '<CSRF_TOKEN>') {
|
|
69
|
+
if (!this.csrfToken) {
|
|
70
|
+
await this.fetchCsrfToken();
|
|
71
|
+
}
|
|
72
|
+
finalHeaders['X-CSRF-Token'] = this.csrfToken;
|
|
73
|
+
}
|
|
74
|
+
delete finalHeaders['Authorization'];
|
|
75
|
+
if (finalHeaders['Cookie'] === '<SESSION_COOKIE>') {
|
|
76
|
+
delete finalHeaders['Cookie'];
|
|
77
|
+
}
|
|
78
|
+
console.log(` [HTTP] ${method} ${url}`);
|
|
79
|
+
this.logRequest(method, url, finalHeaders, finalBody);
|
|
80
|
+
try {
|
|
81
|
+
const response = await this.client.request({
|
|
82
|
+
method,
|
|
83
|
+
url,
|
|
84
|
+
headers: finalHeaders,
|
|
85
|
+
data: finalBody || undefined,
|
|
86
|
+
timeout: 60000
|
|
87
|
+
});
|
|
88
|
+
console.log(` [OK] ${response.status} ${response.statusText}`);
|
|
89
|
+
this.logResponse(response);
|
|
90
|
+
const extractedData = this.extractDataFromResponse(response.data, extract_from_response);
|
|
91
|
+
const { hasErrors, errorMessages } = parseSAPResponse(response.data);
|
|
92
|
+
if (hasErrors) {
|
|
93
|
+
console.log(` [WARN] Found ${errorMessages.length} error(s) in SAP response`);
|
|
94
|
+
errorMessages.forEach((errMsg, index) => {
|
|
95
|
+
console.log(` [ERR] Error ${index + 1}: ${errMsg}`);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
return {
|
|
99
|
+
success: !hasErrors,
|
|
100
|
+
status: response.status,
|
|
101
|
+
statusText: response.statusText,
|
|
102
|
+
headers: response.headers,
|
|
103
|
+
data: {
|
|
104
|
+
raw: response.data,
|
|
105
|
+
...extractedData
|
|
106
|
+
},
|
|
107
|
+
...(errorMessages.length > 0 && {
|
|
108
|
+
error: `SAP validation failed: ${errorMessages.join('; ')}`,
|
|
109
|
+
errorDetails: errorMessages
|
|
110
|
+
})
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
catch (error) {
|
|
114
|
+
const axiosErr = error;
|
|
115
|
+
console.error(` [ERR] ${axiosErr.response?.status || 'Error'} ${axiosErr.message}`);
|
|
116
|
+
return {
|
|
117
|
+
success: false,
|
|
118
|
+
status: axiosErr.response?.status,
|
|
119
|
+
error: axiosErr.message,
|
|
120
|
+
data: axiosErr.response?.data
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
extractDataFromResponse(responseData, extractRules) {
|
|
125
|
+
const extractedData = {};
|
|
126
|
+
console.log(' [DEBUG] extract_from_response:', extractRules);
|
|
127
|
+
console.log(' [DEBUG] response.data type:', typeof responseData);
|
|
128
|
+
console.log(' [DEBUG] response.data (first 200 chars):', typeof responseData === 'string' ? responseData.substring(0, 200) : 'NOT A STRING');
|
|
129
|
+
if (extractRules && typeof responseData === 'string') {
|
|
130
|
+
console.log(' [DEBUG] Attempting to extract values from XML...');
|
|
131
|
+
if (extractRules.lock_handle) {
|
|
132
|
+
console.log(' [DEBUG] Looking for lockHandle in XML...');
|
|
133
|
+
const lockHandleMatch = responseData.match(/<(?:adtcore:)?(?:lock[Hh]andle|LOCK_HANDLE)>(.*?)<\/(?:adtcore:)?(?:lock[Hh]andle|LOCK_HANDLE)>/);
|
|
134
|
+
if (lockHandleMatch) {
|
|
135
|
+
extractedData.lockHandle = lockHandleMatch[1];
|
|
136
|
+
console.log(` [KEY] Extracted lock_handle: ${extractedData.lockHandle}`);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
console.log(' [WARN] lockHandle NOT found in XML');
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
if (extractRules.transport_request) {
|
|
143
|
+
console.log(' [DEBUG] Looking for transportRequest in XML...');
|
|
144
|
+
const transportMatch = responseData.match(/<(?:adtcore:)?(?:corrNr|CORRNR)>(.*?)<\/(?:adtcore:)?(?:corrNr|CORRNR)>/);
|
|
145
|
+
if (transportMatch) {
|
|
146
|
+
extractedData.transportRequest = transportMatch[1];
|
|
147
|
+
console.log(` [KEY] Extracted transport_request: ${extractedData.transportRequest}`);
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
console.log(' [WARN] transportRequest NOT found in XML (or empty)');
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
console.log(` [WARN] No extraction: extract_from_response=${!!extractRules}, is string=${typeof responseData === 'string'}`);
|
|
156
|
+
}
|
|
157
|
+
return extractedData;
|
|
158
|
+
}
|
|
159
|
+
logRequest(method, url, headers, body) {
|
|
160
|
+
console.log('\n ================================================================');
|
|
161
|
+
console.log(' | [REQ] DETAILED REQUEST LOG');
|
|
162
|
+
console.log(' |---------------------------------------------------------------');
|
|
163
|
+
console.log(` | Method: ${method}`);
|
|
164
|
+
console.log(` | URL: ${url}`);
|
|
165
|
+
console.log(' |---------------------------------------------------------------');
|
|
166
|
+
console.log(' | [HEADERS] REQUEST HEADERS:');
|
|
167
|
+
Object.entries(headers).forEach(([key, value]) => {
|
|
168
|
+
console.log(` | ${key}: ${value}`);
|
|
169
|
+
});
|
|
170
|
+
if (this.csrfToken) {
|
|
171
|
+
console.log(' |---------------------------------------------------------------');
|
|
172
|
+
console.log(` | [CSRF] CSRF Token: ${this.csrfToken}`);
|
|
173
|
+
}
|
|
174
|
+
if (body && (method === 'POST' || method === 'PUT')) {
|
|
175
|
+
console.log(' |---------------------------------------------------------------');
|
|
176
|
+
console.log(` | [BODY] REQUEST BODY (${body.length} chars):`);
|
|
177
|
+
console.log(' |');
|
|
178
|
+
body.split('\n').forEach(line => {
|
|
179
|
+
console.log(` | ${line}`);
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
console.log(' ================================================================\n');
|
|
183
|
+
}
|
|
184
|
+
logResponse(response) {
|
|
185
|
+
console.log('\n ================================================================');
|
|
186
|
+
console.log(' | [RES] DETAILED RESPONSE LOG');
|
|
187
|
+
console.log(' |---------------------------------------------------------------');
|
|
188
|
+
console.log(` | Status: ${response.status} ${response.statusText}`);
|
|
189
|
+
console.log(' |---------------------------------------------------------------');
|
|
190
|
+
console.log(' | [HEADERS] RESPONSE HEADERS:');
|
|
191
|
+
if (response.headers) {
|
|
192
|
+
Object.entries(response.headers).forEach(([key, value]) => {
|
|
193
|
+
console.log(` | ${key}: ${value}`);
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
console.log(' |---------------------------------------------------------------');
|
|
197
|
+
console.log(` | [DATA] RESPONSE BODY (${typeof response.data === 'string' ? response.data.length : '?'} chars):`);
|
|
198
|
+
if (typeof response.data === 'string' && response.data.length < 2000) {
|
|
199
|
+
console.log(' |');
|
|
200
|
+
response.data.split('\n').forEach((line) => {
|
|
201
|
+
console.log(` | ${line}`);
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
else if (typeof response.data === 'string') {
|
|
205
|
+
console.log(' | (First 500 chars):');
|
|
206
|
+
console.log(` | ${response.data.substring(0, 500)}...`);
|
|
207
|
+
}
|
|
208
|
+
console.log(' ================================================================\n');
|
|
209
|
+
}
|
|
210
|
+
async fetchCsrfToken() {
|
|
211
|
+
console.log(' [KEY] Fetching CSRF token...');
|
|
212
|
+
try {
|
|
213
|
+
await this.client.get('/sap/bc/adt/compatibility/graph', {
|
|
214
|
+
headers: { 'X-CSRF-Token': 'Fetch' }
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
catch (error) {
|
|
218
|
+
const axiosErr = error;
|
|
219
|
+
if (axiosErr.response?.headers['x-csrf-token']) {
|
|
220
|
+
this.csrfToken = axiosErr.response.headers['x-csrf-token'];
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
clearSession() {
|
|
225
|
+
this.csrfToken = null;
|
|
226
|
+
this.cookies.clear();
|
|
227
|
+
console.log(' [CLEAN] Session cleared');
|
|
228
|
+
}
|
|
229
|
+
async ping() {
|
|
230
|
+
try {
|
|
231
|
+
const response = await this.client.get('/sap/bc/adt/compatibility/graph', {
|
|
232
|
+
timeout: 5000
|
|
233
|
+
});
|
|
234
|
+
return { success: true, status: response.status };
|
|
235
|
+
}
|
|
236
|
+
catch (error) {
|
|
237
|
+
return { success: false, error: error.message };
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
//# sourceMappingURL=sap-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sap-client.js","sourceRoot":"","sources":["../src/sap-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WebSocket Client
|
|
3
|
+
* Connects to MCP Cloud and executes SAP operations locally
|
|
4
|
+
*/
|
|
5
|
+
import { type AppConfig } from './config.js';
|
|
6
|
+
export declare class WebSocketClient {
|
|
7
|
+
private config;
|
|
8
|
+
private ws;
|
|
9
|
+
private sapClient;
|
|
10
|
+
private reconnectTimer;
|
|
11
|
+
private keepAliveTimer;
|
|
12
|
+
private isReconnecting;
|
|
13
|
+
private lockManager;
|
|
14
|
+
constructor(config?: AppConfig);
|
|
15
|
+
connect(): void;
|
|
16
|
+
private onOpen;
|
|
17
|
+
private startKeepAlive;
|
|
18
|
+
private stopKeepAlive;
|
|
19
|
+
private onMessage;
|
|
20
|
+
private handleCommand;
|
|
21
|
+
private executeCallspecs;
|
|
22
|
+
private sendResponse;
|
|
23
|
+
private onError;
|
|
24
|
+
private onClose;
|
|
25
|
+
disconnect(): void;
|
|
26
|
+
}
|