diff --git a/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/annotation/Ingress.java b/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/annotation/Ingress.java
index 82fb5a43c..49f1ef535 100644
--- a/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/annotation/Ingress.java
+++ b/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/annotation/Ingress.java
@@ -29,6 +29,13 @@
*/
String host() default "";
+ /**
+ * The class of the Ingress. If the ingressClassName is omitted, a default Ingress class is used.
+ *
+ * @return The class of the Ingress.
+ */
+ String ingressClassName() default "";
+
/**
* Controls whether the application should be exposed via Ingress
*/
diff --git a/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/decorator/AddIngressDecorator.java b/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/decorator/AddIngressDecorator.java
index 9f30a9075..a3697cdf7 100644
--- a/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/decorator/AddIngressDecorator.java
+++ b/annotations/kubernetes-annotations/src/main/java/io/dekorate/kubernetes/decorator/AddIngressDecorator.java
@@ -60,6 +60,7 @@ public void visit(KubernetesListBuilder list) {
.withLabels(allLabels)
.endMetadata()
.withNewSpec()
+ .withIngressClassName(Strings.defaultIfEmpty(config.getIngress().getIngressClassName(), null))
.addNewRule()
.withHost(config.getIngress().getHost())
.withNewHttp()
diff --git a/assets/config.md b/assets/config.md
index 81c8717f0..267157165 100644
--- a/assets/config.md
+++ b/assets/config.md
@@ -71,11 +71,6 @@ The document is structured as follows.
| dekorate.kubernetes.deployment-strategy | DeploymentStrategy | Specifies the deployment strategy. | None |
| dekorate.kubernetes.rolling-update | RollingUpdate | Specifies rolling update configuration. The configuration is applied when DeploymentStrategy == Rolling update, or when explicit configuration has been provided. In the later case RollingUpdate is assumed. | ( see RollingUpdate ) |
| dekorate.kubernetes.service-account | String | The service account. | |
-| dekorate.kubernetes.ingress.expose | boolean | Controls whether the application should be exposed via Ingress | false |
-| dekorate.kubernetes.ingress.host | String | The host under which the application is going to be exposed. | |
-| dekorate.kubernetes.ingress.tls-secret-name | String | The name of the secret used to configure TLS. | |
-| dekorate.kubernetes.ingress.tls-hosts | String[] | The list of hosts to be included in the TLS certificate. By default, it will use the application host. | |
-| dekorate.kubernetes.ingress.rules | IngressRule[] | Controls the generated ingress rules to be exposed as part of the Ingress resource. | |
| dekorate.kubernetes.ports | Port[] | The application ports. | |
| dekorate.kubernetes.service-type | ServiceType | The type of service that will be generated for the application. | ClusterIP |
| dekorate.kubernetes.pvc-volumes | PersistentVolumeClaimVolume[] | PersistentVolumeClaim volumes to add to all containers. | |
@@ -94,6 +89,7 @@ The document is structured as follows.
| dekorate.kubernetes.request-resources | ResourceRequirements | The resources that the application container requires. | ( see ResourceRequirements ) |
| dekorate.kubernetes.limit-resources | ResourceRequirements | The resource limit for the application container. | ( see ResourceRequirements ) |
| dekorate.kubernetes.sidecars | Container[] | The sidecars. | |
+| dekorate.kubernetes.ingress | Ingress | Configure the ingress resource. Only if the `expose` property is enabled. | (See Ingress) |
| dekorate.kubernetes.headless | boolean | Controls whether the generated {@link Service} will be headless. | false |
| dekorate.kubernetes.auto-deploy-enabled | boolean | Flag to trigger the registration of the deploy hook. It's generally preferable to use `-Ddekorate.deploy=true` instead of hardcoding this here. | false |
| dekorate.kubernetes.jobs | Job[] | The kubernetes jobs. | ( see Job ) |
@@ -124,6 +120,17 @@ The section below describes all the available subtypes.
| configmap | String | | |
| field | String | | |
+#### Ingress
+
+| Property | Type | Description | Default Value |
+|--------------------|---------------|--------------------------------------------------------------------------------------|-----------------------|
+| expose | boolean | Controls whether the application should be exposed via Ingress. | false |
+| host | String | The host under which the application is going to be exposed. | |
+| ingressClassName | String | The class of the Ingress. | |
+| tlsSecretName | String | The name of the secret used to configure TLS | |
+| tlsHosts | String[] | The list of hosts to be included in the TLS certificate | The application host |
+| rules | IngressRule[] | Controls the generated ingress rules to be exposed as part of the Ingress resource. | |
+
#### IngressRule
| Property | Type | Description | Default Value |
|----------------------|----------|--------------------------------------------------------------------------------------------------------------------|---------------|
diff --git a/docs/configuration-guide.md b/docs/configuration-guide.md
index 86be4dafa..ed46d5c46 100644
--- a/docs/configuration-guide.md
+++ b/docs/configuration-guide.md
@@ -93,11 +93,6 @@ The document is structured as follows.
| dekorate.kubernetes.deployment-strategy | DeploymentStrategy | Specifies the deployment strategy. | None |
| dekorate.kubernetes.rolling-update | RollingUpdate | Specifies rolling update configuration. The configuration is applied when DeploymentStrategy == Rolling update, or when explicit configuration has been provided. In the later case RollingUpdate is assumed. | ( see RollingUpdate ) |
| dekorate.kubernetes.service-account | String | The service account. | |
-| dekorate.kubernetes.ingress.expose | boolean | Controls whether the application should be exposed via Ingress | false |
-| dekorate.kubernetes.ingress.host | String | The host under which the application is going to be exposed. | |
-| dekorate.kubernetes.ingress.tls-secret-name | String | The name of the secret used to configure TLS. | |
-| dekorate.kubernetes.ingress.tls-hosts | String[] | The list of hosts to be included in the TLS certificate. By default, it will use the application host. | |
-| dekorate.kubernetes.ingress.rules | IngressRule[] | Controls the generated ingress rules to be exposed as part of the Ingress resource. | |
| dekorate.kubernetes.ports | Port[] | The application ports. | |
| dekorate.kubernetes.service-type | ServiceType | The type of service that will be generated for the application. | ClusterIP |
| dekorate.kubernetes.pvc-volumes | PersistentVolumeClaimVolume[] | PersistentVolumeClaim volumes to add to all containers. | |
@@ -164,6 +159,16 @@ The section below describes all the available subtypes.
| secret | String | | |
| configmap | String | | |
| field | String | | |
+#### Ingress
+
+| Property | Type | Description | Default Value |
+|--------------------|---------------|--------------------------------------------------------------------------------------|-----------------------|
+| expose | boolean | Controls whether the application should be exposed via Ingress. | false |
+| host | String | The host under which the application is going to be exposed. | |
+| ingressClassName | String | The class of the Ingress. | |
+| tlsSecretName | String | The name of the secret used to configure TLS | |
+| tlsHosts | String[] | The list of hosts to be included in the TLS certificate | The application host |
+| rules | IngressRule[] | Controls the generated ingress rules to be exposed as part of the Ingress resource. | |
#### IngressRule
| Property | Type | Description | Default Value |
@@ -215,13 +220,6 @@ The section below describes all the available subtypes.
| success-threshold | int | The success threshold to use. | 1 |
| failure-threshold | int | The failure threshold to use. | 3 |
-#### Ingress
-
-| Property | Type | Description | Default Value |
-|--------------------|----------|---------------------------------------------------------|---------------|
-| tlsSecretName | String | The name of the secret used to configure TLS | |
-| tlsHosts | String[] | The list of hosts to be included in the TLS certificate | The application host |
-
#### Jobs
| Property | Type | Description | Default Value |
diff --git a/tests/feat-ingress-class-name/pom.xml b/tests/feat-ingress-class-name/pom.xml
new file mode 100644
index 000000000..f6cfcc402
--- /dev/null
+++ b/tests/feat-ingress-class-name/pom.xml
@@ -0,0 +1,73 @@
+
+
+ 4.0.0
+
+
+ dekorate-tests
+ io.dekorate
+ 3.1-SNAPSHOT
+ ../
+
+
+ io.dekorate
+ feat-ingress-class-name
+ Dekorate :: Tests :: Annotations :: Kubernetes :: Ingress with class name
+
+
+
+ io.dekorate
+ kubernetes-annotations
+ ${project.version}
+
+
+ io.dekorate
+ dekorate-spring-boot
+ ${project.version}
+
+
+
+ org.springframework.boot
+ spring-boot-starter-actuator
+ ${version.spring-boot}
+
+
+
+ org.springframework.boot
+ spring-boot-starter-web
+ ${version.spring-boot}
+
+
+
+
+ org.junit.jupiter
+ junit-jupiter-api
+ ${version.junit-jupiter}
+ test
+
+
+ org.junit.jupiter
+ junit-jupiter-engine
+ ${version.junit-jupiter}
+ test
+
+
+
+
+
+
+ org.apache.maven.plugins
+ maven-surefire-plugin
+ true
+
+ false
+
+
+
+ org.springframework.boot
+ spring-boot-maven-plugin
+ ${version.spring-boot}
+
+
+
+
diff --git a/tests/feat-ingress-class-name/src/main/java/io/dekorate/annotationless/DemoApplication.java b/tests/feat-ingress-class-name/src/main/java/io/dekorate/annotationless/DemoApplication.java
new file mode 100644
index 000000000..b1f732aad
--- /dev/null
+++ b/tests/feat-ingress-class-name/src/main/java/io/dekorate/annotationless/DemoApplication.java
@@ -0,0 +1,27 @@
+/**
+ * Copyright 2018 The original authors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package io.dekorate.annotationless;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+@SpringBootApplication
+public class DemoApplication {
+
+ public static void main(String[] args) {
+ SpringApplication.run(DemoApplication.class, args);
+ }
+}
diff --git a/tests/feat-ingress-class-name/src/main/resources/application.properties b/tests/feat-ingress-class-name/src/main/resources/application.properties
new file mode 100644
index 000000000..761ea820a
--- /dev/null
+++ b/tests/feat-ingress-class-name/src/main/resources/application.properties
@@ -0,0 +1,3 @@
+dekorate.kubernetes.ingress.expose=true
+dekorate.kubernetes.ports[0].container-port=8080
+dekorate.kubernetes.ingress.ingressClassName=nginx
diff --git a/tests/feat-ingress-class-name/src/test/java/io/dekorate/annotationless/FeatIngressClassNameTest.java b/tests/feat-ingress-class-name/src/test/java/io/dekorate/annotationless/FeatIngressClassNameTest.java
new file mode 100644
index 000000000..98d7ac2f6
--- /dev/null
+++ b/tests/feat-ingress-class-name/src/test/java/io/dekorate/annotationless/FeatIngressClassNameTest.java
@@ -0,0 +1,47 @@
+/**
+ * Copyright 2018 The original authors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package io.dekorate.annotationless;
+
+import static org.junit.jupiter.api.Assertions.*;
+
+import java.util.Optional;
+
+import org.junit.jupiter.api.Test;
+
+import io.dekorate.utils.Serialization;
+import io.fabric8.kubernetes.api.model.HasMetadata;
+import io.fabric8.kubernetes.api.model.KubernetesList;
+import io.fabric8.kubernetes.api.model.networking.v1.Ingress;
+
+public class FeatIngressClassNameTest {
+
+ @Test
+ public void shouldIngressHaveTlsConfiguration() {
+ KubernetesList list = Serialization
+ .unmarshalAsList(getClass().getClassLoader().getResourceAsStream("META-INF/dekorate/kubernetes.yml"));
+ assertNotNull(list);
+ Ingress i = findFirst(list, Ingress.class).orElseThrow(() -> new IllegalStateException());
+ assertNotNull(i);
+ assertEquals("nginx", i.getSpec().getIngressClassName());
+ }
+
+ Optional findFirst(KubernetesList list, Class t) {
+ return (Optional) list.getItems().stream()
+ .filter(i -> t.isInstance(i))
+ .findFirst();
+ }
+}
diff --git a/tests/pom.xml b/tests/pom.xml
index 2e7e29505..542bb39d1 100644
--- a/tests/pom.xml
+++ b/tests/pom.xml
@@ -87,6 +87,7 @@
issue-fetch-helm-dependencies
feat-1083-ingress-rules
issue-existing-route-resource
+ feat-ingress-class-name