fix(deps): update module github.com/ipfs/boxo to v0.40.0#16
Open
renovate[bot] wants to merge 1 commit into
Open
fix(deps): update module github.com/ipfs/boxo to v0.40.0#16renovate[bot] wants to merge 1 commit into
renovate[bot] wants to merge 1 commit into
Conversation
Contributor
Author
ℹ️ Artifact update noticeFile name: go.modIn order to perform the update(s) described in the table above, Renovate ran the
Details:
|
ba0f1a2 to
194d4b5
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
v0.38.0→v0.40.0Release Notes
ipfs/boxo (github.com/ipfs/boxo)
v0.40.0Compare Source
Added
retrieval: addedState.Snapshot,State.Apply, andState.Notifyso consumers can streamStateacross a process boundary, e.g. to drive a live progress bar in Kubo'scat,get, ordag export. #1153pinning/pinner: addedPinner.Close() error. Close cancels every in-flight operation's context, including streaming goroutines fromRecursiveKeys,DirectKeys, andInternalPins, and waits for them to return. A scalar method that observes the cancellation may returncontext.Canceled; a stream interrupted by Close may surfaceErrClosedon the channel before it closes. After Close returns, every other method returns the newErrClosedsentinel; streaming methods deliver it asStreamedPin.Erron a single entry, then close the channel. Close is idempotent and goroutine-safe. Action required: downstreamPinnerimplementations must addClose. #1150pinning/pinner/dspinner: implementsClose. Close cancels the contexts of in-flight operations, so snapshot iteration inRecursiveKeys/DirectKeysand DAG fetches inPinbail out promptly instead of draining to completion. Close returns as soon as those operations honor their ctx. Hosts owning the datastore should callCloseon the pinner before closing the datastore to avoid the use-after-close panic path in stores such as pebble. #1150routing/http/types/iter: addedLimit, an iterator that caps another iterator at a fixed number of values. #1157routing/providerquerymanager: newWithFindPeerFallbackoption. When set, a one-shotFindPeerfallback runs if the first dial to a provider fails; the manager retries the dial with the freshAddrInfo, but only ifFindPeersurfaced at least one address that wasn't already in the routing-record set just tried. Rescues providers whose routing-record snapshot is thin or stale but whose actual addresses are still reachable, without wasting a retry on a duplicate address set. Disabled by default; passWithFindPeerFallback(myDHT)to enable.Changed
upgrade to
go-libp2p-kad-dhtv0.40.0🛠
files: theFileinterface no longer embedsio.Seeker. Seekability is now explicit in the type system instead of implied by an always-presentSeekmethod that returnedErrNotSupportedat runtime for non-seekable inputs. Callers that need to seek type-assert toio.Seeker; the assertion is an honest capability check rather than a guess. Seekable implementations (ReaderFilewrapping a seekable reader,Symlink, UnixFS files returned from the gateway and importer) still satisfy the assertion. Non-seekable implementations (HTTP multipart streams,WebFile) now fail the assertion at compile-aware sites instead of producing runtime errors deep in third-party code. The previous behavior forced downstream workarounds: e.g. ipfs/kubo#11253 had to wrapfiles.Filein a plainio.Reader/io.Closerto stripSeekand forcego-car's forward-only fallback, becausego-car'sNewBlockReadertrusted the interface and calledSeek, which failed with "operation not supported" on CARv2 imports over the HTTP API. With this change the trap stops existing.Action required. Replace direct
Seekcalls onfiles.Filewith a type assertion:See ipfs/kubo#11254 for a worked example of the call-site update. #1128
✨
routing/http/server: the Delegated Routing server now passeslimit=0(unbounded) toDelegatedRouter.FindProviders/FindPeersand applies the configured records limit itself, after filtering. Filtered requests now return a full page of results instead of fewer than requested. The server reads the delegate's iterator lazily and closes it once it has enough records. Action required: delegate implementations should return results lazily and stop work onClose. A delegate that previously used thelimitargument to end its walk early should now end the walk onCloseinstead. #1157path/resolver:ResolveToLastNode,ResolvePath, andResolvePathComponentsnow populateretrieval.Stateon the request context when one is attached. They advance the state toPhasePathResolution, record the root CID from the input path, and record the terminal CID once resolution completes. Until now only the gateway backends populated these fields, leaving non-gateway callers (CLIs, custom tools) without phase or CID diagnostics on retrieval errors. The new calls are idempotent with the existing gateway-side ones, so behavior on the gateway path is unchanged.Fixed
files: now builds underGOOS=js GOARCH=wasmandGOOS=wasip1 GOARCH=wasm. #935routing/http/server: filtered/routing/v1/providersand/routing/v1/peersrequests now return up to the configured records limit. Previously the limit was applied beforefilter-addrs/filter-protocolsran, so records dropped by the filters shrank the response below the limit. The limit now applies after filtering. #1157routing/http/types/iter:Filter.Nextnow iterates instead of recursing on rejected values, so the goroutine stack stays flat even when a long run of records is filtered out. This matters now that the server pulls unbounded results from the delegate. #1157v0.39.0Compare Source
Added
gateway:Config.MaxDeserializedResponseSizeallows setting a maximum file/directory size for deserialized gateway responses. Content exceeding this limit returns410 Gone, directing users to run their own IPFS node. Trustless response formats (application/vnd.ipld.raw,application/vnd.ipld.car) are not affected. The size is read from the UnixFS root block, so no extra block fetches are needed for the check. #1138gateway:Config.MaxUnixFSDAGResponseSizeallows setting a maximum content size applied to all response formats (deserialized, raw blocks, CAR, TAR). Content exceeding this limit returns410 Gone. For most handlers the check reuses size information already available in the request path; for CAR responses a lightweightHeadcall is made only when the limit is configured. #1138Changed
bitswap/server: the default peer comparator now schedules peers fairly. A peer that has never been served, or has waited longer than 10s, outranks non-starved peers. Pending counts cap at 16 for ordering purposes, so peers with small wantlists no longer wait behind peers with large ones. The final tiebreak uses a per-process salted hash of peer.ID, so no peer can craft an ID that permanently outranks everyone. Engines built withWithTaskComparatorkeep their existing behavior. #1141go-libp2p-kad-dhtv0.39.1Fixed
bitswap/network/bsnet:SendMessageandhandleNewStreamnow close streams in a background goroutine. Previously,stream.Closecould hold the caller for up toDefaultNegotiationTimeout(10s) whilelazyClientConn.Closewaited for the remote peer to complete the multistream handshake. This saturated the bitswapTaskWorkerCountpool when peers were unresponsive and stopped bitswap from serving blocks to other peers. As a side effect,SendMessageno longer returns errors fromstream.Close; close failures are logged at Debug. #1142bitswap/server: a peer with a single pending want no longer waits behind peers with large wantlists. #1141pinner/dspinner:RecursiveKeysandDirectKeysnow snapshot the pin index under the read lock and release it before emitting pins, so a slow consumer (e.g. the reprovider draining the channel at DHT speed underProvide.Strategy=pinned*) can no longer starvePin/Unpin/Flushwriters. #1140Configuration
📅 Schedule: (UTC)
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.