{"affected":[{"ranges":[{"events":[{"introduced":"7a08c5507862a7011568506d0c17b1fdef30bee4"},{"fixed":"0209a6df65d605552b378273027b3968b35f26b4"}],"repo":"https://github.com/erlang/otp","type":"GIT"}]}],"aliases":["GHSA-gp7x-mfv6-52cv","CVE-2026-48860"],"credits":[{"name":"Lukas Backström","type":"FINDER"},{"name":"Ingela Anderton Andin","type":"REMEDIATION_DEVELOPER"},{"name":"Raimo Niskanen","type":"REMEDIATION_REVIEWER"},{"name":"Jakub Witczak","type":"REMEDIATION_REVIEWER"}],"database_specific":{"capec_ids":["CAPEC-1","CAPEC-115"],"cpe_ids":["cpe:2.3:a:erlang:erlang\\/otp:*:*:*:*:*:*:*:*"],"cwe_ids":["CWE-1025","CWE-863"]},"details":"## Summary\n\nReliance on IP Address for Authentication vulnerability in Erlang/OTP ssl (inet\\_tls\\_dist module) allows unauthenticated bypass of the distribution-over-TLS LAN allowlist.\n\nThe inet\\_tls\\_dist:check\\_ip/1 function, which enforces a LAN allowlist for Erlang distribution over TLS, calls inet:sockname/1 instead of inet:peername/1 to obtain the peer's IP address. Because inet:sockname/1 returns the local socket address, both the local IP and the supposed peer IP resolve to the same value, causing the subnet mask comparison to always succeed regardless of the actual remote address. Any holder of a CA-signed TLS certificate can therefore bypass the LAN restriction and gain full Erlang distribution access to the node, including rpc:call/4 and code:load\\_binary/3.\n\nThis vulnerability is associated with program file lib/ssl/src/inet\\_tls\\_dist.erl.\n\nThis issue affects OTP from OTP 26.0 before 29.0.2, 28.5.0.2 and 27.3.4.13 corresponding to ssl from 11.0 before 11.7.2, 11.6.0.2 and 11.2.12.9.\n\n## Workaround\n\nImplement a custom verify\\_fun SSL option that correctly checks the peer IP address using inet:peername/1 on the socket.\n\n## Configuration\n\nThe Erlang distribution must be configured to use TLS (inet\\_tls\\_dist) with the check\\_ip option enabled. The default Erlang distribution configuration does not use TLS and is not affected.","id":"EEF-CVE-2026-48860","modified":"2026-06-10T14:38:27.035Z","published":"2026-06-10T14:35:49.987Z","references":[{"type":"ADVISORY","url":"https://github.com/erlang/otp/security/advisories/GHSA-gp7x-mfv6-52cv"},{"type":"WEB","url":"https://cna.erlef.org/cves/CVE-2026-48860.html"},{"type":"WEB","url":"https://www.erlang.org/doc/system/versions.html#order-of-versions"},{"type":"FIX","url":"https://github.com/erlang/otp/commit/0209a6df65d605552b378273027b3968b35f26b4"}],"related":[],"schema_version":"1.7.3","severity":[{"score":"CVSS:4.0/AV:A/AC:H/AT:P/PR:L/UI:N/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N","type":"CVSS_V4"}],"summary":"Distribution-over-TLS LAN allowlist silently bypassed due to sockname/peername confusion in inet_tls_dist","upstream":[]}