User blocking (Following part) (#3035)
* block wip * UndoBlock * UnBlock * wip * follow * UI * fix
This commit is contained in:
parent
bcb0588409
commit
d64dc45899
17 changed files with 537 additions and 4 deletions
28
src/services/blocking/delete.ts
Normal file
28
src/services/blocking/delete.ts
Normal file
|
|
@ -0,0 +1,28 @@
|
|||
import { isLocalUser, isRemoteUser, IUser } from '../../models/user';
|
||||
import Blocking from '../../models/blocking';
|
||||
import pack from '../../remote/activitypub/renderer';
|
||||
import renderBlock from '../../remote/activitypub/renderer/block';
|
||||
import renderUndo from '../../remote/activitypub/renderer/undo';
|
||||
import { deliver } from '../../queue';
|
||||
|
||||
export default async function(blocker: IUser, blockee: IUser) {
|
||||
const blocking = await Blocking.findOne({
|
||||
blockerId: blocker._id,
|
||||
blockeeId: blockee._id
|
||||
});
|
||||
|
||||
if (blocking == null) {
|
||||
console.warn('ブロック解除がリクエストされましたがブロックしていませんでした');
|
||||
return;
|
||||
}
|
||||
|
||||
Blocking.remove({
|
||||
_id: blocking._id
|
||||
});
|
||||
|
||||
// deliver if remote bloking
|
||||
if (isLocalUser(blocker) && isRemoteUser(blockee)) {
|
||||
const content = pack(renderUndo(renderBlock(blocker, blockee), blocker));
|
||||
deliver(blocker, content, blockee.inbox);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue