import * as jose from 'jose';
import { Request, Response } from 'express';
import { getUserInfo } from '../services/user-info-service';
import { getFeatureFlags } from '../services/feature-flags-service';
const GITBOOK_VISITOR_SIGNING_KEY = process.env.GITBOOK_VISITOR_SIGNING_KEY;
const GITBOOK_VISITOR_COOKIE_NAME = 'gitbook-visitor-token';
export async function handleAppLoginRequest(req: Request, res: Response) {
// ログインリクエストを処理するためのビジネスロジック
// たとえば、認証情報を確認してユーザーを認証する
//
// 例:
// const loggedInUser = await authenticateUser(req.body.username, req.body.password);
// ユーザー認証後、GitBook に渡したいユーザー情報を取得します
// データベースまたはユーザーサービスから。
const userInfo = await getUserInfo(loggedInUser.id);
// ユーザー情報を使って JWT のペイロードを構築します
const gitbookVisitorClaims = {
firstName: userInfo.firstName,
lastName: userInfo.lastName,
isBetaUser: userInfo.isBetaUser
products: userInfo.products.map((product) => product.name),
featureFlags: await getFeatureFlags({userId: loggedInUser.id})
}
// クレームを使用して署名付き JWT を生成します
const gitbookVisitorJWT = await new jose.SignJWT(gitbookVisitorClaims)
.setProtectedHeader({ alg: 'HS256' })
.setIssuedAt()
.setExpirationTime('2h') // 任意の 2 時間の有効期限
.sign(GITBOOK_VISITOR_SIGNING_KEY);
// エンコードされた JWT を含む `gitbook-visitor-token` Cookie を
// ログインハンドラーのレスポンスに含めます
res.cookie(GITBOOK_VISITOR_COOKIE_NAME, gitbookVisitorJWT, {
httpOnly: true,
secure: process.env.NODE_ENV === 'production',
maxAge: 2 * 60 * 60 * 1000, // 任意の 2 時間の有効期限
domain: '.acme.org' //
});
// ユーザーをアプリへリダイレクトする処理を含む、ログインハンドラーの残りのロジック
res.redirect('/'); // リダイレクトの例
}