api end fixes
This commit is contained in:
+2
-2
@@ -20,7 +20,7 @@ export type AuthorizationRequest = JwtRequest & {
|
||||
*
|
||||
* NOTE: must be kept in sync with api/tests/support/mock-current-user.ts
|
||||
*/
|
||||
export async function findAndAuthorizeCurrentUserMiddleware(
|
||||
export async function authorizationMiddleware(
|
||||
req: AuthorizationRequest,
|
||||
res: Response,
|
||||
next: NextFunction
|
||||
@@ -38,7 +38,7 @@ export async function findAndAuthorizeCurrentUserMiddleware(
|
||||
|
||||
try {
|
||||
const token = req.headers.authorization || ""
|
||||
const user = await Users.FindFromAuth0TokenService.perform(token)
|
||||
const user = await Users.EnsureFromAuth0TokenService.perform(token)
|
||||
req.currentUser = user
|
||||
return next()
|
||||
} catch (error) {
|
||||
@@ -1,3 +1,3 @@
|
||||
export { findAndAuthorizeCurrentUserMiddleware } from "./find-and-authorize-current-user-middleware"
|
||||
export { authorizationMiddleware } from "./authorization-middleware"
|
||||
export { jwtMiddleware } from "./jwt-middleware"
|
||||
export { requestLoggerMiddleware } from "./request-logger-middleware"
|
||||
|
||||
+2
-2
@@ -14,7 +14,7 @@ import { template } from "lodash"
|
||||
import { APPLICATION_NAME, GIT_COMMIT_HASH, NODE_ENV, RELEASE_TAG } from "@/config"
|
||||
import { logger } from "@/utils/logger"
|
||||
|
||||
import { jwtMiddleware, findAndAuthorizeCurrentUserMiddleware } from "@/middlewares"
|
||||
import { jwtMiddleware, authorizationMiddleware } from "@/middlewares"
|
||||
|
||||
import { CurrentUserController, UsersController } from "@/controllers"
|
||||
|
||||
@@ -31,7 +31,7 @@ router.route("/_status").get((_req: Request, res: Response) => {
|
||||
// external (public) routes - no authentication required
|
||||
|
||||
// api routes
|
||||
router.use("/api", jwtMiddleware, findAndAuthorizeCurrentUserMiddleware)
|
||||
router.use("/api", jwtMiddleware, authorizationMiddleware)
|
||||
|
||||
router.route("/api/current-user").get(CurrentUserController.show)
|
||||
|
||||
|
||||
+19
-4
@@ -2,14 +2,17 @@ import { auth0Integration } from "@/integrations"
|
||||
import { User } from "@/models"
|
||||
import { Op } from "@sequelize/core"
|
||||
import BaseService from "@/services/base-service"
|
||||
import { Users } from "@/services"
|
||||
|
||||
export class FindFromAuth0TokenService extends BaseService {
|
||||
export class EnsureFromAuth0TokenService extends BaseService {
|
||||
constructor(private token: string) {
|
||||
super()
|
||||
}
|
||||
|
||||
async perform(): Promise<User> {
|
||||
const { auth0Subject, email } = await auth0Integration.getUserInfo(this.token)
|
||||
const { auth0Subject, email, firstName, lastName } = await auth0Integration.getUserInfo(
|
||||
this.token
|
||||
)
|
||||
|
||||
const existingUser = await User.withScope(["asCurrentUser"]).findOne({
|
||||
where: { auth0Subject },
|
||||
@@ -28,8 +31,20 @@ export class FindFromAuth0TokenService extends BaseService {
|
||||
return firstTimeUser
|
||||
}
|
||||
|
||||
throw new Error("No user found for this token.")
|
||||
await Users.CreateService.perform({
|
||||
auth0Subject,
|
||||
email,
|
||||
firstName,
|
||||
lastName,
|
||||
})
|
||||
|
||||
const newUser = await User.withScope(["asCurrentUser"]).findOne({
|
||||
where: { auth0Subject },
|
||||
rejectOnEmpty: true,
|
||||
})
|
||||
|
||||
return newUser
|
||||
}
|
||||
}
|
||||
|
||||
export default FindFromAuth0TokenService
|
||||
export default EnsureFromAuth0TokenService
|
||||
@@ -3,4 +3,4 @@ export { UpdateService } from "./update-service"
|
||||
export { DestroyService } from "./destroy-service"
|
||||
|
||||
// Special Services
|
||||
export { FindFromAuth0TokenService } from "./find-from-auth0-token-service"
|
||||
export { EnsureFromAuth0TokenService } from "./ensure-from-auth0-token-service"
|
||||
|
||||
Reference in New Issue
Block a user