diff options
author | Chocobozzz <me@florianbigard.com> | 2020-11-10 16:29:35 +0100 |
---|---|---|
committer | Chocobozzz <me@florianbigard.com> | 2020-11-10 16:29:35 +0100 |
commit | 2af337c83905c420b2d9022ee6fd3d6ef5fd1e42 (patch) | |
tree | fa6293371d4b607e00545a552ccd8bfab465926a /server/models/video | |
parent | b9cf3fb6381f71c976fbe515f728082d90a9c437 (diff) | |
download | PeerTube-2af337c83905c420b2d9022ee6fd3d6ef5fd1e42.tar.gz PeerTube-2af337c83905c420b2d9022ee6fd3d6ef5fd1e42.tar.zst PeerTube-2af337c83905c420b2d9022ee6fd3d6ef5fd1e42.zip |
Cleanup follows of orphean actors
Diffstat (limited to 'server/models/video')
-rw-r--r-- | server/models/video/video-channel.ts | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/server/models/video/video-channel.ts b/server/models/video/video-channel.ts index 9da965bbc..202dc513f 100644 --- a/server/models/video/video-channel.ts +++ b/server/models/video/video-channel.ts | |||
@@ -1,3 +1,5 @@ | |||
1 | import * as Bluebird from 'bluebird' | ||
2 | import { FindOptions, literal, Op, ScopeOptions } from 'sequelize' | ||
1 | import { | 3 | import { |
2 | AllowNull, | 4 | AllowNull, |
3 | BeforeDestroy, | 5 | BeforeDestroy, |
@@ -23,17 +25,8 @@ import { | |||
23 | isVideoChannelNameValid, | 25 | isVideoChannelNameValid, |
24 | isVideoChannelSupportValid | 26 | isVideoChannelSupportValid |
25 | } from '../../helpers/custom-validators/video-channels' | 27 | } from '../../helpers/custom-validators/video-channels' |
26 | import { sendDeleteActor } from '../../lib/activitypub/send' | ||
27 | import { AccountModel, ScopeNames as AccountModelScopeNames, SummaryOptions as AccountSummaryOptions } from '../account/account' | ||
28 | import { ActorModel, unusedActorAttributesForAPI } from '../activitypub/actor' | ||
29 | import { buildServerIdsFollowedBy, buildTrigramSearchIndex, createSimilarityAttribute, getSort, throwIfNotValid } from '../utils' | ||
30 | import { VideoModel } from './video' | ||
31 | import { CONSTRAINTS_FIELDS, WEBSERVER } from '../../initializers/constants' | 28 | import { CONSTRAINTS_FIELDS, WEBSERVER } from '../../initializers/constants' |
32 | import { ServerModel } from '../server/server' | 29 | import { sendDeleteActor } from '../../lib/activitypub/send' |
33 | import { FindOptions, Op, literal, ScopeOptions } from 'sequelize' | ||
34 | import { AvatarModel } from '../avatar/avatar' | ||
35 | import { VideoPlaylistModel } from './video-playlist' | ||
36 | import * as Bluebird from 'bluebird' | ||
37 | import { | 30 | import { |
38 | MChannelAccountDefault, | 31 | MChannelAccountDefault, |
39 | MChannelActor, | 32 | MChannelActor, |
@@ -42,6 +35,14 @@ import { | |||
42 | MChannelFormattable, | 35 | MChannelFormattable, |
43 | MChannelSummaryFormattable | 36 | MChannelSummaryFormattable |
44 | } from '../../types/models/video' | 37 | } from '../../types/models/video' |
38 | import { AccountModel, ScopeNames as AccountModelScopeNames, SummaryOptions as AccountSummaryOptions } from '../account/account' | ||
39 | import { ActorModel, unusedActorAttributesForAPI } from '../activitypub/actor' | ||
40 | import { ActorFollowModel } from '../activitypub/actor-follow' | ||
41 | import { AvatarModel } from '../avatar/avatar' | ||
42 | import { ServerModel } from '../server/server' | ||
43 | import { buildServerIdsFollowedBy, buildTrigramSearchIndex, createSimilarityAttribute, getSort, throwIfNotValid } from '../utils' | ||
44 | import { VideoModel } from './video' | ||
45 | import { VideoPlaylistModel } from './video-playlist' | ||
45 | 46 | ||
46 | export enum ScopeNames { | 47 | export enum ScopeNames { |
47 | FOR_API = 'FOR_API', | 48 | FOR_API = 'FOR_API', |
@@ -293,6 +294,8 @@ export class VideoChannelModel extends Model<VideoChannelModel> { | |||
293 | instance.Actor = await instance.$get('Actor', { transaction: options.transaction }) | 294 | instance.Actor = await instance.$get('Actor', { transaction: options.transaction }) |
294 | } | 295 | } |
295 | 296 | ||
297 | await ActorFollowModel.removeFollowsOf(instance.Actor.id, options.transaction) | ||
298 | |||
296 | if (instance.Actor.isOwned()) { | 299 | if (instance.Actor.isOwned()) { |
297 | return sendDeleteActor(instance.Actor, options.transaction) | 300 | return sendDeleteActor(instance.Actor, options.transaction) |
298 | } | 301 | } |