Merge branch 'admin-delete' into 'main'
Let admins delete events See merge request soapbox-pub/ditto!99
This commit is contained in:
commit
8b3aee7e48
|
@ -44,7 +44,12 @@ import { instanceController } from './controllers/api/instance.ts';
|
||||||
import { mediaController } from './controllers/api/media.ts';
|
import { mediaController } from './controllers/api/media.ts';
|
||||||
import { notificationsController } from './controllers/api/notifications.ts';
|
import { notificationsController } from './controllers/api/notifications.ts';
|
||||||
import { createTokenController, oauthAuthorizeController, oauthController } from './controllers/api/oauth.ts';
|
import { createTokenController, oauthAuthorizeController, oauthController } from './controllers/api/oauth.ts';
|
||||||
import { configController, frontendConfigController, updateConfigController } from './controllers/api/pleroma.ts';
|
import {
|
||||||
|
configController,
|
||||||
|
frontendConfigController,
|
||||||
|
pleromaAdminDeleteStatusController,
|
||||||
|
updateConfigController,
|
||||||
|
} from './controllers/api/pleroma.ts';
|
||||||
import { preferencesController } from './controllers/api/preferences.ts';
|
import { preferencesController } from './controllers/api/preferences.ts';
|
||||||
import { relayController } from './controllers/nostr/relay.ts';
|
import { relayController } from './controllers/nostr/relay.ts';
|
||||||
import { searchController } from './controllers/api/search.ts';
|
import { searchController } from './controllers/api/search.ts';
|
||||||
|
@ -189,6 +194,7 @@ app.get('/api/v1/blocks', requirePubkey, blocksController);
|
||||||
app.get('/api/v1/admin/accounts', adminAccountsController);
|
app.get('/api/v1/admin/accounts', adminAccountsController);
|
||||||
app.get('/api/v1/pleroma/admin/config', requireRole('admin'), configController);
|
app.get('/api/v1/pleroma/admin/config', requireRole('admin'), configController);
|
||||||
app.post('/api/v1/pleroma/admin/config', requireRole('admin'), updateConfigController);
|
app.post('/api/v1/pleroma/admin/config', requireRole('admin'), updateConfigController);
|
||||||
|
app.delete('/api/v1/pleroma/admin/statuses/:id', requireRole('admin'), pleromaAdminDeleteStatusController);
|
||||||
|
|
||||||
// Not (yet) implemented.
|
// Not (yet) implemented.
|
||||||
app.get('/api/v1/custom_emojis', emptyArrayController);
|
app.get('/api/v1/custom_emojis', emptyArrayController);
|
||||||
|
|
|
@ -85,4 +85,13 @@ const updateConfigController: AppController = async (c) => {
|
||||||
return c.json({ configs: newConfigs, need_reboot: false });
|
return c.json({ configs: newConfigs, need_reboot: false });
|
||||||
};
|
};
|
||||||
|
|
||||||
export { configController, frontendConfigController, updateConfigController };
|
const pleromaAdminDeleteStatusController: AppController = async (c) => {
|
||||||
|
await createAdminEvent({
|
||||||
|
kind: 5,
|
||||||
|
tags: [['e', c.req.param('id')]],
|
||||||
|
}, c);
|
||||||
|
|
||||||
|
return c.json({});
|
||||||
|
};
|
||||||
|
|
||||||
|
export { configController, frontendConfigController, pleromaAdminDeleteStatusController, updateConfigController };
|
||||||
|
|
|
@ -66,12 +66,11 @@ async function storeEvent(event: Event, data: EventData, opts: StoreEventOpts =
|
||||||
const { force = false } = opts;
|
const { force = false } = opts;
|
||||||
|
|
||||||
if (force || data.user || isAdminEvent(event) || await isLocallyFollowed(event.pubkey)) {
|
if (force || data.user || isAdminEvent(event) || await isLocallyFollowed(event.pubkey)) {
|
||||||
const [deletion] = await eventsDB.filter(
|
const isDeleted = await eventsDB.count(
|
||||||
[{ kinds: [5], authors: [event.pubkey], '#e': [event.id], limit: 1 }],
|
[{ kinds: [5], authors: [Conf.pubkey, event.pubkey], '#e': [event.id], limit: 1 }],
|
||||||
{ limit: 1 },
|
) > 0;
|
||||||
);
|
|
||||||
|
|
||||||
if (deletion) {
|
if (isDeleted) {
|
||||||
return Promise.reject(new RelayError('blocked', 'event was deleted'));
|
return Promise.reject(new RelayError('blocked', 'event was deleted'));
|
||||||
} else {
|
} else {
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
|
@ -88,13 +87,18 @@ async function storeEvent(event: Event, data: EventData, opts: StoreEventOpts =
|
||||||
async function processDeletions(event: Event): Promise<void> {
|
async function processDeletions(event: Event): Promise<void> {
|
||||||
if (event.kind === 5) {
|
if (event.kind === 5) {
|
||||||
const ids = getTagSet(event.tags, 'e');
|
const ids = getTagSet(event.tags, 'e');
|
||||||
const events = await eventsDB.filter([{ ids: [...ids] }]);
|
|
||||||
|
|
||||||
const deleteIds = events
|
if (event.pubkey === Conf.pubkey) {
|
||||||
.filter(({ pubkey, id }) => pubkey === event.pubkey && ids.has(id))
|
await eventsDB.deleteFilters([{ ids: [...ids] }]);
|
||||||
.map((event) => event.id);
|
} else {
|
||||||
|
const events = await eventsDB.filter([{
|
||||||
|
ids: [...ids],
|
||||||
|
authors: [event.pubkey],
|
||||||
|
}]);
|
||||||
|
|
||||||
await eventsDB.deleteFilters([{ ids: deleteIds }]);
|
const deleteIds = events.map(({ id }) => id);
|
||||||
|
await eventsDB.deleteFilters([{ ids: deleteIds }]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue