catalyst-relay 0.5.4 → 0.5.6

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/dist/index.mjs CHANGED
@@ -2472,6 +2472,143 @@ async function createTransport(client, config) {
2472
2472
  return ok(transportId);
2473
2473
  }
2474
2474
 
2475
+ // src/core/adt/transports/removeFromTransport.ts
2476
+ var ACCEPT_HEADER = "application/vnd.sap.adt.transportorganizer.v1+xml";
2477
+ async function removeFromTransport(client, transportId, object) {
2478
+ const body = [
2479
+ '<?xml version="1.0" encoding="ASCII"?>',
2480
+ `<tm:root xmlns:tm="http://www.sap.com/cts/adt/tm" tm:number="${escapeXml(transportId)}" tm:useraction="removeobject">`,
2481
+ " <tm:request>",
2482
+ ` <tm:abap_object tm:name="${escapeXml(object.name)}" tm:obj_desc="${escapeXml(object.description)}" tm:pgmid="${escapeXml(object.pgmid)}" tm:type="${escapeXml(object.type)}" tm:position="${escapeXml(object.position)}"/>`,
2483
+ " </tm:request>",
2484
+ "</tm:root>"
2485
+ ].join("\n");
2486
+ const [response, requestErr] = await client.request({
2487
+ method: "PUT",
2488
+ path: `/sap/bc/adt/cts/transportrequests/${transportId}`,
2489
+ headers: {
2490
+ "Accept": ACCEPT_HEADER,
2491
+ "Content-Type": "text/plain"
2492
+ },
2493
+ body
2494
+ });
2495
+ if (requestErr) return err(requestErr);
2496
+ if (!response.ok) {
2497
+ const text = await response.text();
2498
+ const errorMsg = extractError(text);
2499
+ return err(new Error(`Failed to remove ${object.name} from transport ${transportId}: ${errorMsg}`));
2500
+ }
2501
+ return ok(void 0);
2502
+ }
2503
+
2504
+ // src/core/adt/transports/deleteTransport.ts
2505
+ var ACCEPT_HEADER2 = "application/vnd.sap.adt.transportorganizer.v1+xml";
2506
+ function parseTransportTasks(doc) {
2507
+ const tasks = [];
2508
+ const taskElements = doc.getElementsByTagName("tm:task");
2509
+ for (let i = 0; i < taskElements.length; i++) {
2510
+ const taskEl = taskElements[i];
2511
+ if (!taskEl) continue;
2512
+ const taskId = taskEl.getAttribute("tm:number");
2513
+ if (!taskId) continue;
2514
+ const objects = [];
2515
+ const objectElements = taskEl.getElementsByTagName("tm:abap_object");
2516
+ for (let j = 0; j < objectElements.length; j++) {
2517
+ const el = objectElements[j];
2518
+ if (!el) continue;
2519
+ const name = el.getAttribute("tm:name");
2520
+ if (!name) continue;
2521
+ objects.push({
2522
+ name,
2523
+ description: el.getAttribute("tm:obj_desc") || el.getAttribute("tm:obj_info") || "",
2524
+ pgmid: el.getAttribute("tm:pgmid") || "",
2525
+ type: el.getAttribute("tm:type") || "",
2526
+ position: el.getAttribute("tm:position") || ""
2527
+ });
2528
+ }
2529
+ tasks.push({ taskId, objects });
2530
+ }
2531
+ return tasks;
2532
+ }
2533
+ async function sortAndCompress(client, taskId) {
2534
+ const [response, requestErr] = await client.request({
2535
+ method: "POST",
2536
+ path: `/sap/bc/adt/cts/transportrequests/${taskId}/sortandcompress`,
2537
+ headers: { "Accept": ACCEPT_HEADER2 }
2538
+ });
2539
+ if (requestErr) return err(requestErr);
2540
+ if (!response.ok) {
2541
+ const text = await response.text();
2542
+ const errorMsg = extractError(text);
2543
+ return err(new Error(`Failed to sort and compress task ${taskId}: ${errorMsg}`));
2544
+ }
2545
+ return ok(void 0);
2546
+ }
2547
+ async function deleteRequest(client, id) {
2548
+ const [response, requestErr] = await client.request({
2549
+ method: "DELETE",
2550
+ path: `/sap/bc/adt/cts/transportrequests/${id}`,
2551
+ headers: { "Accept": ACCEPT_HEADER2 }
2552
+ });
2553
+ if (requestErr) return err(requestErr);
2554
+ if (!response.ok) {
2555
+ const text = await response.text();
2556
+ const errorMsg = extractError(text);
2557
+ return err(new Error(`Failed to delete ${id}: ${errorMsg}`));
2558
+ }
2559
+ return ok(void 0);
2560
+ }
2561
+ async function deleteTransport(client, transportId, removeObjects = false) {
2562
+ const [response, requestErr] = await client.request({
2563
+ method: "GET",
2564
+ path: `/sap/bc/adt/cts/transportrequests/${transportId}`,
2565
+ headers: { "Accept": ACCEPT_HEADER2 }
2566
+ });
2567
+ if (requestErr) return err(requestErr);
2568
+ if (!response.ok) {
2569
+ const text2 = await response.text();
2570
+ const errorMsg = extractError(text2);
2571
+ return err(new Error(`Failed to read transport ${transportId}: ${errorMsg}`));
2572
+ }
2573
+ const text = await response.text();
2574
+ const [doc, parseErr] = safeParseXml(text);
2575
+ if (parseErr) return err(parseErr);
2576
+ const tasks = parseTransportTasks(doc);
2577
+ for (const task of tasks) {
2578
+ if (removeObjects && task.objects.length > 0) {
2579
+ const [, compressErr] = await sortAndCompress(client, task.taskId);
2580
+ if (compressErr) return err(compressErr);
2581
+ const [taskResponse, taskReadErr] = await client.request({
2582
+ method: "GET",
2583
+ path: `/sap/bc/adt/cts/transportrequests/${task.taskId}`,
2584
+ headers: { "Accept": ACCEPT_HEADER2 }
2585
+ });
2586
+ if (taskReadErr) return err(taskReadErr);
2587
+ const taskText = await taskResponse.text();
2588
+ const [taskDoc, taskParseErr] = safeParseXml(taskText);
2589
+ if (taskParseErr) return err(taskParseErr);
2590
+ const elements = taskDoc.getElementsByTagName("tm:abap_object");
2591
+ for (let i = 0; i < elements.length; i++) {
2592
+ const el = elements[i];
2593
+ if (!el) continue;
2594
+ const name = el.getAttribute("tm:name");
2595
+ if (!name) continue;
2596
+ const [, removeErr] = await removeFromTransport(client, task.taskId, {
2597
+ name,
2598
+ description: el.getAttribute("tm:obj_desc") || el.getAttribute("tm:obj_info") || "",
2599
+ pgmid: el.getAttribute("tm:pgmid") || "",
2600
+ type: el.getAttribute("tm:type") || "",
2601
+ position: el.getAttribute("tm:position") || ""
2602
+ });
2603
+ if (removeErr) return err(removeErr);
2604
+ }
2605
+ }
2606
+ const [, taskErr] = await deleteRequest(client, task.taskId);
2607
+ if (taskErr) return err(taskErr);
2608
+ }
2609
+ return deleteRequest(client, transportId);
2610
+ }
2611
+
2475
2612
  // src/core/adt/craud/gitDiff.ts
