mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-01-31 20:03:37 +00:00
- Added a new utility for checking Codex CLI authentication status using the 'codex login status' command. - Integrated the authentication check into the CodexProvider's installation detection and authentication methods. - Updated Codex CLI status display in the UI to reflect authentication status and method. - Enhanced error handling and logging for better debugging during authentication checks. - Refactored related components to ensure consistent handling of authentication across the application.
57 lines
2.1 KiB
TypeScript
57 lines
2.1 KiB
TypeScript
import { Router, Request, Response } from 'express';
|
|
import { CodexUsageService } from '../../services/codex-usage-service.js';
|
|
import { createLogger } from '@automaker/utils';
|
|
|
|
const logger = createLogger('Codex');
|
|
|
|
export function createCodexRoutes(service: CodexUsageService): Router {
|
|
const router = Router();
|
|
|
|
// Get current usage (attempts to fetch from Codex CLI)
|
|
router.get('/usage', async (req: Request, res: Response) => {
|
|
try {
|
|
// Check if Codex CLI is available first
|
|
const isAvailable = await service.isAvailable();
|
|
if (!isAvailable) {
|
|
// IMPORTANT: This endpoint is behind Automaker session auth already.
|
|
// Use a 200 + error payload for Codex CLI issues so the UI doesn't
|
|
// interpret it as an invalid Automaker session (401/403 triggers logout).
|
|
res.status(200).json({
|
|
error: 'Codex CLI not found',
|
|
message: "Please install Codex CLI and run 'codex login' to authenticate",
|
|
});
|
|
return;
|
|
}
|
|
|
|
const usage = await service.fetchUsageData();
|
|
res.json(usage);
|
|
} catch (error) {
|
|
const message = error instanceof Error ? error.message : 'Unknown error';
|
|
|
|
if (message.includes('not authenticated') || message.includes('login')) {
|
|
// Do NOT use 401/403 here: that status code is reserved for Automaker session auth.
|
|
res.status(200).json({
|
|
error: 'Authentication required',
|
|
message: "Please run 'codex login' to authenticate",
|
|
});
|
|
} else if (message.includes('not available') || message.includes('does not provide')) {
|
|
// This is the expected case - Codex doesn't provide usage stats
|
|
res.status(200).json({
|
|
error: 'Usage statistics not available',
|
|
message: message,
|
|
});
|
|
} else if (message.includes('timed out')) {
|
|
res.status(200).json({
|
|
error: 'Command timed out',
|
|
message: 'The Codex CLI took too long to respond',
|
|
});
|
|
} else {
|
|
logger.error('Error fetching usage:', error);
|
|
res.status(500).json({ error: message });
|
|
}
|
|
}
|
|
});
|
|
|
|
return router;
|
|
}
|