Skip to content

Commit

Permalink
🔒 first iteration ingress hardenning
Browse files Browse the repository at this point in the history
  • Loading branch information
Yoan Moscatelli committed Nov 29, 2024
1 parent 75ed313 commit 2acd4d5
Show file tree
Hide file tree
Showing 10 changed files with 155 additions and 28 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

## Release 128.0.1 (in development)

- Only use modern Ciphers in Ingress configuration
(PR[#4488](https://github.com/scality/metalk8s/pull/4488))

## Release 128.0.0

### Enhancements
Expand Down
19 changes: 12 additions & 7 deletions buildchain/buildchain/codegen.py
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ def codegen_chart_fluent_bit() -> types.TaskDict:
def codegen_chart_ingress_nginx() -> types.TaskDict:
"""Generate the SLS file for NGINX Ingress using the chart render script."""
chart_dir = constants.CHART_ROOT / "ingress-nginx"
namespace = "metalk8s-ingress"
actions = []
file_dep = list(utils.git_ls(chart_dir))
file_dep.append(constants.CHART_RENDER_SCRIPT)
Expand All @@ -136,12 +137,13 @@ def codegen_chart_ingress_nginx() -> types.TaskDict:
target_sls = (
constants.ROOT / "salt/metalk8s/addons/nginx-ingress/deployed/chart.sls"
)
value_file = constants.CHART_ROOT / "ingress-nginx.yaml"
name = "ingress-nginx"
value_file = constants.CHART_ROOT / f"{name}.yaml"
actions.append(
doit.action.CmdAction(
f"{constants.CHART_RENDER_CMD} ingress-nginx {value_file} {chart_dir} "
f"--namespace metalk8s-ingress --remove-manifest ConfigMap "
f"ingress-nginx-controller "
f"{constants.CHART_RENDER_CMD} {name} {value_file} {chart_dir} "
f"--namespace {namespace} --remove-manifest ConfigMap "
f"{name}-controller "
f"--output {target_sls}",
cwd=constants.ROOT,
)
Expand All @@ -154,11 +156,14 @@ def codegen_chart_ingress_nginx() -> types.TaskDict:
/ "salt/metalk8s/addons/nginx-ingress-control-plane"
/ "deployed/chart.sls"
)
value_file = constants.CHART_ROOT / "ingress-nginx-control-plane.yaml"
name = "ingress-nginx-control-plane"
value_file = constants.CHART_ROOT / f"{name}.yaml"
actions.append(
doit.action.CmdAction(
f"{constants.CHART_RENDER_CMD} ingress-nginx-control-plane {value_file} "
f"{chart_dir} --namespace metalk8s-ingress --output {target_sls}",
f"{constants.CHART_RENDER_CMD} {name} {value_file} {chart_dir} "
f"--namespace {namespace} --remove-manifest ConfigMap "
f"{name}-controller "
f"--output {target_sls}",
cwd=constants.ROOT,
)
)
Expand Down
9 changes: 9 additions & 0 deletions buildchain/buildchain/salt_tree.py
Original file line number Diff line number Diff line change
Expand Up @@ -443,6 +443,15 @@ def task(self) -> types.TaskDict:
Path("salt/metalk8s/addons/nginx-ingress-control-plane/certs/server.sls"),
Path("salt/metalk8s/addons/nginx-ingress-control-plane/deployed/init.sls"),
Path("salt/metalk8s/addons/nginx-ingress-control-plane/deployed/chart.sls"),
Path("salt/metalk8s/addons/nginx-ingress-control-plane/deployed/config-map.sls"),
Path(
"salt/metalk8s/addons/nginx-ingress-control-plane/deployed/",
"service-configuration.sls",
),
Path(
"salt/metalk8s/addons/nginx-ingress-control-plane/config/",
"ingress-controller.yaml.j2",
),
Path("salt/metalk8s/addons/nginx-ingress-control-plane/deployed/tls-secret.sls"),
Path("salt/metalk8s/backup/certs/ca.sls"),
Path("salt/metalk8s/backup/certs/server.sls"),
Expand Down
52 changes: 49 additions & 3 deletions docs/operation/cluster_and_service_configuration.rst
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,28 @@ under the key ``data.config\.yaml``:
metalk8s-ingress-controller-config
The following documentation is not exhaustive and is just here to give
some hints on basic usage, for more details or advanced
configuration, see the official `Nginx Ingress Controller documentation`_.

.. _Nginx Ingress Controller documentation: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/

Control plane Ingress Controller Configuration Customization
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Same as the Workload plane Ingress Controller, Control Plane can be overridden
by editing its Cluster and Service ConfigMap
``metalk8s-ingress-control-plane-controller-config``
in namespace ``metalk8s-ingress``
under the key ``data.config\.yaml``:

.. code-block:: shell
root@bootstrap $ kubectl --kubeconfig /etc/kubernetes/admin.conf \
edit configmap -n metalk8s-ingress \
metalk8s-ingress-control-plane-controller-config
The following documentation is not exhaustive and is just here to give
some hints on basic usage, for more details or advanced
configuration, see the official `Nginx Ingress Controller documentation`_.
Expand All @@ -186,6 +208,29 @@ HTTP2 can be disabled by setting ``use-http2`` to ``false``:
config:
use-http2: "false"
Modify authorized Ciphers
"""""""""""""""""""""""""

Strong cipher configurations may not allow legacy user agents or user agents
with weak configurations to connect to your site. If your server must also
pass to a legacy upstream server, this may prevent it from being able to
negotiate a cipher upstream.

If you use an old client that does not support modern ciphers, you can use the
ones provided by the CIS Nginx Benchmark for example:

.. code-block:: yaml
apiVersion: v1
kind: ConfigMap
data:
config.yaml: |-
apiVersion: addons.metalk8s.scality.com/v1alpha2
kind: IngressControllerConfig
spec:
config:
ssl-ciphers: "ALL:!EXP:!NULL:!ADH:!LOW:!SSLv2:!SSLv3:!MD5:!RC4"
Applying configuration
""""""""""""""""""""""

Expand All @@ -195,9 +240,10 @@ then be applied with Salt.
.. parsed-literal::
root\@bootstrap $ kubectl exec --kubeconfig /etc/kubernetes/admin.conf \\
-n kube-system -c salt-master salt-master-bootstrap -- \\
salt-run state.sls \\
metalk8s.addons.nginx-ingress.deployed \\
$(kubectl --kubeconfig /etc/kubernetes/admin.conf \\
get pod -n kube-system -l app=salt-master -o name) \\
-n kube-system -c salt-master -- \\
salt-run state.sls metalk8s.addons.nginx-ingress.deployed \\
saltenv=metalk8s-|version|
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
#!jinja|yaml

# Defaults for configuration of Ingress Controller
apiVersion: addons.metalk8s.scality.com/v1alpha2
kind: IngressControllerConfig
spec:
config:
allow-snippet-annotations: 'true'
hide-headers: 'Server,X-Powered-By'
ssl-ciphers: 'EECDH+AESGCM:EDH+AESGCM'
ssl-protocols: 'TLSv1.2 TLSv1.3'
Original file line number Diff line number Diff line change
Expand Up @@ -23,23 +23,6 @@ metadata:
name: ingress-nginx-control-plane
namespace: metalk8s-ingress
---
apiVersion: v1
data:
allow-snippet-annotations: 'true'
kind: ConfigMap
metadata:
labels:
app.kubernetes.io/component: controller
app.kubernetes.io/instance: ingress-nginx-control-plane
app.kubernetes.io/managed-by: salt
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: metalk8s
app.kubernetes.io/version: 1.10.3
helm.sh/chart: ingress-nginx-4.10.3
heritage: metalk8s
name: ingress-nginx-control-plane-controller
namespace: metalk8s-ingress
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
{%- set ingress_control_plane_controller_defaults = salt.slsutil.renderer(
'salt://metalk8s/addons/nginx-ingress-control-plane/config/ingress-controller.yaml.j2', saltenv=saltenv
)
%}

{%- set ingress_control_plane_controller = salt.metalk8s_service_configuration.get_service_conf(
'metalk8s-ingress', 'metalk8s-ingress-control-plane-controller-config', ingress_control_plane_controller_defaults
)
%}

Create Control Plane Ingress Controller configuration Config Map:
metalk8s_kubernetes.object_present:
- manifest:
apiVersion: v1
kind: ConfigMap
metadata:
name: ingress-nginx-control-plane-controller
namespace: metalk8s-ingress
labels:
app.kubernetes.io/component: controller
app.kubernetes.io/instance: ingress-nginx-control-plane
app.kubernetes.io/managed-by: salt
app.kubernetes.io/name: ingress-nginx
app.kubernetes.io/part-of: metalk8s
heritage: metalk8s
annotations:
ingressclass.kubernetes.io/is-default-class: "true"
data:
{{ ingress_control_plane_controller.spec.config | yaml(False) | indent(10) }}
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
include:
- metalk8s.addons.nginx-ingress.deployed.namespace
- .tls-secret
- .chart
- .service-configuration
- .config-map
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
include:
- .namespace

{%- set namespace = 'metalk8s-ingress' %}
{%- set name = 'metalk8s-ingress-control-plane-controller-config' %}

{%- set ingress_service_config = salt.metalk8s_kubernetes.get_object(
kind='ConfigMap',
apiVersion='v1',
namespace=namespace,
name=name
)
%}

{%- if ingress_service_config is none %}

Create Ingress ServiceConfiguration (metalk8s-ingress/metalk8s-ingress-control-plane-controller-config):
metalk8s_kubernetes.object_present:
- manifest:
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ name }}
namespace: {{ namespace }}
data:
config.yaml: |-
apiVersion: addons.metalk8s.scality.com/v1alpha2
kind: IngressControllerConfig
spec: {}


{%- else %}

Ingress ServiceConfiguration already exists:
test.succeed_without_changes: []

{%- endif %}
Original file line number Diff line number Diff line change
Expand Up @@ -6,3 +6,6 @@ kind: IngressControllerConfig
spec:
config:
allow-snippet-annotations: 'true'
hide-headers: 'Server,X-Powered-By'
ssl-ciphers: 'EECDH+AESGCM:EDH+AESGCM'
ssl-protocols: 'TLSv1.2 TLSv1.3'

0 comments on commit 2acd4d5

Please sign in to comment.