Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
# and cross-compiles to $TARGETOS/$TARGETARCH. This makes multi-arch builds
# (linux/amd64, linux/arm64) fast under buildx without requiring QEMU emulation
# for the build itself.
FROM --platform=$BUILDPLATFORM golang:1.25 AS builder
FROM --platform=$BUILDPLATFORM golang:1.26 AS builder

# Provided automatically by BuildKit when using buildx with --platform.
ARG TARGETOS
Expand Down
2 changes: 1 addition & 1 deletion Taskfile.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ vars:
# renovate: datasource=go depName=fybrik.io/crdoc
CRDOC_VERSION: v0.6.4
# renovate: datasource=go depName=github.com/kyverno/chainsaw
CHAINSAW_VERSION: v0.2.13
CHAINSAW_VERSION: v0.2.15
# Container image configuration
MILO_IMAGE_NAME: "ghcr.io/milo-os/milo"
MILO_IMAGE_TAG: "dev"
Expand Down
14 changes: 10 additions & 4 deletions cmd/milo/apiserver/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ import (
sessionsbackend "go.miloapis.com/milo/internal/apiserver/identity/sessions"
useridentitiesbackend "go.miloapis.com/milo/internal/apiserver/identity/useridentities"
identitystorage "go.miloapis.com/milo/internal/apiserver/storage/identity"
kplanestorage "go.miloapis.com/milo/internal/apiserver/storage/kplane"
admissionquota "go.miloapis.com/milo/internal/quota/admission"
discoveryapi "go.miloapis.com/milo/pkg/apis/discovery"
identityapi "go.miloapis.com/milo/pkg/apis/identity"
Expand Down Expand Up @@ -371,9 +372,12 @@ func NewConfig(opts options.CompletedOptions) (*Config, error) {
if registry != nil {
h = discoveryctx.DiscoveryContextFilter(h, registry)
}
// Bridge Milo's request.WithProject(ctx, ...) to kplane's mc.WithCluster(ctx, ...)
// after the project router has parsed the URL but before the rest of the chain runs.
inner := kplanestorage.WithProjectAsCluster(DefaultBuildHandlerChain(h, c, loopbackClientConfig))
return datumfilters.ProjectRouterWithRequestInfo(
DefaultBuildHandlerChain(h, c, loopbackClientConfig), // build stock chain first
c.RequestInfoResolver, // then wrap with router
inner,
c.RequestInfoResolver,
)
}

Expand Down Expand Up @@ -405,8 +409,9 @@ func NewConfig(opts options.CompletedOptions) (*Config, error) {
if registry != nil {
h = discoveryctx.DiscoveryContextFilter(h, registry)
}
inner := kplanestorage.WithProjectAsCluster(DefaultBuildHandlerChain(h, c, loopbackClientConfig))
return datumfilters.ProjectRouterWithRequestInfo(
DefaultBuildHandlerChain(h, c, loopbackClientConfig),
inner,
c.RequestInfoResolver,
)
}
Expand All @@ -431,8 +436,9 @@ func NewConfig(opts options.CompletedOptions) (*Config, error) {
if registry != nil {
h = discoveryctx.DiscoveryContextFilter(h, registry)
}
inner := kplanestorage.WithProjectAsCluster(DefaultBuildHandlerChain(h, c, loopbackClientConfig))
return datumfilters.ProjectRouterWithRequestInfo(
DefaultBuildHandlerChain(h, c, loopbackClientConfig),
inner,
c.RequestInfoResolver,
)
}
Expand Down
25 changes: 11 additions & 14 deletions cmd/milo/apiserver/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import (
"github.com/spf13/cobra"
crd "go.miloapis.com/milo/config/crd"
"go.miloapis.com/milo/internal/apiserver/admission/plugin/namespace/lifecycle"
projectstorage "go.miloapis.com/milo/internal/apiserver/storage/project"
kplanestorage "go.miloapis.com/milo/internal/apiserver/storage/kplane"
apiextensionsv1 "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1"
apiextensionsclient "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" // ← add / keep this
Expand All @@ -21,20 +21,20 @@ import (
"k8s.io/apiserver/pkg/admission"
genericapifilters "k8s.io/apiserver/pkg/endpoints/filters"
genericapiserver "k8s.io/apiserver/pkg/server"
apiservercompat "k8s.io/apiserver/pkg/util/compatibility"
utilfeature "k8s.io/apiserver/pkg/util/feature"
"k8s.io/apiserver/pkg/util/notfoundhandler"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
cliflag "k8s.io/component-base/cli/flag"
"k8s.io/component-base/cli/globalflag"
basecompatibility "k8s.io/component-base/compatibility"
"k8s.io/component-base/logs"
logsapi "k8s.io/component-base/logs/api/v1"
_ "k8s.io/component-base/metrics/prometheus/workqueue"
"k8s.io/component-base/term"
"k8s.io/component-base/version"
"k8s.io/component-base/version/verflag"
basecompatibility "k8s.io/component-base/compatibility"
apiservercompat "k8s.io/apiserver/pkg/util/compatibility"
"k8s.io/klog/v2"
aggregatorapiserver "k8s.io/kube-aggregator/pkg/apiserver"

Expand Down Expand Up @@ -299,13 +299,15 @@ func Run(ctx context.Context, opts options.CompletedOptions) error {
func CreateServerChain(config CompletedConfig) (*aggregatorapiserver.APIAggregator, error) {
notFoundHandler := notfoundhandler.New(config.ControlPlane.Generic.Serializer, genericapifilters.NoMuxAndDiscoveryIncompleteKey)

loopbackConfig := config.ControlPlane.Generic.LoopbackClientConfig

// Native API providers read the control-plane getter when InstallAPIs calls
// NewRESTStorage, so wrapping it once here covers them; CRD storage uses the
// apiextensions getters wrapped below.
config.APIExtensions.GenericConfig.RESTOptionsGetter =
projectstorage.WithProjectAwareDecoratorAndConfig(config.APIExtensions.GenericConfig.RESTOptionsGetter, loopbackConfig)

kplanestorage.WithKplaneStorage(config.APIExtensions.GenericConfig.RESTOptionsGetter)
config.APIExtensions.ExtraConfig.CRDRESTOptionsGetter =
projectstorage.WithProjectAwareDecoratorAndConfig(config.APIExtensions.ExtraConfig.CRDRESTOptionsGetter, loopbackConfig)
kplanestorage.WithKplaneStorage(config.APIExtensions.ExtraConfig.CRDRESTOptionsGetter)
config.ControlPlane.Generic.RESTOptionsGetter =
kplanestorage.WithKplaneStorage(config.ControlPlane.Generic.RESTOptionsGetter)

apiExtensionsServer, err := config.APIExtensions.New(genericapiserver.NewEmptyDelegateWithCustomHandler(notFoundHandler))
if err != nil {
Expand Down Expand Up @@ -353,12 +355,7 @@ func CreateServerChain(config CompletedConfig) (*aggregatorapiserver.APIAggregat
return nil, fmt.Errorf("failed to create storage providers: %w", err)
}

wrapped := make([]controlplaneapiserver.RESTStorageProvider, 0, len(storageProviders))
for _, p := range storageProviders {
wrapped = append(wrapped, projectstorage.WrapProvider(p))
}

if err := nativeAPIs.InstallAPIs(wrapped...); err != nil {
if err := nativeAPIs.InstallAPIs(storageProviders...); err != nil {
return nil, fmt.Errorf("failed to install APIs: %w", err)
}

Expand Down
8 changes: 4 additions & 4 deletions cmd/milo/apiserver/serviceaccounts.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,19 +25,19 @@ func genericTokenGetter(factory informers.SharedInformerFactory) serviceaccount.
// return clientGetter{secretLister: factory.Core().V1().Secrets().Lister(), serviceAccountLister: factory.Core().V1().ServiceAccounts().Lister()}
}

func (c clientGetter) GetServiceAccount(namespace, name string) (*v1.ServiceAccount, error) {
func (c clientGetter) GetServiceAccount(_ context.Context, namespace, name string) (*v1.ServiceAccount, error) {
return c.serviceAccountLister.ServiceAccounts(namespace).Get(name)
}

func (c clientGetter) GetPod(namespace, name string) (*v1.Pod, error) {
func (c clientGetter) GetPod(_ context.Context, namespace, name string) (*v1.Pod, error) {
return nil, apierrors.NewNotFound(v1.Resource("pods"), name)
}

func (c clientGetter) GetSecret(namespace, name string) (*v1.Secret, error) {
func (c clientGetter) GetSecret(_ context.Context, namespace, name string) (*v1.Secret, error) {
return c.secretLister.Secrets(namespace).Get(name)
}

func (c clientGetter) GetNode(name string) (*v1.Node, error) {
func (c clientGetter) GetNode(_ context.Context, name string) (*v1.Node, error) {
return nil, apierrors.NewNotFound(v1.Resource("nodes"), name)
}

Expand Down
164 changes: 98 additions & 66 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,76 +1,89 @@
module go.miloapis.com/milo

go 1.25.0
go 1.26.3

require (
github.com/blang/semver/v4 v4.0.0
github.com/go-logr/logr v1.4.3
github.com/google/cel-go v0.26.0
github.com/spf13/cobra v1.10.0
github.com/spf13/pflag v1.0.9
github.com/google/cel-go v0.26.1
github.com/kplane-dev/apiserver v0.0.10
github.com/spf13/cobra v1.10.2
github.com/spf13/pflag v1.0.10
github.com/stretchr/testify v1.11.1
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.61.0
go.opentelemetry.io/otel v1.36.0
go.opentelemetry.io/otel/trace v1.36.0
golang.org/x/sync v0.18.0
golang.org/x/time v0.12.0
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.65.0
go.opentelemetry.io/otel v1.41.0
go.opentelemetry.io/otel/trace v1.41.0
golang.org/x/sync v0.19.0
golang.org/x/time v0.14.0
gopkg.in/go-jose/go-jose.v2 v2.6.3
k8s.io/api v0.35.0
k8s.io/apiextensions-apiserver v0.35.0
k8s.io/apimachinery v0.35.0
k8s.io/apiserver v0.35.0
k8s.io/client-go v0.35.0
k8s.io/component-base v0.35.0
k8s.io/api v0.36.0
k8s.io/apiextensions-apiserver v0.36.0
k8s.io/apimachinery v0.36.0
k8s.io/apiserver v0.36.0
k8s.io/client-go v1.5.2
k8s.io/component-base v0.36.0
k8s.io/controller-manager v0.35.0
k8s.io/klog/v2 v2.130.1
k8s.io/klog/v2 v2.140.0
k8s.io/kube-aggregator v0.35.0
k8s.io/kube-openapi v0.0.0-20250910181357-589584f1c912
k8s.io/kube-openapi v0.0.0-20260317180543-43fb72c5454a
k8s.io/kubernetes v1.35.0
k8s.io/utils v0.0.0-20251002143259-bc988d571ff4
sigs.k8s.io/controller-runtime v0.23.3
sigs.k8s.io/multicluster-runtime v0.23.3
k8s.io/utils v0.0.0-20260210185600-b8788abfbbc2
sigs.k8s.io/controller-runtime v0.24.1
sigs.k8s.io/multicluster-runtime v0.24.1
sigs.k8s.io/yaml v1.6.0
)

require (
cel.dev/expr v0.24.0 // indirect
cyphar.com/go-pathrs v0.2.1 // indirect
cel.dev/expr v0.25.1 // indirect
cyphar.com/go-pathrs v0.2.2 // indirect
github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161 // indirect
github.com/NYTimes/gziphandler v1.1.1 // indirect
github.com/antlr4-go/antlr/v4 v4.13.0 // indirect
github.com/antlr4-go/antlr/v4 v4.13.1 // indirect
github.com/beorn7/perks v1.0.1 // indirect
github.com/cenkalti/backoff/v4 v4.3.0 // indirect
github.com/cenkalti/backoff/v5 v5.0.3 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/coreos/go-oidc v2.3.0+incompatible // indirect
github.com/coreos/go-oidc v2.5.0+incompatible // indirect
github.com/coreos/go-semver v0.3.1 // indirect
github.com/coreos/go-systemd/v22 v22.5.0 // indirect
github.com/cyphar/filepath-securejoin v0.6.0 // indirect
github.com/coreos/go-systemd/v22 v22.7.0 // indirect
github.com/cyphar/filepath-securejoin v0.6.1 // indirect
github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc // indirect
github.com/distribution/reference v0.6.0 // indirect
github.com/emicklei/go-restful/v3 v3.12.2 // indirect
github.com/emicklei/go-restful/v3 v3.13.0 // indirect
github.com/evanphx/json-patch/v5 v5.9.11 // indirect
github.com/felixge/httpsnoop v1.0.4 // indirect
github.com/fsnotify/fsnotify v1.9.0 // indirect
github.com/fxamacker/cbor/v2 v2.9.0 // indirect
github.com/go-logr/stdr v1.2.2 // indirect
github.com/go-logr/zapr v1.3.0 // indirect
github.com/go-openapi/jsonpointer v0.21.0 // indirect
github.com/go-openapi/jsonreference v0.21.0 // indirect
github.com/go-openapi/swag v0.23.0 // indirect
github.com/go-openapi/jsonpointer v0.22.0 // indirect
github.com/go-openapi/jsonreference v0.21.1 // indirect
github.com/go-openapi/swag v0.24.1 // indirect
github.com/go-openapi/swag/cmdutils v0.24.0 // indirect
github.com/go-openapi/swag/conv v0.24.0 // indirect
github.com/go-openapi/swag/fileutils v0.24.0 // indirect
github.com/go-openapi/swag/jsonname v0.24.0 // indirect
github.com/go-openapi/swag/jsonutils v0.24.0 // indirect
github.com/go-openapi/swag/loading v0.24.0 // indirect
github.com/go-openapi/swag/mangling v0.24.0 // indirect
github.com/go-openapi/swag/netutils v0.24.0 // indirect
github.com/go-openapi/swag/stringutils v0.24.0 // indirect
github.com/go-openapi/swag/typeutils v0.24.0 // indirect
github.com/go-openapi/swag/yamlutils v0.24.0 // indirect
github.com/gogo/protobuf v1.3.2 // indirect
github.com/golang/protobuf v1.5.4 // indirect
github.com/google/btree v1.1.3 // indirect
github.com/google/gnostic-models v0.7.0 // indirect
github.com/google/go-cmp v0.7.0 // indirect
github.com/google/uuid v1.6.0 // indirect
github.com/gorilla/websocket v1.5.4-0.20250319132907-e064f32e3674 // indirect
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 // indirect
github.com/grpc-ecosystem/grpc-gateway/v2 v2.26.3 // indirect
github.com/grpc-ecosystem/go-grpc-middleware/providers/prometheus v1.1.0 // indirect
github.com/grpc-ecosystem/go-grpc-middleware/v2 v2.3.3 // indirect
github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.7 // indirect
github.com/inconshreveable/mousetrap v1.1.0 // indirect
github.com/josharian/intern v1.0.0 // indirect
github.com/json-iterator/go v1.1.12 // indirect
github.com/kplane-dev/informer v0.0.0-00010101000000-000000000000 // indirect
github.com/kplane-dev/storage v0.0.0 // indirect
github.com/kylelemons/godebug v1.1.0 // indirect
github.com/mailru/easyjson v0.7.7 // indirect
github.com/mailru/easyjson v0.9.1 // indirect
github.com/moby/spdystream v0.5.0 // indirect
github.com/moby/sys/mountinfo v0.7.2 // indirect
github.com/moby/term v0.5.0 // indirect
Expand All @@ -79,43 +92,43 @@ require (
github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect
github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f // indirect
github.com/opencontainers/go-digest v1.0.0 // indirect
github.com/opencontainers/selinux v1.13.0 // indirect
github.com/opencontainers/selinux v1.13.1 // indirect
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect
github.com/pquerna/cachecontrol v0.1.0 // indirect
github.com/pquerna/cachecontrol v0.2.0 // indirect
github.com/prometheus/client_golang v1.23.2 // indirect
github.com/prometheus/client_model v0.6.2 // indirect
github.com/prometheus/common v0.66.1 // indirect
github.com/prometheus/procfs v0.16.1 // indirect
github.com/prometheus/common v0.67.5 // indirect
github.com/prometheus/procfs v0.19.2 // indirect
github.com/robfig/cron/v3 v3.0.1 // indirect
github.com/stoewer/go-strcase v1.3.0 // indirect
github.com/stoewer/go-strcase v1.3.1 // indirect
github.com/x448/float16 v0.8.4 // indirect
go.etcd.io/etcd/api/v3 v3.6.5 // indirect
go.etcd.io/etcd/client/pkg/v3 v3.6.5 // indirect
go.etcd.io/etcd/client/v3 v3.6.5 // indirect
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.60.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.34.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.34.0 // indirect
go.opentelemetry.io/otel/metric v1.36.0 // indirect
go.opentelemetry.io/otel/sdk v1.36.0 // indirect
go.opentelemetry.io/proto/otlp v1.5.0 // indirect
go.etcd.io/etcd/api/v3 v3.6.7 // indirect
go.etcd.io/etcd/client/pkg/v3 v3.6.7 // indirect
go.etcd.io/etcd/client/v3 v3.6.7 // indirect
go.opentelemetry.io/auto/sdk v1.2.1 // indirect
go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.65.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.40.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.40.0 // indirect
go.opentelemetry.io/otel/metric v1.41.0 // indirect
go.opentelemetry.io/otel/sdk v1.40.0 // indirect
go.opentelemetry.io/proto/otlp v1.9.0 // indirect
go.uber.org/multierr v1.11.0 // indirect
go.uber.org/zap v1.27.0 // indirect
go.uber.org/zap v1.27.1 // indirect
go.yaml.in/yaml/v2 v2.4.3 // indirect
go.yaml.in/yaml/v3 v3.0.4 // indirect
golang.org/x/crypto v0.45.0 // indirect
golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 // indirect
golang.org/x/net v0.47.0 // indirect
golang.org/x/oauth2 v0.30.0 // indirect
golang.org/x/sys v0.38.0 // indirect
golang.org/x/term v0.37.0 // indirect
golang.org/x/text v0.31.0 // indirect
golang.org/x/tools v0.38.0 // indirect
golang.org/x/crypto v0.47.0 // indirect
golang.org/x/exp v0.0.0-20251219203646-944ab1f22d93 // indirect
golang.org/x/net v0.49.0 // indirect
golang.org/x/oauth2 v0.34.0 // indirect
golang.org/x/sys v0.40.0 // indirect
golang.org/x/term v0.39.0 // indirect
golang.org/x/text v0.33.0 // indirect
golang.org/x/tools v0.41.0 // indirect
gomodules.xyz/jsonpatch/v2 v2.4.0 // indirect
google.golang.org/genproto/googleapis/api v0.0.0-20250303144028-a0af3efb3deb // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20250528174236-200df99c418a // indirect
google.golang.org/grpc v1.72.2 // indirect
google.golang.org/protobuf v1.36.8 // indirect
google.golang.org/genproto/googleapis/api v0.0.0-20260128011058-8636f8732409 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20260128011058-8636f8732409 // indirect
google.golang.org/grpc v1.79.3 // indirect
google.golang.org/protobuf v1.36.12-0.20260120151049-f2248ac996af // indirect
gopkg.in/evanphx/json-patch.v4 v4.13.0 // indirect
gopkg.in/inf.v0 v0.9.1 // indirect
gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect
Expand All @@ -137,8 +150,27 @@ require (
k8s.io/metrics v0.35.0 // indirect
k8s.io/mount-utils v0.35.0 // indirect
k8s.io/pod-security-admission v0.35.0 // indirect
sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.31.2 // indirect
sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.34.0 // indirect
sigs.k8s.io/json v0.0.0-20250730193827-2d320260d730 // indirect
sigs.k8s.io/randfill v1.0.0 // indirect
sigs.k8s.io/structured-merge-diff/v6 v6.3.2-0.20260122202528-d9cc6641c482 // indirect
sigs.k8s.io/structured-merge-diff/v6 v6.3.2 // indirect
)

// pin all k8s.io/* modules to the kplane-dev versions
replace (
// kplane replace doesn't transit to Milo, so we have to repin here.
github.com/kplane-dev/informer => github.com/kplane-dev/informer v0.0.0-20260404055613-d9279cfd5e9b
github.com/kplane-dev/storage => github.com/kplane-dev/storage v0.0.0-20260404055526-b175d95c9fe7
k8s.io/api => github.com/kplane-dev/kubernetes/staging/src/k8s.io/api v0.0.0-20260404055358-aac72e7d04ad
k8s.io/apiextensions-apiserver => github.com/kplane-dev/kubernetes/staging/src/k8s.io/apiextensions-apiserver v0.0.0-20260404055358-aac72e7d04ad
k8s.io/apimachinery => github.com/kplane-dev/kubernetes/staging/src/k8s.io/apimachinery v0.0.0-20260404055358-aac72e7d04ad
k8s.io/apiserver => github.com/kplane-dev/kubernetes/staging/src/k8s.io/apiserver v0.0.0-20260404055358-aac72e7d04ad
k8s.io/client-go => github.com/kplane-dev/kubernetes/staging/src/k8s.io/client-go v0.0.0-20260404055358-aac72e7d04ad
k8s.io/component-base => github.com/kplane-dev/kubernetes/staging/src/k8s.io/component-base v0.0.0-20260404055358-aac72e7d04ad
k8s.io/controller-manager => github.com/kplane-dev/kubernetes/staging/src/k8s.io/controller-manager v0.0.0-20260404055358-aac72e7d04ad
k8s.io/endpointslice => github.com/kplane-dev/kubernetes/staging/src/k8s.io/endpointslice v0.0.0-20260404055358-aac72e7d04ad
k8s.io/kms => github.com/kplane-dev/kubernetes/staging/src/k8s.io/kms v0.0.0-20260404055358-aac72e7d04ad
k8s.io/kube-aggregator => github.com/kplane-dev/kubernetes/staging/src/k8s.io/kube-aggregator v0.0.0-20260404055358-aac72e7d04ad
k8s.io/kube-controller-manager => github.com/kplane-dev/kubernetes/staging/src/k8s.io/kube-controller-manager v0.0.0-20260404055358-aac72e7d04ad
k8s.io/kubernetes => github.com/kplane-dev/kubernetes v0.0.0-20260404055358-aac72e7d04ad
)
Loading
Loading