This release includes security fixes for various DOS vectors when importing untrusted user input with ipfs dag import
and the v0/dag/import
endpoint.
View the linked security advisory for more information.
Full Changelog
- github.com/ipfs/go-ipfs:
- chore: update car
- github.com/ipld/go-car (v0.3.2 -> v0.4.0) & (v2.1.1 -> v2.4.0):
- Bump version in prep for releasing go-car
v0
- Revert changes to
insertionindex
- Revert changes to
index.Index
while keeping most of security fixes - Return error when section length is invalid
varint
- Drop repeated package name from
CarStats
- Benchmark
Reader.Inspect
with and without hash validation - Use consistent CID mismatch error in
Inspect
andBlockReader.Next
- Use streaming APIs to verify the hash of blocks in CAR
Inspect
- test: add fuzzing for reader#Inspect
- feat: add block hash validation to Inspect()
- feat: add Reader#Inspect() function to check basic validity of a CAR and return stats
- Remove support for
ForEach
enumeration from car-index-sorted - Use a fix code as the multihash code for
CarIndexSorted
- Fix testutil assertion logic and update index generation tests
- fix: tighter constraint of singleWidthIndex width, add index recommendation docs
- fix: explicitly disable serialization of insertionindex
- feat: MaxAllowed{Header,Section}Size option
- feat: MaxAllowedSectionSize default to 32M
- fix: use CidFromReader() which has overread and OOM protection
- fix: staticcheck catches
- fix: revert to internalio.NewOffsetReadSeeker in Reader#IndexReader
- fix index comparisons
- feat: Refactor indexes to put storage considerations on consumers
- test: v2 add fuzzing of the index
- fix: v2 don't divide by zero in width indexes
- fix: v2 don't allocate indexes too big
- test: v2 add fuzzing to Reader
- fix: v2 don't accept overflowing offsets while reading v2 headers
- test: v2 add fuzzing to BlockReader
- fix: v2 don't OOM if the header size is too big
- test: add fuzzing of NewCarReader
- fix: do bound check while checking for CIDv0
- fix: don't OOM if the header size is too big
- Add API to regenerate index from CARv1 or CARv2
- PrototypeChooser support (#305) (ipld/go-car#305)
- bump to newer blockstore err not found (#301) (ipld/go-car#301)
- Car command supports for
largebytes
nodes (#296) (ipld/go-car#296) - fix(test): rootless fixture should have no roots, not null roots
- Allow extraction of a raw unixfs file (#284) (ipld/go-car#284)
- cmd/car: use a better install command in the README
- feat: --version selector for
car create
& update deps - feat: add option to create blockstore that writes a plain CARv1 (#288) (ipld/go-car#288)
- add
car detach-index list
to list detached index contents (#287) (ipld/go-car#287) - add
car root
command (#283) (ipld/go-car#283) - make specification of root cid in get-dag command optional (#281) (ipld/go-car#281)
- Update
version.json
after manual tag push - Update v2 to context datastores (#275) (ipld/go-car#275)
- update context datastore (ipld/go-car#273)
- Traversal-based car creation (#269) (ipld/go-car#269)
- Seek to start before index generation in
ReadOnly
blockstore - support extraction of unixfs content stored in car files (#263) (ipld/go-car#263)
- Add a bare bones readme to the car CLI (#262) (ipld/go-car#262)
- sync: update CI config files (#261) (ipld/go-car#261)
- fix!: use -version=n instead of -v1 for index command
- feat: fix get-dag and add version=1 option
- creation of car from file / directory (#246) (ipld/go-car#246)
- forEach iterates over index in stable order (#258) (ipld/go-car#258)
- Bump version in prep for releasing go-car
- github.com/multiformats/go-multicodec (v0.4.1 -> v0.5.0):
- Bump version to 0.5.0
- Bump version to 0.4.2
- deps: update stringer version in go generate command
- docs(readme): improved usage examples (#66) (multiformats/go-multicodec#66)
Contributor | Commits | Lines ± | Files Changed |
---|---|---|---|
Masih H. Derkani | 27 | +1494/-1446 | 100 |
Rod Vagg | 31 | +2021/-606 | 105 |
Will | 19 | +1898/-151 | 69 |
Jorropo | 27 | +1638/-248 | 76 |
Aayush Rajasekaran | 1 | +130/-100 | 10 |
whyrusleeping | 1 | +24/-22 | 4 |
Marcin Rataj | 1 | +27/-1 | 1 |
We're happy to announce go-ipfs 0.13.0, packed full of changes and improvements!
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.
Below is an outline of all that is in this release, so you get a sense of all that's included.
- 🛠 BREAKING CHANGES
- 🔦 Highlights
- 🧑💼 libp2p Network Resource Manager (
Swarm.ResourceMgr
) - 🔃 Relay V2 client with auto discovery (
Swarm.RelayClient
) - 🌉 HTTP Gateway improvements
- 🕵️ OpenTelemetry tracing
- 🩺 Built-in
ipfs diag profile
to ease debugging - 🔑 Support for PEM/PKCS8 for key import/export
- 🧹 Using standard IPLD codec names across the CLI/HTTP API
- 🐳 Custom initialization for Docker
- RPC API docs for experimental and deprecated commands
- Yamux over Mplex
- 🧑💼 libp2p Network Resource Manager (
ipfs block put
command returns a CIDv1 with raw
codec by default now.
ipfs block put --cid-codec
makesblock put
return CID with alternative codec- This impacts only the returned CID; it does not trigger any validation or data transformation.
- Retrieving a block with a different codec or CID version than it was put with is valid.
- Codec names are validated against tables from go-multicodec library.
ipfs block put --format
is deprecated. It used incorrect codec names and should be avoided for new deployments. Use it only if you need the old, invalid behavior, namely:ipfs block put --format=v0
will produce CIDv0 (implicit dag-pb)ipfs block put --format=cbor
will produce CIDv1 with dag-cbor (!)ipfs block put --format=protobuf
will produce CIDv1 with dag-pb (!)
- Now lists codecs from go-multicodec library.
ipfs cid codecs --supported
can be passed to only show codecs supported in various go-ipfs commands.
--codec
was removed and replaced with--mc
to ensure existing users are aware of the following changes:--mc protobuf
now correctly points to code0x50
(was0x70
, which isdab-pg
)--mc cbor
now correctly points to code0x51
(was0x71
, which isdag-cbor
)
- Daemon will refuse to start if long-deprecated RelayV1 config key
Swarm.EnableAutoRelay
orSwarm.DisableRelay
is set totrue
. - If
Swarm.Transports.Network.Relay
is disabled, thenSwarm.RelayService
andSwarm.RelayClient
are also disabled (unless they have been explicitly enabled).
- By default,
Swarm.RelayClient
does not use Circuit Relay V1. Circuit V1 support is only enabled whenSwarm.RelayClient.StaticRelays
are specified.
- go-libp2p 0.19 removed support for undocumented
ls
command (PR). If you are still using it for internal testing, it is time to refactor (example)
Directory listings returned by the HTTP Gateway won't have size column if the directory is bigger than Gateway.FastDirIndexThreshold
config (default is 100).
To understand the wider context why we made these changes, read Highlights below.
You can now easily bound how much resource usage libp2p consumes! This aids in protecting nodes from consuming more resources then are available to them.
The libp2p Network Resource Manager is disabled by default, but can be enabled via:
ipfs config --json Swarm.ResourceMgr.Enabled true
When enabled, it applies some safe defaults that can be inspected and adjusted with:
ipfs swarm stats --help
ipfs swarm limit --help
User changes persist to config at Swarm.ResourceMgr
.
The Resource Manager will be enabled by default in a future release.
All the pieces are enabled for hole-punching by default, improving connecting with nodes behind NATs and Firewalls!
This release enables Swarm.RelayClient
by default, along with circuit v2 relay discovery provided by go-libp2p v0.19.0. This means:
- go-ipfs will coordinate with the counterparty using a relayed connection, to upgrade to a direct connection through a NAT/firewall whenever possible.
- go-ipfs daemon will automatically use public relays if it detects that it cannot be reached from the public internet (e.g., it's behind a firewall). This results in a
/p2p-circuit
address from a public relay.
Notes:
Swarm.RelayClient
does not use Circuit Relay V1 nodes any more. Circuit V1 support is only enabled when static relays are specified inSwarm.RelayClient.StaticRelays
.- One can opt-out via
Swarm.EnableHolePunching
.
HTTP Gateway enables seamless interop with the existing Web, clients, user agents, tools, frameworks and libraries.
This release ships the first batch of improvements that enable creation of faster and smarter CDNs, and unblocks creation of light clients for Mobile and IoT.
Details below.
Alternative response formats from Gateway can be requested to avoid needing to trust a gateway.
For now, {format}
is limited to two options:
raw
– fetching single blockcar
– fetching entire DAG behind a CID as a CARv1 stream
When not set, the default UnixFS response is returned.
Why these two formats? Requesting Block or CAR for /ipfs/{cid}
allows a client to use gateways in a trustless fashion. These types of gateway responses can be verified locally and rejected if digest inside of requested CID does not match received bytes. This enables creation of "light IPFS clients" which use HTTP Gateways as inexpensive transport for content-addressed data, unlocking use in Mobile and IoT contexts.
Future releases will add support for dag-json and dag-cbor responses.
There are two ways for requesting CID specific response format:
- HTTP header:
Accept: application/vnd.ipld.{format}
- Examples: application/vnd.ipld.car, application/vnd.ipld.raw
- URL parameter:
?format=
- Useful for creating "Download CAR" links.
Usage examples:
- Downloading a single raw Block and manually importing it to the local datastore:
$ curl -H 'Accept: application/vnd.ipld.raw' "http://127.0.0.1:8080/ipfs/QmZULkCELmmk5XNfCgTnCyFgAVxBRBXyDHGGMVoLFLiXEN" --output block.bin
$ cat block.bin | ipfs block put
$ ipfs cat QmZULkCELmmk5XNfCgTnCyFgAVxBRBXyDHGGMVoLFLiXEN
hello
- Downloading entire DAG as a CAR file and importing it:
$ ipfs resolve -r /ipns/webui.ipfs.io
/ipfs/bafybeiednzu62vskme5wpoj4bjjikeg3xovfpp4t7vxk5ty2jxdi4mv4bu
$ curl -H 'Accept: application/vnd.ipld.car' "http://127.0.0.1:8080/ipfs/bafybeiednzu62vskme5wpoj4bjjikeg3xovfpp4t7vxk5ty2jxdi4mv4bu" --output webui.car
$ ipfs dag import webui.car
$ ipfs dag stat bafybeiednzu62vskme5wpoj4bjjikeg3xovfpp4t7vxk5ty2jxdi4mv4bu --offline
Size: 27684934, NumBlocks: 394
See also:
- Content Addressable aRchives (CAR / .car) Specifications
- IANA media type definitions: application/vnd.ipld.car, application/vnd.ipld.raw
- ipfs-car - CLI tool for verifying and unpacking CAR files
- go-car, js-car – CAR libraries for GO and JS
Added Gateway.FastDirIndexThreshold
configuration, which allows for fast listings of big directories, without the linear slowdown caused by reading size metadata from child nodes.
As an example, the CID bafybeiggvykl7skb2ndlmacg2k5modvudocffxjesexlod2pfvg5yhwrqm
represents UnixFS directory with over 10k (10100) of files.
Opening it with go-ipfs 0.12 would require fetching size information of each file, which would take a long long time, most likely causing timeout in the browser or CDN, and introducing unnecessary burden on the gateway node.
go-ipfs 0.13 opens it instantly, because the number of items is bigger than the default Gateway.FastDirIndexThreshold
and only the root UnixFS node needs to be resolved before the HTML Dir Index is returned to the user.
Notes:
- The default threshold is 100 items.
- Setting to 0 will enable fast listings for all directories.
- CLI users will note that this is equivalent to running
ipfs ls -s --size=false --resolve-type=false /ipfs/bafybeiggvykl7skb2ndlmacg2k5modvudocffxjesexlod2pfvg5yhwrqm
. Now the same speed is available on the gateways.
Every response type has an unique Etag
which can be used by the client or CDN to save bandwidth, as a gateway does not need to resend a full response if the content was not changed.
Gateway evaluates Etags sent by a client in If-None-Match
and returns status code 304 (Not Modified) on strong or weak match (RFC 7232, 2.3).
X-Ipfs-Roots
is now returned with every Gateway response. It is a way to indicate all CIDs required for resolving path segments from X-Ipfs-Path
. Together, these two headers are meant to improve interop with existing HTTP software (load-balancers, caches, CDNs).
This additional information allows HTTP caches and CDNs to make better decisions around cache invalidation: not just invalidate everything under specific IPNS website when the root changes, but do more fine-grained cache invalidation by detecting when only a specific subdirectory (branch of a DAG) changes.
New metrics can be found at /debug/metrics/prometheus
on the RPC API port (127.0.0.1:5001
is the default):
gw_first_content_block_get_latency_seconds
– the time until the first content block is received on GET from the gateway (no matter the content or response types)gw_unixfs_file_get_duration_seconds
– the time to serve an entire UnixFS file from the gatewaygw_unixfs_gen_dir_listing_get_duration_seconds
– the time to serve a generated UnixFS HTML directory listing from the gatewaygw_car_stream_get_duration_seconds
– the time to GET an entire CAR stream from the gatewaygw_raw_block_get_duration_seconds
– The time to GET an entire raw Block from the gateway
Opt-in tracing support with many spans for tracing the duration of specific tasks performed by go-ipfs.
See Tracing for details.
We will continue to add tracing instrumentation throughout IPFS subcomponents over time.
One can use the jaegertracing/all-in-one
Docker image to run a full Jaeger stack and configure go-ipfs to publish traces to it (here, in an ephemeral container):
$ docker run --rm -it --name jaeger \
-e COLLECTOR_ZIPKIN_HOST_PORT=:9411 \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 14250:14250 \
-p 9411:9411 \
jaegertracing/all-in-one
Then, in other terminal, start go-ipfs with Jaeger tracing enabled:
$ OTEL_TRACES_EXPORTER=jaeger ipfs daemon
Finally, the Jaeger UI is available at http://localhost:16686
Below are examples of visual tracing for Gateway requests. (Note: this a preview how useful this insight is. Details may look different now, as we are constantly improving tracing annotations across the go-ipfs codebase.)
CAR | Block | File | Directory |
---|---|---|---|
The diag profile
command has been expanded to include all information that was previously included in the collect-profiles.sh
script, and the script has been removed. Profiles are now collected in parallel, so that profile collection is much faster. Specific profiles can also be selected for targeted debugging.
See ipfs diag profile --help
for more details.
For general debugging information, see the debug guide.
It is now possible to import or export private keys wrapped in interoperable PEM PKCS8 by passing --format=pem-pkcs8-cleartext
to ipfs key import
and export
commands.
This improved interop allows for key generation outside of the IPFS node:
$ openssl genpkey -algorithm ED25519 > ed25519.pem
$ ipfs key import test-openssl -f pem-pkcs8-cleartext ed25519.pem
Or using external tools like the standard openssl
to get a PEM file with the public key:
$ ipfs key export testkey --format=pem-pkcs8-cleartext -o privkey.pem
$ openssl pkey -in privkey.pem -pubout > pubkey.pem
This release makes necessary (breaking) changes in effort to use canonical codec names from multicodec/table.csv. We also switched to CIDv1 in block put
. The breaking changes are discussed above.
Docker images published at https://hub.docker.com/r/ipfs/go-ipfs/ now support custom initialization by mounting scripts in the /container-init.d
directory in the container. Scripts can set custom configuration using ipfs config
, or otherwise customize the container before the daemon is started.
Scripts are executed sequentially and in lexicographic order, before the IPFS daemon is started and after ipfs init
is run and the swarm keys are copied (if the IPFS repo needs initialization).
For more information, see:
- Documentation: Run IPFS inside Docker
- Examples in ipfs-shipyard/go-ipfs-docker-examples.
https://docs.ipfs.tech/reference/kubo/rpc/ now includes separate sections for experimental and deprecated commands.
We also display a warning in the command line:
$ ipfs name pubsub state --help
WARNING: EXPERIMENTAL, command may change in future releases
The more fully featured yamux stream multiplexer is now prioritized over mplex for outgoing connections.
Full Changelog
- github.com/ipfs/go-ipfs:
- feat: upgrade to [email protected] (#9005) (ipfs/go-ipfs#9005)
- docs: fix typo in the
swarm/peering
help text - feat: disable resource manager by default (#9003) (ipfs/go-ipfs#9003)
- fix: adjust rcmgr limits for accelerated DHT client rt refresh (#8982) (ipfs/go-ipfs#8982)
- fix(ci): make go-ipfs-as-a-library work without external peers (#8978) (ipfs/go-ipfs#8978)
- feat: log when resource manager limits are exceeded (#8980) (ipfs/go-ipfs#8980)
- fix: JS caching via Access-Control-Expose-Headers (#8984) (ipfs/go-ipfs#8984)
- docs: fix abstractions typo
- fix: hanging goroutine in get fileArchive handler
- fix(node/libp2p): disable rcmgr checkImplicitDefaults (ipfs/go-ipfs#8965)
- pubsub multibase encoding (#8933) (ipfs/go-ipfs#8933)
- 'pin rm' helptext: rewrite description as object is not removed from local storage (immediately) (ipfs/go-ipfs#8947)
- (ipfs/go-ipfs#8934)
- Add instructions to resolve repo migration error (#8946) (ipfs/go-ipfs#8946)
- fix: use path instead of filepath for asset embeds to support Windows
- Release v0.13.0-rc1
- docs: v0.13.0 changelog (ipfs/go-ipfs#8941)
- chore: build with go 1.18.1 (ipfs/go-ipfs#8932)
- docs(tracing): update env var docs for new tracing env vars
- feat: enable Resource Manager by default
- chore: Update test/dependencies to match go-ipfs dependencies. (#8928) (ipfs/go-ipfs#8928)
- chore: fix linting errors (#8930) (ipfs/go-ipfs#8930)
- docs: Swarm.ResourceMgr.Limits
- feat: EnableHolePunching by default (ipfs/go-ipfs#8748)
- ci: add more golang strictness checks (ipfs/go-ipfs#8931)
- feat(gateway): Gateway.FastDirIndexThreshold (#8853) (ipfs/go-ipfs#8853)
- docs: replace all git.io links with their actual URLs
- feat: relay v2 discovery (go-libp2p v0.19.0) (#8868) (ipfs/go-ipfs#8868)
- fix(cmds): add: reject files with different import dir
- chore: mark 'log tail' experimental (#8912) (ipfs/go-ipfs#8912)
- feat: persist limits to Swarm.ResourceMgr.Limits (#8901) (ipfs/go-ipfs#8901)
- fix: build after Go 1.17 and Prometheus upgrades (#8916) (ipfs/go-ipfs#8916)
- feat(tracing): use OpenTelemetry env vars where possible (#8875) (ipfs/go-ipfs#8875)
- feat(cmds): allow to set the configuration file path (ipfs/go-ipfs#8634)
- chore: deprecate /api/v0/dns (#8893) (ipfs/go-ipfs#8893)
- fix(cmds): CIDv1 and correct multicodecs in 'block put' and 'cid codecs' (#8568) (ipfs/go-ipfs#8568)
- feat(gw): improved If-None-Match support (#8891) (ipfs/go-ipfs#8891)
- Update Go version to 1.17 (#8815) (ipfs/go-ipfs#8815)
- chore(gw): extract logical functions to improve readability (#8885) (ipfs/go-ipfs#8885)
- feat(docker): /container-init.d for advanced initialization (#6577) (ipfs/go-ipfs#6577)
- feat: port collect-profiles.sh to 'ipfs diag profile' (#8786) (ipfs/go-ipfs#8786)
- fix: assets: correctly use the argument err in the WalkDirFunc Hashing Files
- Change
assets.Asset
from afunc
to the embed.FS - Remove gobindata
- fix: fix context plumbing in gateway handlers (#8871) (ipfs/go-ipfs#8871)
- fix(gw): missing return if dir fails to finalize (#8806) (ipfs/go-ipfs#8806)
- fix(gw): update metrics only when payload data sent (#8827) (ipfs/go-ipfs#8827)
- Merge branch 'release'
- feat: detect changes in go-libp2p-resource-manager (#8857) (ipfs/go-ipfs#8857)
- feat: opt-in Swarm.ResourceMgr (go-libp2p v0.18) (#8680) (ipfs/go-ipfs#8680)
- feat(cmds): add support for CAR v2 imports (#8854) (ipfs/go-ipfs#8854)
- docs(logging): environment variables (#8833) (ipfs/go-ipfs#8833)
- fix: unknown fetcher type error (#8830) (ipfs/go-ipfs#8830)
- chore: deprecate tar commands (#8849) (ipfs/go-ipfs#8849)
- chore: bump go-ipld-format v0.4.0 and fix related sharness tests (ipfs/go-ipfs#8838)
- feat: add basic gateway tracing (#8595) (ipfs/go-ipfs#8595)
- fix(cli): ipfs add with multiple files of same name (#8493) (ipfs/go-ipfs#8493)
- fix(gw): validate requested CAR version (#8835) (ipfs/go-ipfs#8835)
- feat: re-enable docker sharness tests (#8808) (ipfs/go-ipfs#8808)
- docs: gateway.md (#8825) (ipfs/go-ipfs#8825)
- fix(core/commands): do not cache config (#8824) (ipfs/go-ipfs#8824)
- remove unused import (#8787) (ipfs/go-ipfs#8787)
- feat(cmds): document deprecated RPC API commands (#8802) (ipfs/go-ipfs#8802)
- fix(fsrepo): deep merge when setting config (ipfs/go-ipfs#8793)
- feat: add gateway histogram metrics (#8443) (ipfs/go-ipfs#8443)
- ErrNotFound changes: bubble tagged libraries. (ipfs/go-ipfs#8803)
- Fix typos (ipfs/go-ipfs#8757)
- feat(gateway): Block and CAR response formats (#8758) (ipfs/go-ipfs#8758)
- fix: allow ipfs-companion browser extension to access RPC API (#8690) (ipfs/go-ipfs#8690)
- fix(core/node): unwrap fx error in node construction (ipfs/go-ipfs#8638)
- Update PATCH_RELEASE_TEMPLATE.md
- feat: add full goroutine stack dump (#8790) (ipfs/go-ipfs#8790)
- feat(cmds): extend block size check for dag|block put (#8751) (ipfs/go-ipfs#8751)
- feat: add endpoint for enabling block profiling (#8469) (ipfs/go-ipfs#8469)
- fix(cmds): option for progress bar in cat/get (#8686) (ipfs/go-ipfs#8686)
- docs: note the default reprovider strategy as all (#8603) (ipfs/go-ipfs#8603)
- fix: listen on loopback for API and gateway ports in docker-compose.yaml (#8773) (ipfs/go-ipfs#8773)
- fix(discovery): fix daemon not starting due to mdns startup failure (#8704) (ipfs/go-ipfs#8704) (ipfs/go-ipfs#8756)
- feat: ipfs-webui v2.15 (#8712) (ipfs/go-ipfs#8712)
- feat: X-Ipfs-Roots for smarter HTTP caches (#8720) (ipfs/go-ipfs#8720)
- chore: add instructions for Chocolatey release
- fix prioritization of stream muxers (ipfs/go-ipfs#8750)
- fix(cmds/keystore): do not allow to import keys we don't generate (#8733) (ipfs/go-ipfs#8733)
- docs: add Internal.UnixFSShardingSizeThreshold (#8723) (ipfs/go-ipfs#8723)
- feat(cmd): add silent option for repo gc (#7147) (ipfs/go-ipfs#7147)
- docs(changelog): update v0.12.0 release notes
- Merge branch 'release'
- fix: installation without sudo (#8715) (ipfs/go-ipfs#8715)
- Fix typos (#8726) (ipfs/go-ipfs#8726)
- fix(build): Recognize Go Beta versions in makefile (#8677) (ipfs/go-ipfs#8677)
- chore(cmds): encapsulate ipfs rm logic in another function (#8574) (ipfs/go-ipfs#8574)
- feat: warn user when 'pin remote add' while offline (#8621) (ipfs/go-ipfs#8621)
- chore(gateway): debug logging for the http requests (#8518) (ipfs/go-ipfs#8518)
- docker: build for arm cpu (#8633) (ipfs/go-ipfs#8633)
- feat: refactor Fetcher interface used for downloading migrations (#8728) (ipfs/go-ipfs#8728)
- feat: log multifetcher errors
- docs: optionalInteger|String|Duration (#8729) (ipfs/go-ipfs#8729)
- feat: DNS.MaxCacheTTL for DNS-over-HTTPS resolvers (#8615) (ipfs/go-ipfs#8615)
- feat(cmds): ipfs id: support --offline option (#8626) (ipfs/go-ipfs#8626)
- feat(cmds): add cleartext PEM/PKCS8 for key import/export (#8616) (ipfs/go-ipfs#8616)
- docs: update badger section in config.md (#8662) (ipfs/go-ipfs#8662)
- docs: fix typo
- Adding PowerShell to Minimal Go Installation
- Fixed typos in docs/config.md
- docs: add Snap note about customizing IPFS_PATH (#8584) (ipfs/go-ipfs#8584)
- Fix typo (ipfs/go-ipfs#8625)
- chore: update version to v0.13.0-dev
- github.com/ipfs/go-bitswap (v0.5.1 -> v0.6.0):
- v0.6.0
- Use ipld.ErrNotFound
- feat: add peer block filter option (#549) (ipfs/go-bitswap#549)
- configurable target message size (ipfs/go-bitswap#546)
- github.com/ipfs/go-blockservice (v0.2.1 -> v0.3.0):
- v0.3.0
- s/log/logger
- Use ipld.ErrNotFound instead of ErrNotFound
- github.com/ipfs/go-cid (v0.1.0 -> v0.2.0):
- fix: remove invalid multicodec2string mappings (#137) (ipfs/go-cid#137)
- sync: update CI config files (#136) (ipfs/go-cid#136)
- Benchmark existing ways to check for
IDENTITY
CIDs - avoid double alloc in NewCidV1
- sync: update CI config files (ipfs/go-cid#131)
- github.com/ipfs/go-cidutil (v0.0.2 -> v0.1.0):
(ipfs/go-cidutil#36)
- sync: update CI config files (ipfs/go-cidutil#35)
- sync: update CI config files (#34) (ipfs/go-cidutil#34)
- fix staticcheck (ipfs/go-cidutil#31)
- add license file so it can be found by go-licenses (ipfs/go-cidutil#27)
- test: fix for base32 switch (ipfs/go-cidutil#16)
- doc: add a lead maintainer
- github.com/ipfs/go-filestore (v1.1.0 -> v1.2.0):
- v1.2.0
- refactor: follow the happy left practice in Filestore.DeleteBlock
- Use ipld.ErrNotFound
- github.com/ipfs/go-graphsync (v0.11.0 -> v0.13.1):
- docs(CHANGELOG): update for v0.13.1
- feat(ipld): wrap bindnode with panic protection (#368) (ipfs/go-graphsync#368)
- docs(CHANGELOG): update for v0.13.0 (#366) (ipfs/go-graphsync#366)
- fix(impl): delete file
- Minimal alternate metadata type support (#365) (ipfs/go-graphsync#365)
- Fix unixfs fetch (#364) (ipfs/go-graphsync#364)
- [Feature] UUIDs, protocol versioning, v2 protocol w/ dag-cbor messaging (#332) (ipfs/go-graphsync#332)
- feat(CHANGELOG): update for v0.12.0
- Use do not send blocks for pause/resume & prevent processing of blocks on canceled requests (#333) (ipfs/go-graphsync#333)
- Support unixfs reification in default linksystem (#329) (ipfs/go-graphsync#329)
- Don't run hooks on blocks we didn't have (#331) (ipfs/go-graphsync#331)
- feat(responsemanager): trace full messages via links to responses (#325) (ipfs/go-graphsync#325)
- chore(requestmanager): rename processResponses internals for consistency (#328) (ipfs/go-graphsync#328)
- Response message tracing (#327) (ipfs/go-graphsync#327)
- fix(testutil): fix tracing span collection (#324) (ipfs/go-graphsync#324)
- docs(CHANGELOG): update for v0.11.5 release
- feat(requestmanager): add tracing for response messages & block processing (#322) (ipfs/go-graphsync#322)
- ipldutil: simplify state synchronization, add docs (#300) (ipfs/go-graphsync#300)
- docs(CHANGELOG): update for v0.11.4 release
- Scrub response errors (#320) (ipfs/go-graphsync#320)
- fix(responsemanager): remove unused maxInProcessRequests parameter (#319) (ipfs/go-graphsync#319)
- feat(responsemanager): allow ctx augmentation via queued request hook
- make go test with coverpkg=./...
- docs(CHANGELOG): update for v0.11.3
- Merge tag 'v0.10.9'
- feat: add basic tracing for responses (#291) (ipfs/go-graphsync#291)
- fix(impl): remove accidental legacy field (#310) (ipfs/go-graphsync#310)
- docs(CHANGELOG): update for v0.11.2
- Merge branch 'release/v0.10.8'
- feat(taskqueue): fix race on peer state gather (#303) (ipfs/go-graphsync#303)
- feat(responsemanager): clarify response completion (#304) (ipfs/go-graphsync#304)
- docs(CHANGELOG): update for v0.11.1
- Merge branch 'release/v0.10.7'
- Expose task queue diagnostics (#302) (ipfs/go-graphsync#302)
- chore: short-circuit unnecessary message processing
- Add a bit of logging (#301) (ipfs/go-graphsync#301)
- Peer Stats function (#298) (ipfs/go-graphsync#298)
- fix: use sync.Cond to handle no-task blocking wait (#299) (ipfs/go-graphsync#299)
- ipldutil: use chooser APIs from dagpb and basicnode (#292) (ipfs/go-graphsync#292)
- testutil/chaintypes: simplify maintenance of codegen (#294) (ipfs/go-graphsync#294)
- fix(test): increase 1s timeouts to 2s for slow CI (#289) (ipfs/go-graphsync#289)
- docs(tests): document tracing test helper utilities
- feat: add basic OT tracing for incoming requests
- fix(responsemanager): make fix more global
- fix(responsemanager): fix flaky tests
- feat: add WorkerTaskQueue#WaitForNoActiveTasks() for tests (#284) (ipfs/go-graphsync#284)
- github.com/ipfs/go-ipfs-blockstore (v1.1.2 -> v1.2.0):
- v0.2.0 (ipfs/go-ipfs-blockstore#98)
- s/log/logger
- Use ipld.ErrNotFound for NotFound errors
- github.com/ipfs/go-ipfs-cmds (v0.6.0 -> v0.8.1):
- fix(cli/parse): extract dir before name (ipfs/go-ipfs-cmds#230)
- Version 0.8.0 (ipfs/go-ipfs-cmds#228)
- fix(cli): use NewSliceDirectory for duplicate file paths (ipfs/go-ipfs-cmds#220)
- chore: release v0.7.0 (ipfs/go-ipfs-cmds#227)
- feat(Command): add status for the helptext (ipfs/go-ipfs-cmds#225)
- allow header and set header in client (ipfs/go-ipfs-cmds#226)
- sync: update CI config files (#221) (ipfs/go-ipfs-cmds#221)
- fix: chanResponseEmitter cancel being ineffective
- add: tests for postrun execution
- fix: postrun's run condition in Execute
- fix: exec deadlock when emitter is not Typer intf
- sync: update CI config files (ipfs/go-ipfs-cmds#207)
- fix: preserve windows file paths (ipfs/go-ipfs-cmds#214)
- Resolve
staticcheck
issue in prep for unified CI (ipfs/go-ipfs-cmds#212)
- github.com/ipfs/go-ipfs-exchange-offline (v0.1.1 -> v0.2.0):
- v0.2.0
- Improve NotFound error description
- github.com/ipfs/go-ipfs-files (v0.0.9 -> v0.1.1):
- Release v0.1.1
- fix: add dragonfly build option for filewriter flags
- fix: add freebsd build option for filewriter flags
- Release v0.1.0
- docs: fix community CONTRIBUTING.md link (#45) (ipfs/go-ipfs-files#45)
- chore(filewriter): cleanup writes (#43) (ipfs/go-ipfs-files#43)
- sync: update CI config files (#44) (ipfs/go-ipfs-files#44)
- github.com/ipfs/go-ipld-format (v0.2.0 -> v0.4.0):
- chore: release version v0.4.0
- feat: use new more clearer format in ErrNotFound
- chore: bump version to 0.3.1
- fix: make Undef ErrNotFound string consistent with Def version
- Version 0.3.0
- ErrNotFound: change error string (ipfs/go-ipld-format#69)
- Revert "Revert "Add IsErrNotFound() method"" (ipfs/go-ipld-format#68)
- sync: update CI config files (#67) (ipfs/go-ipld-format#67)
- ignore statticheck error for EndOfDag (ipfs/go-ipld-format#62)
- remove Makefile (ipfs/go-ipld-format#59)
- fix staticcheck (ipfs/go-ipld-format#60)
- Allowing custom NavigableNode implementations (ipfs/go-ipld-format#58)
- github.com/ipfs/go-ipld-legacy (v0.1.0 -> v0.1.1):
- feat(node): add json.Marshaller method (ipfs/go-ipld-legacy#7)
- github.com/ipfs/go-log/v2 (v2.3.0 -> v2.5.1):
- feat: add logger option to skip a number of stack frames (ipfs/go-log#132)
- release v2.5.0 (#131) (ipfs/go-log#131)
- config inspection (#129) (ipfs/go-log#129)
- release v2.4.0 (#127) (ipfs/go-log#127)
- sync: update CI config files (#125) (ipfs/go-log#125)
- fix: cannot call SetPrimaryCore after using a Tee logger (ipfs/go-log#121)
- Document environment variables (ipfs/go-log#120)
- sync: update CI config files (#119) (ipfs/go-log#119)
- Add WithStacktrace utility (ipfs/go-log#118)
- In addition to StdOut/Err check the outfile for TTYness (ipfs/go-log#117)
- github.com/ipfs/go-merkledag (v0.5.1 -> v0.6.0):
- v0.6.0
- Improve ErrNotFound
- github.com/ipfs/go-namesys (v0.4.0 -> v0.5.0):
- Version 0.5.0
- fix: CIDv1 error with go-libp2p 0.19 (#32) (ipfs/go-namesys#32)
- feat: add tracing (#30) (ipfs/go-namesys#30)
- fix(publisher): fix garbled code output (#28) (ipfs/go-namesys#28)
- github.com/ipfs/go-path (v0.2.1 -> v0.3.0):
- Release v0.3.0 (ipfs/go-path#55)
- Resolver: convert to interface. (ipfs/go-path#53)
- Release v0.2.2 (#52) (ipfs/go-path#52)
- chore: improve error message for invalid ipfs paths (ipfs/go-path#51)
- github.com/ipfs/go-peertaskqueue (v0.7.0 -> v0.7.1):
- Add topic inspector (ipfs/go-peertaskqueue#20)
- github.com/ipfs/go-pinning-service-http-client (v0.1.0 -> v0.1.1):
- chore: release v0.1.1
- fix: error handling while enumerating pins
- sync: update CI config files (#15) (ipfs/go-pinning-service-http-client#15)
- Resolve lint issues prior to CI integration
- github.com/ipfs/go-unixfsnode (v1.1.3 -> v1.4.0):
- 1.4.0 release (ipfs/go-unixfsnode#29)
- Partial file test (ipfs/go-unixfsnode#26)
- Add unixfs to UnixFS path selector tail (ipfs/go-unixfsnode#28)
- release v1.3.0 (ipfs/go-unixfsnode#25)
- add AsLargeBytes support to unixfs files (#24) (ipfs/go-unixfsnode#24)
- fix: add extra test to span the shard/no-shard boundary
- fix: more Tsize fixes, fix HAMT and make it match go-unixfs output
- fix: encode Tsize correctly everywhere (using wrapped LinkSystem)
- docs(version): tag 1.2.0
- Update deps for ADL selectors (ipfs/go-unixfsnode#20)
- add license (#17) (ipfs/go-unixfsnode#17)
- handle empty files (#15) (ipfs/go-unixfsnode#15)
- Add ADL/single-node-view of a full unixFS file. (#14) (ipfs/go-unixfsnode#14)
- sync: update CI config files (#13) (ipfs/go-unixfsnode#13)
- Add builder for unixfs dags (#12) (ipfs/go-unixfsnode#12)
- github.com/ipfs/interface-go-ipfs-core (v0.5.2 -> v0.7.0):
- refactor(block): CIDv1 and BlockPutSettings CidPrefix (#80) (ipfs/interface-go-ipfs-core#80)
- chore: release v0.6.2
- fix: use IPLD.ErrNotFound instead of string comparison in tests
- fix: document error (#74) (ipfs/interface-go-ipfs-core#74)
- version: release 0.6.1
- v0.6.0
- Update tests to use ipld.IsNotFound to check for notfound errors
- sync: update CI config files (#79) (ipfs/interface-go-ipfs-core#79)
- github.com/ipld/go-codec-dagpb (v1.3.2 -> v1.4.0):
- bump to v1.4.0 given that we updated ipld-prime
- add a decode-then-encode roundtrip fuzzer
- 1.3.1
- fix: use protowire for Links bytes decoding
- delete useless code
- sync: update CI config files (#33) (ipld/go-codec-dagpb#33)
- github.com/ipld/go-ipld-prime (v0.14.2 -> v0.16.0):
- mark v0.16.0
- node/bindnode: enforce pointer requirement for nullable maps
- Implement WalkTransforming traversal (#376) (ipld/go-ipld-prime#376)
- docs(datamodel): add comment to LargeBytesNode
- Add partial-match traversal of large bytes (#375) (ipld/go-ipld-prime#375)
- Implement option to start traversals at a path (ipld/go-ipld-prime#358)
- add top-level "go value with schema" example
- Support optional
LargeBytesNode
interface (#372) (ipld/go-ipld-prime#372) - node/bindnode: support pointers to datamodel.Node to bind with Any
- fix(bindnode): tuple struct iterator should handle absent fields properly
- node/bindnode: make AssignNode work at the repr level
- node/bindnode: add support for unsigned integers
- node/bindnode: cover even more edge case panics
- node/bindnode: polish some more AsT panics
- schema/dmt: stop using a fake test to generate code (ipld/go-ipld-prime#356)
- schema: remove one review note; add another.
- fix: minor EncodedLength fixes, add tests to fully exercise
- feat: add dagcbor.EncodedLength(Node) to calculate length without encoding
- chore: rename Garbage() to Generate()
- fix: minor garbage nits
- fix: Garbage() takes rand parameter, tweak algorithms, improve docs
- feat: add Garbage() Node generator
- node/bindnode: introduce an assembler that always errors
- node/bindnode: polish panics on invalid AssignT calls
- datamodel: don't panic when stringifying an empty KindSet
- node/bindnode: start using ipld.LoadSchema APIs
- selectors: fix for edge case around recursion clauses with an immediate edge. (ipld/go-ipld-prime#334)
- node/bindnode: improve support for pointer types
- node/bindnode: subtract all absents in Length at the repr level
- fix(codecs): error when encoding maps whose lengths don't match entry count
- schema: avoid alloc and copy in Struct and Enum methods
- node/bindnode: allow mapping int-repr enums with Go integers
- schema,node/bindnode: add support for Any
- signaling ADLs in selectors (#301) (ipld/go-ipld-prime#301)
- node/bindnode: add support for enums
- schema/...: add support for enum int representations
- node/bindnode: allow binding cidlink.Link to links
- Update to context datastores (#312) (ipld/go-ipld-prime#312)
- schema: add support for struct tuple reprs
- Allow parsing padding in dag-json bytes fields (#309) (ipld/go-ipld-prime#309)
- github.com/libp2p/go-doh-resolver (v0.3.1 -> v0.4.0):
- Release v0.4.0 (#16) (libp2p/go-doh-resolver#16)
- sync: update CI config files (#14) (libp2p/go-doh-resolver#14)
- Add a max TTL for cached entries (libp2p/go-doh-resolver#12)
- Perform test locally instead of using a live dns resolution (libp2p/go-doh-resolver#13)
- sync: update CI config files (#7) (libp2p/go-doh-resolver#7)
- fix staticcheck (libp2p/go-doh-resolver#6)
- github.com/libp2p/go-libp2p (v0.16.0 -> v0.19.4):
- update go-yamux to v3.1.2, release v0.19.4 (#1590) (libp2p/go-libp2p#1590)
- update quic-go to v0.27.1, release v0.19.3 (#1518) (libp2p/go-libp2p#1518)
- release v0.19.2
- holepunch: fix incorrect message type for the SYNC message (#1478) (libp2p/go-libp2p#1478)
- fix race condition in holepunch service, release v0.19.1 (libp2p/go-libp2p#1474)
- release v0.19.0 (#1408) (libp2p/go-libp2p#1408)
- Close resource manager when host closes (#1343) (libp2p/go-libp2p#1343)
- fix flaky reconnect test (#1406) (libp2p/go-libp2p#1406)
- make sure to not oversubscribe to relays (#1404) (libp2p/go-libp2p#1404)
- rewrite the reconnect test (#1399) (libp2p/go-libp2p#1399)
- don't try to reconnect to already connected relays (#1401) (libp2p/go-libp2p#1401)
- reduce flakiness of AutoRelay TestBackoff test (#1400) (libp2p/go-libp2p#1400)
- improve AutoRelay v1 handling (libp2p/go-libp2p#1396)
- remove note about gx from README (#1385) (libp2p/go-libp2p#1385)
- use the vcs information from ReadBuildInfo in Go 1.18 (libp2p/go-libp2p#1381)
- fix race condition in AutoRelay candidate handling (#1383) (libp2p/go-libp2p#1383)
- implement relay v2 discovery (libp2p/go-libp2p#1368)
- fix go vet error in proxy example (#1377) (libp2p/go-libp2p#1377)
- Resolve addresses when creating a new stream (#1342) (libp2p/go-libp2p#1342)
- remove mplex from the list of default muxers (#1344) (libp2p/go-libp2p#1344)
- refactor the holepunching code (libp2p/go-libp2p#1355)
- speed up the connmgr tests (#1354) (libp2p/go-libp2p#1354)
- update go-libp2p-resource manager, release v0.18.0 (#1361) (libp2p/go-libp2p#1361)
- fix flaky BackoffConnector test (#1353) (libp2p/go-libp2p#1353)
- release v0.18.0-rc6 (#1350) (libp2p/go-libp2p#1350)
- release v0.18.0-rc5 (libp2p/go-libp2p#1341)
- update README (#1330) (libp2p/go-libp2p#1330)
- fix parsing of IP addresses for zeroconf initialization (#1338) (libp2p/go-libp2p#1338)
- fix flaky TestBackoffConnector test (#1328) (libp2p/go-libp2p#1328)
- release v0.18.0-rc4 (libp2p/go-libp2p#1327)
- fix (and speed up) flaky TestBackoffConnector test (#1316) (libp2p/go-libp2p#1316)
- fix flaky TestAutoRelay test (#1322) (libp2p/go-libp2p#1322)
- deflake resource manager tests, take 2 (libp2p/go-libp2p#1318)
- fix race condition causing TestAutoNATServiceDialError test failure (#1312) (libp2p/go-libp2p#1312)
- disable flaky relay example test on CI (#1219) (libp2p/go-libp2p#1219)
- fix flaky resource manager tests (libp2p/go-libp2p#1315)
- update deps, fixing nil peer scope pointer issues in connection upgrading (libp2p/go-libp2p#1309)
- release v0.18.0-rc2 (libp2p/go-libp2p#1306)
- add semaphore to control push/delta concurrency (libp2p/go-libp2p#1305)
- release v0.18.0-rc1 (libp2p/go-libp2p#1300)
- default connection manager (libp2p/go-libp2p#1299)
- Basic resource manager integration tests (libp2p/go-libp2p#1296)
- use the resource manager (libp2p/go-libp2p#1275)
- move the go-libp2p-connmgr here (libp2p/go-libp2p#1297)
- move go-libp2p-discovery here (libp2p/go-libp2p#1291)
- speed up identify tests (libp2p/go-libp2p#1294)
- don't close the connection when opening the identify stream fails (libp2p/go-libp2p#1293)
- use the netutil package that was moved to go-libp2p-testing (#1263) (libp2p/go-libp2p#1263)
- speed up the autorelay test, fix flaky TestAutoRelay test (libp2p/go-libp2p#1272)
- fix flaky TestStreamsStress test (#1288) (libp2p/go-libp2p#1288)
- add an option for the swarm dial timeout (libp2p/go-libp2p#1271)
- use the transport.Upgrader interface (libp2p/go-libp2p#1277)
- fix typo in options.go (#1274) (libp2p/go-libp2p#1274)
- remove direct dependency on libp2p/go-addr-util (libp2p/go-libp2p#1279)
- fix flaky TestNotifications test (libp2p/go-libp2p#1278)
- move go-libp2p-autonat to p2p/host/autonat (libp2p/go-libp2p#1273)
- require the expiration field of the circuit v2 Reservation protobuf (libp2p/go-libp2p#1269)
- run reconnect test using QUIC (libp2p/go-libp2p#1268)
- remove goprocess from the mock package (libp2p/go-libp2p#1266)
- release v0.17.0 (#1265) (libp2p/go-libp2p#1265)
- use the new network.ConnStats (libp2p/go-libp2p#1262)
- move the peerstoremanager to the host (libp2p/go-libp2p#1258)
- reduce the default stream protocol negotiation timeout (#1254) (libp2p/go-libp2p#1254)
- Doc: QUIC is default when no transports set (#1250) (libp2p/go-libp2p#1250)
- exclude web3-bot from mkreleaselog (libp2p/go-libp2p#1248)
- identify: also match observed against listening addresses (libp2p/go-libp2p#1255)
- make it possible to run the auto relays tests multiple times (libp2p/go-libp2p#1253)
- github.com/libp2p/go-libp2p-asn-util (v0.1.0 -> v0.2.0):
- Release 0.2.0 (#21) (libp2p/go-libp2p-asn-util#21)
- perf: replace the ipv6 map by an array of struct (#20) (libp2p/go-libp2p-asn-util#20)
- sync: update CI config files (#18) (libp2p/go-libp2p-asn-util#18)
- github.com/libp2p/go-libp2p-blankhost (v0.2.0 -> v0.3.0):
- add a WithEventBus constructor option (libp2p/go-libp2p-blankhost#61)
- emit the EvtPeerConnectednessChanged event (libp2p/go-libp2p-blankhost#58)
- chore: update go-log to v2 (libp2p/go-libp2p-blankhost#59)
- Remove invalid links (libp2p/go-libp2p-blankhost#57)
- fix go vet (libp2p/go-libp2p-blankhost#53)
- github.com/libp2p/go-libp2p-circuit (v0.4.0 -> v0.6.0):
- release v0.6.0 (#151) (libp2p/go-libp2p-circuit#151)
- chore: update go-log to v2 (#147) (libp2p/go-libp2p-circuit#147)
- release v0.5.0 (#150) (libp2p/go-libp2p-circuit#150)
- use the resource manager (libp2p/go-libp2p-circuit#148)
- use the transport.Upgrader interface (libp2p/go-libp2p-circuit#149)
- sync: update CI config files (#144) (libp2p/go-libp2p-circuit#144)
- (libp2p/go-libp2p-circuit#143)
- add a Close method, remove the context from the constructor (libp2p/go-libp2p-circuit#141)
- chore: update go-libp2p-core, go-libp2p-swarm (libp2p/go-libp2p-circuit#140)
- remove the circuit v2 code (libp2p/go-libp2p-circuit#139)
- implement circuit v2 (libp2p/go-libp2p-circuit#136)
- remove deprecated types (libp2p/go-libp2p-circuit#135)
- fix race condition in TestActiveRelay (libp2p/go-libp2p-circuit#133)
- minor staticcheck fixes (libp2p/go-libp2p-circuit#126)
- Timeout Stream Read (libp2p/go-libp2p-circuit#124)
- github.com/libp2p/go-libp2p-core (v0.11.0 -> v0.15.1):
- release v0.15.1 (#246) (libp2p/go-libp2p-core#246)
- feat: harden encoding/decoding functions against panics (#243) (libp2p/go-libp2p-core#243)
- release v0.15.0 (#242) (libp2p/go-libp2p-core#242)
- sync: update CI config files (#241) (libp2p/go-libp2p-core#241)
- fix: switch to go-multicodec mappings (#240) (libp2p/go-libp2p-core#240)
- chore: add
String()
method toIDSlice
type (#238) (libp2p/go-libp2p-core#238) - release v0.14.0 (#235) (libp2p/go-libp2p-core#235)
- Network Resource Manager interface (#229) (libp2p/go-libp2p-core#229)
- introduce a transport.Upgrader interface (#232) (libp2p/go-libp2p-core#232)
- remove the transport.AcceptTimeout (#231) (libp2p/go-libp2p-core#231)
- remove the DialTimeout (#230) (libp2p/go-libp2p-core#230)
- remove duplicate io.Closer on Network interface (#228) (libp2p/go-libp2p-core#228)
- release v0.13.0 (#227) (libp2p/go-libp2p-core#227)
- rename network.Stat to Stats, introduce ConnStats (#226) (libp2p/go-libp2p-core#226)
- release v0.12.0 (#223) (libp2p/go-libp2p-core#223)
- generate ecdsa public key from an input public key (#219) (libp2p/go-libp2p-core#219)
- add RemovePeer method to PeerMetadata, Metrics, ProtoBook and Keybook (#218) (libp2p/go-libp2p-core#218)
- github.com/libp2p/go-libp2p-kad-dht (v0.15.0 -> v0.16.0):
- Version 0.16.0 (#774) (libp2p/go-libp2p-kad-dht#774)
- feat: add error log when resource manager throttles crawler (#772) (libp2p/go-libp2p-kad-dht#772)
- fix: incorrect format handling (libp2p/go-libp2p-kad-dht#771)
- Upgrade to go-libp2p v0.16.0 (#756) (libp2p/go-libp2p-kad-dht#756)
- sync: update CI config files (libp2p/go-libp2p-kad-dht#758)
- github.com/libp2p/go-libp2p-mplex (v0.4.1 -> v0.7.0):
- release v0.7.0 (#36) (libp2p/go-libp2p-mplex#36)
- release v0.6.0 (#32) (libp2p/go-libp2p-mplex#32)
- update mplex (#31) (libp2p/go-libp2p-mplex#31)
- release v0.5.0 (#30) (libp2p/go-libp2p-mplex#30)
- implement the new network.MuxedConn interface (#29) (libp2p/go-libp2p-mplex#29)
- sync: update CI config files (#28) (libp2p/go-libp2p-mplex#28)
- remove Makefile (libp2p/go-libp2p-mplex#25)
- github.com/libp2p/go-libp2p-noise (v0.3.0 -> v0.4.0):
- release v0.4.0 (#112) (libp2p/go-libp2p-noise#112)
- catch panics during the handshake (#111) (libp2p/go-libp2p-noise#111)
- sync: update CI config files (#106) (libp2p/go-libp2p-noise#106)
- update README to reflect that Noise is enabled by default (libp2p/go-libp2p-noise#101)
- github.com/libp2p/go-libp2p-peerstore (v0.4.0 -> v0.6.0):
- release v0.6.0 (libp2p/go-libp2p-peerstore#189)
- remove the pstoremanager (will be moved to the Host) (libp2p/go-libp2p-peerstore#188)
- release v0.5.0 (#187) (libp2p/go-libp2p-peerstore#187)
- remove metadata interning (libp2p/go-libp2p-peerstore#185)
- when passed an event bus, automatically clean up disconnected peers (libp2p/go-libp2p-peerstore#184)
- implement the RemovePeer method (libp2p/go-libp2p-peerstore#174)
- chore: update go-log to v2 (#179) (libp2p/go-libp2p-peerstore#179)
- github.com/libp2p/go-libp2p-pubsub (v0.6.0 -> v0.6.1):
- add tests for clearing the peerPromises map
- properly clear the peerPromises map
- more info
- add to MinTopicSize godoc re topic size
- github.com/libp2p/go-libp2p-quic-transport (v0.15.0 -> v0.17.0):
- release v0.17.0 (#269) (libp2p/go-libp2p-quic-transport#269)
- update quic-go to v0.27.0 (#264) (libp2p/go-libp2p-quic-transport#264)
- release v0.16.1 (#261) (libp2p/go-libp2p-quic-transport#261)
- Prevent data race in allowWindowIncrease (#259) (libp2p/go-libp2p-quic-transport#259)
- release v0.16.0 (#258) (libp2p/go-libp2p-quic-transport#258)
- use the Resource Manager (libp2p/go-libp2p-quic-transport#249)
- don't start a Go routine for every connection dialed (libp2p/go-libp2p-quic-transport#252)
- migrate to standard Go tests, stop using Ginkgo (libp2p/go-libp2p-quic-transport#250)
- chore: remove Codecov config (#251) (libp2p/go-libp2p-quic-transport#251)
- reduce the maximum number of incoming streams to 256 (#243) (libp2p/go-libp2p-quic-transport#243)
- chore: update go-log to v2 (#242) (libp2p/go-libp2p-quic-transport#242)
- github.com/libp2p/go-libp2p-swarm (v0.8.0 -> v0.10.2):
- bump version to v0.10.2 (libp2p/go-libp2p-swarm#316)
- Refactor dial worker loop into an object and fix bug (libp2p/go-libp2p-swarm#315)
- release v0.10.1 (libp2p/go-libp2p-swarm#313)
- release the stream scope if the conn fails to open a new stream (libp2p/go-libp2p-swarm#312)
- release v0.10.0 (#311) (libp2p/go-libp2p-swarm#311)
- add support for the resource manager (libp2p/go-libp2p-swarm#308)
- use the transport.Upgrader interface (libp2p/go-libp2p-swarm#309)
- remove dependency on go-addr-util (libp2p/go-libp2p-swarm#300)
- stop using transport.DialTimeout in tests (#307) (libp2p/go-libp2p-swarm#307)
- increment active dial counter in dial worker loop (libp2p/go-libp2p-swarm#305)
- speed up the dial tests (libp2p/go-libp2p-swarm#301)
- stop using the deprecated libp2p/go-maddr-filter (libp2p/go-libp2p-swarm#303)
- add constructor options for timeout, stop using transport.DialTimeout (libp2p/go-libp2p-swarm#302)
- release v0.9.0 (#299) (libp2p/go-libp2p-swarm#299)
- count the number of streams on a connection for the stats (libp2p/go-libp2p-swarm#298)
- chore: update go-log to v2 (#294) (libp2p/go-libp2p-swarm#294)
- github.com/libp2p/go-libp2p-testing (v0.5.0 -> v0.9.2):
- release v0.9.2 (#56) (libp2p/go-libp2p-testing#56)
- fix memory allocation check in SubtestStreamReset (#55) (libp2p/go-libp2p-testing#55)
- release v0.9.1 (#54) (libp2p/go-libp2p-testing#54)
- remove stray debug statements for memory allocations
- release v0.9.0 (#53) (libp2p/go-libp2p-testing#53)
- add tests for memory management (libp2p/go-libp2p-testing#52)
- release v0.8.0 (#50) (libp2p/go-libp2p-testing#50)
- use io.ReadFull in muxer test, use require.Equal to compare buffers (#49) (libp2p/go-libp2p-testing#49)
- release v0.7.0 (#47) (libp2p/go-libp2p-testing#47)
- add mocks for the resource manager (libp2p/go-libp2p-testing#46)
- merge libp2p/go-libp2p-netutil into this repo (libp2p/go-libp2p-testing#45)
- reduce the number of connections in the stream muxer stress test (#44) (libp2p/go-libp2p-testing#44)
- release v0.6.0 (#42) (libp2p/go-libp2p-testing#42)
- expose a map, not a slice, of muxer tests (#41) (libp2p/go-libp2p-testing#41)
- sync: update CI config files (#40) (libp2p/go-libp2p-testing#40)
- github.com/libp2p/go-libp2p-tls (v0.3.1 -> v0.4.1):
- release v0.4.1 (#112) (libp2p/go-libp2p-tls#112)
- feat: catch panics in TLS negotiation (libp2p/go-libp2p-tls#111)
- release v0.4.0 (#110) (libp2p/go-libp2p-tls#110)
- use tls.Conn.HandshakeContext instead of tls.Conn.Handshake (#106) (libp2p/go-libp2p-tls#106)
- remove paragraph about Go modules from README (#104) (libp2p/go-libp2p-tls#104)
- migrate to standard Go tests, stop using Ginkgo (libp2p/go-libp2p-tls#105)
- chore: remove Codecov config (#103) (libp2p/go-libp2p-tls#103)
- github.com/libp2p/go-libp2p-transport-upgrader (v0.5.0 -> v0.7.1):
- release v0.7.1 (libp2p/go-libp2p-transport-upgrader#105)
- Fix nil peer scope issues (libp2p/go-libp2p-transport-upgrader#104)
- release v0.7.0 (#103) (libp2p/go-libp2p-transport-upgrader#103)
- use the Resource Manager (libp2p/go-libp2p-transport-upgrader#99)
- rename the package to upgrader (libp2p/go-libp2p-transport-upgrader#101)
- use the new transport.Upgrader interface (libp2p/go-libp2p-transport-upgrader#100)
- reset the temporary error catcher delay after successful accept (libp2p/go-libp2p-transport-upgrader#97)
- make the accept timeout configurable, stop using transport.AcceptTimeout (libp2p/go-libp2p-transport-upgrader#98)
- release v0.6.0 (#95) (libp2p/go-libp2p-transport-upgrader#95)
- remove note about go.mod and Go 1.11 in README (#94) (libp2p/go-libp2p-transport-upgrader#94)
- fix flaky TestAcceptQueueBacklogged test (libp2p/go-libp2p-transport-upgrader#96)
- chore: remove Codecov config (#93) (libp2p/go-libp2p-transport-upgrader#93)
- use the new network.ConnStats (libp2p/go-libp2p-transport-upgrader#92)
- sync: update CI config files (#89) (libp2p/go-libp2p-transport-upgrader#89)
- chore: update go-log (libp2p/go-libp2p-transport-upgrader#88)
- github.com/libp2p/go-libp2p-yamux (v0.6.0 -> v0.9.1):
- release v0.9.1 (#55) (libp2p/go-libp2p-yamux#55)
- release v0.9.0 (#53) (libp2p/go-libp2p-yamux#53)
- release v0.8.2 (#50) (libp2p/go-libp2p-yamux#50)
- disable the incoming streams limit (#49) (libp2p/go-libp2p-yamux#49)
- Release v0.8.1 (libp2p/go-libp2p-yamux#48)
- release v0.8.0 (#47) (libp2p/go-libp2p-yamux#47)
- pass the PeerScope to yamux ( satisfying its MemoryManger interface) (#46) (libp2p/go-libp2p-yamux#46)
- release v0.7.0 (#43) (libp2p/go-libp2p-yamux#43)
- sync: update CI config files (#42) (libp2p/go-libp2p-yamux#42)
- reduce the number of max incoming stream to 256 (libp2p/go-libp2p-yamux#41)
- github.com/libp2p/go-mplex (v0.3.0 -> v0.7.0):
- release v0.7.0 (#112) (libp2p/go-mplex#112)
- catch panics in handleIncoming and handleOutgoing (#109) (libp2p/go-mplex#109)
- remove benchmark tests (#111) (libp2p/go-mplex#111)
- release v0.6.0 (#105) (libp2p/go-mplex#105)
- fix incorrect reset of timer fired variable (#104) (libp2p/go-mplex#104)
- Mplex salvage operations, part II (#102) (libp2p/go-mplex#102)
- release v0.5.0 (#100) (libp2p/go-mplex#100)
- Salvage mplex in the age of resource management (#99) (libp2p/go-mplex#99)
- release v0.4.0 (#97) (libp2p/go-mplex#97)
- add a MemoryManager interface to control memory allocations (libp2p/go-mplex#96)
- sync: update CI config files (#93) (libp2p/go-mplex#93)
- chore: update go-log to v2 (libp2p/go-mplex#92)
- chore: remove Codecov config (libp2p/go-mplex#91)
- sync: update CI config files (#90) (libp2p/go-mplex#90)
- multiplex: add (*Multiplex).CloseChan (libp2p/go-mplex#89)
- add a Go Reference badge to the README (libp2p/go-mplex#88)
- sync: update CI config files (libp2p/go-mplex#85)
- Fix up tests & vet (libp2p/go-mplex#84)
- Bump lodash from 4.17.19 to 4.17.21 in /interop/js (libp2p/go-mplex#83)
- github.com/libp2p/go-msgio (v0.1.0 -> v0.2.0):
- release v0.2.0 (#34) (libp2p/go-msgio#34)
- print recovered panics to stderr (#33) (libp2p/go-msgio#33)
- catch panics when reading / writing protobuf messages (#31) (libp2p/go-msgio#31)
- remove outdated section about channels from README (#32) (libp2p/go-msgio#32)
- sync: update CI config files (#28) (libp2p/go-msgio#28)
- github.com/libp2p/go-netroute (v0.1.6 -> v0.2.0):
- release v0.2.0 (#21) (libp2p/go-netroute#21)
- move some functions from go-sockaddr here, remove go-sockaddr dependency (libp2p/go-netroute#22)
- ignore the error on the RouteMessage on Darwin (libp2p/go-netroute#20)
- sync: update CI config files (#19) (libp2p/go-netroute#19)
- sync: update CI config files (#18) (libp2p/go-netroute#18)
- skip loopback addr as indication of v6 routes (libp2p/go-netroute#17)
- fix staticcheck lint issues (libp2p/go-netroute#15)
- github.com/libp2p/go-stream-muxer-multistream (v0.3.0 -> v0.4.0):
- release v0.4.0 (#23) (libp2p/go-stream-muxer-multistream#23)
- implement the new Multiplexer.NewConn interface (libp2p/go-stream-muxer-multistream#22)
- sync: update CI config files (#19) (libp2p/go-stream-muxer-multistream#19)
- github.com/libp2p/go-tcp-transport (v0.4.0 -> v0.5.1):
- release v0.5.1 (#116) (libp2p/go-tcp-transport#116)
- fix: drop raw EINVAL (from keepalives) errors as well (#115) (libp2p/go-tcp-transport#115)
- release v0.5.0 (#114) (libp2p/go-tcp-transport#114)
- use the ResourceManager (libp2p/go-tcp-transport#110)
- use the transport.Upgrader interface (libp2p/go-tcp-transport#111)
- describe how to use options in README (libp2p/go-tcp-transport#105)
- github.com/libp2p/go-ws-transport (v0.5.0 -> v0.6.0):
- release v0.6.0 (#113) (libp2p/go-ws-transport#113)
- use the resource manager (libp2p/go-ws-transport#109)
- chore: remove Codecov config (#112) (libp2p/go-ws-transport#112)
- remove contexts from libp2p constructors in README (#111) (libp2p/go-ws-transport#111)
- use the transport.Upgrader interface (libp2p/go-ws-transport#110)
- sync: update CI config files (#108) (libp2p/go-ws-transport#108)
- sync: update CI config files (#106) (libp2p/go-ws-transport#106)
- github.com/lucas-clemente/quic-go (v0.24.0 -> v0.27.1):
- don't send path MTU probe packets on a timer
- stop using the deprecated net.Error.Temporary, update golangci-lint to v1.45.2 (lucas-clemente/quic-go#3367)
- add support for serializing Extended CONNECT requests (#3360) (lucas-clemente/quic-go#3360)
- improve the error thrown when building with an unsupported Go version (lucas-clemente/quic-go#3364)
- remove nextdns from list of projects using quic-go (#3363) (lucas-clemente/quic-go#3363)
- rename the Session to Connection (lucas-clemente/quic-go#3361)
- respect the request context when dialing (lucas-clemente/quic-go#3359)
- update HTTP/3 Datagram to draft-ietf-masque-h3-datagram-07 (#3355) (lucas-clemente/quic-go#3355)
- add support for the Extended CONNECT method (#3357) (lucas-clemente/quic-go#3357)
- remove the SkipSchemeCheck RoundTripOpt (#3353) (lucas-clemente/quic-go#3353)
- remove parser logic for HTTP/3 DUPLICATE_PUSH frame (#3356) (lucas-clemente/quic-go#3356)
- improve code coverage of random number generator test (#3358) (lucas-clemente/quic-go#3358)
- advertise multiple listeners via Alt-Svc and improve perf of SetQuicHeaders (#3352) (lucas-clemente/quic-go#3352)
- avoid recursion when skipping unknown HTTP/3 frames (#3354) (lucas-clemente/quic-go#3354)
- Implement http3.Server.ServeListener (#3349) (lucas-clemente/quic-go#3349)
- update for Go 1.18 (lucas-clemente/quic-go#3345)
- don't print a receive buffer warning for closed connections (#3346) (lucas-clemente/quic-go#3346)
- move set DF implementation to separate files & avoid the need for OOBCapablePacketConn (#3334) (lucas-clemente/quic-go#3334)
- add env to disable the receive buffer warning (#3339) (lucas-clemente/quic-go#3339)
- fix typo (#3333) (lucas-clemente/quic-go#3333)
- sendQueue: ignore "datagram too large" error (#3328) (lucas-clemente/quic-go#3328)
- add OONI Probe to list of projects in README (#3324) (lucas-clemente/quic-go#3324)
- remove build status badges from README (#3325) (lucas-clemente/quic-go#3325)
- add a AllowConnectionWindowIncrease config option (lucas-clemente/quic-go#3317)
- Update README.md (#3315) (lucas-clemente/quic-go#3315)
- fix some typos in documentation and tests
- remove unneeded calls to goimports when generating mocks (lucas-clemente/quic-go#3313)
- fix comment about congestionWindow value (#3310) (lucas-clemente/quic-go#3310)
- fix typo *connections (#3309) (lucas-clemente/quic-go#3309)
- add support for Go 1.18 (lucas-clemente/quic-go#3298)
- github.com/multiformats/go-base32 (v0.0.3 -> v0.0.4):
- optimize encode (multiformats/go-base32#1)
- Fix
staticcheck
issue
- github.com/multiformats/go-multiaddr (v0.4.1 -> v0.5.0):
- release v0.5.0 (#171) (multiformats/go-multiaddr#171)
- remove wrong (and redundant) IsIpv6LinkLocal (multiformats/go-multiaddr#170)
- move ResolveUnspecifiedAddress(es) and FilterAddrs here from libp2p/go-addr-util (multiformats/go-multiaddr#168)
- sync: update CI config files (#167) (multiformats/go-multiaddr#167)
- github.com/multiformats/go-multicodec (v0.3.0 -> v0.4.1):
- Version v0.4.1 (multiformats/go-multicodec#64)
- update table with new codecs (multiformats/go-multicodec#63)
- bump version to v0.4.0
- sync: update CI config files (#60) (multiformats/go-multicodec#60)
- add Code.Tag method
- add the KnownCodes API
- use "go run pkg@version" assuming Go 1.17 or later
- update submodule and re-generate
- update to newer multicodec table (multiformats/go-multicodec#57)
- Update
multicodec
submodule to1bcdc08
for CARv2 index codec
- github.com/multiformats/go-multistream (v0.2.2 -> v0.3.0):
- release v0.3.0 (#82) (multiformats/go-multistream#82)
- catch panics (#81) (multiformats/go-multistream#81)
- sync: update CI config files (#78) (multiformats/go-multistream#78)
- reduce the maximum read buffer size from 64 to 1 kB (multiformats/go-multistream#77)
- remove unused ls command (multiformats/go-multistream#76)
- chore: remove empty file cases.md (multiformats/go-multistream#75)
- chore: remove .gx (multiformats/go-multistream#72)
- don't commit the fuzzing binary (multiformats/go-multistream#74)
- sync: update CI config files (#71) (multiformats/go-multistream#71)
- remove Makefile (multiformats/go-multistream#67)
Contributor | Commits | Lines ± | Files Changed |
---|---|---|---|
Marten Seemann | 347 | +14453/-12552 | 842 |
Rod Vagg | 28 | +8848/-4033 | 214 |
vyzo | 133 | +7959/-1783 | 231 |
hannahhoward | 40 | +3761/-1652 | 175 |
Will Scott | 39 | +2885/-1784 | 93 |
Daniel Martí | 32 | +3043/-969 | 103 |
Adin Schmahmann | 48 | +3439/-536 | 121 |
Gus Eggert | 29 | +2644/-788 | 123 |
Steven Allen | 87 | +2417/-840 | 135 |
Marcin Rataj | 29 | +2312/-942 | 75 |
Will | 11 | +2520/-62 | 56 |
Lucas Molas | 28 | +1602/-578 | 90 |
Raúl Kripalani | 18 | +1519/-271 | 38 |
Brian Tiger Chow | 20 | +833/-379 | 40 |
Masih H. Derkani | 5 | +514/-460 | 8 |
Jeromy Johnson | 53 | +646/-302 | 83 |
Łukasz Magiera | 26 | +592/-245 | 43 |
Artem Mikheev | 2 | +616/-120 | 5 |
Franky W | 2 | +49/-525 | 9 |
Laurent Senta | 3 | +468/-82 | 52 |
Hector Sanjuan | 32 | +253/-187 | 62 |
Juan Batiz-Benet | 8 | +285/-80 | 18 |
Justin Johnson | 2 | +181/-88 | 2 |
Thibault Meunier | 5 | +216/-28 | 8 |
James Wetter | 2 | +234/-1 | 2 |
web3-bot | 36 | +158/-66 | 62 |
gammazero | 7 | +140/-84 | 12 |
Rachel Chen | 2 | +165/-57 | 17 |
Jorropo | 18 | +108/-99 | 26 |
Toby | 2 | +107/-86 | 11 |
Antonio Navarro Perez | 4 | +82/-103 | 9 |
Dominic Della Valle | 4 | +148/-33 | 6 |
Ian Davis | 2 | +152/-28 | 6 |
Kyle Huntsman | 2 | +172/-6 | 5 |
huoju | 4 | +127/-41 | 6 |
Jeromy | 19 | +71/-58 | 31 |
Lars Gierth | 12 | +63/-54 | 20 |
Eric Myhre | 3 | +95/-15 | 8 |
Caian Benedicto | 1 | +69/-12 | 6 |
Raúl Kripalani | 2 | +63/-13 | 2 |
Anton Petrov | 1 | +73/-0 | 1 |
hunjixin | 2 | +67/-2 | 5 |
odanado | 1 | +61/-0 | 1 |
Andrew Gillis | 2 | +61/-0 | 3 |
Kevin Atkinson | 6 | +21/-34 | 7 |
Richard Ramos | 1 | +51/-0 | 2 |
Manuel Alonso | 1 | +42/-9 | 2 |
Jakub Sztandera | 10 | +37/-13 | 13 |
Aarsh Shah | 1 | +39/-5 | 2 |
Dave Justice | 1 | +32/-4 | 2 |
Tommi Virtanen | 3 | +23/-9 | 4 |
tarekbadr | 1 | +30/-1 | 1 |
whyrusleeping | 1 | +26/-4 | 3 |
Petar Maymounkov | 2 | +30/-0 | 4 |
rht | 3 | +17/-10 | 4 |
Miguel Mota | 1 | +23/-0 | 1 |
Manfred Touron | 1 | +21/-2 | 2 |
watjurk | 1 | +17/-5 | 1 |
SukkaW | 1 | +11/-11 | 5 |
Nicholas Bollweg | 1 | +21/-0 | 1 |
Ho-Sheng Hsiao | 2 | +11/-10 | 6 |
chblodg | 1 | +18/-2 | 1 |
Friedel Ziegelmayer | 2 | +18/-0 | 2 |
Shu Shen | 2 | +15/-2 | 3 |
Peter Rabbitson | 1 | +15/-2 | 1 |
galargh | 2 | +15/-0 | 2 |
ᴍᴀᴛᴛ ʙᴇʟʟ | 3 | +13/-1 | 4 |
aarshkshah1992 | 3 | +12/-2 | 3 |
RubenKelevra | 4 | +5/-8 | 5 |
Feiran Yang | 1 | +11/-0 | 2 |
zramsay | 2 | +0/-10 | 2 |
Teran McKinney | 1 | +8/-2 | 1 |
Richard Littauer | 2 | +5/-5 | 5 |
Elijah | 1 | +10/-0 | 1 |
Dimitris Apostolou | 2 | +5/-5 | 5 |
Michael Avila | 3 | +8/-1 | 4 |
siiky | 3 | +4/-4 | 3 |
Somajit | 1 | +4/-4 | 1 |
Sherod Taylor | 1 | +0/-8 | 2 |
Eclésio Junior | 1 | +8/-0 | 1 |
godcong | 3 | +4/-3 | 3 |
Piotr Galar | 3 | +3/-4 | 3 |
jwh | 1 | +6/-0 | 2 |
dependabot[bot] | 1 | +3/-3 | 1 |
Volker Mische | 1 | +4/-2 | 1 |
Aayush Rajasekaran | 1 | +3/-3 | 1 |
rene | 2 | +3/-2 | 2 |
keks | 1 | +5/-0 | 1 |
Hlib | 1 | +4/-1 | 2 |
Arash Payan | 1 | +5/-0 | 1 |
Wayback Archiver | 1 | +2/-2 | 1 |
T Mo | 1 | +2/-2 | 1 |
Ju Huo | 1 | +2/-2 | 1 |
Ivan | 2 | +2/-2 | 2 |
Ettore Di Giacinto | 2 | +3/-1 | 2 |
Christian Couder | 1 | +3/-1 | 1 |
ningmingxiao | 1 | +0/-3 | 1 |
市川恭佑 (ebi) | 1 | +1/-1 | 1 |
star | 1 | +0/-2 | 1 |
alliswell | 1 | +0/-2 | 1 |
Preston Van Loon | 1 | +2/-0 | 1 |
Nguyễn Gia Phong | 1 | +1/-1 | 1 |
Nato Boram | 1 | +1/-1 | 1 |
Mildred Ki'Lya | 1 | +2/-0 | 2 |
Michael Burns | 1 | +1/-1 | 1 |
Glenn | 1 | +1/-1 | 1 |
George Antoniadis | 1 | +1/-1 | 1 |
David Florness | 1 | +1/-1 | 1 |
Daniel Norman | 1 | +1/-1 | 1 |
Coenie Beyers | 1 | +1/-1 | 1 |
Benedikt Spies | 1 | +1/-1 | 1 |
Abdul Rauf | 1 | +1/-1 | 1 |
makeworld | 1 | +1/-0 | 1 |
ignoramous | 1 | +0/-1 | 1 |
Omicron166 | 1 | +0/-1 | 1 |
Jan Winkelmann | 1 | +1/-0 | 1 |
Dr Ian Preston | 1 | +1/-0 | 1 |
Baptiste Jonglez | 1 | +1/-0 | 1 |