メインコンテンツまでスキップ

ソーシャル

ソーシャル API はフォロー関係、フォローリクエスト、ブロック、ミュートを扱います。すべての操作には認証が必要です。

フォロー (client.following)

ユーザーをフォローする

final user = await client.following.create(userId: userId);

対象ユーザーがフォール承認を必要とする設定の場合、即時フォローの代わりにリクエストが送信されます。更新後の MisskeyUser が返されます。

withReplies: true を渡すと、そのユーザーのリプライもタイムラインに表示されます。

await client.following.create(userId: userId, withReplies: true);

フォロー解除

await client.following.delete(userId: userId);

フォロー設定の更新

個別のフォロー関係に対して、通知とリプライ表示の設定を変更します。

await client.following.update(
userId: userId,
notify: 'normal', // 'normal' または 'none'
withReplies: true,
);

全フォローの一括更新

フォローしているすべてのアカウントに同じ設定を適用します。レート制限:10リクエスト/時間。

await client.following.updateAll(notify: 'none', withReplies: false);

フォロワーを削除する

自分をフォローしているユーザーを強制的に削除します。

await client.following.invalidate(userId: userId);

フォローリクエスト (client.following.requests)

受信したリクエスト

// 自分への保留中のリクエスト一覧
final incoming = await client.following.requests.list(limit: 20);
for (final req in incoming) {
print(req.follower.username);
}

// リクエストを承認する
await client.following.requests.accept(userId: userId);

// リクエストを拒否する
await client.following.requests.reject(userId: userId);

送信したリクエスト

// 自分が送信したリクエスト一覧
final sent = await client.following.requests.sent(limit: 20);

// 送信したリクエストをキャンセルする
await client.following.requests.cancel(userId: userId);

すべてのリスト系メソッドは sinceId / untilId および sinceDate / untilDate でページングできます。

ブロック (client.blocking)

ブロックすると、自分と対象ユーザーの相互フォロー関係が解除されます。ブロックされたユーザーはあなたをフォローできなくなり、あなたもそのユーザーのコンテンツを閲覧できなくなります。

ユーザーをブロックする

await client.blocking.create(userId: userId);

ブロック解除

await client.blocking.delete(userId: userId);

ブロックリストの取得

final blocked = await client.blocking.list(limit: 20);
for (final b in blocked) {
print(b.blockee.username);
}

sinceId / untilId または sinceDate / untilDate でページングできます。

ミュート (client.mute)

ミュートすると、対象ユーザーのノート・リノート・リアクションがタイムラインに表示されなくなります。ブロックと異なり、相手にはミュートされていることが通知されません。

ユーザーをミュートする

// 永続的なミュート
await client.mute.create(userId: userId);

期限付きミュート

Unixタイムスタンプ(ミリ秒)を渡すと、指定時刻に自動でミュートが解除されます。

// 24時間ミュートする
final expiresAt = DateTime.now()
.add(const Duration(hours: 24))
.millisecondsSinceEpoch;

await client.mute.create(userId: userId, expiresAt: expiresAt);

ミュート解除

await client.mute.delete(userId: userId);

ミュートリストの取得

final muted = await client.mute.list(limit: 20);
for (final m in muted) {
print(m.mutee.username);
}

リノートミュート (client.renoteMute)

リノートミュートは、対象ユーザーのリノートだけをタイムラインから非表示にします。本人のオリジナルノートは引き続き表示されます。相手のオリジナル投稿は見たいが、転送コンテンツは見たくない場合に便利です。

リノートミュートを設定する

await client.renoteMute.create(userId: userId);

リノートミュートを解除する

await client.renoteMute.delete(userId: userId);

リノートミュートリストの取得

final renoteMuted = await client.renoteMute.list(limit: 20);
for (final rm in renoteMuted) {
print(rm.mutee.username);
}

sinceId / untilId または sinceDate / untilDate でページングできます。

比較:ミュート vs リノートミュート

通常ミュートリノートミュート
オリジナルノートを非表示ありなし
リノートを非表示ありあり
相手への通知なしなし
期限付き対応非対応