Page MenuHomePhabricator

Normalize remote IP addresses when writing to logs, etc
ClosedPublic

Authored by epriestley on Dec 5 2016, 6:34 PM.
Tags
None
Referenced Files
F18670137: D16987.diff
Wed, Sep 24, 11:12 PM
F18508346: D16987.id.diff
Sep 5 2025, 2:46 AM
F18161302: D16987.id40867.diff
Aug 15 2025, 2:57 AM
F18081183: D16987.id40872.diff
Aug 4 2025, 10:53 PM
F17752086: D16987.diff
Jul 22 2025, 6:29 AM
F17752040: D16987.diff
Jul 22 2025, 6:25 AM
F17718775: D16987.diff
Jul 18 2025, 2:26 AM
Unknown Object (File)
Jun 18 2025, 12:16 PM
Subscribers
None

Details

Summary

Ref T11939. IPv4 addresses can normally only be written in one way, but IPv6 addresses have several formats.

For example, the addresses "FFF::", "FfF::", "fff::", "0ffF::", "0fFf:0::", and "0FfF:0:0:0:0:0:0:0" are all the same address.

Normalize all addresses before writing them to logs, etc, so we store the most-preferred form ("fff::", above).

Test Plan

Ran an SSH clone over IPv6:

$ git fetch ssh://local@::1/diffusion/26/locktopia.git

It worked; verified that address read out of SSH_CLIENT sensibly.

Faked my remote address as a non-preferred-form IPv6 address using preamble.php.

Failed to login, verified that the preferred-form version of the address appeared in the user activity log.

Made IPv6 requests over HTTP:

$ curl -H "Host: local.phacility.com" "http://[::1]/"

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Normalize remote IP addresses when writing to logs, etc.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: chad.
chad edited edge metadata.
This revision is now accepted and ready to land.Dec 5 2016, 6:40 PM
This revision was automatically updated to reflect the committed changes.