Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: bump go version to 1.22 (#4590) #4687

Merged
merged 4 commits into from
May 28, 2024
Merged

chore: bump go version to 1.22 (#4590) #4687

merged 4 commits into from
May 28, 2024

Conversation

martinconic
Copy link
Contributor

@martinconic martinconic commented May 20, 2024

Checklist

  • I have read the coding guide.
  • My change requires a documentation update, and I have done it.
  • I have added tests to cover my changes.
  • I have filled out the description and linked the related issues.

Description

Upgrading Go version to 1.22
Upgrading multiple golang.org/x library dependencies

Copy link
Member

@janos janos left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The biggest change in go 1.22 is the variable scoping in for loops. While the code should work as expected, whenever the variable is deliberately not scoped inside the iteration, should be adjusted, as with go 1.22 that variable will have the scope in iteration. I do not know of such case in the bee codebase, but it should be good to validate by other reviewers, as well. Have in mind that for loop variable scoping in 1.22 have a lot of strange consequences that may not be obvious and are very indirect.

It appears that CodeQL analyzer is a blocker for this change https://github.com/ethersphere/bee/actions/runs/9160600677/job/25183926395?pr=4687#step:4:103 as it does not support go 1.22, which is unfortunate.

@martinconic
Copy link
Contributor Author

martinconic commented May 20, 2024

There might be 2 solutions here: github/codeql#15647

  1. Add toolchain
  2. Add a more specific Go version 1.22.0 or 1.22.1

@martinconic martinconic requested a review from janos May 20, 2024 16:47
@istae
Copy link
Member

istae commented May 20, 2024

The biggest change in go 1.22 is the variable scoping in for loops. While the code should work as expected, whenever the variable is deliberately not scoped inside the iteration, should be adjusted, as with go 1.22 that variable will have the scope in iteration. I do not know of such case in the bee codebase, but it should be good to validate by other reviewers, as well. Have in mind that for loop variable scoping in 1.22 have a lot of strange consequences that may not be obvious and are very indirect.

It appears that CodeQL analyzer is a blocker for this change https://github.com/ethersphere/bee/actions/runs/9160600677/job/25183926395?pr=4687#step:4:103 as it does not support go 1.22, which is unfortunate.

There is tooling support we should look into. https://tip.golang.org/wiki/LoopvarExperiment
After running go build -gcflags=all=-d=loopvar=2 ./cmd/bee, this is what I got:

# runtime
/usr/local/go/src/runtime/proc.go:1907:7: loop variable freem now per-iteration, stack-allocated
/usr/local/go/src/runtime/proc.go:3269:7: loop variable enum now per-iteration, stack-allocated
/usr/local/go/src/runtime/mgcmark.go:810:6: loop variable d now per-iteration, stack-allocated
/usr/local/go/src/runtime/traceback.go:633:7: loop variable iu now per-iteration, stack-allocated
/usr/local/go/src/runtime/traceback.go:990:7: loop variable iu now per-iteration, stack-allocated
# vendor/golang.org/x/net/dns/dnsmessage
/usr/local/go/src/vendor/golang.org/x/net/dns/dnsmessage/message.go:1161:10: loop variable q now per-iteration, stack-allocated
/usr/local/go/src/vendor/golang.org/x/net/dns/dnsmessage/message.go:1168:10: loop variable a now per-iteration, stack-allocated
/usr/local/go/src/vendor/golang.org/x/net/dns/dnsmessage/message.go:1175:10: loop variable a now per-iteration, stack-allocated
/usr/local/go/src/vendor/golang.org/x/net/dns/dnsmessage/message.go:1182:10: loop variable a now per-iteration, stack-allocated
/usr/local/go/src/vendor/golang.org/x/net/dns/dnsmessage/message.go:2633:9: loop variable o now per-iteration, stack-allocated
# runtime/pprof
/usr/local/go/src/runtime/pprof/pprof.go:386:9: loop variable r now per-iteration, heap-allocated
/usr/local/go/src/runtime/pprof/proto.go:363:6: loop variable e now per-iteration, stack-allocated
/usr/local/go/src/runtime/pprof/proto.go:612:9: loop variable frame now per-iteration, stack-allocated
/usr/local/go/src/runtime/pprof/protomem.go:29:9: loop variable r now per-iteration, heap-allocated
# github.com/ethereum/go-ethereum/rlp
../../go/pkg/mod/github.com/ethereum/[email protected]/rlp/encbuffer.go:68:9: loop variable head now per-iteration, stack-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/rlp/encbuffer.go:84:9: loop variable head now per-iteration, stack-allocated
# net
/usr/local/go/src/net/cgo_unix.go:74:9: loop variable addr now per-iteration, stack-allocated
/usr/local/go/src/net/dnsclient_unix.go:567:9: loop variable ip now per-iteration, stack-allocated
/usr/local/go/src/net/interface_linux.go:27:9: loop variable m now per-iteration, stack-allocated
/usr/local/go/src/net/interface_linux.go:150:9: loop variable m now per-iteration, stack-allocated
/usr/local/go/src/net/sockopt_posix.go:28:9: loop variable ifi now per-iteration, heap-allocated
/usr/local/go/src/net/interface.go:147:9: loop variable ifi now per-iteration, heap-allocated (loop inlined into /usr/local/go/src/net/interface.go:139)
/usr/local/go/src/net/interface.go:147:9: loop variable ifi now per-iteration, heap-allocated (loop inlined into /usr/local/go/src/net/interface_linux.go:159)
# github.com/ethereum/go-ethereum/p2p/netutil
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:93:9: loop variable net now per-iteration, stack-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:130:9: loop variable net now per-iteration, stack-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:130:9: loop variable net now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:144)
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:130:9: loop variable net now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:146)
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:130:9: loop variable net now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:156)
../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:130:9: loop variable net now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/github.com/ethereum/[email protected]/p2p/netutil/net.go:158)
# crypto/x509
/usr/local/go/src/crypto/x509/x509.go:1208:11: loop variable name now per-iteration, stack-allocated
/usr/local/go/src/crypto/x509/x509.go:1220:11: loop variable ipNet now per-iteration, stack-allocated
/usr/local/go/src/crypto/x509/x509.go:1228:11: loop variable email now per-iteration, stack-allocated
/usr/local/go/src/crypto/x509/x509.go:1240:11: loop variable uriDomain now per-iteration, stack-allocated
/usr/local/go/src/crypto/x509/verify.go:856:9: loop variable ext now per-iteration, heap-allocated
/usr/local/go/src/crypto/x509/verify.go:871:10: loop variable ext now per-iteration, heap-allocated
# github.com/casbin/casbin/v2/rbac/default-role-manager
../../go/pkg/mod/github.com/casbin/casbin/[email protected]/rbac/default-role-manager/role_manager.go:103:10: loop variable domain now per-iteration, stack-allocated
../../go/pkg/mod/github.com/casbin/casbin/[email protected]/rbac/default-role-manager/role_manager.go:195:10: loop variable domain now per-iteration, stack-allocated
# github.com/gogo/protobuf/proto
../../go/pkg/mod/github.com/gogo/[email protected]/proto/extensions_gogo.go:163:9: loop variable e now per-iteration, stack-allocated
../../go/pkg/mod/github.com/gogo/[email protected]/proto/extensions_gogo.go:179:9: loop variable e now per-iteration, stack-allocated
# github.com/ethereum/go-ethereum/accounts/abi
../../go/pkg/mod/github.com/ethereum/[email protected]/accounts/abi/abi.go:229:9: loop variable errABI now per-iteration, heap-allocated
# github.com/casbin/casbin/v2/model
../../go/pkg/mod/github.com/casbin/casbin/[email protected]/model/model.go:306:13: loop variable assertion now per-iteration, stack-allocated
# crypto/tls
/usr/local/go/src/crypto/tls/common.go:1146:9: loop variable cert now per-iteration, heap-allocated
/usr/local/go/src/crypto/tls/ticket.go:121:10: loop variable extra now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/ticket.go:143:10: loop variable chain now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/ticket.go:150:12: loop variable cert now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/ticket.go:374:9: loop variable key now per-iteration, heap-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:195:12: loop variable proto now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:233:12: loop variable ks now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:268:12: loop variable psk now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:276:12: loop variable binder now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:355:11: loop variable binder now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:693:12: loop variable sct now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:1186:14: loop variable ca now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:1389:7: loop variable i now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:1389:10: loop variable cert now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_messages.go:1411:15: loop variable sct now per-iteration, stack-allocated
/usr/local/go/src/crypto/tls/handshake_client.go:1099:9: loop variable chain now per-iteration, heap-allocated
/usr/local/go/src/crypto/tls/handshake_server_tls13.go:186:10: loop variable ks now per-iteration, heap-allocated
# internal/profile
/usr/local/go/src/internal/profile/encode.go:251:10: loop variable l now per-iteration, stack-allocated
/usr/local/go/src/internal/profile/encode.go:285:9: loop variable i now per-iteration, stack-allocated
# go.opencensus.io/trace/tracestate
../../go/pkg/mod/[email protected]/trace/tracestate/tracestate.go:67:13: loop variable entry now per-iteration, heap-allocated (loop inlined into ../../go/pkg/mod/[email protected]/trace/tracestate/tracestate.go:78)
../../go/pkg/mod/[email protected]/trace/tracestate/tracestate.go:105:9: loop variable entry now per-iteration, heap-allocated (loop inlined into ../../go/pkg/mod/[email protected]/trace/tracestate/tracestate.go:128)
# google.golang.org/protobuf/internal/impl
../../go/pkg/mod/google.golang.org/[email protected]/internal/impl/message_reflect.go:238:10: loop variable x now per-iteration, stack-allocated
../../go/pkg/mod/google.golang.org/[email protected]/internal/impl/encode.go:156:9: loop variable x now per-iteration, stack-allocated
../../go/pkg/mod/google.golang.org/[email protected]/internal/impl/encode.go:177:10: loop variable x now per-iteration, stack-allocated
../../go/pkg/mod/google.golang.org/[email protected]/internal/impl/merge.go:60:12: loop variable sx now per-iteration, stack-allocated
../../go/pkg/mod/google.golang.org/[email protected]/internal/impl/checkinit.go:69:9: loop variable x now per-iteration, stack-allocated
# gopkg.in/yaml.v2
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:81:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1265:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1322:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1378:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1435:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1605:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1645:6: loop variable i now per-iteration, stack-allocated
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:81:6: loop variable i now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1227)
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:81:6: loop variable i now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1237)
../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:81:6: loop variable i now per-iteration, stack-allocated (loop inlined into ../../go/pkg/mod/gopkg.in/[email protected]/emitterc.go:1251)
# golang.org/x/text/language
../../go/pkg/mod/golang.org/x/[email protected]/language/coverage.go:126:10: loop variable t now per-iteration, stack-allocated
../../go/pkg/mod/golang.org/x/[email protected]/language/match.go:382:9: loop variable tag now per-iteration, stack-allocated
../../go/pkg/mod/golang.org/x/[email protected]/language/match.go:391:9: loop variable tag now per-iteration, stack-allocated
../../go/pkg/mod/golang.org/x/[email protected]/language/match.go:455:9: loop variable ww now per-iteration, stack-allocated
../../go/pkg/mod/golang.org/x/[email protected]/language/match.go:495:10: loop variable t now per-iteration, stack-allocated
# encoding/xml
/usr/local/go/src/encoding/xml/typeinfo.go:81:13: loop variable finfo now per-iteration, stack-allocated
# go.opencensus.io/trace
../../go/pkg/mod/[email protected]/trace/spanstore.go:130:10: loop variable b now per-iteration, stack-allocated
# resenje.org/web
../../go/pkg/mod/resenje.org/[email protected]/auth.go:127:10: loop variable network now per-iteration, stack-allocated
../../go/pkg/mod/resenje.org/[email protected]/auth.go:136:10: loop variable network now per-iteration, stack-allocated
# github.com/uber/jaeger-client-go/utils
../../go/pkg/mod/github.com/uber/[email protected]+incompatible/utils/localip.go:63:9: loop variable iface now per-iteration, stack-allocated
# github.com/koron/go-ssdp/internal/multicast
../../go/pkg/mod/github.com/koron/[email protected]/internal/multicast/interface.go:30:9: loop variable ifi now per-iteration, stack-allocated
../../go/pkg/mod/github.com/koron/[email protected]/internal/multicast/multicast.go:70:9: loop variable ifi now per-iteration, stack-allocated
../../go/pkg/mod/github.com/koron/[email protected]/internal/multicast/multicast.go:116:9: loop variable ifi now per-iteration, heap-allocated
# github.com/google/gopacket/routing
../../go/pkg/mod/github.com/google/[email protected]/routing/routing.go:166:9: loop variable m now per-iteration, stack-allocated
../../go/pkg/mod/github.com/google/[email protected]/routing/routing.go:217:9: loop variable iface now per-iteration, stack-allocated
# github.com/huin/goupnp
../../go/pkg/mod/github.com/huin/[email protected]/network.go:50:9: loop variable iface now per-iteration, stack-allocated
# github.com/libp2p/go-netroute
../../go/pkg/mod/github.com/libp2p/[email protected]/netroute_linux.go:52:9: loop variable m now per-iteration, stack-allocated
../../go/pkg/mod/github.com/libp2p/[email protected]/netroute_linux.go:103:9: loop variable iface now per-iteration, stack-allocated
# github.com/miekg/dns
../../go/pkg/mod/github.com/miekg/[email protected]/types.go:1513:9: loop variable p now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/msg.go:797:9: loop variable r now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/msg.go:919:10: loop variable r now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/msg.go:983:9: loop variable r now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/ztypes.go:308:9: loop variable x now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/ztypes.go:841:9: loop variable e now per-iteration, stack-allocated
../../go/pkg/mod/github.com/miekg/[email protected]/msg_truncate.go:66:9: loop variable r now per-iteration, stack-allocated
# github.com/uber/jaeger-client-go
../../go/pkg/mod/github.com/uber/[email protected]+incompatible/span.go:349:11: loop variable ld now per-iteration, stack-allocated
../../go/pkg/mod/github.com/uber/[email protected]+incompatible/jaeger_thrift_span.go:70:9: loop variable tag now per-iteration, stack-allocated
# github.com/libp2p/go-libp2p/p2p/net/upgrader
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/net/upgrader/upgrader.go:247:9: loop variable m now per-iteration, heap-allocated (loop inlined into ../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/net/upgrader/upgrader.go:240)
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/net/upgrader/upgrader.go:247:9: loop variable m now per-iteration, heap-allocated (loop inlined into ../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/net/upgrader/upgrader.go:259)
# github.com/prometheus/client_golang/prometheus
../../go/pkg/mod/github.com/prometheus/[email protected]/prometheus/metric.go:181:10: loop variable e now per-iteration, stack-allocated
../../go/pkg/mod/github.com/prometheus/[email protected]/prometheus/expvar_collector.go:44:12: loop variable desc now per-iteration, stack-allocated
../../go/pkg/mod/github.com/prometheus/[email protected]/prometheus/go_collector_latest.go:198:9: loop variable d now per-iteration, stack-allocated
# github.com/klauspost/compress/huff0
../../go/pkg/mod/github.com/klauspost/[email protected]/huff0/compress.go:538:9: loop variable v now per-iteration, stack-allocated
../../go/pkg/mod/github.com/klauspost/[email protected]/huff0/compress.go:553:9: loop variable v now per-iteration, stack-allocated
# github.com/libp2p/go-nat
../../go/pkg/mod/github.com/libp2p/[email protected]/natpmp.go:69:9: loop variable iface now per-iteration, stack-allocated
../../go/pkg/mod/github.com/libp2p/[email protected]/upnp.go:30:10: loop variable dev now per-iteration, stack-allocated
../../go/pkg/mod/github.com/libp2p/[email protected]/upnp.go:87:10: loop variable dev now per-iteration, stack-allocated
../../go/pkg/mod/github.com/libp2p/[email protected]/upnp.go:306:9: loop variable iface now per-iteration, stack-allocated
# github.com/prometheus/statsd_exporter/pkg/mapper
../../go/pkg/mod/github.com/prometheus/[email protected]/pkg/mapper/mapper.go:334:9: loop variable mapping now per-iteration, heap-allocated
# github.com/libp2p/go-libp2p/p2p/host/eventbus
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/host/eventbus/basic.go:245:6: loop variable i now per-iteration, stack-allocated
# github.com/libp2p/go-libp2p/p2p/host/resource-manager
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/host/resource-manager/limit_defaults.go:428:9: loop variable l now per-iteration, stack-allocated
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/host/resource-manager/limit_defaults.go:500:9: loop variable l now per-iteration, stack-allocated
# github.com/libp2p/go-libp2p/p2p/net/swarm
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/net/swarm/swarm_dial.go:435:9: loop variable addr now per-iteration, stack-allocated
# github.com/klauspost/compress/zstd
../../go/pkg/mod/github.com/klauspost/[email protected]/zstd/fse_decoder.go:277:9: loop variable v now per-iteration, stack-allocated
# github.com/ethereum/go-ethereum/core/types
../../go/pkg/mod/github.com/ethereum/[email protected]/core/types/bloom9.go:110:11: loop variable b now per-iteration, heap-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/core/types/bloom9.go:124:10: loop variable b now per-iteration, heap-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/core/types/gen_log_rlp.go:13:9: loop variable _tmp2 now per-iteration, stack-allocated
# github.com/quic-go/quic-go
../../go/pkg/mod/github.com/quic-go/[email protected]/server.go:511:10: loop variable p now per-iteration, stack-allocated
# github.com/ethereum/go-ethereum/accounts
../../go/pkg/mod/github.com/ethereum/[email protected]/accounts/manager.go:249:9: loop variable wallet now per-iteration, stack-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/accounts/manager.go:263:9: loop variable wallet now per-iteration, stack-allocated
# github.com/ethereum/go-ethereum/signer/core/apitypes
../../go/pkg/mod/github.com/ethereum/[email protected]/signer/core/apitypes/types.go:629:9: loop variable field now per-iteration, stack-allocated
../../go/pkg/mod/github.com/ethereum/[email protected]/signer/core/apitypes/types.go:713:10: loop variable typeObj now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/bzz
pkg/bzz/utilities.go:9:9: loop variable v now per-iteration, stack-allocated
# github.com/libp2p/go-libp2p/p2p/transport/webtransport
../../go/pkg/mod/github.com/libp2p/[email protected]/p2p/transport/webtransport/cert_manager.go:183:9: loop variable certHash now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/transaction
pkg/transaction/transaction.go:621:9: loop variable abiError now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/storer/internal/cache
pkg/storer/internal/cache/cache.go:271:9: loop variable addr now per-iteration, stack-allocated
pkg/storer/internal/cache/cache.go:289:10: loop variable addr now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/file/joiner
pkg/file/joiner/joiner.go:383:6: loop variable i now per-iteration, stack-allocated
pkg/file/joiner/joiner.go:383:9: loop variable addr now per-iteration, heap-allocated
# github.com/ethersphere/bee/v2/pkg/storer/migration
pkg/storer/migration/reserveRepair.go:111:7: loop variable i now per-iteration, stack-allocated
pkg/storer/migration/step_05.go:27:8: loop variable item now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/storer
pkg/storer/reserve.go:183:9: loop variable batchID now per-iteration, stack-allocated
pkg/storer/compact.go:54:6: loop variable shard now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/pkg/puller
pkg/puller/puller.go:457:6: loop variable bin now per-iteration, stack-allocated
# github.com/ethersphere/bee/v2/cmd/bee/cmd
cmd/bee/cmd/db.go:521:11: loop variable root now per-iteration, stack-allocated
./pkg/storer/migration/reserveRepair.go:111:7: loop variable migration.i now per-iteration, stack-allocated

