Files
gridpilot.gg/apps/website/lib/page-queries/auth/LoginPageQuery.ts
2026-01-14 10:51:05 +01:00

47 lines
1.8 KiB
TypeScript

/**
* Login Page Query
*
* Composes data for the login page using RSC pattern.
* No business logic, only data composition.
*/
import { Result } from '@/lib/contracts/Result';
import { PageQuery } from '@/lib/contracts/page-queries/PageQuery';
import { LoginViewDataBuilder } from '@/lib/builders/view-data/LoginViewDataBuilder';
import { LoginViewData } from '@/lib/builders/view-data/types/LoginViewData';
import { AuthPageService } from '@/lib/services/auth/AuthPageService';
import { SearchParamParser } from '@/lib/routing/search-params/SearchParamParser';
export class LoginPageQuery implements PageQuery<LoginViewData, URLSearchParams> {
async execute(searchParams: URLSearchParams): Promise<Result<LoginViewData, string>> {
// Parse and validate search parameters
const parsedResult = SearchParamParser.parseAuth(searchParams);
if (parsedResult.isErr()) {
return Result.err(`Invalid search parameters: ${parsedResult.getError()}`);
}
const { returnTo, token } = parsedResult.unwrap();
try {
// Use service to process parameters
const authService = new AuthPageService();
const serviceResult = await authService.processLoginParams({ returnTo, token });
if (serviceResult.isErr()) {
return Result.err(serviceResult.getError());
}
// Transform to ViewData using builder
const viewData = LoginViewDataBuilder.build(serviceResult.unwrap());
return Result.ok(viewData);
} catch (error) {
return Result.err('Failed to execute login page query');
}
}
// Static factory method for convenience
static async execute(searchParams: URLSearchParams): Promise<Result<LoginViewData, string>> {
const query = new LoginPageQuery();
return query.execute(searchParams);
}
}