This repository has been archived by the owner on Jul 11, 2024. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathsession.go
44 lines (34 loc) · 1.56 KB
/
session.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
package disgord
import (
"context"
"time"
"github.com/andersfylling/disgord/internal/logger"
)
// Session Is the runtime interface for Disgord. It allows you to interact with a live session (using sockets or not).
// Note that this interface is used after you've configured Disgord, and therefore won't allow you to configure it
// further.
type Session interface {
// Logger returns the injected logger instance. If nothing was injected, a empty wrapper is returned
// to avoid nil panics.
Logger() logger.Logger
// AvgHeartbeatLatency returns the avg. ish time used to send and receive a heartbeat signal.
// The latency is calculated as such:
// 0. start timer (start)
// 1. send heartbeat signal
// 2. wait until a heartbeat ack is sent by Discord
// 3. latency = time.Now().Sub(start)
// 4. avg = (avg + latency) / 2
//
// This feature was requested. But should never be used as a proof for delay between client and Discord.
AvgHeartbeatLatency() (duration time.Duration, err error)
// HeartbeatLatencies returns the latency for each given shard id. shardID => latency
HeartbeatLatencies() (latencies map[uint]time.Duration, err error)
RESTRatelimitBuckets() (group map[string][]string)
Pool() *pools
ClientQueryBuilder
EditInteractionResponse(ctx context.Context, interaction *InteractionCreate, message *UpdateMessage) error
SendInteractionResponse(context context.Context, interaction *InteractionCreate, data *CreateInteractionResponse) error
UpdateStatus(s *UpdateStatusPayload) error
UpdateStatusString(s string) error
GetConnectedGuilds() []Snowflake
}