Skip to content

Commit

Permalink
reformat md
Browse files Browse the repository at this point in the history
  • Loading branch information
zspitzer committed Jun 26, 2024
1 parent 201d850 commit d6c23ac
Show file tree
Hide file tree
Showing 23 changed files with 100 additions and 84 deletions.
1 change: 0 additions & 1 deletion docs/recipes/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -263,4 +263,3 @@ How to install, congigure and create WebSockets
## [XML Fast And Easy, using SAX - Listener Functions](/docs/recipes/xml-fast-and-easy.md)

This document explains how to use XML parsing in Lucee.

3 changes: 2 additions & 1 deletion docs/recipes/application-context-update.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
]
}
-->

# Application Context update

Lucee allows you to update the existing application context defined for example in [cookbook-application-context-basic].
Expand All @@ -43,4 +44,4 @@ This example doesn't extend the existing application mappings with this new one,
<cfapplication action="update" mappings="#mappings#">
```

Of course, it's not only mappings you can update. [tag-application] lets you update all the settings you can do in the Application.cfc!
Of course, it's not only mappings you can update. [tag-application] lets you update all the settings you can do in the Application.cfc!
11 changes: 6 additions & 5 deletions docs/recipes/archives-creating-and-deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
]
}
-->

# Archives - Creating and deploying Lucee Archives (.lar files)

This document explains how to deploy an Application on a live server without using a single CFML file.
Expand Down Expand Up @@ -45,8 +46,8 @@ resource: **Full folder path**/component/

After creating the mapping, you need to create an archive file for the CFC.

* Go to the detail view of mycfc mapping page,
* Click the button **assign archive to mapping**.
- Go to the detail view of mycfc mapping page,
- Click the button **assign archive to mapping**.

An archive (lar file) is created automatically and saved in `WEB-INF/lucee/context/archives`.

Expand All @@ -73,8 +74,8 @@ After creating the mapping in the Administrator, you can create an archive file

Now you can see both lar files in the `WEB-INF/lucee/context/archives` folder:

* One is `lucee/context/archives/xxx-deploy.lar` file,
* Another one is `lucee/context/archives/xxx-mycfc.lar`
- One is `lucee/context/archives/xxx-deploy.lar` file,
- Another one is `lucee/context/archives/xxx-mycfc.lar`

Now you can place the archive files on your target server.

Expand All @@ -86,4 +87,4 @@ You can now view mappings in the admin.

Here you can see the above details in a video:

[Lucee Deploy Archive file](https://www.youtube.com/watch?time_continue=473&v=E9Z0KvspBAY)
[Lucee Deploy Archive file](https://www.youtube.com/watch?time_continue=473&v=E9Z0KvspBAY)
3 changes: 2 additions & 1 deletion docs/recipes/basic-date.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
]
}
-->

# Basic Date - Output the current date

The following examples show you how to output the current date.
Expand All @@ -34,4 +35,4 @@ You can then configure a different locale for the current request in the Applica
<cfoutput>
<p>The time is #lsDateTimeFormat(date:now(),locale:'de_CH')#</p>
</cfoutput>
```
```
3 changes: 2 additions & 1 deletion docs/recipes/cached-within-request.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
]
}
-->

# Cache a Query for the current request

Perhaps you're familiar with the "cachedwithin" attribute of the tag [tag-query], which is normally used as follows:
Expand All @@ -41,4 +42,4 @@ Request query caching is a simple solution to this problem. Replace the timespan
</cfquery>
```

Then the query is cached for only the current request, independent of how long the request takes!
Then the query is cached for only the current request, independent of how long the request takes!
16 changes: 9 additions & 7 deletions docs/recipes/caches-defined-in-application-cfc.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
]
}
-->

# Caches defined in Application.cfc

It is possible to add cache connections in Lucee 5.1+ on a per-application basis by adding configuration to your `Application.cfc`. You can also select the default object cache, query cache, function cache, etc. Note if these caches use an extension that provides the cache driver, the extension must be installed already.
Expand Down Expand Up @@ -57,16 +58,17 @@ The easiest way to generate the code block above is to follow these steps:

