Run
Generate a symbol library from source code and binary inputs to enable structured event processing at runtime.
Setup Guide
Follow the steps below. Steps that require customization link to the relevant Configuration section where you can edit on github.dev or locally.
Step 1: Install
Install the Cloud binary flavor:
Step 2: Set Environment Variables
Set these environment variables before running. See path configuration for details.
| Variable | Description |
|---|---|
TENX_CONFIG |
Path to your configuration directory |
TENX_API_KEY |
Your Log10x API key (get one) |
GH_TOKEN |
GitHub personal access token (create one) (optional) |
DOCKER_USERNAME |
Docker registry username (Docker Hub) (optional) |
DOCKER_TOKEN |
Docker registry token (Docker Hub) (optional) |
ARTIFACTORY_TOKEN |
JFrog Artifactory token (create one) (optional) |
export TENX_CONFIG=/path/to/your/config
export TENX_API_KEY=your-api-key
export GH_TOKEN=your-github-token
See best practices for managing secrets in production.
Step 3: Set Up Input Sources
Specify source code or binary inputPaths to scan.
Clone a repository to the default input path:
Configure githubPull to pull repos automatically:
Configure helmChartNames to pull from Helm charts:
The compiler uses Docker CLI and Helm. The Docker image includes these; otherwise ensure helmCommand and dockerCommand are valid.
Step 4: Configure Output
- Set outputSymbolFolder for symbol unit files
- Set outputSymbolLibraryFile for the final library file
Step 5: Push to GitHub (optional)
Push outputs to GitHub for GitOps workflows, enabling symbol reuse and delivery to edge/cloud apps:
Step 6: Run
Best for: Isolated environments with local configuration.
Best for: CI/CD pipelines with version-controlled configuration.
Step 7: Verify
Verify no errors appear in the log file.
Check output files:
Verify symbol files were generated in your configured outputSymbolFolder and outputSymbolLibraryFile paths.
Configuration
To configure the Compiler app, Edit these settings:
Main Config
Main Config
The main config file loads the Compiler app's required modules.
Uncomment selected modules at: compiler/config.yaml.
#
# 🔟❎ Compiler app main config
# The compile app produces symbol library files which enable 10x apps to
# transform log/trace events into well-defined TenXObjects at runtime.
# To learn more see https://doc.log10x.com/apps/compiler
# =========================== Bootstrap Compiler ==============================
# To learn more see https://doc.log10x.com/compile/bootstrap
tenx: compile
runtimeName: $=TenXEnv.get("TENX_RUNTIME_NAME", "myCompiler")
# ============================ Load App Modules ===============================
# Uncomment and edit selected config.yaml files in the folders below (e.g., compile/scanners/config.yaml)
include:
# ------------------------------ App settings ---------------------------------
# Load general app settings:
- compiler
# Load gitops settings for pulling additional assets from Github.
# Edit the gitops/config.yaml file with specific config
#
# For additional info see - https://doc.log10x.com/config/github
- gitops
# --------------------------- Process Inputs --------------------------------
# Process input source code and binary files on disk.
- compile/scanners # https://doc.log10x.com/compile/scan
# ---------------------------- Pull Inputs ----------------------------------
# This application can fetch source/binary files from remote inputs
# Uncomment and edit config files (e.g. compile/pull/github/config.yaml) to remote pull
#
- compile/pull/github # https://doc.log10x.com/compile/pull/github
- compile/pull/docker # https://doc.log10x.com/compile/pull/docker
- compile/pull/helm # https://doc.log10x.com/compile/pull/helm
# - compile/pull/artifactory # https://doc.log10x.com/compile/pull/artifactory
# ---------------------------- Link Output ----------------------------------
# Link output files into a single symbol library artifact for runtime use
- compile/link # https://doc.log10x.com/compile/link
# ---------------------------- Push Output ----------------------------------
# Push output files to GitHub for use by subsequent compile and run instances
# - compile/push # https://doc.log10x.com/compile/push
Pull
Pull
Activate a Repo Fetcher to pull input source code/binary files from remote repositories.
github
Configure GitHub repositories to pull folders from GitHub repositories to scan for symbol content.
Below is the default configuration from: github/config.yaml (* Required Fields).
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiZ2l0aHViUHVsbCIgOiB7CiAgICAgICJ0eXBlIiA6ICJhcnJheSIsCiAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlLAogICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICJyZXBvcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiTmFtZXMgb2YgcmVwbyhzKSB0byBwdWxsXG5cbklkZW50aWZpZXMgR2l0SHViIHJlcG9zaXRvcmllcyB0byBwdWxsIGluIHRoZSBmb3JtIG9mIHVzZXJuYW1lL293bmVyIChlLmcuLCBvcGVuc2VhcmNoLXByb2plY3QvT3BlblNlYXJjaCkiLAogICAgICAgICAgICAiaXRlbXMiIDogewogICAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICAgIH0KICAgICAgICAgIH0sCiAgICAgICAgICAidG9rZW4iIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJHaXRIdWIgQVBJIGFjY2VzcyB0b2tlblxuXG5EZWZpbmVzIGFuIGFjY2VzcyB0b2tlbiBmb3IgYWNjZXNzaW5nIEdpdGh1YiByZXBvcy4gVG8gbGVhcm4gbW9yZSBzZWUgW0dpdEh1YiB0b2tlbnNdKGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2F1dGhlbnRpY2F0aW9uL2tlZXBpbmcteW91ci1hY2NvdW50LWFuZC1kYXRhLXNlY3VyZS9tYW5hZ2luZy15b3VyLXBlcnNvbmFsLWFjY2Vzcy10b2tlbnMpLiAgIFRoaXMgdmFsdWUgc2hvdWxkIGJlIHNldCB2aWEgYW4gW2Vudmlyb25tZW50IHZhcmlhYmxlXShodHRwczovL2RvYy5sb2cxMHguY29tL2FwaS9qcy8jVGVuWEVudi5nZXQpOiAgYGBgIHlhbWwgZ2l0aHViUHVsbFRva2VuOiAkPVRlblhFbnYuZ2V0KFwiR0hfVE9LRU5cIikgYGBgIgogICAgICAgICAgfSwKICAgICAgICAgICJicmFuY2giIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJUYXJnZXQgYnJhbmNoXG5cblNwZWNpZmllcyB0aGUgYnJhbmNoIHRvIHVzZSB3aGVuIHB1bGxpbmcgZnJvbSBbZ2l0aHViUHVsbFJlcG9zXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvcHVsbC9naXRodWIvI2dpdGh1YnB1bGxyZXBvcykuIElmIG9taXR0ZWQsIHVzZSB0aGUgcmVwb3NpdG9yeSdzIGRlZmF1bHQgYnJhbmNoLiIKICAgICAgICAgIH0sCiAgICAgICAgICAiZm9sZGVycyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUmVwbyBmb2xkZXJzIHRvIHB1bGxcblxuSWRlbnRpZmllcyBmb2xkZXIocykgd2l0aGluIFtnaXRodWJQdWxsUmVwb3NdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9wdWxsL2dpdGh1Yi8jZ2l0aHVicHVsbHJlcG9zKSB0byBwdWxsLiBpZiBvbWl0dGVkLCB0aGUgZW50aXJlIHJlcG8gaXMgcHVsbGVkLiIsCiAgICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICAgInR5cGUiIDogInN0cmluZyIKICAgICAgICAgICAgfQogICAgICAgICAgfQogICAgICAgIH0sCiAgICAgICAgInJlcXVpcmVkIiA6IFsKICAgICAgICAgICJ0b2tlbiIKICAgICAgICBdCiAgICAgIH0KICAgIH0KICB9LAogICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZQp9
# 🔟❎ 'compile' GitHub pull sources configuration
# Configures GitHub repositories folders to pull to disk to scan its contents.
# To learn more see https://doc.log10x.com/compile/pull/github
# For a reference list of industry-standard frameworks, see:
# modules/pipelines/compile/modules/pull/github/library.yaml
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== GitHub Options ===============================
githubPull:
# 'token' specifies the access token for this repo using a shell variable (recommended) or inline
# See https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens
- token: $=TenXEnv.get("GH_TOKEN") # (❗ EnvVar REQUIRED)
# 'repo' specifies the repo names to pull from Github (e.g., apache/spark)
repos: [
#owner/project
]
# 'branch' specifies the branch to pull within 'repos'. If not set, pulls each repo's default branch
branch: null
# 'repoFolders' defines folders within 'repos' to pull. If not specified, pull the entire repo
folders: [
# src/main
]
docker
Configure the Docker image to pull Docker image files to scan for symbol content.
Below is the default configuration from: docker/config.yaml (* Required Fields).
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiZG9ja2VyIiA6IHsKICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZSwKICAgICAgInByb3BlcnRpZXMiIDogewogICAgICAgICJpbWFnZXMiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAibnVsbCIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiRG9ja2VyIGltYWdlIGZpbGVzIHRvIHB1bGxcblxuU3BlY2lmaWVzIHRoZSBVUkxzIGZvciB0aGUgcmVtb3RlIERvY2tlciBpbWFnZXMgdG8gcHVsbCBpbiB0aGUgZm9ybSBvZjogYDxjb250YWluZXItcmVwb3NpdG9yeT4vPGltYWdlPi88dmVyc2lvbj5gLiBGb3IgZXhhbXBsZTogIGBgYCB5YW1sICBkb2NrZXJJbWFnZXM6IC0gZG9ja2VyLmlvL2dyYWZhbmEvZ3JhZmFuYToxMS4xLjAgYGBgIiwKICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAidXNlcm5hbWUiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkRvY2tlciB1c2VyIG5hbWVcblxuU3BlY2lmaWVzIHRoZSBbdXNlciBuYW1lXShodHRwczovL2RvY3MuZG9ja2VyLmNvbS9yZWZlcmVuY2UvY2xpL2RvY2tlci9sb2dpbi8jdXNlcm5hbWUpIGZvciBhdXRoZW50aWNhdGluZyB0aGUgZG9ja2VyIGNsaWVudC4gSWYgdGhpcyB2YWx1ZSBpcyBub3Qgc2V0LCB0aGUgZG9ja2VyIGNsaWVudCBpcyBhc3N1bWVkIHRvIGJlIHByZS1hdXRoZW50aWNhdGVkLiAgVGhpcyB2YWx1ZSBzaG91bGQgYmUgc2V0IHZpYSBhbiBbZW52aXJvbm1lbnQgdmFyaWFibGVdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vYXBpL2pzLyNUZW5YRW52LmdldCk6ICBgYGAgeWFtbCBkb2NrZXJVc2VybmFtZTogJD1UZW5YRW52LmdldChcIkRPQ0tFUl9VU0VSTkFNRVwiKSBgYGAiCiAgICAgICAgfSwKICAgICAgICAicGFzc3dvcmQiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkRvY2tlciBwYXNzd29yZFxuXG5TcGVjaWZpZXMgdGhlIHBhc3N3b3JkIGZvciBhdXRoZW50aWNhdGluZyB0aGUgZG9ja2VyIGNsaWVudCBpbiBjb25qdW5jdGlvbiB3aXRoIFtkb2NrZXJVc2VybmFtZV0oaHR0cHM6Ly9kb2MubG9nMTB4LmNvbS9jb21waWxlL3B1bGwvZG9ja2VyLyNkb2NrZXJ1c2VybmFtZSkuIFRoaXMgdmFsdWUgaXMgd3JpdHRlbiBpbnRvIHRoZSBkb2NrZXIgY2xpZW50J3Mgc3RkIGlucHV0IHZpYSB0aGUgbG9naW4gY29tbWFuZCdzIFtwYXNzd29yZC1zdGRpbl0oaHR0cHM6Ly9kb2NzLmRvY2tlci5jb20vcmVmZXJlbmNlL2NsaS9kb2NrZXIvbG9naW4vI3Bhc3N3b3JkLXN0ZGluKSBhcmd1bWVudC4gIFRoaXMgdmFsdWUgc2hvdWxkIGJlIHNldCB2aWEgYW4gW2Vudmlyb25tZW50IHZhcmlhYmxlXShodHRwczovL2RvYy5sb2cxMHguY29tL2FwaS9qcy8jVGVuWEVudi5nZXQpOiAgYGBgIHlhbWwgZG9ja2VyUGFzc3dvcmQ6ICQ9VGVuWEVudi5nZXQoXCJET0NLRVJfVE9LRU5cIikgYGBgIgogICAgICAgIH0sCiAgICAgICAgInJlbW92ZSIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJib29sZWFuIiwKICAgICAgICAgICAgInN0cmluZyIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUmVtb3ZlIGltYWdlIGFmdGVyIHNjYW5cblxuU3BlY2lmaWVzIHdoZXRoZXIgdG8gcmVtb3ZlIFtkb2NrZXJJbWFnZXNdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9wdWxsL2RvY2tlci8jZG9ja2VyaW1hZ2VzKSB1c2luZyBbZG9ja2VyIHJtaSAtZl0oaHR0cHM6Ly9kb2NzLmRvY2tlci5jb20vcmVmZXJlbmNlL2NsaS9kb2NrZXIvaW1hZ2Uvcm0vKSAoQWNjZXB0cyBib29sZWFuIG9yIHN0cmluZyB3aXRoICQ9IHByZWZpeCBmb3IgcnVudGltZSBldmFsdWF0aW9uKSAoRGVmYXVsdDogdHJ1ZSkiLAogICAgICAgICAgImRlZmF1bHQiIDogdHJ1ZQogICAgICAgIH0sCiAgICAgICAgImdpdGh1YlJlcG9Ub2tlbiIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAibnVsbCIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiR2l0SHViIEFQSSB0b2tlbiBmb3IgcHVsbGluZyBpbWFnZSBzb3VyY2UgY29kZSByZXBvc2l0b3JpZXNcblxuRGVmaW5lcyBhbiBhY2Nlc3MgdG9rZW4gZm9yIHB1bGxpbmcgW0dpdGh1YiByZXBvc10oaHR0cHM6Ly9kb2MubG9nMTB4LmNvbS9jb21waWxlL3B1bGwvZ2l0aHViLykgcmVmZXJlbmNlZCBieSBhIHRhcmdldCBpbWFnZSdzIFtvcmcub3BlbmNvbnRhaW5lcnMuaW1hZ2Uuc291cmNlXShodHRwczovL2dpdGh1Yi5jb20vb3BlbmNvbnRhaW5lcnMvaW1hZ2Utc3BlYy9ibG9iL3YxLjAuMS9hbm5vdGF0aW9ucy5tZCNwcmUtZGVmaW5lZC1hbm5vdGF0aW9uLWtleXMpIHByb3BlcnR5LiAgSWYgdGhpcyBwcm9wZXJ0eSBpcyBub3QgYXZhaWxhYmxlIHdpdGhpbiB0aGUgW2ltYWdlIG1hbmlmZXN0XShodHRwczovL2RvY3MuZG9ja2VyLmNvbS9yZWZlcmVuY2UvY2xpL2RvY2tlci9tYW5pZmVzdC9pbnNwZWN0KSwgYW4gYXR0ZW1wdCBpcyBtYWRlIHRvIGluZmVyIGEgdmFsaWQgR2l0SHViIHJlcG8gbmFtZSBmcm9tIHRoZSBpbWFnZSBuYW1lLiBGb3IgZXhhbXBsZSwgZm9yIHRoZSB0aGUgdGFyZ2V0IGltYWdlIG5hbWU6IGBkb2NrZXIuaW8vZ3JhZmFuYS9ncmFmYW5hOjExLjEuMGAsIHRoZSBbZ3JhZmFuYS9ncmFmYW5hXShodHRwczovL2dpdGh1Yi5jb20vZ3JhZmFuYS9ncmFmYW5hKSBHaXRIdWIgcmVwbyBpcyBpbmZlcnJlZC4gIElmIG5vdCBhbiBBUEkgdG9rZW4gaXMgbm90IHNwZWNpZmllZCwgR2l0SHViIHJlcG9zIHJlZmVyZW5jZWQgd2l0aGluIGltYWdlIG1hbmlmZXN0cyBvciBpbmZlcnJlZCBmcm9tIGltYWdlIG5hbWVzIGFyZSBub3QgcHVsbGVkLiBUbyBsZWFybiBtb3JlIHNlZSBbR2l0SHViIHRva2Vuc10oaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYXV0aGVudGljYXRpb24va2VlcGluZy15b3VyLWFjY291bnQtYW5kLWRhdGEtc2VjdXJlL21hbmFnaW5nLXlvdXItcGVyc29uYWwtYWNjZXNzLXRva2VucykuIgogICAgICAgIH0sCiAgICAgICAgImNvbW1hbmQiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIlBhdGggdG8gZG9ja2VyIGNvbW1hbmRcblxuRGVmaW5lcyB0aGUgcGF0aCB0byB0aGUgW2RvY2tlcl0oaHR0cHM6Ly9kb2NzLmRvY2tlci5jb20vcmVmZXJlbmNlL2NsaS9kb2NrZXIvKSBwcm9ncmFtIHVzZWQgcHVsbGluZyBhbmQgZXhwb3J0aW5nIGltYWdlcy4gKERlZmF1bHQ6ICpOSVg6IC91c3IvbG9jYWwvYmluL2RvY2tlciwgV2luOiBDOi9Qcm9ncmFtIEZpbGVzL0RvY2tlci9Eb2NrZXIvcmVzb3VyY2VzL2Jpbi9kb2NrZXIuZXhlKSIsCiAgICAgICAgICAiZGVmYXVsdCIgOiAiKk5JWDogL3Vzci9sb2NhbC9iaW4vZG9ja2VyLCBXaW46IEM6L1Byb2dyYW0gRmlsZXMvRG9ja2VyL0RvY2tlci9yZXNvdXJjZXMvYmluL2RvY2tlci5leGUiCiAgICAgICAgfQogICAgICB9CiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' Docker configuration
# Pull docker images files using the Docker CLI client from container registries to
# scan for symbol values. To learn more see https://doc.log10x.com/compile/pull/docker
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================= Docker Options ================================
docker:
# 'username' specifies the user name for authenticating the docker client.
# If not set, the docker client is assumed to be pre-authenticated.
# To learn more see https://docs.docker.com/reference/cli/docker/login/#username
username: $=TenXEnv.get("DOCKER_USERNAME") # (❗ EnvVar REQUIRED)
# 'password' specifies the password argument for authenticating the docker client login command.
# This value is written into the docker client's std input via the --password-stdin argument.
# To learn more see https://docs.docker.com/reference/cli/docker/login/#password-stdin.
password: $=TenXEnv.get("DOCKER_TOKEN") # (❗ EnvVar REQUIRED)
# 'command' specifies the location of docker cli https://docs.docker.com/reference/cli/docker/ program
#command: $=TenXString.includes(TenXEnv.get("os.name"), "Windows") ? "C:/Program Files/Docker/Docker/resources/bin/docker.exe":"/usr/local/bin/docker"
# 'images' specify images to pull and export to matching .tar files to scan
images: [
# docker.io/grafana/grafana:11.1.0
]
# 'remove' specifies whether to remove exported images once their contents are extracted.
# To learn more see https://docs.docker.com/reference/cli/docker/image/rm
remove: false
# 'githubRepoToken' defines an access token for pulling Github repos referenced
# by a target image's 'org.opencontainers.image.source' property.
githubRepoToken: $=TenXEnv.get("GH_TOKEN") # (❗ EnvVar REQUIRED)
helm
Configure the Helm chart to pull GitHub repositories and Docker images to scan for symbol content from Helm charts.
Below is the default configuration from: helm/config.yaml (* Required Fields).
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiaGVsbSIgOiB7CiAgICAgICJ0eXBlIiA6ICJvYmplY3QiLAogICAgICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UsCiAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAiY2hhcnROYW1lcyIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJhcnJheSIsCiAgICAgICAgICAgICJudWxsIgogICAgICAgICAgXSwKICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJMaXN0IG9mIGNoYXJ0cyB0byBwdWxsXG5cblNwZWNpZmllcyBhIGxpc3Qgb2YgY2hhcnQgbmFtZXMgKGUuZy4sIG9wZW4tdGVsZW1ldHJ5L29wZW50ZWxlbWV0cnktZGVtbykgdG8gcGFzcyB0byBbaGVsbUNvbW1hbmRdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9wdWxsL2hlbG0vI2hlbG1jb21tYW5kKS4gVGhlIHNjYW5uZXIgd2lsbCBpbnZva2UgdGhlIFt0ZW1wbGF0ZV0oaHR0cHM6Ly9oZWxtLnNoL2RvY3MvaGVsbS9oZWxtX3RlbXBsYXRlLykgYW5kIFtzaG93IGNoYXJ0XShodHRwczovL2hlbG0uc2gvZG9jcy9oZWxtL2hlbG1fc2hvd19jaGFydC8pIGNvbW1hbmRzIHRvIHB1bGwgaXRzIHZhbHVlcy55YW1sIGFuZCBjaGFydC55YW1sIGZpbGVzIHRvIHNjYW4gZm9yIERvY2tlciBjb250YWluZXIgaW1hZ2VzIGFuZCBHaXRIdWIgcmVwbyBmaWxlcy4iLAogICAgICAgICAgIml0ZW1zIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogInN0cmluZyIKICAgICAgICAgIH0KICAgICAgICB9LAogICAgICAgICJjaGFydEZpbGVzIiA6IHsKICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgImFycmF5IiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkxpc3Qgb2YgY2hhcnRzIHRlbXBsYXRlcyBhbmQgdmFsdWUgZmlsZXMgdG8gc2NhblxuXG5TcGVjaWZpZXMgYSBsaXN0IG9mIGNoYXJ0IHZhbHVlIGFuZCB0ZW1wbGF0ZXMgZmlsZXMgdG8gc2Nhbi4gVGhlc2UgZmlsZSBwYXRocyBtYXkgYmUgcmVsYXRpdmUgdG8gdGhlIGluY2x1ZGUgcGF0aHMgbGlzdC4gSWYgZmlsZSBwYXRocyBhcmUgY2Fub25pY2FsLCB0aGVpciBlbmNsb3NpbmcgZm9sZGVycyBtdXN0IGJlIGluY2x1ZGVkIGluIHRoZSBpbmNsdWRlUGF0aHMgYXJndW1lbnQuIiwKICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAicHVsbCIgOiB7CiAgICAgICAgICAidHlwZSIgOiAib2JqZWN0IiwKICAgICAgICAgICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZSwKICAgICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICAgImdpdGh1YiIgOiB7CiAgICAgICAgICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICAgICAgICAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlLAogICAgICAgICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICAgICAgICJyZXBvcyIgOiB7CiAgICAgICAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAgICAgICAiYm9vbGVhbiIsCiAgICAgICAgICAgICAgICAgICAgInN0cmluZyIKICAgICAgICAgICAgICAgICAgXSwKICAgICAgICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIlB1bGwgR2l0SHViIHJlcG9zXG5cblNwZWNpZmllcyB3aGV0aGVyIHRvIHB1bGwgW0dpdEh1YiByZXBvc10oaHR0cHM6Ly9kb2MubG9nMTB4LmNvbS9jb21waWxlL3B1bGwvZ2l0aHViLykgcmVmZXJlbmNlZCBieSBhbiBpbnB1dCBIZWxtIHRlbXBsYXRlIGZpbGVzLiAoQWNjZXB0cyBib29sZWFuIG9yIHN0cmluZyB3aXRoICQ9IHByZWZpeCBmb3IgcnVudGltZSBldmFsdWF0aW9uKSIKICAgICAgICAgICAgICAgIH0sCiAgICAgICAgICAgICAgICAidG9rZW4iIDogewogICAgICAgICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgICAgICAgIF0sCiAgICAgICAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJHaXRIdWIgQVBJIHRva2VuIGZvciBwdWxsaW5nIHJlcG9zaXRvcmllc1xuXG5EZWZpbmVzIGFuIGFjY2VzcyB0b2tlbiBmb3IgcHVsbGluZyBbR2l0aHViIHJlcG9zXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvcHVsbC9naXRodWIvKSByZWZlcmVuY2VkIGJ5IEhlbG0gY2hhcnRzLiIKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0sCiAgICAgICAgICAgICJkb2NrZXJJbWFnZXMiIDogewogICAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAgICJib29sZWFuIiwKICAgICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgICAgXSwKICAgICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUHVsbCBkb2NrZXIgY29udGFpbmVyIGltYWdlc1xuXG5TcGVjaWZpZXMgd2hldGhlciB0byBwdWxsIFtEb2NrZXIgaW1hZ2VzXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvcHVsbC9kb2NrZXIvKSByZWZlcmVuY2VkIGJ5IGFuIGlucHV0IEhlbG0gdmFsdWVzIGFuZCB0ZW1wbGF0ZSBmaWxlcy4gKEFjY2VwdHMgYm9vbGVhbiBvciBzdHJpbmcgd2l0aCAkPSBwcmVmaXggZm9yIHJ1bnRpbWUgZXZhbHVhdGlvbikgKERlZmF1bHQ6IHRydWUpIiwKICAgICAgICAgICAgICAiZGVmYXVsdCIgOiB0cnVlCiAgICAgICAgICAgIH0KICAgICAgICAgIH0KICAgICAgICB9LAogICAgICAgICJjb21tYW5kIiA6IHsKICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICJudWxsIgogICAgICAgICAgXSwKICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJQYXRoIHRvIEhlbG0gY29tbWFuZFxuXG5EZWZpbmVzIHRoZSBwYXRoIHRvIHRoZSBbSGVsbV0oaHR0cHM6Ly9oZWxtLnNoLykgcHJvZ3JhbSB1c2VkIGZvciBxdWVyeWluZyBjaGFydCB0ZW1wbGF0ZXMgYW5kIHZhbHVlcy4gVGhpcyB2YWx1ZSBtdXN0IGJlIHNldCBpZiBbaGVsbUNoYXJ0TmFtZXNdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9wdWxsL2hlbG0vI2hlbG1jaGFydG5hbWVzKSBpcyBzZXQuIChEZWZhdWx0OiAqTklYOiAvdXNyL2xvY2FsL2Jpbi9oZWxtLCBXaW46IEM6L1Byb2dyYW0gRmlsZXMvaGVsbS9oZWxtLmV4ZSkiLAogICAgICAgICAgImRlZmF1bHQiIDogIipOSVg6IC91c3IvbG9jYWwvYmluL2hlbG0sIFdpbjogQzovUHJvZ3JhbSBGaWxlcy9oZWxtL2hlbG0uZXhlIgogICAgICAgIH0sCiAgICAgICAgImdpdEh1YlJlcG9QYXRocyIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAibnVsbCIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiWUFNTCBET00gcGF0aHMgZm9yIGV4dHJhY3RpbmcgR2l0SHViIHJlcG9zXG5cblNwZWNpZmllcyBwYXRocyB3aXRoaW4gYSBZQU1MIGZpbGUgdG8gdHJlYXQgYXMgaG9sZGVycyBmb3IgR2l0SHViIHJlcG8gbmFtZXMuIEZvciBleGFtcGxlLCBmb3IgdGhlIGZvbGxvd2luZyBzZWN0aW9uIGZyb20gYW4gaW5wdXQgY2hhcnQueWFtbCBmaWxlOiBgYGB5YW1sIHNvdXJjZXM6ICAgLSBodHRwczovL2dpdGh1Yi5jb20vb3Blbi10ZWxlbWV0cnkvb3BlbnRlbGVtZXRyeS1kZW1vICMgY2FwdHVyZSB0aGlzIEdpdEh1YiByZXBvIHJlZmVyZW5jZSBgYGAgKERlZmF1bHQ6IFttZXRhZGF0YS5yZXBvc2l0b3J5LCBzcGVjLnNvdXJjZS5naXQsIGNoYXJ0LnJlcG9zaXRvcnldKSIsCiAgICAgICAgICAiZGVmYXVsdCIgOiAiW21ldGFkYXRhLnJlcG9zaXRvcnksIHNwZWMuc291cmNlLmdpdCwgY2hhcnQucmVwb3NpdG9yeV0iCiAgICAgICAgfSwKICAgICAgICAiZG9ja2VySW1hZ2VQYXRocyIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAibnVsbCIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiWUFNTCBET00gcGF0aHMgZm9yIGV4dHJhY3RpbmcgRG9ja2VyIHJlcG8gcmVmZXJlbmNlc1xuXG5TcGVjaWZpZXMgcGF0aHMgd2l0aGluIGEgaGVsbSBZQU1MIGZpbGUgdG8gdHJlYXQgYXMgaG9sZGVycyBmb3IgRG9ja2VyIGltYWdlIG5hbWVzLiBGb3IgZXhhbXBsZSwgZm9yIHRoZSBmb2xsb3dpbmcgc2VjdGlvbiBmcm9tIGFuIGlucHV0IHZhbHVlcy55YW1sIGZpbGU6IGBgYHlhbWwgICAgIHNwZWM6ICAgc2VydmljZUFjY291bnROYW1lOiBvcGVudGVsZW1ldHJ5LWRlbW8gICBjb250YWluZXJzOiAgIC0gbmFtZTogYWNjb3VudGluZ3NlcnZpY2UgICAgICBpbWFnZTogJ2RvY2tlci5pby9ncmFmYW5hL2dyYWZhbmE6MTEuMS4wJyAjIGNhcHR1cmUgdGhpcyBkb2NrZXIgaW1hZ2UgcmVmZXJlbmNlIGBgYCAoRGVmYXVsdDogW3NwZWMudGVtcGxhdGUuc3BlYy5jb250YWluZXJzLmltYWdlLCB2YWx1ZXMuaW1hZ2UsIHNwZWMuY29udGFpbmVycy5pbWFnZSwgc291cmNlc10pIiwKICAgICAgICAgICJkZWZhdWx0IiA6ICJbc3BlYy50ZW1wbGF0ZS5zcGVjLmNvbnRhaW5lcnMuaW1hZ2UsIHZhbHVlcy5pbWFnZSwgc3BlYy5jb250YWluZXJzLmltYWdlLCBzb3VyY2VzXSIKICAgICAgICB9CiAgICAgIH0KICAgIH0KICB9LAogICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZQp9
# 🔟❎ 'compile' k8s Helm scanner configuration
# Configures the k8s Helm chart symbol scanner which pulls referenced GitHub source repositories and
# Docker container images to scan for symbol values.
# To learn more see https://doc.log10x.com/compile/pull/helm
# For a reference list of common infrastructure charts, see:
# modules/pipelines/compile/modules/pull/helm/library.yaml
# Set the 10x pipeline to 'compile'
tenx: compile
# =============================== Helm Options ===============================
helm:
# Charts can be specified as Helm chart names OR as local chart files.
# 'chartNames' specifies a list of remote chart names to scan for values and template files.
chartNames: [
# open-telemetry/opentelemetry-demo,
# ingress-nginx/ingress-nginx,
]
# 'chartFiles' specifies a list of local chart template and values.yaml files on disk.
# File paths may be relative to the 'includePaths' list. If canonical, enclosing folders must added to 'includePaths'.
chartFiles: [
# charts/opentelemetry-demo/values.yaml
]
pull:
# 'dockerImages' specifies whether to pull docker container images referenced by input charts
# To learn more see https://doc.log10x.com/compile/pull/docker
dockerImages: true
github:
# 'repos' specifies whether to pull GitHub repos referenced by 'org.opencontainers.image.source' annotations
# To learn more see https://github.com/opencontainers/image-spec/blob/v1.0.1/annotations.md#pre-defined-annotation-keys
repos: true
# 'token' specifies the GitHub access token for pulling from referenced repos
# To learn more see: https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens
token: $=TenXEnv.get("GH_TOKEN") # (❗ EnvVar REQUIRED)
artifactory
Configure Artifactory repositories to pull files from Artifactory repositories to scan for symbol content.
Below is the default configuration from: artifactory/config.yaml (* Required Fields).
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYXJ0aWZhY3RvcnkiIDogewogICAgICAidHlwZSIgOiAiYXJyYXkiLAogICAgICAiaXRlbXMiIDogewogICAgICAgICJ0eXBlIiA6ICJvYmplY3QiLAogICAgICAgICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZSwKICAgICAgICAicHJvcGVydGllcyIgOiB7CiAgICAgICAgICAiaW5zdGFuY2UiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJBcnRpZmFjdG9yeSByZXBvc2l0b3J5IFVSTFxuXG5VUkwgZm9yIHRoZSByZW1vdGUgQXJ0aWZhY3RvcnkgaW5zdGFuY2UgKGUuZy4sIGh0dHBzOi8vbXl1c2VybmFtZS5qZnJvZy5pby9hcnRpZmFjdG9yeSkiCiAgICAgICAgICB9LAogICAgICAgICAgInRva2VuIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiQXJ0aWZhY3RvcnkgaW5zdGFuY2UgYWNjZXNzIHRva2VuXG5cbkFydGlmYWN0b3J5IFthY2Nlc3MgdG9rZW5dKGh0dHBzOi8vamZyb2cuY29tL2hlbHAvci9qZnJvZy1wbGF0Zm9ybS1hZG1pbmlzdHJhdGlvbi1kb2N1bWVudGF0aW9uL2FjY2Vzcy10b2tlbnMpIGZvciB0aGlzIHJlbW90ZSBpbnN0YW5jZS4gVGhpcyB2YWx1ZSBzaG91bGQgYmUgc2V0IHZpYSBhbiBbZW52aXJvbm1lbnQgdmFyaWFibGVdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vYXBpL2pzLyNUZW5YRW52LmdldCk6ICBgYGAgeWFtbCBhcnRpZmFjdG9yeVRva2VuOiAkPVRlblhFbnYuZ2V0KFwiQVJUSUZBQ1RPUllfVE9LRU5cIikgYGBgIgogICAgICAgICAgfSwKICAgICAgICAgICJyZXBvIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiQXJ0aWZhY3RvcnkgcmVwb3NpdG9yeSBuYW1lXG5cbk5hbWUgb2YgdGhlIFtyZXBvc2l0b3J5XShodHRwczovL2pmcm9nLmNvbS9oZWxwL3IvamZyb2ctYXJ0aWZhY3RvcnktZG9jdW1lbnRhdGlvbi9yZXBvc2l0b3J5LW1hbmFnZW1lbnQpIHdpdGhpbiB0aGUgdGFyZ2V0IEFydGlmYWN0b3J5IGluc3RhbmNlIGZyb20gd2hpY2ggdG8gcHVsbCB0aGUgc3BlY2lmaWVkIGZpbGUuIgogICAgICAgICAgfSwKICAgICAgICAgICJmaWxlcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUmVtb3RlIHJlcG9zaXRvcnkgZmlsZSBwYXRoc1xuXG5QYXRocyBvZiBmaWxlcyB3aXRoaW4gdGhlIHRhcmdldCBBcnRpZmFjdG9yeSBpbnN0YW5jZSByZXBvc2l0b3J5IHRvIHB1bGwiLAogICAgICAgICAgICAiaXRlbXMiIDogewogICAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICAgIH0KICAgICAgICAgIH0sCiAgICAgICAgICAiZm9sZGVycyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUmVtb3RlIHJlcG9zaXRvcnkgZm9sZGVyIHBhdGhzXG5cblBhdGhzIG9mIGZvbGRlcnMgd2l0aGluIHRoZSB0YXJnZXQgQXJ0aWZhY3RvcnkgaW5zdGFuY2UgcmVwb3NpdG9yeSB0byBwdWxsIiwKICAgICAgICAgICAgIml0ZW1zIiA6IHsKICAgICAgICAgICAgICAidHlwZSIgOiAic3RyaW5nIgogICAgICAgICAgICB9CiAgICAgICAgICB9LAogICAgICAgICAgInJlY3Vyc2l2ZSIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAiYm9vbGVhbiIsCiAgICAgICAgICAgICAgInN0cmluZyIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIlB1bGwgZmlsZXMgZnJvbSByZW1vdGUgcmVwb3NpdG9yeSBmb2xkZXJzIHJlY3Vyc2l2ZWx5XG5cblNwZWNpZmllcyB3aGV0aGVyIHRvIHB1bGwgZmlsZXMgZnJvbSBbYXJ0aWZhY3RvcnlGb2xkZXJzXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvcHVsbC9hcnRpZmFjdG9yeS8jYXJ0aWZhY3Rvcnlmb2xkZXJzKSByZWN1cnNpdmVseSAoaS5lLiwgcHVsbCBzdWItZm9sZGVycyBhcyB3ZWxsKS4gKEFjY2VwdHMgYm9vbGVhbiBvciBzdHJpbmcgd2l0aCAkPSBwcmVmaXggZm9yIHJ1bnRpbWUgZXZhbHVhdGlvbikgKERlZmF1bHQ6IGZhbHNlKSIsCiAgICAgICAgICAgICJkZWZhdWx0IiA6IGZhbHNlCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAicmVxdWlyZWQiIDogWwogICAgICAgICAgImluc3RhbmNlIiwKICAgICAgICAgICJ0b2tlbiIsCiAgICAgICAgICAicmVwbyIKICAgICAgICBdCiAgICAgIH0KICAgIH0KICB9LAogICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZQp9
# 🔟❎ 'compile' Artifactory configuration
# Pull artifacts (e.g., Java archives, .NET assemblies) from remote Artifactory instances to
# scan for symbol values. To learn more see https://doc.log10x.com/compile/pull/artifactory
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================= Artifactory Options ===========================
artifactory:
# 'token' specifies an Artifactory API access token.
# To learn more see https://jfrog.com/help/r/jfrog-platform-administration-documentation/access-tokens
- token: $=TenXEnv.get("ARTIFACTORY_TOKEN") # (❗ REQUIRED)
# 'instance' specifies the of location of the remote Artifactory instance (e.g., https://demo.jfrog.io/artifactory)
instance: "" # (❗ REQUIRED)
# 'repo' specifies the target Artifactory repository (e.g., pypi-local)
repo: "" # (❗ REQUIRED)
# 'files' specifies files to pull from the target Artifactory repository # (❗ REQUIRED)
files: [
# dist/jfrog-pypi-example-1.0.0.tar.gz
]
# 'folders' specifies folders paths within the target Artifactory instance repository to pull # (❗ REQUIRED)
folders: [
]
# 'recursive' specifies whether to pull folders recursively (i.e., pull sub-folders as well).
recursive: true
Scan
Scan
Configure the Input Scanner to capture symbol values from source code/binary files and link to an output symbol library.
Below is the default configuration from: scanners/config.yaml.
{
  "type" : "object",
  "properties" : {
    "tenx" : {
      "type" : "string"
    },
    "inputPaths" : {
      "type" : [
        "array"
      ],
      "markdownDescription" : "Input folders to scan\n\nProvides a list of folders that are traversed in search of source code (e.g. .js, .cpp), binary (e.g., .so, .jar, .zip) and text (e.g., .json, .xml) files to capture symbol values from and output to symbol unit files. Input folders may contain files and folders pulled from [GitHub](https://doc.log10x.com/compile/pull/github/) or  and [Artifactory](https://doc.log10x.com/compile/artifactory).",
      "items" : {
        "type" : "string"
      }
    },
    "outputSymbolFolder" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "Location of output symbol folder\n\nSpecifies the root folder in which to write output symbol unit files. This compiler [scan phase](https://doc.log10x.com/compile/scan/) mirrors the structure of the [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths) argument, placing each output symbol unit in the same relative path under [outputSymbolFolder](https://doc.log10x.com/compile/scan/#outputsymbolfolder) as its source/binary input file under its respective `inputPaths` folder entry.  For example, if [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths) is `~/dev` and it contains the file `~/dev/app/foo.js`, and this value is `~/symbols`, the respective output symbol unit file is: `~/symbols/app/foo.js.10x.json`."
    },
    "scan" : {
      "type" : "object",
      "additionalProperties" : false,
      "properties" : {
        "force" : {
          "type" : [
            "boolean",
            "string"
          ],
          "markdownDescription" : "Control whether to scan input files even if a matching existing symbol file exists\n\nControls whether to reuse matching symbol files within [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths). This option is primarily useful when debugging a new scanner module configuration (e.g., ANTLR grammar)  in conjunction with the [scanner debugging](https://doc.log10x.com/compile/scan) options. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
          "default" : false
        },
        "inProcess" : {
          "type" : [
            "boolean",
            "string"
          ],
          "markdownDescription" : "Controls whether to scan source/binary input files using sub-process(es)\n\nThe scanner can launch [subprocesses](https://doc.log10x.com/compile/scan/#subprocess_1) to capture [symbol](https://doc.log10x.com/run/transform/structure/#symbols) information from specific target source/binary input files.   Generating input file [ASTs](https://en.wikipedia.org/wiki/Abstract_syntax_tree) to scan for symbols values for complex syntaxes can be a lengthy, resource-consuming operation, which in the case of  [ANTLR syntaxes](https://tomassetti.me/improving-the-performance-of-an-antlr-parser/) may timeout or run out of memory.     Process [isolation](https://en.wikipedia.org/wiki/Process_isolation) allows for terminating scan operations that timeout for specific files, while allowing others to proceed. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
          "default" : false
        },
        "threadPoolSize" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Maximum number of threads to use concurrently process input source code /binary files\n\nControls the maximum number of threads to process input source code/binary files concurrently: - If the value is between 0 and 1, the number calculates a percentage of available cores (e.g., 0.5 = use up to 50% of available cores).   - If the value is >= 1, the value sets a fixed number of threads (e.g., 10 = 10 threads).   - If the value is 1, allocate a single thread to process input files. (Default: 0.5)",
          "default" : "0.5"
        },
        "unitTimeout" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Timeout interval for scanning a source code /binary input file\n\nSets the timeout interval when scanning a source code /binary input file before dropping it. Set to null to ignore. (Default: 20s)",
          "default" : "20s"
        },
        "operationTimeout" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Timeout interval for the entire scanning operation\n\nSets the timeout interval for the entire scanning operation before terminating it. Set to null to ignore. (Default: 10m)",
          "default" : "10m"
        },
        "debug" : {
          "type" : "object",
          "additionalProperties" : false,
          "properties" : {
            "origins" : {
              "type" : [
                "array",
                "null"
              ],
              "markdownDescription" : "List of input file names for which to log information\n\nSpecifies a list of input file names (e.g., my.scala, foo.java) to log information relating to which symbols were captured/skipped. Specify '*' for all files.",
              "items" : {
                "type" : "string"
              }
            },
            "symbols" : {
              "type" : [
                "array",
                "null"
              ],
              "markdownDescription" : "List of node types within a scanner AST tree for which to log information\n\nList of nodes within an input AST tree, such as class and method names(e.g., 'MyClass', 'foo') for which to log information relating to the context in which they were captured/skipped as symbols.  Specify '*' for all nodes.",
              "items" : {
                "type" : "string"
              }
            },
            "loggerName" : {
              "type" : [
                "string",
                "null"
              ],
              "markdownDescription" : "Debug logger name\n\nSpecifies the log4j logger for logging values for symbols/files matching 'debugOrigins' and 'debugSymbols'. (Default: [consoleOut](https://github.com/log-10x/config/blob/main/log4j2.yaml#L66))",
              "default" : "[consoleOut](https://github.com/log-10x/config/blob/main/log4j2.yaml#L66)"
            }
          }
        }
      }
    },
    "printOutput" : {
      "type" : [
        "boolean",
        "string"
      ],
      "markdownDescription" : "Controls whether to emit output scan operations progress to the console\n\nControls whether information relating to symbol units scanning is emitted to the stdout stream. This value should be set to true when the current 10x process is  spawned by a parent 10x 'compile' pipeline to report its progress. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
      "default" : false
    },
    "unitsToScanPerBatch" : {
      "type" : [
        "number",
        "string"
      ],
      "markdownDescription" : "Maximum number of input files to scan per sub-process.\n\nSets the maximum number of source/binary input files to scan by a single 'compile' sub-process. Set to 0 to unlimited. (Accepts number or string with $= prefix for runtime evaluation) (Default: 40)",
      "default" : 40
    },
    "tokenDelims" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "Token delimiters\n\nDefines which characters break a string of event characters into tokens to classify as symbols or variables. (Default: <>|. ][:-+/*=\\\\,{}_();'\\\"$\\t\\n@)",
      "default" : "<>|. ][:-+/*=\\\\,{}_();'\\\"$\\t\\n@"
    },
    "fileExtStringFormats" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "String format specifier characters\n\nControls which characters identify the start of a [format specifier](https://en.wikipedia.org/wiki/Printf#Format_specifier) for each programming language extension in the form of <ext>:<formatPrefix> (e.g., `.java:%`).  It is a standard programming practice to use string formats to log messages in the form of:  ``` java log.error(\"could not connect to {} with status {}\", host, status); ```  When an TenXTemplate tokenizer processing an event identifies a format prefix (e.g., `%`) it skips it and appends subsequent symbol tokens (e.g., `with status`) to the symbol sequence preceding them (e.g., `could not connect to`).",
      "items" : {
        "type" : "string"
      }
    },
    "maxSymbol" : {
      "type" : "object",
      "additionalProperties" : false,
      "properties" : {
        "unitSectionSize" : {
          "type" : [
            "number",
            "string"
          ],
          "markdownDescription" : "Maximum number of symbol tokens to store in a single symbol unit file\n\nControls the maximum number of symbol tokens to store in a symbol unit before splitting it. This option supports large source code /binary input files that may have thousands of text symbols to avoid  creating sizeable individual symbol unit files.         Set to null to ignore. (Accepts number or string with $= prefix for runtime evaluation) (Default: 500)",
          "default" : 500
        },
        "unitsPerToken" : {
          "type" : [
            "number",
            "string"
          ],
          "markdownDescription" : "Number of symbol units to retrieve when searching for the origin of an TenXTemplate symbol sequence\n\nControls the maximum number of symbol units to load from the pipeline's symbol library when searching for the origin of a specific [TenXTemplate](https://doc.log10x.com/run/template/) symbol.   The [symbolSequence](https://doc.log10x.com/api/js/#TenXObject+symbolSequence) function queries the source code/binary origin of symbol sequences in a target TenXTemplate to identify the logical [message](https://doc.log10x.com/run/initialize/message/) portion of a target app/infra events vs. variable and context information (e.g., user, host, severity).   Since a [symbol](https://doc.log10x.com/run/transform/structure/#symbols) value may appear in hundreds or more locations across a code base,  limiting the number of symbol units to load is necessary to reduce memory consumption.   A second consideration is placing an upper limit on the number of units to load from the symbol library,  which is the more frequent a symbol is, the lower the probability of selecting the correct origin. (Accepts number or string with $= prefix for runtime evaluation) (Default: 128)",
          "default" : 128
        }
      }
    }
  },
  "required" : [
    "inputPaths"
  ],
  "additionalProperties" : false
}
# 🔟❎ 'compile' symbol scanner config
# Configure input and output options for the compile pipeline.
# To learn more see https://doc.log10x.com/compile/scan
tenx: compile
# ========================== Configure I/O Paths ==============================
# 'inputPaths' lists folders on disk containing source code and binary files to scan.
# To learn more see https://doc.log10x.com/compile/scan/#inputpaths
inputPaths:
- $=path("data/compile/sources", "") # Default to none ("") if source folder not found
# - <path-to-input-files> # uncomment to specify additional input paths
# 'outputSymbolFolder' specifies the folder for output symbol unit files.
# To learn more see https://doc.log10x.com/compile/scan/#outputsymbolfolder
outputSymbolFolder: $=TenXEnv.get("TENX_OUTPUT_SYMBOL_FOLDER", path("data/shared/symbols", "<tenx.io.tmpdir>")) # Default to 10x temp dir
Link
Link
Configure the Symbol library linker to link symbol unit files to an output symbol library file.
Below is the default configuration from: link/config.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAib3V0cHV0U3ltYm9sTGlicmFyeUZpbGUiIDogewogICAgICAidHlwZSIgOiBbCiAgICAgICAgInN0cmluZyIsCiAgICAgICAgIm51bGwiCiAgICAgIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJMb2NhdGlvbiBvZiBvdXRwdXQgc3ltYm9sIGxpYnJhcnkgZmlsZVxuXG5TcGVjaWZpZXMgYW4gb3V0cHV0IHN5bWJvbCBsaWJyYXJ5IGZpbGUgbWVyZ2luZyB0aGUgc3ltYm9sIHVuaXQgZmlsZXMgcHJvZHVjZWQgZm9yIFtpbnB1dFBhdGhzXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvc2Nhbi8jaW5wdXRwYXRocykuIFRoZSBzeW1ib2wgbGlicmFyeSBmaWxlIHByb3ZpZGVzIGEgc2luZ2xlIGFydGlmYWN0IHRvIHNldCBhcyB0aGUgW3N5bWJvbFBhdGhzXShodHRwczovL2RvYy5sb2cxMHguY29tL3J1bi9zeW1ib2wvI3N5bWJvbHBhdGhzKSBhdCBydW4gdGltZS4iCiAgICB9LAogICAgIm1heFN5bWJvbFVuaXRGaWxlU2l6ZSIgOiB7CiAgICAgICJ0eXBlIiA6IFsKICAgICAgICAic3RyaW5nIiwKICAgICAgICAibnVsbCIKICAgICAgXSwKICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIk1heCBmaWxlIHNpemUgZm9yICdvdXRwdXRTeW1ib2xMaWJyYXJ5RmlsZScgYmVmb3JlIGl0IGlzIHNwbGl0IGludG8gY2h1bmtzXG5cblNldHMgdGhlIG1heGltdW0gZmlsZSBzaXplIChlLmcuLCA0ME1CKSBmb3IgW291dHB1dFN5bWJvbExpYnJhcnlGaWxlXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvbGluay8jb3V0cHV0c3ltYm9sbGlicmFyeWZpbGUpIGJlZm9yZSBzcGxpdHRpbmcgaW50byBjaHVua3MsIGVhY2ggd2VpZ2hpbmcgbm8gbW9yZSB0aGFuIHRoaXMgdmFsdWUuIFRoaXMgb3B0aW9uIGVuYWJsZXMgbGFyZ2UgIGFydGlmYWN0cyB0byByZW1haW4gW0dpdEh1YiBjb21taXR0YWJsZV0oaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vcmVwb3NpdG9yaWVzL3dvcmtpbmctd2l0aC1maWxlcy9tYW5hZ2luZy1sYXJnZS1maWxlcy9hYm91dC1sYXJnZS1maWxlcy1vbi1naXRodWIpLiAoRGVmYXVsdDogNDBNQikiLAogICAgICAiZGVmYXVsdCIgOiAiNDBNQiIKICAgIH0sCiAgICAic3ltYm9sIiA6IHsKICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZSwKICAgICAgInByb3BlcnRpZXMiIDogewogICAgICAgICJ0eXBlcyIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJhcnJheSIsCiAgICAgICAgICAgICJudWxsIgogICAgICAgICAgXSwKICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJUb2tlbiB0eXBlcyByZWFkIGZyb20gaW5wdXQgc291cmNlL2JpbmFyeSBmaWxlcyB3cml0dGVuIHRvIG91dHB1dFxuXG5GaWx0ZXIgc3ltYm9sIHZhbHVlcyB0byB3cml0ZSB0byBbb3V0cHV0U3ltYm9sTGlicmFyeUZpbGVdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9saW5rLyNvdXRwdXRzeW1ib2xsaWJyYXJ5ZmlsZSkgYmFzZWQgb24gdGhlaXIgW2NvbnRleHRdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vcnVuL3RyYW5zZm9ybS9zeW1ib2wvI2NvbnRleHRzKS4gVGhpcyBvcHRpb24gcmVkdWNlcyB0aGUgc2l6ZSBvZiB0aGUgb3V0cHV0IHN5bWJvbCBsaWJyYXJ5IGZpbGUgYnkgb21pdHRpbmcgc3ltYm9sIHR5cGVzIG5vdCByZXF1aXJlZCBhdCBydW4gdGltZS4gIEZvciBwb3NzaWJsZSB2YWx1ZXMsIHNlZTogW2NvbnRleHRzXShodHRwczovL2RvYy5sb2cxMHguY29tL3J1bi90cmFuc2Zvcm0vc3ltYm9sLyNjb250ZXh0cykuIChEZWZhdWx0OiBbXCJwYWNrYWdlXCIsXCJjbGFzc1wiLFwiZW51bVwiLFwibG9nXCIsXCJ0ZXh0XCIsXCJleGVjXCJdKSIsCiAgICAgICAgICAiaXRlbXMiIDogewogICAgICAgICAgICAidHlwZSIgOiAic3RyaW5nIgogICAgICAgICAgfSwKICAgICAgICAgICJkZWZhdWx0IiA6IFsKICAgICAgICAgICAgInBhY2thZ2UiLAogICAgICAgICAgICAiY2xhc3MiLAogICAgICAgICAgICAiZW51bSIsCiAgICAgICAgICAgICJsb2ciLAogICAgICAgICAgICAidGV4dCIsCiAgICAgICAgICAgICJleGVjIgogICAgICAgICAgXQogICAgICAgIH0sCiAgICAgICAgImZpbGVOYW1lRmlsdGVycyIgOiB7CiAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICJhcnJheSIsCiAgICAgICAgICAgICJudWxsIgogICAgICAgICAgXSwKICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJSZWdleCBwYXR0ZXJucyB0byBleGNsdWRlIHN5bWJvbCBmaWxlcyBmcm9tIG91dHB1dCBzeW1ib2wgbGlicmFyeVxuXG5GaWx0ZXJzIHN5bWJvbCBmaWxlcyB0byBleGNsdWRlIGZyb20gW291dHB1dFN5bWJvbExpYnJhcnlGaWxlXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvbGluay8jb3V0cHV0c3ltYm9sbGlicmFyeWZpbGUpIHVzaW5nIHJlZ2V4IHBhdHRlcm5zLiBUaGlzIG9wdGlvbiBpcyB0eXBpY2FsbHkgdXNlZCB0byBleGNsdWRlIHRlc3QgZmlsZXMgZnJvbSB0aGUgc3ltYm9sIGxpYnJhcnksIHJlZHVjaW5nIG91dHB1dCBzaXplIGFuZCBmb2N1c2luZyBvbiBwcm9kdWN0aW9uIGNvZGUgc3ltYm9scy4gIENvbW1vbiBwYXR0ZXJucyBmb3IgZXhjbHVkaW5nIHRlc3QgZmlsZXMgYWNyb3NzIGxhbmd1YWdlczogLSBKYXZhOiBgXi4qKFRlc3R8VGVzdHN8VGVzdENhc2UpXFwuamF2YSRgIChKVW5pdC9UZXN0TkcgdGVzdCBmaWxlcykgLSBKYXZhU2NyaXB0L1R5cGVTY3JpcHQ6IGBeLipcXC4odGVzdHxzcGVjKVxcLihqc3xqc3h8dHN8dHN4fG1qc3xjanMpJGAgKEplc3QvTW9jaGEvVml0ZXN0IHRlc3QgZmlsZXMpIC0gUHl0aG9uOiBgXnRlc3RfLitcXC5weSRgIG9yIGBeLitfdGVzdFxcLnB5JGAgKHB5dGVzdC91bml0dGVzdCB0ZXN0IGZpbGVzKSAtIFNjYWxhOiBgXi4qKFNwZWN8VGVzdClcXC5zY2FsYSRgIChTY2FsYVRlc3QvU3BlY3MyIHRlc3QgZmlsZXMpIC0gQyM6IGBeLiooVGVzdHxUZXN0cylcXC5jcyRgICh4VW5pdC9OVW5pdC9NU1Rlc3QgdGVzdCBmaWxlcykgLSBHbzogYF4uKl90ZXN0XFwuZ28kYCAoYnVpbHQtaW4gdGVzdGluZyBmcmFtZXdvcmsgdGVzdCBmaWxlcykgLSBDKys6IGBeLiooX3Rlc3R8VGVzdClzP1xcLihjcHB8Y2N8Y3h4fGhwcHxofGh4eCkkYCAoR29vZ2xlVGVzdC9DYXRjaDIvQm9vc3QuVGVzdCB0ZXN0IGZpbGVzKSIsCiAgICAgICAgICAiaXRlbXMiIDogewogICAgICAgICAgICAidHlwZSIgOiAic3RyaW5nIgogICAgICAgICAgfQogICAgICAgIH0sCiAgICAgICAgImZvbGRlckZpbHRlcnMiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAiYXJyYXkiLAogICAgICAgICAgICAibnVsbCIKICAgICAgICAgIF0sCiAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUGF0dGVybnMgdG8gZXhjbHVkZSBzeW1ib2wgZmlsZXMgYnkgZm9sZGVyIGZyb20gb3V0cHV0IHN5bWJvbCBsaWJyYXJ5XG5cbkZpbHRlcnMgc3ltYm9sIGZpbGVzIHRvIGV4Y2x1ZGUgZnJvbSBbb3V0cHV0U3ltYm9sTGlicmFyeUZpbGVdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9saW5rLyNvdXRwdXRzeW1ib2xsaWJyYXJ5ZmlsZSkgYmFzZWQgb24gZm9sZGVyIGxvY2F0aW9uLiBUaGlzIG9wdGlvbiBjb21wbGVtZW50cyBbc3ltYm9sRmlsZU5hbWVGaWx0ZXJzXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvbGluay8jc3ltYm9sZmlsZW5hbWVmaWx0ZXJzKSBieSBleGNsdWRpbmcgZmlsZXMgYmFzZWQgb24gdGhlaXIgY29udGFpbmluZyBmb2xkZXIuICAqKlBsYWluIGZvbGRlciBuYW1lKiogKGUuZy4sIGB0ZXN0YCkgLSBtYXRjaGVzIHdoZW4gdGhlIGZpbGUncyBkaXJlY3QgcGFyZW50IGZvbGRlciBoYXMgdGhpcyBuYW1lLiBPbmx5IGFscGhhbnVtZXJpYyBjaGFyYWN0ZXJzLCB1bmRlcnNjb3JlcywgYW5kIGh5cGhlbnMgYXJlIHRyZWF0ZWQgYXMgcGxhaW4gbmFtZXMuICAqKlJlZ2V4IHBhdHRlcm4qKiAoYW55dGhpbmcgZWxzZSkgLSBtYXRjaGVkIGFnYWluc3QgdGhlIGZ1bGwgZmlsZSBwYXRoIChjYXNlLWluc2Vuc2l0aXZlKS4gVXNlIGBbL1xcXFxdYCBmb3IgY3Jvc3MtcGxhdGZvcm0gcGF0aCBzZXBhcmF0b3JzIChVbml4IGAvYCBhbmQgV2luZG93cyBgXFxgKS4gICoqRXhhbXBsZXM6KiogLSBgdGVzdGAgLSBGaWxlcyBkaXJlY3RseSBpbnNpZGUgYSBgdGVzdGAgZm9sZGVyIC0gYF9fdGVzdHNfX2AgLSBGaWxlcyBkaXJlY3RseSBpbnNpZGUgYF9fdGVzdHNfX2AgKEplc3QgY29udmVudGlvbikgLSBgWy9cXFxcXXZlbmRvclsvXFxcXF1gIC0gRmlsZXMgYW55d2hlcmUgdW5kZXIgYSBgdmVuZG9yYCBmb2xkZXIgKEdvIHZlbmRvcmVkIGRlcHMpIC0gYFsvXFxcXF1ub2RlX21vZHVsZXNbL1xcXFxdYCAtIEZpbGVzIGFueXdoZXJlIHVuZGVyIGBub2RlX21vZHVsZXNgIiwKICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICB9CiAgICAgICAgfQogICAgICB9CiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' merge configuration
# Combine symbol units into a single output symbol library file.
# To learn more see https://doc.log10x.com/compile/link/
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================ Symbol Library Output ==========================
# 'outputSymbolLibraryFile' specifies location of output symbol library file which
# links the contents of 'outputSymbolFolder' to a single .json artifact and a
# compressed .zip version for use at run time by 10x 'run' pipelines.
# If a local output dir exists write to it, otherwise use the pipeline's temp folder.
# To learn more see https://doc.log10x.com/compile/link
outputSymbolLibraryFile: $=TenXEnv.get("TENX_OUTPUT_SYMBOL_LIBRARY_FILE", path("data/shared/symbols", "<tenx.io.tmpdir>") + "/" + TenXEnv.get("runtimeName", "symbols") + ".10x.tar")
# ============================ Symbol Filter options ==========================
# The options below control which symbol files and values are merged into 'outputSymbolLibraryFile'
symbol:
# 'fileNameFilters' — exclude test files from symbol library
fileNameFilters:
# ── Java ───────────────────────────────────────
- ^.*(Test|Tests|TestCase|TestSuite)\.java$ # *Test.java, *TestCase.java, *TestSuite.java
- ^Test.*\.java$ # TestFoo.java (legacy)
# ── JavaScript / TypeScript ────────────────────
- ^.*\.(test|spec)\.(js|jsx|ts|tsx|mjs|cjs)$ # *.test.js, *.spec.tsx
# ── Python ─────────────────────────────────────
- ^test_.+\.py$ # test_utils.py
- ^.+_test\.py$ # utils_test.py
- ^test(s|case|cases|suite|suites)?\.py$ # test.py, tests.py, testcase.py, testcases.py, testsuite.py
# ── Scala ──────────────────────────────────────
- ^.*(Spec|Test|Suite)\.scala$ # *Spec.scala, *Test.scala, *Suite.scala
# ── C# ─────────────────────────────────────────
- ^.*(Test|Tests|TestCase|TestSuite)\.cs$ # *Test.cs, *TestCase.cs, *TestSuite.cs
# ── Go ─────────────────────────────────────────
- ^.*_test\.go$ # *_test.go
# Note: testdata.go is usually a data file, not test code → not filtered here
# ── C++ ───────────────────────────────────────
- ^.*(_test|Test|Tests)s?\.(cpp|cc|cxx|hpp|h|hxx)$ # *_test.cpp, *Test.hpp, *Tests.cpp
# 'folderFilters' — patterns to exclude files by folder
# Plain name (e.g., "test") → matches direct parent folder only
# Regex (e.g., "[/\\]vendor[/\\]") → matches anywhere in full path
folderFilters:
- test # direct parent is "test"
- tests # direct parent is "tests"
- __tests__ # Jest convention
- spec # RSpec/Jasmine convention
- specs # RSpec/Jasmine convention
- unit # unit test folder
- integration # integration test folder
- e2e # e2e tests (Cypress, Playwright)
- end-to-end # alternate e2e naming
- acceptance # acceptance test folder
- testdata # Go test data folder
- fixtures # test fixtures folder
- mocks # mock implementations folder
- "[/\\\\]vendor[/\\\\][a-z]+\\.[a-z]" # Go vendored deps (vendor/domain.tld pattern)
# 'types' controls the types of symbols written into 'outputSymbolLibraryFile'
# for reflective use at runtime.
# Narrowing the this list reduces the size of the output 10x symbols file. Possible values:
types:
- class # source code class/interface name (e.g. 'AcmeLogic')
- enum # source code enum/literal name (e.g. 'severity: {error,warn,debug}')
- log # source code print format passed to a logging method/stream (e.g. 'err("could not connect to %s",..');
- exec # string value extracted from a binary executable input file (e.g. via 'strings' nix command)
# - method # code method/function name (e.g. 'foo')
# - const # string constant assigned into a variable or method arg (e.g. 'greeting = "hello world"')
# - text # string value, usually read from a config file (e.g. JSON/XML/YAML field name)
# - package # source code package/namespace/module name (e.g. 'com.acme.core')
Push
Push
Configure GitHub push committers to push output symbol unit files to GitHub.
Below is the default configuration from: push/config.yaml (* Required Fields).
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiZ2l0aHViUHVzaCIgOiB7CiAgICAgICJ0eXBlIiA6ICJhcnJheSIsCiAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlLAogICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICJyZXBvIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiVGFyZ2V0IEdpdEh1YiByZXBvXG5cbklkZW50aWZpZXMgYSBHaXRIdWIgcmVwb3NpdG9yeSB0byBwdXNoIGZpbGVzIHRvIGluY2x1ZGluZyB0aGUgdXNlcm5hbWUgb2YgdGhlIG93bmVyIChlLmcuLCAnc29tZS11c2VyL3JlcG8tbmFtZScpIgogICAgICAgICAgfSwKICAgICAgICAgICJ0b2tlbiIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgICAibnVsbCIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkdpdEh1YiBBUEkgYWNjZXNzIHRva2VuXG5cbkRlZmluZXMgYW4gYWNjZXNzIHRva2VuIGZvciBhY2Nlc3NpbmcgR2l0aHViIHJlcG9zLiBUbyBsZWFybiBtb3JlIHNlZSBbR2l0SHViIHRva2Vuc10oaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYXV0aGVudGljYXRpb24va2VlcGluZy15b3VyLWFjY291bnQtYW5kLWRhdGEtc2VjdXJlL21hbmFnaW5nLXlvdXItcGVyc29uYWwtYWNjZXNzLXRva2VucykuIgogICAgICAgICAgfSwKICAgICAgICAgICJicmFuY2giIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJUYXJnZXQgYnJhbmNoIHRvIHB1c2ggdG9cblxuU3BlY2lmaWVzIHRoZSBicmFuY2ggdG8gdXNlIHdoZW4gcHVzaGluZyB0byB0aGlzIHJlcG8uIElmIG9taXR0ZWQsIHVzZSB0aGUgcmVwb3NpdG9yeSdzIGRlZmF1bHQgYnJhbmNoLiIKICAgICAgICAgIH0sCiAgICAgICAgICAiZm9sZGVyIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiRm9sZGVyIHdpdGhpbiB0aGUgdGFyZ2V0IEdpdEh1YiByZXBvIGluIHdoaWNoIHRvIHB1c2ggZmlsZXNcblxuSWRlbnRpZmllcyBhIGZvbGRlciB3aXRoaW4gdGhlIHRhcmdldCBHaXRIdWIgcmVwbyB0byBwdXNoIG91dHB1dCBzeW1ib2wgZmlsZXMgdG8iCiAgICAgICAgICB9LAogICAgICAgICAgImZpbHRlciIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgICAibnVsbCIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkEgcmVnZXggcGF0dGVybiBhIGZpbGUgb24gZGlzayBtdXN0IG1hdGNoIHRvIHB1c2hcblxuU3BlY2lmaWVzIGEgYSByZWdleCBwYXR0ZXJuIGEgZmlsZSBvbiBkaXNrIG11c3QgbWF0Y2ggdG8gYmUgcHVzaGVkIHRvIHRoZSB0YXJnZXQgcmVwby4gVGhpcyBvcHRpb24gcHJvdmlkZXMgYSBtZWNoYW5pc20gZm9yICdyb3V0aW5nJyBvdXRwdXQgc3ltYm9sIGZpbGVzIHRvIGRpZmZlcmVudCByZXBvc2l0b3JpZXMgYmFzZWQgb24gdGhlaXIgZmlsZSBleHRlbnNpb24gKGUuZy4sIGBcXC5qc1xcLmpzb24kYCkgb3IgbG9jYXRpb24gd2l0aGluIHRoZSBvdXRwdXQgZm9sZGVyIHRyZWUgKGUuZy4sIGAoXnwvfFxcXFwpYWNtZSgvfFxcXFx8JGApIgogICAgICAgICAgfQogICAgICAgIH0sCiAgICAgICAgInJlcXVpcmVkIiA6IFsKICAgICAgICAgICJyZXBvIgogICAgICAgIF0KICAgICAgfQogICAgfQogIH0sCiAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlCn0=
# 🔟❎ 'compile' GitHub configuration
# Push output symbol unit files for reuse by subsequent compile cycles.
# To learn more see https://doc.log10x.com/compile/push/
# Set the 10x pipeline to 'compile'
tenx: compile
# =============================== GitHub Options ==============================
githubPush:
# 'token' specifies the access token for pushing files to the target repo, read from env or set inline.
# To learn more see: https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens
- token: $=TenXEnv.get("GH_TOKEN") # (❗ EnvVar REQUIRED)
# 'repo' specifies the repo name to pull in Github
# including the username of the owner (e.g., apache/spark)
repo: null # (❗ REQUIRED)
# 'branch' specifies the branch to use when pushing into this repo.
# If not specified, push to the default repo branch
branch: null
# 'folder' specifies a folder within the target repo to push files, if not specified push to root
folder: null
# 'filter' specifies a a regex pattern a file on disk must match to be pushed to the target repo.
filter: null
Advanced Settings
To configure advanced options (optional) for the Compiler app, Edit these settings:
Bootstrap
Bootstrap
Configure the Pipeline Bootstrapper to authenticate the log10x account and launch a target pipeline.
Below is the default configuration from: bootstrap/config.yaml.
{
  "type" : "object",
  "properties" : {
    "tenx" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "Name of pipeline to execute\n\nTarget [pipeline](https://doc.log10x.com/engine/pipeline/) to execute. For example, to specify the [run](https://doc.log10x.com/run/) pipeline and a [YAML](https://doc.log10x.com/config/yaml/) config file containing launch arguments, use:  ``` console $ tenx run @~/my.yaml ``` The YAML file may specify the pipeline name via a 'tenx' entry, allowing the 'pipeline' argument to be omitted from the command line.  For example (my.yaml):  ``` yaml tenx: run # set the pipeline to 'run' apiKey: <my-key> ... ```  Allows for launching the run pipeline via: ``` console $ tenx @~/my.yaml ```"
    },
    "apiKey" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "10x api key\n\nSpecifies an api key used for authenticating against the 10x service. This value is accessible from your [account settings](https://console.log10x.com)."
    },
    "metricEndpoint" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "10x service Prometheus metrics endpoint\n\nSpecifies the address of the Prometheus remote write endpoint to write pipeline usage and health metrics.  !!! note \"\"      This argument is only settable in the 10x 'on-premises' build. (Default: https://prometheus.log10x.com/api/v1/write)",
      "default" : "https://prometheus.log10x.com/api/v1/write"
    },
    "runtime" : {
      "type" : "object",
      "additionalProperties" : false,
      "properties" : {
        "name" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Name to report to the 10x service endpoint for this runtime instance\n\nSpecifies a logical name used as a [tag value](https://www.baeldung.com/micrometer#4-meters) for pipeline metrics. This value identifies instances of the 10x run/compile pipelines when reporting to the 10x service. For example, for a 10x [Edge Optimizer](https://doc.log10x.com/apps/edge/optimizer/) for Fluent Bit forwarders collecting events from a `broker` user-app, this value can be set to: `optimize_fluentbit_broker`"
        },
        "attributes" : {
          "type" : [
            "array",
            "null"
          ],
          "markdownDescription" : "List of attributes to add to all metrics reporting\n\nSpecifies a list of key-value pairs in the format `key:value` to be added as tags to pipeline metrics reported to the 10x service. These tags enable finer-grained filtering and analysis in monitoring systems like Prometheus. Multiple attributes can be combined into a single string using a semicolon (`;`), e.g., `key1:val1;key2:val2`.  If a key does not start with tenx_, the prefix tenx_ is automatically prepended to ensure consistency in tag naming conventions. For example, a provided attribute app:my-app will be reported as tenx_app:my-app  ``` yaml   runtimeAttributes:     - app:reporter     - env:edge ```",
          "items" : {
            "type" : "string"
          }
        }
      }
    },
    "includePaths" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "Pipeline include folders\n\nSpecifies folders on disk for resoling relative references within [include directives](https://doc.log10x.com/config/yaml/#include-directives). (Default: [\"working directory of current process\"])",
      "items" : {
        "type" : "string"
      },
      "default" : [
        "working directory of current process"
      ]
    },
    "jarFiles" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "Jar files to load\n\nSpecifies a list of .jar files to load into the host JVM for use by [compile](https://doc.log10x.com/api/compile/), [input](https://doc.log10x.com/api/input/) and [output](https://doc.log10x.com/api/output/) API extensions.  !!! note \"\"      This argument is not supported in the [edge](https://doc.log10x.com/engine/flavors/#edge) runtime flavor.",
      "items" : {
        "type" : "string"
      }
    },
    "quiet" : {
      "type" : [
        "boolean",
        "string"
      ],
      "markdownDescription" : "Disable printing binary version information to the console\n\nDisable printing build/version information to the console upon launch (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
      "default" : false
    },
    "disabledArgs" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "Limit argument values that can be set by users\n\nSpecifies a list of launch arguments that are disallowed from either command line or user config files. This argument provides a method of limiting the target [pipeline](https://doc.log10x.com/shared/bootstrap/#pipeline), [source](https://doc.log10x.com/config/#sources) and and [command line](https://doc.log10x.com/config/cli/) settable by the user.  This mechanism enables pipeline launchers such as the [Quarkus launcher](https://doc.log10x.com/api/launch/#quarkus) to limit user input received via REST requests to a target subset of 'safe' arguments.  For example, adding [procOutCommand](https://doc.log10x.com/run/output/event/process/#procoutcommand) to this list ensures that no external process outputs can be launched by the runtime.  An optional regex pattern can limit arguments to a certain subset of values in the form of: `<arg-name>[:pattern]` (e.g., specific process names). Multiple patterns can be specified per argument.  Matching the `source` argument determines which source locations to inspect (e.g., folders, files, GitHub repos). For example, an admin may place .yaml config files containing preset Fluent Bit outputs in `/etc/log10x/`, excluding their enclosed arguments from limits set by this list, while disallowing users to directly set them via the command-line or by sourcing them from their local/GitHub config files (see example below).  To limit:  The target pipeline (e.g., [run](https://doc.log10x.com/run/), [compile](https://doc.log10x.com/compile/)):  ``` yaml   disabledArgs:   - \"pipeline:^run\" # disallow compile ```  Target arguments (e.g., [process outputs](https://doc.log10x.com/run/output/event/process/)):  ``` yaml   - \"procOutCommand:^fluent-bit$\"   # limit to Fluent Bit only   # - procOutArgs: <specify-regex>  # further limit args for Fluent Bit ```  Control which argument [sources](https://doc.log10x.com/config/#sources) to inspect:  ``` yaml   - \"source:^github.*\"             # inspect of all arguments sourced from GitHub against this list   - \"source:^(?!/etc/log10x/).*\"   # inspect of all arguments sourced from config files NOT contained in: /etc/log10x/ ```",
      "items" : {
        "type" : "string"
      }
    },
    "debugEnvVars" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "List environment variables to debug\n\nSpecifies a list of env var names for which to log information relating to how they are resolved. For example, the following call: `L1Env.get(\"myVar\", \"myDefault\")` can be resolved from a number of [sources](https://doc.log10x.com/api/js/#TenXEnv.get) ranging from launch arguments, to OS/JVM properties and a default value (e.g., myDefault).  Setting this value to `myVar` will log INFO level information detailing how the value of the `myVar` was resolved.",
      "items" : {
        "type" : "string"
      }
    }
  },
  "required" : [
    "tenx",
    "apiKey"
  ],
  "additionalProperties" : false
}
# 🔟❎ compile bootstrap configuration
# This config file specifies bootstrap options for the compile pipeline.
# To learn more see https://doc.log10x.com/compile/bootstrap
# To learn more see https://doc.log10x.com/config/
tenx: compile
# =============================== Launch Settings ==============================
# 'apiKey' specifies an api key used authenticating against the 10x service
apiKey: $=TenXEnv.get("TENX_API_KEY", "NO-API-KEY")
# 'includePaths' specifies folders on disk for resolving relative config file/folder references in addition to the working folder
includePaths: []
# 'quiet' disables printing version information to the console.
# quiet: true
# 'jarFiles' specifies .jar files to dynamically load for use by compile, input and output API extensions.
jarFiles: []
# 'metricEndpoint' specifies the Prometheus endpoint to report usage/health metrics (enterprise version only).
# metricEndpoint: https://prometheus.log10x.com/api/v1/write
# specifies a list of launch arguments that are disallowed from either command line or user config files.
disabledArgs: []
Github Sync
Github Sync
Below is the default configuration from: gitops/config.yaml (* Required Fields).
ewogICIkc2NoZW1hIjogImh0dHA6Ly9qc29uLXNjaGVtYS5vcmcvZHJhZnQtMDcvc2NoZW1hIyIsCiAgInRpdGxlIjogIkdpdE9wcyBDb25maWd1cmF0aW9uIiwKICAiZGVzY3JpcHRpb24iOiAiQ29uZmlndXJhdGlvbiBmb3IgcHVsbGluZyBzeW1ib2wsIGNvbmZpZyBhbmQgbG9va3VwIGZpbGVzIGZyb20gYSByZW1vdGUgR2l0SHViIHJlcG8gdG8gZW5hYmxlIGNlbnRyYWxpemVkIGNvbmZpZ3VyYXRpb24gbWFuYWdlbWVudCIsCiAgInR5cGUiOiAib2JqZWN0IiwKICAicHJvcGVydGllcyI6IHsKICAgICJ0ZW54IjogewogICAgICAidHlwZSI6ICJzdHJpbmciLAogICAgICAiZGVzY3JpcHRpb24iOiAiVGhlIHRhcmdldCAxMHggcGlwZWxpbmUgdG8gcnVuIChlLmcuLCBydW4sIGNvbXBpbGUpIgogICAgfSwKICAgICJpbmNsdWRlIjogewogICAgICAidHlwZSI6ICJhcnJheSIsCiAgICAgICJkZXNjcmlwdGlvbiI6ICJMaXN0IG9mIGluY2x1ZGUgc291cmNlcyIsCiAgICAgICJpdGVtcyI6IHsKICAgICAgICAidHlwZSI6ICJvYmplY3QiLAogICAgICAgICJwcm9wZXJ0aWVzIjogewogICAgICAgICAgInNvdXJjZSI6IHsKICAgICAgICAgICAgInR5cGUiOiAic3RyaW5nIiwKICAgICAgICAgICAgImNvbnN0IjogImdpdGh1YiIsCiAgICAgICAgICAgICJkZXNjcmlwdGlvbiI6ICJUaGUgc291cmNlIHR5cGUgZm9yIHRoaXMgaW5jbHVkZSIKICAgICAgICAgIH0sCiAgICAgICAgICAib3B0aW9ucyI6IHsKICAgICAgICAgICAgIiRyZWYiOiAiIy9kZWZpbml0aW9ucy9QaXBlbGluZUxhdW5jaEdpdEh1Yk9wdGlvbnMiCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAicmVxdWlyZWQiOiBbInNvdXJjZSIsICJvcHRpb25zIl0KICAgICAgfQogICAgfQogIH0sCiAgImRlZmluaXRpb25zIjogewogICAgIlBpcGVsaW5lTGF1bmNoR2l0SHViT3B0aW9ucyI6IHsKICAgICAgInR5cGUiOiAib2JqZWN0IiwKICAgICAgImRlc2NyaXB0aW9uIjogIkdpdEh1YiBwdWxsIGNvbmZpZ3VyYXRpb24gb3B0aW9ucyIsCiAgICAgICJwcm9wZXJ0aWVzIjogewogICAgICAgICJlbmFibGVkIjogewogICAgICAgICAgInR5cGUiOiAiYm9vbGVhbiIsCiAgICAgICAgICAiZGVzY3JpcHRpb24iOiAiQ29udHJvbHMgd2hldGhlciB0byBlbmFibGUgdGhpcyBwdWxsIGNvbmZpZyIsCiAgICAgICAgICAiZGVmYXVsdCI6IGZhbHNlCiAgICAgICAgfSwKICAgICAgICAidG9rZW4iOiB7CiAgICAgICAgICAidHlwZSI6ICJzdHJpbmciLAogICAgICAgICAgImRlc2NyaXB0aW9uIjogIkFjY2VzcyB0b2tlbiBmb3IgYWNjZXNzaW5nIHRoZSBHaXRIdWIgcmVwby4gU2VlIGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2F1dGhlbnRpY2F0aW9uL2tlZXBpbmcteW91ci1hY2NvdW50LWFuZC1kYXRhLXNlY3VyZS9tYW5hZ2luZy15b3VyLXBlcnNvbmFsLWFjY2Vzcy10b2tlbnMiCiAgICAgICAgfSwKICAgICAgICAicmVwbyI6IHsKICAgICAgICAgICJ0eXBlIjogWyJzdHJpbmciLCAibnVsbCJdLAogICAgICAgICAgImRlc2NyaXB0aW9uIjogIlRoZSBHaXRIdWIgdXNlci9yZXBvIGZyb20gd2hpY2ggdG8gcHVsbCAoZS5nLiwgJ293bmVyL3JlcG8nKSIKICAgICAgICB9LAogICAgICAgICJicmFuY2giOiB7CiAgICAgICAgICAidHlwZSI6IFsic3RyaW5nIiwgIm51bGwiXSwKICAgICAgICAgICJkZXNjcmlwdGlvbiI6ICJCcmFuY2ggb24gcmVwby4gSWYgbnVsbCwgdXNlcyB0aGUgcmVwbydzIGRlZmF1bHQgYnJhbmNoIiwKICAgICAgICAgICJkZWZhdWx0IjogbnVsbAogICAgICAgIH0sCiAgICAgICAgInBhdGhzIjogewogICAgICAgICAgInR5cGUiOiAiYXJyYXkiLAogICAgICAgICAgImRlc2NyaXB0aW9uIjogIkdsb2IgcGF0dGVybnMgd2l0aGluICdyZXBvJyB0byBwdWxsIGFuZCBleHRyYWN0IHRvIGEgdGVtcCBmb2xkZXIiLAogICAgICAgICAgIml0ZW1zIjogewogICAgICAgICAgICAidHlwZSI6ICJzdHJpbmciCiAgICAgICAgICB9LAogICAgICAgICAgImV4YW1wbGVzIjogWwogICAgICAgICAgICBbImNvbmZpZy8qLnlhbWwiLCAic3ltYm9scy8qLjEweC50YXIiLCAibG9va3Vwcy8qLmNzdiIsICJzY3JpcHRzLyouanMiXQogICAgICAgICAgXQogICAgICAgIH0sCiAgICAgICAgInN5bmNJbnRlcnZhbCI6IHsKICAgICAgICAgICJ0eXBlIjogWyJzdHJpbmciLCAibnVsbCJdLAogICAgICAgICAgImRlc2NyaXB0aW9uIjogIkludGVydmFsIHRvIGNoZWNrIHRoZSByZW1vdGUgYnJhbmNoIGZvciB1cGRhdGVzIChlLmcuLCAnNW1pbicpLiBTZXQgdG8gbnVsbCB0byBkaXNhYmxlIHN5bmMiLAogICAgICAgICAgImRlZmF1bHQiOiBudWxsLAogICAgICAgICAgImV4YW1wbGVzIjogWyI1bWluIiwgIjFoIiwgIjMwcyJdCiAgICAgICAgfQogICAgICB9LAogICAgICAicmVxdWlyZWQiOiBbImVuYWJsZWQiLCAicmVwbyJdLAogICAgICAiYWRkaXRpb25hbFByb3BlcnRpZXMiOiBmYWxzZQogICAgfQogIH0KfQo=
# 🔟❎ GitOps configuration
# This config file pulls symbol, config and lookup files from a remote repo to
# enable centralized configuration management via GitHub.
# To learn more see https://doc.log10x.com/config/github
# The target 10x pipeline to run (e.g., run, compile) is specified in the config files pulled from the repo
tenx: any
include:
- source: github
options:
# 'enabled' controls whether to enable this pull config
enabled: false # (❗ REQUIRED)
# 'token' specifies an access token for accessing the Github repo.
# To learn more see https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens
token: $=TenXEnv.get("GH_TOKEN")
# 'repo' specifies the GitHub user/repo from which to pull
repo: null # (❗ REQUIRED)
# 'branch' on 'repo' (if null, uses default repo default branch)
branch: main
# 'paths' specifies Glob patterns within 'repo' to pull and extract to a temp folder.
paths:
- test
# - config/*.yaml # https://doc.log10x.com/config/yaml
# - symbols/*.10x.tar # https://doc.log10x.com/run/symbol
# - lookups/*.csv # https://doc.log10x.com/api/js/#TenXLookup
# - scripts/*.js # https://doc.log10x.com/api/js
# 'syncInterval' specifies an interval by which check to check the remote branch for updates (null to disable)
# This interval works in conjunction with: https://doc.log10x.com/run/reload
syncInterval: 5min
Scan
Scan
Configure the Input Scanner to capture symbol values from source code/binary files and link to an output symbol library.
advanced
Configure the Input Scanner to capture symbol values from source code/binary files and link to an output symbol library.
Below is the default configuration from: advanced/config.yaml.
{
  "type" : "object",
  "properties" : {
    "tenx" : {
      "type" : "string"
    },
    "inputPaths" : {
      "type" : [
        "array"
      ],
      "markdownDescription" : "Input folders to scan\n\nProvides a list of folders that are traversed in search of source code (e.g. .js, .cpp), binary (e.g., .so, .jar, .zip) and text (e.g., .json, .xml) files to capture symbol values from and output to symbol unit files. Input folders may contain files and folders pulled from [GitHub](https://doc.log10x.com/compile/pull/github/) or  and [Artifactory](https://doc.log10x.com/compile/artifactory).",
      "items" : {
        "type" : "string"
      }
    },
    "outputSymbolFolder" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "Location of output symbol folder\n\nSpecifies the root folder in which to write output symbol unit files. This compiler [scan phase](https://doc.log10x.com/compile/scan/) mirrors the structure of the [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths) argument, placing each output symbol unit in the same relative path under [outputSymbolFolder](https://doc.log10x.com/compile/scan/#outputsymbolfolder) as its source/binary input file under its respective `inputPaths` folder entry.  For example, if [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths) is `~/dev` and it contains the file `~/dev/app/foo.js`, and this value is `~/symbols`, the respective output symbol unit file is: `~/symbols/app/foo.js.10x.json`."
    },
    "scan" : {
      "type" : "object",
      "additionalProperties" : false,
      "properties" : {
        "force" : {
          "type" : [
            "boolean",
            "string"
          ],
          "markdownDescription" : "Control whether to scan input files even if a matching existing symbol file exists\n\nControls whether to reuse matching symbol files within [inputPaths](https://doc.log10x.com/compile/scan/#inputpaths). This option is primarily useful when debugging a new scanner module configuration (e.g., ANTLR grammar)  in conjunction with the [scanner debugging](https://doc.log10x.com/compile/scan) options. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
          "default" : false
        },
        "inProcess" : {
          "type" : [
            "boolean",
            "string"
          ],
          "markdownDescription" : "Controls whether to scan source/binary input files using sub-process(es)\n\nThe scanner can launch [subprocesses](https://doc.log10x.com/compile/scan/#subprocess_1) to capture [symbol](https://doc.log10x.com/run/transform/structure/#symbols) information from specific target source/binary input files.   Generating input file [ASTs](https://en.wikipedia.org/wiki/Abstract_syntax_tree) to scan for symbols values for complex syntaxes can be a lengthy, resource-consuming operation, which in the case of  [ANTLR syntaxes](https://tomassetti.me/improving-the-performance-of-an-antlr-parser/) may timeout or run out of memory.     Process [isolation](https://en.wikipedia.org/wiki/Process_isolation) allows for terminating scan operations that timeout for specific files, while allowing others to proceed. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
          "default" : false
        },
        "threadPoolSize" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Maximum number of threads to use concurrently process input source code /binary files\n\nControls the maximum number of threads to process input source code/binary files concurrently: - If the value is between 0 and 1, the number calculates a percentage of available cores (e.g., 0.5 = use up to 50% of available cores).   - If the value is >= 1, the value sets a fixed number of threads (e.g., 10 = 10 threads).   - If the value is 1, allocate a single thread to process input files. (Default: 0.5)",
          "default" : "0.5"
        },
        "unitTimeout" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Timeout interval for scanning a source code /binary input file\n\nSets the timeout interval when scanning a source code /binary input file before dropping it. Set to null to ignore. (Default: 20s)",
          "default" : "20s"
        },
        "operationTimeout" : {
          "type" : [
            "string",
            "null"
          ],
          "markdownDescription" : "Timeout interval for the entire scanning operation\n\nSets the timeout interval for the entire scanning operation before terminating it. Set to null to ignore. (Default: 10m)",
          "default" : "10m"
        },
        "debug" : {
          "type" : "object",
          "additionalProperties" : false,
          "properties" : {
            "origins" : {
              "type" : [
                "array",
                "null"
              ],
              "markdownDescription" : "List of input file names for which to log information\n\nSpecifies a list of input file names (e.g., my.scala, foo.java) to log information relating to which symbols were captured/skipped. Specify '*' for all files.",
              "items" : {
                "type" : "string"
              }
            },
            "symbols" : {
              "type" : [
                "array",
                "null"
              ],
              "markdownDescription" : "List of node types within a scanner AST tree for which to log information\n\nList of nodes within an input AST tree, such as class and method names(e.g., 'MyClass', 'foo') for which to log information relating to the context in which they were captured/skipped as symbols.  Specify '*' for all nodes.",
              "items" : {
                "type" : "string"
              }
            },
            "loggerName" : {
              "type" : [
                "string",
                "null"
              ],
              "markdownDescription" : "Debug logger name\n\nSpecifies the log4j logger for logging values for symbols/files matching 'debugOrigins' and 'debugSymbols'. (Default: [consoleOut](https://github.com/log-10x/config/blob/main/log4j2.yaml#L66))",
              "default" : "[consoleOut](https://github.com/log-10x/config/blob/main/log4j2.yaml#L66)"
            }
          }
        }
      }
    },
    "printOutput" : {
      "type" : [
        "boolean",
        "string"
      ],
      "markdownDescription" : "Controls whether to emit output scan operations progress to the console\n\nControls whether information relating to symbol units scanning is emitted to the stdout stream. This value should be set to true when the current 10x process is  spawned by a parent 10x 'compile' pipeline to report its progress. (Accepts boolean or string with $= prefix for runtime evaluation) (Default: false)",
      "default" : false
    },
    "unitsToScanPerBatch" : {
      "type" : [
        "number",
        "string"
      ],
      "markdownDescription" : "Maximum number of input files to scan per sub-process.\n\nSets the maximum number of source/binary input files to scan by a single 'compile' sub-process. Set to 0 to unlimited. (Accepts number or string with $= prefix for runtime evaluation) (Default: 40)",
      "default" : 40
    },
    "tokenDelims" : {
      "type" : [
        "string",
        "null"
      ],
      "markdownDescription" : "Token delimiters\n\nDefines which characters break a string of event characters into tokens to classify as symbols or variables. (Default: <>|. ][:-+/*=\\\\,{}_();'\\\"$\\t\\n@)",
      "default" : "<>|. ][:-+/*=\\\\,{}_();'\\\"$\\t\\n@"
    },
    "fileExtStringFormats" : {
      "type" : [
        "array",
        "null"
      ],
      "markdownDescription" : "String format specifier characters\n\nControls which characters identify the start of a [format specifier](https://en.wikipedia.org/wiki/Printf#Format_specifier) for each programming language extension in the form of <ext>:<formatPrefix> (e.g., `.java:%`).  It is a standard programming practice to use string formats to log messages in the form of:  ``` java log.error(\"could not connect to {} with status {}\", host, status); ```  When an TenXTemplate tokenizer processing an event identifies a format prefix (e.g., `%`) it skips it and appends subsequent symbol tokens (e.g., `with status`) to the symbol sequence preceding them (e.g., `could not connect to`).",
      "items" : {
        "type" : "string"
      }
    },
    "maxSymbol" : {
      "type" : "object",
      "additionalProperties" : false,
      "properties" : {
        "unitSectionSize" : {
          "type" : [
            "number",
            "string"
          ],
          "markdownDescription" : "Maximum number of symbol tokens to store in a single symbol unit file\n\nControls the maximum number of symbol tokens to store in a symbol unit before splitting it. This option supports large source code /binary input files that may have thousands of text symbols to avoid  creating sizeable individual symbol unit files.         Set to null to ignore. (Accepts number or string with $= prefix for runtime evaluation) (Default: 500)",
          "default" : 500
        },
        "unitsPerToken" : {
          "type" : [
            "number",
            "string"
          ],
          "markdownDescription" : "Number of symbol units to retrieve when searching for the origin of an TenXTemplate symbol sequence\n\nControls the maximum number of symbol units to load from the pipeline's symbol library when searching for the origin of a specific [TenXTemplate](https://doc.log10x.com/run/template/) symbol.   The [symbolSequence](https://doc.log10x.com/api/js/#TenXObject+symbolSequence) function queries the source code/binary origin of symbol sequences in a target TenXTemplate to identify the logical [message](https://doc.log10x.com/run/initialize/message/) portion of a target app/infra events vs. variable and context information (e.g., user, host, severity).   Since a [symbol](https://doc.log10x.com/run/transform/structure/#symbols) value may appear in hundreds or more locations across a code base,  limiting the number of symbol units to load is necessary to reduce memory consumption.   A second consideration is placing an upper limit on the number of units to load from the symbol library,  which is the more frequent a symbol is, the lower the probability of selecting the correct origin. (Accepts number or string with $= prefix for runtime evaluation) (Default: 128)",
          "default" : 128
        }
      }
    }
  },
  "required" : [
    "inputPaths"
  ],
  "additionalProperties" : false
}
# 🔟❎ 'compile' symbol scanner advanced config
# Configure input and output options for the compile pipeline.
# To learn more see https://doc.log10x.com/compile/scan/
# Set the 10x pipeline to 'compile'
tenx: compile
inputPaths: []
# ============================ Advanced options ===============================
# ----------------------------- Tokenizer options -----------------------------
# Tokenization options provide control over how the symbol scanners parse source and config file input.
# To learn more https://doc.log10x.com/compile/scan/#tokenize
# 'tokenDelims' defines which characters break a string of event characters into tokens to
# classify as symbols or variables.
tokenDelims: "<>|. ][:-+/*=\\,{}_();'\"$\t\n@"
# 'fileExtStringFormats' controls which characters identify the start of a format specifier (https://en.wikipedia.org/wiki/Printf#Format_specifier).
fileExtStringFormats:
- .java:%
- .py:{
- .js:${
- .php:$
- .swift:\(
- .kt:$
- .rb:#{
- .ex:#{
- .c:%
- .cpp:%
- .cs:{
- .go:%
- .rs:{
- .ts:${
- .pl:$
- .sh:$
- .r:%
- .m:%
- .scala:$
maxSymbol:
# 'unitsPerToken' controls the maximum number of symbol units to load from the
# pipeline's symbol library when searching for the origin of a specific TenXTemplate symbol.
unitsPerToken: 128
# ----------------------------- Subprocess options ----------------------------
# Subprocess options control whether scanners execute in the current 10x Engine instance
# or via a sub-process to provide better isolation over parsing of complex source code ASTs.
# To learn more https://doc.log10x.com/compile/scan/#subprocess_1
# 'unitsToScanPerBatch' sets the maximum number of input files to scan per subprocess instance.
# When this threshold is exceeded the current subprocess terminated and a new one is spawned until scan is complete.
unitsToScanPerBatch: 200
scan:
# ----------------------------- Threading options ----------------------------
# 'threadPoolSize'controls the maximum number of threads to concurrently
# process input source/binary files. If the value is between 0 and 1, the number calculates
# a percentage of available cores (e.g., 0.5 = use up to 50% of available cores).
# If the value is >= 1, the value sets a fixed number of threads (e.g., 10 = 10 threads).
# If the value is 1, allocate a single thread to process input files.
# To learn more see https://doc.log10x.com/compile/scan/#parallel
threadPoolSize: "0.5"
# 'scanUnitTimeout' sets the timeout interval when scanning a source/binary input
# file before dropping it.
unitTimeout: 30s
# 'scanOperationTimeout' sets the timeout interval for the entire scanning operation
# before terminating it.
operationTimeout: 10m
# -------------------------------- Debug Option -------------------------------
# The settings below provide control over what information is logged
# to console/file when scanning input source code/text/binary files for symbol values.
# These options are primarily used when adding support for a new programming language
# syntax via the 'ANTLR' scanner, text file formats via the Jackson 'text' scanner
# or an external command using the 'executable' scanner.
debug:
# 'origins' lists names of input source/binary files
# (e.g. .class, .js, .yaml, .exe) for which debug information
# is printed to the console via 'consoleOut' log4j logger.
# Printed output is dependent on the scanner assigned to process the input file
# and usually includes the AST of the input file from which tokens are selected.
# This information can be used when debugging which symbols are extracted
# from an input file in the context of an 'antlr', 'text' or 'executable' scanner.
# Set to '*' to match all input files.
origins: [
# '*'
]
# 'symbols' lists the values of nodes within the AST of a
# target input file (e.g. MyClass, MyEnum, myFunc, ..) for which
# debug information is printed to the console via the 'consoleOut' logger.
# This includes source context (e.g. class, enum) and path within the AST
# in which the node was detected. Set to '*' to match all AST nodes.
symbols: [
#'*'
]
# 'inProcess' controls whether to scan source/binary input files from within the current
# 10x process or launch a sequential series subprocesses for better isolation
# inProcess: true
# 'force' enables scanning of source/binary input files even if a matching
# symbol unit was found in 'inputPaths'. This flag is useful when debugging
# an Antlr/text/exec scanner using 'debugOrigins' and 'debugSymbols'
# to ensure a scan takes place even if a matching symbol unit is found.
# force: false
pattern
Configure Regex pattern scanners to extract symbol values from a files using regular expressions.
Below is the default configuration from: pattern/config.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAicGF0dGVybiIgOiB7CiAgICAgICJ0eXBlIiA6ICJhcnJheSIsCiAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlLAogICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICJmaWxlRmlsdGVyIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiRmlsZSBuYW1lIGZpbHRlciByZWd4IHBhdHRlcm5cblxuRGVmaW5lcyBhIHJlZ2V4IHBhdHRlcm4gYSBmaWxlIG5hbWUgbXVzdCBtYXRjaCBmb3IgdGhpcyBzY2FubmVyIHRvIGJlIGFwcGxpZWQgdG8gaXRzIGNvbnRlbnRzIgogICAgICAgICAgfSwKICAgICAgICAgICJsaW5lRmlsdGVyIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiRmlsZSBsaW5lIGZpbHRlciByZWd4IHBhdHRlcm5cblxuRGVmaW5lcyBhIHJlZ2V4IHBhdHRlcm4gYXBwbGllZCB0byBlYWNoIGxpbmUgd2l0aGluIGEgdGFyZ2V0IGZpbGUgd2hlcmUgZWFjaCBtYXRjaGluZyByZWdpb24gd2lsbCBiZSBleHRyYWN0ZWQgYXMgc3ltYm9sIHZhbHVlLiBOT1RFOiBUYWtlIGludG8gY29uc2lkZXJhdGlvbiBwZXJmb3JtYW5jZSBpbXBsaWNhdGlvbnMgb2YgdGhlIGlucHV0IGV4cHJlc3Npb24gdG8gYXZvaWQgbG9uZyBwcm9jZXNzaW5nIHRpbWUgYW5kL29yIGVycm9ycy4iCiAgICAgICAgICB9LAogICAgICAgICAgImV4dHJhY3RRdW90ZXMiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgImJvb2xlYW4iLAogICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJFeHRyYWN0IHNpbmdsZSBhbmQgZG91YmxlIHF1b3RlZCB2YWx1ZXNcblxuRGVmaW5lcyB3aGV0aGVyIHRvIGV4dHJhY3Qgc2luZ2xlIGFuZCBkb3VibGUgcXVvdGVkIHZhbHVlcyBmcm9tIGlucHV0IGxpbmVzLCB0YWtpbmcgaW50byBjb25zaWRlcmF0aW9uIGVzY2FwaW5nIGFuZCBpbXByb3Blcmx5IGNsb3NlZCBxdW90YXRpb25zLiBUaGlzIG9wdGlvbnMgcHJvdmlkZXMgYW0gZWZmaWNpZW50IG1ldGhvZCBmb3IgZXh0cmFjdGluZyBzdHJpbmcgY29uc3RhbnRzIGZyb20gaW5wdXQgZmlsZXMgd2l0aG91dCByZWx5aW5nIG9uIHJlZ2V4IGJhY2t0cmFja2luZy4gVG8gbGVhcm4gbW9yZSBzZWUgW3BzZXVkbyBjb2RlXSAoaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vdGFsd2d4L2QzMTEzM2Y2Mjc4YmI4YjY0MGJhZjA1MGY3ODA0N2Q1KS4gKEFjY2VwdHMgYm9vbGVhbiBvciBzdHJpbmcgd2l0aCAkPSBwcmVmaXggZm9yIHJ1bnRpbWUgZXZhbHVhdGlvbikiCiAgICAgICAgICB9LAogICAgICAgICAgIm1hdGNoQ29udGV4dCIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgICAibnVsbCIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIk91dHB1dCBzeW1ib2wgY29udGV4dFxuXG5TZXRzIHRoZSBzb3VyY2UgY29udGV4dCB0byBhc3NpZ24gYW55IHN5bWJvbHMgY29sbGVjdGVkIHVzaW5nIHRoaXMgdGhpcyBwYXR0ZXJuIHNlbGVjdG9yLiBGb3IgcG9zc2libGUgdmFsdWVzLCBzZWUgc3ltYm9sIFtjb250ZXh0c10oaHR0cHM6Ly9kb2MubG9nMTB4LmNvbS9ydW4vdHJhbnNmb3JtL3N5bWJvbC8jY29udGV4dHMpLiAgIElmIGEgdGFyZ2V0IGlucHV0IGxpbmUgY29udGFpbnMgbWF0Y2hlcyBmb3IgW3BhdHRlcm5MaW5lRmlsdGVyXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvc2Nhbm5lci9wYXR0ZXJuLyNwYXR0ZXJubGluZWZpbHRlcikgQU5EIHRoaXMgdmFsdWUgaXMgc2V0IHRvIFttZXRob2RdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vcnVuL3RyYW5zZm9ybS9zeW1ib2wvI21ldGhvZCkgQU5EIHRoZSBtYXRjaGluZyBsaW5lIGNvbnRhaW5zIHZhbHVlcyBzcGVjaWZpZWQgYXMgW2xvZ21ldGhvZHNdKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vY29tcGlsZS9zY2FubmVyL2xvZ01ldGhvZHMvI2xvZ21ldGhvZHMpIG9yIFtsb2dzdHJlYW1zXShodHRwczovL2RvYy5sb2cxMHguY29tL2NvbXBpbGUvc2Nhbm5lci9sb2dNZXRob2RzLyNsb2dzdHJlYW1zKSBvdXRzaWRlIG9mIG1hdGNoIGJvdW5kcyB0aGVuIHRoZSBjb250ZXh0IHdpbGwgYmUgc2V0IGFzIFtsb2ddKGh0dHBzOi8vZG9jLmxvZzEweC5jb20vcnVuL3RyYW5zZm9ybS9zeW1ib2wvI2xvZykuICBGb3IgZXhhbXBsZSwgZm9yIHRoZSBmb2xsb3dpbmcgaW5wdXQgbGluZSwgYSBwYXR0ZXJuIHNjYW5uZXIgc2V0IHRvIGBtZXRob2RgIHRoYXQgZXh0cmFjdHMgcXVvdGVkIHN0cmluZ3Mgd2lsbCBhc3NpZ25lZCB0aGUgZXh0cmFjdGVkIHZhbHVlJ3MgY29udGV4dCBhcyBgbG9nYCBnaXZlbiB0aGUgcHJlc2VuY2Ugb2YgdGhlIGBDb25zb2xlYCB2YWx1ZSB3aGljaCBpcyBkZWZpbmVkIGFzIGxvZ2dpbmcgc3RyZWFtIGlkZW50aWZpZXIuICBgYGAgY3MgQ29uc29sZS5Xcml0ZUxpbmUoXCJBY2NvdW50aW5nIFxcXCJzZXJ2aWNlIHN0YXJ0ZWRcIik7IGBgYCIKICAgICAgICAgIH0sCiAgICAgICAgICAidW5lc2NhcGVTY2hlbWUiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJVbmVzY2FwZSBzY2hlbWUgdG8gYXBwbHkgdG8gbWF0Y2hpbmcgc2VxdWVuY2VzXG5cblNwZWNpZmllcyBhbiB1bmVzY2FwZSBhbGdvcml0aG0gdG8gYXBwbHkgdG8gbWF0Y2hpbmcgc2VxdWVuY2VzIG9mIFtwYXR0ZXJuTGluZUZpbHRlcl0oaHR0cHM6Ly9kb2MubG9nMTB4LmNvbS9jb21waWxlL3NjYW5uZXIvcGF0dGVybi8jcGF0dGVybmxpbmVmaWx0ZXIpLiBTdXBwb3J0ZWQgdmFsdWVzOiBbanNvbixqYXZhLHhtbCxodG1sLGphdmFTY3JpcHRdLiAgIElmIG5vdCBzcGVjaWZpZWQsIGNoYXJhY3RlcnMgYXJlIHRyZWF0ZWQgYXMgbm90IGVzY2FwZWQuICBUbyBsZWFybiBtb3JlIHNlZSBbVW5lc2NhcGUgYWxnb3JpdGhtc10oaHR0cHM6Ly93d3cudW5iZXNjYXBlLm9yZy91c2luZ3VuYmVzY2FwZS5odG1sKS4iCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAicmVxdWlyZWQiIDogWwogICAgICAgICAgImZpbGVGaWx0ZXIiLAogICAgICAgICAgImV4dHJhY3RRdW90ZXMiCiAgICAgICAgXQogICAgICB9CiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' pattern quoted strings configuration
# This pattern symbol scanner extracts single and double quoted string values
# from target files. This pattern is used a default for capturing symbol values
# from source files for which no ANTLR grammar or built-in scanner is available.
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== Pattern Options ==============================
pattern:
# 'fileFilter' is set as a sink for prominent source code files. Available built-in and ANTLR
# scanners will take precedence over this pattern scanner
- fileFilter: \b\w+\.(java|cs|php|cpp|cxx|c|h|H|hxx|cc|hh|py|go|js|rs|bash|scala|sc|ts|rb|kt|lua|groovy|swift)\b
extractQuotes: true
# 'lineFilter' defines a regex pattern applied to each line within a target file.
# Each matching region will be extracted as symbol value
lineFilter: null
# 'matchContext' sets the source context to assign any symbols collected using this this pattern selector.
# For possible values, see https://doc.log10x.com/run/transform/symbol/#contexts
matchContext: method_invoke
# 'unescapeScheme' specifies an unescape algorithm to apply to matching sequences of patternLineFilter.
# Supported values: [json,java,xml,html,javaScript].
unescapeScheme: java
Cpp
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/cpp.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' C++ ANTLR symbol scanner configuration
# The 'cpp' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from c++ source files.
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR grammar .g4 file used to
# to tokenize and construct an AST for the target cpp file
lang: cpp
fileExt:
- .cpp
- .cxx
- .c++
- .c
- .h
- .H
- .hpp
- .hxx
- .h++
- .cc
- .hh
grammarFile: grammar/CPP14Parser.g4
lexerFile: grammar/CPP14Lexer.g4
rootRule: translationUnit
reserved:
- '::'
- '<<'
- inline
- namespace
- <
- class
- '>'
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
- ^.*\bnew\(\);\b.*$
# The 'rule' list defines the nodes within a cpp AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: enumerator
lang: cpp
context: enum
recursive: false
capture: allSymbols
- name: blockDeclaration
lang: cpp
context: method_invoke
recursive: true
capture: literalsOnly
- name: enumbase
lang: cpp
context: enum
recursive: true
capture: literalsOnly
- name: classHeadName
lang: cpp
context: class
recursive: true
capture: allSymbols
- name: enumSpecifier
lang: cpp
context: class
recursive: false
capture: literalsOnly
condition: ^enumHead$
tag: EnumHead
- name: enumHead
lang: cpp
context: class
recursive: false
capture: allSymbols
ifTag: EnumHead
- name: functionDefinition
lang: cpp
context: method_decl
recursive: false
capture: allSymbols
condition: ^functionDefinition$
tag: FunctionDefinition
- name: declaratorid
lang: cpp
context: method_decl
recursive: true
capture: allSymbols
ifTag: FunctionDefinition
- name: jumpStatement
lang: cpp
context: var_assign
recursive: true
capture: literalsOnly
- name: functionBody
lang: cpp
context: method_invoke
recursive: false
capture: literalsOnly
# condition: ^functionBody$
# tag: FunctionBody
- name: statement
lang: cpp
context: method_invoke
recursive: true
capture: literalsOnly
- name: classSpecifier
lang: cpp
context: class
recursive: false
capture: literalsOnly
subRule: memberSpecification
- name: staticAssertDeclaration
lang: cpp
context: var_assign
recursive: true
capture: literalsOnly
- name: parameterDeclarationList
lang: cpp
context: method_invoke
recursive: false
capture: literalsOnly
# condition: ^parameterDeclarationList$
# tag: ParameterDeclarationList
- name: enumeratorDefinition
lang: cpp
context: enum
recursive: false
capture: allSymbols
- name: namespaceDefinition
lang: cpp
context: package
recursive: false
capture: allSymbols
- name: constantExpression
lang: cpp
context: var_assign
recursive: true
capture: literalsOnly
- name: templateArgumentList
lang: cpp
context: method_invoke
recursive: false
capture: literalsOnly
# condition: ^templateArgumentList$
# tag: TemplateArgumentList
Csharp
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/csharp.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' C# ANTLR symbol scanner configuration
# The 'csharp' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from c# source files.
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR-generated parser class used to
# to tokenize and construct an AST for the target c# file.
lang: csharp
fileExt:
- .csx
- .cs
parserClass: com.log10x.antlr.generated.csharp.CSharpParser
lexerClass: com.log10x.antlr.generated.csharp.CSharpLexer
# 'charStreamClass' is set to remove language elements introduced later than V6.0 which is the latest release supported by this grammar.
# To learn more see https://github.com/antlr/grammars-v4/tree/master/csharp#readme
charStreamClass: com.log10x.antlr.parsers.CSharpDowngrader
rootRule: compilation_unit
reserved:
- namespace
- interface
- class
- enum
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# Remove unsupported C# v10 File scoped namespaces
- ^namespace.*;$
# Remove unsupported C# v9 Target-typed new operator
# - "(?<!\\w)new\\s*\\(\\s*\\)\\s*;"
- ".*new\\(.*"
# The 'rule' list defines the nodes within a csharp AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: interface_definition
lang: csharp
context: class
recursive: false
capture: allSymbols
subRule: identifier
- name: enum_member_declaration
lang: csharp
context: enum
recursive: true
capture: allSymbols
- name: enum_definition
lang: csharp
context: class
recursive: false
capture: allSymbols
subRule: identifier
- name: namespace_body
lang: csharp
context: package
recursive: true
capture: literalsOnly
- name: method_invocation
lang: csharp
context: method_invoke
recursive: true
capture: literalsOnly
- name: object_creation_expression
lang: csharp
context: method_invoke
recursive: true
capture: literalsOnly
- name: interpolated_regular_string_part
lang: csharp
context: method_invoke
recursive: false
capture: allSymbols
subRule: interpolated_regular_string_part
- name: namespace_declaration
lang: csharp
context: package
recursive: true
capture: allSymbols
- name: statement_list
lang: csharp
context: method_invoke
recursive: true
capture: literalsOnly
- name: constant_declaration
lang: csharp
context: var_assign
recursive: true
capture: literalsOnly
- name: method_declaration
lang: csharp
context: method_decl
recursive: true
capture: allSymbols
subRule: identifier
- name: method_body
lang: csharp
context: method_decl
recursive: false
capture: literalsOnly
#- name: method_member_name
# lang: csharp
# context: method_decl
# recursive: true
# capture: allSymbols
- name: local_variable_initializer
lang: csharp
context: var_assign
recursive: true
capture: literalsOnly
- name: returnStatement
lang: csharp
context: var_assign
recursive: true
capture: literalsOnly
- name: class_definition
lang: csharp
context: class
recursive: false
capture: allSymbols
subRule: identifier
- name: attribute_argument
lang: csharp
context: annotation_invoke
recursive: true
capture: literalsOnly
pythonAST
Configure the CPython AST scanner to scan Python source code for symbol values.
Below is the default configuration from: pythonAST/default.yaml.
# 🔟❎ 'compile' python symbol scanner settings
# The Python AST symbol scanner leverages the Python native .py parsing engine.
# to launch the 'astpretty' script from https://github.com/asottile/astpretty
# to parse the contents of an input .py file.
# If a python runtime is unavailable when executing the 'compile' pipeline,
# the 'pythonASTPath' value can be set to null or empty string to default
# to the ANTLR symbol scanner defined in 'python.yaml'
# 'pythonPath' specifies the command for launching a Python run-time.
# A test script verifies a Python run-time is available. If the test script is unsuccessful,
# the scanner is disabled.
pythonPath: python3
archive
Configure the Archive scanner to scan compressed archives for enclosed files containing symbol values.
Below is the default configuration from: archive/default.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYXJjaGl2ZUV4dGVuc2lvbnMiIDogewogICAgICAidHlwZSIgOiBbICJhcnJheSIsICJudWxsIiBdLAogICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiU3VwcG9ydGVkIGFyY2hpdmUgZXh0ZW5zaW9uc1xuXG5EZWZpbmVzIHRoZSBmaWxlIGV4dGVuc2lvbnMgb2YgYXJjaGl2ZSB6aXAgZmlsZXMgdG8gc2NhbiBmb3Igc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlcy4gKERlZmF1bHQ6IFtcIi56aXBcIixcIi5qYXJcIixcIi53YXJcIixcIi5lYXJcIixcIi43c1wiLFwiLmd6XCIsXCIuYnJcIixcIi5sejRcIixcIi5sem1hXCIsXCIudGFyXCIsXCIudGFyLmJyXCIsXCIudGFyLmd6XCIsXCIudGFyLmJ6MlwiLFwiLnRhci5sejRcIixcIi50YXIubHptYVwiXSkiLAogICAgICAiaXRlbXMiIDogewogICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgIH0sCiAgICAgICJkZWZhdWx0IiA6IFsgIi56aXAiLCAiLmphciIsICIud2FyIiwgIi5lYXIiLCAiLjdzIiwgIi5neiIsICIuYnIiLCAiLmx6NCIsICIubHptYSIsICIudGFyIiwgIi50YXIuYnIiLCAiLnRhci5neiIsICIudGFyLmJ6MiIsICIudGFyLmx6NCIsICIudGFyLmx6bWEiIF0KICAgIH0KICB9LAogICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZQp9
# 🔟❎ 'compile' archive symbol scanner config
# The archive'scanner iterates through the contents of file archives
# to seek source/binary files whose contents to scan into
# the output symbol files.
# Set the 10x pipeline to 'compile'
tenx: compile
archiveExtensions:
- .zip
- .jar
- .war
- .ear
- .7s
- .gz
- .br
- .lz4
- .lzma
- .tar
- .tar.br
- .tar.gz
- .tar.bz2
- .tar.lz4
- .tar.lzma
logMethods
Configure the Log method/stream definitions to define logger method and output stream names.
Below is the default configuration from: logMethods/default.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAibG9nIiA6IHsKICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZSwKICAgICAgInByb3BlcnRpZXMiIDogewogICAgICAgICJtZXRob2RzIiA6IHsKICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgImFycmF5IiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIk5hbWVzIG9mIHNvdXJjZSBjb2RlIG1ldGhvZHMgdG8gbWFyayBhcyAnbG9nZ2luZydcblxuTGlzdHMgJ2xvZ2dpbmcnIG1ldGhvZCBuYW1lcyB3aG9zZSBpbnZvY2F0aW9ucyB0byBtYXJrICdsb2dnaW5nJy4gTG9nZ2luZyBmcmFtZXdvcmtzIGNvbW1vbmx5IGRlZmluZSBzdGFuZGFyZCBtZXRob2RzIHRvIGVtaXQgZXZlbnQgaW5mb3JtYXRpb24gdG8gcHJvZ3JhbSBvdXRwdXQgKGUuZy4sICd3YXJuJywgJ2Vycm9yJykuIiwKICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICJ0eXBlIiA6ICJzdHJpbmciCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAibWV0aG9kUmVnZXgiIDogewogICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAic3RyaW5nIiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkEgcGF0dGVybiB0aGF0IHNvdXJjZSBjb2RlIG1ldGhvZHMgbmFtZXMgbXVzdCBtYXRjaCB0byBxdWFsaWZ5IGFzICdsb2dnaW5nJyBtZXRob2RzXG5cblNwZWNpZmllcyBhIHBhdHRlcm4gZm9yIHN5bWJvbCBzY2FubmVycyB0byBhcHBseSB0byBzb3VyY2UgY29kZSBtZXRob2QvZnVuY3Rpb24gbmFtZXMgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgdG8gbWFyayB0aGVtIGFzICdsb2dnaW5nJy4gRm9yIGV4YW1wbGU6IF4obG9nfExvZyl8KExvZ3xsb2cpJCIKICAgICAgICB9LAogICAgICAgICJzdHJlYW1zIiA6IHsKICAgICAgICAgICJ0eXBlIiA6IFsKICAgICAgICAgICAgImFycmF5IiwKICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICBdLAogICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIk5hbWVzIG9mIHNvdXJjZSBjb2RlIHZhcmlhYmxlcyB0byBtYXJrIGFzICdsb2dnaW5nJ1xuXG5MaXN0cyAnbG9nZ2luZycgbWVtYmVyIG5hbWVzIHdob3NlIGFzc2lnbm1lbnRzIHRvIG1hcmsgJ2xvZ2dpbmcnLiBQcm9ncmFtbWluZyBsYW5ndWFnZXMgY29tbW9ubHkgZGVmaW5lIHN0YW5kYXJkIG1lbWJlcnMgdG8gZW1pdCBldmVudHMgdG8gb3V0cHV0IChlLmcuLCAnb3V0JywgJ2NlcnInKS4iLAogICAgICAgICAgIml0ZW1zIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogInN0cmluZyIKICAgICAgICAgIH0KICAgICAgICB9CiAgICAgIH0KICAgIH0KICB9LAogICJhZGRpdGlvbmFsUHJvcGVydGllcyIgOiBmYWxzZQp9
# 🔟❎ 'compile' log methods configuration
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================ Log Options =============================
log:
# 'methods' lists known method names collected from common logging
# frameworks used to indicate source code logging events to stream at runtime.
# Identifying those points in source code that perform logging operations
# and marking them within an output symbol unit file (*.json)
# allows the 'run' pipeline to correlate each TenXObject structured from the event
# data back to its origin in the codebase.
# To learn more about symbol contexts and their use, see https://doc.log10x.com/run/transform/symbol/#contexts
methods:
# Assertions are not enabled by default as they are less likely to appear in prod logs
# - Assert
# - assert
# - assertEquals
# - assertEqual
- exception
- Log
- LOG
- log
- BOOST_LOG_TRIVIAL
- trace
- Trace
- log_trace
- logTrace
- TRACE
- LOG_TRACE
- debug
- Debug
- logDebug
- log_debug
- DEBUG
- LOG_DEBUG
- Debugf
- info
- Info
- log_info
- logInfo
- INFO
- LOG_INFO
- information
- LogInformation
- InfoF
- warn
- Warn
- log_warn
- logWarn
- WARN
- LOG_WARN
- WarnF
- warning
- logWarning
- LOG_WARNING
- error
- Error
- logError
- log_error
- ERROR
- LOG_ERROR
- ErrorF
- err
- fatal
- Fatal
- log_fatal
- logFatal
- FATAL
- LOG_FATAL
- FatalF
- critical
- Panic
# 'methodRegex' specifies an optional regex that will be applied
# to a scanned source code method/function name. If matched, the method
# will be considered to be a 'logging method' (see above).
# For example: ^(log|Log)|(Log|log)$
methodRegex: null
# 'streams' defines which source code variables within
# this ANTLR syntax are treated as output streams (e.g. stdout, stderr, cerr).
# Literal constants (e.g. "error connecting to {}") passed to a variable
# listed below (e.g. 'cout') will be assigned a 'logger_method_invoke'
# symbol source context.
streams:
# - assert
- cout
- cerr
- Error
- Debug
- err
- out
- Console
Go
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/go.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' Go ANTLR symbol scanner configuration
# The 'go' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from GO source files.
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR-generated parser class used to
# to tokenize and construct an AST for the target go file.
lang: go
fileExt:
- .go
parserClass: com.log10x.antlr.generated.golang.GoParser
lexerClass: com.log10x.antlr.generated.golang.GoLexer
rootRule: sourceFile
reserved:
- package
- func
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# The 'rule' list defines the nodes within a go AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: constSpec
lang: go
context: enum
recursive: false
capture: allSymbols
subRule: identifierList
- name: returnStmt
lang: go
context: var_assign
recursive: true
capture: literalsOnly
- name: assignment
lang: go
context: var_assign
recursive: true
capture: literalsOnly
- name: expressionStmt
lang: go
context: method_invoke
recursive: true
capture: literalsOnly
- name: packageClause
lang: go
context: package
recursive: false
capture: allSymbols
- name: arguments
lang: go
context: method_invoke
recursive: true
capture: literalsOnly
- name: typeSpec
lang: go
context: class
recursive: false
capture: allSymbols
- name: functionDecl
lang: go
context: method_decl
recursive: false
capture: allSymbols
- name: methodDecl
lang: go
context: method_decl
recursive: false
capture: allSymbols
Jackson
Configure Text file scanners to scan text/binary files for symbol values using the Jackson library.
Below is the default configuration from: text/jackson.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAidGV4dCIgOiB7CiAgICAgICJ0eXBlIiA6ICJhcnJheSIsCiAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgInR5cGUiIDogIm9iamVjdCIsCiAgICAgICAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlLAogICAgICAgICJwcm9wZXJ0aWVzIiA6IHsKICAgICAgICAgICJwYXJzZXJOYW1lIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUGFyc2VyIGxvZ2ljYWwgbmFtZVxuXG5EZWZpbmVzIGEgbG9naWNhbCB1bmlxdWUgbmFtZSBmb3IgdGhpcyBwYXJzZXIgKGUuZy4sICdsb2dzJykiCiAgICAgICAgICB9LAogICAgICAgICAgImZpbGVOYW1lRmlsdGVyIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJzdHJpbmciLAogICAgICAgICAgICAgICJudWxsIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiUGF0dGVybiB0byBtYXRjaCBmb3IgdGFyZ2V0IGlucHV0IGZpbGUgbmFtZVxuXG5EZWZpbmVzIGEgcmVnZXggcGF0dGVybiBhIGZpbGUgbXVzdCBtYXRjaCBhZ2FpbnN0IGZvciB0aGlzIHNjYW5uZXIgdG8gYXBwbHkgdG8gaXQuIgogICAgICAgICAgfSwKICAgICAgICAgICJwYXJzZXJGYWN0b3J5Q2xhc3MiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgInN0cmluZyIsCiAgICAgICAgICAgICAgIm51bGwiCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJQYXJzZXIgZmFjdG9yeSBjbGFzc1xuXG5Qcm92aWRlcyBhbiBvcHRpb25hbCBmdWxseSBxdWFsaWZpZWQgbmFtZSBvZiBhIGNsYXNzIG5hbWUgZGVyaXZlZCBmcm9tIGEgW0pzb25GYWN0b3J5XShodHRwczovL2Zhc3RlcnhtbC5naXRodWIuaW8vamFja3Nvbi1jb3JlL2phdmFkb2MvMi42L2NvbS9mYXN0ZXJ4bWwvamFja3Nvbi9jb3JlL0pzb25GYWN0b3J5Lmh0bWwpLiAgSWYgc3BlY2lmaWVkLCB0aGUgc2Nhbm5lciBpbnN0YW50aWF0ZXMgdGhlIGZhY3RvcnkgdXNpbmcgYSBwYXJhbWV0ZXJsZXNzIGNvbnN0cnVjdG9yICBhbmQgaW52b2tlcyBpdHMgW2NyZWF0ZVBhcnNlcl0oaHR0cHM6Ly9mYXN0ZXJ4bWwuZ2l0aHViLmlvL2phY2tzb24tY29yZS9qYXZhZG9jLzIuNi9jb20vZmFzdGVyeG1sL2phY2tzb24vY29yZS9Kc29uRmFjdG9yeS5odG1sI2NyZWF0ZVBhcnNlcihqYXZhLmlvLklucHV0U3RyZWFtKSkgbWV0aG9kIHRvIGdlbmVyYXRlIGEgcGFyc2VyIGluc3RhbmNlLiBUaGUgc2Nhbm5lciB1c2VzIHRoZSBwYXJzZXIgdG8gcmVhZCB0b2tlbiB2YWx1ZXMgZnJvbSB0aGUgZmlsZS4gIGlmICd0ZXh0UGFyc2VyRmFjdG9yeUFyZ3MnIGlzIHNwZWNpZmllZCwgYSBjb25zdHJ1Y3RvciByZWNlaXZpbmcgYSBzdHJpbmdbXSBtdXN0ICBiZSBkZWZpbmVkIGJ5IHRoaXMgY2xhc3MgdG8gcmVjZWl2ZSBvcHRpb25hbCBjb25maWcgcGFyYW1ldGVycyIKICAgICAgICAgIH0sCiAgICAgICAgICAicGFyc2VyRmFjdG9yeUFyZ3MiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgImFycmF5IiwKICAgICAgICAgICAgICAibnVsbCIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIkFyZ3VtZW50cyBmb3IgJ3RleHRQYXJzZXJGYWN0b3J5JyBjdG9yXG5cblNwZWNpZmllcyBhcmd1bWVudHMgdG8gcGFzcyB0byB0aGUgcGFyc2VyIGZhY3RvcnkgaW5zdGFuY2UgY29uc3RydWN0b3IuIFRoaXMgb3B0aW9uIG9ubHkgYXBwbGllcyBpZiAndGV4dFBhcnNlckZhY3RvcnlDbGFzcycgaXMgc2V0LiIsCiAgICAgICAgICAgICJpdGVtcyIgOiB7CiAgICAgICAgICAgICAgInR5cGUiIDogInN0cmluZyIKICAgICAgICAgICAgfQogICAgICAgICAgfSwKICAgICAgICAgICJzY2FuRmllbGRWYWx1ZXMiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgImJvb2xlYW4iLAogICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJDb250cm9scyB3aGV0aGVyIHRvIGNhcHR1cmUgSmFja3NvbiBwYXJzZXIgZmllbGQgdmFsdWVzXG5cbkNvbnRyb2xzIHdoZXRoZXIgdG8gY2FwdHVyZSBhIEphY2tzb24gcGFyc2VyJ3MgW1ZBTFVFX1NUUklOR10oaHR0cHM6Ly9mYXN0ZXJ4bWwuZ2l0aHViLmlvL2phY2tzb24tY29yZS9qYXZhZG9jLzIuOC9jb20vZmFzdGVyeG1sL2phY2tzb24vY29yZS9Kc29uVG9rZW4uaHRtbCNWQUxVRV9TVFJJTkcpIHRva2VucyBhcmUgc2Nhbm5lZCBmb3IgZW50cmllcyBvciBqdXN0IHZhbHVlcyBvZiBbRklFTERfTkFNRV0oaHR0cHM6Ly9mYXN0ZXJ4bWwuZ2l0aHViLmlvL2phY2tzb24tY29yZS9qYXZhZG9jLzIuOC9jb20vZmFzdGVyeG1sL2phY2tzb24vY29yZS9Kc29uVG9rZW4uaHRtbCNGSUVMRF9OQU1FKSB0b2tlbnMuICAgIFRoaXMgb3B0aW9uIG9ubHkgYXBwbGllcyBpZiAndGV4dFBhcnNlckZhY3RvcnlDbGFzcycgaXMgc2V0LiAoQWNjZXB0cyBib29sZWFuIG9yIHN0cmluZyB3aXRoICQ9IHByZWZpeCBmb3IgcnVudGltZSBldmFsdWF0aW9uKSIKICAgICAgICAgIH0sCiAgICAgICAgICAibWF4TGluZXMiIDogewogICAgICAgICAgICAidHlwZSIgOiBbCiAgICAgICAgICAgICAgIm51bWJlciIsCiAgICAgICAgICAgICAgInN0cmluZyIKICAgICAgICAgICAgXSwKICAgICAgICAgICAgIm1hcmtkb3duRGVzY3JpcHRpb24iIDogIk1heCBudW1iZXIgb2YgbGluZXMgdG8gc2NhblxuXG5Db250cm9scyB0aGUgbWF4aW11bSBudW1iZXIgb2YgbGluZXMgdG8gc2NhbiBmb3Igc3ltYm9sIHZhbHVlcyBmcm9tIHRoZSBpbnB1dCBmaWxlLiBUaGlzIG9wdGlvbiBpcyB1c2VmdWwgd2hlbiBzY2FubmluZyBleGlzdGluZyBsb2cgZmlsZXMgYXMgJ3RlbXBsYXRlcycgZm9yIHBhcnNpbmcgZnV0dXJlIGxvZ3MgZnJvbSBhIHNpbWlsYXIgaW5wdXQgc3RyZWFtLiAoQWNjZXB0cyBudW1iZXIgb3Igc3RyaW5nIHdpdGggJD0gcHJlZml4IGZvciBydW50aW1lIGV2YWx1YXRpb24pIgogICAgICAgICAgfSwKICAgICAgICAgICJsaW5lT2Zmc2V0IiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJudW1iZXIiLAogICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJMaW5lIG51bWJlciBmcm9tIHdoaWNoIHRvIHN0YXJ0IHNjYW5cblxuU3BlY2lmaWVzIHRoZSBsaW5lIG51bWJlciBmcm9tIHdoaWNoIHRvIHN0YXJ0IHNjYW5uaW5nIGZvciBzeW1ib2xzLiBUaGlzIG9wdGlvbiBpcyB1c2VmdWwgd2hlbiBzY2FubmluZyBhIHNwZWNpZmljIHBvcnRpb24gb2YgYSB0ZXh0IGZpbGUuIChBY2NlcHRzIG51bWJlciBvciBzdHJpbmcgd2l0aCAkPSBwcmVmaXggZm9yIHJ1bnRpbWUgZXZhbHVhdGlvbikiCiAgICAgICAgICB9LAogICAgICAgICAgImFsbG93RGlnaXRzIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJib29sZWFuIiwKICAgICAgICAgICAgICAic3RyaW5nIgogICAgICAgICAgICBdLAogICAgICAgICAgICAibWFya2Rvd25EZXNjcmlwdGlvbiIgOiAiQ29udHJvbHMgd2hldGhlciB0byBjYXB0dXJlIHRva2VucyBjb250YWluaW5nIG51bWVyaWMgYXMgc3ltYm9sIHRva2Vuc1xuXG5Db250cm9scyB3aGV0aGVyIHRva2VucyBjb250YWluIG51bWVyaWMgY2hhcnMgKGUuZy4sIDAtOSkgYXJlIGFjY2VwdGVkIGFzIHN5bWJvbCB0b2tlbnMuIEFzIGFscGhhbnVtZXJpYyBjb21iaW5hdGlvbnMgdGVuZCB0byBoYXZlIGhpZ2ggY2FyZGluYWxpdHkgKGUuZy4sIEdVSUQsIHRyYWNlX2lkKSwgaXQgaXMgbm90IGdlbmVyYWxseSBhZHZpc2VkICB0byBhZGQgdGhlbSB0byBzeW1ib2wgdW5pdHMgdW5sZXNzIHNwZWNpZmljYWxseSBrbm93biB0byBiZSAnY29uc3RhbnQnIC8gbG93IGNhcmRpbmFsaXR5IHZhbHVlcyAoQWNjZXB0cyBib29sZWFuIG9yIHN0cmluZyB3aXRoICQ9IHByZWZpeCBmb3IgcnVudGltZSBldmFsdWF0aW9uKSIKICAgICAgICAgIH0sCiAgICAgICAgICAibWluTGVuZ3RoIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJudW1iZXIiLAogICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJNaW4gY2hhcmFjdGVyIGxlbmd0aCBmb3IgYSB0b2tlbiB0byBiZSBjb25zaWRlcmVkIGEgc3ltYm9sIHZhbHVlXG5cblNldHMgdGhlIG1pbmltYWwgY2hhcmFjdGVyIGxlbmd0aCBhIHRva2VuIG11c3QgaGF2ZSB0byBjb25zdGl0dXRlIGEgc3ltYm9sIHZhbHVlLiBWZXJ5IHNob3J0IHRva2VucyAoZS5nLiwgbGVuIDwgMykgaGF2ZSBhIGhpZ2ggcHJvYmFiaWxpdHkgb2YgYmVpbmcgZHluYW1pYyB2YWx1ZXMgd2l0aCBoaWdoIGNhcmRpbmFsaXR5IGFuZCwgYXMgc3VjaCwgc2hvdWxkIG5vdCAgYmUgY2FwdHVyZWQgYXMgc3ltYm9sIHZhbHVlcy4gKEFjY2VwdHMgbnVtYmVyIG9yIHN0cmluZyB3aXRoICQ9IHByZWZpeCBmb3IgcnVudGltZSBldmFsdWF0aW9uKSIKICAgICAgICAgIH0sCiAgICAgICAgICAibWF4TGVuZ3RoIiA6IHsKICAgICAgICAgICAgInR5cGUiIDogWwogICAgICAgICAgICAgICJudW1iZXIiLAogICAgICAgICAgICAgICJzdHJpbmciCiAgICAgICAgICAgIF0sCiAgICAgICAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJNYXggY2hhcmFjdGVyIGxlbmd0aCBmb3IgYSB0b2tlbiB0byBiZSBjb25zaWRlcmVkIGEgc3ltYm9sIHZhbHVlXG5cblNldHMgdGhlIG1heGltdW0gY2hhcmFjdGVyIGxlbmd0aCBhIHRva2VuIG11c3QgaGF2ZSB0byBjb25zdGl0dXRlIGEgc3ltYm9sIHZhbHVlLiBWZXJ5IGxvbmcgdG9rZW5zIChlLmcuLCBsZW4gPiAxMDApIGhhdmUgYSBoaWdoIHByb2JhYmlsaXR5IG9mIGJlaW5nIGR5bmFtaWMgdmFsdWVzIHdpdGggaGlnaCBjYXJkaW5hbGl0eSBhbmQsIGFzIHN1Y2gsIHNob3VsZCBub3QgIGJlIGNhcHR1cmVkIGFzIHN5bWJvbCB2YWx1ZXMuIChBY2NlcHRzIG51bWJlciBvciBzdHJpbmcgd2l0aCAkPSBwcmVmaXggZm9yIHJ1bnRpbWUgZXZhbHVhdGlvbikiCiAgICAgICAgICB9CiAgICAgICAgfSwKICAgICAgICAicmVxdWlyZWQiIDogWwogICAgICAgICAgInBhcnNlck5hbWUiLAogICAgICAgICAgImZpbGVOYW1lRmlsdGVyIgogICAgICAgIF0KICAgICAgfQogICAgfQogIH0sCiAgImFkZGl0aW9uYWxQcm9wZXJ0aWVzIiA6IGZhbHNlCn0=
# 🔟❎ 'compile' text symbol scanner configuration
# The 'text' scanner parses text files for symbol values. It utilizes
# the Jackson parser library to parse any text/binary format it supports.
# This includes formats such json, yaml, xml, ini, protobuf and more.
# The configuration below is added by default to the 10x 'compile' pipeline.
# Even so, if another text scanner is defined via the 'textScanners' options group
# whose 'fileNameFilter' matches that of the current target input file,
# it will take precedence over the text scanners defined below.
# To learn more about text scanner options below, see:
# https://doc.log10x.com/compile/scanner/text
# Set the 10x pipeline to 'compile'
tenx: compile
# =============================== Text Options ================================
text:
- parserName: text
fileNameFilter: '^.*\.(csv|txt|properties|csv|tsv|ini|conf|sh|log|out)$'
maxLines: 500
lineOffset: 0
allowDigits: false
minLength: 2
maxLength: 50
- parserName: json
fileNameFilter: '^.*\.(json)$'
parserFactoryClass: com.fasterxml.jackson.core.JsonFactory
scanFieldValues: true
- parserName: yaml
fileNameFilter: '^.*\.(yml|yaml)$'
parserFactoryClass: com.log10x.eng.scanner.text.TextYamlFactory
scanFieldValues: true
- parserName: xml
fileNameFilter: '^.*\.(xml|xsd)$'
parserFactoryClass: com.fasterxml.jackson.dataformat.xml.XmlFactory
scanFieldValues: true
Java
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/java.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' Java ANTLR symbol scanner configuration
# The 'java' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from Java source files.
# IMPORTANT: while set to enabled by default, the dedicated java scanner utilizes
# takes precedence over this scanner unless disabled.
# To learn more see https://doc.log10x.com/compile/scanner/javaParser
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR-generated parser class used to
# to tokenize and construct an AST for the target Java file.
lang: java
fileExt:
- .java
parserClass: com.log10x.antlr.generated.java.Java9Parser
lexerClass: com.log10x.antlr.generated.java.Java9Lexer
rootRule: compilationUnit
reserved:
- package
- interface
- class
- enum
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# The 'rule' list defines the nodes within a Java AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: packageDeclaration
lang: java
context: package
recursive: false
capture: allSymbols
- name: methodInvocation
lang: java
context: method_invoke
recursive: true
capture: literalsOnly
- name: enumDeclaration
lang: java
context: class
recursive: false
capture: allSymbols
- name: annotation
lang: java
context: annotation_invoke
recursive: true
capture: literalsOnly
- name: normalClassDeclaration
lang: java
context: class
recursive: false
capture: allSymbols
- name: variableInitializer
lang: java
context: var_assign
recursive: true
capture: literalsOnly
- name: enumConstant
lang: java
context: enum
recursive: false
capture: allSymbols
- name: returnStatement
lang: java
context: var_assign
recursive: true
capture: literalsOnly
- name: methodDeclaration
lang: java
context: method_decl
recursive: false
capture: literalsOnly
- name: argumentList
lang: java
context: method_invoke
recursive: true
capture: literalsOnly
- name: methodInvocation_lfno_primary
lang: java
context: method_invoke
recursive: true
capture: literalsOnly
- name: methodDeclarator
lang: java
context: method_decl
recursive: false
capture: allSymbols
- name: methodInvocation_lf_primary
lang: java
context: method_invoke
recursive: true
capture: literalsOnly
- name: normalInterfaceDeclaration
lang: java
context: class
recursive: false
capture: allSymbols
Javascript
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/javascript.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' JavaScript ANTLR symbol scanner configuration
# The 'javascript' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from JavaScript source files.
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR-generated parser class used to
# to tokenize and construct an AST for the target JavaScript file.
lang: javascript
fileExt:
- .js
parserClass: com.log10x.antlr.parsers.JavaScriptDecoratedParser
lexerClass: com.log10x.antlr.generated.javascript.JavaScriptLexer
rootRule: program2
reserved:
- function
- constructor
- class
maxLineLength: 4096
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# The 'rule' list defines the nodes within a js AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: functionDeclaration
lang: javascript
context: method_decl
recursive: false
capture: allSymbols
subRule: identifier
- name: returnStatement
lang: javascript
context: var_assign
recursive: true
capture: literalsOnly
- name: classDeclaration
lang: javascript
context: class
recursive: false
capture: allSymbols
subRule: identifier
- name: methodDefinition
lang: javascript
context: method_decl
recursive: true
capture: allSymbols
subRule: identifier
- name: formalParameterList
lang: javascript
context: method_decl
recursive: false
capture: literalsOnly
- name: functionBody
lang: javascript
context: method_invoke
recursive: false
capture: literalsOnly
- name: functionDecl
lang: javascript
context: method_decl
recursive: false
capture: allSymbols
- name: anoymousFunctionDecl
lang: javascript
context: method_decl
recursive: false
capture: allSymbols
- name: argumentsExpression
lang: javascript
context: method_invoke
recursive: true
capture: literalsOnly
- name: variableDeclaration
lang: javascript
context: var_assign
recursive: true
capture: literalsOnly
- name: assignmentExpression
lang: javascript
context: var_assign
recursive: true
capture: literalsOnly
Python
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/python.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' Python symbol scanner configuration
# The 'python' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from Python source files.
# NOTE: while set to enabled by default, the 'pythonAST' scanner which utilizes
# the python run-time's built-in AST parser takes precedence over this scanner
# unless a python run-time is not installed or the 'pythonAST' scanner is disabled.
# To learn see https://doc.log10x.com/compile/scanner/pythonAST
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR-generated parser class used to
# to tokenize and construct an AST for the target Python file.
lang: python
fileExt:
- .py
parserClass: com.log10x.antlr.generated.python.PythonParser
lexerClass: com.log10x.antlr.generated.python.PythonLexer
rootRule: root
reserved:
- def
- __str__
- __init__
- class
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# The 'rule' list defines the nodes within a Python AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: classdef
lang: python
context: class
recursive: false
capture: allSymbols
subRule: name
condition: (^Enum$|^enum$)
tag: enumLiteral
- name: testlist_star_expr
lang: python
context: enum
recursive: true
capture: allSymbolsIfMatchCond
ifTag: enumLiteral
- name: trailer
lang: python
context: method_invoke
recursive: true
capture: literalsOnly
subRule: name
- name: return_stmt
lang: python
context: var_assign
recursive: true
capture: literalsOnly
- name: decorator
lang: python
context: annotation_invoke
recursive: true
capture: literalsOnly
subRule: arglist
- name: arglist
lang: python
context: method_invoke
recursive: true
capture: literalsOnly
- name: funcdef
lang: python
context: method_decl
recursive: false
capture: allSymbols
subRule: name
- name: assign_part
lang: python
context: var_assign
recursive: true
capture: literalsOnly
- name: dictorsetmaker
lang: python
context: var_assign
recursive: true
capture: literalsOnly
Scala
Configure the ANTLR scanner to extract symbols from any programming language using the ANTLR framework.
Below is the default configuration from: antlr/scala.yaml.
ewogICJ0eXBlIiA6ICJvYmplY3QiLAogICJwcm9wZXJ0aWVzIiA6IHsKICAgICJ0ZW54IiA6IHsKICAgICAgInR5cGUiIDogInN0cmluZyIKICAgIH0sCiAgICAiYW50bHJQYXJzZVVuaXRUaW1lb3V0IiA6IHsKICAgICAgInR5cGUiIDogWyAic3RyaW5nIiwgIm51bGwiIF0sCiAgICAgICJtYXJrZG93bkRlc2NyaXB0aW9uIiA6ICJTb3VyY2UgZmlsZSBwYXJzZSB0aW1lb3V0XG5cbkRlZmluZXMgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgZm9yIHBhcnNpbmcgYW5kIHNjYW5uaW5nIGEgc291cmNlL2JpbmFyeSBpbnB1dCBmaWxlIGJlZm9yZSBhYm9ydGluZy4gZGVmYXVsdCB2YWx1ZTogNjBzZWMiCiAgICB9CiAgfSwKICAiYWRkaXRpb25hbFByb3BlcnRpZXMiIDogZmFsc2UKfQ==
# 🔟❎ 'compile' Scala symbol scanner configuration
# The 'scala' configuration instructs the ANTLR scanner which symbol values (e.g. class/func names, code constants)
# to extract from Scala source files.
# IMPORTANT: while set to enabled by default, the dedicated scala scanner utilizes
# takes precedence over this scanner unless disabled.
# To learn more see https://doc.log10x.com/compile/scanner/scalameta
# Set the 10x pipeline to 'compile'
tenx: compile
# ============================== ANTLR Options ================================
antlr:
# The 'antlrLang' module is defined in: https://doc.log10x.com/compile/scanner/antlr/langs
# These values define the ANTLR grammar .g4 file used to
# to tokenize and construct an AST for the target .Scala file.
lang: scala
fileExt:
- .scala
- .sc
grammarFile: grammar/scala.g4
rootRule: compilationUnit
reserved:
- interface
- class
- enum
- this
# 'lineFilters' specifies a list of regex patterns for skipping input lines
lineFilters:
- ^\s*(//.*|/\*.*\*/)$
# The 'rule' list defines the nodes within a scala AST tree that are captured
# and added to the output symbol unit.
# To learn more see: https://doc.log10x.com/compile/scanner/antlr/rules/
rule:
- name: classParamClauses
lang: scala
context: class
recursive: false
capture: literalsOnly
- name: patVarDef
lang: scala
context: var_assign
recursive: true
capture: literalsOnly
- name: argumentExprs
lang: scala
context: method_invoke
recursive: true
capture: literalsOnly
- name: annotation
lang: scala
context: annotation_invoke
recursive: true
capture: literalsOnly
- name: objectDef
lang: scala
context: class
recursive: true
capture: allSymbols
- name: paramClauses
lang: scala
context: class
recursive: false
capture: literalsOnly
- name: classTemplateOpt
lang: scala
context: class
recursive: false
capture: literalsOnly
- name: funDcl
lang: scala
context: method_decl
recursive: false
capture: allSymbols
- name: classDef
lang: scala
context: class
recursive: true
capture: allSymbols
- name: qualId
lang: scala
context: package
recursive: true
capture: allSymbols
- name: traitDef
lang: scala
context: class
recursive: true
capture: allSymbols
- name: funDef
lang: scala
context: method_decl
recursive: true
capture: allSymbols
subRule: funSig
- name: type_
lang: scala
context: method_decl
recursive: false
capture: literalsOnly
- name: blockStat
lang: scala
context: var_assign
recursive: true
capture: literalsOnly
- name: templateStat
lang: scala
context: method_invoke
recursive: true
capture: literalsOnly
Strings-nix
Configure Executable scanners to launch a target process from which to read symbol values via its stdout.
Below is the default configuration from: executable/strings-nix.yaml.
{
  "type" : "object",
  "properties" : {
    "tenx" : {
      "type" : "string"
    },
    "exec" : {
      "type" : "array",
      "items" : {
        "type" : "object",
        "additionalProperties" : false,
        "properties" : {
          "name" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A logical name for this exec scanner\n\nA logical name for this exec scanner unique amongst all specified scanner option groups (e.g., 'stringsNIX')"
          },
          "osFilter" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A pattern that must match the name of the host OS to apply this scanner.\n\nDefines a pattern to match against the name of the host OS to determine whether to apply this scanner."
          },
          "extensions" : {
            "type" : [
              "array",
              "null"
            ],
            "markdownDescription" : "A list of file extensions a target file must match to apply this scanner\n\nAn array of file extensions to test a file candidate against. If the candidate matches any extensions, apply this scanner.",
            "items" : {
              "type" : "string"
            }
          },
          "fileNameFilter" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A pattern that the target input file must match to apply this scanner\n\nSets a regex pattern to test a file candidate name against. If the candidate matches any of the extensions, apply this scanner."
          },
          "selector" : {
            "type" : "object",
            "additionalProperties" : false,
            "properties" : {
              "process" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "Name of a process to launch whose output whether to apply this input\n\nDefine a process name to launch to obtain information about the input file. In some OSs (e.g., Linux/Unix), executable files do not necessarily have a known extension. For this, an OS utility such as NIX [file](https://man7.org/linux/man-pages/man1/file.1.html) can obtain information on the actual file contents.  If a selector process is not provided the file's ELF/PE/OSX binary header is tested for a possible match."
              },
              "workDir" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "The path of the working directory when running 'execSelectorProcess'\n\nDefines the working directory when running [execSelectorProcess](https://doc.log10x.com/compile/scanner/executable/#execselectorprocess). If omitted, will use the the working directory."
              },
              "args" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "List of arguments passed to 'execSelectorProcess'\n\nDefines arguments for the selector process, if provided. The `file` macro takes the value of the target exec file to launch.",
                "items" : {
                  "type" : "string"
                }
              },
              "timeout" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "Timeout period after which to terminate 'execSelectorProcess process\n\nSets how long to allow the selector process to run before termination (e.g. '10s')"
              },
              "outputFilter" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "A filter pattern that must match the output of 'execSelectorProcess' to apply this scanner\n\nDefines a regex pattern to match against the contents of the stdout stream read from the [execSelectorProcess](https://doc.log10x.com/compile/scanner/executable/#execselectorprocess) process. If matched, apply this scanner to the input file."
              }
            }
          },
          "process" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Process to launch for extracting symbol values\n\nDefines a process to launch and whose stdout pipe to parse for symbol values."
          },
          "workDir" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "The path of the working directory when running 'execProcess'\n\nDefines the working directory when running [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess). If omitted, uses the working directory."
          },
          "args" : {
            "type" : [
              "array",
              "null"
            ],
            "markdownDescription" : "List of arguments passed to 'execProcess' ('file' is replaced by scan target)\n\nDefines launch arguments [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess). The `file` macro expands into the input file path",
            "items" : {
              "type" : "string"
            }
          },
          "timeout" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Timeout period after which to terminate 'execProcess' process\n\nDefines how long [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess) is allowed to run before termination"
          },
          "symbol" : {
            "type" : "object",
            "additionalProperties" : false,
            "properties" : {
              "minLength" : {
                "type" : [
                  "number",
                  "string"
                ],
                "markdownDescription" : "Minimal length of the string read from 'execProcess' to read as a symbol\n\nSets the minimal length a string read from the scanner process stdout must be to be considered a symbol (Accepts number or string with $= prefix for runtime evaluation)"
              },
              "maxLength" : {
                "type" : [
                  "number",
                  "string"
                ],
                "markdownDescription" : "Max length the string read from 'execProcess' to read as a symbol\n\nSets the maximum length a string read from the scanner process stdout must be to be considered a symbol (Accepts number or string with $= prefix for runtime evaluation)"
              },
              "filters" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "Patterns a line read from 'execProcess' must NOT match\n\nDefines regex patterns applied to each line read from the scanner process' stdout that must NOT match for the line value to be captured as a symbol.   For example, to avoid [AWAV binary](https://stackoverflow.com/questions/39322552/meaning-of-a-common-string-in-executables) when using the `strings` OS utility, specify:  ``` yaml execSymbolFilters:   -  ^AWAV      ````",
                "items" : {
                  "type" : "string"
                }
              },
              "setSelectors" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "Regex patterns to determines whether to treat an input value as set of tokens\n\nDefines regex patterns must ALL matc to treat an input value as a line (e.g., 'error connecting to {}'), or as a series of independent tokens (e.g., 'error', 'connecting', 'to') to reduce the cardinality and size of the output symbol file.   For example, when processing files that contain values GO compile symbols such as:   ``` github.com/open-telemetry/opentelemetry-collector-contrib/exporter/fileexporter.group[go.shape.struct ```  Specify the pattern below to break the string into separate symbol tokens (e.g., shape, struct,..):   ``` yaml setSelectors:  - ^(?:github\\.com|golang\\.org|type:\\.eq\\.(?:github\\.com|golang\\.org))(/[a-zA-Z0-9_-]+)*$ - ^[a-zA-Z0-9_/:\\.\\[\\]\\*,-]*(?:\\.[a-zA-Z0-9]+|\\[[a-zA-Z0-9,\\.\\*/:_-]+\\]|-fm)?$ ```",
                "items" : {
                  "type" : "string"
                }
              }
            }
          },
          "isStructured" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Sets whether output lines read from 'execProcess' are read as plain text or structured JSON\n\nControls whether to read the [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess) stdout as plain text or as a JSON object containing source context information. If false (default), symbol values read from the process' output are marked as having an [exec](https://doc.log10x.com/run/transform/symbol/#exec) context. To learn more about producing structured symbol values, see [SymbolUnit.java](https://github.com/log-10x/pipeline-extensions/blob/main/cloud-extensions/src/main/java/com/log10x/ext/cloud/compile/symbol/SymbolUnit.java)"
          },
          "symbolsPrefix" : {
            "type" : [
              "boolean",
              "string"
            ],
            "markdownDescription" : "A prefix lines read from 'execProcess' must match to parse as structured JSON symbols\n\nSets a prefix that must precede lines read from the scan process' stdout to parse as structured JSON symbol trees. Only applies when [execIsStructured](https://doc.log10x.com/compile/scanner/executable/#execisstructured) is true (Accepts boolean or string with $= prefix for runtime evaluation)"
          }
        },
        "required" : [
          "name",
          "osFilter"
        ]
      }
    }
  },
  "additionalProperties" : false
}
# # 🔟❎ 'compile' executable 'strings' configuration
# This executable symbol scanner configuration uses OS-specific utilities to extract
# constant string values from pre-compiled binaries (e.g. programs, shared libraries).
# Any matching text values are added to the output symbol files.
# The following configuration is added by default to the 10x 'compile' pipeline.
# If another 'executable' scanner is defined whose 'osFilter' matches that of the
# current target input file, it will take precedence over the scanners defined below.
# To learn more about the 'executable' scanner,
# see: https://doc.log10x.com/compile/scanner/executable
# Set the 10x pipeline to 'compile'
tenx: compile
# =============================== Exec Options ================================
exec:
# This scanner uses the Linux built-in 'strings' (https://linux.die.net/man/1/file)
# command to extract symbol values from a target binary executable file
- name: stringsNIX
# This configuration targets NIX OSs
osFilter: (nix|nux|lux|mac)
# try for known extensions before invoking a 'selectorProcess'
extensions:
- .so
- .dynlib
# 'selector' processes provide a method for determining whether a file is an executable binary.
# If a selector process is not provided the file's ELF/PE/OSX binary header is tested.
# Since on NIX, executables do not have a known extension,
# the 'selector' process uses the built-in 'file' command whose
# output is used to verify the target file is a NIX executable file.
selector:
process: file
args:
- file # this macro value is replaced at run-time by the actual input file name
timeout: 5s
outputFilter: ".*?\\bexecutable\\b.*?" # select 'executable' files
process: strings
args:
- -a # scan the whole file, not just initialized and loaded sections
- file # This macro value is replaced at run-time by the actual text/binary input file
timeout: 100s
symbol:
# 'minLength' specifies the min number of chars a value extracted via strings must be to
# in order to qualify as a symbol.
minLength: 4
# 'maxLength' specifies the max number of chars a value extracted via strings must be to
# in order to qualify as a symbol.
maxLength: 1024
# 'filters' defines regex patterns applied to each line read from the scanner process' stdout
# that must NOT match for the line value to be considered a symbol.
filters:
- AWAV. # https://stackoverflow.com/questions/39322552/meaning-of-a-common-string-in-executables
- "^(?=^.{0,7}$)(?=.*[^a-zA-Z]).*$" # Matches any string that is shorter than 8 characters (0 to 7 chars) and contains at least one non-alphabetic character.
# 'setSelector' specifies regex patterns that determines whether to treat an input value as set of tokens
setSelectors:
- '^[0-9].*$' # Starts with digit
- '^\*.*$' # Starts with *
- '^(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,}(?:/[^\s]*)?$' # Domain + optional path (e.g., github.com/user/repo)
- '^type:\\..*$' # Go land metadata starts with "type:." (any suffix)
Strings-win
Configure Executable scanners to launch a target process from which to read symbol values via its stdout.
Below is the default configuration from: executable/strings-win.yaml.
{
  "type" : "object",
  "properties" : {
    "tenx" : {
      "type" : "string"
    },
    "exec" : {
      "type" : "array",
      "items" : {
        "type" : "object",
        "additionalProperties" : false,
        "properties" : {
          "name" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A logical name for this exec scanner\n\nA logical name for this exec scanner unique amongst all specified scanner option groups (e.g., 'stringsNIX')"
          },
          "osFilter" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A pattern that must match the name of the host OS to apply this scanner.\n\nDefines a pattern to match against the name of the host OS to determine whether to apply this scanner."
          },
          "extensions" : {
            "type" : [
              "array",
              "null"
            ],
            "markdownDescription" : "A list of file extensions a target file must match to apply this scanner\n\nAn array of file extensions to test a file candidate against. If the candidate matches any extensions, apply this scanner.",
            "items" : {
              "type" : "string"
            }
          },
          "fileNameFilter" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "A pattern that the target input file must match to apply this scanner\n\nSets a regex pattern to test a file candidate name against. If the candidate matches any of the extensions, apply this scanner."
          },
          "selector" : {
            "type" : "object",
            "additionalProperties" : false,
            "properties" : {
              "process" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "Name of a process to launch whose output whether to apply this input\n\nDefine a process name to launch to obtain information about the input file. In some OSs (e.g., Linux/Unix), executable files do not necessarily have a known extension. For this, an OS utility such as NIX [file](https://man7.org/linux/man-pages/man1/file.1.html) can obtain information on the actual file contents.  If a selector process is not provided the file's ELF/PE/OSX binary header is tested for a possible match."
              },
              "workDir" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "The path of the working directory when running 'execSelectorProcess'\n\nDefines the working directory when running [execSelectorProcess](https://doc.log10x.com/compile/scanner/executable/#execselectorprocess). If omitted, will use the the working directory."
              },
              "args" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "List of arguments passed to 'execSelectorProcess'\n\nDefines arguments for the selector process, if provided. The `file` macro takes the value of the target exec file to launch.",
                "items" : {
                  "type" : "string"
                }
              },
              "timeout" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "Timeout period after which to terminate 'execSelectorProcess process\n\nSets how long to allow the selector process to run before termination (e.g. '10s')"
              },
              "outputFilter" : {
                "type" : [
                  "string",
                  "null"
                ],
                "markdownDescription" : "A filter pattern that must match the output of 'execSelectorProcess' to apply this scanner\n\nDefines a regex pattern to match against the contents of the stdout stream read from the [execSelectorProcess](https://doc.log10x.com/compile/scanner/executable/#execselectorprocess) process. If matched, apply this scanner to the input file."
              }
            }
          },
          "process" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Process to launch for extracting symbol values\n\nDefines a process to launch and whose stdout pipe to parse for symbol values."
          },
          "workDir" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "The path of the working directory when running 'execProcess'\n\nDefines the working directory when running [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess). If omitted, uses the working directory."
          },
          "args" : {
            "type" : [
              "array",
              "null"
            ],
            "markdownDescription" : "List of arguments passed to 'execProcess' ('file' is replaced by scan target)\n\nDefines launch arguments [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess). The `file` macro expands into the input file path",
            "items" : {
              "type" : "string"
            }
          },
          "timeout" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Timeout period after which to terminate 'execProcess' process\n\nDefines how long [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess) is allowed to run before termination"
          },
          "symbol" : {
            "type" : "object",
            "additionalProperties" : false,
            "properties" : {
              "minLength" : {
                "type" : [
                  "number",
                  "string"
                ],
                "markdownDescription" : "Minimal length of the string read from 'execProcess' to read as a symbol\n\nSets the minimal length a string read from the scanner process stdout must be to be considered a symbol (Accepts number or string with $= prefix for runtime evaluation)"
              },
              "maxLength" : {
                "type" : [
                  "number",
                  "string"
                ],
                "markdownDescription" : "Max length the string read from 'execProcess' to read as a symbol\n\nSets the maximum length a string read from the scanner process stdout must be to be considered a symbol (Accepts number or string with $= prefix for runtime evaluation)"
              },
              "filters" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "Patterns a line read from 'execProcess' must NOT match\n\nDefines regex patterns applied to each line read from the scanner process' stdout that must NOT match for the line value to be captured as a symbol.   For example, to avoid [AWAV binary](https://stackoverflow.com/questions/39322552/meaning-of-a-common-string-in-executables) when using the `strings` OS utility, specify:  ``` yaml execSymbolFilters:   -  ^AWAV      ````",
                "items" : {
                  "type" : "string"
                }
              },
              "setSelectors" : {
                "type" : [
                  "array",
                  "null"
                ],
                "markdownDescription" : "Regex patterns to determines whether to treat an input value as set of tokens\n\nDefines regex patterns must ALL matc to treat an input value as a line (e.g., 'error connecting to {}'), or as a series of independent tokens (e.g., 'error', 'connecting', 'to') to reduce the cardinality and size of the output symbol file.   For example, when processing files that contain values GO compile symbols such as:   ``` github.com/open-telemetry/opentelemetry-collector-contrib/exporter/fileexporter.group[go.shape.struct ```  Specify the pattern below to break the string into separate symbol tokens (e.g., shape, struct,..):   ``` yaml setSelectors:  - ^(?:github\\.com|golang\\.org|type:\\.eq\\.(?:github\\.com|golang\\.org))(/[a-zA-Z0-9_-]+)*$ - ^[a-zA-Z0-9_/:\\.\\[\\]\\*,-]*(?:\\.[a-zA-Z0-9]+|\\[[a-zA-Z0-9,\\.\\*/:_-]+\\]|-fm)?$ ```",
                "items" : {
                  "type" : "string"
                }
              }
            }
          },
          "isStructured" : {
            "type" : [
              "string",
              "null"
            ],
            "markdownDescription" : "Sets whether output lines read from 'execProcess' are read as plain text or structured JSON\n\nControls whether to read the [execProcess](https://doc.log10x.com/compile/scanner/executable/#execprocess) stdout as plain text or as a JSON object containing source context information. If false (default), symbol values read from the process' output are marked as having an [exec](https://doc.log10x.com/run/transform/symbol/#exec) context. To learn more about producing structured symbol values, see [SymbolUnit.java](https://github.com/log-10x/pipeline-extensions/blob/main/cloud-extensions/src/main/java/com/log10x/ext/cloud/compile/symbol/SymbolUnit.java)"
          },
          "symbolsPrefix" : {
            "type" : [
              "boolean",
              "string"
            ],
            "markdownDescription" : "A prefix lines read from 'execProcess' must match to parse as structured JSON symbols\n\nSets a prefix that must precede lines read from the scan process' stdout to parse as structured JSON symbol trees. Only applies when [execIsStructured](https://doc.log10x.com/compile/scanner/executable/#execisstructured) is true (Accepts boolean or string with $= prefix for runtime evaluation)"
          }
        },
        "required" : [
          "name",
          "osFilter"
        ]
      }
    }
  },
  "additionalProperties" : false
}
# # 🔟❎ 'compile' executable 'strings' configuration
# This executable symbol scanner configuration uses OS-specific utilities to extract
# constant string values from pre-compiled binaries (e.g. programs, shared libraries).
# Any matching text values are added to the output symbol files.
# The following configuration is added by default to the 10x 'compile' pipeline.
# If another 'executable' scanner is defined whose 'osFilter' matches that of the
# current target input file, it will take precedence over the scanners defined below.
# To learn more about the 'executable' scanner,
# see: https://doc.log10x.com/compile/scanner/executable/
# Set the 10x pipeline to 'compile'
tenx: compile
# =============================== Exec Options ================================
exec:
# This configuration provides a similar capability for scanning Windows executable files.
# *IMPORTANT*: On Windows, the 'strings' command is not installed by default and
# should be downloaded from: https://docs.microsoft.com/en-us/sysinternals/downloads/strings
# and added to 'PATH'
- name: stringsWin
# target Win
osFilter: win
extensions:
- .so
- .dll
process: strings
args:
- file # This macro value is replaced at run-time by the actual input file name
timeout: 10s
This app is defined in compiler/app.yaml.