-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
62 lines (51 loc) · 1.64 KB
/
server.js
File metadata and controls
62 lines (51 loc) · 1.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import mysql from 'mysql2/promise';
import express from 'express';
import sequelize from './app/Model/dbConfig.js';
import './app/Model/index.js';
import companyRoutes from './app/Routes/companyRoute.js';
import catRoutes from './app/Routes/categoryRoute.js';
import custRoutes from './app/Routes/costumerRoute.js';
import prodRoutes from './app/Routes/productRoute.js'
import salesRoute from './app/Routes/salesRoute.js'
import userRout from './app/Routes/userRoute.js'
import adminRout from './app/Routes/adminRoute.js'
const DB_HOST = 'localhost';
const DB_USER = 'root';
const DB_PASS = '';
const DB_NAME = 'Bill_table';
async function ensureDatabase() {
const connection = await mysql.createConnection({
host: DB_HOST,
user: DB_USER,
password: DB_PASS,
});
await connection.query(`CREATE DATABASE IF NOT EXISTS \`${DB_NAME}\`;`);
await connection.end();
}
const app = express();
app.use(express.json());
app.get('/', (req, res) => {
res.send('Welcome to server');
});
app.use('/admin', adminRout);
app.use('/companies', companyRoutes);
app.use('/categories', catRoutes);
app.use('/customers', custRoutes);
app.use('/products', prodRoutes);
app.use('/uploads', express.static('uploads'));
app.use('/sales', salesRoute);
app.use('/users', userRout);
const PORT = process.env.PORT || 3000;
const startServer = async () => {
try {
await ensureDatabase();
await sequelize.sync({ alter: true });
console.log('All models synchronized.');
app.listen(PORT, () => {
console.log(`Server is running on http://localhost:${PORT}`);
});
} catch (err) {
console.error('DB connection failed:', err);
}
};
startServer();