Adding a popup authentication option.
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
@ -1,10 +1,11 @@
|
||||
import { Router } from "express";
|
||||
import Register from "./register";
|
||||
import Login from "./login";
|
||||
import TwoFactorRoute from "./twofactor";
|
||||
import { GetToken, DeleteToken } from "./token";
|
||||
import { GetAccount } from "./account";
|
||||
import { GetContactInfos } from "./contact";
|
||||
import { GetJWTByUser } from "./jwt";
|
||||
import Login from "./login";
|
||||
import Register from "./register";
|
||||
import { DeleteToken, GetToken } from "./token";
|
||||
import TwoFactorRoute from "./twofactor";
|
||||
|
||||
const UserRoute: Router = Router();
|
||||
|
||||
@ -125,4 +126,7 @@ UserRoute.get("/account", GetAccount);
|
||||
* @apiSuccess {Object[]} user.phone Phone numbers
|
||||
*/
|
||||
UserRoute.get("/contact", GetContactInfos);
|
||||
|
||||
UserRoute.get("/jwt", GetJWTByUser);
|
||||
|
||||
export default UserRoute;
|
||||
|
37
src/api/user/jwt.ts
Normal file
37
src/api/user/jwt.ts
Normal file
@ -0,0 +1,37 @@
|
||||
import { Request, Response } from "express";
|
||||
import Stacker from "../middlewares/stacker";
|
||||
import { GetUserMiddleware } from "../middlewares/user";
|
||||
import { URL } from "url";
|
||||
import Client from "../../models/client";
|
||||
import RequestError, { HttpStatusCode } from "../../helper/request_error";
|
||||
import { getAccessTokenJWT } from "../../helper/jwt";
|
||||
|
||||
export const GetJWTByUser = Stacker(
|
||||
GetUserMiddleware(true, false),
|
||||
async (req: Request, res: Response) => {
|
||||
const { client_id, origin } = req.query as { [key: string]: string };
|
||||
|
||||
const client = await Client.findOne({
|
||||
client_id,
|
||||
});
|
||||
|
||||
const clientNotFoundError = new RequestError(
|
||||
"Client not found!",
|
||||
HttpStatusCode.BAD_REQUEST
|
||||
);
|
||||
|
||||
if (!client) throw clientNotFoundError;
|
||||
|
||||
const clientUrl = new URL(client.redirect_url);
|
||||
|
||||
if (clientUrl.hostname !== origin) throw clientNotFoundError;
|
||||
|
||||
const jwt = await getAccessTokenJWT({
|
||||
user: req.user,
|
||||
client: client,
|
||||
permissions: [],
|
||||
});
|
||||
|
||||
res.json({ jwt });
|
||||
}
|
||||
);
|
@ -62,7 +62,7 @@ export default async function TestData() {
|
||||
await Client.save(c);
|
||||
}
|
||||
|
||||
let perm = await Permission.findOne({ id: 0 });
|
||||
let perm = await Permission.findById("507f1f77bcf86cd799439011");
|
||||
if (!perm) {
|
||||
Logging.log("Adding test permission");
|
||||
perm = Permission.new({
|
||||
|
21
src/views/popup.ts
Normal file
21
src/views/popup.ts
Normal file
@ -0,0 +1,21 @@
|
||||
import * as handlebars from "handlebars";
|
||||
import { readFileSync } from "fs";
|
||||
import { __ as i__ } from "i18n";
|
||||
import config from "../config";
|
||||
|
||||
let template: handlebars.TemplateDelegate<any>;
|
||||
function loadStatic() {
|
||||
let html = readFileSync("./views/out/popup/popup.html").toString();
|
||||
template = handlebars.compile(html);
|
||||
}
|
||||
|
||||
export default function GetPopupPage(__: typeof i__): string {
|
||||
if (config.core.dev) {
|
||||
loadStatic();
|
||||
}
|
||||
|
||||
let data = {};
|
||||
return template(data, { helpers: { i18n: __ } });
|
||||
}
|
||||
|
||||
loadStatic();
|
@ -1,9 +1,9 @@
|
||||
import {
|
||||
IRouter,
|
||||
Request,
|
||||
RequestHandler,
|
||||
Router,
|
||||
static as ServeStatic,
|
||||
RequestHandler,
|
||||
} from "express";
|
||||
import * as Handlebars from "handlebars";
|
||||
import * as moment from "moment";
|
||||
@ -13,6 +13,7 @@ import config from "../config";
|
||||
import { HttpStatusCode } from "../helper/request_error";
|
||||
import GetAdminPage from "./admin";
|
||||
import GetAuthPage from "./authorize";
|
||||
import GetPopupPage from "./popup";
|
||||
import GetRegistrationPage from "./register";
|
||||
|
||||
Handlebars.registerHelper("appname", () => config.core.name);
|
||||
@ -68,33 +69,37 @@ ViewRouter.get(
|
||||
|
||||
ViewRouter.get("/auth", GetAuthRoute(true));
|
||||
|
||||
if (config.core.dev) {
|
||||
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,
|
||||
},
|
||||
])
|
||||
);
|
||||
});
|
||||
}
|
||||
ViewRouter.get("/popup", UserMiddleware, (req, res) => {
|
||||
res.send(GetPopupPage(req.__));
|
||||
});
|
||||
|
||||
// if (config.core.dev) {
|
||||
// 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,
|
||||
// },
|
||||
// ])
|
||||
// );
|
||||
// });
|
||||
// }
|
||||
|
||||
export default ViewRouter;
|
||||
|
Reference in New Issue
Block a user