2476
2613
  import { diffArrays } from "diff";
2477
2614
  function computeDiff(serverLines, localLines) {
@@ -2729,6 +2866,18 @@ async function createTransport2(state, requestor, transportConfig) {
2729
2866
  return createTransport(requestor, transportConfig);
2730
2867
  }
2731
2868
 
2869
+ // src/client/methods/transport/deleteTransport.ts
2870
+ async function deleteTransport2(state, requestor, transportId, removeObjects = false) {
2871
+ if (!state.session) return err(new Error("Not logged in"));
2872
+ return deleteTransport(requestor, transportId, removeObjects);
2873
+ }
2874
+
2875
+ // src/client/methods/transport/removeFromTransport.ts
2876
+ async function removeFromTransport2(state, requestor, transportId, object) {
2877
+ if (!state.session) return err(new Error("Not logged in"));
2878
+ return removeFromTransport(requestor, transportId, object);
2879
+ }
2880
+
2732
2881
  // src/client/methods/diff/gitDiff.ts
2733
2882
  async function gitDiff2(state, requestor, objects) {
2734
2883
  if (!state.session) return err(new Error("Not logged in"));
@@ -3105,6 +3254,12 @@ var ADTClientImpl = class {
3105
3254
  async createTransport(transportConfig) {
3106
3255
  return createTransport2(this.state, this.requestor, transportConfig);
3107
3256
  }
3257
+ async deleteTransport(transportId, removeObjects = false) {
3258
+ return deleteTransport2(this.state, this.requestor, transportId, removeObjects);
3259
+ }
3260
+ async removeFromTransport(transportId, object) {
3261
+ return removeFromTransport2(this.state, this.requestor, transportId, object);
3262
+ }
3108
3263
  // --- Diff Operations ---
3109
3264
  async gitDiff(objects) {
3110
3265
  return gitDiff2(this.state, this.requestor, objects);