memento-mcp-server 1.16.2 → 1.16.3-b

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.
Files changed (220) hide show
  1. package/dist/domains/anchor/services/anchor/n-hop-search-service.d.ts.map +1 -1
  2. package/dist/domains/anchor/services/anchor/n-hop-search-service.js +4 -5
  3. package/dist/domains/anchor/services/anchor/n-hop-search-service.js.map +1 -1
  4. package/dist/domains/embedding/services/embedding-service.d.ts.map +1 -1
  5. package/dist/domains/embedding/services/embedding-service.js +5 -2
  6. package/dist/domains/embedding/services/embedding-service.js.map +1 -1
  7. package/dist/domains/embedding/services/gemini-embedding-service.d.ts.map +1 -1
  8. package/dist/domains/embedding/services/gemini-embedding-service.js +6 -3
  9. package/dist/domains/embedding/services/gemini-embedding-service.js.map +1 -1
  10. package/dist/domains/embedding/services/lightweight-embedding-service.d.ts.map +1 -1
  11. package/dist/domains/embedding/services/lightweight-embedding-service.js +4 -2
  12. package/dist/domains/embedding/services/lightweight-embedding-service.js.map +1 -1
  13. package/dist/domains/embedding/services/minilm-embedding-service.d.ts.map +1 -1
  14. package/dist/domains/embedding/services/minilm-embedding-service.js +6 -3
  15. package/dist/domains/embedding/services/minilm-embedding-service.js.map +1 -1
  16. package/dist/domains/embedding/services/openai-embedding-service.d.ts.map +1 -1
  17. package/dist/domains/embedding/services/openai-embedding-service.js +5 -2
  18. package/dist/domains/embedding/services/openai-embedding-service.js.map +1 -1
  19. package/dist/domains/embedding/services/unified-embedding-service.d.ts.map +1 -1
  20. package/dist/domains/embedding/services/unified-embedding-service.js +6 -3
  21. package/dist/domains/embedding/services/unified-embedding-service.js.map +1 -1
  22. package/dist/domains/forgetting/services/forgetting-policy-service.d.ts.map +1 -1
  23. package/dist/domains/forgetting/services/forgetting-policy-service.js +3 -1
  24. package/dist/domains/forgetting/services/forgetting-policy-service.js.map +1 -1
  25. package/dist/domains/memory/services/memory-embedding-service.d.ts +1 -0
  26. package/dist/domains/memory/services/memory-embedding-service.d.ts.map +1 -1
  27. package/dist/domains/memory/services/memory-embedding-service.js +43 -39
  28. package/dist/domains/memory/services/memory-embedding-service.js.map +1 -1
  29. package/dist/domains/memory/services/memory-neighbor-service.d.ts.map +1 -1
  30. package/dist/domains/memory/services/memory-neighbor-service.js +13 -4
  31. package/dist/domains/memory/services/memory-neighbor-service.js.map +1 -1
  32. package/dist/domains/memory/tools/convert-episodic-to-semantic-tool.js +5 -6
  33. package/dist/domains/memory/tools/convert-episodic-to-semantic-tool.js.map +1 -1
  34. package/dist/domains/memory/tools/forget-tool.d.ts.map +1 -1
  35. package/dist/domains/memory/tools/forget-tool.js +5 -2
  36. package/dist/domains/memory/tools/forget-tool.js.map +1 -1
  37. package/dist/domains/memory/tools/memory-injection-prompt.d.ts.map +1 -1
  38. package/dist/domains/memory/tools/memory-injection-prompt.js +3 -1
  39. package/dist/domains/memory/tools/memory-injection-prompt.js.map +1 -1
  40. package/dist/domains/memory/tools/pin-tool.d.ts.map +1 -1
  41. package/dist/domains/memory/tools/pin-tool.js +5 -2
  42. package/dist/domains/memory/tools/pin-tool.js.map +1 -1
  43. package/dist/domains/memory/tools/unpin-tool.d.ts.map +1 -1
  44. package/dist/domains/memory/tools/unpin-tool.js +5 -2
  45. package/dist/domains/memory/tools/unpin-tool.js.map +1 -1
  46. package/dist/domains/monitoring/services/error-logging-service.d.ts +5 -0
  47. package/dist/domains/monitoring/services/error-logging-service.d.ts.map +1 -1
  48. package/dist/domains/monitoring/services/error-logging-service.js +28 -10
  49. package/dist/domains/monitoring/services/error-logging-service.js.map +1 -1
  50. package/dist/domains/monitoring/services/performance-alert-service.d.ts.map +1 -1
  51. package/dist/domains/monitoring/services/performance-alert-service.js +5 -2
  52. package/dist/domains/monitoring/services/performance-alert-service.js.map +1 -1
  53. package/dist/domains/relation/services/relation-graph.d.ts.map +1 -1
  54. package/dist/domains/relation/services/relation-graph.js +3 -4
  55. package/dist/domains/relation/services/relation-graph.js.map +1 -1
  56. package/dist/domains/search/algorithms/hybrid-search-engine.d.ts.map +1 -1
  57. package/dist/domains/search/algorithms/hybrid-search-engine.js +15 -10
  58. package/dist/domains/search/algorithms/hybrid-search-engine.js.map +1 -1
  59. package/dist/domains/search/algorithms/search-engine.d.ts.map +1 -1
  60. package/dist/domains/search/algorithms/search-engine.js +8 -4
  61. package/dist/domains/search/algorithms/search-engine.js.map +1 -1
  62. package/dist/domains/search/algorithms/vector-search-engine-migration.d.ts +13 -8
  63. package/dist/domains/search/algorithms/vector-search-engine-migration.d.ts.map +1 -1
  64. package/dist/domains/search/algorithms/vector-search-engine-migration.js +28 -45
  65. package/dist/domains/search/algorithms/vector-search-engine-migration.js.map +1 -1
  66. package/dist/domains/search/algorithms/vector-search-engine.d.ts +17 -35
  67. package/dist/domains/search/algorithms/vector-search-engine.d.ts.map +1 -1
  68. package/dist/domains/search/algorithms/vector-search-engine.js +94 -478
  69. package/dist/domains/search/algorithms/vector-search-engine.js.map +1 -1
  70. package/dist/domains/search/repositories/vector-performance.repository.d.ts.map +1 -1
  71. package/dist/domains/search/repositories/vector-performance.repository.js +3 -1
  72. package/dist/domains/search/repositories/vector-performance.repository.js.map +1 -1
  73. package/dist/domains/search/repositories/vector-search.repository.d.ts +1 -0
  74. package/dist/domains/search/repositories/vector-search.repository.d.ts.map +1 -1
  75. package/dist/domains/search/repositories/vector-search.repository.js +178 -157
  76. package/dist/domains/search/repositories/vector-search.repository.js.map +1 -1
  77. package/dist/domains/search/services/vector-search/vector-index-manager.d.ts.map +1 -1
  78. package/dist/domains/search/services/vector-search/vector-index-manager.js +7 -3
  79. package/dist/domains/search/services/vector-search/vector-index-manager.js.map +1 -1
  80. package/dist/domains/search/services/vector-search/vector-performance-tester.d.ts.map +1 -1
  81. package/dist/domains/search/services/vector-search/vector-performance-tester.js +3 -1
  82. package/dist/domains/search/services/vector-search/vector-performance-tester.js.map +1 -1
  83. package/dist/infrastructure/database/database/init.d.ts.map +1 -1
  84. package/dist/infrastructure/database/database/init.js +29 -7
  85. package/dist/infrastructure/database/database/init.js.map +1 -1
  86. package/dist/infrastructure/database/database/migrate.d.ts.map +1 -1
  87. package/dist/infrastructure/database/database/migrate.js +5 -2
  88. package/dist/infrastructure/database/database/migrate.js.map +1 -1
  89. package/dist/infrastructure/database/database/migration/backup-manager.d.ts.map +1 -1
  90. package/dist/infrastructure/database/database/migration/backup-manager.js +11 -5
  91. package/dist/infrastructure/database/database/migration/backup-manager.js.map +1 -1
  92. package/dist/infrastructure/database/database/migration/migration-detector.d.ts.map +1 -1
  93. package/dist/infrastructure/database/database/migration/migration-detector.js +3 -1
  94. package/dist/infrastructure/database/database/migration/migration-detector.js.map +1 -1
  95. package/dist/infrastructure/database/database/migration/migration-logger.d.ts.map +1 -1
  96. package/dist/infrastructure/database/database/migration/migration-logger.js +5 -2
  97. package/dist/infrastructure/database/database/migration/migration-logger.js.map +1 -1
  98. package/dist/infrastructure/database/database/migration/migration-runner.d.ts.map +1 -1
  99. package/dist/infrastructure/database/database/migration/migration-runner.js +24 -13
  100. package/dist/infrastructure/database/database/migration/migration-runner.js.map +1 -1
  101. package/dist/infrastructure/database/database/migration/schema-version-manager.d.ts.map +1 -1
  102. package/dist/infrastructure/database/database/migration/schema-version-manager.js +7 -3
  103. package/dist/infrastructure/database/database/migration/schema-version-manager.js.map +1 -1
  104. package/dist/infrastructure/database/database-optimizer.d.ts.map +1 -1
  105. package/dist/infrastructure/database/database-optimizer.js +7 -6
  106. package/dist/infrastructure/database/database-optimizer.js.map +1 -1
  107. package/dist/infrastructure/database/migration-history-service.d.ts.map +1 -1
  108. package/dist/infrastructure/database/migration-history-service.js +3 -1
  109. package/dist/infrastructure/database/migration-history-service.js.map +1 -1
  110. package/dist/infrastructure/logging/triple-extraction-logger.d.ts +6 -0
  111. package/dist/infrastructure/logging/triple-extraction-logger.d.ts.map +1 -1
  112. package/dist/infrastructure/logging/triple-extraction-logger.js +50 -12
  113. package/dist/infrastructure/logging/triple-extraction-logger.js.map +1 -1
  114. package/dist/infrastructure/scheduler/batch-scheduler.d.ts.map +1 -1
  115. package/dist/infrastructure/scheduler/batch-scheduler.js +5 -2
  116. package/dist/infrastructure/scheduler/batch-scheduler.js.map +1 -1
  117. package/dist/infrastructure/scheduler/file-logger.d.ts +4 -1
  118. package/dist/infrastructure/scheduler/file-logger.d.ts.map +1 -1
  119. package/dist/infrastructure/scheduler/file-logger.js +46 -16
  120. package/dist/infrastructure/scheduler/file-logger.js.map +1 -1
  121. package/dist/scripts/check-migration-status.d.ts.map +1 -1
  122. package/dist/scripts/check-migration-status.js +19 -6
  123. package/dist/scripts/check-migration-status.js.map +1 -1
  124. package/dist/server/http-server.d.ts.map +1 -1
  125. package/dist/server/http-server.js +2 -7
  126. package/dist/server/http-server.js.map +1 -1
  127. package/dist/server/index.d.ts +3 -0
  128. package/dist/server/index.d.ts.map +1 -1
  129. package/dist/server/index.js +33 -7
  130. package/dist/server/index.js.map +1 -1
  131. package/dist/server/server-factory.d.ts +65 -0
  132. package/dist/server/server-factory.d.ts.map +1 -0
  133. package/dist/server/server-factory.js +40 -0
  134. package/dist/server/server-factory.js.map +1 -0
  135. package/dist/server/servers/sse-server.d.ts +33 -0
  136. package/dist/server/servers/sse-server.d.ts.map +1 -0
  137. package/dist/server/servers/sse-server.js +48 -0
  138. package/dist/server/servers/sse-server.js.map +1 -0
  139. package/dist/server/servers/stdio-server.d.ts +34 -0
  140. package/dist/server/servers/stdio-server.d.ts.map +1 -0
  141. package/dist/server/servers/stdio-server.js +58 -0
  142. package/dist/server/servers/stdio-server.js.map +1 -0
  143. package/dist/server/simple-mcp-server.d.ts +5 -0
  144. package/dist/server/simple-mcp-server.d.ts.map +1 -1
  145. package/dist/server/simple-mcp-server.js +17 -7
  146. package/dist/server/simple-mcp-server.js.map +1 -1
  147. package/dist/server/sse-server-impl.d.ts +22 -0
  148. package/dist/server/sse-server-impl.d.ts.map +1 -0
  149. package/dist/server/sse-server-impl.js +39 -0
  150. package/dist/server/sse-server-impl.js.map +1 -0
  151. package/dist/server/stdio-server-impl.d.ts +12 -0
  152. package/dist/server/stdio-server-impl.d.ts.map +1 -0
  153. package/dist/server/stdio-server-impl.js +19 -0
  154. package/dist/server/stdio-server-impl.js.map +1 -0
  155. package/dist/services/quality-assurance/quality-recorder.js +2 -2
  156. package/dist/services/quality-assurance/quality-recorder.js.map +1 -1
  157. package/dist/services/quality-assurance/quality-threshold-manager.js +1 -1
  158. package/dist/services/quality-assurance/quality-threshold-manager.js.map +1 -1
  159. package/dist/shared/config/environment.d.ts.map +1 -1
  160. package/dist/shared/config/environment.js +3 -1
  161. package/dist/shared/config/environment.js.map +1 -1
  162. package/dist/shared/types/vector-search.types.d.ts +1 -0
  163. package/dist/shared/types/vector-search.types.d.ts.map +1 -1
  164. package/dist/shared/utils/fts5-migration-status.d.ts.map +1 -1
  165. package/dist/shared/utils/fts5-migration-status.js +6 -2
  166. package/dist/shared/utils/fts5-migration-status.js.map +1 -1
  167. package/dist/shared/utils/logger.d.ts.map +1 -1
  168. package/dist/shared/utils/logger.js +15 -2
  169. package/dist/shared/utils/logger.js.map +1 -1
  170. package/dist/shared/utils/path-validator.d.ts +27 -0
  171. package/dist/shared/utils/path-validator.d.ts.map +1 -0
  172. package/dist/shared/utils/path-validator.js +166 -0
  173. package/dist/shared/utils/path-validator.js.map +1 -0
  174. package/dist/shared/utils/pii-masker.d.ts +31 -0
  175. package/dist/shared/utils/pii-masker.d.ts.map +1 -1
  176. package/dist/shared/utils/pii-masker.js +99 -0
  177. package/dist/shared/utils/pii-masker.js.map +1 -1
  178. package/dist/shared/utils/procedural-memory-extractor.d.ts.map +1 -1
  179. package/dist/shared/utils/procedural-memory-extractor.js +39 -33
  180. package/dist/shared/utils/procedural-memory-extractor.js.map +1 -1
  181. package/dist/shared/utils/prompt-template-loader.d.ts +6 -0
  182. package/dist/shared/utils/prompt-template-loader.d.ts.map +1 -1
  183. package/dist/shared/utils/prompt-template-loader.js +20 -8
  184. package/dist/shared/utils/prompt-template-loader.js.map +1 -1
  185. package/dist/shared/utils/reflection-notes-merge.d.ts.map +1 -1
  186. package/dist/shared/utils/reflection-notes-merge.js +5 -4
  187. package/dist/shared/utils/reflection-notes-merge.js.map +1 -1
  188. package/dist/shared/utils/sql-security-validator.d.ts +25 -0
  189. package/dist/shared/utils/sql-security-validator.d.ts.map +1 -0
  190. package/dist/shared/utils/sql-security-validator.js +67 -0
  191. package/dist/shared/utils/sql-security-validator.js.map +1 -0
  192. package/dist/shared/utils/write-coalescing.d.ts.map +1 -1
  193. package/dist/shared/utils/write-coalescing.js +7 -3
  194. package/dist/shared/utils/write-coalescing.js.map +1 -1
  195. package/package.json +2 -1
  196. package/scripts/__tests__/check-db-integrity.integration.spec.ts +163 -0
  197. package/scripts/__tests__/fix-migration.integration.spec.ts +203 -0
  198. package/scripts/__tests__/migrate-embedding-data.integration.spec.ts +219 -0
  199. package/scripts/__tests__/regenerate-embeddings.integration.spec.ts +192 -0
  200. package/scripts/backup-daily.bat +10 -2
  201. package/scripts/backup-embeddings.js +67 -56
  202. package/scripts/check-db-integrity.js +49 -25
  203. package/scripts/check-file-sizes.ts +4 -4
  204. package/scripts/check-path-traversal.ts +370 -0
  205. package/scripts/check-pii-masking.ts +357 -0
  206. package/scripts/check-sql-injection.ts +598 -0
  207. package/scripts/debug-embeddings.js +74 -93
  208. package/scripts/fix-migration.js +115 -80
  209. package/scripts/fix-vector-dimensions.js +70 -89
  210. package/scripts/migrate-embedding-data.js +111 -25
  211. package/scripts/regenerate-embeddings.js +31 -15
  212. package/scripts/run-migration.js +144 -107
  213. package/scripts/safe-migration.js +192 -142
  214. package/scripts/save-work-memory.ts +6 -7
  215. package/scripts/simple-migrate.js +66 -34
  216. package/scripts/simple-update.js +147 -109
  217. package/dist/domains/search/algorithms/vector-search-engine-refactored.d.ts +0 -56
  218. package/dist/domains/search/algorithms/vector-search-engine-refactored.d.ts.map +0 -1
  219. package/dist/domains/search/algorithms/vector-search-engine-refactored.js +0 -101
  220. package/dist/domains/search/algorithms/vector-search-engine-refactored.js.map +0 -1
