SCheck Getting Started Guide¶
- Version: 1.0.7-7-g251eead
- Release Date: 2023-04-06 11:17:57
- Supported Operating Systems: windows/amd64, windows/386, linux/arm, linux/arm64, linux/386, linux/amd64
This document primarily introduces how to use the basic features of SCheck after SCheck Installation, covering the following aspects:
SCheck Directory Introduction¶
SCheck currently supports two mainstream platforms: Linux and Windows:
| Operating System | Architecture | Installation Path | 
|---|---|---|
| Linux Kernel 2.6.23 or higher | amd64/386/arm/arm64 | /usr/local/scheck | 
| Windows 7, Server 2008R2 or higher | amd64/386 | 64-bit: C:\Program Files\scheck32-bit: C:\Program Files (x86)\scheck | 
Tips: Checking Kernel Version
- Linux: uname -r
- Windows: Run cmdcommand (hold down Win key +r, typecmdand press Enter), then typewinverto get the system version information
After installation, the SCheck directory structure is roughly as follows:
├── [   6]  custom.rules.d
├── [ 12K]  rules.d
├── [ 17M]  scheck
├── [ 664]  scheck.conf
└── [ 222]  version
Where:
- scheck: Main SCheck program, scheck.exe on Windows
- custom.rules.d: User-defined directory
- rules.d: SCheck system directory
- scheck.conf: Main SCheck configuration file
- version: SCheck version information
Note: On the Linux platform, SCheck logs are located in the
/var/log/scheckdirectory.
Related Commands¶
View help:
$ scheck -h
Usage of scheck:
  -check-md5
        md5 checksum
  -config string
        configuration file to load
  -config-sample
        show config sample
  -funcs
        show all supported lua-extend functions
  -test string
        the name of a rule, without file extension
  -testc int
        test rule count
  -version
        show version
  -doc
        Generate doc document from manifest file
  -tpl
        Generate doc document from template file
  -dir
        Used with `-doc` `-tpl` to output files to a specified directory
  -luastatus
        Display all Lua runtime statuses and output to the current directory in Markdown format.
  -sort
        Used with `-luastatus`. Sorting parameters include: name, time, count. Default is count.
     ./scheck -luastatus -sort=time
  -check
        Precompile all Lua files in the user directory once to check for syntax errors.
  -box
        Display all files loaded into the binary
Detection Rules¶
Detection rules are placed in the rules directory, specified by the rule_dir in the configuration file or the user-defined directory custom_dir. Each rule corresponds to two files:
- Script File: Written in Lua, must have a .luaextension.
- Manifest File: Uses TOML format, must have a .manifestextension, see Manifest File.
The script file and manifest file must have the same name.
SChecker periodically executes detection scripts (as specified by the cron field in the manifest file). The Lua script checks for relevant security events (e.g., file changes, new user logins) each time it runs. If an event is triggered, it sends the event (in line protocol format) to the address specified by the output field in the configuration file using the trigger() function.
SChecker defines several Lua extension functions and disables some Lua packages or functions for security reasons. Only the following Lua built-in packages/functions are supported:
- 
All basic built-in packages are supported: - table
- math
- string
- debug
 
- 
In the ospackage, the following functions are not allowed:- execute()
- remove()
- rename()
- setenv()
- setlocale()
 
Adding/modifying manifest files and Lua code does not require restarting the service. SChecker scans the rules directory every 10 seconds.
Manifest File¶
The manifest file describes the content detected by the current rule, such as file changes, port status, etc. The final line protocol data will only contain fields from the manifest file. Details are as follows:
# ---------------- Required Fields ---------------
# Rule ID for the event, e.g., k8s-pod-001, which will be used as the metric name in the line protocol
id = ''
# Event category, defined based on business needs
category = ''
# Event severity level, defined based on business needs, e.g., warn, error
level = ''
# Title of the event, describing the detection content, e.g., "Sensitive file changed"
title = ''
# Description of the event (supports templates, see below)
desc = ''
# Execution schedule for the event (using Linux crontab syntax)
cron = ''
# Supported platforms
os_arch = ["Linux", "Windows"]
# ---------------- Optional Fields ---------------
# Disable this rule
#disabled = false
# Defaultly add hostname in tags
#omit_hostname = false
# Explicitly set hostname
#hostname = ''
# ---------------- Custom Fields ---------------
# Support adding custom key-value pairs, where value must be a string
#instanceID=''
Cron Schedule¶
Currently, only interval-based execution is supported.
# ┌───────────── Second
# │ ┌───────────── Minute
# │ │ ┌───────────── Hour
# │ │ │ ┌───────────── Day-of-Month
# │ │ │ │ ┌───────────── Month
# │ │ │ │ │
# │ │ │ │ │
# │ │ │ │ │
# * * * * *
Examples:
*/10 * * * *: Runs every 10 seconds.
* */5 * * *: Runs every 5 minutes.
disable: Setting disable or an empty string makes the Lua script long-running, e.g., listening for file changes. Once started, these types of Lua scripts do not stop.
Template Support¶
The desc string in the manifest file supports template variables with the syntax {{.<Variable>}}, for example:
Here, FileName and Content are template variables that will be replaced (including the preceding dot .). When calling the trigger() function, you can pass a Lua table containing the replacement values for the template variables. For instance, passing the following parameters:
The final desc value would be:
Testing Rules¶
When writing rule code, you can use scheck --test to test if the code is correct. Suppose there is a demo rule in the rules.d directory:
You can also test multiple rules at once. For example, if one script depends on another:
Lua Functions¶
See Functions
Creating Common Libraries¶
SChecker allows the use of the require function to import Lua modules, which must be stored in the rules.d/lib directory. You can modularize commonly used functions and place them in this lib subdirectory for use by detection scripts.
Suppose you create a Lua module common.lua:
Place common.lua in the /usr/local/scheck/rules.d/lib directory.
Assuming a rule script demo.lua uses this common module:
Line Protocol¶
SCheck outputs in line protocol format, using the rule ID as the metric name.
Tag List (tags)¶
| Name | Type | Description | Required | 
|---|---|---|---|
| title | string | Security event title | true | 
| category | string | Event category | true | 
| level | string | Security event severity, supports: info,warn,critical | true | 
| host | string | Source hostname of the event (default included) | |
| os_arch | string | Host platform | true | 
| Custom tags | string | Tags defined in the manifest file | false | 
Current categories:
- network: Network-related, mainly involving connections, ports, firewalls, etc.
- storage: Storage-related, such as disks, HDFS, etc.
- db: Various databases (MySQL/Redis/...)
- system: Mainly operating system-related
- container: Including Docker and Kubernetes
Field List (fields)¶
| Field Name | Type | Description | 
|---|---|---|
| message | string | Event details | 
SCheck Resource Limitation¶
To limit SCheck's resource usage (e.g., CPU usage) via cgroups, supported only on Linux systems. Navigate to the SCheck installation directory, modify the scheck.conf configuration file, and set enable to true. Example: