strategy.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. var passport = require('passport-strategy')
  2. , siwe = require('siwe')
  3. , util = require('util')
  4. , SessionStore = require('./store/session');
  5. function Strategy(options, verify) {
  6. if (typeof options == 'function') {
  7. verify = options;
  8. options = {};
  9. }
  10. if (!verify) { throw new TypeError('EthereumStrategy requires a verify function'); }
  11. this.name = 'ethereum';
  12. this._verify = verify;
  13. this._passReqToCallback = options.passReqToCallback;
  14. this._store = options.store || new SessionStore();
  15. }
  16. /**
  17. * Inherit from `passport.Strategy`.
  18. */
  19. util.inherits(Strategy, passport.Strategy);
  20. Strategy.prototype.authenticate = function(req, options) {
  21. var message = req.body.message
  22. , signature = req.body.signature;
  23. if (!message) { return this.fail({ message: 'Missing message' }, 400); }
  24. if (!signature) { return this.fail({ message: 'Missing signature' }, 400); }
  25. var self = this;
  26. var siweMessage;
  27. try {
  28. var siweMessage = new siwe.SiweMessage(message);
  29. } catch(ex) {
  30. return self.fail({ message: 'Invalid message' }, 403);
  31. }
  32. this._store.verify(req, siweMessage.nonce, function(err, ok, info) {
  33. if (!ok) {
  34. return self.fail(info, 403);
  35. }
  36. siweMessage.validate(signature)
  37. .then(function(message) {
  38. function verified(err, user, info) {
  39. if (err) { return self.error(err); }
  40. if (!user) { return self.fail(info); }
  41. self.success(user, info);
  42. }
  43. try {
  44. if (self._passReqToCallback) {
  45. self._verify(req, message.address, verified);
  46. } else {
  47. self._verify(message.address, verified);
  48. }
  49. } catch (ex) {
  50. return self.error(ex);
  51. }
  52. })
  53. .catch(function(err) {
  54. return self.fail({ message: 'Invalid signature' });
  55. });
  56. });
  57. };
  58. /**
  59. * Expose `Strategy`.
  60. */
  61. module.exports = Strategy;