2021-08-17 13:30:18 -05:00
|
|
|
# Forked IP address parsing functions
|
|
|
|
|
|
|
|
This directory contains a subset of code from the Go project's `net` package
|
|
|
|
as of Go 1.16, used under the Go project license which we've included here
|
|
|
|
in [`LICENSE`](LICENSE) and [`PATENTS`](PATENTS), which are also copied from
|
|
|
|
the Go project.
|
|
|
|
|
2023-09-20 07:43:06 -05:00
|
|
|
OpenTofu has its own fork of these functions because Go 1.17 included a
|
2021-08-17 13:30:18 -05:00
|
|
|
breaking change to reject IPv4 address octets written with leading zeros.
|
|
|
|
|
|
|
|
The Go project rationale for that change was that Go historically interpreted
|
|
|
|
leading-zero octets inconsistently with many other implementations, trimming
|
|
|
|
off the zeros and still treating the rest as decimal rather than treating the
|
|
|
|
octet as octal.
|
|
|
|
|
|
|
|
The Go team made the reasonable observation that having a function that
|
|
|
|
interprets a non-normalized form in a manner inconsistent with other
|
|
|
|
implementations may cause naive validation or policy checks to produce
|
|
|
|
incorrect results, and thus it's a potential security concern. For more
|
|
|
|
information, see [Go issue #30999](https://golang.org/issue/30999).
|
|
|
|
|
2023-09-20 07:43:06 -05:00
|
|
|
After careful consideration, it was concluded that OpenTofu's
|
2023-08-23 04:39:36 -05:00
|
|
|
use of these functions as part of the implementation of the `cidrhost`,
|
|
|
|
`cidrsubnet`, `cidrsubnets`, and `cidrnetmask` functions has a more limited
|
|
|
|
impact than the general availability of these functions in the Go standard
|
2023-10-12 06:11:01 -05:00
|
|
|
library, and so we can't justify a similar exception to our compatibility
|
|
|
|
promises as the Go team made to their Go 1.0 compatibility promises.
|
2023-08-23 04:39:36 -05:00
|
|
|
|
2021-08-17 13:30:18 -05:00
|
|
|
If you're considering using this package for new functionality _other than_ the
|
|
|
|
built-in functions mentioned above, please do so only if consistency with the
|
|
|
|
behavior of those functions is important. Otherwise, new features are not
|
|
|
|
burdened by the same compatibility constraints and so should typically prefer
|
|
|
|
to use the stricter interpretation of the upstream parsing functions.
|