mirror of
https://github.com/ipfs/kubo.git
synced 2026-03-02 23:08:07 +08:00
correctly handle multi-hop dnslink resolution
Namesys returns `ErrResolveRecursion` when it stops recursing due to a depth limit. It doesn't return success. Alternative to #5199. License: MIT Signed-off-by: Steven Allen <steven@stebalien.com>
This commit is contained in:
parent
e7938a1834
commit
6a81c72cfb
@ -40,7 +40,10 @@ func (m mockNamesys) Resolve(ctx context.Context, name string, opts ...nsopts.Re
|
||||
if depth == nsopts.UnlimitedDepth {
|
||||
depth = math.MaxUint64
|
||||
}
|
||||
for depth > 0 && strings.HasPrefix(name, "/ipns/") {
|
||||
for strings.HasPrefix(name, "/ipns/") {
|
||||
if depth <= 0 {
|
||||
return value, namesys.ErrResolveRecursion
|
||||
}
|
||||
depth--
|
||||
|
||||
var ok bool
|
||||
|
||||
@ -7,6 +7,7 @@ import (
|
||||
"strings"
|
||||
|
||||
core "github.com/ipfs/go-ipfs/core"
|
||||
namesys "github.com/ipfs/go-ipfs/namesys"
|
||||
nsopts "github.com/ipfs/go-ipfs/namesys/opts"
|
||||
|
||||
isd "gx/ipfs/QmZmmuAXgX73UQmX1jRKjTGmjzq24Jinqkq8vzkBtno4uX/go-is-domain"
|
||||
@ -25,7 +26,8 @@ func IPNSHostnameOption() ServeOption {
|
||||
host := strings.SplitN(r.Host, ":", 2)[0]
|
||||
if len(host) > 0 && isd.IsDomain(host) {
|
||||
name := "/ipns/" + host
|
||||
if _, err := n.Namesys.Resolve(ctx, name, nsopts.Depth(1)); err == nil {
|
||||
_, err := n.Namesys.Resolve(ctx, name, nsopts.Depth(1))
|
||||
if err == nil || err == namesys.ErrResolveRecursion {
|
||||
r.Header.Set("X-Ipns-Original-Path", r.URL.Path)
|
||||
r.URL.Path = name + r.URL.Path
|
||||
}
|
||||
|
||||
Loading…
Reference in New Issue
Block a user