UNPKG

rajt

Version:

A serverless bundler layer, fully typed for AWS Lambda (Node.js and LLRT) and Cloudflare Workers.

101 lines (79 loc) 2.55 kB
import { Envir } from 't0n' import { Token as Factory } from 'cripta' import { UAParser } from 'ua-parser-js' import c from '../context' export class Token { static #name: string = 'Authorization' static #prefix: string = 'bearer' static fromRequest() { const token = this.fromCookie() || this.fromHeader() return token ? this.parse(token) : null } static fromHeader(): string | null { const header = c.cx.req.header(this.#name) || c.cx.req.header('HTTP_AUTHORIZATION') || c.cx.req.header('REDIRECT_HTTP_AUTHORIZATION') || null if (header) { const pos = header.toLowerCase().indexOf(this.#prefix.toLowerCase()) if (pos < 0) return header let token = header.slice(pos + this.#prefix.length).trim() const commaPos = token.indexOf(',') if (commaPos > -1) token = token.slice(0, commaPos).trim() return token } return null } static fromCookie(): string | null { const uid = c.cx.req.header('uid') if (uid) { const auth = c.cookie.get('__auth_' + uid) return auth ? auth : null } return null } static parse(token: string) { const host = this.host() const serveHost = Envir.get('FLOW_SERVER', host) as string return Factory.parse(token) .issuedBy(serveHost) .permittedFor(host) .withClaim('u', this.userAgent()) .withClaim('i', this.ip()) } static create(user: any, exp: number = 7200) { const time = Math.floor(Date.now() / 1000) const host = this.host(c.cx.req.header('host') || '') return Factory.create() .issuedBy(host) .permittedFor(host) .issuedAt(time) .expiresAt(time + exp) .withClaim('u', this.userAgent()) .withClaim('i', this.ip()) .body(user) } static setPrefix(prefix: string): void { this.#prefix = prefix } static setName(name: string): void { this.#name = name } static host(url?: string | null | undefined): string { if (!url) url = c.cx.req.url || c.cx.req.header('host') || '' let formattedUrl = String(url) if (!formattedUrl.startsWith('http')) formattedUrl = 'http://' + formattedUrl try { const parsedUrl = new URL(formattedUrl) return parsedUrl.host } catch { return '' } } static userAgent() { if (!c?.userAgent) return 0 const { browser, device, os } = UAParser(c.userAgent) return (browser?.name || '') + (browser?.major || '') + (device?.model || '') + (os?.name || '') } static ip() { return c?.ip || 0 } }