@manojkmfsi/monodog 1.0.23 → 1.0.25

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 (74) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +12 -0
  3. package/dist/controllers/{commitController.js → commit-controller.js} +5 -4
  4. package/dist/controllers/{configController.js → config-controller.js} +3 -3
  5. package/dist/controllers/{healthController.js → health-controller.js} +3 -3
  6. package/dist/controllers/{packageController.js → package-controller.js} +6 -6
  7. package/dist/index.js +11 -236
  8. package/dist/middleware/dashboard-startup.js +124 -0
  9. package/dist/middleware/error-handler.js +36 -0
  10. package/dist/middleware/index.js +23 -0
  11. package/dist/middleware/logger.js +63 -0
  12. package/dist/middleware/security.js +78 -0
  13. package/dist/middleware/server-startup.js +117 -0
  14. package/dist/repositories/commit-repository.js +97 -0
  15. package/dist/repositories/dependency-repository.js +97 -0
  16. package/dist/repositories/index.js +18 -0
  17. package/dist/repositories/package-health-repository.js +65 -0
  18. package/dist/repositories/package-repository.js +126 -0
  19. package/dist/repositories/prisma-client.js +57 -0
  20. package/dist/routes/{commitRoutes.js → commit-routes.js} +2 -2
  21. package/dist/routes/{configRoutes.js → config-routes.js} +3 -3
  22. package/dist/routes/{healthRoutes.js → health-routes.js} +3 -3
  23. package/dist/routes/{packageRoutes.js → package-routes.js} +5 -5
  24. package/dist/serve.js +15 -2
  25. package/dist/services/{commitService.js → commit-service.js} +2 -2
  26. package/dist/services/{configService.js → config-service.js} +2 -40
  27. package/dist/services/{healthService.js → health-service.js} +11 -63
  28. package/dist/services/{packageService.js → package-service.js} +80 -54
  29. package/dist/types/git.js +11 -0
  30. package/dist/types/index.js +1 -0
  31. package/package.json +10 -3
  32. package/prisma/schema/commit.prisma +11 -0
  33. package/prisma/schema/dependency-info.prisma +12 -0
  34. package/prisma/schema/health-status.prisma +14 -0
  35. package/prisma/schema/package-health.prisma +15 -0
  36. package/prisma/schema/package.prisma +21 -0
  37. package/prisma/schema/schema.prisma +15 -0
  38. package/src/controllers/{commitController.ts → commit-controller.ts} +7 -5
  39. package/src/controllers/{configController.ts → config-controller.ts} +4 -3
  40. package/src/controllers/{healthController.ts → health-controller.ts} +4 -3
  41. package/src/controllers/{packageController.ts → package-controller.ts} +7 -6
  42. package/src/index.ts +9 -281
  43. package/src/middleware/dashboard-startup.ts +149 -0
  44. package/src/middleware/error-handler.ts +50 -0
  45. package/src/middleware/index.ts +20 -0
  46. package/src/middleware/logger.ts +58 -0
  47. package/src/middleware/security.ts +81 -0
  48. package/src/middleware/server-startup.ts +142 -0
  49. package/src/repositories/commit-repository.ts +107 -0
  50. package/src/repositories/dependency-repository.ts +109 -0
  51. package/src/repositories/index.ts +10 -0
  52. package/src/repositories/package-health-repository.ts +75 -0
  53. package/src/repositories/package-repository.ts +142 -0
  54. package/src/repositories/prisma-client.ts +25 -0
  55. package/src/routes/{commitRoutes.ts → commit-routes.ts} +1 -1
  56. package/src/routes/{configRoutes.ts → config-routes.ts} +1 -1
  57. package/src/routes/{healthRoutes.ts → health-routes.ts} +1 -1
  58. package/src/routes/{packageRoutes.ts → package-routes.ts} +1 -1
  59. package/src/serve.ts +19 -3
  60. package/src/services/{commitService.ts → commit-service.ts} +1 -1
  61. package/src/services/{configService.ts → config-service.ts} +22 -9
  62. package/src/services/{gitService.ts → git-service.ts} +4 -4
  63. package/src/services/{healthService.ts → health-service.ts} +17 -35
  64. package/src/services/package-service.ts +201 -0
  65. package/src/types/database.ts +57 -1
  66. package/src/types/git.ts +8 -8
  67. package/src/types/index.ts +1 -1
  68. package/dist/utils/db-utils.js +0 -227
  69. package/prisma/schema.prisma +0 -116
  70. package/src/services/packageService.ts +0 -115
  71. package/src/types/monorepo-scanner.d.ts +0 -32
  72. package/src/utils/db-utils.ts +0 -220
  73. /package/dist/services/{gitService.js → git-service.js} +0 -0
  74. /package/prisma/migrations/{20251219074511_create_unique_composite_key_for_commits → 20251219090102_composite_key_for_table_commits}/migration.sql +0 -0
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ /**
3
+ * Security middleware and configuration
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.createHelmetMiddleware = createHelmetMiddleware;
10
+ exports.createApiCorsMiddleware = createApiCorsMiddleware;
11
+ exports.createDashboardCorsMiddleware = createDashboardCorsMiddleware;
12
+ exports.createTimeoutMiddleware = createTimeoutMiddleware;
13
+ exports.buildApiUrl = buildApiUrl;
14
+ exports.buildDashboardUrl = buildDashboardUrl;
15
+ const helmet_1 = __importDefault(require("helmet"));
16
+ const cors_1 = __importDefault(require("cors"));
17
+ /**
18
+ * Create Helmet security middleware with Content Security Policy
19
+ */
20
+ function createHelmetMiddleware(apiUrl) {
21
+ return (0, helmet_1.default)({
22
+ contentSecurityPolicy: {
23
+ directives: {
24
+ defaultSrc: ["'self'"],
25
+ connectSrc: ["'self'", apiUrl, 'http://localhost:*', 'http://127.0.0.1:*'],
26
+ scriptSrc: ["'self'"],
27
+ imgSrc: ["'self'", 'data:', 'https:'],
28
+ },
29
+ },
30
+ });
31
+ }
32
+ /**
33
+ * Create CORS middleware for API server
34
+ */
35
+ function createApiCorsMiddleware(dashboardUrl) {
36
+ const corsOptions = {
37
+ origin: dashboardUrl,
38
+ credentials: true,
39
+ methods: ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS'],
40
+ allowedHeaders: ['Content-Type', 'Authorization'],
41
+ };
42
+ return (0, cors_1.default)(corsOptions);
43
+ }
44
+ /**
45
+ * Create CORS middleware for dashboard (no cross-origin)
46
+ */
47
+ function createDashboardCorsMiddleware() {
48
+ const corsOptions = {
49
+ origin: false, // Don't allow any origin for static assets
50
+ };
51
+ return (0, cors_1.default)(corsOptions);
52
+ }
53
+ /**
54
+ * Request timeout middleware (30 seconds)
55
+ */
56
+ function createTimeoutMiddleware() {
57
+ return (req, res, next) => {
58
+ req.setTimeout(30000);
59
+ res.setTimeout(30000);
60
+ next();
61
+ };
62
+ }
63
+ /**
64
+ * Build API URL based on config
65
+ */
66
+ function buildApiUrl(host, port) {
67
+ const apiHost = host === '0.0.0.0' ? 'localhost' : host;
68
+ return `http://${apiHost}:${port}`;
69
+ }
70
+ /**
71
+ * Build dashboard URL based on config
72
+ */
73
+ function buildDashboardUrl(config) {
74
+ const dashboardHost = config.dashboard.host === '0.0.0.0'
75
+ ? 'localhost'
76
+ : config.dashboard.host;
77
+ return `http://${dashboardHost}:${config.dashboard.port}`;
78
+ }
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+ /**
3
+ * Server startup logic for the API backend
4
+ */
5
+ var __importDefault = (this && this.__importDefault) || function (mod) {
6
+ return (mod && mod.__esModule) ? mod : { "default": mod };
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.startServer = startServer;
10
+ const express_1 = __importDefault(require("express"));
11
+ const body_parser_1 = require("body-parser");
12
+ const logger_1 = require("./logger");
13
+ const config_loader_1 = require("../config-loader");
14
+ const error_handler_1 = require("./error-handler");
15
+ const security_1 = require("./security");
16
+ const package_routes_1 = __importDefault(require("../routes/package-routes"));
17
+ const commit_routes_1 = __importDefault(require("../routes/commit-routes"));
18
+ const health_routes_1 = __importDefault(require("../routes/health-routes"));
19
+ const config_routes_1 = __importDefault(require("../routes/config-routes"));
20
+ // Security constants
21
+ const PORT_MIN = 1024;
22
+ const PORT_MAX = 65535;
23
+ /**
24
+ * Validate port number
25
+ */
26
+ function validatePort(port) {
27
+ const portNum = typeof port === 'string' ? parseInt(port, 10) : port;
28
+ if (isNaN(portNum) || portNum < PORT_MIN || portNum > PORT_MAX) {
29
+ throw new Error(`Port must be between ${PORT_MIN} and ${PORT_MAX}`);
30
+ }
31
+ return portNum;
32
+ }
33
+ /**
34
+ * Create Express app with middleware configuration
35
+ */
36
+ function createApp(rootPath) {
37
+ const app = (0, express_1.default)();
38
+ // Timeout middleware
39
+ app.use((0, security_1.createTimeoutMiddleware)());
40
+ // Store root path for routes
41
+ app.locals.rootPath = rootPath;
42
+ // Security and CORS setup
43
+ const dashboardUrl = (0, security_1.buildDashboardUrl)(config_loader_1.appConfig);
44
+ const apiUrl = (0, security_1.buildApiUrl)(config_loader_1.appConfig.server.host, config_loader_1.appConfig.server.port);
45
+ app.use((0, security_1.createHelmetMiddleware)(apiUrl));
46
+ app.use((0, security_1.createApiCorsMiddleware)(dashboardUrl));
47
+ // Body parser
48
+ app.use((0, body_parser_1.json)({ limit: '1mb' }));
49
+ // HTTP request logging with Morgan
50
+ app.use(logger_1.httpLogger);
51
+ // Routes
52
+ app.use('/api/packages', package_routes_1.default);
53
+ app.use('/api/commits/', commit_routes_1.default);
54
+ app.use('/api/health/', health_routes_1.default);
55
+ app.use('/api/config/', config_routes_1.default);
56
+ // 404 handler
57
+ app.use('*', error_handler_1.notFoundHandler);
58
+ // Global error handler (must be last)
59
+ app.use(error_handler_1.errorHandler);
60
+ return app;
61
+ }
62
+ /**
63
+ * Start the API server
64
+ */
65
+ function startServer(rootPath) {
66
+ try {
67
+ const port = config_loader_1.appConfig.server.port;
68
+ const host = config_loader_1.appConfig.server.host;
69
+ const validatedPort = validatePort(port);
70
+ logger_1.AppLogger.info(`Starting Monodog API server...`);
71
+ logger_1.AppLogger.info(`Analyzing monorepo at root: ${rootPath}`);
72
+ const app = createApp(rootPath);
73
+ const server = app.listen(validatedPort, host, () => {
74
+ console.log(`Backend server listening on http://${host}:${validatedPort}`);
75
+ logger_1.AppLogger.info('API endpoints available:', {
76
+ endpoints: [
77
+ 'GET /api/health',
78
+ 'GET /api/packages/refresh',
79
+ 'GET /api/packages',
80
+ 'GET /api/packages/:name',
81
+ 'PUT /api/packages/update-config',
82
+ 'GET /api/commits/:packagePath',
83
+ 'GET /api/health/packages',
84
+ 'PUT /api/config/files/:id',
85
+ 'GET /api/config/files',
86
+ ],
87
+ });
88
+ });
89
+ server.on('error', (err) => {
90
+ if (err.code === 'EADDRINUSE') {
91
+ logger_1.AppLogger.error(`Port ${validatedPort} is already in use. Please specify a different port.`, err);
92
+ process.exit(1);
93
+ }
94
+ else if (err.code === 'EACCES') {
95
+ logger_1.AppLogger.error(`Permission denied to listen on port ${validatedPort}. Use a port above 1024.`, err);
96
+ process.exit(1);
97
+ }
98
+ else {
99
+ logger_1.AppLogger.error('Server failed to start:', err);
100
+ process.exit(1);
101
+ }
102
+ });
103
+ // Graceful shutdown
104
+ process.on('SIGTERM', () => {
105
+ logger_1.AppLogger.info('SIGTERM signal received: closing HTTP server');
106
+ server.close(() => {
107
+ logger_1.AppLogger.info('HTTP server closed');
108
+ process.exit(0);
109
+ });
110
+ });
111
+ }
112
+ catch (error) {
113
+ const err = error;
114
+ logger_1.AppLogger.error('Failed to start server:', err);
115
+ process.exit(1);
116
+ }
117
+ }
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CommitRepository = void 0;
4
+ const prisma_client_1 = require("./prisma-client");
5
+ const prisma = (0, prisma_client_1.getPrismaClient)();
6
+ const Prisma = (0, prisma_client_1.getPrismaErrors)();
7
+ /**
8
+ * Commit Repository - Handles all Commit-related database operations
9
+ */
10
+ class CommitRepository {
11
+ /**
12
+ * Find all commits for a package
13
+ */
14
+ static async findByPackageName(packageName) {
15
+ return await prisma.commit.findMany({
16
+ where: { packageName },
17
+ });
18
+ }
19
+ /**
20
+ * Find a specific commit
21
+ */
22
+ static async findByHash(hash, packageName) {
23
+ return await prisma.commit.findUnique({
24
+ where: {
25
+ hash_packageName: {
26
+ hash,
27
+ packageName,
28
+ },
29
+ },
30
+ });
31
+ }
32
+ /**
33
+ * Create or update a commit
34
+ */
35
+ static async upsert(data) {
36
+ try {
37
+ return await prisma.commit.upsert({
38
+ where: {
39
+ hash_packageName: {
40
+ hash: data.hash,
41
+ packageName: data.packageName,
42
+ },
43
+ },
44
+ update: {
45
+ message: data.message || '',
46
+ author: data.author || '',
47
+ date: data.date,
48
+ type: data.type || '',
49
+ },
50
+ create: {
51
+ hash: data.hash,
52
+ message: data.message || '',
53
+ author: data.author || '',
54
+ date: data.date,
55
+ type: data.type || '',
56
+ packageName: data.packageName,
57
+ },
58
+ });
59
+ }
60
+ catch (e) {
61
+ const err = e;
62
+ if (err instanceof Prisma.PrismaClientKnownRequestError &&
63
+ err.code === 'P2002') {
64
+ console.warn(`Skipping commit: ${data.hash} (Commit already exists)`);
65
+ }
66
+ else {
67
+ console.error(`Failed to store commit: ${data.hash}`, err);
68
+ throw err;
69
+ }
70
+ }
71
+ }
72
+ /**
73
+ * Store multiple commits
74
+ */
75
+ static async storeMany(packageName, commits) {
76
+ console.log('Storing commits for: ' + packageName);
77
+ for (const commit of commits) {
78
+ await this.upsert({
79
+ hash: commit.hash,
80
+ message: commit.message,
81
+ author: commit.author,
82
+ date: commit.date,
83
+ type: commit.type,
84
+ packageName,
85
+ });
86
+ }
87
+ }
88
+ /**
89
+ * Delete all commits for a package
90
+ */
91
+ static async deleteByPackageName(packageName) {
92
+ return await prisma.commit.deleteMany({
93
+ where: { packageName },
94
+ });
95
+ }
96
+ }
97
+ exports.CommitRepository = CommitRepository;
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DependencyRepository = void 0;
4
+ const prisma_client_1 = require("./prisma-client");
5
+ const prisma = (0, prisma_client_1.getPrismaClient)();
6
+ const Prisma = (0, prisma_client_1.getPrismaErrors)();
7
+ /**
8
+ * Dependency Repository - Handles all DependencyInfo-related database operations
9
+ */
10
+ class DependencyRepository {
11
+ /**
12
+ * Find all dependencies for a package
13
+ */
14
+ static async findByPackageName(packageName) {
15
+ return await prisma.dependencyInfo.findMany({
16
+ where: { packageName },
17
+ });
18
+ }
19
+ /**
20
+ * Find a specific dependency
21
+ */
22
+ static async findByNameAndPackage(name, packageName) {
23
+ return await prisma.dependencyInfo.findUnique({
24
+ where: {
25
+ name_packageName: {
26
+ name,
27
+ packageName,
28
+ },
29
+ },
30
+ });
31
+ }
32
+ /**
33
+ * Create or update a dependency
34
+ */
35
+ static async upsert(data) {
36
+ try {
37
+ return await prisma.dependencyInfo.upsert({
38
+ where: {
39
+ name_packageName: {
40
+ name: data.name,
41
+ packageName: data.packageName,
42
+ },
43
+ },
44
+ update: {
45
+ version: data.version,
46
+ type: data.type,
47
+ latest: data.latest || '',
48
+ outdated: data.outdated ?? false,
49
+ },
50
+ create: {
51
+ name: data.name,
52
+ version: data.version,
53
+ type: data.type,
54
+ latest: data.latest || '',
55
+ outdated: data.outdated ?? false,
56
+ packageName: data.packageName,
57
+ },
58
+ });
59
+ }
60
+ catch (e) {
61
+ const err = e;
62
+ if (err instanceof Prisma.PrismaClientKnownRequestError &&
63
+ err.code === 'P2002') {
64
+ console.warn(`Skipping dependency: ${data.name} (Dependency already exists)`);
65
+ }
66
+ else {
67
+ console.error(`Failed to store dependency: ${data.name}`, err);
68
+ throw err;
69
+ }
70
+ }
71
+ }
72
+ /**
73
+ * Store multiple dependencies
74
+ */
75
+ static async storeMany(packageName, dependencies) {
76
+ console.log('Storing Dependencies for: ' + packageName);
77
+ for (const dep of dependencies) {
78
+ await this.upsert({
79
+ name: dep.name,
80
+ version: dep.version,
81
+ type: dep.type,
82
+ latest: dep.latest,
83
+ outdated: dep.outdated,
84
+ packageName,
85
+ });
86
+ }
87
+ }
88
+ /**
89
+ * Delete all dependencies for a package
90
+ */
91
+ static async deleteByPackageName(packageName) {
92
+ return await prisma.dependencyInfo.deleteMany({
93
+ where: { packageName },
94
+ });
95
+ }
96
+ }
97
+ exports.DependencyRepository = DependencyRepository;
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ /**
3
+ * Repository Pattern Index
4
+ * Exports all repositories for data access layer
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.getPrismaErrors = exports.getPrismaClient = exports.DependencyRepository = exports.CommitRepository = exports.PackageHealthRepository = exports.PackageRepository = void 0;
8
+ var package_repository_1 = require("./package-repository");
9
+ Object.defineProperty(exports, "PackageRepository", { enumerable: true, get: function () { return package_repository_1.PackageRepository; } });
10
+ var package_health_repository_1 = require("./package-health-repository");
11
+ Object.defineProperty(exports, "PackageHealthRepository", { enumerable: true, get: function () { return package_health_repository_1.PackageHealthRepository; } });
12
+ var commit_repository_1 = require("./commit-repository");
13
+ Object.defineProperty(exports, "CommitRepository", { enumerable: true, get: function () { return commit_repository_1.CommitRepository; } });
14
+ var dependency_repository_1 = require("./dependency-repository");
15
+ Object.defineProperty(exports, "DependencyRepository", { enumerable: true, get: function () { return dependency_repository_1.DependencyRepository; } });
16
+ var prisma_client_1 = require("./prisma-client");
17
+ Object.defineProperty(exports, "getPrismaClient", { enumerable: true, get: function () { return prisma_client_1.getPrismaClient; } });
18
+ Object.defineProperty(exports, "getPrismaErrors", { enumerable: true, get: function () { return prisma_client_1.getPrismaErrors; } });
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PackageHealthRepository = void 0;
4
+ const prisma_client_1 = require("./prisma-client");
5
+ const prisma = (0, prisma_client_1.getPrismaClient)();
6
+ /**
7
+ * Package Health Repository - Handles all PackageHealth-related database operations
8
+ */
9
+ class PackageHealthRepository {
10
+ /**
11
+ * Find all package health records
12
+ */
13
+ static async findAll() {
14
+ return await prisma.packageHealth.findMany();
15
+ }
16
+ /**
17
+ * Find package health by package name
18
+ */
19
+ static async findByPackageName(packageName) {
20
+ return await prisma.packageHealth.findUnique({
21
+ where: { packageName },
22
+ });
23
+ }
24
+ /**
25
+ * Create or update package health record
26
+ */
27
+ static async upsert(data) {
28
+ return await prisma.packageHealth.upsert({
29
+ where: { packageName: data.packageName },
30
+ update: {
31
+ packageOverallScore: data.packageOverallScore,
32
+ packageBuildStatus: data.packageBuildStatus,
33
+ packageTestCoverage: data.packageTestCoverage,
34
+ packageLintStatus: data.packageLintStatus,
35
+ packageSecurity: data.packageSecurity,
36
+ packageDependencies: data.packageDependencies || '',
37
+ updatedAt: new Date(),
38
+ },
39
+ create: {
40
+ packageName: data.packageName,
41
+ packageOverallScore: data.packageOverallScore,
42
+ packageBuildStatus: data.packageBuildStatus,
43
+ packageTestCoverage: data.packageTestCoverage,
44
+ packageLintStatus: data.packageLintStatus,
45
+ packageSecurity: data.packageSecurity,
46
+ packageDependencies: data.packageDependencies || '',
47
+ },
48
+ });
49
+ }
50
+ /**
51
+ * Delete package health record
52
+ */
53
+ static async deleteByPackageName(packageName) {
54
+ return await prisma.packageHealth.delete({
55
+ where: { packageName },
56
+ });
57
+ }
58
+ /**
59
+ * Delete all package health records
60
+ */
61
+ static async deleteAll() {
62
+ return await prisma.packageHealth.deleteMany();
63
+ }
64
+ }
65
+ exports.PackageHealthRepository = PackageHealthRepository;
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PackageRepository = void 0;
4
+ const prisma_client_1 = require("./prisma-client");
5
+ const prisma = (0, prisma_client_1.getPrismaClient)();
6
+ /**
7
+ * Package Repository - Handles all Package-related database operations
8
+ */
9
+ class PackageRepository {
10
+ /**
11
+ * Find all packages
12
+ */
13
+ static async findAll() {
14
+ return await prisma.package.findMany();
15
+ }
16
+ /**
17
+ * Find a package by name
18
+ */
19
+ static async findByName(name) {
20
+ return await prisma.package.findUnique({
21
+ where: { name },
22
+ });
23
+ }
24
+ /**
25
+ * Find a package with related data
26
+ */
27
+ static async findByNameWithRelations(name) {
28
+ return await prisma.package.findUnique({
29
+ where: { name },
30
+ include: {
31
+ dependenciesInfo: true,
32
+ commits: true,
33
+ packageHealth: true,
34
+ },
35
+ });
36
+ }
37
+ /**
38
+ * Create or update a package
39
+ */
40
+ static async upsert(data) {
41
+ const createData = {
42
+ createdAt: new Date(),
43
+ lastUpdated: new Date(),
44
+ dependencies: JSON.stringify(data.dependencies || {}),
45
+ maintainers: typeof data.maintainers === 'string' ? data.maintainers : '',
46
+ scripts: JSON.stringify(data.scripts || {}),
47
+ devDependencies: JSON.stringify(data.devDependencies || {}),
48
+ peerDependencies: JSON.stringify(data.peerDependencies || {}),
49
+ name: data.name,
50
+ version: data.version || '',
51
+ type: data.type || '',
52
+ path: data.path || '',
53
+ description: data.description || '',
54
+ license: data.license || '',
55
+ repository: JSON.stringify(data.repository || {}),
56
+ status: data.status || '',
57
+ };
58
+ const updateData = {
59
+ version: data.version,
60
+ type: data.type,
61
+ path: data.path,
62
+ description: data.description,
63
+ license: data.license,
64
+ repository: JSON.stringify(data.repository || {}),
65
+ scripts: JSON.stringify(data.scripts || {}),
66
+ lastUpdated: new Date(),
67
+ };
68
+ return await prisma.package.upsert({
69
+ where: { name: data.name },
70
+ create: createData,
71
+ update: updateData,
72
+ });
73
+ }
74
+ /**
75
+ * Update package status
76
+ */
77
+ static async updateStatus(name, status) {
78
+ return await prisma.package.update({
79
+ where: { name },
80
+ data: { status },
81
+ });
82
+ }
83
+ /**
84
+ * Update package configuration
85
+ */
86
+ static async updateConfig(name, updateData) {
87
+ const data = {
88
+ lastUpdated: new Date(),
89
+ };
90
+ if (updateData.version)
91
+ data.version = updateData.version;
92
+ if (updateData.description !== undefined)
93
+ data.description = updateData.description || '';
94
+ if (updateData.license !== undefined)
95
+ data.license = updateData.license || '';
96
+ if (updateData.scripts)
97
+ data.scripts = JSON.stringify(updateData.scripts);
98
+ if (updateData.repository)
99
+ data.repository = JSON.stringify(updateData.repository);
100
+ if (updateData.dependencies)
101
+ data.dependencies = JSON.stringify(updateData.dependencies);
102
+ if (updateData.devDependencies)
103
+ data.devDependencies = JSON.stringify(updateData.devDependencies);
104
+ if (updateData.peerDependencies)
105
+ data.peerDependencies = JSON.stringify(updateData.peerDependencies);
106
+ return await prisma.package.update({
107
+ where: { name },
108
+ data,
109
+ });
110
+ }
111
+ /**
112
+ * Delete all packages
113
+ */
114
+ static async deleteAll() {
115
+ return await prisma.package.deleteMany();
116
+ }
117
+ /**
118
+ * Delete a package by name
119
+ */
120
+ static async deleteByName(name) {
121
+ return await prisma.package.delete({
122
+ where: { name },
123
+ });
124
+ }
125
+ }
126
+ exports.PackageRepository = PackageRepository;
@@ -0,0 +1,57 @@
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 __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.getPrismaClient = getPrismaClient;
37
+ exports.getPrismaErrors = getPrismaErrors;
38
+ const PrismaPkg = __importStar(require("@prisma/client"));
39
+ const PrismaClient = PrismaPkg.PrismaClient || PrismaPkg.default || PrismaPkg;
40
+ const Prisma = PrismaPkg.Prisma || PrismaPkg.PrismaClient?.Prisma || PrismaPkg.default?.Prisma || PrismaPkg;
41
+ let prismaInstance = null;
42
+ /**
43
+ * Get singleton instance of Prisma Client
44
+ */
45
+ function getPrismaClient() {
46
+ if (!prismaInstance) {
47
+ prismaInstance = new PrismaClient();
48
+ }
49
+ return prismaInstance;
50
+ }
51
+ /**
52
+ * Get Prisma error classes for error handling
53
+ */
54
+ function getPrismaErrors() {
55
+ return Prisma;
56
+ }
57
+ exports.default = getPrismaClient;
@@ -4,9 +4,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const express_1 = __importDefault(require("express"));
7
- const commitController_1 = require("../controllers/commitController");
7
+ const commit_controller_1 = require("../controllers/commit-controller");
8
8
  const commitRouter = express_1.default.Router();
9
9
  commitRouter
10
10
  .route('/:packagePath')
11
- .get(commitController_1.getCommitsByPath);
11
+ .get(commit_controller_1.getCommitsByPath);
12
12
  exports.default = commitRouter;
@@ -4,12 +4,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const express_1 = __importDefault(require("express"));
7
- const configController_1 = require("../controllers/configController");
7
+ const config_controller_1 = require("../controllers/config-controller");
8
8
  const configRouter = express_1.default.Router();
9
9
  configRouter
10
10
  .route('/files')
11
- .get(configController_1.getConfigurationFiles);
11
+ .get(config_controller_1.getConfigurationFiles);
12
12
  configRouter
13
13
  .route('/files/:id')
14
- .put(configController_1.updateConfigFile);
14
+ .put(config_controller_1.updateConfigFile);
15
15
  exports.default = configRouter;