Maintain state for upstream ISUPPORT

This commit is contained in:
Simon Ser 2021-03-15 23:06:36 +01:00
parent ff2cd9423f
commit 2992ff79c4

View File

@ -83,6 +83,7 @@ type upstreamConn struct {
availableChannelModes map[byte]channelModeType availableChannelModes map[byte]channelModeType
availableChannelTypes string availableChannelTypes string
availableMemberships []membership availableMemberships []membership
isupport map[string]*string
registered bool registered bool
nick string nick string
@ -193,6 +194,7 @@ func connectToUpstream(network *network) (*upstreamConn, error) {
availableChannelTypes: stdChannelTypes, availableChannelTypes: stdChannelTypes,
availableChannelModes: stdChannelModes, availableChannelModes: stdChannelModes,
availableMemberships: stdMemberships, availableMemberships: stdMemberships,
isupport: make(map[string]*string),
pendingLISTDownstreamSet: make(map[uint64]struct{}), pendingLISTDownstreamSet: make(map[uint64]struct{}),
} }
return uc, nil return uc, nil
@ -613,17 +615,28 @@ func (uc *upstreamConn) handleMessage(msg *irc.Message) error {
return err return err
} }
for _, token := range msg.Params[1 : len(msg.Params)-1] { for _, token := range msg.Params[1 : len(msg.Params)-1] {
negate := false
parameter := token parameter := token
value := "" var negate, hasValue bool
var value string
if strings.HasPrefix(token, "-") { if strings.HasPrefix(token, "-") {
negate = true negate = true
token = token[1:] token = token[1:]
} else if i := strings.IndexByte(token, '='); i >= 0 { } else if i := strings.IndexByte(token, '='); i >= 0 {
parameter = token[:i] parameter = token[:i]
value = token[i+1:] value = token[i+1:]
hasValue = true
} }
if !negate {
if hasValue {
uc.isupport[parameter] = &value
} else if !negate {
uc.isupport[parameter] = nil
} else {
delete(uc.isupport, parameter)
}
if !negate && hasValue {
// TODO: reset to defaults when the token is negated
switch parameter { switch parameter {
case "CHANMODES": case "CHANMODES":
if err := uc.handleChanModes(value); err != nil { if err := uc.handleChanModes(value); err != nil {
@ -638,8 +651,6 @@ func (uc *upstreamConn) handleMessage(msg *irc.Message) error {
case "NETWORK": case "NETWORK":
uc.networkName = value uc.networkName = value
} }
} else {
// TODO: handle ISUPPORT negations
} }
} }
case "BATCH": case "BATCH":