mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-04 02:09:37 +02:00
Add redis cache to feed route
This commit is contained in:
parent
cff8b272b1
commit
4195cd2bc5
4 changed files with 113 additions and 16 deletions
|
@ -1,7 +1,14 @@
|
|||
import * as express from 'express'
|
||||
import { createClient, RedisClient } from 'redis'
|
||||
import { logger } from '../helpers/logger'
|
||||
import { generateRandomString } from '../helpers/utils'
|
||||
import { CONFIG, USER_PASSWORD_RESET_LIFETIME, VIDEO_VIEW_LIFETIME } from '../initializers'
|
||||
import { CONFIG, FEEDS, USER_PASSWORD_RESET_LIFETIME, VIDEO_VIEW_LIFETIME } from '../initializers'
|
||||
|
||||
type CachedRoute = {
|
||||
body: string,
|
||||
contentType?: string
|
||||
statusCode?: string
|
||||
}
|
||||
|
||||
class Redis {
|
||||
|
||||
|
@ -54,6 +61,22 @@ class Redis {
|
|||
return this.exists(this.buildViewKey(ip, videoUUID))
|
||||
}
|
||||
|
||||
async getCachedRoute (req: express.Request) {
|
||||
const cached = await this.getObject(this.buildCachedRouteKey(req))
|
||||
|
||||
return cached as CachedRoute
|
||||
}
|
||||
|
||||
setCachedRoute (req: express.Request, body: any, contentType?: string, statusCode?: number) {
|
||||
const cached: CachedRoute = {
|
||||
body: body.toString(),
|
||||
contentType,
|
||||
statusCode: statusCode.toString()
|
||||
}
|
||||
|
||||
return this.setObject(this.buildCachedRouteKey(req), cached, FEEDS.CACHE_LIFETIME)
|
||||
}
|
||||
|
||||
listJobs (jobsPrefix: string, state: string, mode: 'alpha', order: 'ASC' | 'DESC', offset: number, count: number) {
|
||||
return new Promise<string[]>((res, rej) => {
|
||||
this.client.sort(jobsPrefix + ':jobs:' + state, 'by', mode, order, 'LIMIT', offset.toString(), count.toString(), (err, values) => {
|
||||
|
@ -79,13 +102,39 @@ class Redis {
|
|||
this.client.set(this.prefix + key, value, 'PX', expirationMilliseconds, (err, ok) => {
|
||||
if (err) return rej(err)
|
||||
|
||||
if (ok !== 'OK') return rej(new Error('Redis result is not OK.'))
|
||||
if (ok !== 'OK') return rej(new Error('Redis set result is not OK.'))
|
||||
|
||||
return res()
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
private setObject (key: string, obj: { [ id: string ]: string }, expirationMilliseconds: number) {
|
||||
return new Promise<void>((res, rej) => {
|
||||
this.client.hmset(this.prefix + key, obj, (err, ok) => {
|
||||
if (err) return rej(err)
|
||||
if (!ok) return rej(new Error('Redis mset result is not OK.'))
|
||||
|
||||
this.client.pexpire(this.prefix + key, expirationMilliseconds, (err, ok) => {
|
||||
if (err) return rej(err)
|
||||
if (!ok) return rej(new Error('Redis expiration result is not OK.'))
|
||||
|
||||
return res()
|
||||
})
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
private getObject (key: string) {
|
||||
return new Promise<{ [ id: string ]: string }>((res, rej) => {
|
||||
this.client.hgetall(this.prefix + key, (err, value) => {
|
||||
if (err) return rej(err)
|
||||
|
||||
return res(value)
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
private exists (key: string) {
|
||||
return new Promise<boolean>((res, rej) => {
|
||||
this.client.exists(this.prefix + key, (err, existsNumber) => {
|
||||
|
@ -104,6 +153,10 @@ class Redis {
|
|||
return videoUUID + '-' + ip
|
||||
}
|
||||
|
||||
private buildCachedRouteKey (req: express.Request) {
|
||||
return req.method + '-' + req.originalUrl
|
||||
}
|
||||
|
||||
static get Instance () {
|
||||
return this.instance || (this.instance = new this())
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue