Skip to content

Commit

Permalink
feat: bzz head route
Browse files Browse the repository at this point in the history
  • Loading branch information
notanatol committed Feb 23, 2024
1 parent 5de732c commit 5eac12a
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 11 deletions.
2 changes: 1 addition & 1 deletion pkg/api/bytes.go
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ func (s *Service) bytesGetHandler(w http.ResponseWriter, r *http.Request) {
ContentTypeHeader: {"application/octet-stream"},
}

s.downloadHandler(logger, w, r, paths.Address, additionalHeaders, true)
s.downloadHandler(logger, w, r, paths.Address, additionalHeaders, true, false)
}

func (s *Service) bytesHeadHandler(w http.ResponseWriter, r *http.Request) {
Expand Down
43 changes: 34 additions & 9 deletions pkg/api/bzz.go
Original file line number Diff line number Diff line change
Expand Up @@ -299,10 +299,29 @@ func (s *Service) bzzDownloadHandler(w http.ResponseWriter, r *http.Request) {
paths.Path = strings.TrimRight(paths.Path, "/") + "/" // NOTE: leave one slash if there was some.
}

s.serveReference(logger, paths.Address, paths.Path, w, r)
s.serveReference(logger, paths.Address, paths.Path, w, r, false)
}

func (s *Service) serveReference(logger log.Logger, address swarm.Address, pathVar string, w http.ResponseWriter, r *http.Request) {
func (s *Service) bzzHeadHandler(w http.ResponseWriter, r *http.Request) {
logger := tracing.NewLoggerWithTraceID(r.Context(), s.logger.WithName("head_bzz_by_path").Build())

paths := struct {
Address swarm.Address `map:"address,resolve" validate:"required"`
Path string `map:"path"`
}{}
if response := s.mapStructure(mux.Vars(r), &paths); response != nil {
response("invalid path params", logger, w)
return
}

if strings.HasSuffix(paths.Path, "/") {
paths.Path = strings.TrimRight(paths.Path, "/") + "/" // NOTE: leave one slash if there was some.
}

s.serveReference(logger, paths.Address, paths.Path, w, r, true)
}

func (s *Service) serveReference(logger log.Logger, address swarm.Address, pathVar string, w http.ResponseWriter, r *http.Request, headerOnly bool) {
loggerV1 := logger.V(1).Build()

headers := struct {
Expand Down Expand Up @@ -404,7 +423,7 @@ FETCH:
// index document exists
logger.Debug("bzz download: serving path", "path", pathWithIndex)

s.serveManifestEntry(logger, w, r, indexDocumentManifestEntry, !feedDereferenced)
s.serveManifestEntry(logger, w, r, indexDocumentManifestEntry, !feedDereferenced, headerOnly)
return
}
}
Expand Down Expand Up @@ -447,7 +466,7 @@ FETCH:
// index document exists
logger.Debug("bzz download: serving path", "path", pathWithIndex)

s.serveManifestEntry(logger, w, r, indexDocumentManifestEntry, !feedDereferenced)
s.serveManifestEntry(logger, w, r, indexDocumentManifestEntry, !feedDereferenced, headerOnly)
return
}
}
Expand All @@ -461,7 +480,7 @@ FETCH:
// error document exists
logger.Debug("bzz download: serving path", "path", errorDocumentPath)

s.serveManifestEntry(logger, w, r, errorDocumentManifestEntry, !feedDereferenced)
s.serveManifestEntry(logger, w, r, errorDocumentManifestEntry, !feedDereferenced, headerOnly)
return
}
}
Expand All @@ -475,15 +494,15 @@ FETCH:
}

// serve requested path
s.serveManifestEntry(logger, w, r, me, !feedDereferenced)
s.serveManifestEntry(logger, w, r, me, !feedDereferenced, headerOnly)
}

func (s *Service) serveManifestEntry(
logger log.Logger,
w http.ResponseWriter,
r *http.Request,
manifestEntry manifest.Entry,
etag bool,
etag, headersOnly bool,
) {
additionalHeaders := http.Header{}
mtdt := manifestEntry.Metadata()
Expand All @@ -496,11 +515,11 @@ func (s *Service) serveManifestEntry(
additionalHeaders[ContentTypeHeader] = []string{mimeType}
}

s.downloadHandler(logger, w, r, manifestEntry.Reference(), additionalHeaders, etag)
s.downloadHandler(logger, w, r, manifestEntry.Reference(), additionalHeaders, etag, headersOnly)
}

// downloadHandler contains common logic for dowloading Swarm file from API
func (s *Service) downloadHandler(logger log.Logger, w http.ResponseWriter, r *http.Request, reference swarm.Address, additionalHeaders http.Header, etag bool) {
func (s *Service) downloadHandler(logger log.Logger, w http.ResponseWriter, r *http.Request, reference swarm.Address, additionalHeaders http.Header, etag, headersOnly bool) {
headers := struct {
Strategy *getter.Strategy `map:"Swarm-Redundancy-Strategy"`
FallbackMode *bool `map:"Swarm-Redundancy-Fallback-Mode"`
Expand Down Expand Up @@ -551,6 +570,12 @@ func (s *Service) downloadHandler(logger log.Logger, w http.ResponseWriter, r *h
}
w.Header().Set(ContentLengthHeader, strconv.FormatInt(l, 10))
w.Header().Set("Access-Control-Expose-Headers", ContentDispositionHeader)

if headersOnly {
w.WriteHeader(http.StatusOK)
return
}

bufSize := lookaheadBufferSize(l)
if headers.LookaheadBufferSize != nil {
bufSize = *(headers.LookaheadBufferSize)
Expand Down
3 changes: 3 additions & 0 deletions pkg/api/router.go
Original file line number Diff line number Diff line change
Expand Up @@ -270,6 +270,9 @@ func (s *Service) mountAPI() {
s.newTracingHandler("bzz-download"),
web.FinalHandlerFunc(s.bzzDownloadHandler),
),
"HEAD": web.ChainHandlers(
web.FinalHandlerFunc(s.bzzHeadHandler),
),
})

handle("/pss/send/{topic}/{targets}", web.ChainHandlers(
Expand Down
2 changes: 1 addition & 1 deletion pkg/api/subdomain.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,5 +28,5 @@ func (s *Service) subdomainHandler(w http.ResponseWriter, r *http.Request) {
paths.Path = strings.TrimRight(paths.Path, "/") + "/" // NOTE: leave one slash if there was some.
}

s.serveReference(logger, paths.Subdomain, paths.Path, w, r)
s.serveReference(logger, paths.Subdomain, paths.Path, w, r, false)
}

0 comments on commit 5eac12a

Please sign in to comment.