uri.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. // Copyright 2017 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package api
  17. import (
  18. "fmt"
  19. "net/url"
  20. "strings"
  21. )
  22. // URI is a reference to content stored in swarm.
  23. type URI struct {
  24. // Scheme has one of the following values:
  25. //
  26. // * bzz - an entry in a swarm manifest
  27. // * bzz-raw - raw swarm content
  28. // * bzz-immutable - immutable URI of an entry in a swarm manifest
  29. // (address is not resolved)
  30. // * bzz-list - list of all files contained in a swarm manifest
  31. //
  32. // Deprecated Schemes:
  33. // * bzzr - raw swarm content
  34. // * bzzi - immutable URI of an entry in a swarm manifest
  35. // (address is not resolved)
  36. Scheme string
  37. // Addr is either a hexadecimal storage key or it an address which
  38. // resolves to a storage key
  39. Addr string
  40. // Path is the path to the content within a swarm manifest
  41. Path string
  42. }
  43. // Parse parses rawuri into a URI struct, where rawuri is expected to have one
  44. // of the following formats:
  45. //
  46. // * <scheme>:/
  47. // * <scheme>:/<addr>
  48. // * <scheme>:/<addr>/<path>
  49. // * <scheme>://
  50. // * <scheme>://<addr>
  51. // * <scheme>://<addr>/<path>
  52. //
  53. // with scheme one of bzz, bzz-raw, bzz-immutable or bzz-list
  54. // or deprecated ones bzzr and bzzi
  55. func Parse(rawuri string) (*URI, error) {
  56. u, err := url.Parse(rawuri)
  57. if err != nil {
  58. return nil, err
  59. }
  60. uri := &URI{Scheme: u.Scheme}
  61. // check the scheme is valid
  62. switch uri.Scheme {
  63. case "bzz", "bzz-raw", "bzz-immutable", "bzz-list", "bzzr", "bzzi":
  64. default:
  65. return nil, fmt.Errorf("unknown scheme %q", u.Scheme)
  66. }
  67. // handle URIs like bzz://<addr>/<path> where the addr and path
  68. // have already been split by url.Parse
  69. if u.Host != "" {
  70. uri.Addr = u.Host
  71. uri.Path = strings.TrimLeft(u.Path, "/")
  72. return uri, nil
  73. }
  74. // URI is like bzz:/<addr>/<path> so split the addr and path from
  75. // the raw path (which will be /<addr>/<path>)
  76. parts := strings.SplitN(strings.TrimLeft(u.Path, "/"), "/", 2)
  77. uri.Addr = parts[0]
  78. if len(parts) == 2 {
  79. uri.Path = parts[1]
  80. }
  81. return uri, nil
  82. }
  83. func (u *URI) Raw() bool {
  84. return u.Scheme == "bzz-raw"
  85. }
  86. func (u *URI) Immutable() bool {
  87. return u.Scheme == "bzz-immutable"
  88. }
  89. func (u *URI) List() bool {
  90. return u.Scheme == "bzz-list"
  91. }
  92. func (u *URI) DeprecatedRaw() bool {
  93. return u.Scheme == "bzzr"
  94. }
  95. func (u *URI) DeprecatedImmutable() bool {
  96. return u.Scheme == "bzzi"
  97. }
  98. func (u *URI) String() string {
  99. return u.Scheme + ":/" + u.Addr + "/" + u.Path
  100. }