3
0
mirror of https://github.com/ergochat/ergo.git synced 2024-12-31 23:22:38 +01:00

refactor DEOP

DEOP is now pure syntactic sugar for /mode #channel -o nick,
the change is attributed to the originating user and not to ChanServ.
This commit is contained in:
Shivaram Lingamneni 2020-10-26 23:08:05 -04:00
parent f010914965
commit 610fc5068d

View File

@ -42,10 +42,9 @@ this command if you're the founder of the channel.`,
DEOP removes the given nickname, or yourself, the channel admin. You can only use DEOP removes the given nickname, or yourself, the channel admin. You can only use
this command if you're the founder of the channel.`, this command if you're the founder of the channel.`,
helpShort: `$bDEOP$b removes the given user (or yourself) from a channel admin.`, helpShort: `$bDEOP$b removes the given user (or yourself) from a channel admin.`,
authRequired: true, enabled: chanregEnabled,
enabled: chanregEnabled, minParams: 1,
minParams: 1,
}, },
"register": { "register": {
handler: csRegisterHandler, handler: csRegisterHandler,
@ -194,7 +193,6 @@ func csNotice(rb *ResponseBuffer, text string) {
rb.Add(nil, chanservMask, "NOTICE", rb.target.Nick(), text) rb.Add(nil, chanservMask, "NOTICE", rb.target.Nick(), text)
} }
func csAmodeHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) { func csAmodeHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) {
channelName := params[0] channelName := params[0]
@ -325,16 +323,13 @@ func csOpHandler(server *Server, client *Client, command string, params []string
} }
func csDeopHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) { func csDeopHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) {
channelInfo := server.channels.Get(params[0]) channel := server.channels.Get(params[0])
if channelInfo == nil { if channel == nil {
csNotice(rb, client.t("Channel does not exist")) csNotice(rb, client.t("Channel does not exist"))
return return
} }
channelName := channelInfo.Name() if !channel.hasClient(client) {
csNotice(rb, client.t("You're not on that channel"))
clientAccount := client.Account()
if clientAccount == "" || clientAccount != channelInfo.Founder() {
csNotice(rb, client.t("Only the channel founder can do this"))
return return
} }
@ -349,29 +344,35 @@ func csDeopHandler(server *Server, client *Client, command string, params []stri
target = client target = client
} }
// give them privs present, cumodes := channel.ClientStatus(target)
givenMode := modes.ChannelOperator if !present || len(cumodes) == 0 {
if clientAccount == target.Account() { csNotice(rb, client.t("Target has no privileges to remove"))
givenMode = modes.ChannelFounder return
} }
applied, change := channelInfo.applyModeToMember(client,
modes.ModeChange{Mode: givenMode, tnick := target.Nick()
Op: modes.Remove, modeChanges := make(modes.ModeChanges, len(cumodes))
Arg: target.NickCasefolded(), for i, mode := range cumodes {
}, modeChanges[i] = modes.ModeChange{
rb) Mode: mode,
if applied { Op: modes.Remove,
announceCmodeChanges(channelInfo, modes.ModeChanges{change}, chanservMask, "*", "", rb) Arg: tnick,
}
}
// use the user's own permissions for the check, then announce
// the changes as coming from chanserv
applied := channel.ApplyChannelModeChanges(client, false, modeChanges, rb)
details := client.Details()
announceCmodeChanges(channel, applied, details.nickMask, details.accountName, details.account, rb)
if len(applied) == 0 {
return
} }
csNotice(rb, client.t("Successfully removed operator privileges")) csNotice(rb, client.t("Successfully removed operator privileges"))
tnick := target.Nick()
server.logger.Info("services", fmt.Sprintf("Client %s deop'd [%s] in channel %s", client.Nick(), tnick, channelName))
server.snomasks.Send(sno.LocalChannels, fmt.Sprintf(ircfmt.Unescape("Client $c[grey][$r%s$c[grey]] CS deOP'd $c[grey][$r%s$c[grey]] in channel $c[grey][$r%s$c[grey]]"), client.NickMaskString(), tnick, channelName))
} }
func csRegisterHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) { func csRegisterHandler(server *Server, client *Client, command string, params []string, rb *ResponseBuffer) {
if server.Config().Channels.Registration.OperatorOnly && !client.HasRoleCapabs("chanreg") { if server.Config().Channels.Registration.OperatorOnly && !client.HasRoleCapabs("chanreg") {
csNotice(rb, client.t("Channel registration is restricted to server operators")) csNotice(rb, client.t("Channel registration is restricted to server operators"))