Skip to content

Commit

Permalink
Run dnsmasq not as privileged user
Browse files Browse the repository at this point in the history
Jira: OSPRH-10853

Signed-off-by: Martin Schuppert <[email protected]>
  • Loading branch information
stuggi committed Oct 22, 2024
1 parent 6534d49 commit 5a57c6d
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 15 deletions.
12 changes: 8 additions & 4 deletions controllers/network/dnsmasq_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import (

k8s_errors "k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/util/intstr"
"k8s.io/client-go/kubernetes"
ctrl "sigs.k8s.io/controller-runtime"
"sigs.k8s.io/controller-runtime/pkg/builder"
Expand Down Expand Up @@ -375,10 +376,13 @@ func (r *DNSMasqReconciler) reconcileNormal(ctx context.Context, instance *netwo
Namespace: instance.Namespace,
Labels: serviceLabels,
Selector: serviceLabels,
Port: service.GenericServicePort{
Name: dnsmasq.ServiceName,
Port: dnsmasq.DNSPort,
Protocol: corev1.ProtocolUDP,
Ports: []corev1.ServicePort{
{
Name: dnsmasq.ServiceName,
Protocol: corev1.ProtocolUDP,
Port: dnsmasq.DNSPort,
TargetPort: intstr.IntOrString{Type: intstr.Int, IntVal: dnsmasq.DNSTargetPort},
},
},
}),
5,
Expand Down
2 changes: 2 additions & 0 deletions pkg/dnsmasq/const.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,6 @@ const (

// DNSPort -
DNSPort int32 = 53
// DNSTargetPort - port used the service is listening on in the pod
DNSTargetPort int32 = 5353
)
20 changes: 14 additions & 6 deletions pkg/dnsmasq/deployment.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/util/intstr"
"k8s.io/utils/ptr"
)

const (
Expand All @@ -45,7 +46,6 @@ func Deployment(
annotations map[string]string,
cms *corev1.ConfigMapList,
) *appsv1.Deployment {
runAsUser := int64(0)
terminationGracePeriodSeconds := int64(10)

livenessProbe := &corev1.Probe{
Expand Down Expand Up @@ -73,7 +73,7 @@ func Deployment(
dnsmasqCmd = append(dnsmasqCmd, "--log-debug")
dnsmasqCmd = append(dnsmasqCmd, "--bind-interfaces")
dnsmasqCmd = append(dnsmasqCmd, "--listen-address=$(POD_IP)")
dnsmasqCmd = append(dnsmasqCmd, "--port "+strconv.Itoa(int(DNSPort)))
dnsmasqCmd = append(dnsmasqCmd, "--port "+strconv.Itoa(int(DNSTargetPort)))
// log to stdout
dnsmasqCmd = append(dnsmasqCmd, "--log-facility=-")
// dns
Expand All @@ -94,10 +94,10 @@ func Deployment(
// https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/
//
livenessProbe.TCPSocket = &corev1.TCPSocketAction{
Port: intstr.IntOrString{Type: intstr.Int, IntVal: int32(DNSPort)},
Port: intstr.IntOrString{Type: intstr.Int, IntVal: DNSTargetPort},
}
readinessProbe.TCPSocket = &corev1.TCPSocketAction{
Port: intstr.IntOrString{Type: intstr.Int, IntVal: int32(DNSPort)},
Port: intstr.IntOrString{Type: intstr.Int, IntVal: DNSTargetPort},
}

envVars := map[string]env.Setter{}
Expand Down Expand Up @@ -129,7 +129,11 @@ func Deployment(
Args: initArgs,
Image: instance.Spec.ContainerImage,
SecurityContext: &corev1.SecurityContext{
RunAsUser: &runAsUser,
RunAsNonRoot: ptr.To(true),
AllowPrivilegeEscalation: ptr.To(false),
SeccompProfile: &corev1.SeccompProfile{
Type: corev1.SeccompProfileTypeRuntimeDefault,
},
},
Env: env.MergeEnvs([]corev1.EnvVar{}, envVars),
VolumeMounts: getVolumeMounts(instance.Name, cms),
Expand All @@ -142,7 +146,11 @@ func Deployment(
Args: args,
Image: instance.Spec.ContainerImage,
SecurityContext: &corev1.SecurityContext{
RunAsUser: &runAsUser,
RunAsNonRoot: ptr.To(true),
AllowPrivilegeEscalation: ptr.To(false),
SeccompProfile: &corev1.SeccompProfile{
Type: corev1.SeccompProfileTypeRuntimeDefault,
},
},
Env: env.MergeEnvs([]corev1.EnvVar{}, envVars),
VolumeMounts: getVolumeMounts(instance.Name, cms),
Expand Down
6 changes: 3 additions & 3 deletions pkg/dnsmasq/volumes.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,14 @@ func getVolumes(
name string,
cms *corev1.ConfigMapList,
) []corev1.Volume {
var config0640AccessMode int32 = 0640
var config0644AccessMode int32 = 0644

volumes := []corev1.Volume{
{
Name: "config",
VolumeSource: corev1.VolumeSource{
ConfigMap: &corev1.ConfigMapVolumeSource{
DefaultMode: &config0640AccessMode,
DefaultMode: &config0644AccessMode,
LocalObjectReference: corev1.LocalObjectReference{
Name: name,
},
Expand All @@ -45,7 +45,7 @@ func getVolumes(
Name: cm.Name,
VolumeSource: corev1.VolumeSource{
ConfigMap: &corev1.ConfigMapVolumeSource{
DefaultMode: &config0640AccessMode,
DefaultMode: &config0644AccessMode,
LocalObjectReference: corev1.LocalObjectReference{
Name: cm.Name,
},
Expand Down
4 changes: 2 additions & 2 deletions tests/functional/dnsmasq_controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,8 +184,8 @@ var _ = Describe("DNSMasq controller", func() {
g.Expect(container.VolumeMounts).To(HaveLen(3))
g.Expect(container.Image).To(Equal(containerImage))

g.Expect(container.LivenessProbe.TCPSocket.Port.IntVal).To(Equal(int32(53)))
g.Expect(container.ReadinessProbe.TCPSocket.Port.IntVal).To(Equal(int32(53)))
g.Expect(container.LivenessProbe.TCPSocket.Port.IntVal).To(Equal(int32(5353)))
g.Expect(container.ReadinessProbe.TCPSocket.Port.IntVal).To(Equal(int32(5353)))
}, timeout, interval).Should(Succeed())
})

Expand Down

0 comments on commit 5a57c6d

Please sign in to comment.