forked from 0oM4R/LitFair-Server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreceive.js
111 lines (82 loc) · 3.05 KB
/
receive.js
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
const amqp = require('amqplib/callback_api');
const mongoose = require('mongoose');
const ObjectId = require('mongoose').Types.ObjectId;
require('dotenv').config();
const env = {
job_DB: process.env.job_DB,
// rabbitMQ
MQ_URL: process.env.MQ_URL,
PUBLISH_VIDEOMQ_NAME: process.env.PUBLISH_VIDEOMQ_NAME,
CONSUME_VIDEOMQ_NAME: process.env.CONSUME_VIDEOMQ_NAME,
CONSUME_CVMQ_NAME: process.env.CONSUME_CVMQ_NAME,
};
const appModel = (async (_id, predictions) => {
mongoose.connect(env.job_DB).then(async(connection)=>{
//const connection = mongoose.connection;
let doc = await mongoose.connection.collection('applications').find({_id: ObjectId(_id.appId)}).toArray();
doc = doc[0];
let update = {};
let total_score = 0;
for(const [key, value] of Object.entries(predictions)){
const inc = parseFloat(doc.feedback_1[key])+ parseFloat(value);
console.log(`${key}: ${value}`)
if(inc>=0.0){
total_score+= inc;
update[key] = Math.round( inc * 100) / 100;
}
}
update.total_score = Math.round( total_score * 100) / 100;
res = await mongoose.connection.collection('applications').updateOne({_id: ObjectId(_id.appId)}, {$set:{feedback_1:update, 'progress.feedback_1': true}});
connection.disconnect();
console.log(res);
})
});
async function receive() {
try {
amqp.connect(env.MQ_URL, function(error0, connection) {
if (error0) {
throw error0;
}
connection.createChannel(function(error1, channel) {
if (error1) {
throw error1;
}
channel.assertQueue(env.CONSUME_VIDEOMQ_NAME, {
durable: true
});
console.log("[x] Jobs queue Waiting for messages. To exit press CTRL+C");
channel.consume(env.CONSUME_VIDEOMQ_NAME, function(msg) {
const obj = JSON.parse(msg.content);
appModel(obj._id, obj.predictions);
console.log(" [x] Received %s", msg.content.toString());
channel.ack(msg);
},
{
noAck: false
});
});
//CV connection
connection.createChannel(function(error2, channel2) {
if (error2) {
throw error2;
}
channel2.assertQueue(env.CONSUME_CVMQ_NAME, {
durable: true
});
console.log("[x] CV queue Waiting for messages. To exit press CTRL+C");
channel2.consume(env.CONSUME_CVMQ_NAME, function(msg) {
const obj = JSON.parse(msg.content);
appModel(obj._id, obj.predictions);
console.log(" [x] Received %s", msg.content.toString());
channel2.ack(msg);
},
{
noAck: false
});
});
});
} catch (e) {
console.log(e)
}
}
receive();