Co-Authored-By: ✨ <25006819+sabihoshi@users.noreply.github.com> Co-authored-by: ✨ <25006819+sabihoshi@users.noreply.github.com>tags/3.4.0
@@ -21,7 +21,7 @@ namespace Discord | |||
/// </summary> | |||
/// <remarks> | |||
/// <note type="important"> | |||
/// The returned collection is an asynchronous enumerable object; one must call | |||
/// The returned collection is an asynchronous enumerable object; one must call | |||
/// <see cref="AsyncEnumerableExtensions.FlattenAsync{T}"/> to access the individual messages as a | |||
/// collection. | |||
/// </note> | |||
@@ -227,7 +227,7 @@ namespace Discord.Rest | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
=> AsyncEnumerable.Empty<IReadOnlyCollection<IGuildUser>>(); //Overridden //Overridden in Text/Voice | |||
=> AsyncEnumerable.Empty<IReadOnlyCollection<IGuildUser>>(); //Overridden in Text/Voice | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(null); //Overridden in Text/Voice | |||
@@ -261,7 +261,7 @@ namespace Discord.Rest | |||
/// The duration on which this thread archives after. | |||
/// <para> | |||
/// <b>Note: </b> Options <see cref="ThreadArchiveDuration.OneWeek"/> and <see cref="ThreadArchiveDuration.ThreeDays"/> | |||
/// are only available for guilds that are boosted. You can check in the <see cref="IGuild.Features"/> to see if the | |||
/// are only available for guilds that are boosted. You can check in the <see cref="IGuild.Features"/> to see if the | |||
/// guild has the <b>THREE_DAY_THREAD_ARCHIVE</b> and <b>SEVEN_DAY_THREAD_ARCHIVE</b>. | |||
/// </para> | |||
/// </param> | |||
@@ -364,10 +364,9 @@ namespace Discord.Rest | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
{ | |||
if (mode == CacheMode.AllowDownload) | |||
return GetUsersAsync(options); | |||
else | |||
return AsyncEnumerable.Empty<IReadOnlyCollection<IGuildUser>>(); | |||
return mode == CacheMode.AllowDownload | |||
? GetUsersAsync(options) | |||
: AsyncEnumerable.Empty<IReadOnlyCollection<IGuildUser>>(); | |||
} | |||
#endregion | |||
@@ -209,7 +209,7 @@ namespace Discord.WebSocket | |||
/// Sets the <paramref name="activity"/> of the logged-in user. | |||
/// </summary> | |||
/// <remarks> | |||
/// This method sets the <paramref name="activity"/> of the user. | |||
/// This method sets the <paramref name="activity"/> of the user. | |||
/// <note type="note"> | |||
/// Discord will only accept setting of name and the type of activity. | |||
/// </note> | |||
@@ -219,7 +219,7 @@ namespace Discord.WebSocket | |||
/// </note> | |||
/// <note type="warning"> | |||
/// Rich Presence cannot be set via this method or client. Rich Presence is strictly limited to RPC | |||
/// clients only. | |||
/// clients only. | |||
/// </note> | |||
/// </remarks> | |||
/// <param name="activity">The activity to be set.</param> | |||
@@ -240,7 +240,7 @@ namespace Discord.WebSocket | |||
/// Creates a guild for the logged-in user who is in less than 10 active guilds. | |||
/// </summary> | |||
/// <remarks> | |||
/// This method creates a new guild on behalf of the logged-in user. | |||
/// This method creates a new guild on behalf of the logged-in user. | |||
/// <note type="warning"> | |||
/// Due to Discord's limitation, this method will only work for users that are in less than 10 guilds. | |||
/// </note> | |||
@@ -317,8 +317,15 @@ namespace Discord.WebSocket | |||
=> await CreateGuildAsync(name, region, jpegIcon, options).ConfigureAwait(false); | |||
/// <inheritdoc /> | |||
Task<IUser> IDiscordClient.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(id)); | |||
async Task<IUser> IDiscordClient.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await Rest.GetUserAsync(id, options).ConfigureAwait(false); | |||
} | |||
/// <inheritdoc /> | |||
Task<IUser> IDiscordClient.GetUserAsync(string username, string discriminator, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(username, discriminator)); | |||
@@ -533,8 +533,15 @@ namespace Discord.WebSocket | |||
=> await CreateGuildAsync(name, region, jpegIcon).ConfigureAwait(false); | |||
/// <inheritdoc /> | |||
Task<IUser> IDiscordClient.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(id)); | |||
async Task<IUser> IDiscordClient.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await Rest.GetUserAsync(id, options).ConfigureAwait(false); | |||
} | |||
/// <inheritdoc /> | |||
Task<IUser> IDiscordClient.GetUserAsync(string username, string discriminator, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(username, discriminator)); | |||
@@ -543,7 +543,7 @@ namespace Discord.WebSocket | |||
if(model == null) | |||
return null; | |||
if (model.GuildId.IsSpecified) | |||
{ | |||
var guild = State.GetGuild(model.GuildId.Value); | |||
@@ -2128,7 +2128,7 @@ namespace Discord.WebSocket | |||
{ | |||
await TimedInvokeAsync(_speakerRemoved, nameof(SpeakerRemoved), stage, guildUser); | |||
} | |||
} | |||
} | |||
} | |||
await TimedInvokeAsync(_userVoiceStateUpdatedEvent, nameof(UserVoiceStateUpdated), user, before, after).ConfigureAwait(false); | |||
@@ -2520,7 +2520,7 @@ namespace Discord.WebSocket | |||
} | |||
break; | |||
case "THREAD_MEMBERS_UPDATE": | |||
case "THREAD_MEMBERS_UPDATE": | |||
{ | |||
await _gatewayLogger.DebugAsync("Received Dispatch (THREAD_MEMBERS_UPDATE)").ConfigureAwait(false); | |||
@@ -3113,7 +3113,14 @@ namespace Discord.WebSocket | |||
/// <inheritdoc /> | |||
async Task<IUser> IDiscordClient.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> mode == CacheMode.AllowDownload ? await GetUserAsync(id, options).ConfigureAwait(false) : GetUser(id); | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await Rest.GetUserAsync(id, options).ConfigureAwait(false); | |||
} | |||
/// <inheritdoc /> | |||
Task<IUser> IDiscordClient.GetUserAsync(string username, string discriminator, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(username, discriminator)); | |||
@@ -4,6 +4,7 @@ using System.Collections.Immutable; | |||
using System.Diagnostics; | |||
using System.Linq; | |||
using System.Threading.Tasks; | |||
using Discord.Rest; | |||
using Model = Discord.API.Channel; | |||
namespace Discord.WebSocket | |||
@@ -64,21 +65,44 @@ namespace Discord.WebSocket | |||
#endregion | |||
#region IGuildChannel | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
=> ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, | |||
RequestOptions options) | |||
{ | |||
return mode == CacheMode.AllowDownload | |||
? ChannelHelper.GetUsersAsync(this, Guild, Discord, null, null, options) | |||
: ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
} | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(GetUser(id)); | |||
async Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await ChannelHelper.GetUserAsync(this, Guild, Discord, id, options).ConfigureAwait(false); | |||
} | |||
#endregion | |||
#region IChannel | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IUser>> IChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
=> ImmutableArray.Create<IReadOnlyCollection<IUser>>(Users).ToAsyncEnumerable(); | |||
{ | |||
return mode == CacheMode.AllowDownload | |||
? ChannelHelper.GetUsersAsync(this, Guild, Discord, null, null, options) | |||
: ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
} | |||
/// <inheritdoc /> | |||
Task<IUser> IChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(id)); | |||
async Task<IUser> IChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await ChannelHelper.GetUserAsync(this, Guild, Discord, id, options).ConfigureAwait(false); | |||
} | |||
#endregion | |||
} | |||
} |
@@ -352,7 +352,7 @@ namespace Discord.WebSocket | |||
Task IAudioChannel.ModifyAsync(Action<AudioChannelProperties> func, RequestOptions options) { throw new NotSupportedException(); } | |||
#endregion | |||
#region IChannel | |||
#region IChannel | |||
/// <inheritdoc /> | |||
Task<IUser> IChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IUser>(GetUser(id)); | |||
@@ -214,10 +214,10 @@ namespace Discord.WebSocket | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
=> ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
=> ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); //Overridden in Text/Voice | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(GetUser(id)); | |||
=> Task.FromResult<IGuildUser>(GetUser(id)); //Overridden in Text/Voice | |||
#endregion | |||
#region IChannel | |||
@@ -103,7 +103,7 @@ namespace Discord.WebSocket | |||
/// The duration on which this thread archives after. | |||
/// <para> | |||
/// <b>Note: </b> Options <see cref="ThreadArchiveDuration.OneWeek"/> and <see cref="ThreadArchiveDuration.ThreeDays"/> | |||
/// are only available for guilds that are boosted. You can check in the <see cref="IGuild.Features"/> to see if the | |||
/// are only available for guilds that are boosted. You can check in the <see cref="IGuild.Features"/> to see if the | |||
/// guild has the <b>THREE_DAY_THREAD_ARCHIVE</b> and <b>SEVEN_DAY_THREAD_ARCHIVE</b>. | |||
/// </para> | |||
/// </param> | |||
@@ -355,11 +355,22 @@ namespace Discord.WebSocket | |||
#region IGuildChannel | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(GetUser(id)); | |||
async Task<IGuildUser> IGuildChannel.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await ChannelHelper.GetUserAsync(this, Guild, Discord, id, options).ConfigureAwait(false); | |||
} | |||
/// <inheritdoc /> | |||
IAsyncEnumerable<IReadOnlyCollection<IGuildUser>> IGuildChannel.GetUsersAsync(CacheMode mode, RequestOptions options) | |||
=> ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
{ | |||
return mode == CacheMode.AllowDownload | |||
? ChannelHelper.GetUsersAsync(this, Guild, Discord, null, null, options) | |||
: ImmutableArray.Create<IReadOnlyCollection<IGuildUser>>(Users).ToAsyncEnumerable(); | |||
} | |||
#endregion | |||
#region IMessageChannel | |||
@@ -372,7 +372,7 @@ namespace Discord.WebSocket | |||
/// This field is based off of caching alone, since there is no events returned on the guild model. | |||
/// </remarks> | |||
/// <returns> | |||
/// A read-only collection of guild events found within this guild. | |||
/// A read-only collection of guild events found within this guild. | |||
/// </returns> | |||
public IReadOnlyCollection<SocketGuildEvent> Events => _events.ToReadOnlyCollection(); | |||
@@ -1928,8 +1928,15 @@ namespace Discord.WebSocket | |||
async Task<IGuildUser> IGuild.AddGuildUserAsync(ulong userId, string accessToken, Action<AddGuildUserProperties> func, RequestOptions options) | |||
=> await AddGuildUserAsync(userId, accessToken, func, options); | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuild.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(GetUser(id)); | |||
async Task<IGuildUser> IGuild.GetUserAsync(ulong id, CacheMode mode, RequestOptions options) | |||
{ | |||
var user = GetUser(id); | |||
if (user is not null || mode == CacheMode.CacheOnly) | |||
return user; | |||
return await GuildHelper.GetUserAsync(this, Discord, id, options).ConfigureAwait(false); | |||
} | |||
/// <inheritdoc /> | |||
Task<IGuildUser> IGuild.GetCurrentUserAsync(CacheMode mode, RequestOptions options) | |||
=> Task.FromResult<IGuildUser>(CurrentUser); | |||