summaryrefslogtreecommitdiff
path: root/packages/megalodon/src
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-03-24 14:26:25 -0400
committerHazelnoot <acomputerdog@gmail.com>2025-03-27 19:51:43 -0400
commit58cdee77d5d7a8dceef39683695d33947a614070 (patch)
treec68d2544191043adc30d60a57795ea5e0ad67a09 /packages/megalodon/src
parentdon't render CW as HTML for mastodon (diff)
downloadsharkey-58cdee77d5d7a8dceef39683695d33947a614070.tar.gz
sharkey-58cdee77d5d7a8dceef39683695d33947a614070.tar.bz2
sharkey-58cdee77d5d7a8dceef39683695d33947a614070.zip
convert notification types in mastodon API
Diffstat (limited to 'packages/megalodon/src')
-rw-r--r--packages/megalodon/src/index.ts2
-rw-r--r--packages/megalodon/src/mastodon/notification.ts33
-rw-r--r--packages/megalodon/src/misskey/api_client.ts3
-rw-r--r--packages/megalodon/src/notification.ts48
4 files changed, 66 insertions, 20 deletions
diff --git a/packages/megalodon/src/index.ts b/packages/megalodon/src/index.ts
index 621f007ccf..7a4f10ab02 100644
--- a/packages/megalodon/src/index.ts
+++ b/packages/megalodon/src/index.ts
@@ -6,7 +6,7 @@ import { MegalodonInterface, WebSocketInterface } from './megalodon'
import { detector } from './detector'
import Misskey from './misskey'
import Entity from './entity'
-import NotificationType from './notification'
+import * as NotificationType from './notification'
import FilterContext from './filter_context'
import Converter from './converter'
import MastodonEntity from './mastodon/entity';
diff --git a/packages/megalodon/src/mastodon/notification.ts b/packages/megalodon/src/mastodon/notification.ts
new file mode 100644
index 0000000000..9c51f9698d
--- /dev/null
+++ b/packages/megalodon/src/mastodon/notification.ts
@@ -0,0 +1,33 @@
+export const Mention = 'mention' as const;
+export const Reblog = 'reblog' as const;
+export const Favourite = 'favourite' as const;
+export const Follow = 'follow' as const;
+export const Poll = 'poll' as const;
+export const FollowRequest = 'follow_request' as const;
+export const Status = 'status' as const;
+export const Update = 'update' as const;
+export const AdminSignup = 'admin.sign_up' as const;
+export const AdminReport = 'admin.report' as const;
+export const Reaction = 'reaction' as const;
+export const ModerationWarning = 'moderation_warning' as const;
+export const SeveredRelationships = 'severed_relationships' as const;
+export const AnnualReport = 'annual_report' as const;
+
+export const mastodonNotificationTypes = [
+ Mention,
+ Reblog,
+ Favourite,
+ Follow,
+ Poll,
+ FollowRequest,
+ Status,
+ Update,
+ AdminSignup,
+ AdminReport,
+ Reaction,
+ ModerationWarning,
+ SeveredRelationships,
+ AnnualReport,
+];
+
+export type MastodonNotificationType = typeof mastodonNotificationTypes[number];
diff --git a/packages/megalodon/src/misskey/api_client.ts b/packages/megalodon/src/misskey/api_client.ts
index 4c975c4dfa..6dfa59f132 100644
--- a/packages/megalodon/src/misskey/api_client.ts
+++ b/packages/megalodon/src/misskey/api_client.ts
@@ -9,7 +9,8 @@ import MisskeyEntity from './entity'
import MegalodonEntity from '../entity'
import WebSocket from './web_socket'
import MisskeyNotificationType from './notification'
-import NotificationType, { UnknownNotificationTypeError } from '../notification'
+import * as NotificationType from '../notification'
+import { UnknownNotificationTypeError } from '../notification';
namespace MisskeyAPI {
export namespace Entity {
diff --git a/packages/megalodon/src/notification.ts b/packages/megalodon/src/notification.ts
index 7c08c5d47f..846d79c6d7 100644
--- a/packages/megalodon/src/notification.ts
+++ b/packages/megalodon/src/notification.ts
@@ -1,20 +1,16 @@
-import Entity from './entity'
-
-namespace NotificationType {
- export const Follow: Entity.NotificationType = 'follow'
- export const Favourite: Entity.NotificationType = 'favourite'
- export const Reblog: Entity.NotificationType = 'reblog'
- export const Mention: Entity.NotificationType = 'mention'
- export const EmojiReaction: Entity.NotificationType = 'emoji_reaction'
- export const FollowRequest: Entity.NotificationType = 'follow_request'
- export const Status: Entity.NotificationType = 'status'
- export const PollVote: Entity.NotificationType = 'poll_vote'
- export const PollExpired: Entity.NotificationType = 'poll_expired'
- export const Update: Entity.NotificationType = 'update'
- export const Move: Entity.NotificationType = 'move'
- export const AdminSignup: Entity.NotificationType = 'admin.sign_up'
- export const AdminReport: Entity.NotificationType = 'admin.report'
-}
+export const Follow = 'follow' as const;
+export const Favourite = 'favourite' as const;
+export const Reblog = 'reblog' as const;
+export const Mention = 'mention' as const;
+export const EmojiReaction = 'emoji_reaction' as const;
+export const FollowRequest = 'follow_request' as const;
+export const Status = 'status' as const;
+export const PollVote = 'poll_vote' as const;
+export const PollExpired = 'poll_expired' as const;
+export const Update = 'update' as const;
+export const Move = 'move' as const;
+export const AdminSignup = 'admin.sign_up' as const;
+export const AdminReport = 'admin.report' as const;
export class UnknownNotificationTypeError extends Error {
constructor() {
@@ -23,4 +19,20 @@ export class UnknownNotificationTypeError extends Error {
}
}
-export default NotificationType
+export const notificationTypes = [
+ Follow,
+ Favourite,
+ Reblog,
+ Mention,
+ EmojiReaction,
+ FollowRequest,
+ Status,
+ PollVote,
+ PollExpired,
+ Update,
+ Move,
+ AdminSignup,
+ AdminReport,
+];
+
+export type NotificationType = typeof notificationTypes[number];