From b3005417d28aafa6929a160d2a4c93da6d844995 Mon Sep 17 00:00:00 2001 From: Zac Spitzer Date: Sat, 6 Jul 2024 20:10:42 +0200 Subject: [PATCH] cleanup markdown --- docs/recipes/extension-installation.md | 17 ++++++++++++++++- docs/recipes/java-explicit-casting.md | 3 +++ docs/recipes/startup-listeners-code.md | 2 ++ 3 files changed, 21 insertions(+), 1 deletion(-) diff --git a/docs/recipes/extension-installation.md b/docs/recipes/extension-installation.md index fcc799e9b..7ca98c13a 100644 --- a/docs/recipes/extension-installation.md +++ b/docs/recipes/extension-installation.md @@ -23,29 +23,36 @@ In Lucee, there are multiple ways to install an extension. This recipe will show you all the possibilities along with their pros and cons. ## Lucee Administrator + You can install an extension in the Lucee Administrator by navigating to Extensions/Applications in the Lucee (Server) Administrator and installing or uninstalling the extension you need. ### Pros + - No physical access to the server needed - User-friendly interface - Immediate feedback on the installation process -### Cons +### Cons + - Manual process that is not easily repeatable - Requires access to the Lucee Administrator interface ## `deploy` Directory + Simply copy the extension you want to install into the folder `{lucee-installation}/lucee-server/deploy`. Lucee will pick it up at startup or within a minute after startup and install it. You can find extensions to install under [download.lucee.org](https://download.lucee.org). ### Pros + - Hot deployment on a running server possible with no restart needed (except for some extensions) - Can be automated with scripts ### Cons + - Requires physical or SSH access to the server - Some extensions may require a restart to work properly ## `.CFConfig.json` Configuration (Lucee 6 Only) + With Lucee 6, you can define the extensions you need in the `.CFConfig.json` file that holds all your configurations. ```json @@ -77,17 +84,21 @@ On a fresh install of Lucee, Lucee will install the [bundled extensions](https:/ With Lucee 6.1, the "id" attribute is no longer necessary when you define a path. ### Important Notes for Multi-Mode (Server and Web Admin Enabled) + - If you run Lucee in Multi-Mode (Server and Web Admin enabled), you need to add the extension configuration to the root of the server context JSON file located at `{lucee-installation}/lucee-server/context/.CFConfig.json` and not in the web context JSON file. ### Pros + - You can automate the process - Easy to manage configurations and extensions in one place ### Cons + - No hot deployment - Requires configuration file management ## Environment Variable / System Property + You can also define the extension in an environment variable or system property. This option is similar to the `.CFConfig.json` option. Define a comma-separated list of Lucee extensions to install when starting up. This can be a simple list of IDs, in which case the latest versions will be installed: @@ -124,17 +135,21 @@ java -Dlucee.extensions="99A4EF8D-F2FD-40C8-8FB8C2E67A4EEEB6;name=MSSQL;version= ``` ### Pros + - Can be used in various deployment environments (e.g., Docker, cloud services) - Supports automation and infrastructure as code practices ### Cons + - No hot deployment - Requires setting environment variables or system properties, which might be complex in some environments ## Logging and Troubleshooting + If you encounter issues while installing extensions, you can check the log at `{lucee-installation}/lucee-server/context/logs/deploy.log` not only for any errors reported but also to see what actions were performed. This log is by default set to info level and should contain all details about the installation process. ## Conclusion + Lucee offers several methods to install extensions, each with its own advantages and disadvantages. Choose the method that best fits your deployment and management workflow: - **Lucee Administrator**: Best for manual, ad-hoc installations. diff --git a/docs/recipes/java-explicit-casting.md b/docs/recipes/java-explicit-casting.md index 41922d46a..8411ae2f8 100644 --- a/docs/recipes/java-explicit-casting.md +++ b/docs/recipes/java-explicit-casting.md @@ -21,6 +21,7 @@ This guide demonstrates how to explicitly cast a component to a specific interface in Lucee. ## Implicit Casting + Lucee supports implicit casting by passing a component to a method where the method argument is of a specific type. For example: ```lucee @@ -39,9 +40,11 @@ getPageContext().setLocale(cs); In this example, Lucee implicitly finds a matching method and converts the component to a class implementing the `java.lang.CharSequence` interface. ## Explicit Casting + Sometimes, implicit casting can be problematic if Lucee cannot make the correct fit, or if a method is overloaded and you need to specify which method to use. For instance, the `PageContext` class has two `setLocale` methods: + - `setLocale(java.lang.String): void` - `setLocale(java.util.Locale): void` diff --git a/docs/recipes/startup-listeners-code.md b/docs/recipes/startup-listeners-code.md index dad645d99..f82ed9e43 100644 --- a/docs/recipes/startup-listeners-code.md +++ b/docs/recipes/startup-listeners-code.md @@ -72,9 +72,11 @@ Start the Lucee Server, and the server console should display the above system o ### Functions in Server.cfc #### onServerStart + `onServerStart` is called when you start Lucee. The `reload` argument is set to `false` on the first start, and `true` when any configuration in the Lucee Administrator is updated or an extension is installed. #### onBuild (since Lucee 6.1.1) + `onBuild` is called when you start Lucee with the environment variable `LUCEE_BUILD` (or the older variable `LUCEE_ENABLE_WARMUP`) set to `true`. You can also use the system property `-Dlucee.build` (or `-dlucee-enable.warmup`). This feature got indroduced in Lucee 6.1.1. ## Web.cfc