Let's take a look at some of the keys used to define a cache connection.

* **class** - This is the Java class of the driver for the cache engine.
* **bundleName** - Optional. The name of the OSGI bundle to load the `class` from.
* **bundleVersion** - Optional. The version of the OSGI bundle to load the `class` from.
* **storage** - A boolean that flags whether this cache can be used for client or session storage.
* **custom** - A struct of key/value pairs for configuring the cache. This struct is entirely dependent on the cache driver in use, so refer to the docs for that cache driver to see the possible values. Note, some of these custom values might be required for some cache drivers to work.
* **default** - Optional. If you want this cache to be used as a default cache, then give this one of these values: `function`, `object`, `template`, `query`, `resource`, `include`, `http`, `file`, `webservice`.
- **class** - This is the Java class of the driver for the cache engine.
- **bundleName** - Optional. The name of the OSGI bundle to load the `class` from.
- **bundleVersion** - Optional. The version of the OSGI bundle to load the `class` from.
- **storage** - A boolean that flags whether this cache can be used for client or session storage.
- **custom** - A struct of key/value pairs for configuring the cache. This struct is entirely dependent on the cache driver in use, so refer to the docs for that cache driver to see the possible values. Note, some of these custom values might be required for some cache drivers to work.
- **default** - Optional. If you want this cache to be used as a default cache, then give this one of these values: `function`, `object`, `template`, `query`, `resource`, `include`, `http`, `file`, `webservice`.

## Default Caches

When declaring a cache, you can make it the default cache for creation operations, but it is also possible to configure the default caches for each operation all at once in your `Application.cfc` like so:

```lucee
this.cache.object = "myCache";
this.cache.template = "AnotherCache";
Expand All @@ -79,4 +81,4 @@ this.cache.file = "<cache-name>";
this.cache.webservice = "<cache-name>";
```

A single cache can only be the default storage location for a single operation at a time. For example, a cache named "myCache" cannot both be the default cache for objects as well as queries.
A single cache can only be the default storage location for a single operation at a time. For example, a cache named "myCache" cannot both be the default cache for objects as well as queries.
3 changes: 2 additions & 1 deletion docs/recipes/check-for-changes.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
]
}
-->

# Check for changes in your configuration file automatically

Lucee can automatically check for changes in your configuration files from the complete server or a single web context.
Expand Down Expand Up @@ -51,4 +52,4 @@ And add the same changes from above:

Lucee will now check for any changes in the Lucee configuration files every minute, and if there is a change, reload it and enable those changes.

A very handy little feature for those automated deployments!
A very handy little feature for those automated deployments!
9 changes: 5 additions & 4 deletions docs/recipes/checksum.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
]
}
-->

# Checksum

