* feat(api/bolt): backport bolt changes * feat(api/exec): backport exec changes * feat(api/http): backport http/handler/dockerhub changes * feat(api/http): backport http/handler/endpoints changes * feat(api/http): backport http/handler/registries changes * feat(api/http): backport http/handler/stacks changes * feat(api/http): backport http/handler changes * feat(api/http): backport http/proxy/factory/azure changes * feat(api/http): backport http/proxy/factory/docker changes * feat(api/http): backport http/proxy/factory/utils changes * feat(api/http): backport http/proxy/factory/kubernetes changes * feat(api/http): backport http/proxy/factory changes * feat(api/http): backport http/security changes * feat(api/http): backport http changes * feat(api/internal): backport internal changes * feat(api): backport api changes * feat(api/kubernetes): backport kubernetes changes * fix(api/http): changes on backend following backport
46 lines
1.2 KiB
Go
46 lines
1.2 KiB
Go
package kubernetes
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
portainer "github.com/portainer/portainer/api"
|
|
)
|
|
|
|
func (transport *baseTransport) proxyNamespaceDeleteOperation(request *http.Request, namespace string) (*http.Response, error) {
|
|
registries, err := transport.dataStore.Registry().Registries()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
for _, registry := range registries {
|
|
for endpointID, registryAccessPolicies := range registry.RegistryAccesses {
|
|
if endpointID != transport.endpoint.ID {
|
|
continue
|
|
}
|
|
|
|
namespaces := []string{}
|
|
for _, ns := range registryAccessPolicies.Namespaces {
|
|
if ns == namespace {
|
|
continue
|
|
}
|
|
namespaces = append(namespaces, ns)
|
|
}
|
|
|
|
if len(namespaces) != len(registryAccessPolicies.Namespaces) {
|
|
updatedAccessPolicies := portainer.RegistryAccessPolicies{
|
|
Namespaces: namespaces,
|
|
UserAccessPolicies: registryAccessPolicies.UserAccessPolicies,
|
|
TeamAccessPolicies: registryAccessPolicies.TeamAccessPolicies,
|
|
}
|
|
|
|
registry.RegistryAccesses[endpointID] = updatedAccessPolicies
|
|
err := transport.dataStore.Registry().UpdateRegistry(registry.ID, ®istry)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return transport.executeKubernetesRequest(request, false)
|
|
}
|