mirror of
https://github.com/ergochat/ergo.git
synced 2024-12-22 10:42:52 +01:00
Merge pull request #1629 from jesopo/global-notice
implement mass/global messaging
This commit is contained in:
commit
8bf6231ec6
@ -622,6 +622,7 @@ oper-classes:
|
||||
- "chanreg"
|
||||
- "history"
|
||||
- "defcon"
|
||||
- "massmessage"
|
||||
|
||||
# ircd operators
|
||||
opers:
|
||||
|
@ -2157,6 +2157,27 @@ func dispatchMessageToTarget(client *Client, tags map[string]string, histType hi
|
||||
return
|
||||
}
|
||||
channel.SendSplitMessage(command, lowestPrefix, tags, client, message, rb)
|
||||
} else if target[0] == '$' && len(target) > 2 && client.Oper().HasRoleCapab("massmessage") {
|
||||
details := client.Details()
|
||||
matcher, err := utils.CompileGlob(target[2:], false)
|
||||
if err != nil {
|
||||
rb.Add(nil, server.name, ERR_UNKNOWNERROR, details.nick, command, client.t("Erroneous target"))
|
||||
return
|
||||
}
|
||||
|
||||
nickMaskString := details.nickMask
|
||||
accountName := details.accountName
|
||||
isBot := client.HasMode(modes.Bot)
|
||||
for _, tClient := range server.clients.AllClients() {
|
||||
if (target[1] == '$' && matcher.MatchString(tClient.server.name)) || // $$servername
|
||||
(target[1] == '#' && matcher.MatchString(tClient.Hostname())) { // $#hostname
|
||||
|
||||
tnick := tClient.Nick()
|
||||
for _, session := range tClient.Sessions() {
|
||||
session.sendSplitMsgFromClientInternal(false, nickMaskString, accountName, isBot, nil, command, tnick, message)
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
lowercaseTarget := strings.ToLower(target)
|
||||
service, isService := OragonoServices[lowercaseTarget]
|
||||
|
@ -594,6 +594,7 @@ oper-classes:
|
||||
- "chanreg"
|
||||
- "history"
|
||||
- "defcon"
|
||||
- "massmessage"
|
||||
|
||||
# ircd operators
|
||||
opers:
|
||||
|
Loading…
Reference in New Issue
Block a user