Skip to content

EdwarDDay/kotlin-server-scripts

Repository files navigation

Kotlin Server Scripts

Kotlin Server Scripts let you run kotlin scripts in response to server requests, without setting up a complete project.

Setup

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.

Nginx setup

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

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

Add dependencies

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.

Change logging configuration

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.

Building

To build the library just run ./gradlew scripting-host:build.