Documentation ¶
Overview ¶
Package path contains utilities to work with dep2p paths.
Index ¶
Constants ¶
const ( DeP2PNamespace = "dep2p" IPNSNamespace = "ipns" IPLDNamespace = "ipld" )
Variables ¶
Functions ¶
func SegmentsToString ¶
SegmentsToString converts an array of segments into a string. The returned string will always be prefixed with a "/" if there are any segments. For example, if the given segments array is ["foo", "bar"], the returned value will be "/foo/bar". Given an empty array, an empty string is returned.
func StringToSegments ¶
StringToSegments converts a string into an array of segments. This function follows the rules of [Path.Segments]: the path is first cleaned through gopath.Clean and no empty segments are returned.
Types ¶
type ErrInvalidPath ¶
type ErrInvalidPath struct {
// contains filtered or unexported fields
}
func (*ErrInvalidPath) Error ¶
func (e *ErrInvalidPath) Error() string
func (*ErrInvalidPath) Is ¶
func (e *ErrInvalidPath) Is(err error) bool
func (*ErrInvalidPath) Unwrap ¶
func (e *ErrInvalidPath) Unwrap() error
type ImmutablePath ¶
type ImmutablePath struct {
// contains filtered or unexported fields
}
ImmutablePath is a Path which is guaranteed to have an immutable [Namespace].
func FromCid ¶
func FromCid(cid cid.Cid) ImmutablePath
FromCid returns a new "/dep2p" path with the provided CID.
func NewImmutablePath ¶
func NewImmutablePath(p Path) (ImmutablePath, error)
func (ImmutablePath) Mutable ¶
func (ip ImmutablePath) Mutable() bool
func (ImmutablePath) Namespace ¶
func (ip ImmutablePath) Namespace() string
func (ImmutablePath) RootCid ¶
func (ip ImmutablePath) RootCid() cid.Cid
func (ImmutablePath) Segments ¶
func (ip ImmutablePath) Segments() []string
func (ImmutablePath) String ¶
func (ip ImmutablePath) String() string
type Path ¶
type Path interface { // String returns the path as a string. String() string // Namespace returns the first component of the path. For example, the namespace // of "/dep2p/bafy" is "dep2p". Namespace() string // Mutable returns false if the data under this path's namespace is guaranteed to not change. Mutable() bool // Segments returns the different elements of a path delimited by a forward // slash ("/"). The returned array must not contain any empty segments, and // must have a length of at least two: the first element must be the namespace, // and the second must be root. // // Examples: // - "/ipld/bafkqaaa" returns ["ipld", "bafkqaaa"] // - "/dep2p/bafkqaaa/a/b/" returns ["dep2p", "bafkqaaa", "a", "b"] // - "/ipns/dnslink.net" returns ["ipns", "dnslink.net"] Segments() []string }
Path is a generic, valid, and well-formed path. A valid path is shaped as follows:
/{namespace}/{root}[/remaining/path]
Where:
- Namespace is "dep2p", "ipld", or "ipns".
- If namespace is "dep2p" or "ipld", "root" must be a valid cid.Cid.
- If namespace is "ipns", "root" may be a [ipns.Name] or a DNSLink FQDN.
func NewPath ¶
NewPath takes the given string and returns a well-formed and sanitized Path. The given string is cleaned through gopath.Clean, but preserving the final trailing slash. This function returns an error when the given string is not a valid content path.
func NewPathFromSegments ¶
NewPathFromSegments creates a new Path from the provided segments. This function simply calls NewPath internally with the segments concatenated using a forward slash "/" as separator. Please see [Path.Segments] for more information about how segments must be structured.