|
|
|
@ -1,4 +1,4 @@
|
|
|
|
|
import { Router, IRouter, Request, static as ServeStatic } from "express"
|
|
|
|
|
import { Router, IRouter, Request, static as ServeStatic } from "express";
|
|
|
|
|
import GetLoginPage from "./login";
|
|
|
|
|
import GetAuthPage from "./authorize";
|
|
|
|
|
import promiseMiddleware from "../helper/promiseMiddleware";
|
|
|
|
@ -17,105 +17,120 @@ import { UserMiddleware, GetUserMiddleware } from "../api/middlewares/user";
|
|
|
|
|
|
|
|
|
|
Handlebars.registerHelper("appname", () => config.core.name);
|
|
|
|
|
|
|
|
|
|
const cacheTime = config.core.dev ? moment.duration(1, "month").asSeconds() : 10;
|
|
|
|
|
const cacheTime = config.core.dev
|
|
|
|
|
? moment.duration(1, "month").asSeconds()
|
|
|
|
|
: 10;
|
|
|
|
|
|
|
|
|
|
const ViewRouter: IRouter = Router();
|
|
|
|
|
ViewRouter.get("/", UserMiddleware, (req, res) => {
|
|
|
|
|
res.send("This is the main page")
|
|
|
|
|
})
|
|
|
|
|
res.send("This is the main page");
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ViewRouter.get("/register", (req, res) => {
|
|
|
|
|
res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
|
|
|
|
res.send(GetRegistrationPage(req.__));
|
|
|
|
|
})
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ViewRouter.use("/login", ServeStatic("./views_repo/build/login"));
|
|
|
|
|
|
|
|
|
|
// ViewRouter.use("/login", (req, res) => {
|
|
|
|
|
// res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
|
|
|
|
// res.send(GetLoginPage(req.__))
|
|
|
|
|
// })
|
|
|
|
|
ViewRouter.use("/user", ServeStatic("./views_repo/build/user"));
|
|
|
|
|
|
|
|
|
|
ViewRouter.get("/code", (req, res) => {
|
|
|
|
|
res.setHeader("Cache-Control", "no-cache");
|
|
|
|
|
if (req.query.error)
|
|
|
|
|
res.send("Some error occured: " + req.query.error);
|
|
|
|
|
else
|
|
|
|
|
res.send(`Your code is: ${req.query.code}`);
|
|
|
|
|
})
|
|
|
|
|
if (req.query.error) res.send("Some error occured: " + req.query.error);
|
|
|
|
|
else res.send(`Your code is: ${req.query.code}`);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
ViewRouter.get("/admin", GetUserMiddleware(false, true), (req: Request, res, next) => {
|
|
|
|
|
if (!req.isAdmin) res.sendStatus(HttpStatusCode.FORBIDDEN)
|
|
|
|
|
else next()
|
|
|
|
|
}, (req, res) => {
|
|
|
|
|
res.send(GetAdminPage(req.__))
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
// ViewRouter.get("/user", Stacker(GetUserMiddleware(false, true), (req, res) => {
|
|
|
|
|
// res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
|
|
|
|
// res.send(GetUserPage(req.__));
|
|
|
|
|
// }));
|
|
|
|
|
|
|
|
|
|
ViewRouter.get("/auth", Stacker(GetUserMiddleware(false, true), async (req, res) => {
|
|
|
|
|
let { scope, redirect_uri, state, client_id }: { [key: string]: string } = req.query;
|
|
|
|
|
const sendError = (type) => {
|
|
|
|
|
res.redirect(redirect_uri += `?error=${type}&state=${state}`);
|
|
|
|
|
}
|
|
|
|
|
let client = await Client.findOne({ client_id: client_id })
|
|
|
|
|
if (!client) {
|
|
|
|
|
return sendError("unauthorized_client")
|
|
|
|
|
ViewRouter.get(
|
|
|
|
|
"/admin",
|
|
|
|
|
GetUserMiddleware(false, true),
|
|
|
|
|
(req: Request, res, next) => {
|
|
|
|
|
if (!req.isAdmin) res.sendStatus(HttpStatusCode.FORBIDDEN);
|
|
|
|
|
else next();
|
|
|
|
|
},
|
|
|
|
|
(req, res) => {
|
|
|
|
|
res.send(GetAdminPage(req.__));
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
let permissions: IPermission[] = [];
|
|
|
|
|
let proms: PromiseLike<void>[] = [];
|
|
|
|
|
if (scope) {
|
|
|
|
|
for (let perm of scope.split(";").filter(e => e !== "read_user")) {
|
|
|
|
|
proms.push(Permission.findById(perm).then(p => {
|
|
|
|
|
if (!p) return Promise.reject(new Error());
|
|
|
|
|
permissions.push(p);
|
|
|
|
|
}));
|
|
|
|
|
ViewRouter.get(
|
|
|
|
|
"/auth",
|
|
|
|
|
Stacker(GetUserMiddleware(false, true), async (req, res) => {
|
|
|
|
|
let {
|
|
|
|
|
scope,
|
|
|
|
|
redirect_uri,
|
|
|
|
|
state,
|
|
|
|
|
client_id
|
|
|
|
|
}: { [key: string]: string } = req.query;
|
|
|
|
|
const sendError = type => {
|
|
|
|
|
res.redirect((redirect_uri += `?error=${type}&state=${state}`));
|
|
|
|
|
};
|
|
|
|
|
let client = await Client.findOne({ client_id: client_id });
|
|
|
|
|
if (!client) {
|
|
|
|
|
return sendError("unauthorized_client");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
let err = false;
|
|
|
|
|
await Promise.all(proms).catch(e => {
|
|
|
|
|
err = true;
|
|
|
|
|
|
|
|
|
|
let permissions: IPermission[] = [];
|
|
|
|
|
let proms: PromiseLike<void>[] = [];
|
|
|
|
|
if (scope) {
|
|
|
|
|
for (let perm of scope.split(";").filter(e => e !== "read_user")) {
|
|
|
|
|
proms.push(
|
|
|
|
|
Permission.findById(perm).then(p => {
|
|
|
|
|
if (!p) return Promise.reject(new Error());
|
|
|
|
|
permissions.push(p);
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
let err = false;
|
|
|
|
|
await Promise.all(proms).catch(e => {
|
|
|
|
|
err = true;
|
|
|
|
|
});
|
|
|
|
|
Logging.debug(err);
|
|
|
|
|
if (err) {
|
|
|
|
|
return sendError("invalid_scope");
|
|
|
|
|
}
|
|
|
|
|
let scopes = await Promise.all(
|
|
|
|
|
permissions.map(async perm => {
|
|
|
|
|
let client = await Client.findById(perm.client);
|
|
|
|
|
return {
|
|
|
|
|
name: perm.name,
|
|
|
|
|
description: perm.description,
|
|
|
|
|
logo: client.logo
|
|
|
|
|
};
|
|
|
|
|
})
|
|
|
|
|
);
|
|
|
|
|
res.send(GetAuthPage(req.__, client.name, scopes));
|
|
|
|
|
})
|
|
|
|
|
Logging.debug(err);
|
|
|
|
|
if (err) {
|
|
|
|
|
return sendError("invalid_scope")
|
|
|
|
|
}
|
|
|
|
|
let scopes = await Promise.all(permissions.map(async perm => {
|
|
|
|
|
let client = await Client.findById(perm.client);
|
|
|
|
|
return {
|
|
|
|
|
name: perm.name,
|
|
|
|
|
description: perm.description,
|
|
|
|
|
logo: client.logo
|
|
|
|
|
}
|
|
|
|
|
}))
|
|
|
|
|
res.send(GetAuthPage(req.__, client.name, scopes));
|
|
|
|
|
}));
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
if (config.core.dev) {
|
|
|
|
|
const logo = ""
|
|
|
|
|
const logo =
|
|
|
|
|
"";
|
|
|
|
|
ViewRouter.get("/devauth", (req, res) => {
|
|
|
|
|
res.send(GetAuthPage(req.__, "Test 05265", [
|
|
|
|
|
{
|
|
|
|
|
name: "Access Profile",
|
|
|
|
|
description: "It allows the application to know who you are. Required for all applications. And a lot of more Text, because why not? This will not stop, till it is multiple lines long and maybe kill the layout, so keep reading as long as you like, but I promise it will get boring after some time. So this should be enougth.",
|
|
|
|
|
logo: logo
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Test 1",
|
|
|
|
|
description: "This is not an real permission. This is used just to verify the layout",
|
|
|
|
|
logo: logo
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Test 2",
|
|
|
|
|
description: "This is not an real permission. This is used just to verify the layout",
|
|
|
|
|
logo: logo
|
|
|
|
|
}
|
|
|
|
|
]))
|
|
|
|
|
})
|
|
|
|
|
res.send(
|
|
|
|
|
GetAuthPage(req.__, "Test 05265", [
|
|
|
|
|
{
|
|
|
|
|
name: "Access Profile",
|
|
|
|
|
description:
|
|
|
|
|
"It allows the application to know who you are. Required for all applications. And a lot of more Text, because why not? This will not stop, till it is multiple lines long and maybe kill the layout, so keep reading as long as you like, but I promise it will get boring after some time. So this should be enougth.",
|
|
|
|
|
logo: logo
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Test 1",
|
|
|
|
|
description:
|
|
|
|
|
"This is not an real permission. This is used just to verify the layout",
|
|
|
|
|
logo: logo
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Test 2",
|
|
|
|
|
description:
|
|
|
|
|
"This is not an real permission. This is used just to verify the layout",
|
|
|
|
|
logo: logo
|
|
|
|
|
}
|
|
|
|
|
])
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default ViewRouter;
|
|
|
|
|
export default ViewRouter;
|
|
|
|
|