@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.
@@ -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
+ }