123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- // Copyright 2017 The go-ethereum Authors
- // This file is part of the go-ethereum library.
- //
- // The go-ethereum library is free software: you can redistribute it and/or modify
- // it under the terms of the GNU Lesser General Public License as published by
- // the Free Software Foundation, either version 3 of the License, or
- // (at your option) any later version.
- //
- // The go-ethereum library is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- // GNU Lesser General Public License for more details.
- //
- // You should have received a copy of the GNU Lesser General Public License
- // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
- package api
- import (
- "fmt"
- "net/url"
- "strings"
- )
- // URI is a reference to content stored in swarm.
- type URI struct {
- // Scheme has one of the following values:
- //
- // * bzz - an entry in a swarm manifest
- // * bzz-raw - raw swarm content
- // * bzz-immutable - immutable URI of an entry in a swarm manifest
- // (address is not resolved)
- // * bzz-list - list of all files contained in a swarm manifest
- //
- // Deprecated Schemes:
- // * bzzr - raw swarm content
- // * bzzi - immutable URI of an entry in a swarm manifest
- // (address is not resolved)
- // * bzz-hash - hash of swarm content
- //
- Scheme string
- // Addr is either a hexadecimal storage key or it an address which
- // resolves to a storage key
- Addr string
- // Path is the path to the content within a swarm manifest
- Path string
- }
- // Parse parses rawuri into a URI struct, where rawuri is expected to have one
- // of the following formats:
- //
- // * <scheme>:/
- // * <scheme>:/<addr>
- // * <scheme>:/<addr>/<path>
- // * <scheme>://
- // * <scheme>://<addr>
- // * <scheme>://<addr>/<path>
- //
- // with scheme one of bzz, bzz-raw, bzz-immutable, bzz-list or bzz-hash
- // or deprecated ones bzzr and bzzi
- func Parse(rawuri string) (*URI, error) {
- u, err := url.Parse(rawuri)
- if err != nil {
- return nil, err
- }
- uri := &URI{Scheme: u.Scheme}
- // check the scheme is valid
- switch uri.Scheme {
- case "bzz", "bzz-raw", "bzz-immutable", "bzz-list", "bzz-hash", "bzzr", "bzzi":
- default:
- return nil, fmt.Errorf("unknown scheme %q", u.Scheme)
- }
- // handle URIs like bzz://<addr>/<path> where the addr and path
- // have already been split by url.Parse
- if u.Host != "" {
- uri.Addr = u.Host
- uri.Path = strings.TrimLeft(u.Path, "/")
- return uri, nil
- }
- // URI is like bzz:/<addr>/<path> so split the addr and path from
- // the raw path (which will be /<addr>/<path>)
- parts := strings.SplitN(strings.TrimLeft(u.Path, "/"), "/", 2)
- uri.Addr = parts[0]
- if len(parts) == 2 {
- uri.Path = parts[1]
- }
- return uri, nil
- }
- func (u *URI) Raw() bool {
- return u.Scheme == "bzz-raw"
- }
- func (u *URI) Immutable() bool {
- return u.Scheme == "bzz-immutable"
- }
- func (u *URI) List() bool {
- return u.Scheme == "bzz-list"
- }
- func (u *URI) DeprecatedRaw() bool {
- return u.Scheme == "bzzr"
- }
- func (u *URI) DeprecatedImmutable() bool {
- return u.Scheme == "bzzi"
- }
- func (u *URI) Hash() bool {
- return u.Scheme == "bzz-hash"
- }
- func (u *URI) String() string {
- return u.Scheme + ":/" + u.Addr + "/" + u.Path
- }
|