Adding new API for getting contact information of user
This commit is contained in:
parent
c8550b517a
commit
92cc97c396
@ -6,7 +6,7 @@ indent_size = 3
|
|||||||
end_of_line = crlf
|
end_of_line = crlf
|
||||||
charset = utf-8
|
charset = utf-8
|
||||||
trim_trailing_whitespace = false
|
trim_trailing_whitespace = false
|
||||||
insert_final_newline = false
|
insert_final_newline = true
|
||||||
|
|
||||||
[*.yml]
|
[*.yml]
|
||||||
indent_size = 2
|
indent_size = 2
|
3
.vscode/extensions.json
vendored
Normal file
3
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"recommendations": ["esbenp.prettier-vscode"]
|
||||||
|
}
|
@ -37,5 +37,6 @@
|
|||||||
"No special token": "No special token",
|
"No special token": "No special token",
|
||||||
"Login token invalid": "Login token invalid",
|
"Login token invalid": "Login token invalid",
|
||||||
"No login token": "No login token",
|
"No login token": "No login token",
|
||||||
"You are not logged in or your login is expired (Login token invalid)": "You are not logged in or your login is expired (Login token invalid)"
|
"You are not logged in or your login is expired (Login token invalid)": "You are not logged in or your login is expired (Login token invalid)",
|
||||||
|
"You are not logged in or your login is expired (No special token)": "You are not logged in or your login is expired (No special token)"
|
||||||
}
|
}
|
2
package-lock.json
generated
2
package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "open_auth_service",
|
"name": "open_auth_service",
|
||||||
"version": "1.0.0",
|
"version": "1.1.1",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
16
src/api/user/contact.ts
Normal file
16
src/api/user/contact.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import { Request, Response } from "express";
|
||||||
|
import Stacker from "../middlewares/stacker";
|
||||||
|
import { GetUserMiddleware } from "../middlewares/user";
|
||||||
|
import Mail from "../../models/mail";
|
||||||
|
|
||||||
|
export const GetContactInfos = Stacker(GetUserMiddleware(true, true), async (req: Request, res: Response) => {
|
||||||
|
let mails = await Promise.all(
|
||||||
|
req.user.mails.map(mail => Mail.findById(mail))
|
||||||
|
);
|
||||||
|
|
||||||
|
let contact = {
|
||||||
|
mails: mails.filter(e => !!e),
|
||||||
|
phones: req.user.phones
|
||||||
|
};
|
||||||
|
res.json({ contact });
|
||||||
|
});
|
@ -4,6 +4,7 @@ import Login from "./login";
|
|||||||
import TwoFactorRoute from "./twofactor";
|
import TwoFactorRoute from "./twofactor";
|
||||||
import { GetToken, DeleteToken } from "./token";
|
import { GetToken, DeleteToken } from "./token";
|
||||||
import { GetAccount } from "./account";
|
import { GetAccount } from "./account";
|
||||||
|
import { GetContactInfos } from "./contact";
|
||||||
|
|
||||||
const UserRoute: Router = Router();
|
const UserRoute: Router = Router();
|
||||||
|
|
||||||
@ -105,10 +106,24 @@ UserRoute.delete("/token/:id", DeleteToken);
|
|||||||
* @apiSuccess {Boolean} success
|
* @apiSuccess {Boolean} success
|
||||||
* @apiSuccess {Object[]} user
|
* @apiSuccess {Object[]} user
|
||||||
* @apiSuccess {String} user.id User ID
|
* @apiSuccess {String} user.id User ID
|
||||||
* @apiSuccess {String} token.name Full name of the user
|
* @apiSuccess {String} user.name Full name of the user
|
||||||
* @apiSuccess {String} token.username Username of user
|
* @apiSuccess {String} user.username Username of user
|
||||||
* @apiSuccess {Date} token.birthday Birthday
|
* @apiSuccess {Date} user.birthday Birthday
|
||||||
* @apiSuccess {Number} token.gender Gender of user (none = 0, male = 1, female = 2, other = 3)
|
* @apiSuccess {Number} user.gender Gender of user (none = 0, male = 1, female = 2, other = 3)
|
||||||
*/
|
*/
|
||||||
UserRoute.get("/account", GetAccount);
|
UserRoute.get("/account", GetAccount);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @api {delete} /user/account
|
||||||
|
* @apiName UserGetAccount
|
||||||
|
*
|
||||||
|
* @apiGroup user
|
||||||
|
* @apiPermission user
|
||||||
|
*
|
||||||
|
* @apiSuccess {Boolean} success
|
||||||
|
* @apiSuccess {Object} contact
|
||||||
|
* @apiSuccess {Object[]} user.mail EMail addresses
|
||||||
|
* @apiSuccess {Object[]} user.phone Phone numbers
|
||||||
|
*/
|
||||||
|
UserRoute.get("/contact", GetContactInfos);
|
||||||
export default UserRoute;
|
export default UserRoute;
|
@ -11,10 +11,23 @@ import TwoFactor from "./models/twofactor";
|
|||||||
|
|
||||||
import * as speakeasy from "speakeasy";
|
import * as speakeasy from "speakeasy";
|
||||||
import LoginToken from "./models/login_token";
|
import LoginToken from "./models/login_token";
|
||||||
import { log } from "handlebars";
|
import Mail from "./models/mail";
|
||||||
|
|
||||||
export default async function TestData() {
|
export default async function TestData() {
|
||||||
await DB.db.dropDatabase();
|
await DB.db.dropDatabase();
|
||||||
|
|
||||||
|
let mail = await Mail.findOne({ mail: "test@test.de" });
|
||||||
|
if (!mail) {
|
||||||
|
mail = Mail.new({
|
||||||
|
mail: "test@test.de",
|
||||||
|
primary: true,
|
||||||
|
verified: true
|
||||||
|
})
|
||||||
|
|
||||||
|
await Mail.save(mail);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
let u = await User.findOne({ username: "test" });
|
let u = await User.findOne({ username: "test" });
|
||||||
if (!u) {
|
if (!u) {
|
||||||
Logging.log("Adding test user");
|
Logging.log("Adding test user");
|
||||||
@ -25,7 +38,12 @@ export default async function TestData() {
|
|||||||
name: "Test Test",
|
name: "Test Test",
|
||||||
password: "125d6d03b32c84d492747f79cf0bf6e179d287f341384eb5d6d3197525ad6be8e6df0116032935698f99a09e265073d1d6c32c274591bf1d0a20ad67cba921bc",
|
password: "125d6d03b32c84d492747f79cf0bf6e179d287f341384eb5d6d3197525ad6be8e6df0116032935698f99a09e265073d1d6c32c274591bf1d0a20ad67cba921bc",
|
||||||
salt: "test",
|
salt: "test",
|
||||||
admin: true
|
admin: true,
|
||||||
|
phones: [
|
||||||
|
{ phone: "+4915962855955", primary: true, verified: true },
|
||||||
|
{ phone: "+4915962855932", primary: false, verified: false }
|
||||||
|
],
|
||||||
|
mails: [mail._id]
|
||||||
})
|
})
|
||||||
await User.save(u);
|
await User.save(u);
|
||||||
}
|
}
|
||||||
|
@ -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 GetLoginPage from "./login";
|
||||||
import GetAuthPage from "./authorize";
|
import GetAuthPage from "./authorize";
|
||||||
import promiseMiddleware from "../helper/promiseMiddleware";
|
import promiseMiddleware from "../helper/promiseMiddleware";
|
||||||
@ -17,105 +17,120 @@ import { UserMiddleware, GetUserMiddleware } from "../api/middlewares/user";
|
|||||||
|
|
||||||
Handlebars.registerHelper("appname", () => config.core.name);
|
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();
|
const ViewRouter: IRouter = Router();
|
||||||
ViewRouter.get("/", UserMiddleware, (req, res) => {
|
ViewRouter.get("/", UserMiddleware, (req, res) => {
|
||||||
res.send("This is the main page")
|
res.send("This is the main page");
|
||||||
})
|
});
|
||||||
|
|
||||||
ViewRouter.get("/register", (req, res) => {
|
ViewRouter.get("/register", (req, res) => {
|
||||||
res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
||||||
res.send(GetRegistrationPage(req.__));
|
res.send(GetRegistrationPage(req.__));
|
||||||
})
|
});
|
||||||
|
|
||||||
ViewRouter.use("/login", ServeStatic("./views_repo/build/login"));
|
ViewRouter.use("/login", ServeStatic("./views_repo/build/login"));
|
||||||
|
|
||||||
// ViewRouter.use("/login", (req, res) => {
|
ViewRouter.use("/user", ServeStatic("./views_repo/build/user"));
|
||||||
// res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
|
||||||
// res.send(GetLoginPage(req.__))
|
|
||||||
// })
|
|
||||||
|
|
||||||
ViewRouter.get("/code", (req, res) => {
|
ViewRouter.get("/code", (req, res) => {
|
||||||
res.setHeader("Cache-Control", "no-cache");
|
res.setHeader("Cache-Control", "no-cache");
|
||||||
if (req.query.error)
|
if (req.query.error) res.send("Some error occured: " + req.query.error);
|
||||||
res.send("Some error occured: " + req.query.error);
|
else res.send(`Your code is: ${req.query.code}`);
|
||||||
else
|
});
|
||||||
res.send(`Your code is: ${req.query.code}`);
|
|
||||||
})
|
|
||||||
|
|
||||||
ViewRouter.get("/admin", GetUserMiddleware(false, true), (req: Request, res, next) => {
|
ViewRouter.get(
|
||||||
if (!req.isAdmin) res.sendStatus(HttpStatusCode.FORBIDDEN)
|
"/admin",
|
||||||
else next()
|
GetUserMiddleware(false, true),
|
||||||
}, (req, res) => {
|
(req: Request, res, next) => {
|
||||||
res.send(GetAdminPage(req.__))
|
if (!req.isAdmin) res.sendStatus(HttpStatusCode.FORBIDDEN);
|
||||||
})
|
else next();
|
||||||
|
},
|
||||||
// ViewRouter.get("/user", Stacker(GetUserMiddleware(false, true), (req, res) => {
|
(req, res) => {
|
||||||
// res.setHeader("Cache-Control", "public, max-age=" + cacheTime);
|
res.send(GetAdminPage(req.__));
|
||||||
// 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")
|
|
||||||
}
|
}
|
||||||
|
);
|
||||||
|
|
||||||
let permissions: IPermission[] = [];
|
ViewRouter.get(
|
||||||
let proms: PromiseLike<void>[] = [];
|
"/auth",
|
||||||
if (scope) {
|
Stacker(GetUserMiddleware(false, true), async (req, res) => {
|
||||||
for (let perm of scope.split(";").filter(e => e !== "read_user")) {
|
let {
|
||||||
proms.push(Permission.findById(perm).then(p => {
|
scope,
|
||||||
if (!p) return Promise.reject(new Error());
|
redirect_uri,
|
||||||
permissions.push(p);
|
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;
|
let permissions: IPermission[] = [];
|
||||||
await Promise.all(proms).catch(e => {
|
let proms: PromiseLike<void>[] = [];
|
||||||
err = true;
|
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) {
|
if (config.core.dev) {
|
||||||
const logo = ""
|
const logo =
|
||||||
|
"";
|
||||||
ViewRouter.get("/devauth", (req, res) => {
|
ViewRouter.get("/devauth", (req, res) => {
|
||||||
res.send(GetAuthPage(req.__, "Test 05265", [
|
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.",
|
name: "Access Profile",
|
||||||
logo: logo
|
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 1",
|
||||||
},
|
description:
|
||||||
{
|
"This is not an real permission. This is used just to verify the layout",
|
||||||
name: "Test 2",
|
logo: logo
|
||||||
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;
|
2
views/package-lock.json
generated
2
views/package-lock.json
generated
@ -243,7 +243,7 @@
|
|||||||
},
|
},
|
||||||
"duplexer": {
|
"duplexer": {
|
||||||
"version": "0.1.1",
|
"version": "0.1.1",
|
||||||
"resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz",
|
"resolved": "http://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz",
|
||||||
"integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=",
|
"integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit 47f98674eae7bdb6a92917a57bf4fe46dd593e8b
|
Subproject commit e30b04f83c959e19393e82fc5ccc74a363aae53b
|
Loading…
Reference in New Issue
Block a user