Add webserver documentation

Signed-off-by: DL6ER <dl6er@dl6er.de>
This commit is contained in:
DL6ER
2025-06-30 13:31:09 +02:00
parent 69fb881177
commit 1e5ca0f9c4
2 changed files with 41 additions and 1 deletions

40
docs/ftldns/webserver.md Normal file
View File

@@ -0,0 +1,40 @@
### FTL's Embedded Webserver and Lua Server Pages
FTL comes with the embedded webserver [CivetWeb](https://github.com/civetweb/civetweb) supporting Lua server pages (LSP). This means you can write dynamic web content directly using Lua scripts, similar to how PHP is used in traditional web development. Lua offers several advantages over PHP in the embedded context:
- **Lightweight and Fast:** Lua has a very small memory footprint and is designed for high performance, making it ideal for our purposes.
- **Easy Integration:** Lua is easy to embed and extend, allowing seamless integration with FTL. We can easily bundle any Lua libraries we need, and they can be used directly in the webserver. No extra tools or external dependencies are required.
- **Simplicity:** Lua's syntax is straightforward and easy to learn, reducing the complexity of writing and maintaining server-side scripts.
- **Security:** Running Lua scripts within the FTL webserver provides a controlled environment, minimizing potential security risks compared to running a full PHP interpreter.
---
You can use the webserver to serve static files, dynamic content, or even custom HTTP responses (see the following examples). The webserver is configured through `pihole.toml` and can be accessed at `https://pi.hole/admin/`. Serving files outside of the webserver's home directory (`admin/`) is disabled by default for security reasons. It can be enabled by setting `webserver.serve_all` to `true`.
### Example 1: Custom HTTP status code
Create a file like
``` plain
HTTP/1.1 204 No Content
Connection: close
Cache-Control: max-age=0, must-revalidate
```
Two important things here: You need to save it using "MS-DOS formatting" (`\r\n` line endings) and there needs to be a single trailing line.
### Example 2: Regular page but manual headers
You could also use it for "regular" pages, e.g.,
``` plain
HTTP/1.0 200 OK
Content-Type: text/html
<html><body>
<p><?= 1+1 ?></p>
</body></html>
```
which will print an empty page with "2" on it.

View File

@@ -142,6 +142,7 @@ nav:
- 'Blocking mode': ftldns/blockingmode.md
- 'Privacy levels': ftldns/privacylevels.md
- 'dnsmasq warnings': ftldns/dnsmasq_warn.md
- 'Webserver': ftldns/webserver.md
- 'Advanced':
- 'Install from source': ftldns/compile.md
- 'Signals': 'ftldns/signals.md'
@@ -246,7 +247,6 @@ plugins:
- redirects:
redirect_maps:
'ftldns/database.md': database/index.md
'ftldns/regex/index.md': ftldns/regex/overview.md
'main/presentations.md': index.md
'main/prerequesites.md': main/prerequisites.md
'guides/unbound.md': guides/dns/unbound.md