diff --git a/config/crd/bases/camel.apache.org_integrationkits.yaml b/config/crd/bases/camel.apache.org_integrationkits.yaml index 13a8e5802d..2a9de14410 100644 --- a/config/crd/bases/camel.apache.org_integrationkits.yaml +++ b/config/crd/bases/camel.apache.org_integrationkits.yaml @@ -201,6 +201,12 @@ spec: description: The builder trait is internally used to determine the best strategy to build and configure IntegrationKits. properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/config/crd/bases/camel.apache.org_integrationplatforms.yaml b/config/crd/bases/camel.apache.org_integrationplatforms.yaml index 7d6b012d75..97dc83d033 100644 --- a/config/crd/bases/camel.apache.org_integrationplatforms.yaml +++ b/config/crd/bases/camel.apache.org_integrationplatforms.yaml @@ -510,6 +510,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string @@ -2364,6 +2370,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/config/crd/bases/camel.apache.org_integrations.yaml b/config/crd/bases/camel.apache.org_integrations.yaml index f7f71765ef..558ba2dc95 100644 --- a/config/crd/bases/camel.apache.org_integrations.yaml +++ b/config/crd/bases/camel.apache.org_integrations.yaml @@ -6417,6 +6417,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/config/crd/bases/camel.apache.org_kameletbindings.yaml b/config/crd/bases/camel.apache.org_kameletbindings.yaml index 208613e03e..574914b8c6 100644 --- a/config/crd/bases/camel.apache.org_kameletbindings.yaml +++ b/config/crd/bases/camel.apache.org_kameletbindings.yaml @@ -6699,6 +6699,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to + use for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/config/crd/bases/camel.apache.org_pipes.yaml b/config/crd/bases/camel.apache.org_pipes.yaml index 2038cd3a5e..7984794fc0 100644 --- a/config/crd/bases/camel.apache.org_pipes.yaml +++ b/config/crd/bases/camel.apache.org_pipes.yaml @@ -6697,6 +6697,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to + use for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/docs/modules/ROOT/partials/apis/camel-k-crds.adoc b/docs/modules/ROOT/partials/apis/camel-k-crds.adoc index 44c752fff3..c17c963354 100644 --- a/docs/modules/ROOT/partials/apis/camel-k-crds.adoc +++ b/docs/modules/ROOT/partials/apis/camel-k-crds.adoc @@ -5953,6 +5953,13 @@ map[string]string Defines a set of nodes the builder pod is eligible to be scheduled on, based on labels on the node. +|`annotations` + +map[string]string +| + + +When using `pod` strategy, annotation to use for the builder pod. + |=== @@ -6157,6 +6164,8 @@ in order to save resources when the integration does not need to be executed. Integrations that start from the following components are evaluated by the cron trait: `timer`, `cron`, `quartz`. +WARNING: In case of native build-mode defined in xref:traits:quarkus.adoc[quarkus] trait, the component can't be customized. + The rules for using a Kubernetes CronJob are the following: - `timer`: when period is set in milliseconds with no remaining seconds, for example 120000. If there is any second left as in 121000 (120s and 1s) or the presence of any of these parameters (delay, repeatCount, time) then a CronJob won't be created, but a standard deployment. diff --git a/docs/modules/traits/pages/builder.adoc b/docs/modules/traits/pages/builder.adoc index 22f17fa114..deb3481a88 100755 --- a/docs/modules/traits/pages/builder.adoc +++ b/docs/modules/traits/pages/builder.adoc @@ -109,6 +109,10 @@ if you need to execute them. Useful only with `pod` strategy. | map[string]string | Defines a set of nodes the builder pod is eligible to be scheduled on, based on labels on the node. +| builder.annotations +| map[string]string +| When using `pod` strategy, annotation to use for the builder pod. + |=== // End of autogenerated code - DO NOT EDIT! (configuration) diff --git a/docs/modules/traits/pages/cron.adoc b/docs/modules/traits/pages/cron.adoc index 124ae3542c..2250e33057 100755 --- a/docs/modules/traits/pages/cron.adoc +++ b/docs/modules/traits/pages/cron.adoc @@ -10,6 +10,8 @@ in order to save resources when the integration does not need to be executed. Integrations that start from the following components are evaluated by the cron trait: `timer`, `cron`, `quartz`. +WARNING: In case of native build-mode defined in xref:traits:quarkus.adoc[quarkus] trait, the component can't be customized. + The rules for using a Kubernetes CronJob are the following: - `timer`: when period is set in milliseconds with no remaining seconds, for example 120000. If there is any second left as in 121000 (120s and 1s) or the presence of any of these parameters (delay, repeatCount, time) then a CronJob won't be created, but a standard deployment. diff --git a/helm/camel-k/crds/crd-integration-kit.yaml b/helm/camel-k/crds/crd-integration-kit.yaml index 13a8e5802d..2a9de14410 100644 --- a/helm/camel-k/crds/crd-integration-kit.yaml +++ b/helm/camel-k/crds/crd-integration-kit.yaml @@ -201,6 +201,12 @@ spec: description: The builder trait is internally used to determine the best strategy to build and configure IntegrationKits. properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/helm/camel-k/crds/crd-integration-platform.yaml b/helm/camel-k/crds/crd-integration-platform.yaml index 7d6b012d75..97dc83d033 100644 --- a/helm/camel-k/crds/crd-integration-platform.yaml +++ b/helm/camel-k/crds/crd-integration-platform.yaml @@ -510,6 +510,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string @@ -2364,6 +2370,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/helm/camel-k/crds/crd-integration.yaml b/helm/camel-k/crds/crd-integration.yaml index f7f71765ef..558ba2dc95 100644 --- a/helm/camel-k/crds/crd-integration.yaml +++ b/helm/camel-k/crds/crd-integration.yaml @@ -6417,6 +6417,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to use + for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/helm/camel-k/crds/crd-kamelet-binding.yaml b/helm/camel-k/crds/crd-kamelet-binding.yaml index 208613e03e..574914b8c6 100644 --- a/helm/camel-k/crds/crd-kamelet-binding.yaml +++ b/helm/camel-k/crds/crd-kamelet-binding.yaml @@ -6699,6 +6699,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to + use for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/helm/camel-k/crds/crd-pipe.yaml b/helm/camel-k/crds/crd-pipe.yaml index 2038cd3a5e..7984794fc0 100644 --- a/helm/camel-k/crds/crd-pipe.yaml +++ b/helm/camel-k/crds/crd-pipe.yaml @@ -6697,6 +6697,12 @@ spec: builder: description: The configuration of Builder trait properties: + annotations: + additionalProperties: + type: string + description: When using `pod` strategy, annotation to + use for the builder pod. + type: object baseImage: description: Specify a base image type: string diff --git a/pkg/apis/camel/v1/trait/zz_generated.deepcopy.go b/pkg/apis/camel/v1/trait/zz_generated.deepcopy.go index 4b6191a0cf..28edd1939a 100644 --- a/pkg/apis/camel/v1/trait/zz_generated.deepcopy.go +++ b/pkg/apis/camel/v1/trait/zz_generated.deepcopy.go @@ -106,6 +106,13 @@ func (in *BuilderTrait) DeepCopyInto(out *BuilderTrait) { (*out)[key] = val } } + if in.Annotations != nil { + in, out := &in.Annotations, &out.Annotations + *out = make(map[string]string, len(*in)) + for key, val := range *in { + (*out)[key] = val + } + } } // DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new BuilderTrait. diff --git a/resources/traits.yaml b/resources/traits.yaml index 5fd331dd26..747827bea3 100755 --- a/resources/traits.yaml +++ b/resources/traits.yaml @@ -309,6 +309,9 @@ traits: type: map[string]string description: Defines a set of nodes the builder pod is eligible to be scheduled on, based on labels on the node. + - name: annotations + type: map[string]string + description: When using `pod` strategy, annotation to use for the builder pod. - name: camel platform: true profiles: @@ -396,14 +399,15 @@ traits: For such tasks, the cron trait can materialize the integration as a Kubernetes CronJob instead of a standard deployment, in order to save resources when the integration does not need to be executed. Integrations that start from the following - components are evaluated by the cron trait: `timer`, `cron`, `quartz`. The rules - for using a Kubernetes CronJob are the following: - `timer`: when period is set - in milliseconds with no remaining seconds, for example 120000. If there is any - second left as in 121000 (120s and 1s) or the presence of any of these parameters - (delay, repeatCount, time) then a CronJob won''t be created, but a standard deployment. - - `cron`, `quartz`: when the cron expression does not contain seconds (or the - "seconds" part is set to 0). E.g. `cron:tab?schedule=0/2${plus}*{plus}*{plus}*{plus}?` - or `quartz:trigger?cron=0{plus}0/2{plus}*{plus}*{plus}*{plus}?`.' + components are evaluated by the cron trait: `timer`, `cron`, `quartz`. WARNING: + In case of native build-mode defined in xref:traits:quarkus.adoc[quarkus] trait, + the component can''t be customized. The rules for using a Kubernetes CronJob are + the following: - `timer`: when period is set in milliseconds with no remaining + seconds, for example 120000. If there is any second left as in 121000 (120s and + 1s) or the presence of any of these parameters (delay, repeatCount, time) then + a CronJob won''t be created, but a standard deployment. - `cron`, `quartz`: when + the cron expression does not contain seconds (or the "seconds" part is set to + 0). E.g. `cron:tab?schedule=0/2${plus}*{plus}*{plus}*{plus}?` or `quartz:trigger?cron=0{plus}0/2{plus}*{plus}*{plus}*{plus}?`.' properties: - name: enabled type: bool