1
0
Fork 0
mirror of https://github.com/diamondburned/arikawa.git synced 2025-01-21 03:57:26 +00:00

api/discord: Add RTCRegionID and VoiceQuality

This commit is contained in:
Maximilian von Lindern 2021-05-29 20:22:57 +02:00 committed by diamondburned
parent b936d00ead
commit 6f73088e7d
2 changed files with 73 additions and 1 deletions

View file

@ -59,8 +59,18 @@ type CreateChannelData struct {
CategoryID discord.ChannelID `json:"parent_id,string,omitempty"` CategoryID discord.ChannelID `json:"parent_id,string,omitempty"`
// NSFW specifies whether the channel is nsfw. // NSFW specifies whether the channel is nsfw.
// //
// Channel Types: Text, News, Store. // Channel Types: Text, News, Store
NSFW bool `json:"nsfw,omitempty"` NSFW bool `json:"nsfw,omitempty"`
// RTCRegionID is the channel voice region id. It will be determined
// automatically set, if omitted.
//
// Channel Types: Voice
RTCRegionID string `json:"rtc_region,omitempty"`
// VideoQualityMode is the camera video quality mode of the voice channel.
// This defaults to discord.AutoVideoQuality, if not set.
//
// ChannelTypes: Voice
VoiceQualityMode discord.VideoQualityMode `json:"voice_quality_mode,omitempty"`
} }
// CreateChannel creates a new channel object for the guild. // CreateChannel creates a new channel object for the guild.

View file

@ -1,6 +1,7 @@
package discord package discord
import ( import (
"github.com/diamondburned/arikawa/v2/utils/json"
"strconv" "strconv"
"strings" "strings"
"time" "time"
@ -58,6 +59,59 @@ type Channel struct {
CategoryID ChannelID `json:"parent_id,omitempty"` CategoryID ChannelID `json:"parent_id,omitempty"`
// LastPinTime is when the last pinned message was pinned. // LastPinTime is when the last pinned message was pinned.
LastPinTime Timestamp `json:"last_pin_timestamp,omitempty"` LastPinTime Timestamp `json:"last_pin_timestamp,omitempty"`
// RTCRegionID is the voice region id for the voice channel. If set to
// null, the voice region is determined automatically.
//
// If RTCRegionID is an empty string, the region is automatically
// determined.
RTCRegionID *string `json:"rtc_region,omitempty"`
// VideoQualityMode is the camera video quality mode of the voice channel.
VideoQualityMode VideoQualityMode `json:"video_quality_mode,omitempty"`
}
func (ch *Channel) UnmarshalJSON(data []byte) error {
if err := json.Unmarshal(data, ch); err != nil {
return err
}
// In the docs, Discord states that if VideoQualityMode is omitted, it is
// actually 1 aka. AutoVideoQuality, and they just didn't bother to send
// it.
// Refer to:
// https://discord.com/developers/docs/resources/channel#channel-object-channel-structure
if ch.VideoQualityMode == 0 {
ch.VideoQualityMode = 1
}
// "rtc_region" is present in the json and was unmarshalled as nil, so
// Discord sent us JSON null. Set this to &"", refer to the doc of
// .RTCRegionID for more information.
if strings.Contains(string(data), `"rtc_region"`) && ch.RTCRegionID == nil {
region := ""
ch.RTCRegionID = &region
}
return nil
}
func (ch Channel) MarshalJSON() ([]byte, error) {
if ch.RTCRegionID == nil || *ch.RTCRegionID != "" {
return json.Marshal(ch)
}
marshalChannel := struct {
Channel
// Remove the ",omitempty" flag, forcing RTCRegionID to be marshalled
// as JSON null. See the doc of Channel.RTCRegionID for more
// information.
RTCRegionID *string `json:"rtc_region"`
}{
Channel: ch,
RTCRegionID: nil,
}
return json.Marshal(marshalChannel)
} }
// CreatedAt returns a time object representing when the channel was created. // CreatedAt returns a time object representing when the channel was created.
@ -161,3 +215,11 @@ func (otype *OverwriteType) UnmarshalJSON(b []byte) error {
*otype = OverwriteType(u) *otype = OverwriteType(u)
return nil return nil
} }
type VideoQualityMode uint8
// https://discord.com/developers/docs/resources/channel#channel-object-video-quality-modes
const (
AutoVideoQuality VideoQualityMode = iota + 1
FullVideoQuality
)