Kotlin Server Scripts let you run kotlin scripts in response to server requests, without setting up a complete project.
There is an easy to use install script to install the latest release on a linux system. It downloads the release archive, installs the executable and creates and enables a system service.
curl 'https://raw.githubusercontent.com/EdwarDDay/kotlin-server-scripts/main/install.sh' --output install.sh
chmod u+x install.sh
./install.sh # admin privileges might be needed
The install.sh
script will by default save the executable in the /usr/bin/
directory, creates system service file
with www-data
as service execution user and puts a configuration sample file. If you want to configure any of these
settings or see the default values, execute ./install.sh --help
for more information.
To fetch the release asset, the script needs either authorized access to the GitHub API - either via a GH PAT
(--token
option) or via the authenticated gh
commandline tool - or needs the jq
tool to parse the GitHub REST
response.
To execute server scripts, add something like the following configuration to you nginx.conf:
# match all kts files
location ~ ^(.*)\.kts(\?.*)?$ {
# match the server script with .server.kts extension
try_files \$1.server.kts =404;
# use default fastcgir parameters
include fastcgi_params;
# pass request to kss process
fastcgi_pass unix:/var/run/kss/kss.sock;
}
Example script looks like:
HelloWorld.server.kts
setHeader("Content-Type", "text/html")
status(200)
writeOutput(
"""
<!DOCTYPE html>
<html>
<head>
<title>Hello Kotlin</title>
</head>
<body>
<h1>Hello Kotlin</h1>
</body
</html>
"""
)
You can find more examples in the test folder
If you want to add a maven dependency, you can add a @file:DependsOn("<artifact id>"")
annotation to the file. If your
dependency isn't in the maven central repository, you can add additional repositories via a
@file:Repository("<repository url>")
annotation at file level.
You can reference a logback configuration file in the
kss.properties
configuration file via logging.logback.configurationFile=<path to file>
. This way you can change the
log level from the default info
or log to a file instead of the command line as it's done by default.
To build the library just run ./gradlew scripting-host:build
.