ScuttleBot
feat(#38,#39): autojoin enforcement and bot INVITE handling - topology.Manager.ProvisionChannel calls Invite() after provisioning (#38) - All system bots (bridge, systembot, scribe, herald, oracle, sentinel, steward, auditbot, warden, snitch) now handle girc.INVITE by joining the channel (#39) - bridge routes INVITE through JoinChannel() to initialise its buffer map first - snitch needed a strings import to support the HasPrefix check
Commit
bd16e1f7ac804eea6aa5f8c14fdf3944fb353ae2f3ac39e65c4abdaa3273b66c
Parent
dd3a887e30cee4f…
10 files changed
+6
+6
+6
+6
+6
+6
+7
+6
+6
+6
~
internal/bots/auditbot/auditbot.go
~
internal/bots/bridge/bridge.go
~
internal/bots/herald/herald.go
~
internal/bots/oracle/oracle.go
~
internal/bots/scribe/scribe.go
~
internal/bots/sentinel/sentinel.go
~
internal/bots/snitch/snitch.go
~
internal/bots/steward/steward.go
~
internal/bots/systembot/systembot.go
~
internal/bots/warden/warden.go
| --- internal/bots/auditbot/auditbot.go | ||
| +++ internal/bots/auditbot/auditbot.go | ||
| @@ -115,10 +115,16 @@ | ||
| 115 | 115 | for _, ch := range b.channels { |
| 116 | 116 | cl.Cmd.Join(ch) |
| 117 | 117 | } |
| 118 | 118 | b.log.Info("auditbot connected", "channels", b.channels, "audit_types", b.auditTypesList()) |
| 119 | 119 | }) |
| 120 | + | |
| 121 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 122 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 123 | + cl.Cmd.Join(ch) | |
| 124 | + } | |
| 125 | + }) | |
| 120 | 126 | |
| 121 | 127 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 122 | 128 | if len(e.Params) < 1 { |
| 123 | 129 | return |
| 124 | 130 | } |
| 125 | 131 |
| --- internal/bots/auditbot/auditbot.go | |
| +++ internal/bots/auditbot/auditbot.go | |
| @@ -115,10 +115,16 @@ | |
| 115 | for _, ch := range b.channels { |
| 116 | cl.Cmd.Join(ch) |
| 117 | } |
| 118 | b.log.Info("auditbot connected", "channels", b.channels, "audit_types", b.auditTypesList()) |
| 119 | }) |
| 120 | |
| 121 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 122 | if len(e.Params) < 1 { |
| 123 | return |
| 124 | } |
| 125 |
| --- internal/bots/auditbot/auditbot.go | |
| +++ internal/bots/auditbot/auditbot.go | |
| @@ -115,10 +115,16 @@ | |
| 115 | for _, ch := range b.channels { |
| 116 | cl.Cmd.Join(ch) |
| 117 | } |
| 118 | b.log.Info("auditbot connected", "channels", b.channels, "audit_types", b.auditTypesList()) |
| 119 | }) |
| 120 | |
| 121 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 122 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 123 | cl.Cmd.Join(ch) |
| 124 | } |
| 125 | }) |
| 126 | |
| 127 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 128 | if len(e.Params) < 1 { |
| 129 | return |
| 130 | } |
| 131 |
| --- internal/bots/bridge/bridge.go | ||
| +++ internal/bots/bridge/bridge.go | ||
| @@ -162,10 +162,16 @@ | ||
| 162 | 162 | } |
| 163 | 163 | for _, ch := range b.initChannels { |
| 164 | 164 | cl.Cmd.Join(ch) |
| 165 | 165 | } |
| 166 | 166 | }) |
| 167 | + | |
| 168 | + c.Handlers.AddBg(girc.INVITE, func(_ *girc.Client, e girc.Event) { | |
| 169 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 170 | + b.JoinChannel(ch) | |
| 171 | + } | |
| 172 | + }) | |
| 167 | 173 | |
| 168 | 174 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 169 | 175 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name != b.nick { |
| 170 | 176 | return |
| 171 | 177 | } |
| 172 | 178 |
| --- internal/bots/bridge/bridge.go | |
| +++ internal/bots/bridge/bridge.go | |
| @@ -162,10 +162,16 @@ | |
| 162 | } |
| 163 | for _, ch := range b.initChannels { |
| 164 | cl.Cmd.Join(ch) |
| 165 | } |
| 166 | }) |
| 167 | |
| 168 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 169 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name != b.nick { |
| 170 | return |
| 171 | } |
| 172 |
| --- internal/bots/bridge/bridge.go | |
| +++ internal/bots/bridge/bridge.go | |
| @@ -162,10 +162,16 @@ | |
| 162 | } |
| 163 | for _, ch := range b.initChannels { |
| 164 | cl.Cmd.Join(ch) |
| 165 | } |
| 166 | }) |
| 167 | |
| 168 | c.Handlers.AddBg(girc.INVITE, func(_ *girc.Client, e girc.Event) { |
| 169 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 170 | b.JoinChannel(ch) |
| 171 | } |
| 172 | }) |
| 173 | |
| 174 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 175 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name != b.nick { |
| 176 | return |
| 177 | } |
| 178 |
| --- internal/bots/herald/herald.go | ||
| +++ internal/bots/herald/herald.go | ||
| @@ -149,10 +149,16 @@ | ||
| 149 | 149 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 150 | 150 | if b.log != nil { |
| 151 | 151 | b.log.Info("herald connected") |
| 152 | 152 | } |
| 153 | 153 | }) |
| 154 | + | |
| 155 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 156 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 157 | + cl.Cmd.Join(ch) | |
| 158 | + } | |
| 159 | + }) | |
| 154 | 160 | |
| 155 | 161 | b.client = c |
| 156 | 162 | |
| 157 | 163 | errCh := make(chan error, 1) |
| 158 | 164 | go func() { |
| 159 | 165 |
| --- internal/bots/herald/herald.go | |
| +++ internal/bots/herald/herald.go | |
| @@ -149,10 +149,16 @@ | |
| 149 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 150 | if b.log != nil { |
| 151 | b.log.Info("herald connected") |
| 152 | } |
| 153 | }) |
| 154 | |
| 155 | b.client = c |
| 156 | |
| 157 | errCh := make(chan error, 1) |
| 158 | go func() { |
| 159 |
| --- internal/bots/herald/herald.go | |
| +++ internal/bots/herald/herald.go | |
| @@ -149,10 +149,16 @@ | |
| 149 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 150 | if b.log != nil { |
| 151 | b.log.Info("herald connected") |
| 152 | } |
| 153 | }) |
| 154 | |
| 155 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 156 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 157 | cl.Cmd.Join(ch) |
| 158 | } |
| 159 | }) |
| 160 | |
| 161 | b.client = c |
| 162 | |
| 163 | errCh := make(chan error, 1) |
| 164 | go func() { |
| 165 |
| --- internal/bots/oracle/oracle.go | ||
| +++ internal/bots/oracle/oracle.go | ||
| @@ -162,10 +162,16 @@ | ||
| 162 | 162 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 163 | 163 | if b.log != nil { |
| 164 | 164 | b.log.Info("oracle connected") |
| 165 | 165 | } |
| 166 | 166 | }) |
| 167 | + | |
| 168 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 169 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 170 | + cl.Cmd.Join(ch) | |
| 171 | + } | |
| 172 | + }) | |
| 167 | 173 | |
| 168 | 174 | // Only handle DMs — oracle ignores channel messages. |
| 169 | 175 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 170 | 176 | if len(e.Params) < 1 || e.Source == nil { |
| 171 | 177 | return |
| 172 | 178 |
| --- internal/bots/oracle/oracle.go | |
| +++ internal/bots/oracle/oracle.go | |
| @@ -162,10 +162,16 @@ | |
| 162 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 163 | if b.log != nil { |
| 164 | b.log.Info("oracle connected") |
| 165 | } |
| 166 | }) |
| 167 | |
| 168 | // Only handle DMs — oracle ignores channel messages. |
| 169 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 170 | if len(e.Params) < 1 || e.Source == nil { |
| 171 | return |
| 172 |
| --- internal/bots/oracle/oracle.go | |
| +++ internal/bots/oracle/oracle.go | |
| @@ -162,10 +162,16 @@ | |
| 162 | c.Handlers.AddBg(girc.CONNECTED, func(_ *girc.Client, _ girc.Event) { |
| 163 | if b.log != nil { |
| 164 | b.log.Info("oracle connected") |
| 165 | } |
| 166 | }) |
| 167 | |
| 168 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 169 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 170 | cl.Cmd.Join(ch) |
| 171 | } |
| 172 | }) |
| 173 | |
| 174 | // Only handle DMs — oracle ignores channel messages. |
| 175 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 176 | if len(e.Params) < 1 || e.Source == nil { |
| 177 | return |
| 178 |
| --- internal/bots/scribe/scribe.go | ||
| +++ internal/bots/scribe/scribe.go | ||
| @@ -67,10 +67,16 @@ | ||
| 67 | 67 | for _, ch := range b.channels { |
| 68 | 68 | client.Cmd.Join(ch) |
| 69 | 69 | } |
| 70 | 70 | b.log.Info("scribe connected and joined channels", "channels", b.channels) |
| 71 | 71 | }) |
| 72 | + | |
| 73 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 74 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 75 | + cl.Cmd.Join(ch) | |
| 76 | + } | |
| 77 | + }) | |
| 72 | 78 | |
| 73 | 79 | // Log PRIVMSG — the agent message stream. |
| 74 | 80 | c.Handlers.AddBg(girc.PRIVMSG, func(client *girc.Client, e girc.Event) { |
| 75 | 81 | if len(e.Params) < 1 { |
| 76 | 82 | return |
| 77 | 83 |
| --- internal/bots/scribe/scribe.go | |
| +++ internal/bots/scribe/scribe.go | |
| @@ -67,10 +67,16 @@ | |
| 67 | for _, ch := range b.channels { |
| 68 | client.Cmd.Join(ch) |
| 69 | } |
| 70 | b.log.Info("scribe connected and joined channels", "channels", b.channels) |
| 71 | }) |
| 72 | |
| 73 | // Log PRIVMSG — the agent message stream. |
| 74 | c.Handlers.AddBg(girc.PRIVMSG, func(client *girc.Client, e girc.Event) { |
| 75 | if len(e.Params) < 1 { |
| 76 | return |
| 77 |
| --- internal/bots/scribe/scribe.go | |
| +++ internal/bots/scribe/scribe.go | |
| @@ -67,10 +67,16 @@ | |
| 67 | for _, ch := range b.channels { |
| 68 | client.Cmd.Join(ch) |
| 69 | } |
| 70 | b.log.Info("scribe connected and joined channels", "channels", b.channels) |
| 71 | }) |
| 72 | |
| 73 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 74 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 75 | cl.Cmd.Join(ch) |
| 76 | } |
| 77 | }) |
| 78 | |
| 79 | // Log PRIVMSG — the agent message stream. |
| 80 | c.Handlers.AddBg(girc.PRIVMSG, func(client *girc.Client, e girc.Event) { |
| 81 | if len(e.Params) < 1 { |
| 82 | return |
| 83 |
| --- internal/bots/sentinel/sentinel.go | ||
| +++ internal/bots/sentinel/sentinel.go | ||
| @@ -146,10 +146,16 @@ | ||
| 146 | 146 | if b.log != nil { |
| 147 | 147 | b.log.Info("sentinel connected") |
| 148 | 148 | } |
| 149 | 149 | cl.Cmd.Join(b.cfg.ModChannel) |
| 150 | 150 | }) |
| 151 | + | |
| 152 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 153 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 154 | + cl.Cmd.Join(ch) | |
| 155 | + } | |
| 156 | + }) | |
| 151 | 157 | |
| 152 | 158 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 153 | 159 | if len(e.Params) < 1 || e.Source == nil { |
| 154 | 160 | return |
| 155 | 161 | } |
| 156 | 162 |
| --- internal/bots/sentinel/sentinel.go | |
| +++ internal/bots/sentinel/sentinel.go | |
| @@ -146,10 +146,16 @@ | |
| 146 | if b.log != nil { |
| 147 | b.log.Info("sentinel connected") |
| 148 | } |
| 149 | cl.Cmd.Join(b.cfg.ModChannel) |
| 150 | }) |
| 151 | |
| 152 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 153 | if len(e.Params) < 1 || e.Source == nil { |
| 154 | return |
| 155 | } |
| 156 |
| --- internal/bots/sentinel/sentinel.go | |
| +++ internal/bots/sentinel/sentinel.go | |
| @@ -146,10 +146,16 @@ | |
| 146 | if b.log != nil { |
| 147 | b.log.Info("sentinel connected") |
| 148 | } |
| 149 | cl.Cmd.Join(b.cfg.ModChannel) |
| 150 | }) |
| 151 | |
| 152 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 153 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 154 | cl.Cmd.Join(ch) |
| 155 | } |
| 156 | }) |
| 157 | |
| 158 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 159 | if len(e.Params) < 1 || e.Source == nil { |
| 160 | return |
| 161 | } |
| 162 |
| --- internal/bots/snitch/snitch.go | ||
| +++ internal/bots/snitch/snitch.go | ||
| @@ -12,10 +12,11 @@ | ||
| 12 | 12 | "context" |
| 13 | 13 | "fmt" |
| 14 | 14 | "log/slog" |
| 15 | 15 | "net" |
| 16 | 16 | "strconv" |
| 17 | + "strings" | |
| 17 | 18 | "sync" |
| 18 | 19 | "time" |
| 19 | 20 | |
| 20 | 21 | "github.com/lrstanley/girc" |
| 21 | 22 | ) |
| @@ -136,10 +137,16 @@ | ||
| 136 | 137 | } |
| 137 | 138 | if b.cfg.AlertChannel != "" { |
| 138 | 139 | cl.Cmd.Join(b.cfg.AlertChannel) |
| 139 | 140 | } |
| 140 | 141 | }) |
| 142 | + | |
| 143 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 144 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 145 | + cl.Cmd.Join(ch) | |
| 146 | + } | |
| 147 | + }) | |
| 141 | 148 | |
| 142 | 149 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 143 | 150 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name == b.cfg.Nick { |
| 144 | 151 | return |
| 145 | 152 | } |
| 146 | 153 |
| --- internal/bots/snitch/snitch.go | |
| +++ internal/bots/snitch/snitch.go | |
| @@ -12,10 +12,11 @@ | |
| 12 | "context" |
| 13 | "fmt" |
| 14 | "log/slog" |
| 15 | "net" |
| 16 | "strconv" |
| 17 | "sync" |
| 18 | "time" |
| 19 | |
| 20 | "github.com/lrstanley/girc" |
| 21 | ) |
| @@ -136,10 +137,16 @@ | |
| 136 | } |
| 137 | if b.cfg.AlertChannel != "" { |
| 138 | cl.Cmd.Join(b.cfg.AlertChannel) |
| 139 | } |
| 140 | }) |
| 141 | |
| 142 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 143 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name == b.cfg.Nick { |
| 144 | return |
| 145 | } |
| 146 |
| --- internal/bots/snitch/snitch.go | |
| +++ internal/bots/snitch/snitch.go | |
| @@ -12,10 +12,11 @@ | |
| 12 | "context" |
| 13 | "fmt" |
| 14 | "log/slog" |
| 15 | "net" |
| 16 | "strconv" |
| 17 | "strings" |
| 18 | "sync" |
| 19 | "time" |
| 20 | |
| 21 | "github.com/lrstanley/girc" |
| 22 | ) |
| @@ -136,10 +137,16 @@ | |
| 137 | } |
| 138 | if b.cfg.AlertChannel != "" { |
| 139 | cl.Cmd.Join(b.cfg.AlertChannel) |
| 140 | } |
| 141 | }) |
| 142 | |
| 143 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 144 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 145 | cl.Cmd.Join(ch) |
| 146 | } |
| 147 | }) |
| 148 | |
| 149 | c.Handlers.AddBg(girc.JOIN, func(_ *girc.Client, e girc.Event) { |
| 150 | if len(e.Params) < 1 || e.Source == nil || e.Source.Name == b.cfg.Nick { |
| 151 | return |
| 152 | } |
| 153 |
| --- internal/bots/steward/steward.go | ||
| +++ internal/bots/steward/steward.go | ||
| @@ -130,10 +130,16 @@ | ||
| 130 | 130 | if b.log != nil { |
| 131 | 131 | b.log.Info("steward connected") |
| 132 | 132 | } |
| 133 | 133 | cl.Cmd.Join(b.cfg.ModChannel) |
| 134 | 134 | }) |
| 135 | + | |
| 136 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 137 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 138 | + cl.Cmd.Join(ch) | |
| 139 | + } | |
| 140 | + }) | |
| 135 | 141 | |
| 136 | 142 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 137 | 143 | if len(e.Params) < 1 || e.Source == nil { |
| 138 | 144 | return |
| 139 | 145 | } |
| 140 | 146 |
| --- internal/bots/steward/steward.go | |
| +++ internal/bots/steward/steward.go | |
| @@ -130,10 +130,16 @@ | |
| 130 | if b.log != nil { |
| 131 | b.log.Info("steward connected") |
| 132 | } |
| 133 | cl.Cmd.Join(b.cfg.ModChannel) |
| 134 | }) |
| 135 | |
| 136 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 137 | if len(e.Params) < 1 || e.Source == nil { |
| 138 | return |
| 139 | } |
| 140 |
| --- internal/bots/steward/steward.go | |
| +++ internal/bots/steward/steward.go | |
| @@ -130,10 +130,16 @@ | |
| 130 | if b.log != nil { |
| 131 | b.log.Info("steward connected") |
| 132 | } |
| 133 | cl.Cmd.Join(b.cfg.ModChannel) |
| 134 | }) |
| 135 | |
| 136 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 137 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 138 | cl.Cmd.Join(ch) |
| 139 | } |
| 140 | }) |
| 141 | |
| 142 | c.Handlers.AddBg(girc.PRIVMSG, func(_ *girc.Client, e girc.Event) { |
| 143 | if len(e.Params) < 1 || e.Source == nil { |
| 144 | return |
| 145 | } |
| 146 |
| --- internal/bots/systembot/systembot.go | ||
| +++ internal/bots/systembot/systembot.go | ||
| @@ -92,10 +92,16 @@ | ||
| 92 | 92 | for _, ch := range b.channels { |
| 93 | 93 | cl.Cmd.Join(ch) |
| 94 | 94 | } |
| 95 | 95 | b.log.Info("systembot connected", "channels", b.channels) |
| 96 | 96 | }) |
| 97 | + | |
| 98 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 99 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 100 | + cl.Cmd.Join(ch) | |
| 101 | + } | |
| 102 | + }) | |
| 97 | 103 | |
| 98 | 104 | // NOTICE — server announcements, NickServ/ChanServ responses. |
| 99 | 105 | c.Handlers.AddBg(girc.NOTICE, func(_ *girc.Client, e girc.Event) { |
| 100 | 106 | channel := "" |
| 101 | 107 | if len(e.Params) > 0 && strings.HasPrefix(e.Params[0], "#") { |
| 102 | 108 |
| --- internal/bots/systembot/systembot.go | |
| +++ internal/bots/systembot/systembot.go | |
| @@ -92,10 +92,16 @@ | |
| 92 | for _, ch := range b.channels { |
| 93 | cl.Cmd.Join(ch) |
| 94 | } |
| 95 | b.log.Info("systembot connected", "channels", b.channels) |
| 96 | }) |
| 97 | |
| 98 | // NOTICE — server announcements, NickServ/ChanServ responses. |
| 99 | c.Handlers.AddBg(girc.NOTICE, func(_ *girc.Client, e girc.Event) { |
| 100 | channel := "" |
| 101 | if len(e.Params) > 0 && strings.HasPrefix(e.Params[0], "#") { |
| 102 |
| --- internal/bots/systembot/systembot.go | |
| +++ internal/bots/systembot/systembot.go | |
| @@ -92,10 +92,16 @@ | |
| 92 | for _, ch := range b.channels { |
| 93 | cl.Cmd.Join(ch) |
| 94 | } |
| 95 | b.log.Info("systembot connected", "channels", b.channels) |
| 96 | }) |
| 97 | |
| 98 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 99 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 100 | cl.Cmd.Join(ch) |
| 101 | } |
| 102 | }) |
| 103 | |
| 104 | // NOTICE — server announcements, NickServ/ChanServ responses. |
| 105 | c.Handlers.AddBg(girc.NOTICE, func(_ *girc.Client, e girc.Event) { |
| 106 | channel := "" |
| 107 | if len(e.Params) > 0 && strings.HasPrefix(e.Params[0], "#") { |
| 108 |
| --- internal/bots/warden/warden.go | ||
| +++ internal/bots/warden/warden.go | ||
| @@ -201,10 +201,16 @@ | ||
| 201 | 201 | } |
| 202 | 202 | if b.log != nil { |
| 203 | 203 | b.log.Info("warden connected") |
| 204 | 204 | } |
| 205 | 205 | }) |
| 206 | + | |
| 207 | + c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { | |
| 208 | + if ch := e.Last(); strings.HasPrefix(ch, "#") { | |
| 209 | + cl.Cmd.Join(ch) | |
| 210 | + } | |
| 211 | + }) | |
| 206 | 212 | |
| 207 | 213 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 208 | 214 | if len(e.Params) < 1 || e.Source == nil { |
| 209 | 215 | return |
| 210 | 216 | } |
| 211 | 217 |
| --- internal/bots/warden/warden.go | |
| +++ internal/bots/warden/warden.go | |
| @@ -201,10 +201,16 @@ | |
| 201 | } |
| 202 | if b.log != nil { |
| 203 | b.log.Info("warden connected") |
| 204 | } |
| 205 | }) |
| 206 | |
| 207 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 208 | if len(e.Params) < 1 || e.Source == nil { |
| 209 | return |
| 210 | } |
| 211 |
| --- internal/bots/warden/warden.go | |
| +++ internal/bots/warden/warden.go | |
| @@ -201,10 +201,16 @@ | |
| 201 | } |
| 202 | if b.log != nil { |
| 203 | b.log.Info("warden connected") |
| 204 | } |
| 205 | }) |
| 206 | |
| 207 | c.Handlers.AddBg(girc.INVITE, func(cl *girc.Client, e girc.Event) { |
| 208 | if ch := e.Last(); strings.HasPrefix(ch, "#") { |
| 209 | cl.Cmd.Join(ch) |
| 210 | } |
| 211 | }) |
| 212 | |
| 213 | c.Handlers.AddBg(girc.PRIVMSG, func(cl *girc.Client, e girc.Event) { |
| 214 | if len(e.Params) < 1 || e.Source == nil { |
| 215 | return |
| 216 | } |
| 217 |