CxConfigProvider - checkmarx-ltd/cx-flow GitHub Wiki
CxConfigProvider
CxConfigProvider is a Configuration library used by CxFlow. It reads configurations in a JSON or YAML formats from .checkmarx
folder in the root of a Git repository.
Overview
- Implemented in plain Java
- Supports files in 2 formats: JSON and YAML.
- Can load files from
.checkmarx
folder in the root of a Git repository. - Support for nesting configurations
- Can resolve parameters inside the configuration
Special notes on YAML
github:
token: ${GITHUB_TOKEN}
configAsCode: cx.configuration
ast:
apiUrl: "http://this.is.just.an.example"
token: ${AST_TOKEN}
preset: true
incremental: false
Unlike normal YAML files, the configuration can have variables. The variables are resolved as follows:
- ${XXX} - will be resolved to the system environment variable with the name XXX. ex. ${AST_TOKEN}
- ${path.in.config} - will be resolved to the value inside the configuration. ex. ${ast.preset} is true
- \"TEST\" - TEST is a value that should not be resolved. ex. \"this is a normal text with special characters like $ and { \"
Special notes on JSON
{
"github": {
"token": ${GITHUB_TOKEN},
"configAsCode": "cx.configuration"
},
"ast": {
"apiUrl": "http://this.is.just.an.example",
"token": ${AST_TOKEN},
"preset": true,
"incremental": false
}
}
Unlike normal JSON files, the configuration is HOCON and can have variables. The variables are resolved; if the value is not quoted as follows:
- ${XXX} - will be resolved to the system environment variable with the name XXX. ex. ${AST_TOKEN}
- ${path.in.config} - will be resolved to the value inside the configuration. ex. ${ast.preset} is true
note: if the value is quoted, the variables will not be resolved. ex. "this is a normal text with special characters like $ and { "
For more information visit Cx-ConfigProvider