import { AccountModel } from './account'
import { getSort } from '../utils'
import { AccountBlock } from '../../../shared/models/blocklist'
+import { Op } from 'sequelize'
enum ScopeNames {
WITH_ACCOUNTS = 'WITH_ACCOUNTS'
{
model: () => AccountModel,
required: true,
- as: 'AccountBlocked'
+ as: 'BlockedAccount'
}
]
}
name: 'targetAccountId',
allowNull: false
},
- as: 'AccountBlocked',
+ as: 'BlockedAccount',
onDelete: 'CASCADE'
})
- AccountBlocked: AccountModel
+ BlockedAccount: AccountModel
+
+ static isAccountMutedBy (accountId: number, targetAccountId: number) {
+ return AccountBlocklistModel.isAccountMutedByMulti([ accountId ], targetAccountId)
+ .then(result => result[accountId])
+ }
+
+ static isAccountMutedByMulti (accountIds: number[], targetAccountId: number) {
+ const query = {
+ attributes: [ 'accountId', 'id' ],
+ where: {
+ accountId: {
+ [Op.any]: accountIds
+ },
+ targetAccountId
+ },
+ raw: true
+ }
+
+ return AccountBlocklistModel.unscoped()
+ .findAll(query)
+ .then(rows => {
+ const result: { [accountId: number]: boolean } = {}
+
+ for (const accountId of accountIds) {
+ result[accountId] = !!rows.find(r => r.accountId === accountId)
+ }
+
+ return result
+ })
+ }
static loadByAccountAndTarget (accountId: number, targetAccountId: number) {
const query = {
toFormattedJSON (): AccountBlock {
return {
byAccount: this.ByAccount.toFormattedJSON(),
- accountBlocked: this.AccountBlocked.toFormattedJSON(),
+ blockedAccount: this.BlockedAccount.toFormattedJSON(),
createdAt: this.createdAt
}
}