본문으로 건너뛰기

알림

client.notifications API는 알림 조회, 삭제, 정책 관리 기능을 제공합니다.

알림 조회

목록 조회

final page = await client.notifications.fetch(limit: 20);

for (final n in page.items) {
print('${n.type}: ${n.account?.displayName}');
}

타입별 필터링

// 멘션과 좋아요만
final page = await client.notifications.fetch(
types: ['mention', 'favourite'],
);

// 팔로우를 제외한 모든 알림
final page = await client.notifications.fetch(
excludeTypes: ['follow'],
);

단일 알림 조회

final notification = await client.notifications.fetchById('12345');

읽지 않은 알림 수 (Mastodon 4.3+)

final count = await client.notifications.fetchUnreadCount();
print(count.count);

알림 삭제

단일 삭제

await client.notifications.dismiss('12345');

전체 삭제

await client.notifications.clear();

알림 정책 (Mastodon 4.3+)

현재 정책 조회

final policy = await client.notifications.fetchPolicy();
print(policy.forNotFollowing); // accept, filter, drop

정책 업데이트

await client.notifications.updatePolicy(policy);

알림 요청 (Mastodon 4.3+)

정책 조건에 맞는 계정의 필터링된 알림은 요청으로 수집됩니다.

요청 목록 조회

final page = await client.notifications.fetchRequests(limit: 20);

수락 / 거절

// 단건
await client.notifications.acceptRequest('12345');
await client.notifications.dismissRequest('12345');

// 일괄
await client.notifications.acceptRequests(['1', '2', '3']);
await client.notifications.dismissRequests(['4', '5']);

병합 상태 확인

final merged = await client.notifications.checkRequestsMerged();
if (merged) {
// 수락된 요청이 알림 목록에 병합됨
}

그룹화된 알림 (v2)

그룹화된 알림 API를 사용하려면 client.groupedNotifications를 사용합니다:

final result = await client.groupedNotifications.fetch(limit: 20);
for (final group in result.notificationGroups) {
print('${group.type}: ${group.notificationsCount} notifications');
}