1
0
Fork 0
management/front/dkha-web-sz-main/node_modules/browserify-sign/browser/index.js

93 lines
2.2 KiB
JavaScript
Raw Normal View History

2024-01-16 21:26:16 +08:00
'use strict';
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
var Buffer = require('safe-buffer').Buffer;
var createHash = require('create-hash');
var stream = require('readable-stream');
var inherits = require('inherits');
var sign = require('./sign');
var verify = require('./verify');
var algorithms = require('./algorithms.json');
2023-12-18 13:12:25 +08:00
Object.keys(algorithms).forEach(function (key) {
2024-01-16 21:26:16 +08:00
algorithms[key].id = Buffer.from(algorithms[key].id, 'hex');
algorithms[key.toLowerCase()] = algorithms[key];
});
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
function Sign(algorithm) {
stream.Writable.call(this);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
var data = algorithms[algorithm];
if (!data) { throw new Error('Unknown message digest'); }
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
this._hashType = data.hash;
this._hash = createHash(data.hash);
this._tag = data.id;
this._signType = data.sign;
2023-12-18 13:12:25 +08:00
}
2024-01-16 21:26:16 +08:00
inherits(Sign, stream.Writable);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Sign.prototype._write = function _write(data, _, done) {
this._hash.update(data);
done();
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Sign.prototype.update = function update(data, enc) {
this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
return this;
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Sign.prototype.sign = function signMethod(key, enc) {
this.end();
var hash = this._hash.digest();
var sig = sign(hash, key, this._hashType, this._signType, this._tag);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
return enc ? sig.toString(enc) : sig;
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
function Verify(algorithm) {
stream.Writable.call(this);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
var data = algorithms[algorithm];
if (!data) { throw new Error('Unknown message digest'); }
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
this._hash = createHash(data.hash);
this._tag = data.id;
this._signType = data.sign;
2023-12-18 13:12:25 +08:00
}
2024-01-16 21:26:16 +08:00
inherits(Verify, stream.Writable);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Verify.prototype._write = function _write(data, _, done) {
this._hash.update(data);
done();
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Verify.prototype.update = function update(data, enc) {
this._hash.update(typeof data === 'string' ? Buffer.from(data, enc) : data);
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
return this;
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
Verify.prototype.verify = function verifyMethod(key, sig, enc) {
var sigBuffer = typeof sig === 'string' ? Buffer.from(sig, enc) : sig;
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
this.end();
var hash = this._hash.digest();
return verify(sigBuffer, hash, key, this._signType, this._tag);
};
2023-12-18 13:12:25 +08:00
2024-01-16 21:26:16 +08:00
function createSign(algorithm) {
return new Sign(algorithm);
2023-12-18 13:12:25 +08:00
}
2024-01-16 21:26:16 +08:00
function createVerify(algorithm) {
return new Verify(algorithm);
2023-12-18 13:12:25 +08:00
}
module.exports = {
Sign: createSign,
Verify: createVerify,
createSign: createSign,
createVerify: createVerify
2024-01-16 21:26:16 +08:00
};