-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
81 lines (68 loc) · 2.17 KB
/
server.js
File metadata and controls
81 lines (68 loc) · 2.17 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
require('dotenv').config();
const PROTO_PATH = './proto/client-comm.proto';
const PROTO_PATH_Node = './proto/node-comm.proto';
const PROTO_PATH_GATEWAY = './proto/gateway-comm.proto';
const PROTO_PATH_SENTINEL = './proto/sentinel-comm.proto';
var ip = require("ip");
var {redisClient} = require('./redisClient');
const grpc = require('grpc');
const protoLoader = require('@grpc/proto-loader');
let packageDefinition = protoLoader.loadSync(
PROTO_PATH,
{
keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true
});
let client_comm_proto = grpc.loadPackageDefinition(packageDefinition)
let packageDefinition_node = protoLoader.loadSync(
PROTO_PATH_Node,
{keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true
});
let node_comm_proto = grpc.loadPackageDefinition(packageDefinition_node);
let packageDefinition_gateway = protoLoader.loadSync(
PROTO_PATH_GATEWAY,
{keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true
});
let gateway_comm_proto = grpc.loadPackageDefinition(packageDefinition_gateway).stream;
let packageDefinition_sentinel = protoLoader.loadSync(
PROTO_PATH_SENTINEL,
{keepCase: true,
longs: String,
enums: String,
defaults: true,
oneofs: true
});
let sentinel_comm_proto = grpc.loadPackageDefinition(packageDefinition_sentinel);
let { UploadFile } = require('./UploadFile.js');
let { CreateReplica } = require('./CreateReplica.js');
let { ReplicateFile } = require('./ReplicateFile.js');
let { DownloadFile } = require('./DownloadFile.js');
async function main() {
let server = new grpc.Server();
server.addService(client_comm_proto.stream.Streaming.service,
{UploadFile: UploadFile,
DownloadFile: DownloadFile
}
);
server.addService(node_comm_proto.stream.NodeReplication.service,
{CreateReplica: CreateReplica,
ReplicateFile: ReplicateFile }
);
server.addService(sentinel_comm_proto.stream.SentinelMonitoring.service,
{ healthCheck: (call, callback) => {callback(null, {status: "SUCCESS"})} }
);
server.bind('0.0.0.0:6080', grpc.ServerCredentials.createInsecure());
server.start();
}
main();