2023-07-31 14:34:36 +02:00
|
|
|
import { sequelizeTypescript } from '@server/initializers/database.js'
|
|
|
|
import { getServerActor } from '@server/models/application/application.js'
|
|
|
|
import { MAccountBlocklist, MAccountId, MAccountHost, MServerBlocklist } from '@server/types/models/index.js'
|
|
|
|
import { AccountBlocklistModel } from '../models/account/account-blocklist.js'
|
|
|
|
import { ServerBlocklistModel } from '../models/server/server-blocklist.js'
|
2024-02-12 10:47:52 +01:00
|
|
|
import { UserNotificationModel } from '@server/models/user/user-notification.js'
|
|
|
|
import { logger } from '@server/helpers/logger.js'
|
2018-10-12 15:26:04 +02:00
|
|
|
|
2024-02-12 10:47:52 +01:00
|
|
|
async function addAccountInBlocklist (options: {
|
|
|
|
byAccountId: number
|
|
|
|
targetAccountId: number
|
|
|
|
|
|
|
|
removeNotificationOfUserId: number | null // If blocked by a user
|
|
|
|
}) {
|
|
|
|
const { byAccountId, targetAccountId, removeNotificationOfUserId } = options
|
|
|
|
|
|
|
|
await sequelizeTypescript.transaction(async t => {
|
2018-10-12 17:26:40 +02:00
|
|
|
return AccountBlocklistModel.upsert({
|
2018-10-12 15:26:04 +02:00
|
|
|
accountId: byAccountId,
|
2022-07-13 11:58:01 +02:00
|
|
|
targetAccountId
|
2018-10-12 15:26:04 +02:00
|
|
|
}, { transaction: t })
|
|
|
|
})
|
2024-02-12 10:47:52 +01:00
|
|
|
|
|
|
|
UserNotificationModel.removeNotificationsOf({
|
|
|
|
id: targetAccountId,
|
|
|
|
type: 'account',
|
|
|
|
forUserId: removeNotificationOfUserId
|
|
|
|
}).catch(err => logger.error('Cannot remove notifications after an account mute.', { err }))
|
2018-10-12 15:26:04 +02:00
|
|
|
}
|
|
|
|
|
2024-02-12 10:47:52 +01:00
|
|
|
async function addServerInBlocklist (options: {
|
|
|
|
byAccountId: number
|
|
|
|
targetServerId: number
|
|
|
|
|
|
|
|
removeNotificationOfUserId: number | null
|
|
|
|
}) {
|
|
|
|
const { byAccountId, targetServerId, removeNotificationOfUserId } = options
|
|
|
|
|
|
|
|
await sequelizeTypescript.transaction(async t => {
|
2018-10-12 17:26:40 +02:00
|
|
|
return ServerBlocklistModel.upsert({
|
2018-10-12 15:26:04 +02:00
|
|
|
accountId: byAccountId,
|
|
|
|
targetServerId
|
|
|
|
}, { transaction: t })
|
|
|
|
})
|
2024-02-12 10:47:52 +01:00
|
|
|
|
|
|
|
UserNotificationModel.removeNotificationsOf({
|
|
|
|
id: targetServerId,
|
|
|
|
type: 'server',
|
|
|
|
forUserId: removeNotificationOfUserId
|
|
|
|
}).catch(err => logger.error('Cannot remove notifications after a server mute.', { err }))
|
2018-10-12 15:26:04 +02:00
|
|
|
}
|
|
|
|
|
2019-08-15 11:53:26 +02:00
|
|
|
function removeAccountFromBlocklist (accountBlock: MAccountBlocklist) {
|
2018-10-12 15:26:04 +02:00
|
|
|
return sequelizeTypescript.transaction(async t => {
|
|
|
|
return accountBlock.destroy({ transaction: t })
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-08-15 11:53:26 +02:00
|
|
|
function removeServerFromBlocklist (serverBlock: MServerBlocklist) {
|
2018-10-12 15:26:04 +02:00
|
|
|
return sequelizeTypescript.transaction(async t => {
|
|
|
|
return serverBlock.destroy({ transaction: t })
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
Add Podcast RSS feeds (#5487)
* Initial test implementation of Podcast RSS
This is a pretty simple implementation to add support for The Podcast Namespace in RSS -- instead of affecting the existing RSS implementation, this adds a new UI option.
I attempted to retain compatibility with the rest of the RSS feed implementation as much as possible and have created a temporary fork of the "pfeed" library to support this effort.
* Update to pfeed-podcast 1.2.2
* Initial test implementation of Podcast RSS
This is a pretty simple implementation to add support for The Podcast Namespace in RSS -- instead of affecting the existing RSS implementation, this adds a new UI option.
I attempted to retain compatibility with the rest of the RSS feed implementation as much as possible and have created a temporary fork of the "pfeed" library to support this effort.
* Update to pfeed-podcast 1.2.2
* Initial test implementation of Podcast RSS
This is a pretty simple implementation to add support for The Podcast Namespace in RSS -- instead of affecting the existing RSS implementation, this adds a new UI option.
I attempted to retain compatibility with the rest of the RSS feed implementation as much as possible and have created a temporary fork of the "pfeed" library to support this effort.
* Update to pfeed-podcast 1.2.2
* Add correct feed image to RSS channel
* Prefer HLS videos for podcast RSS
Remove video/stream titles, add optional height attribute to podcast RSS
* Prefix podcast RSS images with root server URL
* Add optional video query support to include captions
* Add transcripts & person images to podcast RSS feed
* Prefer webseed/webtorrent files over HLS fragmented mp4s
* Experimentally adding podcast fields to basic config page
* Add validation for new basic config fields
* Don't include "content" in podcast feed, use full description for "description"
* Initial test implementation of Podcast RSS
This is a pretty simple implementation to add support for The Podcast Namespace in RSS -- instead of affecting the existing RSS implementation, this adds a new UI option.
I attempted to retain compatibility with the rest of the RSS feed implementation as much as possible and have created a temporary fork of the "pfeed" library to support this effort.
* Update to pfeed-podcast 1.2.2
* Add correct feed image to RSS channel
* Prefer HLS videos for podcast RSS
Remove video/stream titles, add optional height attribute to podcast RSS
* Prefix podcast RSS images with root server URL
* Add optional video query support to include captions
* Add transcripts & person images to podcast RSS feed
* Prefer webseed/webtorrent files over HLS fragmented mp4s
* Experimentally adding podcast fields to basic config page
* Add validation for new basic config fields
* Don't include "content" in podcast feed, use full description for "description"
* Add medium/socialInteract to podcast RSS feeds. Use HTML for description
* Change base production image to bullseye, install prosody in image
* Add liveItem and trackers to Podcast RSS feeds
Remove height from alternateEnclosure, replaced with title.
* Clear Podcast RSS feed cache when live streams start/end
* Upgrade to Node 16
* Refactor clearCacheRoute to use ApiCache
* Remove unnecessary type hint
* Update dockerfile to node 16, install python-is-python2
* Use new file paths for captions/playlists
* Fix legacy videos in RSS after migration to object storage
* Improve method of identifying non-fragmented mp4s in podcast RSS feeds
* Don't include fragmented MP4s in podcast RSS feeds
* Add experimental support for podcast:categories on the podcast RSS item
* Fix undefined category when no videos exist
Allows for empty feeds to exist (important for feeds that might only go live)
* Add support for podcast:locked -- user has to opt in to show their email
* Use comma for podcast:categories delimiter
* Make cache clearing async
* Fix merge, temporarily test with pfeed-podcast
* Syntax changes
* Add EXT_MIMETYPE constants for captions
* Update & fix tests, fix enclosure mimetypes, remove admin email
* Add test for podacst:socialInteract
* Add filters hooks for podcast customTags
* Remove showdown, updated to pfeed-podcast 6.1.2
* Add 'action:api.live-video.state.updated' hook
* Avoid assigning undefined category to podcast feeds
* Remove nvmrc
* Remove comment
* Remove unused podcast config
* Remove more unused podcast config
* Fix MChannelAccountDefault type hint missed in merge
* Remove extra line
* Re-add newline in config
* Fix lint errors for isEmailPublic
* Fix thumbnails in podcast feeds
* Requested changes based on review
* Provide podcast rss 2.0 only on video channels
* Misc cleanup for a less messy PR
* Lint fixes
* Remove pfeed-podcast
* Add peertube version to new hooks
* Don't use query include, remove TODO
* Remove film medium hack
* Clear podcast rss cache before video/channel update hooks
* Clear podcast rss cache before video uploaded/deleted hooks
* Refactor podcast feed cache clearing
* Set correct person name from video channel
* Styling
* Fix tests
---------
Co-authored-by: Chocobozzz <me@florianbigard.com>
2023-05-22 16:00:05 +02:00
|
|
|
async function isBlockedByServerOrAccount (targetAccount: MAccountHost, userAccount?: MAccountId) {
|
2020-05-22 17:06:26 +02:00
|
|
|
const serverAccountId = (await getServerActor()).Account.id
|
|
|
|
const sourceAccounts = [ serverAccountId ]
|
|
|
|
|
|
|
|
if (userAccount) sourceAccounts.push(userAccount.id)
|
|
|
|
|
2021-12-06 16:53:00 +01:00
|
|
|
const accountMutedHash = await AccountBlocklistModel.isAccountMutedByAccounts(sourceAccounts, targetAccount.id)
|
2020-05-22 17:06:26 +02:00
|
|
|
if (accountMutedHash[serverAccountId] || (userAccount && accountMutedHash[userAccount.id])) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2021-12-06 16:53:00 +01:00
|
|
|
const instanceMutedHash = await ServerBlocklistModel.isServerMutedByAccounts(sourceAccounts, targetAccount.Actor.serverId)
|
2020-05-22 17:06:26 +02:00
|
|
|
if (instanceMutedHash[serverAccountId] || (userAccount && instanceMutedHash[userAccount.id])) {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2018-10-12 15:26:04 +02:00
|
|
|
export {
|
|
|
|
addAccountInBlocklist,
|
|
|
|
addServerInBlocklist,
|
|
|
|
removeAccountFromBlocklist,
|
2020-05-22 17:06:26 +02:00
|
|
|
removeServerFromBlocklist,
|
|
|
|
isBlockedByServerOrAccount
|
2018-10-12 15:26:04 +02:00
|
|
|
}
|