This document explains how to use a checksum in Lucee.
Expand Down Expand Up @@ -53,9 +54,9 @@ dump("something went wrong! give it another try?");
</cfscript>
```

* Download the jar file by using cfhttp.
* Dump the file response header. You can see the "X-Checksum-MD5" "X-Checksum-SHA1" keys from the file itself.
* Save the file, and dump(fileInfo(localFile.checksum)). Check to see if the dump matches the value of the downloaded file response["X-Checksum-MD5"] header.
- Download the jar file by using cfhttp.
- Dump the file response header. You can see the "X-Checksum-MD5" "X-Checksum-SHA1" keys from the file itself.
- Save the file, and dump(fileInfo(localFile.checksum)). Check to see if the dump matches the value of the downloaded file response["X-Checksum-MD5"] header.

Checksum values are hashed from the binaryfile itself.

Expand Down Expand Up @@ -145,4 +146,4 @@ The above code checks and validates the downloaded file.
## Footnotes

You can see the details in this video:
[Checksum](https://www.youtube.com/watch?v=Kb_zSsRDEOg)
[Checksum](https://www.youtube.com/watch?v=Kb_zSsRDEOg)
3 changes: 2 additions & 1 deletion docs/recipes/configuration-administrator-cfc.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
]
}
-->

# Configure Lucee within your application

Lucee provides a web frontend to configure the server and each web context, but you can also do this configuration from within your application.
Expand All @@ -31,4 +32,4 @@ admin.updateCharset(resourceCharset: "UTF-8"); // set the resource charset
## cfadmin Tag

The component "Administrator" is far from being feature complete, so if you miss a functionality, best consult the unofficial tag "cfadmin" (undocumented) and check out how this tag is used inside the [Lucee Administrator](https://github.com/lucee/Lucee/blob/5.2/core/src/main/java/resource/component/org/lucee/cfml/Administrator.cfc).
Of course, it would be great if you could contribute your addition to the "Administrator" component.
Of course, it would be great if you could contribute your addition to the "Administrator" component.
5 changes: 3 additions & 2 deletions docs/recipes/convert-a-cfml-func-to-java.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
]
}
-->

# Convert a CFML Function/Component to use in Java

Lucee allows you to convert user-defined functions or components so you can use them in Java.
Expand Down Expand Up @@ -42,7 +43,7 @@ component {
Then you can pass that component to a Java method needing a specific interface/class.

```lucee
// This class has a method that takes as an argument a CharSequence.
// This class has a method that takes as an argument a CharSequence.
// This way we can force Lucee to convert/wrap our component to that interface.
HashUtil = createObject("java", "lucee.commons.digest.HashUtil");
Expand Down Expand Up @@ -76,4 +77,4 @@ numeric function echoInt(numeric i) {
if (i == 1) throw "Test output!!!";
return i * 2;
}
```
```
3 changes: 2 additions & 1 deletion docs/recipes/datasource-how-to-define-them.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
]
}
-->

# Datasource - How to define them

To execute queries, you need a datasource definition, which points to a specific local or remote datasource. There are different ways to do so.
Expand Down Expand Up @@ -85,4 +86,4 @@ this.datasource = {
username: 'root',
password: 'encrypted:5120611ea34c6123fd85120a0c27ab23fd81ea34cb854'
};
```
```
3 changes: 2 additions & 1 deletion docs/recipes/docker.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ Docker is a platform that enables developers to automate the deployment, scaling
## What are the benefits of running Lucee in Docker

Running Lucee in Docker provides several key benefits:

- **Consistency and Portability**: Docker containers ensure that Lucee and its dependencies are packaged together, eliminating compatibility issues and reducing setup time. This makes it easier to develop, test, and deploy applications consistently across different environments.
- **Scalability**: Docker's lightweight nature allows for efficient scaling of Lucee applications. You can quickly scale up or down based on demand, making it ideal for both small and large-scale deployments.
- **Resource Efficiency**: Docker containers share the host system's kernel, which leads to efficient utilization of system resources and improved performance compared to traditional virtual machines.
Expand Down Expand Up @@ -76,7 +77,7 @@ You can customize your Lucee container by creating your own Dockerfile and addin
For more complex setups, consider using Docker Compose to manage multiple services and their dependencies. Below is an example `docker-compose.yml` file to run Lucee with an Nginx reverse proxy:

```yaml
version: '3'
version: "3"

services:
lucee:
Expand Down
11 changes: 6 additions & 5 deletions docs/recipes/encryption_decryption.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,16 +22,17 @@
]
}
-->
# Encryption/Decryption

# Encryption/Decryption

This document explains about Encryption/Decryption with public and private keys with simple examples.

Encryption/Decryption is a new functionality in Lucee 5.3. We have a new way to encrypt/decrypt string values. First we start with keys. In this case, there are two keys:

* Private key to encrypt
* Public key to decrypt
- Private key to encrypt
- Public key to decrypt

## Example 1:
## Example 1:

```luceescript
//index.cfm
Expand Down Expand Up @@ -75,4 +76,4 @@ This is a full detailed example of encrypt/decrypt functions. We create a key an

Here you can see these details in the video also:

