1
0
mirror of https://github.com/Foltik/Shimapan synced 2025-01-07 08:42:49 -05:00

Add custom authenticator in upload.js

This commit is contained in:
Jack Foltz 2018-07-28 12:19:38 -04:00
parent e7eafef605
commit 4770fd3178
Signed by: foltik
GPG Key ID: 303F88F996E95541
3 changed files with 44 additions and 9 deletions

View File

@ -2,22 +2,24 @@ const express = require('express');
const router = express.Router(); const router = express.Router();
const config = require('config'); const config = require('config');
const fsPromises = require('fs').promises;
const ModelPath = '../models/'; const ModelPath = '../models/';
const User = require(ModelPath + 'User.js'); const User = require(ModelPath + 'User.js');
const Upload = require(ModelPath + 'Upload.js'); const Upload = require(ModelPath + 'Upload.js');
const Key = require(ModelPath + 'Key.js'); const Key = require(ModelPath + 'Key.js');
const verifyScope = require('../util/verifyScope.js');
const multer = require('multer'); const multer = require('multer');
const fileUpload = multer({dest: config.get('Upload.path')}).single('file'); const fileUpload = multer({dest: config.get('Upload.path')}).single('file');
const fsPromises = require('fs').promises;
const requireAuth = require('../util/requireAuth');
const wrap = require('../util/wrap.js'); const wrap = require('../util/wrap.js');
const generatedIdExists = async id => const generatedIdExists = async id =>
await Upload.countDocuments({id: id}) === 1; await Upload.countDocuments({id: id}) === 1;
const generateId = async () => { const generateId = async() => {
const charset = config.get('Upload.charset'); const charset = config.get('Upload.charset');
const len = config.get('Upload.idLength'); const len = config.get('Upload.idLength');
@ -39,7 +41,37 @@ const updateStats = async req =>
]); ]);
router.post('/', requireAuth('file.upload'), fileUpload, wrap(async (req, res) => { router.post('/', fileUpload, wrap(async(req, res) => {
// We need to authenticate in place because the form data needs to be processed by multer first
const deleteAndError = async (code, message) => {
if (req.file)
await fsPromises.unlink(req.file.path);
res.status(code).json({message: message});
};
if (req.isAuthenticated()) {
if (verifyScope(req.session.passport.scope, 'file.upload')) {
req.username = req.session.passport.user;
req.displayname = req.session.passport.displayname;
req.scope = req.session.passport.scope;
req.key = null;
} else {
return await deleteAndError(403, 'Forbidden.');
}
} else if (req.body.key) {
const key = await Key.findOne({key: req.body.key});
if (verifyScope(key.scope, 'file.upload')) {
req.username = key.issuer;
req.displayname = key.issuer;
req.scope = key.scope;
req.key = key.key;
} else {
return await deleteAndError(403, 'Forbidden.');
}
} else {
return await deleteAndError(401, 'Unauthorized.');
}
if (!req.file) if (!req.file)
return res.status(400).json({message: 'No file specified.'}); return res.status(400).json({message: 'No file specified.'});

View File

@ -1,7 +1,7 @@
const Key = require('../models/Key.js'); const Key = require('../models/Key.js');
const wrap = require('./wrap.js'); const wrap = require('./wrap.js');
const verifyScope = (scope, requiredScope) => scope.indexOf(requiredScope) !== -1; const verifyScope = require('./verifyScope.js');
// Checks for authentication by either API Key or Session // Checks for authentication by either API Key or Session
// Sets body.authUser and body.authKey if check passed // Sets body.authUser and body.authKey if check passed
@ -20,11 +20,11 @@ const requireAuth = scope =>
} else { } else {
res.status(403).json({message: 'Forbidden.'}); res.status(403).json({message: 'Forbidden.'});
} }
} else if (req.body.apikey) { } else if (req.body.key) {
const key = await Key.findOne({key: apikey}); const key = await Key.findOne({key: key});
if (scope ? verifyScope(key.scope, scope) : true) { if (scope ? verifyScope(key.scope, scope) : true) {
req.username = key.username; req.username = key.issuer;
req.displayname = key.username; req.displayname = key.issuer;
req.scope = key.scope; req.scope = key.scope;
req.key = key.key; req.key = key.key;
next(); next();

3
app/util/verifyScope.js Normal file
View File

@ -0,0 +1,3 @@
const verifyScope = (scope, requiredScope) => scope.indexOf(requiredScope) !== -1;
module.exports = verifyScope;