logs-gateway 2.0.0 → 2.0.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.
@@ -1 +1 @@
1
- {"version":3,"file":"app-info.d.ts","sourceRoot":"","sources":["../src/app-info.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,MAAM,WAAW,OAAO;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAID;;;;;;;;GAQG;AACH,wBAAgB,aAAa,IAAI,OAAO,CA6DvC;AAED;;GAEG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAExC"}
1
+ {"version":3,"file":"app-info.d.ts","sourceRoot":"","sources":["../src/app-info.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,MAAM,WAAW,OAAO;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAID;;;;;;;;GAQG;AACH,wBAAgB,aAAa,IAAI,OAAO,CA4HvC;AAED;;GAEG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAExC"}
package/dist/app-info.js CHANGED
@@ -59,22 +59,83 @@ function detectAppInfo() {
59
59
  return cachedAppInfo;
60
60
  }
61
61
  try {
62
- // Start from the caller's directory (where logs-gateway is being used)
63
- // We need to go up from where the module is being called, not from logs-gateway's own directory
64
- // __dirname in this file will be logs-gateway's dist directory
65
- // We need to find the consuming project's package.json
62
+ // Determine logs-gateway's own package.json location
63
+ // __dirname in compiled code will be dist/app-info.js, so we go up to find logs-gateway root
64
+ let logsGatewayPackageJsonPath = null;
65
+ let logsGatewayRootDir = null;
66
+ // Search up from __dirname to find logs-gateway's own package.json
67
+ const rootPath = path.parse(__dirname).root;
68
+ let searchDir = __dirname;
69
+ while (searchDir !== rootPath) {
70
+ const packageJsonPath = path.join(searchDir, 'package.json');
71
+ if (fs.existsSync(packageJsonPath) && !searchDir.includes('node_modules')) {
72
+ try {
73
+ const packageJsonContent = fs.readFileSync(packageJsonPath, 'utf8');
74
+ const packageJson = JSON.parse(packageJsonContent);
75
+ // Check if this is logs-gateway's own package.json
76
+ if (packageJson.name === 'logs-gateway') {
77
+ logsGatewayPackageJsonPath = path.resolve(packageJsonPath);
78
+ logsGatewayRootDir = path.resolve(searchDir);
79
+ break;
80
+ }
81
+ }
82
+ catch (parseError) {
83
+ // Invalid JSON, continue searching
84
+ }
85
+ }
86
+ const parentDir = path.dirname(searchDir);
87
+ if (parentDir === searchDir) {
88
+ break;
89
+ }
90
+ searchDir = parentDir;
91
+ }
66
92
  // Strategy: Start from process.cwd() (the working directory where the app is running)
67
93
  // and search up until we find a package.json that's not in node_modules
94
+ // If we find logs-gateway's own package.json, check if we're running from within logs-gateway
95
+ // (i.e., logs-gateway IS the app). If so, use it. Otherwise, skip it and continue searching.
68
96
  let currentDir = process.cwd();
69
- const rootPath = path.parse(currentDir).root; // Get root to avoid infinite loop
70
- while (currentDir !== rootPath) {
97
+ const cwdRootPath = path.parse(currentDir).root;
98
+ while (currentDir !== cwdRootPath) {
71
99
  const packageJsonPath = path.join(currentDir, 'package.json');
72
100
  // Check if package.json exists and is not in node_modules
73
101
  if (fs.existsSync(packageJsonPath) && !currentDir.includes('node_modules')) {
74
102
  try {
75
103
  const packageJsonContent = fs.readFileSync(packageJsonPath, 'utf8');
76
104
  const packageJson = JSON.parse(packageJsonContent);
77
- // Found a valid package.json - extract name and version
105
+ const resolvedPackageJsonPath = path.resolve(packageJsonPath);
106
+ // If this is logs-gateway's own package.json
107
+ if (packageJson.name === 'logs-gateway') {
108
+ // Check if we're running from within logs-gateway's directory
109
+ // (i.e., logs-gateway IS the app, not a dependency)
110
+ // We check if the current working directory is within logs-gateway's root
111
+ const resolvedCwd = path.resolve(process.cwd());
112
+ const isWithinLogsGateway = logsGatewayRootDir && (resolvedCwd === logsGatewayRootDir ||
113
+ resolvedCwd.startsWith(logsGatewayRootDir + path.sep));
114
+ if (isWithinLogsGateway &&
115
+ resolvedPackageJsonPath === logsGatewayPackageJsonPath) {
116
+ // We're running from logs-gateway itself, use its package.json
117
+ const appInfo = {};
118
+ if (packageJson.name) {
119
+ appInfo.name = packageJson.name;
120
+ }
121
+ if (packageJson.version) {
122
+ appInfo.version = packageJson.version;
123
+ }
124
+ cachedAppInfo = appInfo;
125
+ return appInfo;
126
+ }
127
+ else {
128
+ // This is logs-gateway's package.json but we're using it as a dependency
129
+ // Skip it and continue searching for the consuming app's package.json
130
+ const parentDir = path.dirname(currentDir);
131
+ if (parentDir === currentDir) {
132
+ break;
133
+ }
134
+ currentDir = parentDir;
135
+ continue;
136
+ }
137
+ }
138
+ // Found a valid package.json that's not logs-gateway - extract name and version
78
139
  const appInfo = {};
79
140
  if (packageJson.name) {
80
141
  appInfo.name = packageJson.name;
@@ -1 +1 @@
1
- {"version":3,"file":"app-info.js","sourceRoot":"","sources":["../src/app-info.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBH,sCA6DC;AAKD,8CAEC;AAvFD,uCAAyB;AACzB,2CAA6B;AAO7B,IAAI,aAAa,GAAmB,IAAI,CAAC;AAEzC;;;;;;;;GAQG;AACH,SAAgB,aAAa;IAC3B,oCAAoC;IACpC,IAAI,aAAa,KAAK,IAAI,EAAE,CAAC;QAC3B,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,IAAI,CAAC;QACH,uEAAuE;QACvE,gGAAgG;QAChG,+DAA+D;QAC/D,uDAAuD;QAEvD,sFAAsF;QACtF,wEAAwE;QACxE,IAAI,UAAU,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC/B,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,kCAAkC;QAEhF,OAAO,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC/B,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;YAE9D,0DAA0D;YAC1D,IAAI,EAAE,CAAC,UAAU,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;gBAC3E,IAAI,CAAC;oBACH,MAAM,kBAAkB,GAAG,EAAE,CAAC,YAAY,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC;oBACpE,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;oBAEnD,wDAAwD;oBACxD,MAAM,OAAO,GAAY,EAAE,CAAC;oBAC5B,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;wBACrB,OAAO,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC;oBAClC,CAAC;oBACD,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;wBACxB,OAAO,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC;oBACxC,CAAC;oBAED,mBAAmB;oBACnB,aAAa,GAAG,OAAO,CAAC;oBACxB,OAAO,OAAO,CAAC;gBACjB,CAAC;gBAAC,OAAO,UAAU,EAAE,CAAC;oBACpB,mCAAmC;gBACrC,CAAC;YACH,CAAC;YAED,wBAAwB;YACxB,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,SAAS,KAAK,UAAU,EAAE,CAAC;gBAC7B,+BAA+B;gBAC/B,MAAM;YACR,CAAC;YACD,UAAU,GAAG,SAAS,CAAC;QACzB,CAAC;QAED,8CAA8C;QAC9C,gDAAgD;QAChD,aAAa,GAAG,EAAE,CAAC;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,iDAAiD;QACjD,aAAa,GAAG,EAAE,CAAC;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB;IAC/B,aAAa,GAAG,IAAI,CAAC;AACvB,CAAC"}
1
+ {"version":3,"file":"app-info.js","sourceRoot":"","sources":["../src/app-info.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "logs-gateway",
3
- "version": "2.0.0",
3
+ "version": "2.0.5",
4
4
  "description": "Standardized logging gateway for Node.js with PII sanitization, correlation trails, Shadow Logging for test/debug capture, scoping with text filters, story output, troubleshooting integration, and multi-format output (JSON/YAML/text)",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",