private async Task RemoveChannelPermissions(Channel channel, string userOrRoleId, string idType) { CheckReady(); if (channel == null) throw new NullReferenceException(nameof(channel)); if (userOrRoleId == null) throw new NullReferenceException(nameof(userOrRoleId)); if (idType == null) throw new NullReferenceException(nameof(idType)); try { var perms = channel.PermissionOverwrites.Where(x => x.TargetType != idType || x.TargetId != userOrRoleId).FirstOrDefault(); await _api.DeleteChannelPermissions(channel.Id, userOrRoleId).ConfigureAwait(false); if (perms != null) { channel.PermissionOverwrites.Where(x => x.TargetType != idType || x.TargetId != userOrRoleId).ToArray(); if (idType == PermissionTarget.Role) channel.InvalidatePermissionsCache(); else if (idType == PermissionTarget.Member) channel.InvalidatePermissionsCache(userOrRoleId); } } catch (HttpException ex) when (ex.StatusCode == HttpStatusCode.NotFound) { } }
private async Task SetChannelPermissions(Channel channel, string targetId, string targetType, PackedChannelPermissions allow = null, PackedChannelPermissions deny = null) { CheckReady(); if (channel == null) throw new NullReferenceException(nameof(channel)); if (targetId == null) throw new NullReferenceException(nameof(targetId)); if (targetType == null) throw new NullReferenceException(nameof(targetType)); uint allowValue = allow?.RawValue ?? 0; uint denyValue = deny?.RawValue ?? 0; bool changed = false; var perms = channel.PermissionOverwrites.Where(x => x.TargetType != targetType || x.TargetId != targetId).FirstOrDefault(); if (allowValue != 0 || denyValue != 0) { await _api.SetChannelPermissions(channel.Id, targetId, targetType, allowValue, denyValue); if (perms != null) { perms.Allow.SetRawValueInternal(allowValue); perms.Deny.SetRawValueInternal(denyValue); } else { var oldPerms = channel._permissionOverwrites; var newPerms = new Channel.PermissionOverwrite[oldPerms.Length + 1]; Array.Copy(oldPerms, newPerms, oldPerms.Length); newPerms[oldPerms.Length] = new Channel.PermissionOverwrite(targetType, targetId, allowValue, denyValue); channel._permissionOverwrites = newPerms; } changed = true; } else { try { await _api.DeleteChannelPermissions(channel.Id, targetId); if (perms != null) { channel._permissionOverwrites = channel.PermissionOverwrites.Where(x => x.TargetType != targetType || x.TargetId != targetId).ToArray(); changed = true; } } catch (HttpException ex) when (ex.StatusCode == HttpStatusCode.NotFound) { } } if (changed) { if (targetType == PermissionTarget.Role) channel.InvalidatePermissionsCache(); else if (targetType == PermissionTarget.Member) channel.InvalidatePermissionsCache(targetId); } }