https://twitter.com/nluedtke1/status/1469435658389561345
It appears some configurations of log4j 1.x are vulnerable - is cyberduck using one of them?
CD seems to be using a really old version (1.2.17) https://github.com/iterate-ch/cyberduck/blob/e4c2dfe5c1e5623a5bfc484ae3f4ae58a1e929f1/pom.xml#L198 that has other security issues https://www.cvedetails.com/cve/CVE-2019-17571/
As said we do not have a dependency for Apache Log4j 2. Also as a client side desktop application it does not seem relevant.
@dkocher Where was this discussed before? I searched but didn't find.
CD depends on log4J 1, not 2, but 1 seems to also be affected https://twitter.com/nluedtke1/status/1469435658389561345
Even as a client side app, maybe you connect to a server that has files with $ escapes that you log and run.
@dkocher log4j shows up in your pom.xml - so something appears to be using it?
I also see a config file for it - https://github.com/iterate-ch/cyberduck/blob/fa0aa0d5d7b07ec09a4c328b2c0cf9a56bf01c4d/core/src/main/resources/log4j.xml
As well as references to it in your code- https://github.com/iterate-ch/cyberduck/blob/745598c7f84e48b21d7b7b6679db926d5d6e98e4/core/src/main/java/ch/cyberduck/core/logging/LoggerPrintStream.java#L19
It makes sense to eventually move away/upgrade from Log4j 1.x but I see no immediate urgency in this dependency upgrade. I do not see that CVE-2019-17571 would affect us as from my understanding this usage would need to be explicitly configured.
CVE-2019-17571 is related to log4j versions >= 1.2, <= 1.2.27. In the Cyberduck package, I find log4j-1.2.17. Why does that not affect Cyberduck, even though the version of log4j is affected?
Because that vulnerability only affects the log4j SocketServer which, when used to centrally log from remote clients, can execute arbitrary code. Cyberduck isn鈥檛 providing a central logging target so isn鈥檛 affected.
when listening to untrusted network traffic for log data
Since log4j 1 is out of support, vulnerabilities aren't tracked and we have to assume that it's unsafe.
Since log4j 1 is out of support, vulnerabilities aren't tracked and we have to assume that it's unsafe.
Log4j 1.x does not feature the JNDI functionality that caused CVE-2021-44228
But it may have other undocumented issues.
But it may have other undocumented issues.
Like any software.
log4j maintainers only document and fix issues on supported versions. Using log4j 1 is like using Windows XP: you don't even know the ways you could get attacked.
There are already quite a number of (large) companies that do not allow any old (vulnerable) log4j libraries on employees laptops. Without a proper version of log4j, cyberduck is not working anymore since the library is automatically removed from company devices.
There are already quite a number of (large) companies that do not allow any old (vulnerable) log4j libraries on employees laptops. Without a proper version of log4j, cyberduck is not working anymore since the library is automatically removed from company devices.
I have opened #12706.
Most helpful comment
I have opened #12706.