mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-08 19:22:53 +01:00
Merge pull request #1340 from slingamn/coerce_ident
replace suppress-ident with coerce-ident; make coerce-ident a recommended default
This commit is contained in:
commit
f019f62167
@ -127,9 +127,10 @@ server:
|
|||||||
# use ident protocol to get usernames
|
# use ident protocol to get usernames
|
||||||
check-ident: true
|
check-ident: true
|
||||||
|
|
||||||
# ignore the supplied user/ident string from the USER command; always set the value to
|
# ignore the supplied user/ident string from the USER command, always setting user/ident
|
||||||
# `~user` (literally) instead. this can potentially reduce confusion and simplify bans.
|
# to the following literal value; this can potentially reduce confusion and simplify bans.
|
||||||
suppress-ident: false
|
# the value must begin with a '~' character. comment out / omit to disable:
|
||||||
|
#coerce-ident: '~u'
|
||||||
|
|
||||||
# password to login to the server
|
# password to login to the server
|
||||||
# generated using "oragono genpasswd"
|
# generated using "oragono genpasswd"
|
||||||
|
@ -154,9 +154,10 @@ server:
|
|||||||
# use ident protocol to get usernames
|
# use ident protocol to get usernames
|
||||||
check-ident: false
|
check-ident: false
|
||||||
|
|
||||||
# ignore the supplied user/ident string from the USER command; always set the value to
|
# ignore the supplied user/ident string from the USER command, always setting user/ident
|
||||||
# `~user` (literally) instead. this can potentially reduce confusion and simplify bans.
|
# to the following literal value; this can potentially reduce confusion and simplify bans.
|
||||||
suppress-ident: false
|
# the value must begin with a '~' character. comment out / omit to disable:
|
||||||
|
coerce-ident: '~u'
|
||||||
|
|
||||||
# password to login to the server
|
# password to login to the server
|
||||||
# generated using "oragono genpasswd"
|
# generated using "oragono genpasswd"
|
||||||
|
@ -416,6 +416,11 @@ func (server *Server) AddAlwaysOnClient(account ClientAccount, chnames []string,
|
|||||||
cloakedHostname = config.Server.Cloaks.ComputeAccountCloak(account.Name)
|
cloakedHostname = config.Server.Cloaks.ComputeAccountCloak(account.Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
username := "~u"
|
||||||
|
if config.Server.CoerceIdent != "" {
|
||||||
|
username = config.Server.CoerceIdent
|
||||||
|
}
|
||||||
|
|
||||||
client := &Client{
|
client := &Client{
|
||||||
lastSeen: lastSeen,
|
lastSeen: lastSeen,
|
||||||
lastActive: now,
|
lastActive: now,
|
||||||
@ -424,7 +429,7 @@ func (server *Server) AddAlwaysOnClient(account ClientAccount, chnames []string,
|
|||||||
languages: server.Languages().Default(),
|
languages: server.Languages().Default(),
|
||||||
server: server,
|
server: server,
|
||||||
|
|
||||||
username: "~user",
|
username: username,
|
||||||
cloakedHostname: cloakedHostname,
|
cloakedHostname: cloakedHostname,
|
||||||
rawHostname: rawHostname,
|
rawHostname: rawHostname,
|
||||||
realIP: utils.IPv4LoopbackAddress,
|
realIP: utils.IPv4LoopbackAddress,
|
||||||
@ -1118,8 +1123,8 @@ func (client *Client) SetNames(username, realname string, fromIdent bool) error
|
|||||||
return errInvalidUsername
|
return errInvalidUsername
|
||||||
}
|
}
|
||||||
|
|
||||||
if config.Server.SuppressIdent {
|
if config.Server.CoerceIdent != "" {
|
||||||
username = "~user"
|
username = config.Server.CoerceIdent
|
||||||
} else if !fromIdent {
|
} else if !fromIdent {
|
||||||
username = "~" + username
|
username = "~" + username
|
||||||
}
|
}
|
||||||
|
@ -507,7 +507,7 @@ type Config struct {
|
|||||||
lookupHostnames bool
|
lookupHostnames bool
|
||||||
ForwardConfirmHostnames bool `yaml:"forward-confirm-hostnames"`
|
ForwardConfirmHostnames bool `yaml:"forward-confirm-hostnames"`
|
||||||
CheckIdent bool `yaml:"check-ident"`
|
CheckIdent bool `yaml:"check-ident"`
|
||||||
SuppressIdent bool `yaml:"suppress-ident"`
|
CoerceIdent string `yaml:"coerce-ident"`
|
||||||
MOTD string
|
MOTD string
|
||||||
motdLines []string
|
motdLines []string
|
||||||
MOTDFormatting bool `yaml:"motd-formatting"`
|
MOTDFormatting bool `yaml:"motd-formatting"`
|
||||||
@ -913,8 +913,16 @@ func LoadConfig(filename string) (config *Config, err error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if config.Server.CheckIdent && config.Server.SuppressIdent {
|
if config.Server.CoerceIdent != "" {
|
||||||
return nil, errors.New("Can't configure both check-ident and suppress-ident")
|
if config.Server.CheckIdent {
|
||||||
|
return nil, errors.New("Can't configure both check-ident and coerce-ident")
|
||||||
|
}
|
||||||
|
if config.Server.CoerceIdent[0] != '~' {
|
||||||
|
return nil, errors.New("coerce-ident value must start with a ~")
|
||||||
|
}
|
||||||
|
if !isIdent(config.Server.CoerceIdent[1:]) {
|
||||||
|
return nil, errors.New("coerce-ident must be valid as an IRC user/ident field")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
config.Server.supportedCaps = caps.NewCompleteSet()
|
config.Server.supportedCaps = caps.NewCompleteSet()
|
||||||
|
Loading…
Reference in New Issue
Block a user