Skip to content

Commit

Permalink
feat: Improve security posture of proxy containers. (#322)
Browse files Browse the repository at this point in the history
This adds additional controls on the security context for pod containers to address these common
k8s security best practices:

- Run as a non-root user
- Mount container's root filesystem as read only
- Restrict Container from acquiring additional privileges
  • Loading branch information
hessjcg authored Apr 20, 2023
1 parent 548a922 commit dc8911e
Showing 1 changed file with 13 additions and 4 deletions.
17 changes: 13 additions & 4 deletions internal/workload/podspec_updates.go
Original file line number Diff line number Diff line change
Expand Up @@ -482,7 +482,7 @@ func (s *updateState) update(wl *PodWorkload, matches []*cloudsqlapi.AuthProxyWo
inst := matches[i]

newContainer := corev1.Container{}
s.updateContainer(inst, wl, &newContainer)
s.updateContainer(inst, &newContainer)
containers = append(containers, newContainer)

// Add pod annotation for each instance
Expand Down Expand Up @@ -515,9 +515,7 @@ func (s *updateState) update(wl *PodWorkload, matches []*cloudsqlapi.AuthProxyWo
}

// updateContainer Creates or updates the proxy container in the workload's PodSpec
func (s *updateState) updateContainer(p *cloudsqlapi.AuthProxyWorkload, wl Workload, c *corev1.Container) {
l.Info("Updating wl {{wl}}, no update needed.", "name", client.ObjectKeyFromObject(wl.Object()))

func (s *updateState) updateContainer(p *cloudsqlapi.AuthProxyWorkload, c *corev1.Container) {
// if the c was fully overridden, just use that c.
if p.Spec.AuthProxyContainer != nil && p.Spec.AuthProxyContainer.Container != nil {
p.Spec.AuthProxyContainer.Container.DeepCopyInto(c)
Expand Down Expand Up @@ -629,8 +627,19 @@ func (s *updateState) updateContainer(p *cloudsqlapi.AuthProxyWorkload, wl Workl
// applyContainerSpec applies settings from cloudsqlapi.AuthProxyContainerSpec
// to the container
func (s *updateState) applyContainerSpec(p *cloudsqlapi.AuthProxyWorkload, c *corev1.Container) {
t := true
var f bool
c.Image = s.defaultProxyImage()
c.Resources = defaultContainerResources
c.SecurityContext = &corev1.SecurityContext{
// The default Cloud SQL Auth Proxy image runs as the
// "nonroot" user and group (uid: 65532) by default.
RunAsNonRoot: &t,
// Use a read-only filesystem
ReadOnlyRootFilesystem: &t,
// Do not allow privilege escalation
AllowPrivilegeEscalation: &f,
}

if p.Spec.AuthProxyContainer == nil {
return
Expand Down

0 comments on commit dc8911e

Please sign in to comment.