@@ -0,0 +1,357 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * PII 마스킹 적용 여부 검사 스크립트
4
+ *
5
+ * PRD 0019: 보안 강화 (Phase 1) - PII 마스킹 강화
6
+ *
7
+ * 사용법:
8
+ * tsx scripts/check-pii-masking.ts
9
+ * tsx scripts/check-pii-masking.ts --ci
10
+ * tsx scripts/check-pii-masking.ts --directory src/
11
+ *
12
+ * 목표:
13
+ * - 모든 로거에서 PII 마스킹 적용 확인
14
+ * - 미적용 로거 0개
15
+ * - CI/CD 통합 가능
16
+ */
17
+
18
+ import { readFileSync } from 'fs';
19
+ import { readdir } from 'fs/promises';
20
+ import { join, relative } from 'path';
21
+
22
+ /**
23
+ * CLI 옵션
24
+ */
25
+ interface CliOptions {
26
+ ci?: boolean;
27
+ directory?: string;
28
+ exclude?: string[];
29
+ }
30
+
31
+ /**
32
+ * PII 마스킹 미적용 발견 위치
33
+ */
34
+ interface PIIMaskingLocation {
35
+ file: string;
36
+ line: number;
37
+ column: number;
38
+ pattern: string; // 발견된 패턴 종류
39
+ context: string; // 해당 라인 내용
40
+ severity: 'high' | 'medium' | 'low'; // 심각도
41
+ }
42
+
43
+ /**
44
+ * 검사 결과
45
+ */
46
+ interface CheckResult {
47
+ total: number;
48
+ locations: PIIMaskingLocation[];
49
+ byFile: Map<string, PIIMaskingLocation[]>;
50
+ byPattern: Map<string, number>;
51
+ }
52
+
53
+ /**
54
+ * 명령줄 인자 파싱
55
+ */
56
+ function parseArgs(): CliOptions {
57
+ const args = process.argv.slice(2);
58
+ const options: CliOptions = {
59
+ exclude: ['**/node_modules/**', '**/dist/**', '**/*.d.ts', '**/*.spec.ts', '**/__tests__/**']
60
+ };
61
+
62
+ for (let i = 0; i < args.length; i++) {
63
+ const arg = args[i];
64
+ if (arg === '--ci') {
65
+ options.ci = true;
66
+ } else if (arg === '--directory' && args[i + 1]) {
67
+ options.directory = args[i + 1];
68
+ i++;
69
+ } else if (arg === '--exclude' && args[i + 1]) {
70
+ if (!options.exclude) {
71
+ options.exclude = [];
72
+ }
73
+ options.exclude.push(args[i + 1]);
74
+ i++;
75
+ } else if (arg === '--help' || arg === '-h') {
76
+ printHelp();
77
+ process.exit(0);
78
+ }
79
+ }
80
+
81
+ return options;
82
+ }
83
+
84
+ /**
85
+ * 도움말 출력
86
+ */
87
+ function printHelp(): void {
88
+ console.log(`
89
+ PII 마스킹 적용 여부 검사 스크립트
90
+
91
+ 사용법:
92
+ tsx scripts/check-pii-masking.ts [options]
93
+
94
+ 옵션:
95
+ --ci CI 모드 (미적용 로거 발견 시 exit code 1 반환)
96
+ --directory <path> 검사할 디렉토리 (기본값: src/)
97
+ --exclude <pattern> 제외할 파일 패턴 (여러 번 사용 가능)
98
+ --help, -h 도움말 출력
99
+
100
+ 예제:
101
+ tsx scripts/check-pii-masking.ts
102
+ tsx scripts/check-pii-masking.ts --ci
103
+ tsx scripts/check-pii-masking.ts --directory src/domains
104
+ `);
105
+ }
106
+
107
+ /**
108
+ * 파일이 제외 패턴에 해당하는지 확인
109
+ */
110
+ function shouldExclude(file: string, excludePatterns: string[]): boolean {
111
+ for (const pattern of excludePatterns) {
112
+ // 간단한 패턴 매칭 (glob 패턴은 복잡하므로 기본적인 것만 지원)
113
+ if (pattern.includes('**')) {
114
+ const regex = new RegExp(pattern.replace(/\*\*/g, '.*').replace(/\*/g, '[^/]*'));
115
+ if (regex.test(file)) {
116
+ return true;
117
+ }
118
+ } else if (file.includes(pattern)) {
119
+ return true;
120
+ }
121
+ }
122
+ return false;
123
+ }
124
+
125
+ /**
126
+ * 재귀적으로 디렉토리 탐색
127
+ */
128
+ async function findFiles(
129
+ dir: string,
130
+ excludePatterns: string[],
131
+ fileList: string[] = []
132
+ ): Promise<string[]> {
133
+ try {
134
+ const entries = await readdir(dir, { withFileTypes: true });
135
+
136
+ for (const entry of entries) {
137
+ const fullPath = join(dir, entry.name);
138
+ const relativePath = relative(process.cwd(), fullPath);
139
+
140
+ if (shouldExclude(relativePath, excludePatterns)) {
141
+ continue;
142
+ }
143
+
144
+ if (entry.isDirectory()) {
145
+ await findFiles(fullPath, excludePatterns, fileList);
146
+ } else if (entry.isFile() && entry.name.endsWith('.ts')) {
147
+ fileList.push(fullPath);
148
+ }
149
+ }
150
+ } catch (error) {
151
+ // 디렉토리 읽기 실패는 무시
152
+ }
153
+
154
+ return fileList;
155
+ }
156
+
157
+ /**
158
+ * 파일 내용에서 PII 마스킹 미적용 패턴 검색
159
+ */
160
+ function checkFile(filePath: string): PIIMaskingLocation[] {
161
+ const locations: PIIMaskingLocation[] = [];
162
+
163
+ try {
164
+ const content = readFileSync(filePath, 'utf-8');
165
+ const lines = content.split('\n');
166
+ const relativePath = relative(process.cwd(), filePath);
167
+
168
+ // logger.ts는 이미 PII 마스킹이 적용되어 있으므로 제외
169
+ if (relativePath.includes('shared/utils/logger.ts')) {
170
+ return locations;
171
+ }
172
+
173
+ // logger.ts를 import하는지 확인 (이미 마스킹이 적용되어 있음)
174
+ const usesLoggerUtils = /import.*logger.*from.*['"]\.\.?\/.*shared\/utils\/logger|from.*['"]\.\.?\/.*shared\/utils\/logger/.test(content);
175
+
176
+ // 로거 파일인지 확인 (logger, file-logger, error-logging-service 등)
177
+ const isLoggerFile = /logger|log|error-logging/i.test(relativePath);
178
+
179
+ // logger.error, logger.warn, logger.info, logger.debug 호출 확인
180
+ // logger.ts를 import하는 경우는 이미 마스킹이 적용되어 있으므로 제외
181
+ if (!usesLoggerUtils) {
182
+ const loggerMethodPattern = /logger\.(error|warn|info|debug|log)\s*\(/g;
183
+ let match;
184
+
185
+ while ((match = loggerMethodPattern.exec(content)) !== null) {
186
+ const lineNumber = content.substring(0, match.index).split('\n').length;
187
+ const line = lines[lineNumber - 1];
188
+
189
+ // PIIMasker를 사용하지 않는 logger 호출 확인
190
+ // 해당 메서드 호출 전후로 PIIMasker 사용 여부 확인
191
+ const beforeContext = content.substring(Math.max(0, match.index - 500), match.index);
192
+ const afterContext = content.substring(match.index, Math.min(content.length, match.index + 500));
193
+
194
+ // PIIMasker.mask가 사용되지 않은 경우
195
+ if (!beforeContext.includes('PIIMasker.mask') && !afterContext.includes('PIIMasker.mask')) {
196
+ locations.push({
197
+ file: relativePath,
198
+ line: lineNumber,
199
+ column: match.index - content.substring(0, match.index).lastIndexOf('\n') - 1,
200
+ pattern: 'logger-method-without-masking',
201
+ context: line.trim(),
202
+ severity: isLoggerFile ? 'high' : 'medium'
203
+ });
204
+ }
205
+ }
206
+ }
207
+
208
+ // console.error에서 error.message 또는 error.stack 직접 사용 확인
209
+ const consoleErrorPattern = /console\.(error|warn|log|info|debug)\s*\([^)]*(error\.(message|stack)|error\))/g;
210
+ let consoleMatch;
211
+
212
+ while ((consoleMatch = consoleErrorPattern.exec(content)) !== null) {
213
+ const lineNumber = content.substring(0, consoleMatch.index).split('\n').length;
214
+ const line = lines[lineNumber - 1];
215
+
216
+ // PIIMasker를 사용하지 않는 console.error 호출 확인
217
+ const beforeContext = content.substring(Math.max(0, consoleMatch.index - 500), consoleMatch.index);
218
+ const afterContext = content.substring(consoleMatch.index, Math.min(content.length, consoleMatch.index + 500));
219
+
220
+ if (!beforeContext.includes('PIIMasker.mask') && !afterContext.includes('PIIMasker.mask')) {
221
+ // catch 블록 내부인지 확인
222
+ const beforeCatch = content.substring(Math.max(0, consoleMatch.index - 1000), consoleMatch.index);
223
+ if (beforeCatch.includes('catch') || line.includes('catch')) {
224
+ locations.push({
225
+ file: relativePath,
226
+ line: lineNumber,
227
+ column: consoleMatch.index - content.substring(0, consoleMatch.index).lastIndexOf('\n') - 1,
228
+ pattern: 'console-error-without-masking',
229
+ context: line.trim(),
230
+ severity: 'high'
231
+ });
232
+ }
233
+ }
234
+ }
235
+
236
+ // logger.error에서 error 객체를 직접 전달하는 경우 확인
237
+ // logger.ts를 import하는 경우는 이미 마스킹이 적용되어 있으므로 제외
238
+ if (!usesLoggerUtils) {
239
+ const loggerErrorPattern = /logger\.(error|warn|info|debug)\s*\([^,)]*,\s*\{[^}]*error[^}]*\}/g;
240
+ let loggerErrorMatch;
241
+
242
+ while ((loggerErrorMatch = loggerErrorPattern.exec(content)) !== null) {
243
+ const lineNumber = content.substring(0, loggerErrorMatch.index).split('\n').length;
244
+ const line = lines[lineNumber - 1];
245
+
246
+ // error 객체가 마스킹되지 않은 상태로 전달되는지 확인
247
+ const beforeContext = content.substring(Math.max(0, loggerErrorMatch.index - 500), loggerErrorMatch.index);
248
+
249
+ if (!beforeContext.includes('PIIMasker.mask') && !line.includes('PIIMasker.mask')) {
250
+ locations.push({
251
+ file: relativePath,
252
+ line: lineNumber,
253
+ column: loggerErrorMatch.index - content.substring(0, loggerErrorMatch.index).lastIndexOf('\n') - 1,
254
+ pattern: 'logger-error-object-without-masking',
255
+ context: line.trim(),
256
+ severity: 'medium'
257
+ });
258
+ }
259
+ }
260
+ }
261
+
262
+ } catch (error) {
263
+ // 파일 읽기 실패는 무시
264
+ }
265
+
266
+ return locations;
267
+ }
268
+
269
+ /**
270
+ * 모든 파일 검사
271
+ */
272
+ async function checkAllFiles(options: CliOptions): Promise<CheckResult> {
273
+ const directory = options.directory || 'src';
274
+ const excludePatterns = options.exclude || [];
275
+
276
+ const files = await findFiles(directory, excludePatterns);
277
+ const locations: PIIMaskingLocation[] = [];
278
+ const byFile = new Map<string, PIIMaskingLocation[]>();
279
+ const byPattern = new Map<string, number>();
280
+
281
+ for (const file of files) {
282
+ const fileLocations = checkFile(file);
283
+ if (fileLocations.length > 0) {
284
+ const relativePath = relative(process.cwd(), file);
285
+ locations.push(...fileLocations);
286
+ byFile.set(relativePath, fileLocations);
287
+
288
+ for (const loc of fileLocations) {
289
+ byPattern.set(loc.pattern, (byPattern.get(loc.pattern) || 0) + 1);
290
+ }
291
+ }
292
+ }
293
+
294
+ return {
295
+ total: locations.length,
296
+ locations,
297
+ byFile,
298
+ byPattern
299
+ };
300
+ }
301
+
302
+ /**
303
+ * 결과 출력
304
+ */
305
+ function printResults(result: CheckResult): void {
306
+ console.log('\n⚠️ 발견된 PII 마스킹 미적용:', result.total, '개');
307
+
308
+ if (result.total === 0) {
309
+ console.log('✅ 모든 로거에서 PII 마스킹이 적용되어 있습니다.');
310
+ return;
311
+ }
312
+
313
+ console.log('📁 파일별 미적용 목록:');
314
+
315
+ for (const [file, locations] of result.byFile.entries()) {
316
+ console.log(`\n ${file} (${locations.length}개):`);
317
+
318
+ for (const loc of locations) {
319
+ const severityIcon = loc.severity === 'high' ? '🔴' : loc.severity === 'medium' ? '🟡' : '🟢';
320
+ console.log(` ${severityIcon} 라인 ${loc.line}:${loc.column} - ${loc.pattern}`);
321
+ console.log(` ${loc.context}`);
322
+ }
323
+ }
324
+
325
+ console.log('\n📊 패턴별 통계:');
326
+ for (const [pattern, count] of result.byPattern.entries()) {
327
+ console.log(` ${pattern}: ${count}개`);
328
+ }
329
+ }
330
+
331
+ /**
332
+ * 메인 함수
333
+ */
334
+ async function main(): Promise<void> {
335
+ const options = parseArgs();
336
+
337
+ console.log('🔍 PII 마스킹 적용 여부 검사 시작...\n');
338
+
339
+ const result = await checkAllFiles(options);
340
+ printResults(result);
341
+
342
+ if (options.ci && result.total > 0) {
343
+ console.error('\n❌ CI 실패: PII 마스킹 미적용 로거가 발견되었습니다.');
344
+ process.exit(1);
345
+ }
346
+
347
+ if (result.total === 0) {
348
+ console.log('\n✅ 검사 완료: 모든 로거에서 PII 마스킹이 적용되어 있습니다.');
349
+ }
350
+ }
351
+
352
+ // 스크립트 실행
353
+ main().catch(error => {
354
+ console.error('❌ 스크립트 실행 실패:', error);
355
+ process.exit(1);
356
+ });
357
+