Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 1 | 'use strict' |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 2 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 3 | import dotenv from 'dotenv' |
| 4 | dotenv.config() |
| 5 | |
| 6 | import { promises as fs } from 'fs' |
| 7 | import http from 'http' |
| 8 | import express from 'express' |
| 9 | import session from 'express-session' |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 10 | //const cookieParser = require('cookie-parser') |
| 11 | //const io = require('socket.io')(server) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 12 | import path from 'path' |
| 13 | import passport from 'passport' |
| 14 | import { Strategy as LocalStrategy } from 'passport-local' |
| 15 | //import { createRequire } from 'module'; |
| 16 | //const require = createRequire(import.meta.url); |
| 17 | import { fileURLToPath } from 'url'; |
| 18 | const __filename = fileURLToPath(import.meta.url); |
| 19 | const __dirname = path.dirname(__filename); |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 20 | |
Adrien Béraud | 947e879 | 2021-04-15 18:32:44 -0400 | [diff] [blame] | 21 | //const redis = require('redis-url').connect() |
| 22 | //const RedisStore = require('connect-redis')(session) |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 23 | /*const passportSocketIo = require('passport.socketio')*/ |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 24 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 25 | import indexRouter from './routes/index.js' |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 26 | |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 27 | //const cors = require('cors') |
| 28 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 29 | import JamiRestApi from './routes/jami.js' |
| 30 | import JamiDaemon from './JamiDaemon.js' |
| 31 | |
| 32 | const configPath = 'jamiServerConfig.json' |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 33 | |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 34 | //const sessionStore = new RedisStore({ client: redis }) |
| 35 | const sessionStore = new session.MemoryStore() |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 36 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 37 | const loadConfig = async (filePath) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 38 | const config = {users: {}, authMethods: []} |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 39 | try { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 40 | return Object.assign(config, JSON.parse(await fs.readFile(filePath))) |
| 41 | } catch(e) { |
| 42 | console.log(e) |
| 43 | return config |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 44 | } |
Adrien Béraud | 824a713 | 2021-04-17 17:25:27 -0400 | [diff] [blame] | 45 | } |
| 46 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 47 | const saveConfig = (filePath, config) => { |
| 48 | return fs.writeFile(filePath, JSON.stringify(config)) |
| 49 | } |
| 50 | |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 51 | /* |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 52 | Share sessions between Passport.js and Socket.io |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 53 | */ |
| 54 | |
| 55 | function logSuccess() { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 56 | console.log("passportSocketIo authorized user with Success 😁") |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 57 | } |
| 58 | |
| 59 | function logFail() { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 60 | console.log("passportSocketIo failed to authorized user 👺") |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 61 | } |
| 62 | |
| 63 | /* |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 64 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 65 | tempAccounts holds users accounts while tempting to authenticate them on Jams. |
| 66 | connectedUsers holds users accounts after they got authenticated by Jams. |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 67 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 68 | Users should be removed from connectedUsers when receiving a disconnect |
| 69 | web socket call |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 70 | |
| 71 | */ |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 72 | const tempAccounts = {} |
| 73 | const connectedUsers = {} |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 74 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 75 | const createServer = async (appConfig) => { |
| 76 | const app = express() |
| 77 | console.log(`Loading server for ${app.get('env')} with config:`) |
| 78 | console.log(appConfig) |
| 79 | const development = app.get('env') === 'development' |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 80 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 81 | if (development) { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 82 | const [ webpack, webpackDev, webpackHot, webpackConfig ] = await Promise.all([ |
| 83 | import('webpack'), |
| 84 | import('webpack-dev-middleware'), |
| 85 | import('webpack-hot-middleware'), |
| 86 | import('./client/webpack.config.js') |
| 87 | ]) |
| 88 | const compiler = webpack.default(webpackConfig.default) |
| 89 | app.use(webpackDev.default(compiler, { |
| 90 | publicPath: webpackConfig.default.output.publicPath |
| 91 | })) |
| 92 | app.use(webpackHot.default(compiler)) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 93 | } |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 94 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 95 | /* |
| 96 | Configuation for Passeport Js |
| 97 | */ |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 98 | app.disable('x-powered-by') |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 99 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 100 | app.use(session({ |
| 101 | store: sessionStore, |
| 102 | resave: false, |
| 103 | saveUninitialized: true, |
| 104 | cookie: { |
| 105 | secure: false,//!development, |
| 106 | maxAge: 2419200000 |
| 107 | }, |
| 108 | secret: process.env.SECRET_KEY_BASE |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 109 | })) |
| 110 | app.use(passport.initialize()) |
| 111 | app.use(passport.session()) |
| 112 | // app.use(app.router) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 113 | //app.use(cors()) |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 114 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 115 | const jami = new JamiDaemon() |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 116 | const apiRouter = new JamiRestApi(jami).getRouter() |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 117 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 118 | /* |
| 119 | io.use(passportSocketIo.authorize({ |
| 120 | key: 'connect.sid', |
| 121 | secret: process.env.SECRET_KEY_BASE, |
| 122 | store: sessionStore, |
| 123 | passport: passport, |
| 124 | cookieParser: cookieParser, |
| 125 | //success: logSuccess(), |
| 126 | // fail: logFail(), |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 127 | })) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 128 | */ |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 129 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 130 | const isSetupComplete = () => { |
| 131 | return 'admin' in appConfig.users |
| 132 | } |
| 133 | |
| 134 | const accountFilter = filter => { |
| 135 | if (typeof filter === 'string') { |
| 136 | if (filter === '*') |
| 137 | return undefined |
| 138 | else |
| 139 | return account => account.getId() === filter |
| 140 | } else if (Array.isArray(filter)) { |
| 141 | return account => filter.includes(account.getId()) |
| 142 | } else { |
| 143 | throw new Error('Invalid account filter string') |
| 144 | } |
| 145 | } |
| 146 | |
| 147 | const user = (id, config) => { |
| 148 | return { |
| 149 | id, |
| 150 | config, |
| 151 | username: config.username || id, |
| 152 | accountFilter: accountFilter(config.accounts) |
| 153 | } |
| 154 | } |
| 155 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 156 | passport.serializeUser((user, done) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 157 | connectedUsers[user.id] = user.config |
| 158 | console.log("=============================SerializeUser called " + user.id) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 159 | console.log(user) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 160 | done(null, user.id) |
| 161 | }) |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 162 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 163 | const deserializeUser = (id, done) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 164 | console.log("=============================DeserializeUser called on: " + id) |
| 165 | const userConfig = connectedUsers[id] |
| 166 | console.log(userConfig) |
| 167 | if (userConfig) { |
| 168 | done(null, user(id, userConfig)) |
| 169 | } else |
| 170 | done(404, null) |
| 171 | } |
| 172 | passport.deserializeUser(deserializeUser) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 173 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 174 | const jamsStrategy = new LocalStrategy( |
| 175 | (username, password, done) => { |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 176 | const accountId = jami.addAccount({ |
| 177 | 'managerUri': 'https://jams.savoirfairelinux.com', |
| 178 | 'managerUsername': username, |
| 179 | 'archivePassword': password |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 180 | }) |
| 181 | const id = `jams_${username}` |
| 182 | const userConfig = { username, type: 'jams', accounts: accountId } |
| 183 | const newUser = user(id, userConfig) |
| 184 | console.log("AccountId: " + accountId) |
| 185 | tempAccounts[accountId] = { done, newUser } |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 186 | |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 187 | } |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 188 | ) |
| 189 | jamsStrategy.name = "jams" |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 190 | |
| 191 | const localStrategy = new LocalStrategy( |
| 192 | (username, password, done) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 193 | console.log("localStrategy: " + username + " " + password) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 194 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 195 | const id = username |
| 196 | const userConfig = appConfig.users[username] |
| 197 | if (!userConfig) { |
| 198 | return done(null, false, { message: 'Incorrect username.' }) |
| 199 | } |
| 200 | if (userConfig.password !== password) { |
| 201 | return done(null, false, { message: 'Incorrect password.' }) |
| 202 | } |
| 203 | userConfig.type = 'local' |
| 204 | |
| 205 | done(null, user(id, userConfig)) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 206 | } |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 207 | ) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 208 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 209 | passport.use(jamsStrategy) |
| 210 | passport.use(localStrategy) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 211 | |
| 212 | const secured = (req, res, next) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 213 | if (req.user) { |
| 214 | return next() |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 215 | } |
| 216 | res.status(401).end() |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 217 | } |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 218 | const securedRedirect = (req, res, next) => { |
| 219 | if (req.user && req.user.accountId) { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 220 | return next() |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 221 | } |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 222 | req.session.returnTo = req.originalUrl |
| 223 | res.redirect('/login') |
| 224 | } |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 225 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 226 | app.use(express.json()) |
| 227 | app.post('/setup', (req, res) => { |
| 228 | if (isSetupComplete()) { |
| 229 | return res.status(404).end() |
| 230 | } |
| 231 | if (!req.body.password) { |
| 232 | return res.status(400).end() |
| 233 | } |
| 234 | console.log(req.body) |
| 235 | appConfig.users.admin = { |
| 236 | "accounts": "*", |
| 237 | password: req.body.password |
| 238 | } |
| 239 | res.status(200).end() |
| 240 | saveConfig(configPath, appConfig) |
| 241 | }) |
| 242 | app.post('/auth/jams', passport.authenticate('jams'), (req, res) => { |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 243 | res.json({ loggedin: true }) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 244 | }) |
| 245 | app.post('/auth/local', passport.authenticate('local'), (req, res) => { |
| 246 | res.json({ loggedin: true, user: req.user.id }) |
| 247 | }) |
| 248 | app.get('/auth', (req, res) => { |
| 249 | if (req.user) { |
| 250 | res.json({ loggedin: true, username: req.user.username, type: req.user.type }) |
| 251 | } else if (isSetupComplete()) { |
| 252 | res.status(401).json({}) |
| 253 | } else { |
| 254 | res.status(401).json({ setupComplete: false }) |
| 255 | } |
| 256 | }) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 257 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 258 | app.use('/api', secured, apiRouter) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 259 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 260 | app.use('/', indexRouter) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 261 | |
| 262 | /* GET React App */ |
| 263 | |
| 264 | app.use(express.static(path.join(__dirname, 'client', 'dist'))) |
| 265 | |
| 266 | app.use((req, res, next) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 267 | res.sendFile(path.join(__dirname, 'client', 'dist', 'index.html')) |
| 268 | }) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 269 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 270 | return http.Server(app) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 271 | } |
| 272 | |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 273 | loadConfig(configPath) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 274 | .then(createServer) |
| 275 | .then(server => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 276 | server.listen(3000) |
Adrien Béraud | 3b5d9a6 | 2021-04-17 18:40:27 -0400 | [diff] [blame] | 277 | }) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 278 | |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 279 | /* |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 280 | io.on('connection', (socket) => { |
| 281 | console.log("Client just connected !") |
| 282 | socket.on('SendMessage', (data) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 283 | console.log("Message " + data.text + " sent to " + data.destinationId + " by " + socket.session.user.accountId) |
| 284 | const msgMap = new jami.dring.StringMap() |
| 285 | msgMap.set('text/plain', data.text) |
| 286 | jami.dring.sendAccountTextMessage(socket.session.user.accountId, data.destinationId, msgMap) |
| 287 | }) |
| 288 | }) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 289 | |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 290 | io.use((socket, next) => { |
| 291 | cookieParser(socket.handshake, {}, (err) => { |
| 292 | if (err) { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 293 | console.log("error in parsing cookie") |
| 294 | return next(err) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 295 | } |
| 296 | if (!socket.handshake.signedCookies) { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 297 | console.log("no secureCookies|signedCookies found") |
| 298 | return next(new Error("no secureCookies found")) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 299 | } |
| 300 | sessionStore.get(socket.handshake.signedCookies["connect.sid"], (err, session) => { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 301 | socket.session = session |
| 302 | if (!err && !session) err = new Error('session not found') |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 303 | if (err) { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 304 | console.log('failed connection to socket.io:', err) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 305 | } else { |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 306 | console.log(session) |
| 307 | console.log('successful connection to socket.io ' + session.passport.user) |
| 308 | const userKey = session.passport.user |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 309 | deserializeUser(userKey, (err, user) => { |
| 310 | console.log("deserializeUser: " + user) |
| 311 | if (err) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 312 | return next(err, true) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 313 | if (!user) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 314 | return next("User not found", false) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 315 | |
| 316 | console.log("User associated socket id: " + socket.id) |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 317 | user.socketId = socket.id |
| 318 | socket.session.user = user |
| 319 | console.log("User added to session --------> " + user.accountId) |
| 320 | //auth.success(data, accept) |
| 321 | next(err, true) |
| 322 | }) |
Larbi Gharib | e9af973 | 2021-03-31 15:08:01 +0100 | [diff] [blame] | 323 | } |
Adrien Béraud | e74741b | 2021-04-19 13:22:54 -0400 | [diff] [blame] | 324 | }) |
| 325 | }) |
| 326 | }) |
Adrien Béraud | 6ecaa40 | 2021-04-06 17:37:25 -0400 | [diff] [blame] | 327 | */ |