catalyst-relay 0.4.4 → 0.4.5

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.d.mts CHANGED
@@ -117,6 +117,8 @@ interface TreeQuery {
117
117
  package?: string;
118
118
  /** Path within the package for drilling down (e.g., 'CORE_DATA_SERVICES/DATA_DEFINITIONS') */
119
119
  path?: string;
120
+ /** Filter by object owner (e.g., 'EBOSCH'). Only returns objects created by this user. */
121
+ owner?: string;
120
122
  }
121
123
  /**
122
124
  * Data preview query
package/dist/index.d.ts CHANGED
@@ -117,6 +117,8 @@ interface TreeQuery {
117
117
  package?: string;
118
118
  /** Path within the package for drilling down (e.g., 'CORE_DATA_SERVICES/DATA_DEFINITIONS') */
119
119
  path?: string;
120
+ /** Filter by object owner (e.g., 'EBOSCH'). Only returns objects created by this user. */
121
+ owner?: string;
120
122
  }
121
123
  /**
122
124
  * Data preview query
package/dist/index.js CHANGED
@@ -800,7 +800,7 @@ function buildQueryFromPath(packageName, path) {
800
800
  }
801
801
  return query;
802
802
  }
803
- function constructTreeBody(query, searchPattern) {
803
+ function constructTreeBody(query, searchPattern, owner) {
804
804
  const facets = [];
805
805
  const specified = {};
806
806
  const sortedFacets = ["PACKAGE", "GROUP", "TYPE", "API"];
@@ -815,9 +815,18 @@ function constructTreeBody(query, searchPattern) {
815
815
  facets.push(facet);
816
816
  }
817
817
  }
818
- const specifiedXml = Object.entries(specified).map(([facet, name]) => ` <vfs:preselection facet="${facet.toLowerCase()}">
818
+ const preselections = [];
819
+ if (owner) {
820
+ preselections.push(` <vfs:preselection facet="owner">
821
+ <vfs:value>${owner}</vfs:value>
822
+ </vfs:preselection>`);
823
+ }
824
+ for (const [facet, name] of Object.entries(specified)) {
825
+ preselections.push(` <vfs:preselection facet="${facet.toLowerCase()}">
819
826
  <vfs:value>${name}</vfs:value>
820
- </vfs:preselection>`).join("\n");
827
+ </vfs:preselection>`);
828
+ }
829
+ const specifiedXml = preselections.join("\n");
821
830
  const atObjectLevel = query.PACKAGE && query.GROUP && query.TYPE;
822
831
  const facetorderXml = atObjectLevel || facets.length === 0 ? " <vfs:facetorder/>" : ` <vfs:facetorder>
823
832
  ${facets.map((f) => ` <vfs:facet>${f.toLowerCase()}</vfs:facet>`).join("\n")}
@@ -949,8 +958,8 @@ async function fetchChildPackages(client, parentPackage) {
949
958
  }
950
959
 
951
960
  // src/core/adt/discovery/tree/virtualFolders.ts
952
- async function fetchVirtualFolders(client, query) {
953
- const body = constructTreeBody(query, "*");
961
+ async function fetchVirtualFolders(client, query, owner) {
962
+ const body = constructTreeBody(query, "*", owner);
954
963
  const [response, requestErr] = await client.request({
955
964
  method: "POST",
956
965
  path: "/sap/bc/adt/repository/informationsystem/virtualfolders/contents",
@@ -973,7 +982,7 @@ async function fetchVirtualFolders(client, query) {
973
982
  // src/core/adt/discovery/tree/index.ts
974
983
  async function getTree(client, query = {}) {
975
984
  if (!query.package) {
976
- const [parsed2, parseErr2] = await fetchVirtualFolders(client, {});
985
+ const [parsed2, parseErr2] = await fetchVirtualFolders(client, {}, query.owner);
977
986
  if (parseErr2) return err(parseErr2);
978
987
  const packages2 = parsed2.folders.filter((f) => f.facet === "PACKAGE").map((f) => {
979
988
  const pkg = {
@@ -996,7 +1005,7 @@ async function getTree(client, query = {}) {
996
1005
  packages = childPkgs;
997
1006
  }
998
1007
  const internalQuery = buildQueryFromPath(query.package, query.path);
999
- const [parsed, parseErr] = await fetchVirtualFolders(client, internalQuery);
1008
+ const [parsed, parseErr] = await fetchVirtualFolders(client, internalQuery, query.owner);
1000
1009
  if (parseErr) return err(parseErr);
1001
1010
  const result = transformToTreeResponse(parsed, query.package);
1002
1011
  result.packages = packages;