55 lines
2.3 KiB
Markdown
55 lines
2.3 KiB
Markdown
|
Symfony Contracts
|
||
|
=================
|
||
|
|
||
|
A set of abstractions extracted out of the Symfony components.
|
||
|
|
||
|
Can be used to build on semantics that the Symfony components proved useful - and
|
||
|
that already have battle tested implementations.
|
||
|
|
||
|
Design Principles
|
||
|
-----------------
|
||
|
|
||
|
* contracts are split by domain, each into their own sub-namespaces;
|
||
|
* contracts are small and consistent sets of PHP interfaces, traits, normative
|
||
|
docblocks and reference test suites when applicable, ...;
|
||
|
* all contracts must have a proven implementation to enter this repository;
|
||
|
* they must be backward compatible with existing Symfony components.
|
||
|
|
||
|
Packages that implement specific contracts should list them in the "provide"
|
||
|
section of their "composer.json" file, using the `symfony/*-implementation`
|
||
|
convention (e.g. `"provide": { "symfony/cache-implementation": "1.0" }`).
|
||
|
|
||
|
FAQ
|
||
|
---
|
||
|
|
||
|
### How to use this package?
|
||
|
|
||
|
The abstractions in this package are useful to achieve loose coupling and
|
||
|
interoperability. By using the provided interfaces as type hints, you are able
|
||
|
to reuse any implementations that match their contracts. It could be a Symfony
|
||
|
component, or another one provided by the PHP community at large.
|
||
|
|
||
|
Depending on their semantics, some interfaces can be combined with autowiring to
|
||
|
seamlessly inject a service in your classes.
|
||
|
|
||
|
Others might be useful as labeling interfaces, to hint about a specific behavior
|
||
|
that could be enabled when using autoconfiguration or manual service tagging (or
|
||
|
any other means provided by your framework.)
|
||
|
|
||
|
### How is this different from PHP-FIG's PSRs?
|
||
|
|
||
|
When applicable, the provided contracts are built on top of PHP-FIG's PSRs. But
|
||
|
the group has different goals and different processes. Here, we're focusing on
|
||
|
providing abstractions that are useful on their own while still compatible with
|
||
|
implementations provided by Symfony. Although not the main target, we hope that
|
||
|
the declared contracts will directly or indirectly contribute to the PHP-FIG.
|
||
|
|
||
|
Resources
|
||
|
---------
|
||
|
|
||
|
* [Documentation](https://symfony.com/doc/current/components/contracts.html)
|
||
|
* [Contributing](https://symfony.com/doc/current/contributing/index.html)
|
||
|
* [Report issues](https://github.com/symfony/symfony/issues) and
|
||
|
[send Pull Requests](https://github.com/symfony/symfony/pulls)
|
||
|
in the [main Symfony repository](https://github.com/symfony/symfony)
|