base.go 1.08 KB
Newer Older
1 2 3 4 5
package namesys

import (
	"strings"

6
	context "context"
7 8 9 10 11 12

	path "github.com/ipfs/go-ipfs/path"
)

type resolver interface {
	// resolveOnce looks up a name once (without recursion).
13
	resolveOnce(ctx context.Context, name string, opts *ResolveOpts) (value path.Path, err error)
14 15 16
}

// resolve is a helper for implementing Resolver.ResolveN using resolveOnce.
17 18
func resolve(ctx context.Context, r resolver, name string, opts *ResolveOpts, prefixes ...string) (path.Path, error) {
	depth := opts.Depth
19
	for {
20
		p, err := r.resolveOnce(ctx, name, opts)
21 22 23
		if err != nil {
			return "", err
		}
24
		log.Debugf("resolved %s to %s", name, p.String())
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54

		if strings.HasPrefix(p.String(), "/ipfs/") {
			// we've bottomed out with an IPFS path
			return p, nil
		}

		if depth == 1 {
			return p, ErrResolveRecursion
		}

		matched := false
		for _, prefix := range prefixes {
			if strings.HasPrefix(p.String(), prefix) {
				matched = true
				if len(prefixes) == 1 {
					name = strings.TrimPrefix(p.String(), prefix)
				}
				break
			}
		}

		if !matched {
			return p, nil
		}

		if depth > 1 {
			depth--
		}
	}
}