Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qossmic/deptrac
Keep your architecture clean.
https://github.com/qossmic/deptrac
architecture clean-architecture php
Last synced: 13 days ago
JSON representation
Keep your architecture clean.
- Host: GitHub
- URL: https://github.com/qossmic/deptrac
- Owner: qossmic
- License: mit
- Created: 2015-10-30T15:28:28.000Z (about 9 years ago)
- Default Branch: 2.0.x
- Last Pushed: 2024-10-27T08:28:10.000Z (15 days ago)
- Last Synced: 2024-10-27T09:36:34.961Z (15 days ago)
- Topics: architecture, clean-architecture, php
- Language: PHP
- Homepage: https://qossmic.github.io/deptrac
- Size: 25.2 MB
- Stars: 2,634
- Watchers: 44
- Forks: 135
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: docs/CONTRIBUTING.md
- Code of conduct: docs/CODE_OF_CONDUCT.md
- Security: docs/SECURITY.md
Awesome Lists containing this project
- awesome-laravel-filament - DEPTract
- awesome-php - Deptrac - A static code analysis tool that helps to enforce rules for dependencies between software layers. (Table of Contents / Static Analysis)
- awesome-php-cn - Deptrac - 一个静态代码分析工具,以帮助执行规则的软件层之间的依赖关系. (目录 / 静态分析 Static Analysis)
- awesome-projects - Deptrac - A static code analysis tool that helps to enforce rules for dependencies between software layers. (PHP / Static Analysis)
- awesome-php - Deptrac - A static code analysis tool that helps to enforce rules for dependencies between software layers. (Table of Contents / Static Analysis)
- my-awesome - qossmic/deptrac - architecture,php pushed_at:2024-10 star:2.6k fork:0.1k Keep your architecture clean. (PHP)
README
# Deptrac
Deptrac is a static code analysis tool for PHP that helps you communicate,
visualize and enforce architectural decisions in your projects. You can freely
define your architectural layers over classes and which rules should apply to
them.For example, you can use Deptrac to ensure that bundles/modules/extensions in
your project are truly independent of each other to make them easier to reuse.Deptrac can be used in a CI pipeline to make sure a pull request does not
violate any of the architectural rules you defined. With the optional Graphviz
or Mermaidjs formatter you can visualize your layers, rules and violations.## Documentation
You can find the documentation in the /docs directory or visit the doc page:
https://qossmic.github.io/deptrac## Getting Started
You can install Deptrac via Composer. We recommend using the
[deptrac](https://github.com/qossmic/deptrac) package for this:```console
composer require --dev qossmic/deptrac
```Once you have downloaded/installed deptrac, you will need to create a
[configuration file](docs/index.md#configuration), where you define your layers and
communication ruleset. This configuration file is written in YAML or php and, by default,
is stored with the name `deptrac.yaml` in your project's root directory.Deptrac can generate a template for you, using the `init` command.
```console
vendor/bin/deptrac init
```When you have this file, you can analyse your code by
running the `analyse` command:```console
vendor/bin/deptrac# which is equivalent to
vendor/bin/deptrac analyse --config-file=deptrac.yaml
```In order to run Deptrac you need at least PHP 8.1.
You can analyse projects that require an older PHP version as long as
[nikic/php-parser](https://github.com/nikic/PHP-Parser) can parse it.## How to Contribute
See the [contribution guide](docs/CONTRIBUTING.md) or go to development repository [qossmic/deptrac-src](https://github.com/qossmic/deptrac-src).
## Further Documentation
* [Backwards Compatibility](docs/bc_policy.md) - General info on how we approach
backwards compatibility
* [Upgrade Guide](docs/upgrade.md) - List of backwards breaking changes that
need to be addressed when upgrading Deptrac to a new version and how to do it.
* [Core Concepts](docs/concepts.md) - Explains layers, rules and violations in
more details.
* [Configuration](docs/configuration.md) - Reference for all available settings
in a depfile
* [Collectors](docs/collectors.md) - Reference for which collectors are
available in Deptrac to define your layers.
* [Formatters](docs/formatters.md) - Lists the different output formats
supported by Deptrac
* [Debugging](docs/debugging.md) - Overview of the debug commands
* [Code Of Conduct](docs/CODE_OF_CONDUCT.md) - Our community standards
* [Contribute](docs/CONTRIBUTING.md) - Advice for contributing code changes,
e.g. how to run tests or how to build a phar file with your changes that you
can use to analyse your projects
* [Security Guide](docs/SECURITY.md) - How to report security vulnerabilities