enterprise-logging-system 1.0.0

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 (102) hide show
  1. package/README.md +16 -0
  2. package/dist/__tests__/exports.test.d.ts +2 -0
  3. package/dist/__tests__/exports.test.d.ts.map +1 -0
  4. package/dist/__tests__/exports.test.js +48 -0
  5. package/dist/__tests__/exports.test.js.map +1 -0
  6. package/dist/backend/config/database.d.ts +11 -0
  7. package/dist/backend/config/database.d.ts.map +1 -0
  8. package/dist/backend/config/database.js +65 -0
  9. package/dist/backend/config/database.js.map +1 -0
  10. package/dist/backend/config/logging.config.d.ts +28 -0
  11. package/dist/backend/config/logging.config.d.ts.map +1 -0
  12. package/dist/backend/config/logging.config.js +36 -0
  13. package/dist/backend/config/logging.config.js.map +1 -0
  14. package/dist/backend/controllers/LogController.d.ts +18 -0
  15. package/dist/backend/controllers/LogController.d.ts.map +1 -0
  16. package/dist/backend/controllers/LogController.js +159 -0
  17. package/dist/backend/controllers/LogController.js.map +1 -0
  18. package/dist/backend/index.d.ts +8 -0
  19. package/dist/backend/index.d.ts.map +1 -0
  20. package/dist/backend/index.js +24 -0
  21. package/dist/backend/index.js.map +1 -0
  22. package/dist/backend/middleware/loggingMiddleware.d.ts +8 -0
  23. package/dist/backend/middleware/loggingMiddleware.d.ts.map +1 -0
  24. package/dist/backend/middleware/loggingMiddleware.js +112 -0
  25. package/dist/backend/middleware/loggingMiddleware.js.map +1 -0
  26. package/dist/backend/models/AccessLog.d.ts +73 -0
  27. package/dist/backend/models/AccessLog.d.ts.map +1 -0
  28. package/dist/backend/models/AccessLog.js +10 -0
  29. package/dist/backend/models/AccessLog.js.map +1 -0
  30. package/dist/backend/models/ChangeLog.d.ts +81 -0
  31. package/dist/backend/models/ChangeLog.d.ts.map +1 -0
  32. package/dist/backend/models/ChangeLog.js +11 -0
  33. package/dist/backend/models/ChangeLog.js.map +1 -0
  34. package/dist/backend/models/ExportLog.d.ts +64 -0
  35. package/dist/backend/models/ExportLog.d.ts.map +1 -0
  36. package/dist/backend/models/ExportLog.js +10 -0
  37. package/dist/backend/models/ExportLog.js.map +1 -0
  38. package/dist/backend/models/SessionLog.d.ts +94 -0
  39. package/dist/backend/models/SessionLog.d.ts.map +1 -0
  40. package/dist/backend/models/SessionLog.js +11 -0
  41. package/dist/backend/models/SessionLog.js.map +1 -0
  42. package/dist/backend/models/index.d.ts +5 -0
  43. package/dist/backend/models/index.d.ts.map +1 -0
  44. package/dist/backend/models/index.js +21 -0
  45. package/dist/backend/models/index.js.map +1 -0
  46. package/dist/backend/repositories/AccessLogRepository.d.ts +14 -0
  47. package/dist/backend/repositories/AccessLogRepository.d.ts.map +1 -0
  48. package/dist/backend/repositories/AccessLogRepository.js +60 -0
  49. package/dist/backend/repositories/AccessLogRepository.js.map +1 -0
  50. package/dist/backend/repositories/BaseRepository.d.ts +28 -0
  51. package/dist/backend/repositories/BaseRepository.d.ts.map +1 -0
  52. package/dist/backend/repositories/BaseRepository.js +112 -0
  53. package/dist/backend/repositories/BaseRepository.js.map +1 -0
  54. package/dist/backend/repositories/ChangeLogRepository.d.ts +12 -0
  55. package/dist/backend/repositories/ChangeLogRepository.d.ts.map +1 -0
  56. package/dist/backend/repositories/ChangeLogRepository.js +47 -0
  57. package/dist/backend/repositories/ChangeLogRepository.js.map +1 -0
  58. package/dist/backend/repositories/ExportLogRepository.d.ts +11 -0
  59. package/dist/backend/repositories/ExportLogRepository.d.ts.map +1 -0
  60. package/dist/backend/repositories/ExportLogRepository.js +45 -0
  61. package/dist/backend/repositories/ExportLogRepository.js.map +1 -0
  62. package/dist/backend/repositories/SessionLogRepository.d.ts +20 -0
  63. package/dist/backend/repositories/SessionLogRepository.d.ts.map +1 -0
  64. package/dist/backend/repositories/SessionLogRepository.js +171 -0
  65. package/dist/backend/repositories/SessionLogRepository.js.map +1 -0
  66. package/dist/backend/repositories/index.d.ts +6 -0
  67. package/dist/backend/repositories/index.d.ts.map +1 -0
  68. package/dist/backend/repositories/index.js +22 -0
  69. package/dist/backend/repositories/index.js.map +1 -0
  70. package/dist/backend/services/LoggingService.d.ts +110 -0
  71. package/dist/backend/services/LoggingService.d.ts.map +1 -0
  72. package/dist/backend/services/LoggingService.js +97 -0
  73. package/dist/backend/services/LoggingService.js.map +1 -0
  74. package/dist/backend/utils/Logger.d.ts +8 -0
  75. package/dist/backend/utils/Logger.d.ts.map +1 -0
  76. package/dist/backend/utils/Logger.js +23 -0
  77. package/dist/backend/utils/Logger.js.map +1 -0
  78. package/dist/examples/queries.d.ts +29 -0
  79. package/dist/examples/queries.d.ts.map +1 -0
  80. package/dist/examples/queries.js +151 -0
  81. package/dist/examples/queries.js.map +1 -0
  82. package/dist/frontend/activity-monitor/ActivityMonitor.d.ts +45 -0
  83. package/dist/frontend/activity-monitor/ActivityMonitor.d.ts.map +1 -0
  84. package/dist/frontend/activity-monitor/ActivityMonitor.js +159 -0
  85. package/dist/frontend/activity-monitor/ActivityMonitor.js.map +1 -0
  86. package/dist/frontend/idle-tracker/IdleTracker.d.ts +34 -0
  87. package/dist/frontend/idle-tracker/IdleTracker.d.ts.map +1 -0
  88. package/dist/frontend/idle-tracker/IdleTracker.js +56 -0
  89. package/dist/frontend/idle-tracker/IdleTracker.js.map +1 -0
  90. package/dist/frontend/index.d.ts +3 -0
  91. package/dist/frontend/index.d.ts.map +1 -0
  92. package/dist/frontend/index.js +19 -0
  93. package/dist/frontend/index.js.map +1 -0
  94. package/dist/index.d.ts +15 -0
  95. package/dist/index.d.ts.map +1 -0
  96. package/dist/index.js +72 -0
  97. package/dist/index.js.map +1 -0
  98. package/dist/shared/types/index.d.ts +41 -0
  99. package/dist/shared/types/index.d.ts.map +1 -0
  100. package/dist/shared/types/index.js +3 -0
  101. package/dist/shared/types/index.js.map +1 -0
  102. package/package.json +56 -0
