sunrise-cms/helpers/functions.user.ts

47 lines
1.0 KiB
TypeScript

import { getUserNameFromApiKey } from './functions.api.js'
import * as configFunctions from './functions.config.js'
import type { User } from '../types/recordTypes'
export interface UserRequest {
session?: {
user?: User
}
}
export interface APIRequest {
params?: {
apiKey?: string
}
}
export function userIsAdmin(request: UserRequest): boolean {
return request.session?.user?.userProperties?.isAdmin ?? false
}
export function userCanUpdate(request: UserRequest): boolean {
return request.session?.user?.userProperties?.canUpdate ?? false
}
export async function apiKeyIsValid(request: APIRequest): Promise<boolean> {
const apiKey = request.params?.apiKey
if (apiKey === undefined) {
return false
}
const userName = await getUserNameFromApiKey(apiKey)
if (userName === undefined) {
return false
}
const canLogin = configFunctions
.getProperty('users.canLogin')
.some((currentUserName) => {
return userName === currentUserName.toLowerCase()
})
return canLogin
}