75 lines
2.1 KiB
TypeScript
75 lines
2.1 KiB
TypeScript
|
import { logger } from '@server/helpers/logger'
|
||
|
import { WEBSERVER } from '@server/initializers/constants'
|
||
|
import { getAbuseTargetUrl } from '@server/lib/activitypub/url'
|
||
|
import { UserModel } from '@server/models/user/user'
|
||
|
import { UserNotificationModel } from '@server/models/user/user-notification'
|
||
|
import { MAbuseFull, MUserDefault, MUserWithNotificationSetting, UserNotificationModelForApi } from '@server/types/models'
|
||
|
import { AbuseState, UserNotificationType } from '@shared/models'
|
||
|
import { AbstractNotification } from '../common/abstract-notification'
|
||
|
|
||
|
export class AbuseStateChangeForReporter extends AbstractNotification <MAbuseFull> {
|
||
|
|
||
|
private user: MUserDefault
|
||
|
|
||
|
async prepare () {
|
||
|
const reporter = this.abuse.ReporterAccount
|
||
|
if (reporter.isOwned() !== true) return
|
||
|
|
||
|
this.user = await UserModel.loadByAccountActorId(this.abuse.ReporterAccount.actorId)
|
||
|
}
|
||
|
|
||
|
log () {
|
||
|
logger.info('Notifying reporter of abuse % of state change.', getAbuseTargetUrl(this.abuse))
|
||
|
}
|
||
|
|
||
|
getSetting (user: MUserWithNotificationSetting) {
|
||
|
return user.NotificationSetting.abuseStateChange
|
||
|
}
|
||
|
|
||
|
getTargetUsers () {
|
||
|
if (!this.user) return []
|
||
|
|
||
|
return [ this.user ]
|
||
|
}
|
||
|
|
||
|
async createNotification (user: MUserWithNotificationSetting) {
|
||
|
const notification = await UserNotificationModel.create<UserNotificationModelForApi>({
|
||
|
type: UserNotificationType.ABUSE_STATE_CHANGE,
|
||
|
userId: user.id,
|
||
|
abuseId: this.abuse.id
|
||
|
})
|
||
|
notification.Abuse = this.abuse
|
||
|
|
||
|
return notification
|
||
|
}
|
||
|
|
||
|
createEmail (to: string) {
|
||
|
const text = this.abuse.state === AbuseState.ACCEPTED
|
||
|
? 'Report #' + this.abuse.id + ' has been accepted'
|
||
|
: 'Report #' + this.abuse.id + ' has been rejected'
|
||
|
|
||
|
const abuseUrl = WEBSERVER.URL + '/my-account/abuses?search=%23' + this.abuse.id
|
||
|
|
||
|
const action = {
|
||
|
text,
|
||
|
url: abuseUrl
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
template: 'abuse-state-change',
|
||
|
to,
|
||
|
subject: text,
|
||
|
locals: {
|
||
|
action,
|
||
|
abuseId: this.abuse.id,
|
||
|
abuseUrl,
|
||
|
isAccepted: this.abuse.state === AbuseState.ACCEPTED
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
private get abuse () {
|
||
|
return this.payload
|
||
|
}
|
||
|
}
|