You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

144 lines
4.0 KiB

4 years ago
var express = require('express');
var expressWs = require('express-ws');
var router = express.Router();
var redis = require('redis');
4 years ago
var md5 = require('md5');
4 years ago
var mysql = require('mysql');
4 years ago
4 years ago
/* mysql start */
var sql = mysql.createConnection(require('/mnt/config/dbKeys/auth.js'));
sql.connect();
4 years ago
/* redis start */
4 years ago
var rc = new redis.createClient({
host: 'redis'
});
4 years ago
4 years ago
4 years ago
var getAddress = (mask) => {
return new Promise((resolve, reject)=>{
sql.query("SELECT * FROM mask where mask=?", [mask], (err, res, fields)=>{
if(err || !res){
resolve(null);
return;
}
var token = res[0]['token'];
sql.query("SELECT * FROM token where token=?", [token], (err, res, fields)=>{
if(err || !res){
resolve(token);
return;
}
if(!res[0]['state']){
resolve(token);
return;
}
var hash = res[0]['hash'];
resolve(hash);
})
});
4 years ago
});
}
4 years ago
router.get('/set', async function(req, res, next) {
4 years ago
res.header('Access-Control-Allow-Origin', '*');
4 years ago
if(!req.query.key || !req.query.val || !req.query.t || !req.query.mask) {res.send({"code":"500"});;return;}
let hash = await getAddress(req.query.mask);
4 years ago
rc.hset('session/dialog/'+hash, req.query.key, req.query.val);
rc.hset('session/dialog/'+hash, 'LastOperateTime', req.query.t);
4 years ago
res.send({code:"200"});
});
4 years ago
router.get('/del', async function(req, res, next) {
4 years ago
res.header('Access-Control-Allow-Origin', '*');
4 years ago
if(!req.query.del || !req.query.mask || !req.query.t) {res.send({"code":"500"});;return;}
4 years ago
4 years ago
let hash = await getAddress(req.query.mask);
4 years ago
rc.hdel('session/dialog/'+hash, req.query.del);
rc.hset('session/dialog/'+hash, 'LastOperateTime', req.query.t);
4 years ago
res.send({code:"200"});
});
4 years ago
router.get('/get', async function(req, res, next) {
4 years ago
res.header('Access-Control-Allow-Origin', '*');
4 years ago
if(!req.query.mask) {res.send({"code":"500"});;return;}
let hash = await getAddress(req.query.mask);
4 years ago
var o = {};
4 years ago
rc.hkeys('session/dialog/'+hash, function(err, keys){
4 years ago
if(!err){
if(!keys.length){
res.send(o);
}
keys.forEach(function(key, i){
4 years ago
rc.hget('session/dialog/'+hash, key, function(err2, val){
4 years ago
if(!err2){
o[key] = val;
if(i == keys.length - 1){
res.send(o);
}
}
})
});
}
});
});
expressWs(router);
router
4 years ago
.ws('/', async function (ws, req){
4 years ago
if(req.query.mask){
var hash = await getAddress(req.query.mask);
4 years ago
}else{
ws.close();
}
4 years ago
ws.on('message', async function (msg) {
4 years ago
if(msg == 'get'){
var o = {};
4 years ago
rc.hkeys('session/dialog/'+hash, function(err, keys){
4 years ago
if(!err){
keys.forEach(function(key, i){
4 years ago
rc.hget('session/dialog/'+hash, key, function(err2, val){
4 years ago
if(!err2){
o[key] = val;
if(i == keys.length - 1){
ws.send(JSON.stringify(o));
}
}
})
});
}
});
}else if(isJson(msg)){
obj = JSON.parse(msg);
if(obj.del && obj.t){
4 years ago
rc.hdel('session/dialog/'+hash, obj.del);
rc.hset('session/dialog/'+hash, 'LastOperateTime', obj.t);
4 years ago
}
if(obj.key && obj.val && obj.t){
4 years ago
rc.hset('session/dialog/'+hash, obj.key, obj.val);
rc.hset('session/dialog/'+hash, 'LastOperateTime', obj.t);
4 years ago
}
}
})
})
module.exports = router;
function isJson(str) {
try {
if (typeof JSON.parse(str) == "object") {
return true;
}
} catch(e) {
}
return false;
}