noot
This commit is contained in:
parent
19922d6fc5
commit
c738036f14
@ -1,83 +0,0 @@
|
|||||||
package ircmw
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"tuxpa.in/a/irc/pkg/ircv3"
|
|
||||||
)
|
|
||||||
|
|
||||||
type Capabilities struct {
|
|
||||||
pending int
|
|
||||||
}
|
|
||||||
|
|
||||||
var capabilitiesKey struct{}
|
|
||||||
|
|
||||||
func AddPending(ctx context.Context, i int) {
|
|
||||||
val, ok := ctx.Value(capabilitiesKey).(*Capabilities)
|
|
||||||
if !ok {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
val.pending += i
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Capabilities) Middleware(next ircv3.Handler) ircv3.Handler {
|
|
||||||
return ircv3.HandlerFunc(func(ctx context.Context, w ircv3.MessageWriter, m *ircv3.Message) {
|
|
||||||
ctx = context.WithValue(ctx, capabilitiesKey, c)
|
|
||||||
if m.Command == "" {
|
|
||||||
c.pending++
|
|
||||||
w.WriteMessage(ircv3.NewMessage("CAP", "LS", "302"))
|
|
||||||
}
|
|
||||||
next.Handle(ctx, w, m)
|
|
||||||
if m.Command == "CAP" && m.Param(0) == "*" && m.Param(1) == "LS" {
|
|
||||||
c.pending--
|
|
||||||
}
|
|
||||||
if c.pending == 0 {
|
|
||||||
c.pending = -1
|
|
||||||
w.WriteMessage(ircv3.NewMessage("CAP", "END"))
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func CapabilityExchange(next ircv3.Handler) ircv3.Handler {
|
|
||||||
return ircv3.HandlerFunc(func(ctx context.Context, w ircv3.MessageWriter, m *ircv3.Message) {
|
|
||||||
next.Handle(ctx, w, m)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
var keyServerTime struct{}
|
|
||||||
|
|
||||||
func ServerTime(ctx context.Context) time.Time {
|
|
||||||
val, ok := ctx.Value(keyServerTime).(time.Time)
|
|
||||||
if !ok {
|
|
||||||
return time.Time{}
|
|
||||||
}
|
|
||||||
return val
|
|
||||||
}
|
|
||||||
|
|
||||||
func CapabilityServerTime(next ircv3.Handler) ircv3.Handler {
|
|
||||||
enabled := false
|
|
||||||
return ircv3.HandlerFunc(func(ctx context.Context, w ircv3.MessageWriter, m *ircv3.Message) {
|
|
||||||
if m.Command == "CAP" && m.Param(0) == "*" && m.Param(1) == "LS" {
|
|
||||||
if strings.Contains(m.Param(2), "server-time") {
|
|
||||||
AddPending(ctx, 1)
|
|
||||||
w.WriteMessage(ircv3.NewMessage("CAP", "REQ", "server-time"))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if m.Command == "CAP" && m.Param(1) == "ACK" && m.Param(2) == "server-time" {
|
|
||||||
AddPending(ctx, -1)
|
|
||||||
enabled = true
|
|
||||||
}
|
|
||||||
if enabled {
|
|
||||||
tString := m.Tags.Get("time")
|
|
||||||
if tString != "" {
|
|
||||||
parsedTime, err := time.Parse("2006-01-02T15:04:05.000Z", tString)
|
|
||||||
if err == nil {
|
|
||||||
ctx = context.WithValue(ctx, keyServerTime, parsedTime)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
next.Handle(ctx, w, m)
|
|
||||||
})
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user