@@ -0,0 +1,3 @@
1
+ export * from './activity-monitor/ActivityMonitor';
2
+ export * from './idle-tracker/IdleTracker';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/frontend/index.ts"],"names":[],"mappings":"AAAA,cAAc,oCAAoC,CAAC;AACnD,cAAc,4BAA4B,CAAC"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./activity-monitor/ActivityMonitor"), exports);
18
+ __exportStar(require("./idle-tracker/IdleTracker"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/frontend/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qEAAmD;AACnD,6DAA2C"}
@@ -0,0 +1,15 @@
1
+ export * from './backend/services/LoggingService';
2
+ export * from './backend/repositories';
3
+ export * from './backend/models';
4
+ export * from './shared/types';
5
+ export * from './frontend';
6
+ export declare function setupLoggingSystem(db: any): Promise<{
7
+ loggingService: import("./backend/services/LoggingService").LoggingService;
8
+ logController: import("./backend/controllers/LogController").LogController;
9
+ loggingMiddleware: {
10
+ apiLogger: (req: import("express").Request, res: import("express").Response, next: import("express").NextFunction) => void;
11
+ sessionTracker: (req: import("express").Request, res: import("express").Response, next: import("express").NextFunction) => Promise<void>;
12
+ changeLogger: (req: import("express").Request, res: import("express").Response, next: import("express").NextFunction) => Promise<void>;
13
+ };
14
+ }>;
15
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mCAAmC,CAAC;AAClD,cAAc,wBAAwB,CAAC;AACvC,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAG/B,cAAc,YAAY,CAAC;AAG3B,wBAAsB,kBAAkB,CAAC,EAAE,EAAE,GAAG;;;;;;;;GAuC/C"}
package/dist/index.js ADDED
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
19
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
20
+ };
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.setupLoggingSystem = setupLoggingSystem;
40
+ __exportStar(require("./backend/services/LoggingService"), exports);
41
+ __exportStar(require("./backend/repositories"), exports);
42
+ __exportStar(require("./backend/models"), exports);
43
+ __exportStar(require("./shared/types"), exports);
44
+ // Frontend exports
45
+ __exportStar(require("./frontend"), exports);
46
+ // Setup function for backend
47
+ async function setupLoggingSystem(db) {
48
+ const { AccessLogRepository, SessionLogRepository, ChangeLogRepository, ExportLogRepository } = await Promise.resolve().then(() => __importStar(require('./backend/repositories')));
49
+ const repos = {
50
+ accessLogRepo: new AccessLogRepository(db),
51
+ sessionLogRepo: new SessionLogRepository(db),
52
+ changeLogRepo: new ChangeLogRepository(db),
53
+ exportLogRepo: new ExportLogRepository(db)
54
+ };
55
+ // Initialize all repositories
56
+ await Promise.all([
57
+ repos.accessLogRepo.initialize(),
58
+ repos.sessionLogRepo.initialize(),
59
+ repos.changeLogRepo.initialize(),
60
+ repos.exportLogRepo.initialize()
61
+ ]);
62
+ const { LoggingService } = await Promise.resolve().then(() => __importStar(require('./backend/services/LoggingService')));
63
+ const { LogController } = await Promise.resolve().then(() => __importStar(require('./backend/controllers/LogController')));
64
+ const { createLoggingMiddleware } = await Promise.resolve().then(() => __importStar(require('./backend/middleware/loggingMiddleware')));
65
+ const loggingService = new LoggingService(repos.accessLogRepo, repos.sessionLogRepo, repos.changeLogRepo, repos.exportLogRepo);
66
+ return {
67
+ loggingService,
68
+ logController: new LogController(loggingService),
69
+ loggingMiddleware: createLoggingMiddleware(loggingService)
70
+ };
71
+ }
72
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASA,gDAuCC;AAhDD,oEAAkD;AAClD,yDAAuC;AACvC,mDAAiC;AACjC,iDAA+B;AAE/B,mBAAmB;AACnB,6CAA2B;AAE3B,6BAA6B;AACtB,KAAK,UAAU,kBAAkB,CAAC,EAAO;IAC9C,MAAM,EACJ,mBAAmB,EACnB,oBAAoB,EACpB,mBAAmB,EACnB,mBAAmB,EACpB,GAAG,wDAAa,wBAAwB,GAAC,CAAC;IAE3C,MAAM,KAAK,GAAG;QACZ,aAAa,EAAE,IAAI,mBAAmB,CAAC,EAAE,CAAC;QAC1C,cAAc,EAAE,IAAI,oBAAoB,CAAC,EAAE,CAAC;QAC5C,aAAa,EAAE,IAAI,mBAAmB,CAAC,EAAE,CAAC;QAC1C,aAAa,EAAE,IAAI,mBAAmB,CAAC,EAAE,CAAC;KAC3C,CAAC;IAEF,8BAA8B;IAC9B,MAAM,OAAO,CAAC,GAAG,CAAC;QAChB,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE;QAChC,KAAK,CAAC,cAAc,CAAC,UAAU,EAAE;QACjC,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE;QAChC,KAAK,CAAC,aAAa,CAAC,UAAU,EAAE;KACjC,CAAC,CAAC;IAEH,MAAM,EAAE,cAAc,EAAE,GAAG,wDAAa,mCAAmC,GAAC,CAAC;IAC7E,MAAM,EAAE,aAAa,EAAE,GAAG,wDAAa,qCAAqC,GAAC,CAAC;IAC9E,MAAM,EAAE,uBAAuB,EAAE,GAAG,wDAAa,wCAAwC,GAAC,CAAC;IAE3F,MAAM,cAAc,GAAG,IAAI,cAAc,CACvC,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,aAAa,CACpB,CAAC;IAEF,OAAO;QACL,cAAc;QACd,aAAa,EAAE,IAAI,aAAa,CAAC,cAAc,CAAC;QAChD,iBAAiB,EAAE,uBAAuB,CAAC,cAAc,CAAC;KAC3D,CAAC;AACJ,CAAC"}
@@ -0,0 +1,41 @@
1
+ export interface BaseLogEntry {
2
+ _id: string;
3
+ tenantId: string;
4
+ userId: string;
5
+ userRole: string;
6
+ ipAddress: string;
7
+ userAgent: string;
8
+ timestamp: Date;
9
+ sessionId: string;
10
+ metadata?: Record<string, any>;
11
+ }
12
+ export interface GeoLocation {
13
+ country?: string;
14
+ region?: string;
15
+ city?: string;
16
+ latitude?: number;
17
+ longitude?: number;
18
+ }
19
+ export interface NetworkInfo {
20
+ connectionType?: string;
21
+ effectiveType?: string;
22
+ downlink?: number;
23
+ rtt?: number;
24
+ }
25
+ export interface BrowserInfo {
26
+ name?: string;
27
+ version?: string;
28
+ os?: string;
29
+ platform?: string;
30
+ }
31
+ export interface PaginationParams {
32
+ page: number;
33
+ limit: number;
34
+ sortBy?: string;
35
+ sortOrder?: 'asc' | 'desc';
36
+ }
37
+ export interface DateRange {
38
+ startDate: Date;
39
+ endDate: Date;
40
+ }
41
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/shared/types/index.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,WAAW;IAC1B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,WAAW;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC;CAC5B;AAED,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/shared/types/index.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,56 @@
1
+ {
2
+ "name": "enterprise-logging-system",
3
+ "version": "1.0.0",
4
+ "description": "Enterprise logging system with idle time tracking for MongoDB/DocumentDB",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist",
9
+ "README.md"
10
+ ],
11
+ "scripts": {
12
+ "build": "tsc",
13
+ "build:frontend": "webpack --config webpack.frontend.config.js",
14
+ "build:backend": "webpack --config webpack.backend.config.js",
15
+ "test": "jest",
16
+ "test:compatibility": "jest --testPathPattern=compatibility",
17
+ "lint": "eslint src --ext .ts",
18
+ "prepare": "npm run build"
19
+ },
20
+ "keywords": [
21
+ "logging",
22
+ "audit",
23
+ "idle-tracking",
24
+ "mongodb",
25
+ "documentdb",
26
+ "enterprise"
27
+ ],
28
+ "author": "Your Company",
29
+ "license": "MIT",
30
+ "dependencies": {
31
+ "express": "^4.18.0",
32
+ "joi": "^17.9.0",
33
+ "mongodb": ">=4.0.0 <5.0.0",
34
+ "uuid": "^9.0.0"
35
+ },
36
+ "devDependencies": {
37
+ "@types/express": "^4.17.0",
38
+ "@types/jest": "^30.0.0",
39
+ "@types/node": "^18.0.0",
40
+ "@types/uuid": "^9.0.0",
41
+ "eslint": "^8.0.0",
42
+ "jest": "^29.0.0",
43
+ "jest-environment-jsdom": "^30.2.0",
44
+ "ts-jest": "^29.0.0",
45
+ "ts-loader": "^9.0.0",
46
+ "typescript": "^5.0.0",
47
+ "webpack": "^5.0.0",
48
+ "webpack-cli": "^5.0.0"
49
+ },
50
+ "peerDependencies": {
51
+ "mongodb": ">=4.0.0 <5.0.0"
52
+ },
53
+ "engines": {
54
+ "node": ">=22.0.0"
55
+ }
56
+ }