@istae
Copy link
Member

istae commented May 20, 2024

I do not know how to interepet the above yet but it's a start

@janos
Copy link
Member

janos commented May 20, 2024

I do not know how to interepet the above yet but it's a start

That is indeed a nice start, especially as there are not so many reported for loops under pkg/. It is nice that every module as dependency declares the supported go version and the for loop scoping will be used according to it, so we do not have to care about the dependencies when we are upgrading go version in our own module (bee).

@istae istae merged commit 97e7ee6 into master May 28, 2024
14 checks passed
@istae istae deleted the chore/bump-go-version branch May 28, 2024 15:29
aranyia added a commit to Solar-Punk-Ltd/bee that referenced this pull request Jun 7, 2024
* chore: bump protobuf version to 1.33.0 (ethersphere#4613) (ethersphere#4688)

* fix: save stamp issuer after failed uploads (ethersphere#4684)

* chore: pre-release updates (ethersphere#4675)

* chore: bump go ethereum version to 1.14.3 (ethersphere#4661) (ethersphere#4689)

* fix: allow maxMultiplexForwards to be set to zero (ethersphere#4682)

* chore: bump go version to 1.22 (ethersphere#4590) (ethersphere#4687)

* feat: remove debug api (ethersphere#4674)

* feat: remove auth (ethersphere#4679)

---------

Co-authored-by: Calin Martinconi <[email protected]>
Co-authored-by: istae <[email protected]>
Co-authored-by: ldeffenb <[email protected]>
Co-authored-by: Acha Bill <[email protected]>
aranyia pushed a commit to Solar-Punk-Ltd/bee that referenced this pull request Jul 9, 2024
Diffie-Hellman (#3)

* Use DiffieHellmanMock

* Adds a comment about Get

* Add support for ECDSA public key in DiffieHellman.SharedSecret function

* Update defaultAct implementation

* Adds pseudo code for Access Logic

* Update default Act creation; Fix basic Act tests

* Refactor access logic to use new ActMock implementation

* feat(history): test mockups wip

* Refactor DiffieHellman implementation

* changes pseudocode for Diffie-Hellmann read

* Co-authored-by: Bálint Ujvári <[email protected]>

* DiffieHellman mock generates a real sherd secret

* Refactor Act

* Adds manifest lookup

* Extend act_test

* Adds unit tests, some values are mocked

* Refactor act mock impl with map[string]map[string]string

* Add check mock implementation for DiffieHellman interface

* Add Load, Store to Act interface. Refactor Act interface

* refactor act, diffieHellman mocks, tests

* Add TestLoadStore function to act_test.go

* Remove unnecessary code in Load function

* Add history mock and History lookup test

* Act refactor

Co-authored-by: Bálint Ujvári <[email protected]>

* Refactor Add method to return Act interface

* Change Get method return type to []byte

---------

Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Levente Kiss <[email protected]>
Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Kexort <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>

Acces Logic (#8)

* Use DiffieHellmanMock

* Adds a comment about Get

* Add support for ECDSA public key in DiffieHellman.SharedSecret function

* Update defaultAct implementation

* Adds pseudo code for Access Logic

* Update default Act creation; Fix basic Act tests

* Refactor access logic to use new ActMock implementation

* feat(history): test mockups wip

* Refactor DiffieHellman implementation

* changes pseudocode for Diffie-Hellmann read

* Co-authored-by: Bálint Ujvári <[email protected]>

* DiffieHellman mock generates a real sherd secret

* Refactor Act

* Adds manifest lookup

* Extend act_test

* Adds unit tests, some values are mocked

* Refactor act mock impl with map[string]map[string]string

* Add check mock implementation for DiffieHellman interface

* started Add

* changed some sig

* save

* new grantee addition handling

* mod

* changed helper function visibilities

* some mod with grantee

* test mod

* save

* no error in actInit

* Add_New_Grantee_To_Content

* comment

* copied act_test.go

* no compiler errors on our side

* Adds Add_New_Grantee_To_Content and ActInit

* almost complete grantee container

* maybe complete grantee container

* Solves merge conflict

* access-logic-merge

* fix merge issues

Added context & details to use cases (#6)

ZH ethersphere#106 Added context & details to use cases

Add grantee management (#10)

* Add grantee management

* Added controller test

* Fix test fixture, refactor accesslogic

* Add UploadHandler

---------

Co-authored-by: Bálint Ujvári <[email protected]>

(refactor): from `Get` to `Lookup` to improve clarity and consistency. The changes have been made in the `accesslogic.go`, `act.go`, `act_test.go`, `history_test.go`, and `mock/act.go` files. (#13)

Co-authored-by: Ferenc Sárai <[email protected]>

Act params rename doc (#14)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

---------

Co-authored-by: Ferenc Sárai <[email protected]>

Move and refactor ACT diffieHellman to Session. Add Key and NewFromKeystore functions. (#16)

Act swarm address (#15)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

* Add in-memory storage and implement Store and Load methods

* Move and refactor ACT diffieHellman to Session. Add Key and NewFromKeystore functions.

---------

Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>

(rename): defaultAct to inMemoryAct (#17)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

* Add in-memory storage and implement Store and Load methods

* *refactor) Rename defaultAct to inMemroryAct

---------

Co-authored-by: Ferenc Sárai <[email protected]>

(refactor): Update controller_test.go to use NewInMemoryAct, modify Session.Key to return correct dimensional byte slice (#18)

* (refactor): Update controller_test.go to use NewInMemoryAct, modify Session.Key to return two-dimensional byte slice

* (refactor:) Refactor session Key function to use append instead of index-based assignment

---------

Co-authored-by: Ferenc Sárai <[email protected]>

Act access logic merge (#19)

* grantee container and access logc tests are passed

* refactored access logic and grantee container

* PR 19 comments resolving

* Refactor

* Refactor

Act kvs merge (#22)

* grantee container and access logc tests are passed

* refactored access logic and grantee container

* PR 19 comments resolving

* Refactor

* Refactor

* working manifest ACT with basic tests

* (refactor:) Refactor act_test

* (refactor:) Refactor kvs -> kvs.manifest, kvs.memory

* (refactror:) kvs

* refactor kvs contsructors

---------

Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>

Session refactor (#24)

* pr comment fix

* add comment to session.NewFromKeystore

Access logic refactor (#25)

Refactors access logic

---------

Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Peter Ott <[email protected]>

(refactor:) PR comments (#23)

* grantee-refactor

* Dried up code, related to AddPublisher - AddNewGranteeToContent

* Refactor

* removed getEncryptedAccessKey

* Renamed AddGrentees, RemoveGrantees, etc to Add, Remove, etc

* (refactor:) PR comments

* (refactor:) compile check

* removed encrypted_ref, grantee check (validation)

* changed interface

* comments

* some more comments

* refactor kvs and add load and store

* (refactor:) Use ref

* renamed defaultGrantee to granteeList

* removed null encrypted test in  in TestGet_Error

* refactor kvs: pass kvs IF argument instead of storing it

* Refactor according to the result of the workshop

* refactor kvs IF and mock

* fix merge errors and Logic/get_error test

* (test:) Add test for put/get after kvs.Save

---------

Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Peter Ott <[email protected]>

Add referenced mock kvs (#26)

Act kvs test (#27)

* (test:) Refactor tests

* (fix:) Save reset counter

---------

Co-authored-by: Ferenc Sárai <[email protected]>

Small refactor + al test (#28)

Adds TestDecryptRefWithGrantee_Success and replaces generateFixPrivateKey with getPrivKey

Co-authored-by: Peter Ott <[email protected]>

Persist grantee list on swarm (#30)

* Persist grantee list on swarm
* accesslogic refactor
* Refactor grantee list tests

Co-authored-by: Roland Seres <[email protected]>

Update package imports to use the v2 version of the modules (#33)

Co-authored-by: Ferenc Sárai <[email protected]>

chore(mantaray): merge mantaray fix for rebase

Dynamicaccess service for ACT (#35)

* feat: add act.go with TODOs

feat: Add Act interface

feat: Add Marshal, Unmarshal skeleton

feat: Refactor AccessType to iota

feat: Add upload

feat: Rename GenerateAccessControlManifest -> create

feat: Add saltLengthIs32

feat: Add Mrshal, Unmarshal impl

feat: Add Marshal Unmarshal

feat: Remove ManifestEntry json annotations

feat: Modify to public finc/method

feat: Add ErrSaltLength

Add pkg/dynamicaccess

Refactor interfaces and implement default structs

Refactor typo

Refactor History package to use NewHistory() function

Add Act interface and default implementation

Add ACT use cases to act_ucs.md

Add new files and implement interfaces, refactor packeges

Update act_ucs.md

base usecases

Refactor access logic and add mock implementations***

Add DiffieHellman implementation and remove Keystore***

Refactor NewAccessLogic function

Replace encryption.go to pkg/encryption

Refactor packages

Update act_ucs.md

Update act_ucs.md

Update act_ucs.md

Update act_ucs.md

Update act_ucs.md

* Diffie-Hellman (#3)

* Use DiffieHellmanMock

* Adds a comment about Get

* Add support for ECDSA public key in DiffieHellman.SharedSecret function

* Update defaultAct implementation

* Adds pseudo code for Access Logic

* Update default Act creation; Fix basic Act tests

* Refactor access logic to use new ActMock implementation

* feat(history): test mockups wip

* Refactor DiffieHellman implementation

* changes pseudocode for Diffie-Hellmann read

* Co-authored-by: Bálint Ujvári <[email protected]>

* DiffieHellman mock generates a real sherd secret

* Refactor Act

* Adds manifest lookup

* Extend act_test

* Adds unit tests, some values are mocked

* Refactor act mock impl with map[string]map[string]string

* Add check mock implementation for DiffieHellman interface

* Add Load, Store to Act interface. Refactor Act interface

* refactor act, diffieHellman mocks, tests

* Add TestLoadStore function to act_test.go

* Remove unnecessary code in Load function

* Add history mock and History lookup test

* Act refactor

Co-authored-by: Bálint Ujvári <[email protected]>

* Refactor Add method to return Act interface

* Change Get method return type to []byte

---------

Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Levente Kiss <[email protected]>
Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Kexort <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>

* Acces Logic (#8)

* Use DiffieHellmanMock

* Adds a comment about Get

* Add support for ECDSA public key in DiffieHellman.SharedSecret function

* Update defaultAct implementation

* Adds pseudo code for Access Logic

* Update default Act creation; Fix basic Act tests

* Refactor access logic to use new ActMock implementation

* feat(history): test mockups wip

* Refactor DiffieHellman implementation

* changes pseudocode for Diffie-Hellmann read

* Co-authored-by: Bálint Ujvári <[email protected]>

* DiffieHellman mock generates a real sherd secret

* Refactor Act

* Adds manifest lookup

* Extend act_test

* Adds unit tests, some values are mocked

* Refactor act mock impl with map[string]map[string]string

* Add check mock implementation for DiffieHellman interface

* started Add

* changed some sig

* save

* new grantee addition handling

* mod

* changed helper function visibilities

* some mod with grantee

* test mod

* save

* no error in actInit

* Add_New_Grantee_To_Content

* comment

* copied act_test.go

* no compiler errors on our side

* Adds Add_New_Grantee_To_Content and ActInit

* almost complete grantee container

* maybe complete grantee container

* Solves merge conflict

* access-logic-merge

* fix merge issues

* Added context & details to use cases (#6)

ZH ethersphere#106 Added context & details to use cases

* Add grantee management (#10)

* Add grantee management

* Added controller test

* Fix test fixture, refactor accesslogic

* Add UploadHandler

---------

Co-authored-by: Bálint Ujvári <[email protected]>

* (refactor): from `Get` to `Lookup` to improve clarity and consistency. The changes have been made in the `accesslogic.go`, `act.go`, `act_test.go`, `history_test.go`, and `mock/act.go` files. (#13)

Co-authored-by: Ferenc Sárai <[email protected]>

* Act params rename doc (#14)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

---------

Co-authored-by: Ferenc Sárai <[email protected]>

* Move and refactor ACT diffieHellman to Session. Add Key and NewFromKeystore functions. (#16)

* Act swarm address (#15)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

* Add in-memory storage and implement Store and Load methods

* Move and refactor ACT diffieHellman to Session. Add Key and NewFromKeystore functions.

---------

Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>

* (rename): defaultAct to inMemoryAct (#17)

* (refactor): ACT interface params + add doc comments

* Revert "(refactor): ACT interface params + add doc comments"

This reverts commit ee8da04.

* (refactor): ACT interface params + add doc comments

* (refactor): Add error to ACT interface methods

* Add in-memory storage and implement Store and Load methods

* *refactor) Rename defaultAct to inMemroryAct

---------

Co-authored-by: Ferenc Sárai <[email protected]>

* (refactor): Update controller_test.go to use NewInMemoryAct, modify Session.Key to return correct dimensional byte slice (#18)

* (refactor): Update controller_test.go to use NewInMemoryAct, modify Session.Key to return two-dimensional byte slice

* (refactor:) Refactor session Key function to use append instead of index-based assignment

---------

Co-authored-by: Ferenc Sárai <[email protected]>

* Act access logic merge (#19)

* grantee container and access logc tests are passed

* refactored access logic and grantee container

* PR 19 comments resolving

* Refactor

* Refactor

* Act kvs merge (#22)

* grantee container and access logc tests are passed

* refactored access logic and grantee container

* PR 19 comments resolving

* Refactor

* Refactor

* working manifest ACT with basic tests

* (refactor:) Refactor act_test

* (refactor:) Refactor kvs -> kvs.manifest, kvs.memory

* (refactror:) kvs

* refactor kvs contsructors

---------

Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>

* Session refactor (#24)

* pr comment fix

* add comment to session.NewFromKeystore

* Access logic refactor (#25)

Refactors access logic

---------

Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Peter Ott <[email protected]>

* (refactor:) PR comments (#23)

* grantee-refactor

* Dried up code, related to AddPublisher - AddNewGranteeToContent

* Refactor

* removed getEncryptedAccessKey

* Renamed AddGrentees, RemoveGrantees, etc to Add, Remove, etc

* (refactor:) PR comments

* (refactor:) compile check

* removed encrypted_ref, grantee check (validation)

* changed interface

* comments

* some more comments

* refactor kvs and add load and store

* (refactor:) Use ref

* renamed defaultGrantee to granteeList

* removed null encrypted test in  in TestGet_Error

* refactor kvs: pass kvs IF argument instead of storing it

* Refactor according to the result of the workshop

* refactor kvs IF and mock

* fix merge errors and Logic/get_error test

* (test:) Add test for put/get after kvs.Save

---------

Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: Peter Ott <[email protected]>

* Add referenced mock kvs (#26)

* add controller upload test

* compile

* Add test for grantee

* Add Upload test

* Implement controller logic, move grantee management

* Act kvs test (#27)

* (test:) Refactor tests

* (fix:) Save reset counter

---------

Co-authored-by: Ferenc Sárai <[email protected]>

* feat: add history lookup and add

* feat: expose mantaray manifest

* Small refactor + al test (#28)

Adds TestDecryptRefWithGrantee_Success and replaces generateFixPrivateKey with getPrivKey

Co-authored-by: Peter Ott <[email protected]>

* chore: tests + minor fixes

* chore: minor test change

* feat: history with reference

* chore: debugging

* Persist grantee list on swarm (#30)

* Persist grantee list on swarm
* accesslogic refactor
* Refactor grantee list tests

Co-authored-by: Roland Seres <[email protected]>

* Merging Swarm 2.0 master (#32)

* fix(stamper): global lock stamper across multiple upload sessions (ethersphere#4578)
* fix: strategy and fetch timeout parsing (ethersphere#4579)
* feat: neighborhood suggester config (ethersphere#4580)
* feat: add codeql.yml (ethersphere#4334)
* feat: add reserveSizeWithinRadius to status protocol (ethersphere#4585)
* fix: missing 200 response (ethersphere#4526)
* feat: pinned reference integrity check API (ethersphere#4573)
* fix(redundancy/getter): wait for recovery and return error (ethersphere#4581)
* fix(pushsync): store the chunk locally when no peers are available fo… (ethersphere#4597)
* fix(redundancy): on by default when downloading (ethersphere#4602)
* fix: add missing openapi spec (ethersphere#4598)
* feat: bzz resource info API (ethersphere#4588)
* fix(redundancy): bzz unit test (ethersphere#4603)
* feat: redundancy ci (ethersphere#4591)
* chore: bump github.com/quic-go/quic-go from 0.38.1 to 0.38.2 (ethersphere#4534)
* feat: split input file to chunks with specified redundancy (ethersphere#4600)
* perf(getter): cancel inflight requests if enough chunks are fetched for recovery (ethersphere#4608)
* fix: store dir error info (ethersphere#4605)
* chore: remove repetitive words (ethersphere#4611)
* fix: use neighborhood suggester only on mainnet (ethersphere#4612)
* feat: alternative withdrawal address (ethersphere#4606)
* fix(seg65) (ethersphere#4604)
* fix(getter): redundancy getter cleanup (ethersphere#4610)
* feat: v2 (ethersphere#4615)
* fix(pin_integrity): changed route and added openapi (ethersphere#4616)
* fix: missing v2 in the makefile and goreleaser (ethersphere#4622)

* chore: package update

* Update package imports to use the v2 version of the modules (#33)

Co-authored-by: Ferenc Sárai <[email protected]>

* fix walkfn with key sort

* feat: new option to walk nodes of mantaray in sequence

* feat: add latest timestamp check

* chore: uncomment wip stuff

* chore: requested changes

* test: fix to latest adjustment

* Add ctrl logic

* Add dac service

* Continue add ACT handler

* chore: use ZeroAddress

* chore: make var name more general

* connect api test with dac service

* refactor ctrl based on history v2

* Fix: controller upload download flow + basic tests

* hacked mock dac service for simple upload and download

* Insert act uploadhandler into /bzz endpoint and remove uphandler

* Refactor controller and api; enrypt and rLevel passed on during up/download

* Connect Get,Head,Post endpoints with ACT

* Add: act to devnode

* devnode: close dac during shutdown

* pass decrypted ref in r.ctx

* set address ctx as swarm address

* refactor: call actEncrpytionHandler in every endpoint

* typo and comment fix in dynamicaccess

* Add: mock dynamicaccess service and api tests

* Add: TestDacEachEndpointWithAct; fixed some review comments

* Add ACT head test for endpoints

* CHG: first encrypt via ACT then upload normal reference

* FIX: apiservice.dac nil error

---------

Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Ferenc Sárai <[email protected]>
Co-authored-by: Peter Ott <[email protected]>
Co-authored-by: Levente Kiss <[email protected]>
Co-authored-by: Roland Seres <[email protected]>
Co-authored-by: Kexort <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>
Co-authored-by: András Arányi <[email protected]>
Co-authored-by: rolandlor <[email protected]>
Co-authored-by: Peter Ott <[email protected]>

Act refactor api and ctrl (#36)

* Refactor: newreference pattern for history, kvs, grantee

* CHG: history metadata to store granteelist reference

* History test with metadata

* Remove putter from grantee

ACT grantee management (#37)

* implement grantee management

* Add POST endpoint + fixes

* Save grantees as pubkey list and fix remove error; CHG: act-handler logger names

* Refactor: pass getter, putter to controller functions

* Refactor: error handling in dynamicaccess; Read cache header only for download handlers

* CHG: grantees ref is encrypted and added to history ref + tests

* Fix nil pointer dereference panic

* CHG: put actref in handlegrantees; Add: pin, tag,deferred headers

* CHG: pass loadsave to handlers; check if history address is nil

* FIX: re-init history so that it can be saved; only add publisher if histroy is zero

* make act timestamp optional

* fix revoke grantees

* Fix: Act timestamp header nil check; Uploadhandler UT

* Fix controller nil pointer deref

---------

Co-authored-by: Bálint Ujvári <[email protected]>

Start refactoring for new linter rules (#39)

refactor: refactoring to match new linter rules according to #38

Not everything is fixed, just a reference what can and needs to be improved.

* implement grantee management

* Add POST endpoint + fixes

* Save grantees as pubkey list and fix remove error; CHG: act-handler logger names

* Refactor: pass getter, putter to controller functions

* Refactor: error handling in dynamicaccess; Read cache header only for download handlers

* CHG: grantees ref is encrypted and added to history ref + tests

* Fix nil pointer dereference panic

* CHG: put actref in handlegrantees; Add: pin, tag,deferred headers

* CHG: pass loadsave to handlers; check if history address is nil

* FIX: re-init history so that it can be saved; only add publisher if histroy is zero

* make act timestamp optional

* fix revoke grantees

* Fix: Act timestamp header nil check; Uploadhandler UT

* refactor: start refactoring for now linter rules

* refactor: revert non ACT related files

* CHG: accesslogic getkeys refactor

* refactor: fix errcheck and ineffassign linter errors in most cases

* refactor: add headers, and change error handling

* refactor: add headers

---------

Co-authored-by: Kexort <[email protected]>
Co-authored-by: Bálint Ujvári <[email protected]>

refactor(act): typos & docs (#40)

refactor(act): typos, docs, removed unused import aliases

refactor(act): naming and fix remaining PR comments (#42)

* Refactor naming and fix remaining PR comments

* use ctx in grantees.get

* remove act_ucs.md

Refactor accesslogic.AddGrantee and parallelize tests (#43)

docs(act): add act api to openapi (#44)

docs(act): add incoming act headers to openapi
docs(act): add act headers to upload endpoints in openapi
docs(act): add act grantee list endpoints to openapi

refactor(act): chunk download and granteelist handling (#46)

refactor(act): controller logic (#47)

test(act): controller add, revoke and get with history + fix typos (#48)

refactor(act): fix pr comments (#50)

* refactor(act): fix pr comments

* refactor(act): fix linter errors

* refactor(act): move kvs to accesscontrol as a subpackage

* refactor(act): typo and comment fix

chore: bump protobuf version to 1.33.0 (ethersphere#4613) (ethersphere#4688)

fix: save stamp issuer after failed uploads (ethersphere#4684)

chore: pre-release updates (ethersphere#4675)

chore: bump go ethereum version to 1.14.3 (ethersphere#4661) (ethersphere#4689)

fix: allow maxMultiplexForwards to be set to zero (ethersphere#4682)

chore: bump go version to 1.22 (ethersphere#4590) (ethersphere#4687)

feat: remove debug api (ethersphere#4674)

feat: remove auth (ethersphere#4679)

doc(act): add grantee endpoint to openapi (#62)

ci: disable commit linting (temporarily) (#63)

refactor(act): error handling and testing (#64)
aranyia pushed a commit to Solar-Punk-Ltd/bee that referenced this pull request Jul 9, 2024
aranyia pushed a commit to Solar-Punk-Ltd/bee that referenced this pull request Jul 9, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants