123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- import { registerTSPaths } from '../server/helpers/register-ts-paths'
- registerTSPaths()
- import { WEBSERVER } from '../server/initializers/constants'
- import { ActorFollowModel } from '../server/models/activitypub/actor-follow'
- import { VideoModel } from '../server/models/video/video'
- import { ActorModel } from '../server/models/activitypub/actor'
- import {
- getLocalAccountActivityPubUrl,
- getLocalVideoActivityPubUrl,
- getLocalVideoAnnounceActivityPubUrl,
- getLocalVideoChannelActivityPubUrl,
- getLocalVideoCommentActivityPubUrl
- } from '../server/lib/activitypub/url'
- import { VideoShareModel } from '../server/models/video/video-share'
- import { VideoCommentModel } from '../server/models/video/video-comment'
- import { AccountModel } from '../server/models/account/account'
- import { VideoChannelModel } from '../server/models/video/video-channel'
- import { VideoStreamingPlaylistModel } from '../server/models/video/video-streaming-playlist'
- import { initDatabaseModels } from '../server/initializers/database'
- import { createTorrentAndSetInfoHash } from '@server/helpers/webtorrent'
- import { getServerActor } from '@server/models/application/application'
- run()
- .then(() => process.exit(0))
- .catch(err => {
- console.error(err)
- process.exit(-1)
- })
- async function run () {
- await initDatabaseModels(true)
- const serverAccount = await getServerActor()
- {
- const res = await ActorFollowModel.listAcceptedFollowingUrlsForApi([ serverAccount.id ], undefined)
- const hasFollowing = res.total > 0
- if (hasFollowing === true) {
- throw new Error('Cannot update host because you follow other servers!')
- }
- }
- console.log('Updating actors.')
- const actors: ActorModel[] = await ActorModel.unscoped().findAll({
- include: [
- {
- model: VideoChannelModel.unscoped(),
- required: false
- },
- {
- model: AccountModel.unscoped(),
- required: false
- }
- ]
- })
- for (const actor of actors) {
- if (actor.isOwned() === false) continue
- console.log('Updating actor ' + actor.url)
- const newUrl = actor.Account
- ? getLocalAccountActivityPubUrl(actor.preferredUsername)
- : getLocalVideoChannelActivityPubUrl(actor.preferredUsername)
- actor.url = newUrl
- actor.inboxUrl = newUrl + '/inbox'
- actor.outboxUrl = newUrl + '/outbox'
- actor.sharedInboxUrl = WEBSERVER.URL + '/inbox'
- actor.followersUrl = newUrl + '/followers'
- actor.followingUrl = newUrl + '/following'
- await actor.save()
- }
- console.log('Updating video shares.')
- const videoShares: VideoShareModel[] = await VideoShareModel.findAll({
- include: [ VideoModel.unscoped(), ActorModel.unscoped() ]
- })
- for (const videoShare of videoShares) {
- if (videoShare.Video.isOwned() === false) continue
- console.log('Updating video share ' + videoShare.url)
- videoShare.url = getLocalVideoAnnounceActivityPubUrl(videoShare.Actor, videoShare.Video)
- await videoShare.save()
- }
- console.log('Updating video comments.')
- const videoComments: VideoCommentModel[] = await VideoCommentModel.findAll({
- include: [
- {
- model: VideoModel.unscoped()
- },
- {
- model: AccountModel.unscoped(),
- include: [
- {
- model: ActorModel.unscoped()
- }
- ]
- }
- ]
- })
- for (const comment of videoComments) {
- if (comment.isOwned() === false) continue
- console.log('Updating comment ' + comment.url)
- comment.url = getLocalVideoCommentActivityPubUrl(comment.Video, comment)
- await comment.save()
- }
- console.log('Updating video and torrent files.')
- const videos = await VideoModel.listLocal()
- for (const video of videos) {
- console.log('Updating video ' + video.uuid)
- video.url = getLocalVideoActivityPubUrl(video)
- await video.save()
- for (const file of video.VideoFiles) {
- console.log('Updating torrent file %s of video %s.', file.resolution, video.uuid)
- await createTorrentAndSetInfoHash(video, file)
- }
- for (const playlist of video.VideoStreamingPlaylists) {
- playlist.playlistUrl = WEBSERVER.URL + VideoStreamingPlaylistModel.getHlsMasterPlaylistStaticPath(video.uuid)
- playlist.segmentsSha256Url = WEBSERVER.URL + VideoStreamingPlaylistModel.getHlsSha256SegmentsStaticPath(video.uuid, video.isLive)
- await playlist.save()
- }
- }
- }
|