PeerTube/server/tests/api/moderation/abuses.ts

917 lines
32 KiB
TypeScript
Raw Normal View History

2020-07-07 12:34:16 +00:00
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha'
import * as chai from 'chai'
import { AbuseMessage, AbusePredefinedReasonsString, AbuseState, AdminAbuse, UserAbuse } from '@shared/models'
2020-07-07 12:34:16 +00:00
import {
2021-07-06 10:01:59 +00:00
AbusesCommand,
2020-07-07 12:34:16 +00:00
cleanupTests,
2021-07-16 07:47:51 +00:00
createMultipleServers,
2021-07-16 08:42:24 +00:00
doubleFollow,
2021-07-16 07:47:51 +00:00
PeerTubeServer,
2020-07-07 12:34:16 +00:00
setAccessTokensToServers,
setDefaultAccountAvatar,
setDefaultChannelAvatar,
2021-07-06 10:01:59 +00:00
waitJobs
} from '@shared/server-commands'
2020-07-07 12:34:16 +00:00
const expect = chai.expect
describe('Test abuses', function () {
2021-07-16 07:47:51 +00:00
let servers: PeerTubeServer[] = []
2020-07-24 13:05:51 +00:00
let abuseServer1: AdminAbuse
let abuseServer2: AdminAbuse
2021-07-06 10:01:59 +00:00
let commands: AbusesCommand[]
2020-07-07 12:34:16 +00:00
before(async function () {
this.timeout(50000)
// Run servers
2021-07-16 07:47:51 +00:00
servers = await createMultipleServers(2)
2020-07-07 12:34:16 +00:00
await setAccessTokensToServers(servers)
await setDefaultChannelAvatar(servers)
await setDefaultAccountAvatar(servers)
2020-07-07 12:34:16 +00:00
// Server 1 and server 2 follow each other
await doubleFollow(servers[0], servers[1])
2021-07-06 10:01:59 +00:00
2021-07-16 07:04:35 +00:00
commands = servers.map(s => s.abuses)
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
describe('Video abuses', function () {
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
before(async function () {
this.timeout(50000)
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
// Upload some videos on each servers
2021-07-15 08:02:54 +00:00
{
const attributes = {
name: 'my super name for server 1',
description: 'my super description for server 1'
}
2021-07-16 07:04:35 +00:00
await servers[0].videos.upload({ attributes })
2020-07-08 13:51:46 +00:00
}
2020-07-07 12:34:16 +00:00
2021-07-15 08:02:54 +00:00
{
const attributes = {
name: 'my super name for server 2',
description: 'my super description for server 2'
}
2021-07-16 07:04:35 +00:00
await servers[1].videos.upload({ attributes })
2020-07-08 13:51:46 +00:00
}
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
// Wait videos propagation, server 2 has transcoding enabled
await waitJobs(servers)
2020-07-07 12:34:16 +00:00
2021-07-16 07:04:35 +00:00
const { data } = await servers[0].videos.list()
2021-07-15 08:02:54 +00:00
expect(data.length).to.equal(2)
2020-07-07 12:34:16 +00:00
2021-07-22 12:28:03 +00:00
servers[0].store.videoCreated = data.find(video => video.name === 'my super name for server 1')
servers[1].store.videoCreated = data.find(video => video.name === 'my super name for server 2')
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should not have abuses', async function () {
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(body.total).to.equal(0)
expect(body.data).to.be.an('array')
expect(body.data.length).to.equal(0)
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should report abuse on a local video', async function () {
this.timeout(15000)
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
const reason = 'my super bad reason'
2021-07-22 12:28:03 +00:00
await commands[0].report({ videoId: servers[0].store.videoCreated.id, reason })
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
// We wait requests propagation, even if the server 1 is not supposed to make a request to server 2
await waitJobs(servers)
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should have 1 video abuses on server 1 and 0 on server 2', async function () {
2021-07-06 10:01:59 +00:00
{
const body = await commands[0].getAdminList()
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(body.total).to.equal(1)
expect(body.data).to.be.an('array')
expect(body.data.length).to.equal(1)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data[0]
expect(abuse.reason).to.equal('my super bad reason')
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse.reporterAccount.name).to.equal('root')
expect(abuse.reporterAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2021-07-22 12:28:03 +00:00
expect(abuse.video.id).to.equal(servers[0].store.videoCreated.id)
2021-07-06 10:01:59 +00:00
expect(abuse.video.channel).to.exist
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse.comment).to.be.null
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse.flaggedAccount.name).to.equal('root')
expect(abuse.flaggedAccount.host).to.equal(servers[0].host)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse.video.countReports).to.equal(1)
expect(abuse.video.nthReport).to.equal(1)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse.countReportsForReporter).to.equal(1)
expect(abuse.countReportsForReportee).to.equal(1)
}
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[1].getAdminList()
expect(body.total).to.equal(0)
expect(body.data).to.be.an('array')
expect(body.data.length).to.equal(0)
}
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should report abuse on a remote video', async function () {
this.timeout(10000)
const reason = 'my super bad reason 2'
2021-07-22 12:28:03 +00:00
const videoId = await servers[0].videos.getId({ uuid: servers[1].store.videoCreated.uuid })
2021-07-06 10:01:59 +00:00
await commands[0].report({ videoId, reason })
2020-07-08 13:51:46 +00:00
// We wait requests propagation
2020-07-07 12:34:16 +00:00
await waitJobs(servers)
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should have 2 video abuses on server 1 and 1 on server 2', async function () {
2021-07-06 10:01:59 +00:00
{
const body = await commands[0].getAdminList()
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(body.total).to.equal(2)
expect(body.data.length).to.equal(2)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const abuse1 = body.data[0]
expect(abuse1.reason).to.equal('my super bad reason')
expect(abuse1.reporterAccount.name).to.equal('root')
expect(abuse1.reporterAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2021-07-22 12:28:03 +00:00
expect(abuse1.video.id).to.equal(servers[0].store.videoCreated.id)
2021-07-06 10:01:59 +00:00
expect(abuse1.video.countReports).to.equal(1)
expect(abuse1.video.nthReport).to.equal(1)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse1.comment).to.be.null
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse1.flaggedAccount.name).to.equal('root')
expect(abuse1.flaggedAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse1.state.id).to.equal(AbuseState.PENDING)
expect(abuse1.state.label).to.equal('Pending')
expect(abuse1.moderationComment).to.be.null
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const abuse2 = body.data[1]
expect(abuse2.reason).to.equal('my super bad reason 2')
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.reporterAccount.name).to.equal('root')
expect(abuse2.reporterAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2022-06-07 09:40:47 +00:00
expect(abuse2.video.uuid).to.equal(servers[1].store.videoCreated.uuid)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.comment).to.be.null
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.flaggedAccount.name).to.equal('root')
expect(abuse2.flaggedAccount.host).to.equal(servers[1].host)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.state.id).to.equal(AbuseState.PENDING)
expect(abuse2.state.label).to.equal('Pending')
expect(abuse2.moderationComment).to.be.null
}
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[1].getAdminList()
expect(body.total).to.equal(1)
expect(body.data.length).to.equal(1)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
abuseServer2 = body.data[0]
expect(abuseServer2.reason).to.equal('my super bad reason 2')
expect(abuseServer2.reporterAccount.name).to.equal('root')
expect(abuseServer2.reporterAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.flaggedAccount.name).to.equal('root')
expect(abuseServer2.flaggedAccount.host).to.equal(servers[1].host)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.state.id).to.equal(AbuseState.PENDING)
expect(abuseServer2.state.label).to.equal('Pending')
expect(abuseServer2.moderationComment).to.be.null
}
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should hide video abuses from blocked accounts', async function () {
this.timeout(10000)
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
{
2021-07-22 12:28:03 +00:00
const videoId = await servers[1].videos.getId({ uuid: servers[0].store.videoCreated.uuid })
2021-07-06 10:01:59 +00:00
await commands[1].report({ videoId, reason: 'will mute this' })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(3)
2020-07-08 13:51:46 +00:00
}
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
const accountToBlock = 'root@' + servers[1].host
{
2021-07-16 07:04:35 +00:00
await servers[0].blocklist.addToServerBlocklist({ account: accountToBlock })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data.find(a => a.reason === 'will mute this')
2020-07-08 13:51:46 +00:00
expect(abuse).to.be.undefined
}
{
2021-07-16 07:04:35 +00:00
await servers[0].blocklist.removeFromServerBlocklist({ account: accountToBlock })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(3)
2020-07-08 13:51:46 +00:00
}
})
it('Should hide video abuses from blocked servers', async function () {
const serverToBlock = servers[1].host
{
2021-07-16 07:04:35 +00:00
await servers[0].blocklist.addToServerBlocklist({ server: serverToBlock })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data.find(a => a.reason === 'will mute this')
2020-07-08 13:51:46 +00:00
expect(abuse).to.be.undefined
}
{
2021-07-16 07:04:35 +00:00
await servers[0].blocklist.removeFromServerBlocklist({ server: serverToBlock })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(3)
2020-07-08 13:51:46 +00:00
}
})
it('Should keep the video abuse when deleting the video', async function () {
this.timeout(10000)
2021-07-16 07:04:35 +00:00
await servers[1].videos.remove({ id: abuseServer2.video.uuid })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList()
expect(body.total).to.equal(2, 'wrong number of videos returned')
expect(body.data).to.have.lengthOf(2, 'wrong number of videos returned')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data[0]
expect(abuse.id).to.equal(abuseServer2.id, 'wrong origin server id for first video')
expect(abuse.video.id).to.equal(abuseServer2.video.id, 'wrong video id')
2020-07-08 13:51:46 +00:00
expect(abuse.video.channel).to.exist
expect(abuse.video.deleted).to.be.true
})
it('Should include counts of reports from reporter and reportee', async function () {
this.timeout(10000)
// register a second user to have two reporters/reportees
const user = { username: 'user2', password: 'password' }
2021-07-16 07:04:35 +00:00
await servers[0].users.create({ ...user })
const userAccessToken = await servers[0].login.getAccessToken(user)
2020-07-08 13:51:46 +00:00
// upload a third video via this user
2021-07-15 08:02:54 +00:00
const attributes = {
2020-07-08 13:51:46 +00:00
name: 'my second super name for server 1',
description: 'my second super description for server 1'
}
2021-07-16 07:04:35 +00:00
const { id } = await servers[0].videos.upload({ token: userAccessToken, attributes })
2021-07-15 08:02:54 +00:00
const video3Id = id
2020-07-08 13:51:46 +00:00
// resume with the test
const reason3 = 'my super bad reason 3'
2021-07-06 10:01:59 +00:00
await commands[0].report({ videoId: video3Id, reason: reason3 })
2020-07-08 13:51:46 +00:00
const reason4 = 'my super bad reason 4'
2021-07-22 12:28:03 +00:00
await commands[0].report({ token: userAccessToken, videoId: servers[0].store.videoCreated.id, reason: reason4 })
2020-07-08 13:51:46 +00:00
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
const abuses = body.data
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuseVideo3 = body.data.find(a => a.video.id === video3Id)
2020-07-08 13:51:46 +00:00
expect(abuseVideo3).to.not.be.undefined
expect(abuseVideo3.video.countReports).to.equal(1, 'wrong reports count for video 3')
expect(abuseVideo3.video.nthReport).to.equal(1, 'wrong report position in report list for video 3')
expect(abuseVideo3.countReportsForReportee).to.equal(1, 'wrong reports count for reporter on video 3 abuse')
expect(abuseVideo3.countReportsForReporter).to.equal(3, 'wrong reports count for reportee on video 3 abuse')
2020-07-08 13:51:46 +00:00
2021-07-22 12:28:03 +00:00
const abuseServer1 = abuses.find(a => a.video.id === servers[0].store.videoCreated.id)
expect(abuseServer1.countReportsForReportee).to.equal(3, 'wrong reports count for reporter on video 1 abuse')
2020-07-08 13:51:46 +00:00
}
})
it('Should list predefined reasons as well as timestamps for the reported video', async function () {
this.timeout(10000)
const reason5 = 'my super bad reason 5'
const predefinedReasons5: AbusePredefinedReasonsString[] = [ 'violentOrRepulsive', 'captions' ]
2021-07-06 10:01:59 +00:00
const createRes = await commands[0].report({
2021-07-22 12:28:03 +00:00
videoId: servers[0].store.videoCreated.id,
2020-07-08 13:51:46 +00:00
reason: reason5,
predefinedReasons: predefinedReasons5,
startAt: 1,
endAt: 5
2021-07-06 10:01:59 +00:00
})
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
2020-07-08 13:51:46 +00:00
{
2021-07-06 10:01:59 +00:00
const abuse = body.data.find(a => a.id === createRes.abuse.id)
2020-07-08 13:51:46 +00:00
expect(abuse.reason).to.equals(reason5)
expect(abuse.predefinedReasons).to.deep.equals(predefinedReasons5, 'predefined reasons do not match the one reported')
2020-07-08 13:51:46 +00:00
expect(abuse.video.startAt).to.equal(1, "starting timestamp doesn't match the one reported")
expect(abuse.video.endAt).to.equal(5, "ending timestamp doesn't match the one reported")
}
})
it('Should delete the video abuse', async function () {
this.timeout(10000)
2021-07-06 10:01:59 +00:00
await commands[1].delete({ abuseId: abuseServer2.id })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
{
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList()
expect(body.total).to.equal(1)
expect(body.data.length).to.equal(1)
expect(body.data[0].id).to.not.equal(abuseServer2.id)
2020-07-08 13:51:46 +00:00
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList()
expect(body.total).to.equal(6)
2020-07-08 13:51:46 +00:00
}
})
it('Should list and filter video abuses', async function () {
this.timeout(10000)
2021-07-06 10:01:59 +00:00
async function list (query: Parameters<AbusesCommand['getAdminList']>[0]) {
const body = await commands[0].getAdminList(query)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
return body.data
2020-07-07 12:34:16 +00:00
}
2020-07-08 13:51:46 +00:00
expect(await list({ id: 56 })).to.have.lengthOf(0)
expect(await list({ id: 1 })).to.have.lengthOf(1)
expect(await list({ search: 'my super name for server 1' })).to.have.lengthOf(4)
expect(await list({ search: 'aaaaaaaaaaaaaaaaaaaaaaaaaa' })).to.have.lengthOf(0)
expect(await list({ searchVideo: 'my second super name for server 1' })).to.have.lengthOf(1)
expect(await list({ searchVideoChannel: 'root' })).to.have.lengthOf(4)
expect(await list({ searchVideoChannel: 'aaaa' })).to.have.lengthOf(0)
expect(await list({ searchReporter: 'user2' })).to.have.lengthOf(1)
expect(await list({ searchReporter: 'root' })).to.have.lengthOf(5)
expect(await list({ searchReportee: 'root' })).to.have.lengthOf(5)
expect(await list({ searchReportee: 'aaaa' })).to.have.lengthOf(0)
expect(await list({ videoIs: 'deleted' })).to.have.lengthOf(1)
expect(await list({ videoIs: 'blacklisted' })).to.have.lengthOf(0)
expect(await list({ state: AbuseState.ACCEPTED })).to.have.lengthOf(0)
expect(await list({ state: AbuseState.PENDING })).to.have.lengthOf(6)
expect(await list({ predefinedReason: 'violentOrRepulsive' })).to.have.lengthOf(1)
expect(await list({ predefinedReason: 'serverRules' })).to.have.lengthOf(0)
})
2020-07-07 12:34:16 +00:00
})
2020-07-08 13:51:46 +00:00
describe('Comment abuses', function () {
2020-07-07 12:34:16 +00:00
2021-07-16 07:47:51 +00:00
async function getComment (server: PeerTubeServer, videoIdArg: number | string) {
2020-07-08 13:51:46 +00:00
const videoId = typeof videoIdArg === 'string'
2021-07-16 07:04:35 +00:00
? await server.videos.getId({ uuid: videoIdArg })
2020-07-08 13:51:46 +00:00
: videoIdArg
2020-07-07 12:34:16 +00:00
2021-07-16 07:04:35 +00:00
const { data } = await server.comments.listThreads({ videoId })
2020-07-07 12:34:16 +00:00
2021-07-09 12:15:11 +00:00
return data[0]
2020-07-07 12:34:16 +00:00
}
2020-07-08 13:51:46 +00:00
before(async function () {
this.timeout(50000)
2020-07-07 12:34:16 +00:00
2021-07-22 12:28:03 +00:00
servers[0].store.videoCreated = await servers[0].videos.quickUpload({ name: 'server 1' })
servers[1].store.videoCreated = await servers[1].videos.quickUpload({ name: 'server 2' })
2020-07-08 13:51:46 +00:00
2021-07-22 12:28:03 +00:00
await servers[0].comments.createThread({ videoId: servers[0].store.videoCreated.id, text: 'comment server 1' })
await servers[1].comments.createThread({ videoId: servers[1].store.videoCreated.id, text: 'comment server 2' })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should report abuse on a comment', async function () {
this.timeout(15000)
2021-07-22 12:28:03 +00:00
const comment = await getComment(servers[0], servers[0].store.videoCreated.id)
2020-07-08 13:51:46 +00:00
const reason = 'it is a bad comment'
2021-07-06 10:01:59 +00:00
await commands[0].report({ commentId: comment.id, reason })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should have 1 comment abuse on server 1 and 0 on server 2', async function () {
{
2021-07-22 12:28:03 +00:00
const comment = await getComment(servers[0], servers[0].store.videoCreated.id)
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment' })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(body.total).to.equal(1)
expect(body.data).to.have.lengthOf(1)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data[0]
2020-07-08 13:51:46 +00:00
expect(abuse.reason).to.equal('it is a bad comment')
expect(abuse.reporterAccount.name).to.equal('root')
expect(abuse.reporterAccount.host).to.equal(servers[0].host)
expect(abuse.video).to.be.null
expect(abuse.comment.deleted).to.be.false
expect(abuse.comment.id).to.equal(comment.id)
expect(abuse.comment.text).to.equal(comment.text)
expect(abuse.comment.video.name).to.equal('server 1')
2021-07-22 12:28:03 +00:00
expect(abuse.comment.video.id).to.equal(servers[0].store.videoCreated.id)
expect(abuse.comment.video.uuid).to.equal(servers[0].store.videoCreated.uuid)
2020-07-08 13:51:46 +00:00
expect(abuse.countReportsForReporter).to.equal(5)
expect(abuse.countReportsForReportee).to.equal(5)
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(0)
expect(body.data.length).to.equal(0)
2020-07-08 13:51:46 +00:00
}
})
it('Should report abuse on a remote comment', async function () {
this.timeout(10000)
2021-07-22 12:28:03 +00:00
const comment = await getComment(servers[0], servers[1].store.videoCreated.uuid)
2020-07-08 13:51:46 +00:00
const reason = 'it is a really bad comment'
2021-07-06 10:01:59 +00:00
await commands[0].report({ commentId: comment.id, reason })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should have 2 comment abuses on server 1 and 1 on server 2', async function () {
2022-01-07 07:45:05 +00:00
const commentServer2 = await getComment(servers[0], servers[1].store.videoCreated.shortUUID)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[0].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(2)
expect(body.data.length).to.equal(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data[0]
expect(abuse.reason).to.equal('it is a bad comment')
expect(abuse.countReportsForReporter).to.equal(6)
expect(abuse.countReportsForReportee).to.equal(5)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse2 = body.data[1]
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.reason).to.equal('it is a really bad comment')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.reporterAccount.name).to.equal('root')
expect(abuse2.reporterAccount.host).to.equal(servers[0].host)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.video).to.be.null
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.comment.deleted).to.be.false
expect(abuse2.comment.id).to.equal(commentServer2.id)
expect(abuse2.comment.text).to.equal(commentServer2.text)
expect(abuse2.comment.video.name).to.equal('server 2')
2021-07-22 12:28:03 +00:00
expect(abuse2.comment.video.uuid).to.equal(servers[1].store.videoCreated.uuid)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.state.id).to.equal(AbuseState.PENDING)
expect(abuse2.state.label).to.equal('Pending')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.moderationComment).to.be.null
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.countReportsForReporter).to.equal(6)
expect(abuse2.countReportsForReportee).to.equal(2)
}
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[1].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(1)
expect(body.data.length).to.equal(1)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
abuseServer2 = body.data[0]
expect(abuseServer2.reason).to.equal('it is a really bad comment')
expect(abuseServer2.reporterAccount.name).to.equal('root')
expect(abuseServer2.reporterAccount.host).to.equal(servers[0].host)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.state.id).to.equal(AbuseState.PENDING)
expect(abuseServer2.state.label).to.equal('Pending')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.moderationComment).to.be.null
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.countReportsForReporter).to.equal(1)
expect(abuseServer2.countReportsForReportee).to.equal(1)
}
2020-07-08 13:51:46 +00:00
})
it('Should keep the comment abuse when deleting the comment', async function () {
this.timeout(10000)
2022-06-07 09:40:47 +00:00
const commentServer2 = await getComment(servers[0], servers[1].store.videoCreated.uuid)
2020-07-08 13:51:46 +00:00
2021-07-22 12:28:03 +00:00
await servers[0].comments.delete({ videoId: servers[1].store.videoCreated.uuid, commentId: commentServer2.id })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(2)
expect(body.data).to.have.lengthOf(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data.find(a => a.comment?.id === commentServer2.id)
2020-07-08 13:51:46 +00:00
expect(abuse).to.not.be.undefined
expect(abuse.comment.text).to.be.empty
expect(abuse.comment.video.name).to.equal('server 2')
expect(abuse.comment.deleted).to.be.true
})
it('Should delete the comment abuse', async function () {
this.timeout(10000)
2021-07-06 10:01:59 +00:00
await commands[1].delete({ abuseId: abuseServer2.id })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
{
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(0)
expect(body.data.length).to.equal(0)
2020-07-08 13:51:46 +00:00
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(2)
2020-07-08 13:51:46 +00:00
}
})
it('Should list and filter video abuses', async function () {
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment', searchReportee: 'foo' })
expect(body.total).to.equal(0)
2020-07-08 13:51:46 +00:00
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment', searchReportee: 'ot' })
expect(body.total).to.equal(2)
2020-07-08 13:51:46 +00:00
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'comment', start: 1, count: 1, sort: 'createdAt' })
expect(body.data).to.have.lengthOf(1)
expect(body.data[0].comment.text).to.be.empty
}
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[0].getAdminList({ filter: 'comment', start: 1, count: 1, sort: '-createdAt' })
expect(body.data).to.have.lengthOf(1)
expect(body.data[0].comment.text).to.equal('comment server 1')
2020-07-07 12:34:16 +00:00
}
2020-07-08 13:51:46 +00:00
})
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
describe('Account abuses', function () {
2020-07-07 12:34:16 +00:00
2021-07-16 07:47:51 +00:00
function getAccountFromServer (server: PeerTubeServer, targetName: string, targetServer: PeerTubeServer) {
2021-07-16 07:04:35 +00:00
return server.accounts.get({ accountName: targetName + '@' + targetServer.host })
2020-07-07 12:34:16 +00:00
}
2020-07-08 13:51:46 +00:00
before(async function () {
this.timeout(50000)
2021-07-16 07:04:35 +00:00
await servers[0].users.create({ username: 'user_1', password: 'donald' })
2020-07-08 13:51:46 +00:00
2021-07-16 07:04:35 +00:00
const token = await servers[1].users.generateUserAndToken('user_2')
await servers[1].videos.upload({ token, attributes: { name: 'super video' } })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should report abuse on an account', async function () {
this.timeout(15000)
2021-07-07 11:38:26 +00:00
const account = await getAccountFromServer(servers[0], 'user_1', servers[0])
2020-07-08 13:51:46 +00:00
const reason = 'it is a bad account'
2021-07-06 10:01:59 +00:00
await commands[0].report({ accountId: account.id, reason })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should have 1 account abuse on server 1 and 0 on server 2', async function () {
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'account' })
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(body.total).to.equal(1)
expect(body.data).to.have.lengthOf(1)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data[0]
2020-07-08 13:51:46 +00:00
expect(abuse.reason).to.equal('it is a bad account')
expect(abuse.reporterAccount.name).to.equal('root')
expect(abuse.reporterAccount.host).to.equal(servers[0].host)
expect(abuse.video).to.be.null
expect(abuse.comment).to.be.null
expect(abuse.flaggedAccount.name).to.equal('user_1')
expect(abuse.flaggedAccount.host).to.equal(servers[0].host)
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList({ filter: 'comment' })
expect(body.total).to.equal(0)
expect(body.data.length).to.equal(0)
2020-07-08 13:51:46 +00:00
}
})
it('Should report abuse on a remote account', async function () {
this.timeout(10000)
2021-07-07 11:38:26 +00:00
const account = await getAccountFromServer(servers[0], 'user_2', servers[1])
2020-07-08 13:51:46 +00:00
const reason = 'it is a really bad account'
2021-07-06 10:01:59 +00:00
await commands[0].report({ accountId: account.id, reason })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
})
it('Should have 2 comment abuses on server 1 and 1 on server 2', async function () {
2021-07-06 10:01:59 +00:00
{
const body = await commands[0].getAdminList({ filter: 'account' })
expect(body.total).to.equal(2)
expect(body.data.length).to.equal(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse: AdminAbuse = body.data[0]
expect(abuse.reason).to.equal('it is a bad account')
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const abuse2: AdminAbuse = body.data[1]
expect(abuse2.reason).to.equal('it is a really bad account')
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.reporterAccount.name).to.equal('root')
expect(abuse2.reporterAccount.host).to.equal(servers[0].host)
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.video).to.be.null
expect(abuse2.comment).to.be.null
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.state.id).to.equal(AbuseState.PENDING)
expect(abuse2.state.label).to.equal('Pending')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuse2.moderationComment).to.be.null
}
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
{
const body = await commands[1].getAdminList({ filter: 'account' })
expect(body.total).to.equal(1)
expect(body.data.length).to.equal(1)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
abuseServer2 = body.data[0]
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.reason).to.equal('it is a really bad account')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.reporterAccount.name).to.equal('root')
expect(abuseServer2.reporterAccount.host).to.equal(servers[0].host)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.state.id).to.equal(AbuseState.PENDING)
expect(abuseServer2.state.label).to.equal('Pending')
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
expect(abuseServer2.moderationComment).to.be.null
}
2020-07-08 13:51:46 +00:00
})
it('Should keep the account abuse when deleting the account', async function () {
this.timeout(10000)
2021-07-07 11:38:26 +00:00
const account = await getAccountFromServer(servers[1], 'user_2', servers[1])
2021-07-16 07:04:35 +00:00
await servers[1].users.remove({ userId: account.userId })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'account' })
expect(body.total).to.equal(2)
expect(body.data).to.have.lengthOf(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
const abuse = body.data.find(a => a.reason === 'it is a really bad account')
2020-07-08 13:51:46 +00:00
expect(abuse).to.not.be.undefined
})
it('Should delete the account abuse', async function () {
this.timeout(10000)
2021-07-06 10:01:59 +00:00
await commands[1].delete({ abuseId: abuseServer2.id })
2020-07-08 13:51:46 +00:00
await waitJobs(servers)
{
2021-07-06 10:01:59 +00:00
const body = await commands[1].getAdminList({ filter: 'account' })
expect(body.total).to.equal(0)
expect(body.data.length).to.equal(0)
2020-07-08 13:51:46 +00:00
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ filter: 'account' })
expect(body.total).to.equal(2)
2020-07-08 13:51:46 +00:00
2021-07-06 10:01:59 +00:00
abuseServer1 = body.data[0]
2020-07-08 13:51:46 +00:00
}
})
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
describe('Common actions on abuses', function () {
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should update the state of an abuse', async function () {
2021-07-06 10:01:59 +00:00
await commands[0].update({ abuseId: abuseServer1.id, body: { state: AbuseState.REJECTED } })
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ id: abuseServer1.id })
expect(body.data[0].state.id).to.equal(AbuseState.REJECTED)
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
2020-07-08 13:51:46 +00:00
it('Should add a moderation comment', async function () {
2021-07-06 10:01:59 +00:00
await commands[0].update({ abuseId: abuseServer1.id, body: { state: AbuseState.ACCEPTED, moderationComment: 'Valid' } })
2020-07-07 12:34:16 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getAdminList({ id: abuseServer1.id })
expect(body.data[0].state.id).to.equal(AbuseState.ACCEPTED)
expect(body.data[0].moderationComment).to.equal('Valid')
2020-07-08 13:51:46 +00:00
})
2020-07-07 12:34:16 +00:00
})
2020-07-24 13:05:51 +00:00
describe('My abuses', async function () {
let abuseId1: number
let userAccessToken: string
before(async function () {
2021-07-16 07:04:35 +00:00
userAccessToken = await servers[0].users.generateUserAndToken('user_42')
2020-07-24 13:05:51 +00:00
2021-07-22 12:28:03 +00:00
await commands[0].report({ token: userAccessToken, videoId: servers[0].store.videoCreated.id, reason: 'user reason 1' })
2020-07-24 13:05:51 +00:00
2021-07-22 12:28:03 +00:00
const videoId = await servers[0].videos.getId({ uuid: servers[1].store.videoCreated.uuid })
2021-07-06 10:01:59 +00:00
await commands[0].report({ token: userAccessToken, videoId, reason: 'user reason 2' })
2020-07-24 13:05:51 +00:00
})
it('Should correctly list my abuses', async function () {
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, start: 0, count: 5, sort: 'createdAt' })
expect(body.total).to.equal(2)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 1')
expect(abuses[1].reason).to.equal('user reason 2')
abuseId1 = abuses[0].id
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, start: 1, count: 1, sort: 'createdAt' })
expect(body.total).to.equal(2)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses: UserAbuse[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 2')
}
{
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, start: 1, count: 1, sort: '-createdAt' })
expect(body.total).to.equal(2)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses: UserAbuse[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 1')
}
})
it('Should correctly filter my abuses by id', async function () {
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, id: abuseId1 })
expect(body.total).to.equal(1)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses: UserAbuse[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 1')
})
it('Should correctly filter my abuses by search', async function () {
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, search: 'server 2' })
expect(body.total).to.equal(1)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses: UserAbuse[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 2')
})
it('Should correctly filter my abuses by state', async function () {
2021-07-06 10:01:59 +00:00
await commands[0].update({ abuseId: abuseId1, body: { state: AbuseState.REJECTED } })
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const body = await commands[0].getUserList({ token: userAccessToken, state: AbuseState.REJECTED })
expect(body.total).to.equal(1)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuses: UserAbuse[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuses[0].reason).to.equal('user reason 1')
})
})
describe('Abuse messages', async function () {
let abuseId: number
2021-07-06 10:01:59 +00:00
let userToken: string
2020-07-24 13:05:51 +00:00
let abuseMessageUserId: number
let abuseMessageModerationId: number
before(async function () {
2021-07-16 07:04:35 +00:00
userToken = await servers[0].users.generateUserAndToken('user_43')
2020-07-24 13:05:51 +00:00
2021-07-22 12:28:03 +00:00
const body = await commands[0].report({ token: userToken, videoId: servers[0].store.videoCreated.id, reason: 'user 43 reason 1' })
2021-07-06 10:01:59 +00:00
abuseId = body.abuse.id
2020-07-24 13:05:51 +00:00
})
it('Should create some messages on the abuse', async function () {
2021-07-06 10:01:59 +00:00
await commands[0].addMessage({ token: userToken, abuseId, message: 'message 1' })
await commands[0].addMessage({ abuseId, message: 'message 2' })
await commands[0].addMessage({ abuseId, message: 'message 3' })
await commands[0].addMessage({ token: userToken, abuseId, message: 'message 4' })
2020-07-24 13:05:51 +00:00
})
it('Should have the correct messages count when listing abuses', async function () {
const results = await Promise.all([
2021-07-06 10:01:59 +00:00
commands[0].getAdminList({ start: 0, count: 50 }),
commands[0].getUserList({ token: userToken, start: 0, count: 50 })
2020-07-24 13:05:51 +00:00
])
2021-07-06 10:01:59 +00:00
for (const body of results) {
const abuses = body.data
2020-07-24 13:05:51 +00:00
const abuse = abuses.find(a => a.id === abuseId)
expect(abuse.countMessages).to.equal(4)
}
})
it('Should correctly list messages of this abuse', async function () {
const results = await Promise.all([
2021-07-06 10:01:59 +00:00
commands[0].listMessages({ abuseId }),
commands[0].listMessages({ token: userToken, abuseId })
2020-07-24 13:05:51 +00:00
])
2021-07-06 10:01:59 +00:00
for (const body of results) {
expect(body.total).to.equal(4)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuseMessages: AbuseMessage[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuseMessages[0].message).to.equal('message 1')
expect(abuseMessages[0].byModerator).to.be.false
expect(abuseMessages[0].account.name).to.equal('user_43')
abuseMessageUserId = abuseMessages[0].id
expect(abuseMessages[1].message).to.equal('message 2')
expect(abuseMessages[1].byModerator).to.be.true
expect(abuseMessages[1].account.name).to.equal('root')
expect(abuseMessages[2].message).to.equal('message 3')
expect(abuseMessages[2].byModerator).to.be.true
expect(abuseMessages[2].account.name).to.equal('root')
abuseMessageModerationId = abuseMessages[2].id
expect(abuseMessages[3].message).to.equal('message 4')
expect(abuseMessages[3].byModerator).to.be.false
expect(abuseMessages[3].account.name).to.equal('user_43')
}
})
it('Should delete messages', async function () {
2021-07-06 10:01:59 +00:00
await commands[0].deleteMessage({ abuseId, messageId: abuseMessageModerationId })
await commands[0].deleteMessage({ token: userToken, abuseId, messageId: abuseMessageUserId })
2020-07-24 13:05:51 +00:00
const results = await Promise.all([
2021-07-06 10:01:59 +00:00
commands[0].listMessages({ abuseId }),
commands[0].listMessages({ token: userToken, abuseId })
2020-07-24 13:05:51 +00:00
])
2021-07-06 10:01:59 +00:00
for (const body of results) {
expect(body.total).to.equal(2)
2020-07-24 13:05:51 +00:00
2021-07-06 10:01:59 +00:00
const abuseMessages: AbuseMessage[] = body.data
2020-07-24 13:05:51 +00:00
expect(abuseMessages[0].message).to.equal('message 2')
expect(abuseMessages[1].message).to.equal('message 4')
}
})
})
2020-07-07 12:34:16 +00:00
after(async function () {
await cleanupTests(servers)
})
})