Fix: Linter warnings (#137)

* Automaticly fixable eslint issues, mostly 3 -> 2 space indentation

* fix: updated plex_userid to camelcase

* Linted and some consistency refactor on middleware

* eslint uses ecmaversion 2020 & allow empty catch rule

* Started linting source files

* Fixed eslint errors & improved a lot of error handling

* Set 2 eslint rules as warning temporarly
This commit is contained in:
2022-08-20 17:21:25 +02:00
committed by GitHub
parent cfbd4965db
commit 1815a429b0
83 changed files with 1625 additions and 1294 deletions

View File

@@ -1,31 +1,31 @@
const establishedDatabase = require("../../database/database");
// eslint-disable-next-line consistent-return
const mustBeAdmin = (req, res, next) => {
let database = establishedDatabase;
const database = establishedDatabase;
if (req.loggedInUser === undefined) {
return res.status(401).send({
res.status(401).send({
success: false,
message: "You must be logged in."
});
} else {
database
.get(
`SELECT admin FROM user WHERE user_name IS ?`,
req.loggedInUser.username
)
.then(isAdmin => {
console.log(isAdmin, req.loggedInUser);
if (isAdmin.admin == 0) {
return res.status(401).send({
success: false,
message: "You must be logged in as a admin."
});
}
});
}
return next();
database
.get(
`SELECT admin FROM user WHERE user_name IS ?`,
req.loggedInUser.username
)
.then(isAdmin => {
if (isAdmin.admin === 0) {
return res.status(401).send({
success: false,
message: "You must be logged in as a admin."
});
}
return next();
});
};
module.exports = mustBeAdmin;

View File

@@ -1,3 +1,4 @@
// eslint-disable-next-line consistent-return
const mustBeAuthenticated = (req, res, next) => {
if (req.loggedInUser === undefined) {
return res.status(401).send({
@@ -5,7 +6,8 @@ const mustBeAuthenticated = (req, res, next) => {
message: "You must be logged in."
});
}
return next();
next();
};
module.exports = mustBeAuthenticated;

View File

@@ -1,35 +1,36 @@
const establishedDatabase = require("../../database/database");
/* eslint-disable consistent-return */
const mustHaveAccountLinkedToPlex = (req, res, next) => {
let database = establishedDatabase;
const loggedInUser = req.loggedInUser;
const database = establishedDatabase;
const { loggedInUser } = req;
if (loggedInUser === undefined) {
if (loggedInUser === null) {
return res.status(401).send({
success: false,
message: "You must have your account linked to a plex account."
});
} else {
database
.get(
`SELECT plex_userid FROM settings WHERE user_name IS ?`,
loggedInUser.username
)
.then(row => {
const plex_userid = row.plex_userid;
if (plex_userid === null || plex_userid === undefined) {
return res.status(403).send({
success: false,
message:
"No plex account user id found for your user. Please authenticate your plex account at /user/authenticate."
});
} else {
req.loggedInUser.plex_userid = plex_userid;
return next();
}
});
}
database
.get(
`SELECT plex_userid FROM settings WHERE user_name IS ?`,
loggedInUser.username
)
.then(row => {
const plexUserId = row.plex_userid;
if (plexUserId === null) {
return res.status(403).send({
success: false,
message:
"No plex account user id found for your user. Please authenticate your plex account at /user/authenticate."
});
}
req.loggedInUser.plexUserId = plexUserId;
next();
});
};
/* eslint-enable consistent-return */
module.exports = mustHaveAccountLinkedToPlex;

View File

@@ -11,22 +11,18 @@ const reqTokenToUser = (req, res, next) => {
const cookieAuthToken = req.cookies.authorization;
const headerAuthToken = req.headers.authorization;
if (cookieAuthToken || headerAuthToken) {
try {
const token = Token.fromString(
cookieAuthToken || headerAuthToken,
secret
);
req.loggedInUser = token.user;
} catch (error) {
req.loggedInUser = undefined;
}
} else {
// guest session
console.debug("No auth token in header or cookie.");
if (!(cookieAuthToken || headerAuthToken)) {
return next();
}
next();
try {
const token = Token.fromString(cookieAuthToken || headerAuthToken, secret);
req.loggedInUser = token.user;
} catch (error) {
req.loggedInUser = null;
}
return next();
};
module.exports = reqTokenToUser;