diff --git a/docs/modules/ROOT/images/architecture/kamelets_deployment.png b/docs/modules/ROOT/images/architecture/kamelets_deployment.png new file mode 100644 index 0000000000..dbb184f071 Binary files /dev/null and b/docs/modules/ROOT/images/architecture/kamelets_deployment.png differ diff --git a/docs/modules/ROOT/camel_k_pipeline.png b/docs/modules/ROOT/images/camel_k_pipeline.png similarity index 100% rename from docs/modules/ROOT/camel_k_pipeline.png rename to docs/modules/ROOT/images/camel_k_pipeline.png diff --git a/docs/modules/ROOT/nav-end.adoc b/docs/modules/ROOT/nav-end.adoc index 2df74b5cb2..46576b7ff5 100644 --- a/docs/modules/ROOT/nav-end.adoc +++ b/docs/modules/ROOT/nav-end.adoc @@ -83,6 +83,7 @@ *** xref:architecture/cr/camel-catalog.adoc[CamelCatalog] ** xref:architecture/runtime.adoc[Runtime] ** xref:architecture/traits.adoc[Traits] +** xref:architecture/kamelets.adoc[Kamelets] ** xref:architecture/incremental-image.adoc[Incremental Image] * API ** xref:apis/camel-k.adoc[Camel K API] diff --git a/docs/modules/ROOT/pages/architecture/kamelets.adoc b/docs/modules/ROOT/pages/architecture/kamelets.adoc new file mode 100644 index 0000000000..b978262088 --- /dev/null +++ b/docs/modules/ROOT/pages/architecture/kamelets.adoc @@ -0,0 +1,13 @@ += Kamelets architecture in Camel K + +xref:kamelets/kamelets.adoc[Kamelets] are a technology which were originally developed as a Camel K side resource but moved into Camel framework as Kamelet component. From an design point of view, a Kamelet is a specification that is provided into the cluster and which can be used at any point by an Integration or a Pipe, in order to reuse the connector style approach. + +In Camel framework, a Kamelet is nothing than a component which can be used as any other component with the `kamelet` uri scheme. This is translated to one or more Route Templates. What's important for Camel runtime is to have the Kamelet spec available somewhere when running the application making reference to it. + +== Deployment model + +In Camel K, it is worth to explain how the Kamelets are deployed in order to make Camel runtime application to correctly use the Kamelet referenced in the Integration. First of all, the operator uses a xref:traits:kamelets.adoc[Camel K trait] which is in charge to discover the Kamelets used in your route. This is due to get all the specification and dependencies required. + +image::architecture/kamelets_deployment.png[Kamelets deployment model] + +The operator creates a Configmap in order to bundle all the Kamelets which are eventually required by the application runtime. The Kamelets spec has to be available and in ready phase status. Once the application is created and ready to start, the operator mounts such a Configmap in a known location (default `/etc/camel/kamelets`) so that the Camel application will be able to read the definition from such location and run them according the logic expected in the same Camel framework. diff --git a/docs/modules/ROOT/pages/kamelets/kamelets-distribution.adoc b/docs/modules/ROOT/pages/kamelets/kamelets-distribution.adoc index 617039bc3e..77e5a99fb5 100644 --- a/docs/modules/ROOT/pages/kamelets/kamelets-distribution.adoc +++ b/docs/modules/ROOT/pages/kamelets/kamelets-distribution.adoc @@ -18,4 +18,13 @@ kamel kamelet add-repo :/[/path_to_kamelets_folder][@ ``` Mind that `` is the repository of your choice, for instance `github` and `[@version]` is the tag to use (by default it will use `main` branch). -With this approach you can dynamically include any repository where your Kamelets are hosted. They will be lazily initialized as soon as they are required by any of the Integration or Pipes which will make use of them. \ No newline at end of file +With this approach you can dynamically include any repository where your Kamelets are hosted. They will be lazily initialized as soon as they are required by any of the Integration or Pipes which will make use of them. + +[[kamelets-as-dependency]] +== Kamelets as a dependency + +The Camel K has an opinionated way to use Kamelets which is the one exposed above. Here the Kamelet spec resource is expected to be available in the cluster. + +However, you may find situations where you want to bundle a Kamelet in a dependency (ie, some external catalog containing all Kamelets spec). As Kamelets are a Camel thing, then, you can use such dependency and let the runtime use the Kamelets available in the classpath. + +If you're using such an approach, then, you will need to make sure to skip the Kamelet trait (which is in charge to discover them and get required dependencies), and provide all the dependencies which may be required by your Kamelet. Additionally, you may need to specify a Camel property to tell the runtime where to expect to find the Kamelets, `camel.component.kamelet.location` (default `classpath:/kamelets`). \ No newline at end of file diff --git a/docs/modules/ROOT/pages/kamelets/kamelets-user.adoc b/docs/modules/ROOT/pages/kamelets/kamelets-user.adoc index cdb00a68f3..10eec3afe1 100644 --- a/docs/modules/ROOT/pages/kamelets/kamelets-user.adoc +++ b/docs/modules/ROOT/pages/kamelets/kamelets-user.adoc @@ -205,35 +205,6 @@ from('timer:tick') You can run this integration without specifying other parameters, the Kamelet endpoint will be implicitly configured by the Camel K operator that will automatically mount the secret into the integration Pod. -[[kamelets-default-catalog]] -== Kamelets Catalog - -When you install a Camel K Operator, you will have automatically a wide set of canned Kamelets available to be used. The catalog and the related documentation is available at link:/camel-kamelets/next/index.html[Apache Kamelets Catalog]. There is a CLI command very useful to have a quick list of the available Kamelets: -[source,shell] ----- -$ kamel kamelet get ----- - -These Kamelets are installed by default when you install Camel K operator. You will be able to use them without worrying to install each of them, just look at the documentation and be ready to experiment how easy they are. - -[[kamelets-custom-catalog]] -=== Use a custom Catalog - -You can overwrite the default catalog by adding certain configuration to the `IntegrationPlatform`. In order to add a new repository, you must edit the `IntegrationPlatfom` and edit the `.spec.kamelet.repositories[].uri` field, which expects an array of repository URIs where you can host your catalog of Kamelets, ie: -[source,yaml] ----- -spec: - ... - kamelet: - repositories: - - uri: github:my-org/my-repo - ... ----- - -By default the value is null, which means they fallback to the Apache Kamelets Catalog. - -NOTE: this option is experimental and may be subjected to changes in future versions. - [[kamelets-usage-binding]] == Binding Kamelets diff --git a/pkg/trait/kamelets.go b/pkg/trait/kamelets.go index 96460ecefe..af082a2a1b 100644 --- a/pkg/trait/kamelets.go +++ b/pkg/trait/kamelets.go @@ -58,8 +58,6 @@ func newConfigurationKey(kamelet, configurationID string) configurationKey { } const ( - contentKey = "content" - kameletLabel = "camel.apache.org/kamelet" kameletConfigurationLabel = "camel.apache.org/kamelet.configuration" ) @@ -240,7 +238,7 @@ func addKamelet(kamelet *v1.Kamelet, kameletBundle *corev1.ConfigMap) error { // kubectl create secret generic my-company-log-sink.mynamedconfig --from-file=mynamedconfig.properties // kubectl label secret my-company-log-sink.mynamedconfig camel.apache.org/kamelet=my-company-log-sink camel.apache.org/kamelet.configuration=mynamedconfig // -// then, this func is in charge to add such a secret to the Integration +// then, this func is in charge to add such a secret to the Integration. func (t *kameletsTrait) addConfigurationSecrets(e *Environment) error { for _, k := range t.getConfigurationKeys() { options := metav1.ListOptions{