[Encryption/Decryption with public and private keys](https://www.youtube.com/watch?v=2fgfq-3nWfk)
[Encryption/Decryption with public and private keys](https://www.youtube.com/watch?v=2fgfq-3nWfk)
23 changes: 12 additions & 11 deletions docs/recipes/event-gateway-create.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
]
}
-->

# Custom Event Gateways

Here you will find a short introduction into writing your own Event Gateway type.
Expand All @@ -24,9 +25,9 @@ Since you can write these in pure CFML (and Java when you want it), it is really

There are 2 to 3 files you need to create:

* the Gateway CFC
* the Gateway Driver CFC
* A listener CFC
- the Gateway CFC
- the Gateway Driver CFC
- A listener CFC

## The Gateway CFC

Expand All @@ -36,18 +37,18 @@ Also, it is the file which is instantiated by Lucee when the gateway starts.

You can take the following files as an example:

* {Lucee-install}/lib/lucee-server/context/gateway/lucee/extension/gateway/DirectoryWatcher.cfc
* {Lucee-install}/lib/lucee-server/context/gateway/lucee/extension/gateway/MailWatcher.cfc
- {Lucee-install}/lib/lucee-server/context/gateway/lucee/extension/gateway/DirectoryWatcher.cfc
- {Lucee-install}/lib/lucee-server/context/gateway/lucee/extension/gateway/MailWatcher.cfc

The example code shown underneath is a modified version of the DirectoryWatcher.cfc, which, at time of writing, is in line for reviewing at the Lucee team.

By default, you need to have the following functions:

* An init function, which receives the necessary config data.
* A start function, which continues to run while variables.state="running".
* A stop and restart function.
* A getState function, which returns the current state of the gateway instance (running, stopping, stopped).
* A sendMessage function, which will be called when the CFML sendGatewayMessage function is used.
- An init function, which receives the necessary config data.
- A start function, which continues to run while variables.state="running".
- A stop and restart function.
- A getState function, which returns the current state of the gateway instance (running, stopping, stopped).
- A sendMessage function, which will be called when the CFML sendGatewayMessage function is used.

The following is all the code you need:

Expand Down Expand Up @@ -141,4 +142,4 @@ Minimalsize: the minimum filesize in bytes.

After executing the cfadmin code, or going through the admin screens, you should now have an instance of your own Event Gateway type running!

When creating a Socket gateway or an Instant messaging gateway, you will need to do a bit more coding, but hopefully this instruction helped you out!
When creating a Socket gateway or an Instant messaging gateway, you will need to do a bit more coding, but hopefully this instruction helped you out!
11 changes: 6 additions & 5 deletions docs/recipes/event-gateway-in-app-cfc.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
]
}
-->

# Event Handling in Application.cfc

Lucee provides several event handling functions within `Application.cfc` that can be used to manage different stages and types of requests. Here is an overview of these functions and their usage.
Expand Down Expand Up @@ -65,7 +66,7 @@ component {
}
```

### OnRequestStart ###
### OnRequestStart

This method is triggered at the start of each request.

Expand Down Expand Up @@ -115,7 +116,7 @@ component {

As arguments you receive the exception (cfcatch block) and the eventName.

## OnAbort
## OnAbort

This method is triggered when a request is ended with help of the tag `<cfabort>`.

Expand All @@ -127,7 +128,7 @@ component {
}
```

## OnDebug
## OnDebug

This method is triggered when debugging is enabled for this request.

Expand All @@ -153,7 +154,7 @@ component {

## Application.cfc Default Template

Below you can find an Application.cfc template that may serve as a starting point for your own applications settings with Lucee CFML engine.
Below you can find an Application.cfc template that may serve as a starting point for your own applications settings with Lucee CFML engine.

When creating an Application.cfc for the first time, you can configure all the settings within the Lucee Server or Web Administrator and use its "Export" tool (Lucee Administrator => Settings => Export) to move (by copy and paste) the settings into your Application.cfc file.

Expand Down Expand Up @@ -261,4 +262,4 @@ component {
}
}
```
```
Loading

0 comments on commit d6c23ac

Please sign in to comment.