backend: added /note/history endpoint
This commit is contained in:
parent
02e6aebd33
commit
d64d133d7f
5 changed files with 106 additions and 3 deletions
|
@ -65,14 +65,14 @@ import { UserPending } from "./entities/user-pending.js";
|
||||||
import { InstanceRepository } from "./repositories/instance.js";
|
import { InstanceRepository } from "./repositories/instance.js";
|
||||||
import { Webhook } from "./entities/webhook.js";
|
import { Webhook } from "./entities/webhook.js";
|
||||||
import { UserIp } from "./entities/user-ip.js";
|
import { UserIp } from "./entities/user-ip.js";
|
||||||
import { NoteEdit } from "./entities/note-edit.js";
|
|
||||||
import { NoteFileRepository } from "./repositories/note-file.js";
|
import { NoteFileRepository } from "./repositories/note-file.js";
|
||||||
|
import { NoteEditRepository } from "./repositories/note-edit.js";
|
||||||
|
|
||||||
export const Announcements = db.getRepository(Announcement);
|
export const Announcements = db.getRepository(Announcement);
|
||||||
export const AnnouncementReads = db.getRepository(AnnouncementRead);
|
export const AnnouncementReads = db.getRepository(AnnouncementRead);
|
||||||
export const Apps = AppRepository;
|
export const Apps = AppRepository;
|
||||||
export const Notes = NoteRepository;
|
export const Notes = NoteRepository;
|
||||||
export const NoteEdits = db.getRepository(NoteEdit);
|
export const NoteEdits = NoteEditRepository;
|
||||||
export const NoteFiles = NoteFileRepository;
|
export const NoteFiles = NoteFileRepository;
|
||||||
export const NoteFavorites = NoteFavoriteRepository;
|
export const NoteFavorites = NoteFavoriteRepository;
|
||||||
export const NoteWatchings = db.getRepository(NoteWatching);
|
export const NoteWatchings = db.getRepository(NoteWatching);
|
||||||
|
|
37
packages/backend/src/models/repositories/note-edit.ts
Normal file
37
packages/backend/src/models/repositories/note-edit.ts
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
import { db } from "@/db/postgre.js";
|
||||||
|
import { NoteEdit } from "@/models/entities/note-edit.js";
|
||||||
|
import { awaitAll } from "@/prelude/await-all.js";
|
||||||
|
import type { Packed } from "@/misc/schema.js";
|
||||||
|
|
||||||
|
export const NoteEditRepository = db.getRepository(NoteEdit).extend({
|
||||||
|
async pack(
|
||||||
|
noteEdit: NoteEdit,
|
||||||
|
) {
|
||||||
|
const packed: Packed<"NoteEdit"> = await awaitAll({
|
||||||
|
id: noteEdit.id,
|
||||||
|
noteId: noteEdit.noteId,
|
||||||
|
updatedAt: noteEdit.updatedAt.toISOString(),
|
||||||
|
text: noteEdit.text,
|
||||||
|
cw: noteEdit.cw,
|
||||||
|
fileIds: noteEdit.fileIds,
|
||||||
|
})
|
||||||
|
|
||||||
|
return packed;
|
||||||
|
},
|
||||||
|
async packMany(
|
||||||
|
noteEdits: NoteEdit[],
|
||||||
|
) {
|
||||||
|
if (noteEdits.length === 0) return [];
|
||||||
|
|
||||||
|
const promises = await Promise.allSettled(
|
||||||
|
noteEdits.map((n) =>
|
||||||
|
this.pack(n)
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
// filter out rejected promises, only keep fulfilled values
|
||||||
|
return promises.flatMap((result) =>
|
||||||
|
result.status === "fulfilled" ? [result.value] : [],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
|
@ -16,7 +16,7 @@ export const packedNoteEdit = {
|
||||||
},
|
},
|
||||||
note: {
|
note: {
|
||||||
type: "object",
|
type: "object",
|
||||||
optional: false,
|
optional: true,
|
||||||
nullable: false,
|
nullable: false,
|
||||||
ref: "Note",
|
ref: "Note",
|
||||||
},
|
},
|
||||||
|
|
|
@ -240,6 +240,7 @@ import * as ep___notes_conversation from "./endpoints/notes/conversation.js";
|
||||||
import * as ep___notes_create from "./endpoints/notes/create.js";
|
import * as ep___notes_create from "./endpoints/notes/create.js";
|
||||||
import * as ep___notes_delete from "./endpoints/notes/delete.js";
|
import * as ep___notes_delete from "./endpoints/notes/delete.js";
|
||||||
import * as ep___notes_edit from "./endpoints/notes/edit.js";
|
import * as ep___notes_edit from "./endpoints/notes/edit.js";
|
||||||
|
import * as ep___notes_history from "./endpoints/notes/history.js";
|
||||||
import * as ep___notes_favorites_create from "./endpoints/notes/favorites/create.js";
|
import * as ep___notes_favorites_create from "./endpoints/notes/favorites/create.js";
|
||||||
import * as ep___notes_favorites_delete from "./endpoints/notes/favorites/delete.js";
|
import * as ep___notes_favorites_delete from "./endpoints/notes/favorites/delete.js";
|
||||||
import * as ep___notes_featured from "./endpoints/notes/featured.js";
|
import * as ep___notes_featured from "./endpoints/notes/featured.js";
|
||||||
|
@ -583,6 +584,7 @@ const eps = [
|
||||||
["notes/create", ep___notes_create],
|
["notes/create", ep___notes_create],
|
||||||
["notes/delete", ep___notes_delete],
|
["notes/delete", ep___notes_delete],
|
||||||
["notes/edit", ep___notes_edit],
|
["notes/edit", ep___notes_edit],
|
||||||
|
["notes/history", ep___notes_history],
|
||||||
["notes/favorites/create", ep___notes_favorites_create],
|
["notes/favorites/create", ep___notes_favorites_create],
|
||||||
["notes/favorites/delete", ep___notes_favorites_delete],
|
["notes/favorites/delete", ep___notes_favorites_delete],
|
||||||
["notes/featured", ep___notes_featured],
|
["notes/featured", ep___notes_featured],
|
||||||
|
|
64
packages/backend/src/server/api/endpoints/notes/history.ts
Normal file
64
packages/backend/src/server/api/endpoints/notes/history.ts
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
import { NoteEdits } from "@/models/index.js";
|
||||||
|
import define from "@/server/api/define.js";
|
||||||
|
import { ApiError } from "@/server/api/error.js";
|
||||||
|
import { getNote } from "@/server/api/common/getters.js";
|
||||||
|
import type { NoteEdit } from "@/models/entities/note-edit.js";
|
||||||
|
|
||||||
|
export const meta = {
|
||||||
|
tags: ["notes"],
|
||||||
|
|
||||||
|
requireCredential: false,
|
||||||
|
requireCredentialPrivateMode: true,
|
||||||
|
description: "Get edit history of a note",
|
||||||
|
|
||||||
|
res: {
|
||||||
|
type: "array",
|
||||||
|
optional: false,
|
||||||
|
nullable: true,
|
||||||
|
items: {
|
||||||
|
type: "object",
|
||||||
|
optional: false,
|
||||||
|
nullable: false,
|
||||||
|
ref: "NoteEdit",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
errors: {
|
||||||
|
noSuchNote: {
|
||||||
|
message: "No such note.",
|
||||||
|
code: "NO_SUCH_NOTE",
|
||||||
|
id: "e1035875-9551-45ec-afa8-1ded1fcb53c8",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
} as const;
|
||||||
|
|
||||||
|
export const paramDef = {
|
||||||
|
type: "object",
|
||||||
|
properties: {
|
||||||
|
noteId: {
|
||||||
|
type: "string",
|
||||||
|
format: "misskey:id",
|
||||||
|
},
|
||||||
|
limit: { type: "integer", minimum: 1, maximum: 100, default: 10 },
|
||||||
|
offset: { type: "integer", default: 0 },
|
||||||
|
},
|
||||||
|
required: ["noteId"],
|
||||||
|
} as const;
|
||||||
|
|
||||||
|
export default define(meta, paramDef, async (ps, user) => {
|
||||||
|
const note = await getNote(ps.noteId, user).catch((err) => {
|
||||||
|
if (err.id === "9725d0ce-ba28-4dde-95a7-2cbb2c15de24")
|
||||||
|
throw new ApiError(meta.errors.noSuchNote);
|
||||||
|
throw err;
|
||||||
|
});
|
||||||
|
|
||||||
|
const history: NoteEdit[] = await NoteEdits.find({
|
||||||
|
where: {
|
||||||
|
noteId: note.id,
|
||||||
|
},
|
||||||
|
take: ps.limit,
|
||||||
|
skip: ps.offset,
|
||||||
|
});
|
||||||
|
|
||||||
|
return await NoteEdits.packMany(history);
|
||||||
|
});
|
Loading…
Reference in a new issue