-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathservers.js
More file actions
122 lines (84 loc) · 4.33 KB
/
servers.js
File metadata and controls
122 lines (84 loc) · 4.33 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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
const mysql = require("mysql2");
const WebSocket = require('ws');
const ws_server = new WebSocket.Server({ port: 8081 });
require('dotenv').config()
var conn = mysql.createConnection({
host: 'localhost',
user: 'root',
password: process.env.MYSQL_PASSWORD,
database: 'cs223p_server1'
});
conn.connect((err) => {
console.log('Connected to the Server 1 database');
});
const server_report = new WebSocket('ws://localhost:8084');
async function run() {
ws_server.on('connection', (ws) => {
ws.on('message', async (code) => {
console.log(`Server 1 received message => ${code}`);
var args = code.toString().split(';');
if(args[0] == 'T1') {
console.log("T1 started on server 1!");
var sql = "INSERT INTO DOCTOR (first_name, specialization) VALUES('" + args[1] + "', '" + args[2] + "');";
await conn.promise().query(sql);
console.log("T1 completed on server 1");
} else if(args[0] == 'T2') {
console.log("T2 started on server 1!")
var sql = "SELECT PATIENT_ID FROM PATIENT WHERE FIRST_NAME='" + args[1] + "'";
var result = await conn.promise().query(sql);
var p_id = result[0][0]['PATIENT_ID'];
console.log("[T2: Read Patient] Patient ID: " + p_id);
sql = "SELECT DOCTOR_ID FROM DOCTOR WHERE FIRST_NAME='"+ args[2] + "'";
result = await conn.promise().query(sql);
var d_id = result[0][0]['DOCTOR_ID']
console.log("[T2: Read Doctor] Doctor ID: " + d_id);
sql = "INSERT INTO APPOINTMENT (patient_id, doctor_id, appointment_date, appointment_time)" +
" VALUES(" + p_id + ", " + d_id + ", '2024-06-05', '10:00:00');"
await conn.promise().query(sql);
console.log("T2 completed on server 1");
} else if(args[0] == 'T3') {
console.log("T3 started on server 1!")
var sql = "SELECT PATIENT_ID FROM PATIENT WHERE FIRST_NAME='" + args[1] + "'";
var result = await conn.promise().query(sql);
var p_id = result[0][0]['PATIENT_ID'];
console.log("[T3: Read Patient] Patient ID: " + p_id);
var param = "T3;" + p_id;
console.log("[T3] Sending Request to Report Server");
server_report.send(param);
console.log("T3 completed on server 1");
} else if(args[0] == 'T4') {
console.log("T4 started on server 1!")
var sql = "SELECT PATIENT_ID FROM PATIENT WHERE FIRST_NAME='" + args[1] + "'";
var result = await conn.promise().query(sql);
var p_id = result[0][0]['PATIENT_ID'];
var a_id = 1;
var param = "T4;" + p_id + ";" + a_id;
console.log("[T4] Sending Request to Report Server");
server_report.send(param);
console.log("[T4: Read Patient] Patient ID: " + p_id);
console.log("T4 completed on server 1");
} else if(args[0] == 'T6') {
console.log("T6 started on server 1!")
var sql = "SELECT PATIENT_ID FROM PATIENT WHERE FIRST_NAME='" + args[1] + "'";
var result = await conn.promise().query(sql);
var p_id = result[0][0]['PATIENT_ID'];
var a_id = 1;
var param = "T6;" + p_id + ";" + a_id;
console.log("[T6: Read Patient] Patient ID: " + d_id);
console.log("[T6] Sending Request to Report Server");
server_report.send(param);
console.log("T6 completed on server 1");
} else if(args[0] == 'T7') {
console.log("T7 started on server 1!")
var sql = "INSERT INTO PATIENT(FIRST_NAME, AGE) VALUES('" + args[1] + "', 25);";
await conn.promise().query(sql);
console.log("T7 completed on server 1");
}
});
ws.on('close', () => {
console.log('Server 1: Client has disconnected');
});
});
console.log('WebSocket server 1 is running on ws://localhost:8081');
}
run();