Changelog History
Page 1
-
v2.10.0 Changes
May 29, 2022๐ We're pleased to be publishing v2.10.0, a new stable release.
๐ This release contains no changes to the config file format or database file format.
โ Many thanks to @csmith, @FiskFan1999, @Mikaela, @progval, and @thesamesam for contributing patches, and to @emersion, @eskimo, @FiskFan1999, @jigsy1, @Mikaela, @mogad0n, @progval, and @xnaas for reporting issues and helping test.
Config changes
- ๐ For better interoperability with Goguma, the recommended value of
history.chathistory-maxmessages
has been increased to1000
(previously100
) (#1919)
๐ Changed
- Persistent voice (
AMODE +v
) in a channel is now treated as a permanent invite (i.e. overriding+i
on the channel) (#1901, thanks @eskimo!) - If you are
+R
, sending a direct message to an anonymous user allows them to send you replies (#1687, #1688, thanks @Mikaela and @progval!) - ๐ป
0
is no longer valid as a nickname or account name, with a grandfather exception if it was registered on a previous version of Ergo (#1896) - Implemented the ratified version of the bot mode spec; the tag name is now
bot
instead ofdraft/bot
(#1938) - Privileged WHOX on a user with multiclient shows an arbitrarily chosen client IP address, comparable to WHO (#1897)
SAREGISTER
is allowed even underDEFCON
levels 4 and lower (#1922)- Operators with the
history
capability are now exempted from time cutoff restrictions on history retrieval (#1593, #1955)
โ Added
- โ Added
draft/read-marker
capability, allowing server-side tracking of read messages for synchronization across multiple clients. (#1926, thanks @emersion!) INFO
now includes the server start time (#1895, thanks @xnaas!)- โ Added
ACCEPT
command modeled on Charybdis/Solanum, allowing+R
users to whitelist users who can DM them (#1688, thanks @Mikaela!) - โ Added
NS SAVERIFY
for operators to manually complete an account verification (#1924, #1952, thanks @tacerus!)
๐ Fixed
- ๐ Having the
samode
operator capability made all uses of theKICK
command privileged (i.e. overriding normal channel privilege checks); this has been fixed (#1906, thanks @pcho!) - ๐ Fixed
LIST <n
always returning no results (#1934, thanks @progval and @mitchr!) - NickServ commands are now more clear about when a nickname is unavailable because it was previously registered and unregistered (#1886, thanks @Mikaela!)
- ๐ Fixed KLINE'd clients producing a
QUIT
snotice without a correspondingCONNECT
snotice (#1941, thanks @tacerus, @xnaas!) - ๐ Fixed incorrect handling of long/multiline
319 RPL_WHOISCHANNELS
responses (#1935, thanks @Mikaela!) - ๐ Fixed
LIST
returning403 ERR_NOSUCHCHANNEL
for a nonexistent channel; the correct response is an empty list (#1928, thanks @emersion!) - ๐ Fixed
+s
("secret") channels not appearing inLIST
even when the client is already a member (#1911, #1923, thanks @jigsy1 and @FiskFan1999!) - ๐ Fixed a spurious success message in
HISTSERV DELETE
by always requiring a consistent number of parameters (#1881, #1927, thanks @FiskFan1999!) - ๐ Sending the empty string as a nickname would not always produce the expected error numeric
431 ERR_NONICKNAMEGIVEN
; this has been fixed (#1933, #1936, thanks @kylef!) - ๐
znc.in/playback
timestamps are now parsed as pairs of exact integers, not as floats (#1918)
Internal
- โฌ๏ธ Upgraded to Go 1.18 (#1925)
- โฌ๏ธ Upgraded Alpine version in official Docker image
- ๐ Fixed some issues in the example OpenRC init scripts (#1914, #1920, thanks @thesamesam!)
- ๐ For better interoperability with Goguma, the recommended value of
-
v2.9.1 Changes
January 10, 2021๐ Ergo 2.9.1 is a bugfix release, fixing a regression introduced in 2.9.0. We regret the oversight.
๐ This release includes no changes to the config file format or database format relative to 2.9.0.
Many thanks to @FiskFan1999 for reporting the issue.
๐ Fixed
- ๐ Every use of NS SAREGISTER would fail; this has been fixed (#1898, thanks @FiskFan1999!)
-
v2.9.0 Changes
January 09, 2021๐ We're pleased to be publishing 2.9.0, a new stable release. This release contains mostly bug fixes, with some enhancements to moderation tools.
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading. It includes no changes to the database file format.
โ Many thanks to @erincerys, @FiskFan1999, @mogad0n, and @tacerus for contributing patches, and to @ajaspers, @emersion, @FiskFan1999, @Jobe1986, @kylef, @Mikaela, @mogad0n, @pcho, and @progval for reporting issues and helping test.
Config changes
- โ Added
lock-file
, which helps protect against accidentally starting multiple instances of Ergo. This is a no-op if unset. The recommended default value isircd.lock
, which (like the default datastore pathircd.db
) is relative to the working directory of the Ergo process. If yourdatastore.path
is absolute, this path (if set) should be absolute as well. (#1823) - 0๏ธโฃ
+C
(no channel-wide CTCP messages other than ACTION) is now a recommended default channel mode (#1851) - โ Added
exempt-sasl
boolean toserver.ip-check-script
; if enabled, IP check scripts are run only for connections without SASL, improving performance for registered users (#1888) - 0๏ธโฃ
hidden: true
is now the recommended default for operator definitions (#1730)
๐ Changed
- The semantics of
+R
have been changed.+R
now only prevents unauthenticated users from joining, so unregistered users who have already joined can still speak. The old semantics are still available via+RM
(i.e.+R
together with the+M
"moderated-registered" mode). (#1858, thanks @ajaspers!) - ๐ป Unauthenticated users matching a
+I
invite exception mask can now join+R
channels (#1871) - INVITE now exempts the user from
+b
bans (#1876, thanks @progval!) - NS SUSPEND now only requires only the
ban
operator capability, as opposed toaccreg
(#1828, #1839, thanks @mogad0n!)
โ Added
- ๐จ SHA-256 certificate fingerprints can now be imported from Anope and Atheme (#1864, #1869, thanks @tacerus!)
- ๐ IP check scripts can now be run only for users that have not authenticated with SASL by the end of the handshake, improving performance for registered users (#1888)
- ๐ฒ Logging into an unverified account with SASL sends the new
NOTE AUTHENTICATE VERIFICATION_REQUIRED
standard reply code (#1852, #1853, thanks @emersion!) - CS PURGE now sends a snotice (#1826, thanks @tacerus!)
- The
v
snomask is now used to send notifications about vhost changes initiated by operators (#1844, thanks @pcho!)
๐ Fixed
- ๐ CAP LS and LIST responses after connection registration could be truncated in some cases; this has been fixed (#1872)
- Unprivileged users with both a password and a certfp could not remove their password with
NS PASSWD <password> * *
as expected; this has been fixed (#1883, #1884, thanks @FiskFan1999!) - ๐ RELAYMSG identifiers that were not already in their case-normalized form could not be muted with
+b m:
; this has been fixed (#1838, thanks @mogad0n!) - ๐ CS AMODE changes did not take immediate effect if
force-nick-equals-account
was disabled and the nick did not coincide with the account; this has been fixed (#1860, thanks @eskimo!) 315 RPL_ENDOFWHO
now sends the exact, un-normalized mask argument provided by the client (#1831, thanks @progval!)- A leading
$
character is now disallowed in new nicknames and account names, to avoid collision with the massmessage syntax (#1857, thanks @emersion!) - ๐ The deprecated
o
parameter ofWHO
now returns an empty list of results, instead of being ignored (#1730, thanks @kylef, @emersion, @progval!) - ๐ท WHOX queries for channel oplevel now receive
*
instead of0
(#1866, thanks @Jobe1986!)
Internal
- ๐ Updated list of official release binaries: added Apple M1, OpenBSD x86-64, and Plan 9 x86-64, removed Linux armv7, FreeBSD x86-32, and Windows x86-32. (The removed platforms are still fully supported by Ergo; you can build them from source or ask us for help.) (#1833)
- โ Added an official Linux arm64 Docker image (#1855, thanks @erincerys!)
- โ Added service management files for OpenSolaris/Illumos (#1846, thanks @tacerus!)
- โ Added
-
v2.9.0-rc1 Changes
January 02, 2021๐ We're pleased to be publishing the release candidate for 2.9.0 (the official release should follow in a week or so).
๐ This release contains mostly bug fixes, with some enhancements to moderation tools.
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading. It includes no changes to the database file format.
๐ท Many thanks to @erincerys, @FiskFan1999, @mogad0n, and @tacerus for contributing patches, and to @ajaspers, @emersion, @FiskFan1999, @Jobe1986, @kylef, @mogad0n, @pcho, and @progval for reporting issues,
Config changes
- โ Added
lock-file
, which helps protect against accidentally starting multiple instances of Ergo. This is a no-op if unset. The recommended default value isircd.lock
, which (like the default datastore pathircd.db
) is relative to the working directory of the Ergo process. If yourdatastore.path
is absolute, this path (if set) should be absolute as well. (#1823) - 0๏ธโฃ
+C
(no channel-wide CTCP messages other than ACTION) is now a recommended default channel mode (#1851) - โ Added
exempt-sasl
boolean toserver.ip-check-script
; if enabled, IP check scripts are run only for connections without SASL, improving performance for registered users (#1888) - 0๏ธโฃ
hidden: true
is now the recommended default for operator definitions (#1730)
๐ Changed
- The semantics of
+R
have been changed.+R
now only prevents unauthenticated users from joining, so unregistered users who have already joined can still speak. The old semantics are still available via+RM
(i.e.+R
together with the+M
"moderated-registered" mode). (#1858, thanks @ajaspers!) - ๐ป Unauthenticated users matching a
+I
invite exception mask can now join+R
channels (#1871) - INVITE now exempts the user from
+b
bans (#1876, thanks @progval!) - NS SUSPEND now only requires only the
ban
operator capability, as opposed toaccreg
(#1828, #1839, thanks @mogad0n!)
โ Added
- ๐จ SHA-256 certificate fingerprints can now be imported from Anope and Atheme (#1864, #1869, thanks @tacerus!)
- ๐ IP check scripts can now be run only for users that have not authenticated with SASL by the end of the handshake, improving performance for registered users (#1888)
- ๐ฒ Logging into an unverified account with SASL sends the new
NOTE AUTHENTICATE VERIFICATION_REQUIRED
standard reply code (#1852, #1853, thanks @emersion!) - CS PURGE now sends a snotice (#1826, thanks @tacerus!)
- The
v
snomask is now used to send notifications about vhost changes initiated by operators (#1844, thanks @pcho!)
๐ Fixed
- ๐ CAP LS and LIST responses after connection registration could be truncated in some cases; this has been fixed (#1872)
- Unprivileged users with both a password and a certfp could not remove their password with
NS PASSWD <password> * *
as expected; this has been fixed (#1883, #1884, thanks @FiskFan1999!) - ๐ RELAYMSG identifiers that were not already in their case-normalized form could not be muted with
+b m:
; this has been fixed (#1838, thanks @mogad0n!) - ๐ CS AMODE changes did not take immediate effect if
force-nick-equals-account
was disabled and the nick did not coincide with the account; this has been fixed (#1860, thanks @eskimo!) 315 RPL_ENDOFWHO
now sends the exact, un-normalized mask argument provided by the client (#1831, thanks @progval!)- A leading
$
character is now disallowed in new nicknames and account names, to avoid collision with the massmessage syntax (#1857, thanks @emersion!) - ๐ The deprecated
o
parameter ofWHO
now returns an empty list of results, instead of being ignored (#1730, thanks @kylef, @emersion, @progval!) - ๐ท WHOX queries for channel oplevel now receive
*
instead of0
(#1866, thanks @Jobe1986!)
Internal
- ๐ Updated list of official release binaries: added Apple M1, OpenBSD x86-64, and Plan 9 x86-64, removed Linux armv7, FreeBSD x86-32, and Windows x86-32. (The removed platforms are still fully supported by Ergo; you can build them from source or ask us for help.) (#1833)
- โ Added an official Linux arm64 Docker image (#1855, thanks @erincerys!)
- โ Added service management files for OpenSolaris/Illumos (#1846, thanks @tacerus!)
- โ Added
-
v2.8.0 Changes
November 14, 2021๐ We're pleased to be publishing Ergo 2.8.0. This release contains many fixes and enhancements, plus one major user-facing feature: user-initiated password resets via e-mail (#734).
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading.
๐ This release includes a database change. If you have
datastore.autoupgrade
set totrue
in your configuration, it will be automatically applied when you restart Ergo. Otherwise, you can update the database manually by runningergo upgradedb
(see the manual for complete instructions).๐ As part of this release, our official Docker images have moved from Docker Hub to the GitHub Container Registry, at
ghcr.io/ergochat/ergo
. Thestable
andmaster
tags correspond to the respective branches. Tagged releases (e.g.v2.8.0
) are available under the corresponding named tags.๐ Many thanks to @ajaspers, @delthas, @mogad0n, @majiru, @ProgVal, and @tacerus for contributing patches, to @ajaspers for contributing code review, to @ajaspers, @cxxboy, @dallemon, @emersion, @erikh, @eskimo, @jwheare, @kylef, @Mikaela, @mogad0n, @MystaraTheGreat, @ProgVal, @tacerus, @tamiko, and @xnaas for reporting issues and helping test, and to our translators for contributing translations.
Config changes
- โ Added
accounts.registration.email-verification.password-reset
block to configure e-mail-based password reset (#734, #1779) - โ Added
accounts.registration.email-verification.timeout
to impose a timeout on e-mail sending; the recommended default value is60s
(60 seconds) (#1741) - โ Added
server.suppress-lusers
to allow hiding the LUSERS counts (#1802, thanks @eskimo!)
๐ Security
- โ Added
accounts.registration.email-verification.timeout
to impose a timeout on e-mail sending; the recommended default value is60s
(60 seconds) (#1741)
โ Added
- โ Added user-initiated password resets via email (#734). This requires e-mail verification of accounts, and must additionally be enabled explicitly: see the
email-verification
block indefault.yaml
for more information. - โ Added the
draft/extended-monitor
capability (#1761, thanks @delthas!) - When doing direct sending of verification emails, make email delivery failures directly visible to the end user (#1659, #1741, thanks @tacerus!)
- For operators,
NS INFO
now shows the user's email address (you can also view your own address) (#1677, thanks @ajaspers!) - ๐ Operators with the appropriate permissions will now see IPs in
/WHOWAS
output (#1702, thanks @ajaspers!) - โ Added the
+s d
snomask, for operators to receive information about session disconnections that do not result in a full QUIT (#1709, #1728, thanks @mogad0n!) - โ Added support for the
SCRAM-SHA-256
SASL authentication mechanism (#175). This mechanism is not currently advertised inCAP LS
output because IRCCloud handles it incorrectly. We also recommend against using SCRAM because of its lack of genuine security benefits. /UBAN LIST
output now includes the time the ban was created (#1725, #1755, thanks @Mikaela and @mogad0n!)- โ Added support for running as a
Type=notify
systemd service (#1733) - โ Added a warning to help users detect incorrect uses of
/QUOTE
(#1530)
๐ Fixed
- ๐ The
+M
(only registered users can speak) channel mode did not work; this has been fixed (#1696, thanks @Mikaela!) - ๐ A channel
/RENAME
that only changed the case of the channel would delete the channel registration; this has been fixed (#1751, thanks @Mikaela!) - ๐ Fixed
allow-truncation: true
not actually allowing truncation of overlong lines (#1766, thanks @tacerus!) - ๐ Fixed several pagination bugs in
CHATHISTORY
(#1676, thanks @emersion!) - ๐ Fixed support for kicking multiple users from a channel on the same line, the
TARGMAX
005 parameter that advertises this, and the default kick message (#1748, #1777, #1776), thanks @ProgVal!) - ๐ Fixed
/SAMODE
on a channel not producing a snomask (#1787, thanks @mogad0n, @ajaspers!) - โ Adding
+f
to a channel withSAMODE
used to require channel operator privileges on the receiving channel; this has been fixed (#1825, thanks @Mikaela!) - Fixed parameters sent with
697 ERR_LISTMODEALREADYSET
and698 ERR_LISTMODENOTSET
(#1727, thanks @kylef!) - ๐ Fixed parameter sent with
696 ERR_INVALIDMODEPARAM
(#1773, thanks @kylef!) - ๐ Fixed handling of channel mode
+k
with an empty parameter (#1774, #1775, thanks @ProgVal!) WHOWAS
with an empty string as the parameter now produces an appropriate error response (#1703, thanks @kylef!)- ๐ Fixed error response to an empty realname on the
USER
line (#1778, thanks @ProgVal!) - ๐ Fixed
/UBAN ADD
of a NUH mask (i.e. a k-line) not killing affected clients (#1736, thanks @mogad0n!) - ๐ Fixed buggy behavior when
+i
is configured as a default mode for channels (#1756, thanks @Mikaela!) - ๐ Fixed issues with
channels.operator-only-creation
not respecting/SAJOIN
or always-on clients (#1757) - Protocol-breaking operator vhosts are now disallowed during config validation (#1722)
- ๐ Fixed error message associated with
/NS PASSWD
on a nonexistent account (#1738, thanks @Mikaela!) - ๐ Fixed an incorrect
CHATHISTORY
fail message (#1731, thanks @ProgVal!) - ๐ Fixed a panic on an invalid configuration case (#1714, thanks @erikh!)
๐ Changed
- โฌ๏ธ Upgraded the
draft/register
capability to the latestdraft/account-registration
iteration (#1740) - Unregistered users with
+v
or higher can now speak in+R
(registered-only) channels (#1715, thanks @Mikaela and @ajaspers!) - For always-on clients with at least one active connection,
338 RPL_WHOISACTUALLY
now displays an arbitrarily chosen client IP address (#1650, thanks @MystaraTheGreat!) #
can no longer be used in new account names and nicknames, or as the RELAYMSG separator (#1679)- The
oragono.io/nope
capability was renamed toergo.chat/nope
(#1793)
โ Removed
- โช
never
is no longer accepted as a value of thereplay-joins
NickServ setting (/NS SET replay-joins
); user accounts which enabled this setting have been reverted to the default value ofcommands-only
(#1676)
Internal
- We have a cool new logo!
- ๐ Official builds now use Go 1.17 (#1781)
- ๐ณ Official Docker containers are now at ghcr.io/ergochat/ergo (#1808)
- โ Added a traditional SysV init script (#1691, thanks @tacerus!)
- โ Added an s6 init script (#1786, thanks @majiru!)
- โ Added
-
v2.7.0 Changes
June 07, 2021๐ We're pleased to be publishing Ergo 2.7.0, our first official release under our new name of Ergo. This release contains bug fixes and minor enhancements.
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading. This release includes no changes to the database format.
โก๏ธ Because the name of the executable has changed from
oragono
toergo
(ergo.exe
on Windows), you may need to update your system configuration (e.g., scripts or systemd unit files that reference the executable).๐ Many thanks to @ajaspers and @jesopo for contributing patches, to @ajaspers, @ChrisTX, @emersion, @jwheare, @kylef, @Mikaela, @mogad0n, and @ProgVal for reporting issues and helping test, and to our translators for contributing translations.
๐ Changed
- ๐ The project was renamed from "Oragono" to "Ergo" (#897, thanks to everyone who contributed feedback or voted in the poll)
Config changes
- 0๏ธโฃ Entries in
server.listeners
now take a new key,min-tls-version
, that can be used to set the minimum required TLS version; the recommended default value is1.2
(#1611, thanks @ChrisTX!) - โ Added
max-conns
(maximum connection count) andmax-conn-lifetime
(maximum lifetime of a connection before it is cycled) todatastore.mysql
(#1622) - โ Added
massmessage
operator capability to allow sending NOTICEs to all connected users (#1153, #1629, thanks @jesopo!)
๐ Security
- If
require-sasl.enabled
is set totrue
,tor-listeners.require-sasl
will be automatically set totrue
as well (#1636) - ๐ง It is now possible to set the minimum required TLS version, using the
min-tls-version
key in listener configuration - ๐ง Configurations that require SASL but allow user registration now produce a warning (#1637)
โ Added:
- Operators with the correct permissions can now send "mass messages", e.g.
/NOTICE $$*
will send aNOTICE
to all users (#1153, #1629, thanks @jesopo!) - ๐ Operators can now extend the maximum (non-tags) length of the IRC line using the
server.max-line-len
configuration key. This is not recommended for use outside of "closed-circuit" deployments where IRC operators have full control of all client software. (#1651)
๐ Fixed
RELAYMSG
now sends a full NUH ("nick-user-host"), instead of only the relay nickname, as the message source (#1647, thanks @ProgVal, @jwheare, and @Mikaela!)- ๐ Fixed a case where channels would remain visible in
/LIST
after unregistration (#1619, thanks @ajaspers!) - ๐ Fixed incorrect tags on
JOIN
lines in+u
("auditorium") channels (#1642) - ๐ Fixed an issue where LUSERS counts could get out of sync (#1617)
- ๐ It was impossible to add a restricted set of snomasks to an operator's permissions; this has been fixed (#1618)
- ๐ Fixed incorrect language in
NS INFO
responses (#1627, thanks @ajaspers!) - ๐ Fixed a case where the
REGISTER
command would emit an invalid error message (#1633, thanks @ajaspers!) - ๐ Fixed snomasks displaying in a nondeterministic order (#1669, thanks @Mikaela!)
โ Removed
- โ Removed the
draft/resume-0.5
capability, and the associatedRESUME
andBRB
commands (#1624)
Internal
- โก๏ธ Optimized MySQL storage of direct messages (#1615)
-
v2.7.0-rc1 Changes
May 30, 2021๐ We're pleased to be publishing Ergo 2.7.0-rc1, our first release candidate under our new name of Ergo. This release contains bug fixes and minor enhancements.
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading. This release includes no changes to the database format.
โก๏ธ Because the name of the executable has changed from
oragono
toergo
(ergo.exe
on Windows), you may need to update your system configuration (e.g., scripts or systemd unit files that reference the executable).๐ Many thanks to @ajaspers and @jesopo for contributing patches, to @ajaspers, @ChrisTX, @emersion, @jwheare, @kylef, @Mikaela, @mogad0n, and @ProgVal for reporting issues and helping test, and to our translators for contributing translations.
๐ Changed
- ๐ The project was renamed from "Oragono" to "Ergo" (#897, thanks to everyone who contributed feedback or voted in the poll)
Config changes
- 0๏ธโฃ Entries in
server.listeners
now take a new key,min-tls-version
, that can be used to set the minimum required TLS version; the recommended default value is1.2
(#1611, thanks @ChrisTX!) - โ Added
max-conns
(maximum connection count) andmax-conn-lifetime
(maximum lifetime of a connection before it is cycled) todatastore.mysql
(#1622) - โ Added
massmessage
operator capability to allow sending NOTICEs to all connected users (#1153, #1629, thanks @jesopo!)
๐ Security
- If
require-sasl.enabled
is set totrue
,tor-listeners.require-sasl
will be automatically set totrue
as well (#1636) - ๐ง It is now possible to set the minimum required TLS version, using the
min-tls-version
key in listener configuration - ๐ง Configurations that require SASL but allow user registration now produce a warning (#1637)
โ Added:
- Operators with the correct permissions can now send "mass messages", e.g.
/NOTICE $$*
will send aNOTICE
to all users (#1153, #1629, thanks @jesopo!) - ๐ Operators can now extend the maximum (non-tags) length of the IRC line using the
server.max-line-len
configuration key. This is not recommended for use outside of "closed-circuit" deployments where IRC operators have full control of all client software. (#1651)
๐ Fixed
RELAYMSG
now sends a full NUH ("nick-user-host"), instead of only the relay nickname, as the message source (#1647, thanks @ProgVal, @jwheare, and @Mikaela!)- ๐ Fixed a case where channels would remain visible in
/LIST
after unregistration (#1619, thanks @ajaspers!) - ๐ Fixed incorrect tags on
JOIN
lines in+u
("auditorium") channels (#1642) - ๐ Fixed an issue where LUSERS counts could get out of sync (#1617)
- ๐ It was impossible to add a restricted set of snomasks to an operator's permissions; this has been fixed (#1618)
- ๐ Fixed incorrect language in
NS INFO
responses (#1627, thanks @ajaspers!) - ๐ Fixed a case where the
REGISTER
command would emit an invalid error message (#1633, thanks @ajaspers!) - ๐ Fixed snomasks displaying in a nondeterministic order (#1669, thanks @Mikaela!)
โ Removed
- โ Removed the
draft/resume-0.5
capability, and the associatedRESUME
andBRB
commands (#1624)
Internal
- โก๏ธ Optimized MySQL storage of direct messages (#1615)
-
v2.6.1 Changes
April 26, 2021๐ Oragono 2.6.1 is a bugfix release, fixing a security issue that is critical for some private server configurations. We regret the oversight.
๐ง The issue affects two classes of server configuration:
โฌ๏ธ 1. Private servers that use
server.password
(i.e., thePASS
command) for protection. Ifaccounts.registration.allow-before-connect
is enabled, theREGISTER
command can be used to bypass authentication. Affected operators should set this field tofalse
, or upgrade to 2.6.1, which disallows the insecure configuration. (If the field does not appear in the configuration file, the configuration is secure since the value defaults to false when unset.) ๐ง 2. Private servers that useaccounts.require-sasl
for protection. If these servers do not additionally setaccounts.registration.enabled
tofalse
, theREGISTER
command can potentially be used to bypass authentication. Affected operators should setaccounts.registration.enabled
to false; this recommendation appeared in the operator manual but was not emphasized sufficiently. (Configurations that require SASL but allow open registration are potentially valid, e.g., in the case of public servers that require everyone to use a registered account; accordingly, Oragono 2.6.1 continues to permit such configurations.)๐ This release includes no changes to the config file format or the database.
Many thanks to @ajaspers for reporting the issue.
๐ Security
- ๐ Fixed and documented potential authentication bypasses via the
REGISTER
command (#1634, thanks @ajaspers!)
- ๐ Fixed and documented potential authentication bypasses via the
-
v2.6.0 Changes
April 18, 2021๐ We're pleased to announce Oragono 2.6.0, a new stable release.
๐ This release has some user-facing enhancements, but is primarily focused on fixing bugs and advancing the state of IRCv3 standardization (by publishing a release that implements the latest drafts). Some highlights:
- A new CHATHISTORY API for listing direct message conversations (#1592)
- โ The latest proposal for IRC-over-websockets, which should be backwards-compatible with existing clients (#1558)
- โ
The latest specification for the bot usermode (
+B
in our implementation) (#1562)
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading.
๐ This release includes no changes to the embedded database format. If you are using MySQL for history storage, it adds a new table; this change is backwards and forwards-compatible and does not require any manual intervention.
If you are using nginx as a reverse proxy for IRC-over-websockets, previous documentation did not recommend increasing
proxy_read_timeout
; the default value of60s
is too low and can lead to user disconnections. The current recommended value isproxy_read_timeout 600s;
; see the manual for an example configuration.๐ Many thanks to @ajaspers and @Mikaela for contributing patches, to @aster1sk, @emersion, @eskimo, @hhirtz, @jlu5, @jwheare, @KoraggKnightWolf, @kylef, @Mikaela, @mogad0n, @ProgVal, and @szlend for reporting issues and helping test, and to our translators for contributing translations.
Config changes
- ๐ Listeners now support multiple TLS certificates for use with SNI; see the manual for details (#875, thanks @Mikaela!)
- โ Added
server.compatibility.allow-truncation
, controlling whether the server accepts messages that are too long to be relayed intact; this value defaults totrue
when unset (#1577, #1586, thanks @kylef!) - โ Added new
snomasks
operator capability; operators must have either theban
orsnomasks
capability to subscribe to additional snomasks (#1176)
๐ Security
- ๐ Fixed several edge cases where Oragono might relay invalid UTF8 despite the
UTF8ONLY
guarantee, or to a text-mode websocket client (#1575, #1596, thanks @ProgVal!) - All operator privilege checks now use the capabilities system, making it easier to define operators with restricted powers (#1176)
- โ Adding and removing bans with
UBAN
now produces snomasks and audit loglines (#1518, thanks @mogad0n!)
๐ Fixed
- ๐ Fixed an edge case in line buffering that could result in client disconnections (#1572, thanks @ProgVal!)
- โฌ๏ธ Upgraded buntdb, our embedded database library, fixing an edge case that could cause data corruption (#1603, thanks @Mikaela, @tidwall!)
- ๐ Improved compatibility with the published
draft/register
specification (#1568, thanks @ProgVal!) 433 ERR_NICKNAMEINUSE
is no longer sent when a fully connected ("registered") client fails to claim a reserved nickname, fixing a bad interaction with some client software (#1594, thanks @ProgVal!)- ๐ Fixed
znc.in/playback
commands causing client disconnections when history is disabled (#1552, thanks @szlend!) - ๐ Fixed syntactically invalid
696 ERR_INVALIDMODEPARAM
response for invalid channel keys (#1563, thanks @ProgVal!) - ๐ User-set nickserv settings now display as "enabled" instead of "mandatory" (#1544, thanks @Mikaela!)
- ๐ Improved error messages for some invalid configuration cases (#1559, thanks @aster1sk!)
- ๐ Improved
CS TRANSFER
error messages (#1534, thanks burning!) - ๐ Handle panics caused when rehashing with SIGHUP (#1570)
๐ Changed
- Registered channels will always appear in
/LIST
output, even with no members (#1507) - ๐ง In the new recommended default configuration, Oragono will preemptively reject messages that are too long to be relayed to clients without truncation. This is controlled by the config variable
server.compatibility.allow-truncation
; this field defaults totrue
when unset, preserving the legacy behavior for older config files (#1577, #1586, thanks @kylef!) - Auto-away behavior now respects individual clients; the user is not considered away unless all clients are away or disconnected (#1531, thanks @kylef!)
- Direct messages rejected due to the
+R
registered-only usermode now produce an error message (#1064, thanks @KoraggKnightWolf, @ajaspers!) - RELAYMSG identifiers now respect bans and mutes (#1502)
- If end user message deletion is enabled, channel operators can now delete channel messages (#1565, thanks @Mikaela!)
- Halfops can change the channel topic (#1523)
- ๐ Snomask add/remove syntax now matches other ircds more closely (#1074)
- ๐
CS OP
will regrant your channelAMODE
, in case you removed it (#1516, #1307, thanks @jlu5!) - ๐ User passwords may no longer begin with
:
(#1571) - ๐ Improved documentation of
CS AMODE
andNS UNREGISTER
(#1524, #1545, thanks @Mikaela!) - Disabling history disables history-related CAPs (#1549)
โ Added
- Implemented the new CHATHISTORY TARGETS API for listing direct message conversations (#1592, thanks @emersion, @hhirtz, @jwheare, @kylef!)
- ๐ Implemented the new IRC-over-websockets draft, adding support for binary websockets and subprotocol negotiation (#1558, thanks @jwheare!)
- Implemented the new bot mode spec (#1562)
- Implemented the new forward mode spec (#1612, thanks @ProgVal!)
WARN NICK ACCOUNT_REQUIRED
is sent on failed attempts to claim a reserved nickname (#1594)NS CLIENTS LIST
displays enabled client capabilities (#1576)CS INFO
with no arguments lists your registered channels (#765)NS PASSWORD
is now accepted as an alias forNS PASSWD
(#1547)
Internal
- โฌ๏ธ Upgraded to Go 1.16 (#1510)
-
v2.6.0-rc1 Changes
April 11, 2021๐ We're pleased to be publishing the release candidate for 2.6.0 (the official release should follow in a week or so).
๐ This release has some user-facing enhancements, but is primarily focused on fixing bugs and advancing the state of IRCv3 standardization (by publishing a release that implements the latest drafts). Some highlights:
- A new CHATHISTORY API for listing direct message conversations (#1592)
- โ The latest proposal for IRC-over-websockets, which should be backwards-compatible with existing clients (#1558)
- โ
The latest specification for the bot usermode (
+B
in our implementation) (#1562)
๐ This release includes changes to the config file format, all of which are fully backwards-compatible and do not require updating the file before upgrading.
๐ This release includes no changes to the embedded database format. If you are using MySQL for history storage, it adds a new table; this change is backwards and forwards-compatible and does not require any manual intervention.
If you are using nginx as a reverse proxy for IRC-over-websockets, previous documentation did not recommend increasing
proxy_read_timeout
; the default value of60s
is too low and can lead to user disconnections. The current recommended value isproxy_read_timeout 600s;
; see the manual for an example configuration.๐ Many thanks to @ajaspers and @Mikaela for contributing patches, to @aster1sk, @emersion, @eskimo, @hhirtz, @jlu5, @jwheare, @KoraggKnightWolf, @kylef, @Mikaela, @mogad0n, @ProgVal, and @szlend for reporting issues and helping test, and to our translators for contributing translations.
Config changes
- ๐ Listeners now support multiple TLS certificates for use with SNI; see the manual for details (#875, thanks @Mikaela!)
- โ Added
server.compatibility.allow-truncation
, controlling whether the server accepts messages that are too long to be relayed intact; this value defaults totrue
when unset (#1596, thanks @kylef!) - โ Added new
snomasks
operator capability; operators must have either theban
orsnomasks
capability to subscribe to additional snomasks (#1176)
๐ Security
- ๐ Fixed several edge cases where Oragono might relay invalid UTF8 despite the
UTF8ONLY
guarantee, or to a text-mode websocket client (#1575, #1596, thanks @ProgVal!) - All operator privilege checks now use the capabilities system, making it easier to define operators with restricted powers (#1176)
- โ Adding and removing bans with
UBAN
now produces snomasks and audit loglines (#1518, thanks @mogad0n!)
๐ Fixed
- ๐ Fixed an edge case in line buffering that could result in client disconnections (#1572, thanks @ProgVal!)
- โฌ๏ธ Upgraded buntdb, our embedded database library, fixing an edge case that could cause data corruption (#1603, thanks @Mikaela, @tidwall!)
- ๐ Improved compatibility with the published
draft/register
specification (#1568, thanks @ProgVal!) 433 ERR_NICKNAMEINUSE
is no longer sent when a fully connected ("registered") client fails to claim a reserved nickname, fixing a bad interaction with some client software (#1594, thanks @ProgVal!)- ๐ Fixed
znc.in/playback
commands causing client disconnections when history is disabled (#1552, thanks @szlend!) - ๐ Fixed syntactically invalid
696 ERR_INVALIDMODEPARAM
response for invalid channel keys (#1563, thanks @ProgVal!) - ๐ User-set nickserv settings now display as "enabled" instead of "mandatory" (#1544, thanks @Mikaela!)
- ๐ Improved error messages for some invalid configuration cases (#1559, thanks @aster1sk!)
- ๐ Improved
CS TRANSFER
error messages (#1534, thanks burning!) - ๐ Handle panics caused when rehashing with SIGHUP (#1570)
๐ Changed
- Registered channels will always appear in
/LIST
output, even with no members (#1507) - ๐ง In the new recommended default configuration, Oragono will preemptively reject messages that are too long to be relayed to clients without truncation. This is controlled by the config variable
server.compatibility.allow-truncation
; this field defaults totrue
when unset, preserving the legacy behavior for older config files (#1577, #1586, thanks @kylef!) - Auto-away behavior now respects individual clients; the user is not considered away unless all clients are away or disconnected (#1531, thanks @kylef!)
- Direct messages rejected due to the
+R
registered-only usermode now produce an error message (#1064, thanks @KoraggKnightWolf, @ajaspers!) - RELAYMSG identifiers now respect bans and mutes (#1502)
- If end user message deletion is enabled, channel operators can now delete channel messages (#1565, thanks @Mikaela!)
- Halfops can change the channel topic (#1523)
- ๐ Snomask add/remove syntax now matches other ircds more closely (#1074)
- ๐
CS OP
will regrant your channelAMODE
, in case you removed it (#1516, #1307, thanks @jlu5!) - ๐ User passwords may no longer begin with
:
(#1571) - ๐ Improved documentation of
CS AMODE
andNS UNREGISTER
(#1524, #1545, thanks @Mikaela!) - Disabling history disables history-related CAPs (#1549)
โ Added
- Implemented the new CHATHISTORY TARGETS API for listing direct message conversations (#1592, thanks @emersion, @hhirtz, @jwheare, @kylef!)
- ๐ Implemented the new IRC-over-websockets draft, adding support for binary websockets and subprotocol negotiation (#1558, thanks @jwheare!)
- Implemented the new bot mode spec (#1562)
- Implemented the new forward mode spec (#1612, thanks @ProgVal!)
WARN NICK ACCOUNT_REQUIRED
is sent on failed attempts to claim a reserved nickname (#1594)NS CLIENTS LIST
displays enabled client capabilities (#1576)CS INFO
with no arguments lists your registered channels (#765)NS PASSWORD
is now accepted as an alias forNS PASSWD
(#1547)
Internal
- โฌ๏ธ Upgraded to Go 1.16 (#1510)