mirror of
https://github.com/diamondburned/arikawa.git
synced 2025-05-25 00:23:15 +00:00
Merge pull request #81 from mavolin/77-no-limits
This commit is contained in:
commit
05f01964fe
121
api/guild.go
121
api/guild.go
|
@ -103,29 +103,95 @@ func (c *Client) GuildWithCount(id discord.Snowflake) (*discord.Guild, error) {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Guilds returns all guilds, automatically paginating. Be careful, as this
|
// Guilds returns a list of partial guild objects the current user is a member
|
||||||
// method may abuse the API by requesting thousands or millions of guilds. For
|
// of. This method automatically paginates until it reaches the passed limit,
|
||||||
// lower-level access, use GuildsRange. Guilds returned have some fields
|
// or, if the limit is set to 0, has fetched all guilds within the passed
|
||||||
// filled only (ID, Name, Icon, Owner, Permissions).
|
// range.
|
||||||
//
|
//
|
||||||
// Max can be 0, in which case the function will try and fetch all guilds.
|
// As the underlying endpoint has a maximum of 100 guilds per request, at
|
||||||
func (c *Client) Guilds(max uint) ([]discord.Guild, error) {
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
var guilds []discord.Guild
|
// may be less, if no more guilds are available.
|
||||||
var after discord.Snowflake = 0
|
//
|
||||||
|
// When fetching the guilds, those with the smallest ID will be fetched first.
|
||||||
|
//
|
||||||
|
// Also note that 100 is the maximum number of guilds a non-bot user can join.
|
||||||
|
// Therefore, pagination is not needed for integrations that need to get a list
|
||||||
|
// of the users' guilds.
|
||||||
|
//
|
||||||
|
// Requires the guilds OAuth2 scope.
|
||||||
|
func (c *Client) Guilds(limit uint) ([]discord.Guild, error) {
|
||||||
|
return c.GuildsAfter(0, limit)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GuildsBefore returns a list of partial guild objects the current user is a
|
||||||
|
// member of. This method automatically paginates until it reaches the
|
||||||
|
// passed limit, or, if the limit is set to 0, has fetched all guilds within
|
||||||
|
// the passed range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 guilds per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more guilds are available.
|
||||||
|
//
|
||||||
|
// Requires the guilds OAuth2 scope.
|
||||||
|
func (c *Client) GuildsBefore(before discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
||||||
|
var guilds []discord.Guild
|
||||||
|
|
||||||
|
// this is the limit of max guilds per request,as imposed by Discord
|
||||||
const hardLimit int = 100
|
const hardLimit int = 100
|
||||||
|
|
||||||
unlimited := max == 0
|
unlimited := limit == 0
|
||||||
|
|
||||||
for fetch := uint(hardLimit); max > 0 || unlimited; fetch = uint(hardLimit) {
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
if max > 0 {
|
if limit > 0 {
|
||||||
if fetch > max {
|
if fetch > limit {
|
||||||
fetch = max
|
fetch = limit
|
||||||
}
|
}
|
||||||
max -= fetch
|
limit -= fetch
|
||||||
}
|
}
|
||||||
|
|
||||||
g, err := c.GuildsAfter(after, fetch)
|
g, err := c.guildsRange(before, 0, fetch)
|
||||||
|
if err != nil {
|
||||||
|
return guilds, err
|
||||||
|
}
|
||||||
|
guilds = append(g, guilds...)
|
||||||
|
|
||||||
|
if len(g) < hardLimit {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
before = g[0].ID
|
||||||
|
}
|
||||||
|
|
||||||
|
return guilds, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// GuildsAfter returns a list of partial guild objects the current user is a
|
||||||
|
// member of. This method automatically paginates until it reaches the
|
||||||
|
// passed limit, or, if the limit is set to 0, has fetched all guilds within
|
||||||
|
// the passed range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 guilds per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more guilds are available.
|
||||||
|
//
|
||||||
|
// Requires the guilds OAuth2 scope.
|
||||||
|
func (c *Client) GuildsAfter(after discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
||||||
|
var guilds []discord.Guild
|
||||||
|
|
||||||
|
// this is the limit of max guilds per request, as imposed by Discord
|
||||||
|
const hardLimit int = 100
|
||||||
|
|
||||||
|
unlimited := limit == 0
|
||||||
|
|
||||||
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
|
if limit > 0 {
|
||||||
|
if fetch > limit {
|
||||||
|
fetch = limit
|
||||||
|
}
|
||||||
|
limit -= fetch
|
||||||
|
}
|
||||||
|
|
||||||
|
g, err := c.guildsRange(0, after, fetch)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return guilds, err
|
return guilds, err
|
||||||
}
|
}
|
||||||
|
@ -141,29 +207,8 @@ func (c *Client) Guilds(max uint) ([]discord.Guild, error) {
|
||||||
return guilds, nil
|
return guilds, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GuildsBefore fetches guilds before the specified ID. Check GuildsRange.
|
func (c *Client) guildsRange(
|
||||||
func (c *Client) GuildsBefore(before discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
before, after discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
||||||
return c.GuildsRange(before, 0, limit)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GuildsAfter fetches guilds after the specified ID. Check GuildsRange.
|
|
||||||
func (c *Client) GuildsAfter(after discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
|
||||||
return c.GuildsRange(0, after, limit)
|
|
||||||
}
|
|
||||||
|
|
||||||
// GuildsRange returns a list of partial guild objects the current user is a
|
|
||||||
// member of. Requires the guilds OAuth2 scope.
|
|
||||||
//
|
|
||||||
// This endpoint returns 100 guilds by default, which is the maximum number
|
|
||||||
// of guilds a non-bot user can join. Therefore, pagination is not needed
|
|
||||||
// for integrations that need to get a list of the users' guilds.
|
|
||||||
func (c *Client) GuildsRange(before, after discord.Snowflake, limit uint) ([]discord.Guild, error) {
|
|
||||||
switch {
|
|
||||||
case limit == 0:
|
|
||||||
limit = 100
|
|
||||||
case limit > 100:
|
|
||||||
limit = 100
|
|
||||||
}
|
|
||||||
|
|
||||||
var param struct {
|
var param struct {
|
||||||
Before discord.Snowflake `schema:"before,omitempty"`
|
Before discord.Snowflake `schema:"before,omitempty"`
|
||||||
|
|
|
@ -12,33 +12,50 @@ func (c *Client) Member(guildID, userID discord.Snowflake) (*discord.Member, err
|
||||||
return m, c.RequestJSON(&m, "GET", EndpointGuilds+guildID.String()+"/members/"+userID.String())
|
return m, c.RequestJSON(&m, "GET", EndpointGuilds+guildID.String()+"/members/"+userID.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
// Members returns members until it reaches max. This function automatically
|
// Members returns a list of members of the guild with the passed id. This
|
||||||
// paginates, meaning the normal 1000 limit is handled internally.
|
// method automatically paginates until it reaches the passed limit, or, if the
|
||||||
|
// limit is set to 0, has fetched all members within the passed range.
|
||||||
//
|
//
|
||||||
// Max can be 0, in which case the function will try and fetch all members.
|
// As the underlying endpoint has a maximum of 1000 members per request, at
|
||||||
func (c *Client) Members(guildID discord.Snowflake, max uint) ([]discord.Member, error) {
|
// maximum a total of limit/1000 rounded up requests will be made, although
|
||||||
|
// they may be less, if no more members are available.
|
||||||
|
//
|
||||||
|
// When fetching the members, those with the smallest ID will be fetched first.
|
||||||
|
func (c *Client) Members(guildID discord.Snowflake, limit uint) ([]discord.Member, error) {
|
||||||
|
return c.MembersAfter(guildID, 0, limit)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MembersAfter returns a list of members of the guild with the passed id. This
|
||||||
|
// method automatically paginates until it reaches the passed limit, or, if the
|
||||||
|
// limit is set to 0, has fetched all members within the passed range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 1000 members per request, at
|
||||||
|
// maximum a total of limit/1000 rounded up requests will be made, although
|
||||||
|
// they may be less, if no more members are available.
|
||||||
|
func (c *Client) MembersAfter(
|
||||||
|
guildID, after discord.Snowflake, limit uint) ([]discord.Member, error) {
|
||||||
|
|
||||||
var mems []discord.Member
|
var mems []discord.Member
|
||||||
var after discord.Snowflake = 0
|
|
||||||
|
|
||||||
const hardLimit int = 1000
|
const hardLimit int = 1000
|
||||||
|
|
||||||
unlimited := max == 0
|
unlimited := limit == 0
|
||||||
|
|
||||||
for fetch := uint(hardLimit); max > 0 || unlimited; fetch = uint(hardLimit) {
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
if max > 0 {
|
if limit > 0 {
|
||||||
if fetch > max {
|
if fetch > limit {
|
||||||
fetch = max
|
fetch = limit
|
||||||
}
|
}
|
||||||
max -= fetch
|
limit -= fetch
|
||||||
}
|
}
|
||||||
|
|
||||||
m, err := c.MembersAfter(guildID, after, fetch)
|
m, err := c.membersAfter(guildID, after, fetch)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return mems, err
|
return mems, err
|
||||||
}
|
}
|
||||||
mems = append(mems, m...)
|
mems = append(mems, m...)
|
||||||
|
|
||||||
// There aren't any to fetch, even if this is less than max.
|
// There aren't any to fetch, even if this is less than limit.
|
||||||
if len(mems) < hardLimit {
|
if len(mems) < hardLimit {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -49,9 +66,7 @@ func (c *Client) Members(guildID discord.Snowflake, max uint) ([]discord.Member,
|
||||||
return mems, nil
|
return mems, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// MembersAfter returns a list of all guild members, from 1-1000 for limits. The
|
func (c *Client) membersAfter(
|
||||||
// default limit is 1 and the maximum limit is 1000.
|
|
||||||
func (c *Client) MembersAfter(
|
|
||||||
guildID, after discord.Snowflake, limit uint) ([]discord.Member, error) {
|
guildID, after discord.Snowflake, limit uint) ([]discord.Member, error) {
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
|
|
118
api/message.go
118
api/message.go
|
@ -6,25 +6,93 @@ import (
|
||||||
"github.com/diamondburned/arikawa/utils/json/option"
|
"github.com/diamondburned/arikawa/utils/json/option"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Messages gets all messages, automatically paginating. Use with care, as
|
// Messages returns a list of messages sent in the channel with the passed ID.
|
||||||
// this could get as many as hundred thousands of messages, making a lot of
|
// This method automatically paginates until it reaches the passed limit, or,
|
||||||
// queries.
|
// if the limit is set to 0, has fetched all guilds within the passed ange.
|
||||||
//
|
//
|
||||||
// Max can be 0, in which case the function will try and fetch all messages.
|
// As the underlying endpoint has a maximum of 100 messages per request, at
|
||||||
func (c *Client) Messages(channelID discord.Snowflake, max uint) ([]discord.Message, error) {
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
var msgs []discord.Message
|
// may be less, if no more messages are available.
|
||||||
var after discord.Snowflake = 0
|
//
|
||||||
|
// When fetching the messages, those with the smallest ID will be fetched
|
||||||
|
// first.
|
||||||
|
func (c *Client) Messages(channelID discord.Snowflake, limit uint) ([]discord.Message, error) {
|
||||||
|
return c.MessagesAfter(channelID, 0, limit)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MessagesAround returns messages around the ID, with a limit of 100.
|
||||||
|
func (c *Client) MessagesAround(
|
||||||
|
channelID, around discord.Snowflake, limit uint) ([]discord.Message, error) {
|
||||||
|
|
||||||
|
return c.messagesRange(channelID, 0, 0, around, limit)
|
||||||
|
}
|
||||||
|
|
||||||
|
// MessagesBefore returns a list messages sent in the channel with the passed
|
||||||
|
// ID. This method automatically paginates until it reaches the passed limit,
|
||||||
|
// or, if the limit is set to 0, has fetched all guilds within the passed
|
||||||
|
// range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 messages per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more messages are available.
|
||||||
|
func (c *Client) MessagesBefore(
|
||||||
|
channelID, before discord.Snowflake, limit uint) ([]discord.Message, error) {
|
||||||
|
|
||||||
|
var msgs []discord.Message
|
||||||
|
|
||||||
|
// this is the limit of max messages per request, as imposed by Discord
|
||||||
const hardLimit int = 100
|
const hardLimit int = 100
|
||||||
|
|
||||||
unlimited := max == 0
|
unlimited := limit == 0
|
||||||
|
|
||||||
for fetch := uint(hardLimit); max > 0 || unlimited; fetch = uint(hardLimit) {
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
if max > 0 {
|
if limit > 0 {
|
||||||
if fetch > max {
|
if fetch > limit {
|
||||||
fetch = max
|
fetch = limit
|
||||||
}
|
}
|
||||||
max -= fetch
|
limit -= fetch
|
||||||
|
}
|
||||||
|
|
||||||
|
m, err := c.messagesRange(channelID, before, 0, 0, fetch)
|
||||||
|
if err != nil {
|
||||||
|
return msgs, err
|
||||||
|
}
|
||||||
|
msgs = append(m, msgs...)
|
||||||
|
|
||||||
|
if len(m) < hardLimit {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
before = m[0].Author.ID
|
||||||
|
}
|
||||||
|
|
||||||
|
return msgs, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// MessagesAfter returns a list messages sent in the channel with the passed
|
||||||
|
// ID. This method automatically paginates until it reaches the passed limit,
|
||||||
|
// or, if the limit is set to 0, has fetched all guilds within the passed
|
||||||
|
// range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 messages per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more messages are available.
|
||||||
|
func (c *Client) MessagesAfter(
|
||||||
|
channelID, after discord.Snowflake, limit uint) ([]discord.Message, error) {
|
||||||
|
|
||||||
|
var msgs []discord.Message
|
||||||
|
|
||||||
|
// this is the limit of max messages per request, as imposed by Discord
|
||||||
|
const hardLimit int = 100
|
||||||
|
|
||||||
|
unlimited := limit == 0
|
||||||
|
|
||||||
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
|
if limit > 0 {
|
||||||
|
if fetch > limit {
|
||||||
|
fetch = limit
|
||||||
|
}
|
||||||
|
limit -= fetch
|
||||||
}
|
}
|
||||||
|
|
||||||
m, err := c.messagesRange(channelID, 0, after, 0, fetch)
|
m, err := c.messagesRange(channelID, 0, after, 0, fetch)
|
||||||
|
@ -43,30 +111,8 @@ func (c *Client) Messages(channelID discord.Snowflake, max uint) ([]discord.Mess
|
||||||
return msgs, nil
|
return msgs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// MessagesAround returns messages around the ID, with a limit of 1-100.
|
|
||||||
func (c *Client) MessagesAround(
|
|
||||||
channelID, around discord.Snowflake, limit uint) ([]discord.Message, error) {
|
|
||||||
|
|
||||||
return c.messagesRange(channelID, 0, 0, around, limit)
|
|
||||||
}
|
|
||||||
|
|
||||||
// MessagesBefore returns messages before the ID, with a limit of 1-100.
|
|
||||||
func (c *Client) MessagesBefore(
|
|
||||||
channelID, before discord.Snowflake, limit uint) ([]discord.Message, error) {
|
|
||||||
|
|
||||||
return c.messagesRange(channelID, before, 0, 0, limit)
|
|
||||||
}
|
|
||||||
|
|
||||||
// MessagesAfter returns messages after the ID, with a limit of 1-100.
|
|
||||||
func (c *Client) MessagesAfter(
|
|
||||||
channelID, after discord.Snowflake, limit uint) ([]discord.Message, error) {
|
|
||||||
|
|
||||||
return c.messagesRange(channelID, 0, after, 0, limit)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Client) messagesRange(
|
func (c *Client) messagesRange(
|
||||||
channelID, before, after, around discord.Snowflake,
|
channelID, before, after, around discord.Snowflake, limit uint) ([]discord.Message, error) {
|
||||||
limit uint) ([]discord.Message, error) {
|
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case limit == 0:
|
case limit == 0:
|
||||||
|
|
|
@ -25,27 +25,88 @@ func (c *Client) Unreact(chID, msgID discord.Snowflake, emoji Emoji) error {
|
||||||
return c.DeleteUserReaction(chID, msgID, 0, emoji)
|
return c.DeleteUserReaction(chID, msgID, 0, emoji)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reactions returns reactions up to the specified limit. It will paginate
|
// Reactions returns a list of users that reacted with the passed Emoji. This
|
||||||
// automatically.
|
// method automatically paginates until it reaches the passed limit, or, if the
|
||||||
|
// limit is set to 0, has fetched all users within the passed range.
|
||||||
//
|
//
|
||||||
// Max can be 0, in which case the function will try and fetch all reactions.
|
// As the underlying endpoint has a maximum of 100 users per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more guilds are available.
|
||||||
|
//
|
||||||
|
// When fetching the users, those with the smallest ID will be fetched first.
|
||||||
func (c *Client) Reactions(
|
func (c *Client) Reactions(
|
||||||
channelID, messageID discord.Snowflake, max uint, emoji Emoji) ([]discord.User, error) {
|
channelID, messageID discord.Snowflake, limit uint, emoji Emoji) ([]discord.User, error) {
|
||||||
|
|
||||||
|
return c.ReactionsAfter(channelID, messageID, 0, limit, emoji)
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReactionsBefore returns a list of users that reacted with the passed Emoji.
|
||||||
|
// This method automatically paginates until it reaches the passed limit, or,
|
||||||
|
// if the limit is set to 0, has fetched all users within the passed range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 users per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more guilds are available.
|
||||||
|
func (c *Client) ReactionsBefore(
|
||||||
|
channelID, messageID, before discord.Snowflake,
|
||||||
|
limit uint, emoji Emoji) ([]discord.User, error) {
|
||||||
|
|
||||||
var users []discord.User
|
var users []discord.User
|
||||||
var after discord.Snowflake = 0
|
|
||||||
|
|
||||||
const hardLimit int = 100
|
const hardLimit int = 100
|
||||||
|
|
||||||
for fetch := uint(hardLimit); max > 0; fetch = uint(hardLimit) {
|
unlimited := limit == 0
|
||||||
if max > 0 {
|
|
||||||
if fetch > max {
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
fetch = max
|
if limit > 0 {
|
||||||
|
if fetch > limit {
|
||||||
|
fetch = limit
|
||||||
}
|
}
|
||||||
max -= fetch
|
limit -= fetch
|
||||||
}
|
}
|
||||||
|
|
||||||
r, err := c.ReactionsRange(channelID, messageID, 0, after, fetch, emoji)
|
r, err := c.reactionsRange(channelID, messageID, before, 0, fetch, emoji)
|
||||||
|
if err != nil {
|
||||||
|
return users, err
|
||||||
|
}
|
||||||
|
users = append(users, r...)
|
||||||
|
|
||||||
|
if len(r) < hardLimit {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
before = r[0].ID
|
||||||
|
}
|
||||||
|
|
||||||
|
return users, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReactionsAfter returns a list of users that reacted with the passed Emoji.
|
||||||
|
// This method automatically paginates until it reaches the passed limit, or,
|
||||||
|
// if the limit is set to 0, has fetched all users within the passed range.
|
||||||
|
//
|
||||||
|
// As the underlying endpoint has a maximum of 100 users per request, at
|
||||||
|
// maximum a total of limit/100 rounded up requests will be made, although they
|
||||||
|
// may be less, if no more guilds are available.
|
||||||
|
func (c *Client) ReactionsAfter(
|
||||||
|
channelID, messageID, after discord.Snowflake, limit uint, emoji Emoji,
|
||||||
|
) ([]discord.User, error) {
|
||||||
|
|
||||||
|
var users []discord.User
|
||||||
|
|
||||||
|
const hardLimit int = 100
|
||||||
|
|
||||||
|
unlimited := limit == 0
|
||||||
|
|
||||||
|
for fetch := uint(hardLimit); limit > 0 || unlimited; fetch = uint(hardLimit) {
|
||||||
|
if limit > 0 {
|
||||||
|
if fetch > limit {
|
||||||
|
fetch = limit
|
||||||
|
}
|
||||||
|
limit -= fetch
|
||||||
|
}
|
||||||
|
|
||||||
|
r, err := c.reactionsRange(channelID, messageID, 0, after, fetch, emoji)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return users, err
|
return users, err
|
||||||
}
|
}
|
||||||
|
@ -61,25 +122,9 @@ func (c *Client) Reactions(
|
||||||
return users, nil
|
return users, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReactionsBefore gets all reactions before the passed user ID.
|
// reactionsRange get users before and after IDs. Before, after, and limit are
|
||||||
func (c *Client) ReactionsBefore(
|
|
||||||
channelID, messageID, before discord.Snowflake,
|
|
||||||
limit uint, emoji Emoji) ([]discord.User, error) {
|
|
||||||
|
|
||||||
return c.ReactionsRange(channelID, messageID, before, 0, limit, emoji)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Refer to ReactionsRange.
|
|
||||||
func (c *Client) ReactionsAfter(
|
|
||||||
channelID, messageID, after discord.Snowflake,
|
|
||||||
limit uint, emoji Emoji) ([]discord.User, error) {
|
|
||||||
|
|
||||||
return c.ReactionsRange(channelID, messageID, 0, after, limit, emoji)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ReactionsRange get users before and after IDs. Before, after, and limit are
|
|
||||||
// optional. A maximum limit of only 100 reactions could be returned.
|
// optional. A maximum limit of only 100 reactions could be returned.
|
||||||
func (c *Client) ReactionsRange(
|
func (c *Client) reactionsRange(
|
||||||
channelID, messageID, before, after discord.Snowflake,
|
channelID, messageID, before, after discord.Snowflake,
|
||||||
limit uint, emoji Emoji) ([]discord.User, error) {
|
limit uint, emoji Emoji) ([]discord.User, error) {
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue