mirror of
https://github.com/OneUptime/oneuptime.git
synced 2026-04-06 00:32:12 +02:00
- Implemented MonitorUtil for managing monitor secrets and populating them in monitor steps and tests. - Created StackTraceParser to parse and structure stack traces from various programming languages. - Developed SyslogParser to handle and parse syslog messages in both RFC 5424 and RFC 3164 formats.
38 lines
1004 B
TypeScript
38 lines
1004 B
TypeScript
import Express, {
|
|
ExpressRequest,
|
|
ExpressResponse,
|
|
ExpressRouter,
|
|
NextFunction,
|
|
} from "Common/Server/Utils/Express";
|
|
import TelemetryQueueService from "../Services/Queue/TelemetryQueueService";
|
|
// import ClusterKeyAuthorization from "Common/Server/Middleware/ClusterKeyAuthorization";
|
|
|
|
const router: ExpressRouter = Express.getRouter();
|
|
|
|
/**
|
|
* JSON metrics endpoint for KEDA autoscaling
|
|
* Returns queue size as JSON for KEDA metrics-api scaler
|
|
*/
|
|
router.get(
|
|
"/metrics/queue-size",
|
|
// ClusterKeyAuthorization.isAuthorizedServiceMiddleware, // Temporarily disabled for KEDA debugging
|
|
async (
|
|
_req: ExpressRequest,
|
|
res: ExpressResponse,
|
|
next: NextFunction,
|
|
): Promise<void> => {
|
|
try {
|
|
const queueSize: number = await TelemetryQueueService.getQueueSize();
|
|
|
|
res.setHeader("Content-Type", "application/json");
|
|
res.status(200).json({
|
|
queueSize: queueSize,
|
|
});
|
|
} catch (err) {
|
|
return next(err);
|
|
}
|
|
},
|
|
);
|
|
|
|
export default router;
|