summaryrefslogtreecommitdiff
path: root/packages/backend/src/core/NoteCreateService.ts
diff options
context:
space:
mode:
authordakkar <dakkar@thenautilus.net>2024-11-22 10:42:58 +0000
committerdakkar <dakkar@thenautilus.net>2024-11-22 10:42:58 +0000
commitd069d78c213dfe2c78c1f160dbd99d48d0b44670 (patch)
tree4144ce79b89f5cb7026e71598eb85e1751742274 /packages/backend/src/core/NoteCreateService.ts
parentfix SCSS warning (diff)
parentmerge: Fix: Center SkModPlayer on big displays (!734) (diff)
downloadsharkey-d069d78c213dfe2c78c1f160dbd99d48d0b44670.tar.gz
sharkey-d069d78c213dfe2c78c1f160dbd99d48d0b44670.tar.bz2
sharkey-d069d78c213dfe2c78c1f160dbd99d48d0b44670.zip
Merge branch 'develop' into feature/2024.10
Diffstat (limited to 'packages/backend/src/core/NoteCreateService.ts')
-rw-r--r--packages/backend/src/core/NoteCreateService.ts9
1 files changed, 8 insertions, 1 deletions
diff --git a/packages/backend/src/core/NoteCreateService.ts b/packages/backend/src/core/NoteCreateService.ts
index e5808eccdc..13bafb7883 100644
--- a/packages/backend/src/core/NoteCreateService.ts
+++ b/packages/backend/src/core/NoteCreateService.ts
@@ -146,6 +146,8 @@ type Option = {
app?: MiApp | null;
};
+export type PureRenoteOption = Option & { renote: MiNote } & ({ text?: null } | { cw?: null } | { reply?: null } | { poll?: null } | { files?: null | [] });
+
@Injectable()
export class NoteCreateService implements OnApplicationShutdown {
#shutdownController = new AbortController();
@@ -412,7 +414,7 @@ export class NoteCreateService implements OnApplicationShutdown {
if (user.host && !data.cw) {
await this.federatedInstanceService.fetchOrRegister(user.host).then(async i => {
- if (i.isNSFW) {
+ if (i.isNSFW && !this.isPureRenote(data)) {
data.cw = 'Instance is marked as NSFW';
}
});
@@ -822,6 +824,11 @@ export class NoteCreateService implements OnApplicationShutdown {
}
@bindThis
+ public isPureRenote(note: Option): note is PureRenoteOption {
+ return this.isRenote(note) && !this.isQuote(note);
+ }
+
+ @bindThis
private isRenote(note: Option): note is Option & { renote: MiNote } {
return note.renote != null;
}