1
0
Fork 0
mirror of https://github.com/diamondburned/arikawa.git synced 2024-12-13 08:55:12 +00:00
arikawa/discord/user.go

242 lines
5.8 KiB
Go
Raw Normal View History

package discord
2020-01-02 05:39:52 +00:00
2020-05-15 20:07:27 +00:00
import (
"strconv"
2021-05-20 22:47:44 +00:00
"time"
2020-05-15 20:07:27 +00:00
)
2020-04-15 03:52:48 +00:00
2020-01-02 05:39:52 +00:00
type User struct {
ID UserID `json:"id"`
Username string `json:"username"`
Discriminator string `json:"discriminator"`
Avatar Hash `json:"avatar"`
2020-01-02 05:39:52 +00:00
// These fields may be omitted
Bot bool `json:"bot,omitempty"`
MFA bool `json:"mfa_enabled,omitempty"`
Nitro UserNitro `json:"premium_type,omitempty"`
Flags UserFlags `json:"flags,omitempty"`
PublicFlags UserFlags `json:"public_flags,omitempty"`
2020-01-02 05:39:52 +00:00
DiscordSystem bool `json:"system,omitempty"`
EmailVerified bool `json:"verified,omitempty"`
Locale string `json:"locale,omitempty"`
Email string `json:"email,omitempty"`
Banner Hash `json:"banner,omitempty"`
Accent Color `json:"accent_color,omitempty"`
2020-01-02 05:39:52 +00:00
}
2021-05-20 22:47:44 +00:00
// CreatedAt returns a time object representing when the user was created.
func (u User) CreatedAt() time.Time {
return u.ID.Time()
}
2021-05-20 22:17:58 +00:00
// Mention returns a mention of the user.
2020-01-24 05:45:47 +00:00
func (u User) Mention() string {
return u.ID.Mention()
2020-01-24 05:45:47 +00:00
}
2021-05-20 22:49:56 +00:00
// Tag returns a tag of the user.
func (u User) Tag() string {
return u.Username + "#" + u.Discriminator
}
2020-05-15 20:07:27 +00:00
// AvatarURL returns the URL of the Avatar Image. It automatically detects a
// suitable type.
2020-01-24 06:00:41 +00:00
func (u User) AvatarURL() string {
2020-05-15 20:07:27 +00:00
return u.AvatarURLWithType(AutoImage)
}
// AvatarURLWithType returns the URL of the Avatar Image using the passed type.
// If the user has no Avatar, his default avatar will be returned. This
// requires ImageType Auto or PNG
//
// Supported Image Types: PNG, JPEG, WebP, GIF (read above for caveat)
func (u User) AvatarURLWithType(t ImageType) string {
2020-01-24 06:00:41 +00:00
if u.Avatar == "" {
2020-05-15 20:07:27 +00:00
if t != PNGImage && t != AutoImage {
return ""
}
2020-01-24 06:00:41 +00:00
2020-05-15 20:07:27 +00:00
disc, err := strconv.Atoi(u.Discriminator)
if err != nil { // this should never happen
return ""
}
2020-05-22 21:38:53 +00:00
picNo := strconv.Itoa(disc % 5)
2020-01-24 06:00:41 +00:00
2020-05-22 21:38:53 +00:00
return "https://cdn.discordapp.com/embed/avatars/" + picNo + ".png"
2020-01-24 06:00:41 +00:00
}
2020-05-15 20:07:27 +00:00
return "https://cdn.discordapp.com/avatars/" + u.ID.String() + "/" + t.format(u.Avatar)
2020-01-24 06:00:41 +00:00
}
// BannerURL returns the URL of the Banner Image. It automatically detects a
// suitable type.
func (u User) BannerURL() string {
return u.BannerURLWithType(AutoImage)
}
// BannerURLWithType returns the URL of the Banner Image using the passed type.
// If the user has no Banner, an empty string will be returned.
func (u User) BannerURLWithType(t ImageType) string {
if u.Banner == "" {
return ""
}
return "https://cdn.discordapp.com/banners/" + u.ID.String() + "/" + t.format(u.Banner)
}
type UserFlags uint32
2020-01-02 05:39:52 +00:00
const NoFlag UserFlags = 0
2020-01-02 05:39:52 +00:00
const (
Employee UserFlags = 1 << iota
Partner
2020-01-02 05:39:52 +00:00
HypeSquadEvents
BugHunterLvl1
_
_
2020-01-02 05:39:52 +00:00
HouseBravery
HouseBrilliance
HouseBalance
EarlySupporter
TeamUser
_
2020-01-02 05:39:52 +00:00
System
_
BugHunterLvl2
_
VerifiedBot
VerifiedBotDeveloper
CertifiedModerator
2022-04-17 09:47:48 +00:00
LikelySpammer // undocumented
2020-01-02 05:39:52 +00:00
)
2020-01-04 04:19:24 +00:00
type UserNitro uint8
2020-01-02 05:39:52 +00:00
const (
2020-01-04 04:19:24 +00:00
NoUserNitro UserNitro = iota
2020-01-02 05:39:52 +00:00
NitroClassic
NitroFull
)
type Connection struct {
ID string `json:"id"`
Name string `json:"name"`
Type Service `json:"type"`
Revoked bool `json:"revoked"`
Verified bool `json:"verified"`
FriendSync bool `json:"friend_sync"`
ShowActivity bool `json:"show_activity"`
Visibility ConnectionVisibility `json:"visibility"`
// Only partial
2020-01-15 07:34:18 +00:00
Integrations []Integration `json:"integrations"`
}
type ConnectionVisibility uint8
const (
ConnectionNotVisible ConnectionVisibility = iota
ConnectionVisibleEveryone
)
2020-01-18 21:04:12 +00:00
type Activity struct {
Name string `json:"name"`
URL URL `json:"url,omitempty"`
2020-01-18 21:04:12 +00:00
Type ActivityType `json:"type"`
// User only
Instance bool `json:"instance,omitempty"`
Flags ActivityFlags `json:"flags,omitempty"`
CreatedAt UnixTimestamp `json:"created_at,omitempty"`
Timestamps *ActivityTimestamps `json:"timestamps,omitempty"`
2020-01-18 21:04:12 +00:00
AppID AppID `json:"application_id,omitempty"`
Details string `json:"details,omitempty"`
State string `json:"state,omitempty"` // party status
Emoji *Emoji `json:"emoji,omitempty"`
2020-01-18 21:04:12 +00:00
Party *ActivityParty `json:"party,omitempty"`
Assets *ActivityAssets `json:"assets,omitempty"`
Secrets *ActivitySecrets `json:"secrets,omitempty"`
2020-01-18 21:04:12 +00:00
2020-02-23 17:56:16 +00:00
// Undocumented fields
SyncID string `json:"sync_id,omitempty"`
SessionID string `json:"session_id,omitempty"`
2020-01-18 21:04:12 +00:00
}
type ActivityType uint8
const (
2021-11-16 22:34:37 +00:00
GameActivity ActivityType = iota // Playing $name
StreamingActivity // Streaming $details
ListeningActivity // Listening to $name
WatchingActivity // Watching $name
CustomActivity // $emoji $state
CompetingActivity // Competing in $name
2020-01-18 21:04:12 +00:00
)
type ActivityFlags uint32
2020-01-18 21:04:12 +00:00
const (
InstanceActivity ActivityFlags = 1 << iota
JoinActivity
SpectateActivity
JoinRequestActivity
SyncActivity
PlayActivity
)
2020-03-31 05:00:28 +00:00
type ActivityTimestamps struct {
Start UnixMsTimestamp `json:"start,omitempty"`
End UnixMsTimestamp `json:"end,omitempty"`
}
2020-03-31 05:00:28 +00:00
type ActivityParty struct {
ID string `json:"id,omitempty"`
Size [2]int `json:"size,omitempty"` // [ current, max ]
}
type ActivityAssets struct {
LargeImage string `json:"large_image,omitempty"` // id
LargeText string `json:"large_text,omitempty"`
SmallImage string `json:"small_image,omitempty"` // id
SmallText string `json:"small_text,omitempty"`
}
type ActivitySecrets struct {
Join string `json:"join,omitempty"`
Spectate string `json:"spectate,omitempty"`
Match string `json:"match,omitempty"`
}
// A Relationship between the logged in user and the user in the struct. This
// struct is undocumented.
type Relationship struct {
UserID UserID `json:"id"`
User User `json:"user"`
Type RelationshipType `json:"type"`
}
// RelationshipType is an enum for a relationship.
type RelationshipType uint8
const (
_ RelationshipType = iota
FriendRelationship
BlockedRelationship
IncomingFriendRequest
SentFriendRequest
)