PeerTube/server/controllers/bots.ts

99 lines
2.8 KiB
TypeScript
Raw Normal View History

2021-08-27 14:32:44 +02:00
import express from 'express'
2021-07-26 15:04:37 +02:00
import { truncate } from 'lodash'
2020-04-01 14:16:19 +02:00
import { SitemapStream, streamToPromise } from 'sitemap'
2021-07-26 15:04:37 +02:00
import { buildNSFWFilter } from '../helpers/express-utils'
import { ROUTE_CACHE_LIFETIME, WEBSERVER } from '../initializers/constants'
import { asyncMiddleware } from '../middlewares'
import { cacheRoute } from '../middlewares/cache/cache'
import { AccountModel } from '../models/account/account'
2018-12-05 17:27:24 +01:00
import { VideoModel } from '../models/video/video'
import { VideoChannelModel } from '../models/video/video-channel'
const botsRouter = express.Router()
// Special route that add OpenGraph and oEmbed tags
// Do not use a template engine for a so little thing
botsRouter.use('/sitemap.xml',
cacheRoute(ROUTE_CACHE_LIFETIME.SITEMAP),
2018-12-05 17:27:24 +01:00
asyncMiddleware(getSitemap)
)
// ---------------------------------------------------------------------------
export {
botsRouter
}
// ---------------------------------------------------------------------------
async function getSitemap (req: express.Request, res: express.Response) {
let urls = getSitemapBasicUrls()
urls = urls.concat(await getSitemapLocalVideoUrls())
urls = urls.concat(await getSitemapVideoChannelUrls())
urls = urls.concat(await getSitemapAccountUrls())
2020-04-01 14:16:19 +02:00
const sitemapStream = new SitemapStream({ hostname: WEBSERVER.URL })
2018-12-05 17:27:24 +01:00
2020-04-01 17:02:52 +02:00
for (const urlObj of urls) {
sitemapStream.write(urlObj)
2020-04-01 14:16:19 +02:00
}
sitemapStream.end()
const xml = await streamToPromise(sitemapStream)
2018-12-05 17:27:24 +01:00
2019-10-21 14:50:55 +02:00
res.header('Content-Type', 'application/xml')
res.send(xml)
2018-12-05 17:27:24 +01:00
}
async function getSitemapVideoChannelUrls () {
const rows = await VideoChannelModel.listLocalsForSitemap('createdAt')
return rows.map(channel => ({
2019-04-11 11:33:44 +02:00
url: WEBSERVER.URL + '/video-channels/' + channel.Actor.preferredUsername
2018-12-05 17:27:24 +01:00
}))
}
async function getSitemapAccountUrls () {
const rows = await AccountModel.listLocalsForSitemap('createdAt')
return rows.map(channel => ({
2019-04-11 11:33:44 +02:00
url: WEBSERVER.URL + '/accounts/' + channel.Actor.preferredUsername
2018-12-05 17:27:24 +01:00
}))
}
async function getSitemapLocalVideoUrls () {
2020-01-08 14:15:16 +01:00
const { data } = await VideoModel.listForApi({
2018-12-05 17:27:24 +01:00
start: 0,
count: undefined,
sort: 'createdAt',
includeLocalVideos: true,
nsfw: buildNSFWFilter(),
filter: 'local',
2020-01-08 14:15:16 +01:00
withFiles: false,
countVideos: false
2018-12-05 17:27:24 +01:00
})
2020-01-08 14:15:16 +01:00
return data.map(v => ({
2021-07-26 15:04:37 +02:00
url: WEBSERVER.URL + v.getWatchStaticPath(),
2018-12-05 17:27:24 +01:00
video: [
{
title: v.name,
// Sitemap description should be < 2000 characters
description: truncate(v.description || v.name, { length: 2000, omission: '...' }),
2021-07-26 15:04:37 +02:00
player_loc: WEBSERVER.URL + v.getEmbedStaticPath(),
2019-04-23 09:50:57 +02:00
thumbnail_loc: WEBSERVER.URL + v.getMiniatureStaticPath()
2018-12-05 17:27:24 +01:00
}
]
}))
}
function getSitemapBasicUrls () {
const paths = [
'/about/instance',
'/videos/local'
]
2019-04-11 11:33:44 +02:00
return paths.map(p => ({ url: WEBSERVER.URL + p }))
2018-12-05 17:27:24 +01:00
}