forked from smogon/pokemon-showdown
-
Notifications
You must be signed in to change notification settings - Fork 0
/
verifier.js
63 lines (53 loc) · 1.69 KB
/
verifier.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
/**
* Verifier process
* Pokemon Showdown - http://pokemonshowdown.com/
*
* This is just an asynchronous implementation of a verifier for a
* signed key, because Node.js's crypto functions are synchronous,
* strangely, considering how everything else is asynchronous.
*
* I wrote this one day hoping it would help with performance, but
* I don't think it had any noticeable effect.
*
* @license MIT
*/
'use strict';
const crypto = require('crypto');
/*********************************************************
* Process manager
*********************************************************/
const QueryProcessManager = require('./lib/process-manager').QueryProcessManager;
/**@type {QueryProcessManager} */
// @ts-ignore
const PM = new QueryProcessManager(module, async ({data, signature}) => {
let verifier = crypto.createVerify(Config.loginserverkeyalgo);
verifier.update(data);
let success = false;
try {
success = verifier.verify(Config.loginserverpublickey, signature, 'hex');
} catch (e) {}
return success;
});
if (!PM.isParentProcess) {
// This is a child process!
// @ts-ignore This file doesn't exist on the repository, so Travis checks fail if this isn't ignored
global.Config = require('./config/config');
require('./lib/repl').start('verifier', /** @param {string} cmd */ cmd => eval(cmd));
} else {
PM.spawn(global.Config ? Config.verifierprocesses : 1);
}
/*********************************************************
* Exports
*********************************************************/
/**
* @param {string} data
* @param {string} signature
* @return {Promise<boolean>}
*/
function verify(data, signature) {
return PM.query({data, signature});
}
module.exports = {
verify,
PM,
};