session.js 1.73 KB
Newer Older
1
2
3
4
5
6
'use strict';

const db = require('../models/db');
var config = require('config');

module.exports = (req, res, next) => {
mntmn's avatar
mntmn committed
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

  // authentication via API token
  const api_token = req.headers["x-spacedeck-api-token"];

  if (api_token && api_token.length>7) {
    db.User.findOne({where: {api_token: api_token}}).then(user => {
      req.user = user;
      next();
    }).error(err => {
      res.status(403).json({
        "error": "invalid_api-token"
      });
      next();
    });

    return;
  }

  // authentication via session/cookie
26
  const token = req.cookies["sdsession"];
mntmn's avatar
mntmn committed
27

28
29
30
31
32
33
34
35
36
37
  if (token && token != "null" && token != null) {
    db.Session.findOne({where: {token: token}})
      .then(session => {
        if (!session) {
          // session not found
          next();
        }
        else db.User.findOne({where: {_id: session.user_id}})
          .then(user => {
            if (!user) {
38
              var domain = (process.env.NODE_ENV == "production") ? new URL(config.get("endpoint")).hostname : req.headers.hostname;
39
              res.clearCookie('sdsession', { domain: domain });
40
41
42
43
44
45
46
47
48
49

              if (req.accepts("text/html")) {
                res.send("Please clear your cookies and try again.");
              } else if (req.accepts('application/json')) {
                res.status(403).json({
                  "error": "token_not_found"
                });
              } else {
                res.send("Please clear your cookies and try again.");
              }
mntmn's avatar
mntmn committed
50

51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
            } else {
              req["token"] = token;
              req["user"] = user;
              next();
            }
          });
      })
      .error(err => {
        console.error("Session resolve error",err);
        next();
      });
  } else {
    next();
  }
}