소스 검색

Handle redis disconnection gracefully (#5599)

* feat(server/api/contact): handle redis disconnection

* feat(server/api/metrics): handle metrics disabled
tags/v5.1.0
kontrollanten GitHub 2 달 전
부모
커밋
e72ace5a50
No known key found for this signature in database GPG 키 ID: 4AEE18F83AFDEB23
2개의 변경된 파일11개의 추가작업 그리고 1개의 파일을 삭제
  1. +5
    -0
      server/controllers/api/metrics.ts
  2. +6
    -1
      server/controllers/api/server/contact.ts

+ 5
- 0
server/controllers/api/metrics.ts 파일 보기

@@ -2,6 +2,7 @@ import express from 'express'
import { OpenTelemetryMetrics } from '@server/lib/opentelemetry/metrics'
import { HttpStatusCode, PlaybackMetricCreate } from '@shared/models'
import { addPlaybackMetricValidator, asyncMiddleware } from '../../middlewares'
import { CONFIG } from '@server/initializers/config'

const metricsRouter = express.Router()

@@ -19,6 +20,10 @@ export {
// ---------------------------------------------------------------------------

function addPlaybackMetric (req: express.Request, res: express.Response) {
if (!CONFIG.OPEN_TELEMETRY.METRICS.ENABLED) {
return res.sendStatus(HttpStatusCode.FORBIDDEN_403)
}

const body: PlaybackMetricCreate = req.body

OpenTelemetryMetrics.Instance.observePlaybackMetric(res.locals.onlyImmutableVideo, body)


+ 6
- 1
server/controllers/api/server/contact.ts 파일 보기

@@ -1,3 +1,4 @@
import { logger } from '@server/helpers/logger'
import express from 'express'
import { HttpStatusCode } from '../../../../shared/models/http/http-error-codes'
import { ContactForm } from '../../../../shared/models/server'
@@ -17,7 +18,11 @@ async function contactAdministrator (req: express.Request, res: express.Response

Emailer.Instance.addContactFormJob(data.fromEmail, data.fromName, data.subject, data.body)

await Redis.Instance.setContactFormIp(req.ip)
try {
await Redis.Instance.setContactFormIp(req.ip)
} catch (err) {
logger.error(err)
}

return res.status(HttpStatusCode.NO_CONTENT_204).end()
}


불러오는 중...
취소
저장