go-ipfs 0.11.0 Release
We're happy to announce go-ipfs 0.11.0. This release comes with improvements to the UnixFS Sharding and PubSub experiments as well as support for Circuit-Relay v2 which sets the network up for decentralized hole punching support.
As usual, this release includes important fixes, some of which may be critical for security. Unless the fix addresses a bug being exploited in the wild, the fix will not be called out in the release notes. Please make sure to update ASAP. See our release process for details.
🛠 BREAKING CHANGES
- UnixFS sharding is now automatic and enabled by default
- HAMT-based sharding is applied to large directories (i.e. those that would serialize into block larger than ~256KiB)s. This means importing data via commands like
ipfs add -r <directory>
may result in different CIDs due to the different DAG representations. - Support for
Experimental.ShardingEnabled
is removed.
- HAMT-based sharding is applied to large directories (i.e. those that would serialize into block larger than ~256KiB)s. This means importing data via commands like
- go-ipfs can no longer act as a Circuit Relay v1
- Node will refuse to start if
Swarm.EnableRelayHop
is set totrue
- If you depend on v1 relay service provider, see "Removal of v1 relay service" section for available migration options.
- Node will refuse to start if
- HTTP RPC wire format for experimental commands at
/api/v0/pubsub
changed.- If you use js-ipfs-http-client or go-ipfs-http-client, just update to their latest version.
- If you use something else, see "Multibase in PubSub" section below for migration details.
Keep reading to learn more details.
🔦 Highlights
🗃️ Automatic UnixFS sharding
Truly big directories can have so many items, that the root block with all of their names is too big to be exchanged with other peers. This was partially solved by HAMT-sharding, which was introduced a while ago as opt-in. The main downside of the implementation was that it was a global flag that sharded all imported directories (big and small).
This release solves that inconvenience by making UnixFS sharding smarter and applies it only to larger directories (i.e. directories that would be at least ~256KiB). This is now the default behavior in ipfs add
and ipfs files
commands, where UnixFS sharding works out-of-the-box.
🔁 Circuit Relay v2
This release adds support for the circuit relay v2 protocol based on the reference implementation from go-libp2p 0.16.
This is the cornerstone for maximizing p2p connections between IPFS peers. Every publicly dialable peer can now act as a limited relay v2, which can be used for hole punching and other decentralized signaling protocols.
Limited relay v2 configuration options
go-ipfs can now be configured to act as a RelayClient
that uses other peers for autorelay functionality when behind a NAT, or provide a limited RelayService
to other peers on the network.
Starting with go-ipfs v0.11 every publicly dialable go-ipfs (based on AutoNAT determination) will start a limited RelayService
. RelayClient
remains disabled by default for now, as we want the network to update and get enough v2 service providers first.
Note: the limited Circuit Relay v2 provided with this release only allows low-bandwidth protocols (identify, ping, holepunch) over transient connections. If you want to relay things like bitswap sessions, you need to set up a v1 relay by some other means. See details below.
Removal of unlimited v1 relay service provider
Switching to v2 of the relay spec means removal or deprecation of configuration keys that were specific to v1.
- Relay transport and client support circuit-relay v2:
Swarm.EnableAutoRelay
was replaced bySwarm.RelayClient.Enable
.Swarm.DisableRelay
is deprecated, relay transport can be now disabled globally (both client and service) by settingSwarm.Transports.Network.Relay
tofalse
- Relay v1 service provider was replaced by v2:
Swarm.EnableRelayHop
no longer starts an unlimited v1 relay. If you have it set totrue
the node will refuse to start and display an error message.- Existing users who choose to continue running a v1 relay should migrate their setups to relay v1 based on js-ipfs running in node, or the standalone libp2p-relay-daemon configured with
RelayV1.Enabled
set totrue
. Be mindful that v1 relays are unlimited, and one may want to set up some ACL based either on PeerIDs or Subnets.
🕳 Decentralized Hole Punching (DCUtR protocol client)
We are working towards enabling hole punching for NAT traversal when port forwarding is not possible.
go-libp2p 0.16 provides an implementation of the DCUtR (decentralized hole punching) protocol. It is hidden behind the Swarm.EnableHolePunching
configuration flag.
When enabled, go-ipfs will coordinate with the counterparty using a relayed v2 connection, to upgrade to a direct connection through a NAT/firewall whenever possible.
This feature is disabled by default in this release, but we hope to enable it by default as soon the network updates to go-ipfs v0.11 and gains a healthy set of limited v2 relays.
💬 Multibase in PubSub HTTP RPC API
This release fixed some edge cases that were reported by users of the PubSub experiment, getting it closer to becoming a stable feature of go-ipfs. Some PubSub users will notice that the plaintext limitation is lifted: one can now use line breaks in messages published to non-ascii topic names, or even publish arbitrary bytes to arbitrary topics. It required a change to the wire format used when pubsub commands are executed over the HTTP RPC API at /api/v0/pubsub/*
, and also modified the behavior of the ipfs pubsub pub
command, which now is publishing only a single pubsub message with data read from a file or stdin.
PubSub client migration tips
If you use the HTTP RPC API with the go-ipfs-http-client library, make sure to update to the latest version. The next version of js-ipfs-http-client will use the new wire format as well, so you don't need to do anything.
If you use /api/v0/pubsub/*
directly or maintain your own client library, you must adjust your HTTP client code. Byte fields and URL args are now encoded in base64url
Multibase. Encode/decode bytes using the ipfs multibase --help
commands, or use the multiformats libraries (js-multiformats, go-multibase).
Low level changes:
topic
passed as URLarg
in requests to/api/v0/pubsub/*
must be encoded in URL-safe multibase (base64url
)data
,from
,seqno
andtopicIDs
returned in JSON responses are now encoded in multibase- Peer IDs returned in
from
now use the same default text representation from go-libp2p and peerid encoder/decoder from libp2p. This means the same text representation as in as inswarm peers
, which makes it possible to compare them without decoding multibase. /api/v0/pubsub/pub
no longer acceptsdata
to be passed as URL, it has to be sent asmultipart/form-data
. This removes size limitations based on URL length, and enables regular HTTP clients to publish data to PubSub topics. For example, to publishsome-file
to topic namedtest-topic
using vanillacurl
, one would execute:curl -X POST -v -F "stdin=@some-file" 'http://127.0.0.1:5001/api/v0/pubsub/pub?arg=$(echo -n test-topic | ipfs multibase encode -b base64url)'
ipfs pubsub pub
on the command line no longer accepts variadicdata
arguments. Instead, it expects a single file input or stream of bytes from stdin. This ensures arbitrary stream of bytes can be published, removing limitation around messages that include\n
or\r\n
.
⚙️ New configuration flags
Addresses.AppendAnnounce
is an array of multiaddrs, similar toAddresses.Announce
, except it does not override inferred swarm addresses, but appends custom ones to the list.- Pubsub experiments can now be enabled via config, removing the need for CLI flag to be passed every time daemon starts:
Pubsub.Enabled
enables the pubsub system.Ipns.UsePubsub
enables IPFS over pubsub experiment for publishing IPNS records in real time.
🔐 Support for DAG-JOSE IPLD codec
JOSE is a standard for signing and encrypting JSON objects. DAG-JOSE is an IPLD codec based on JOSE and represented in CBOR. Upon encountering the dag-jose
multicodec indicator, implementations can expect that the block contains dag-cbor encoded data which matches the IPLD schema from the DAG-JOSE spec.
This work was contributed by Ceramic and acts as a template for future IPFS improvements driven by the real world needs of the IPFS community.
Changelog
Full Changelog
- github.com/ipfs/go-ipfs:
- docs: update changelog for v0.11.0
- Release v0.11.0-rc2
- fix(corehttp): adjust peer counting metrics (#8577) (ipfs/go-ipfs#8577)
- Release v0.11.0-rc1
- feat: Swarm.EnableHolePunching flag (#8562) (ipfs/go-ipfs#8562)
- feat: enabling pubsub and ipns-pubsub via config flags (#8510) (ipfs/go-ipfs#8510)
- Integrate go-dag-jose plugin (#8569) (ipfs/go-ipfs#8569)
- feat: Addresses.AppendAnnounce (#8177) (ipfs/go-ipfs#8177)
- fix: multibase in pubsub http rpc (#8183) (ipfs/go-ipfs#8183)
- refactor: remove dir-index-html submodule (ipfs/go-ipfs#8555)
- feat: hard deprecation of IPFS_REUSEPORT
- feat: go-libp2p 0.16, UnixFS autosharding and go-datastore with contexts (#8563) (ipfs/go-ipfs#8563)
- chore: fix link in README.md (#8551) (ipfs/go-ipfs#8551)
- Updating release template based off some 0.10 learnings (#8491) (ipfs/go-ipfs#8491)
- fix: multiple subdomain gateways on same domain (#8556) (ipfs/go-ipfs#8556)
- Fix typos (#8548) (ipfs/go-ipfs#8548)
- Add support for multiple files to
ipfs files rm
. - add a docker-compose file (#8387) (ipfs/go-ipfs#8387)
- fix(sharness): use -Q option instead of pipe to tail cmd
- Add Homebrew installation method. (ipfs/go-ipfs#8545)
- docs: fix ipfs files cp examples (#8533) (ipfs/go-ipfs#8533)
- fix(unixfs): check for errors before dereferencing the link (ipfs/go-ipfs#8508)
- chore: replace go-merkledag walk with go-ipld-prime traversal for dag export (#8506) (ipfs/go-ipfs#8506)
- test: add sharness test for reading ADLs with FUSE
- fix: allow the levelds compression level to be unspecified
- (ipfs/go-ipfs#8457)
- (ipfs/go-ipfs#8482)
- Added the missing heathcheck for the container (#8429) (ipfs/go-ipfs#8429)
- chore: update dir-index-html to v1.2.2
- Update RELEASE_ISSUE_TEMPLATE.md
- Update RELEASE_ISSUE_TEMPLATE.md
- add more logging to flaky TestPeersTotal
- Update RELEASE_ISSUE_TEMPLATE.md
- Update RELEASE_ISSUE_TEMPLATE.md
- Updating chocolatey to reference go-ipfs
- chore: update changelog for v0.10.0
- add testground plans to bitswap on CI
- ci: move Docker image build to Actions (#8467) (ipfs/go-ipfs#8467)
- fix(cli): object add-link: do not allow blocks over BS limit (#8414) (ipfs/go-ipfs#8414)
- fuse: load unixfs adls as their dagpb substrates
- enable the legacy mDNS implementation
- change ipfs dag get flag name from format to output-codec (ipfs/go-ipfs#8440)
- change names of ipfs dag put flags to make changes clearer (ipfs/go-ipfs#8439)
- test: check behavior of loading UnixFS sharded directories with missing shards
- (ipfs/go-ipfs#8432)
- feat: dag import --stats (#8237) (ipfs/go-ipfs#8237)
- feat: ipfs-webui v2.13.0 (#8430) (ipfs/go-ipfs#8430)
- feat(cli): add daemon option --agent-version-suffix (#8419) (ipfs/go-ipfs#8419)
- feat: multibase transcode command (#8403) (ipfs/go-ipfs#8403)
- fix: take the lock while listing peers
- feature: 'ipfs swarm peering' command (#8147) (ipfs/go-ipfs#8147)
- chore: update IPFS Desktop testing steps (#8393) (ipfs/go-ipfs#8393)
- add more buttons; remove some sections covered in the docs; general cleanup (ipfs/go-ipfs#8274)
- Cosmetic fixups in examples (#8325) (ipfs/go-ipfs#8325)
- perf: use performance-enhancing FUSE mount options
- ci: publish Docker images for bifrost-* branches
- chore: add comments to peerlog plugin about being unsupported
- test: add unit tests for peerlog config parsing
- ci: preload peerlog plugin, disable by default
- fix(mkreleaselog): specify the parent commit when diffing
- update version to v0.11.0-dev
- github.com/ipfs/go-bitswap (v0.4.0 -> v0.5.1):
- Version 0.5.1
- Change incorrect function name in README (#541) (ipfs/go-bitswap#541)
- Version 0.5.0 (#540) (ipfs/go-bitswap#540)
- feat: plumb through contexts (#539) (ipfs/go-bitswap#539)
- sync: update CI config files (#538) (ipfs/go-bitswap#538)
- fix: optimize handling for peers with lots of tasks (ipfs/go-bitswap#537)
- Enable custom task prioritization logic (ipfs/go-bitswap#535)
- feat: cache the materialized wantlist (ipfs/go-bitswap#530)
- fix: reduce receive contention (ipfs/go-bitswap#536)
- Fix ProviderQueryManager test timings (ipfs/go-bitswap#534)
- fix: rename wiretap to tracer (ipfs/go-bitswap#531)
- fix: fix race on "responsive" check (ipfs/go-bitswap#528)
- fix: reduce log verbosity
- github.com/ipfs/go-blockservice (v0.1.7 -> v0.2.1):
- Version 0.2.1
- Version 0.2.0 (#87) (ipfs/go-blockservice#87)
- feat: add context to interfaces (#86) (ipfs/go-blockservice#86)
- sync: update CI config files (#85) (ipfs/go-blockservice#85)
- chore: update log (ipfs/go-blockservice#84)
- github.com/ipfs/go-cid (v0.0.7 -> v0.1.0):
- amend the CidFromReader slice extension math
- implement CidFromReader
- chore: fixups from running go vet, go fmt and staticcheck (ipfs/go-cid#122)
- s/characters/bytes
- Fix inaccurate comment for uvarint
- coverage: more tests for cid
- coverage: more tests for varint
- coverage: more tests for builder
- fix: make tests run with Go 1.15
- Add the dagjose multiformat
- github.com/ipfs/go-datastore (v0.4.6 -> v0.5.1):
- Release v0.5.1
- chore: add lots of interface assertions
- fix: make NullDatastore satisfy the Batching interface again
- Update version.json (#183) (ipfs/go-datastore#183)
- feat: add context to interfaces (#181) (ipfs/go-datastore#181)
- sync: update CI config files (ipfs/go-datastore#182)
- github.com/ipfs/go-ds-badger (v0.2.7 -> v0.3.0):
- feat: plumb through contexts (#119) (ipfs/go-ds-badger#119)
- github.com/ipfs/go-ds-flatfs (v0.4.5 -> v0.5.1):
- Update version.json
- fix: add context to DiskUsage()
- Version 0.5.0 (#99) (ipfs/go-ds-flatfs#99)
- feat: add contexts on datastore methods (#98) (ipfs/go-ds-flatfs#98)
- sync: update CI config files (#97) (ipfs/go-ds-flatfs#97)
- sync: update CI config files (ipfs/go-ds-flatfs#96)
- fix staticcheck (ipfs/go-ds-flatfs#92)
- fix typo in readme.go (ipfs/go-ds-flatfs#89)
- github.com/ipfs/go-ds-leveldb (v0.4.2 -> v0.5.0):
- Version 0.5.0 (#58) (ipfs/go-ds-leveldb#58)
- feat: plumb through contexts (#57) (ipfs/go-ds-leveldb#57)
- sync: update CI config files (#56) (ipfs/go-ds-leveldb#56)
- fix closing of datastore in tests (ipfs/go-ds-leveldb#52)
- fix staticcheck (ipfs/go-ds-leveldb#49)
- fix typo in function documentation (ipfs/go-ds-leveldb#46)
- github.com/ipfs/go-ds-measure (v0.1.0 -> v0.2.0):
- Version 0.2.0 (#39) (ipfs/go-ds-measure#39)
- feat: add contexts on datastore methods (#38) (ipfs/go-ds-measure#38)
- sync: update CI config files (#37) (ipfs/go-ds-measure#37)
- github.com/ipfs/go-fetcher (v1.5.0 -> v1.6.1):
- Version 1.6.1
- Version 1.6.0 (#29) (ipfs/go-fetcher#29)
- feat: plumb through context changes (#28) (ipfs/go-fetcher#28)
- sync: update CI config files (#27) (ipfs/go-fetcher#27)
- add a fetcher constructor for the case where we already have a session (ipfs/go-fetcher#26)
- github.com/ipfs/go-filestore (v0.0.3 -> v0.1.0):
- feat: plumb through context changes (#56) (ipfs/go-filestore#56)
- github.com/ipfs/go-graphsync (v0.8.0 -> v0.11.0):
- docs(CHANGELOG): update for v0.11.0 release
- Merge branch 'release/v0.10.6'
- update to context datastores (#275) (ipfs/go-graphsync#275)
- feat!(requestmanager): remove request allocation backpressure (#272) (ipfs/go-graphsync#272)
- message/pb: stop using gogo/protobuf (#277) (ipfs/go-graphsync#277)
- mark all test helper funcs via t.Helper (#276) (ipfs/go-graphsync#276)
- chore(queryexecutor): remove unused RunTraversal
- chore(responsemanager): remove unused workSignal
- chore(queryexecutor): fix tests for runtraversal refactor + clean up
- feat(queryexecutor): merge RunTraversal into QueryExecutor
- feat(responsemanager): QueryExecutor to separate module - use TaskQueue, add tests
- Merge branch 'release/v0.10.5'
- fix(responseassembler): dont hold block data reference in passed on subscribed block link (#268) (ipfs/go-graphsync#268)
- sync: update CI config files (#266) (ipfs/go-graphsync#266)
- Check IPLD context cancellation error type instead of string comparison
- Use
context.CancelFunc
instead offunc()
(#257) (ipfs/go-graphsync#257) - fix: bail properly when budget exceeded
- feat(requestmanager): report inProgressRequestCount on OutgoingRequests event
- fix(requestmanager): remove failing racy test select block
- feat(requestmanager): add OutgoingRequeustProcessingListener
- Merge branch 'release/v0.10.4'
- fix(allocator): prevent buffer overflow (#248) (ipfs/go-graphsync#248)
- Merge branch 'release/v0.10.3'
- Configure message parameters (#247) (ipfs/go-graphsync#247)
- Stats! (#246) (ipfs/go-graphsync#246)
- Limit simultaneous incoming requests on a per peer basis (#245) (ipfs/go-graphsync#245)
- sync: update CI config files (#191) (ipfs/go-graphsync#191)
- Merge branch 'release/v0.10.2'
- test(responsemanager): fix flakiness TestCancellationViaCommand (#243) (ipfs/go-graphsync#243)
- Fix deadlock on notifications (#242) (ipfs/go-graphsync#242)
- Merge branch 'release/v0.10.1'
- Free memory on request finish (#240) (ipfs/go-graphsync#240)
- release: v1.10.0 (ipfs/go-graphsync#238)
- Add support for IPLD prime's budgets feature in selectors (#235) (ipfs/go-graphsync#235)
- feat(graphsync): add an index for blocks in the on new block hook (#234) (ipfs/go-graphsync#234)
- Do not send first blocks extension (#230) (ipfs/go-graphsync#230)
- Protect Libp2p Connections (#229) (ipfs/go-graphsync#229)
- test(responsemanager): remove check (#228) (ipfs/go-graphsync#228)
- feat(graphsync): give missing blocks a named error (#227) (ipfs/go-graphsync#227)
- Add request limits (#224) (ipfs/go-graphsync#224)
- Tech Debt Cleanup and Docs Update (#219) (ipfs/go-graphsync#219)
- Release/v0.9.3 (ipfs/go-graphsync#218)
- 0.9.2 release (ipfs/go-graphsync#217)
- fix(requestmanager): remove main thread block on allocation (#216) (ipfs/go-graphsync#216)
- feat(allocator): add debug logging (#213) (ipfs/go-graphsync#213)
- fix: spurious warn log (#210) (ipfs/go-graphsync#210)
- docs(CHANGELOG): update for v0.9.1 release (#212) (ipfs/go-graphsync#212)
- fix(message): fix dropping of response extensions (#211) (ipfs/go-graphsync#211)
- docs(CHANGELOG): update change log (ipfs/go-graphsync#208)
- docs(README): add notice about branch rename
- fix(graphsync): make sure linkcontext is passed (#207) (ipfs/go-graphsync#207)
- Merge final v0.6.x commit history, and 0.8.0 changelog (#205) (ipfs/go-graphsync#205)
- Fix broken link to IPLD selector documentation (#189) (ipfs/go-graphsync#189)
- fix: check errors before defering a close (#200) (ipfs/go-graphsync#200)
- chore: fix checks (#197) (ipfs/go-graphsync#197)
- Merge the v0.6.x commit history (#190) (ipfs/go-graphsync#190)
- Ready for universal CI (#187) (ipfs/go-graphsync#187)
- fix(requestmanager): pass through linksystem (#166) (ipfs/go-graphsync#166)
- fix missing word in section title (#179) (ipfs/go-graphsync#179)
- github.com/ipfs/go-ipfs-blockstore (v0.1.6 -> v0.2.1):
- fix: revert back to go-ipfs-ds-help@v0.1.1 (#92) (ipfs/go-ipfs-blockstore#92)
- feat: add context to interfaces & plumb through datastore contexts (#89) (ipfs/go-ipfs-blockstore#89)
- github.com/ipfs/go-ipfs-config (v0.16.0 -> v0.18.0):
- Release v0.18.0 (#159) (ipfs/go-ipfs-config#159)
- feat: add Addresses.AppendAnnounce (#135) (ipfs/go-ipfs-config#135)
- feat: omitempty Swarm.EnableRelayHop for circuit v1 migration (#157) (ipfs/go-ipfs-config#157)
- chore: omitempty Experimental.ShardingEnabled (#158) (ipfs/go-ipfs-config#158)
- chore: update comment to match struct
- Release v0.17.0 (#156) (ipfs/go-ipfs-config#156)
- feat: add a flag to enable the hole punching service (#155) (ipfs/go-ipfs-config#155)
- improve AutoRelay configuration, add config option for static relays (ipfs/go-ipfs-config#154)
- feat: Swarm.RelayService (circuit v2) (#146) (ipfs/go-ipfs-config#146)
- fix: String method on the OptionalString (#153) (ipfs/go-ipfs-config#153)
- sync: update CI config files (#152) (ipfs/go-ipfs-config#152)
- feat: OptionalString type and UnixFSShardingSizeThreshold (#149) (ipfs/go-ipfs-config#149)
- feat: pubsub and ipns pubsub flags (#145) (ipfs/go-ipfs-config#145)
- feat: add an OptionalDuration type (#148) (ipfs/go-ipfs-config#148)
- github.com/ipfs/go-ipfs-exchange-interface (v0.0.1 -> v0.1.0):
- Update version.json (#20) (ipfs/go-ipfs-exchange-interface#20)
- sync: update CI config files (#19) (ipfs/go-ipfs-exchange-interface#19)
- feat: add context to interface (#18) (ipfs/go-ipfs-exchange-interface#18)
- doc: add a lead maintainer
- github.com/ipfs/go-ipfs-exchange-offline (v0.0.1 -> v0.1.1):
- Version 0.1.1
- Version 0.1.0 (#43) (ipfs/go-ipfs-exchange-offline#43)
- feat: plumb through contexts (#42) (ipfs/go-ipfs-exchange-offline#42)
- sync: update CI config files (#41) (ipfs/go-ipfs-exchange-offline#41)
- fix staticcheck (ipfs/go-ipfs-exchange-offline#35)
- chore(gx): remove gx
- github.com/ipfs/go-ipfs-files (v0.0.8 -> v0.0.9):
- sync: update CI config files (ipfs/go-ipfs-files#40)
- fix: manually parse the content disposition to preserve directories (ipfs/go-ipfs-files#42)
- fix: round timestamps down by truncating them to seconds (ipfs/go-ipfs-files#41)
- sync: update CI config files (ipfs/go-ipfs-files#34)
- Fix test failure on Windows caused by nil
sys
in mockFileInfo
(ipfs/go-ipfs-files#39) - fix staticcheck (ipfs/go-ipfs-files#35)
- fix linters (ipfs/go-ipfs-files#33)
- github.com/ipfs/go-ipfs-pinner (v0.1.2 -> v0.2.1):
- feat: plumb through context changes (#18) (ipfs/go-ipfs-pinner#18)
- github.com/ipfs/go-ipfs-provider (v0.6.1 -> v0.7.1):
- Fix go vet and staticcheck (ipfs/go-ipfs-provider#40)
- feat: plumb through datastore contexts (#39) (ipfs/go-ipfs-provider#39)
- github.com/ipfs/go-ipfs-routing (v0.1.0 -> v0.2.1):
- Version 0.2.1
- Bump version to 0.2.0 (#29) (ipfs/go-ipfs-routing#29)
- feat: plumb through context changes (#28) (ipfs/go-ipfs-routing#28)
- sync: update CI config files (#27) (ipfs/go-ipfs-routing#27)
- fix staticcheck (ipfs/go-ipfs-routing#24)
- github.com/ipfs/go-merkledag (v0.4.0 -> v0.5.1):
- Version 0.5.1
- Version 0.5.0 (#79) (ipfs/go-merkledag#79)
- feat: plumb through contexts (#78) (ipfs/go-merkledag#78)
- sync: update CI config files (#77) (ipfs/go-merkledag#77)
- expose session construction to other callers
- fix RawNode incomplete stats
- github.com/ipfs/go-mfs (v0.1.2 -> v0.2.1):
- Version 0.2.1
- Version 0.2.0 (#96) (ipfs/go-mfs#96)
- support threshold based automatic sharding and unsharding of directories (#88) (ipfs/go-mfs#88)
- sync: update CI config files (#94) (ipfs/go-mfs#94)
- Fix lint errors (ipfs/go-mfs#90)
- remove Makefile (ipfs/go-mfs#89)
- github.com/ipfs/go-namesys (v0.3.1 -> v0.4.0):
- Release v0.4.0
- feat: plumb through datastore contexts
- sync: update CI config files (#23) (ipfs/go-namesys#23)
- github.com/ipfs/go-path (v0.1.2 -> v0.2.1):
- Version 0.2.1
- Version 0.2.0 (#48) (ipfs/go-path#48)
- feat: plumb through context changes (#47) (ipfs/go-path#47)
- sync: update CI config files (#46) (ipfs/go-path#46)
- Revert "feat: plumb through context changes"
- feat: plumb through context changes
- github.com/ipfs/go-peertaskqueue (v0.4.0 -> v0.7.0):
- feat: optimize checking if a new task is "better" (ipfs/go-peertaskqueue#19)
- Adds customizable prioritization logic for peertracker and peertaskqueue (ipfs/go-peertaskqueue#17)
- When priority is equal, use FIFO (ipfs/go-peertaskqueue#16)
- github.com/ipfs/go-unixfs (v0.2.5 -> v0.3.1):
- Version 0.3.1
- Version 0.3.0 (#114) (ipfs/go-unixfs#114)
- feat: plumb through datastore context changes
- Size-based unsharding (#94) (ipfs/go-unixfs#94)
- sync: update CI config files (#112) (ipfs/go-unixfs#112)
- chore(deps): move bitfield to ipfs org (ipfs/go-unixfs#98)
- fix staticcheck (ipfs/go-unixfs#95)
- fix(directory): initialize size when computing it (ipfs/go-unixfs#93)
- fix: always return upgradeable instead of basic dir (#92) (ipfs/go-unixfs#92)
- feat: switch to HAMT based on size (#91) (ipfs/go-unixfs#91)
- go fmt
- fix: add pointer receiver
- add test
- feat: add UpgradeableDirectory
- github.com/ipfs/interface-go-ipfs-core (v0.5.1 -> v0.5.2):
- fix: check errors by string (ipfs/interface-go-ipfs-core#76)
- github.com/ipfs/tar-utils (v0.0.1 -> v0.0.2):
- Release v0.0.2 (#8) (ipfs/tar-utils#8)
- sync: update CI config files (ipfs/tar-utils#7)
- sync: update CI config files (#6) (ipfs/tar-utils#6)
- allow .. in file and directory names (ipfs/tar-utils#5)
- github.com/ipld/go-car (v0.3.1 -> v0.3.2):
- Expose selector traversal options for SelectiveCar (ipld/go-car#251)
- Implement API to allow replacing root CIDs in a CARv1 or CARv2
- blockstore: OpenReadWrite should not modify if it refuses to resume
- clarify the relation between StoreIdentityCIDs and SetFullyIndexed
- Implement options to handle
IDENTITY
CIDs gracefully - Combine API options for simplicity and logical coherence
- Add test script for car verify (#236) (ipld/go-car#236)
- cmd/car: add first testscript tests
- integrate
car/
cli intocmd/car
(#233) (ipld/go-car#233) - Add
car get-dag
command (#232) (ipld/go-car#232) - Separate CLI to separate module (#231) (ipld/go-car#231)
- add
get block
to car cli (#230) (ipld/go-car#230) - use file size when loading from v1 car (#229) (ipld/go-car#229)
- add interface describing iteration (#228) (ipld/go-car#228)
- Add
list
andfilter
commands (#227) (ipld/go-car#227) - Add
car split
command (#226) (ipld/go-car#226) - Make
MultihashIndexSorted
the default index codec for CARv2 - Add carve utility for updating the index of a car{v1,v2} file (#219) (ipld/go-car#219)
- Ignore records with
IDENTITY
CID inIndexSorted
- Fix index GetAll infinite loop if function always returns
true
- Expose the ability to iterate over records in
MultihasIndexSorted
- avoid another alloc per read byte
- avoid allocating on every byte read
- Implement new index type that also includes mutltihash code
- Return
nil
as Index reader when reading indexless CARv2 - Assert
OpenReader
from file does not panic after closure - Document performance caveats of
ExtractV1File
and address comments - Implement utility to extract CARv1 from a CARv2
- v2/blockstore: add ReadWrite.Discard
- update LICENSE files to point to the new gateway
- re-add root LICENSE file
- v2: stop using a symlink for LICENSE.md
- Update the readme with link to examples
- update package godocs and root level README for v2
- blockstore: stop embedding ReadOnly in ReadWrite
- Implement version agnostic streaming CAR block iterator
- blockstore: use errors when API contracts are broken
- add the first read-only benchmarks
- Implement reader block iterator over CARv1 or CARv2
- Propagate async
blockstore.AllKeysChan
errors via context - Add zero-length sections as EOF option to internal CARv1 reader
- Improve error handing in tests
- Allow
ReadOption
s to be set when getting or generating index - Use
ioutil.TempFile
to simplify file creation in index example - Avoid writing to files in testdata
- blockstore: implement UseWholeCIDs
- Merge wip-v2 into master (#178) (ipld/go-car#178)
- github.com/ipld/go-ipld-prime (v0.12.2 -> v0.14.2):
- dagcbor: coerce undef to null. (ipld/go-ipld-prime#308)
- fluent: add toInterface (#304) (ipld/go-ipld-prime#304)
- traversal: s/Walk/WalkLocal/
- traversal: add a primitive walk function.
- Remove dependency to
go-wish
- mark v0.14.0
- (ipld/go-ipld-prime#279)
- Port
traversal
package tests to quicktest - Port
codec
package tests to quicktest - changelog: backfill.
- Gracefully handle
TypedNode
withnil
type of kindMap
- Gracefully print typed nodes with
nil
type - Implement handling of
Link
and[]byte
inprinter
(#294) (ipld/go-ipld-prime#294) - changelog: backfill for the v0.12.x series.
- readme: introduce a migration guide.
- Port
fluent
package tests to quicktest - Port
datamodel
package tests to quicktest - Port
adl
package tests to quicktest - Port
node
package tests to quicktest - node/bindnode: support links in ProduceGoTypes
- bump CI to Go 1.16 and 1.17
- node/bindnode: support links in schema-type verification
- node/bindnode: export ProduceGoTypes
- all: fix "an" typos after the ipld->datamodel refactor
- node/bindnode: fix test code after two PR merges
- add LoadSchema APIs to the root package
- storage: add 'Has' feature. (ipld/go-ipld-prime#276)
- node/bindnode: start verifying schema compatibility
- linking: add LoadRaw and LoadPlusRaw functions to LinkSystem. (ipld/go-ipld-prime#267)
- node/bindnode: add support for lists behind kinded unions
- node/bindnode: also run TestPrototype with just schemas
- node/bindnode: polish a few TODO panics away
- node/bindnode: add support for all scalars behind kinded unions
- node/bindnode: get closer to passing the Links schema tests
- start using Rod's schema tests from ipld/ipld
- fully support parsing, encoding, and decoding the schema-schema
- node/bindnode: add native support for cid.Cid
- A more Featureful Approach to Storage APIs (ipld/go-ipld-prime#265)
- Add a cidlink.Memory storage option (#266) (ipld/go-ipld-prime#266)
- Improve docs for AssignNode; and datamodel.Copy function. (ipld/go-ipld-prime#264)
- schemadsl: assign the struct representation.
- schema,tests,gen/go: more tests, gen union fixes. (ipld/go-ipld-prime#257)
- fix: deal with LinkRevisit->LinkVisitOnlyOnce change
- traversal: the link-visit-only-once behavior should require opt-in, rather than defaulting to on.
- chore: add LinkRevisit:false traversal test
- traversal: track seen links, and revisit only if configured to do so.
- fix: use datamodel.Node selectors
- Revert encode round-trip to leave unencoded node test intact
- Add more walk tests, including tests for use of SkipMe
- Round-trip test nodes through custom codec to ensure stability
- Don't abort block processing when encountering SkipMe
- traversal: implement monotonically decrementing budgets. (ipld/go-ipld-prime#260)
- Use datamodel.Node for "Common" selector variants
- schema/dmt: first pass at a parser (ipld/go-ipld-prime#253)
- drop codectools.
- drop jst codec. It lives in https://github.com/warpfork/go-jst/ now.
- drop dagjson2.
- fix(traversal): properly wrap errors
- printer: empty maps and lists and structs should stay on one line.
- schema: turn TypeName into an alias
- schema/dmt: sync with schema-schema changes, finish Compile
- schema: add ways to set and access the ImplicitValue for a struct field.
- schema: accessor for TypeEnum.Representation.
- schema: finish minimum viable support for describing enum types.
- github.com/libp2p/go-conn-security-multistream (v0.2.1 -> v0.3.0):
- use the new SecureTransport and SecureMuxer interfaces (#36) (libp2p/go-conn-security-multistream#36)
- fix go vet and staticcheck (libp2p/go-conn-security-multistream#33)
- github.com/libp2p/go-libp2p (v0.15.0 -> v0.16.0):
- release v0.16.0 (libp2p/go-libp2p#1246)
- allow the ping protocol on transient connections (libp2p/go-libp2p#1244)
- make the Type field required in the HolePunch protobuf (libp2p/go-libp2p#1241)
- reject hole punching attempts when we don't have any public addresses (libp2p/go-libp2p#1214)
- refactor the AutoRelay code (libp2p/go-libp2p#1240)
- remove dead API link in README (libp2p/go-libp2p#1233)
- pass static relays to EnableAutoRelay, deprecate libp2p.StaticRelays and libp2p.DefaultStaticRelays (libp2p/go-libp2p#1239)
- feat: plumb through peerstore context changes (#1237) (libp2p/go-libp2p#1237)
- emit the EvtPeerConnectednessChanged event (libp2p/go-libp2p#1230)
- update go-libp2p-swarm to v0.7.0 (libp2p/go-libp2p#1226)
- sync: update CI config files (#1225) (libp2p/go-libp2p#1225)
- simplify circuitv2 package structure (libp2p/go-libp2p#1224)
- use a random string for the mDNS peer-name (libp2p/go-libp2p#1222)
- remove {Un}RegisterNotifee functions from mDNS service (libp2p/go-libp2p#1220)
- fix structured logging in holepunch coordination (libp2p/go-libp2p#1213)
- fix flaky TestStBackpressureStreamWrite test (libp2p/go-libp2p#1212)
- properly close hosts in mDNS tests (libp2p/go-libp2p#1216)
- close the ObserverAddrManager when the ID service is closed (libp2p/go-libp2p#1218)
- make it possible to pass options to a transport constructor (libp2p/go-libp2p#1205)
- remove goprocess from the NATManager (libp2p/go-libp2p#1193)
- add an option to start the relay v2 (libp2p/go-libp2p#1197)
- fix flaky TestFastDisconnect identify test (libp2p/go-libp2p#1200)
- chore: update go-tcp-transport to v0.3.0 (libp2p/go-libp2p#1203)
- fix: skip variadic params in constructors (libp2p/go-libp2p#1204)
- fix flaky BasicHost tests (libp2p/go-libp2p#1202)
- remove dependency on github.com/ipfs/go-detect-race (libp2p/go-libp2p#1201)
- fix flaky TestEndToEndSimConnect holepunching test (libp2p/go-libp2p#1191)
- autorelay support for circuitv2 relays (#1198) (libp2p/go-libp2p#1198)
- reject circuitv2 reservations with nonsensical expiration times (libp2p/go-libp2p#1199)
- Tag relay hops in relay implementations (libp2p/go-libp2p#1188)
- Add standalone implementation of v1 Relay (#1186) (libp2p/go-libp2p#1186)
- remove the context from the libp2p and the Host constructor (libp2p/go-libp2p#1190)
- don't use a context to shut down the circuitv2 (libp2p/go-libp2p#1185)
- fix: remove v1 go-log dep (libp2p/go-libp2p#1189)
- don't use the context to shut down the relay (libp2p/go-libp2p#1184)
- Use circuitv2 code (#1183) (libp2p/go-libp2p#1183)
- clean up badges in README (libp2p/go-libp2p#1179)
- remove recommendation about Go module proxy from README (libp2p/go-libp2p#1180)
- merge branch 'hole-punching'
- don't use a context for closing the ObservedAddrManager (libp2p/go-libp2p#1175)
- move the circuit v2 code here (libp2p/go-libp2p#1174)
- make QUIC a default transport (libp2p/go-libp2p#1128)
- stop using jbenet/go-cienv (libp2p/go-libp2p#1176)
- fix flaky TestObsAddrSet test (libp2p/go-libp2p#1172)
- clean up messy defer logic in IDService.sendIdentifyResp (libp2p/go-libp2p#1169)
- remove secio from README, add noise (libp2p/go-libp2p#1165)
- github.com/libp2p/go-libp2p-asn-util (v0.0.0-20200825225859-85005c6cf052 -> v0.1.0):
- Update from upstream and make regeneration easier (#17) (libp2p/go-libp2p-asn-util#17)
- add license file so it can be found by go-licenses (libp2p/go-libp2p-asn-util#10)
- refactor: rename ASN table files (libp2p/go-libp2p-asn-util#9)
- Library for IP -> ASN mapping (libp2p/go-libp2p-asn-util#1)
- github.com/libp2p/go-libp2p-autonat (v0.4.2 -> v0.6.0):
- Version 0.6.0 (#112) (libp2p/go-libp2p-autonat#112)
- feat: plumb through contexts from peerstore (#111) (libp2p/go-libp2p-autonat#111)
- sync: update CI config files (#110) (libp2p/go-libp2p-autonat#110)
- remove context from constructor, implement a proper Close method (libp2p/go-libp2p-autonat#109)
- fix stream deadlines (libp2p/go-libp2p-autonat#107)
- disable failing integration test (libp2p/go-libp2p-autonat#108)
- fix staticcheck (libp2p/go-libp2p-autonat#103)
- github.com/libp2p/go-libp2p-core (v0.9.0 -> v0.11.0):
- release v0.11.0 (#217) (libp2p/go-libp2p-core#217)
- remove the ConnHandler (#214) (libp2p/go-libp2p-core#214)
- sync: update CI config files (#216) (libp2p/go-libp2p-core#216)
- remove the Process from the Network interface (#212) (libp2p/go-libp2p-core#212)
- pass the peer ID to SecureInbound in the SecureTransport and SecureMuxer (#211) (libp2p/go-libp2p-core#211)
- save the role (client, server) in the simultaneous connect context (#210) (libp2p/go-libp2p-core#210)
- sync: update CI config files (#209) (libp2p/go-libp2p-core#209)
- github.com/libp2p/go-libp2p-discovery (v0.5.1 -> v0.6.0):
- feat: plumb peerstore contexts changes through (#75) (libp2p/go-libp2p-discovery#75)
- remove deprecated types (libp2p/go-libp2p-discovery#73)
- github.com/libp2p/go-libp2p-kad-dht (v0.13.1 -> v0.15.0):
- Bump version to 0.15.0 (#755) (libp2p/go-libp2p-kad-dht#755)
- sync: update CI config files (#754) (libp2p/go-libp2p-kad-dht#754)
- feat: plumb through datastore contexts (#753) (libp2p/go-libp2p-kad-dht#753)
- custom ProviderManager that brokers AddrInfos (#751) (libp2p/go-libp2p-kad-dht#751)
- feat: make compatible with go-libp2p 0.15 (libp2p/go-libp2p-kad-dht#747)
- sync: update CI config files (libp2p/go-libp2p-kad-dht#743)
- Disallow GetPublicKey when DisableValues is passed (libp2p/go-libp2p-kad-dht#604)
- github.com/libp2p/go-libp2p-nat (v0.0.6 -> v0.1.0):
- remove Codecov config file (libp2p/go-libp2p-nat#39)
- stop using goprocess for shutdown (libp2p/go-libp2p-nat#38)
- chore: update go-log (libp2p/go-libp2p-nat#37)
- remove unused field permanent from mapping (libp2p/go-libp2p-nat#33)
- github.com/libp2p/go-libp2p-noise (v0.2.2 -> v0.3.0):
- add the peer ID to SecureInbound (libp2p/go-libp2p-noise#104)
- update go-libp2p-core, remove integration test (libp2p/go-libp2p-noise#102)
- github.com/libp2p/go-libp2p-peerstore (v0.2.8 -> v0.4.0):
- Update version.json (#178) (libp2p/go-libp2p-peerstore#178)
- limit the number of protocols we store per peer (libp2p/go-libp2p-peerstore#172)
- sync: update CI config files (#177) (libp2p/go-libp2p-peerstore#177)
- feat: plumb through datastore contexts (#176) (libp2p/go-libp2p-peerstore#176)
- remove leftover peerstore implementation in the root package (libp2p/go-libp2p-peerstore#173)
- fix: replace deprecated call (libp2p/go-libp2p-peerstore#168)
- feat: remove queue (libp2p/go-libp2p-peerstore#166)
- remove deprecated types (libp2p/go-libp2p-peerstore#165)
- github.com/libp2p/go-libp2p-pubsub (v0.5.4 -> v0.6.0):
- feat: plumb through context changes (#459) (libp2p/go-libp2p-pubsub#459)
- support MinTopicSize without a discovery mechanism
- clear peerPromises map when fullfilling a promise
- README: remove obsolete notice, fix example code for tracing.
- remove peer filter check from subscriptions (#453) (libp2p/go-libp2p-pubsub#453)
- Create peer filter option
- github.com/libp2p/go-libp2p-pubsub-router (v0.4.0 -> v0.5.0):
- Version 0.5.0
- feat: plumb through datastore contexts
- sync: update CI config files (#86) (libp2p/go-libp2p-pubsub-router#86)
- Remove arbitrary sleeps from tests (libp2p/go-libp2p-pubsub-router#87)
- cleanup: fix staticcheck failures (libp2p/go-libp2p-pubsub-router#84)
- Add WithDatastore option. (libp2p/go-libp2p-pubsub-router#82)
- github.com/libp2p/go-libp2p-quic-transport (v0.12.0 -> v0.15.0):
- release v0.15.0 (#241) (libp2p/go-libp2p-quic-transport#241)
- reuse the same router until we change listeners (libp2p/go-libp2p-quic-transport#240)
- release v0.14.0 (libp2p/go-libp2p-quic-transport#237)
- fix error assertions in the tracer (libp2p/go-libp2p-quic-transport#234)
- sync: update CI config files (#235) (libp2p/go-libp2p-quic-transport#235)
- read the client option from the simultaneous connect context (libp2p/go-libp2p-quic-transport#230)
- github.com/libp2p/go-libp2p-swarm (v0.5.3 -> v0.8.0):
- Version 0.8.0 (#292) (libp2p/go-libp2p-swarm#292)
- feat: plumb contexts through from peerstore (#290) (libp2p/go-libp2p-swarm#290)
- release v0.7.0 (libp2p/go-libp2p-swarm#289)
- update go-tcp-transport to v0.4.0 (libp2p/go-libp2p-swarm#287)
- remove the ConnHandler (libp2p/go-libp2p-swarm#286)
- sync: update CI config files (#288) (libp2p/go-libp2p-swarm#288)
- remove a lot of incorrect statements from the README (libp2p/go-libp2p-swarm#284)
- unexport the DialSync (libp2p/go-libp2p-swarm#281)
- add an error return value to the constructor (libp2p/go-libp2p-swarm#280)
- use functional options to configure the swarm (libp2p/go-libp2p-swarm#279)
- stop using goprocess to control teardown (libp2p/go-libp2p-swarm#278)
- read and use the direction from the simultaneous connect context (libp2p/go-libp2p-swarm#277)
- simplify the DialSync code (libp2p/go-libp2p-swarm#272)
- remove redundant self-dialing check, simplify starting of dialWorkerLoop (libp2p/go-libp2p-swarm#273)
- add a test case for the testing package (libp2p/go-libp2p-swarm#276)
- simplify limiter by removing the injected isFdConsumingFnc (libp2p/go-libp2p-swarm#274)
- update badges (libp2p/go-libp2p-swarm#271)
- remove unused context in Swarm.dialWorkerLoop (libp2p/go-libp2p-swarm#268)
- remove Codecov config (libp2p/go-libp2p-swarm#270)
- fix race condition in TestFailFirst (libp2p/go-libp2p-swarm#269)
- github.com/libp2p/go-libp2p-testing (v0.4.2 -> v0.5.0):
- chore: update go-libp2p-core to v0.10.0 (libp2p/go-libp2p-testing#38)
- sync: update CI config files (#37) (libp2p/go-libp2p-testing#37)
- github.com/libp2p/go-libp2p-tls (v0.2.0 -> v0.3.1):
- release v0.3.1 (libp2p/go-libp2p-tls#101)
- set a random certificate subject (libp2p/go-libp2p-tls#100)
- sync: update CI config files (#96) (libp2p/go-libp2p-tls#96)
- add the peer ID to SecureInbound (libp2p/go-libp2p-tls#94)
- sync: update CI config files (libp2p/go-libp2p-tls#91)
- github.com/libp2p/go-libp2p-transport-upgrader (v0.4.6 -> v0.5.0):
- increase timeout in TestConnectionsClosedIfNotAccepted on CI (libp2p/go-libp2p-transport-upgrader#85)
- add the peer ID to SecureInbound (libp2p/go-libp2p-transport-upgrader#83)
- github.com/libp2p/go-msgio (v0.0.6 -> v0.1.0):
- sync: update CI config files (#27) (libp2p/go-msgio#27)
- remove .gxignore file (libp2p/go-msgio#24)
- remove Codecov config (libp2p/go-msgio#26)
- remove "Chan" type (libp2p/go-msgio#23)
- github.com/libp2p/go-nat (v0.0.5 -> v0.1.0):
- pass a context to DiscoverGateway (libp2p/go-nat#23)
- github.com/libp2p/go-reuseport (v0.0.2 -> v0.1.0):
- stop using github.com/pkg/errors (libp2p/go-reuseport#85)
- sync: update CI config files (#84) (libp2p/go-reuseport#84)
- github.com/libp2p/go-reuseport-transport (v0.0.5 -> v0.1.0):
- remove Codecov config file (libp2p/go-reuseport-transport#36)
- chore: update go-log to v2 (libp2p/go-reuseport-transport#35)
- sync: update CI config files (libp2p/go-reuseport-transport#31)
- github.com/libp2p/go-tcp-transport (v0.2.8 -> v0.4.0):
- release v0.4.0 (libp2p/go-tcp-transport#108)
- sync: update CI config files (#107) (libp2p/go-tcp-transport#107)
- remove the deprecated IPFS_REUSEPORT command line flag (libp2p/go-tcp-transport#104)
- add options to the constructor (libp2p/go-tcp-transport#99)
- remove the context from the libp2p constructor in README (libp2p/go-tcp-transport#101)
- don't use libp2p.ChainOption in README (libp2p/go-tcp-transport#102)
- remove incorrect statement about dns addresses in README (libp2p/go-tcp-transport#100)
- use the assigned role when upgrading a sim open connection (libp2p/go-tcp-transport#95)
- chore: update go-log to v2 (libp2p/go-tcp-transport#97)
- simplify dial timeout context (libp2p/go-tcp-transport#94)
- github.com/libp2p/go-yamux/v2 (v2.2.0 -> v2.3.0):
- limit the number of concurrent incoming streams (libp2p/go-yamux#66)
- drastically reduce allocations in ring buffer implementation (#64) (libp2p/go-yamux#64)
- sync: update CI config files (#63) (libp2p/go-yamux#63)
- remove call to asyncNotify in Stream.Read
- github.com/libp2p/zeroconf/v2 (v2.0.0 -> v2.1.1):
- fix flaky TTL test (libp2p/zeroconf#18)
- implement a clean shutdown of the probe method (libp2p/zeroconf#16)
- remove dependency on the backoff library (libp2p/zeroconf#17)
- Don't stop browsing after ~15min (libp2p/zeroconf#13)
- fix delays when sending initial probe packets (libp2p/zeroconf#14)
- improve starting of mDNS service in tests, stop using pkg/errors (libp2p/zeroconf#15)
- update import path to include v2 in README (libp2p/zeroconf#11)
- github.com/lucas-clemente/quic-go (v0.23.0 -> v0.24.0):
- don't unlock the receive stream mutex for copying from STREAM frames (lucas-clemente/quic-go#3290)
- List projects using quic-go (lucas-clemente/quic-go#3266)
- disable Path MTU Discovery on Windows (lucas-clemente/quic-go#3276)
- enter the regular run loop if no undecryptable packet was processed (lucas-clemente/quic-go#3268)
- Allow use of custom port value in Alt-Svc header. (lucas-clemente/quic-go#3272)
- disable the goconst linter (lucas-clemente/quic-go#3286)
- use x/net/ipv{4,6} to construct oob info when writing packets (#3278) (lucas-clemente/quic-go#3278)
- run gofmt to add the new go:build tags (lucas-clemente/quic-go#3277)
- fix log string in client example (lucas-clemente/quic-go#3264)
- github.com/multiformats/go-multiaddr (v0.4.0 -> v0.4.1):
- add the plaintextv2 protocol (multiformats/go-multiaddr#165)
- github.com/multiformats/go-multihash (v0.0.15 -> v0.1.0):
- bump version to v0.1.0 (multiformats/go-multihash#151)
- add version.json per tooling convention.
- murmur3 support (#150) (multiformats/go-multihash#150)
- Add variations of sha2 (multiformats/go-multihash#149)
- don't use pointers for Multihash.String
- Add blake3 hash and sharness tests (multiformats/go-multihash#147)
- remove Makefile (multiformats/go-multihash#142)
- fix staticcheck (multiformats/go-multihash#141)
- New SumStream function reads from io.Reader (multiformats/go-multihash#138)
- github.com/warpfork/go-testmark (v0.3.0 -> v0.9.0):
- testexec: will now always set up tmpdirs.
- testexec: fix typo in error message.
- testexec: subtest ("then-*") feature (warpfork/go-testmark#7)
- testexec: quote error from child; attribution better via more t.Helper.
- Improve documentation of format.
- Rename Hunk.BlockTag -> InfoString.
- testexec: will now create tmpdirs and files for you if you have an 'fs' entry tree.
- testexec: getting exit codes correctly. (warpfork/go-testmark#6)
- fix parsing CRLF files, part 3 (warpfork/go-testmark#5)
- fix parsing CRLF files, part 2 (warpfork/go-testmark#4)
- testexec: support both simple sequence and script mode.
- Proper tests for read function.
- avoid creeping extra linebreaks at the end of a patched document.
- refrain from making double linebreaks when patching with content that ends in a linebreak.
- Merge branch 'testexec'
- add support for parsing CRLF line endings (warpfork/go-testmark#3)
- link to patch example code
- More readme; and, parsing recommendations document.
- Further improve readme.
❤️ Contributors
Contributor | Commits | Lines ± | Files Changed |
---|---|---|---|
Will | 13 | +73226/-130481 | 43 |
Masih H. Derkani | 99 | +10549/-5799 | 489 |
hannahhoward | 43 | +5515/-3293 | 233 |
Daniel Martí | 60 | +5312/-2883 | 208 |
Marten Seemann | 175 | +4839/-3254 | 396 |
Eric Myhre | 73 | +3924/-3328 | 175 |
Jessica Schilling | 52 | +2709/-2386 | 75 |
Rod Vagg | 30 | +2719/-1703 | 79 |
vyzo | 10 | +3516/-177 | 87 |
Gus Eggert | 64 | +1677/-1416 | 147 |
Adin Schmahmann | 23 | +1708/-381 | 95 |
Lucas Molas | 14 | +1557/-365 | 48 |
Will Scott | 7 | +1846/-15 | 34 |
Steven Allen | 32 | +537/-897 | 56 |
Cory Schwartz | 3 | +614/-109 | 12 |
rht | 3 | +576/-4 | 7 |
Simon Zhu | 9 | +352/-51 | 16 |
Petar Maymounkov | 7 | +173/-167 | 23 |
RubenKelevra | 1 | +107/-188 | 1 |
jwh | 2 | +212/-80 | 7 |
longfeiW | 1 | +4/-249 | 10 |
guseggert | 5 | +230/-21 | 11 |
Kevin Neaton | 8 | +137/-80 | 13 |
Takashi Matsuda | 1 | +199/-0 | 5 |
Andrey Kostakov | 1 | +107/-49 | 2 |
Jesse Bouwman | 1 | +151/-0 | 7 |
web3-bot | 39 | +136/-3 | 52 |
Marcin Rataj | 16 | +62/-57 | 25 |
Marco Munizaga | 1 | +118/-0 | 2 |
Aaron Riekenberg | 4 | +64/-52 | 6 |
Ian Davis | 4 | +81/-32 | 7 |
Jorropo | 2 | +79/-19 | 6 |
Mohsin Zaidi | 1 | +89/-1 | 20 |
Andey Robins | 1 | +70/-3 | 3 |
gammazero | 3 | +40/-25 | 4 |
Steve Loeppky | 2 | +26/-27 | 3 |
Dimitris Apostolou | 1 | +25/-25 | 15 |
Sudarshan Reddy | 1 | +9/-40 | 1 |
Richard Littauer | 2 | +42/-1 | 3 |
pymq | 1 | +32/-8 | 2 |
Dirk McCormick | 2 | +23/-1 | 2 |
Nicholas Bollweg | 1 | +21/-0 | 1 |
anorth | 1 | +14/-6 | 2 |
Jack Loughran | 1 | +16/-0 | 2 |
whyrusleeping | 2 | +11/-2 | 2 |
bt90 | 1 | +13/-0 | 1 |
Yi Cao | 1 | +10/-0 | 1 |
Max | 1 | +7/-3 | 1 |
Juan Batiz-Benet | 2 | +8/-2 | 2 |
Keenan Nemetz | 1 | +8/-0 | 1 |
muXxer | 1 | +3/-3 | 1 |
galargh | 2 | +3/-3 | 3 |
Didrik Nordström | 1 | +2/-4 | 1 |
Ben Lubar | 1 | +3/-3 | 1 |
arjunraghurama | 1 | +5/-0 | 1 |
Whyrusleeping | 1 | +3/-2 | 1 |
TUSF | 1 | +3/-2 | 3 |
mathew-cf | 1 | +3/-1 | 2 |
Stephen Whitmore | 1 | +2/-2 | 1 |
Song Zhu | 1 | +2/-2 | 1 |
Michael Muré | 1 | +4/-0 | 1 |
Alex Good | 1 | +4/-0 | 2 |
aarshkshah1992 | 1 | +2/-1 | 1 |
susarlanikhilesh | 1 | +1/-1 | 1 |
falstack | 1 | +1/-1 | 1 |
Michael Vorburger ⛑️ | 1 | +1/-1 | 1 |
Ismail Khoffi | 1 | +1/-1 | 1 |
George Xie | 1 | +1/-1 | 1 |
Bryan Stenson | 1 | +1/-1 | 1 |
Lars Gierth | 1 | +1/-0 | 1 |