The configuration file describes your layers, ruleset and adjusts output formatting.
We suggest you also check out Deptrac's configuration for checking its own architecture as it uses most available options.
The following table shows the available config keys for Deptrac.
Property Path | Input description | Example usage |
---|---|---|
analyser.internal_tag |
Specifies a custom doc block tag which deptrac should use to identify layer-internal
class-like structures. The tag @deptrac-internal will always be used
for this purpose. This option allows an additional tag to be specified, such as
@layer-internal or plain @internal .
|
deptrac:
analyser:
internal_tag: "@layer-internal" |
analyser.types |
A list with at least one of the following supported dependency types:
|
deptrac:
analyser:
types:
- "use"
- "file"
- "class_superglobal"
- "function_superglobal"
- "function_call" |
paths |
List of paths where Deptrac should look for dependencies to be analysed.
Usually, this is where your code is stored, e.g. |
deptrac:
paths:
- src/ |
exclude_files |
A list of regular expression-patterns to determine which files or directories to exclude, e.g. test files or config |
deptrac:
exclude_files:
- '#.*Test\.php$#' |
formatters.graphviz.groups |
Key is the name of the group and values are the layers belonging to that group |
deptrac:
formatters:
graphviz:
groups:
Entrypoints:
- Controllers
- Commands
Persistence:
- Repositories
- Entities |
formatters.graphviz.hidden_layers |
List of layers to be excluded from the Graphviz output |
deptrac:
formatters:
graphviz:
hidden_layers:
- Controllers |
formatters.codeclimate.severity |
Assigns a severity to each section reported by Deptrac. The following severity types are supported by codeclimate:
|
deptrac:
formatters:
codeclimate:
severity:
failure: blocker
skipped: major
uncovered: major |
deptrac.ignore_uncovered_internal_classes |
Whether PHP-internal classes like |
deptrac:
ignore_uncovered_internal_classes: false # default: true |
deptrac.layers |
Defines your architectural layers by collecting dependencies using collectors |
deptrac:
layers:
-
name: Controller
collectors:
-
type: classLike
value: .*Controller.* |
deptrac.ruleset |
Assign communication rules by specifying which layers a layer can
communicate with (if any). If you prepend a layer with |
deptrac:
ruleset:
Controllers: [Services]
Services:
- Repositories
Repositories: ~ |
deptrac.skip_violations |
Define a dictionary of dependencies and their known violations. This violations will be ignored in your pipeline and not trigger a failing return code. |
deptrac:
skip_violations:
Library\LibClass:
- Core\CoreClass |
If your config file becomes too large, you can split it up into multiple files
that can then be imported in the main file using the imports
section.
This is also useful to separate your baseline from the rest of the
configuration, so it can be regenerated by the baseline
formatter.
Example:
imports:
- deptrac.baseline.yaml
Please see Symfony docs. This allows you to register new services, e.g. custom formatters or collectors.
services:
- class: Internal\Qossmic\Deptrac\IgnoreDependenciesOnContract
tags:
- { name: kernel.event_listener, event: Qossmic\Deptrac\Contract\Analyser\ProcessEvent }
Deptrac provides parameters that can be user in your configuration.
%currentWorkingDirectory%
The path Deptrac runs in%projectDirectory%
The path where the configuration is stored.%deptrac.cache_file%
contains the filename and path for the cache file. Note: This parameter is set by--cache-file=
and will be overwritten.
You can specify your own parameters and reuse them in your configuration:
Example:
parameters:
Project: MyProject
deptrac:
layers:
-
name: Foo
collectors:
-
type: implements
value: '%Project%\SomeInterface'