Download the PHP package pimcore/static-resolver-bundle without Composer
On this page you can find all versions of the php package pimcore/static-resolver-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download pimcore/static-resolver-bundle
More information about pimcore/static-resolver-bundle
Files in pimcore/static-resolver-bundle
Package static-resolver-bundle
Short Description Pimcore Static Resolver Bundle
License proprietary
Informations about the package static-resolver-bundle
Static Resolver Bundle
What is the Static Resolver Bundle?
The Static Resolver Bundle is a Pimcore bundle designed to encapsulate static method calls within a service-oriented architecture. It provides a straightforward mechanism to transform static methods into injectable services, promoting a cleaner, more testable, and well-organized codebase.
In many PHP applications, including Pimcore, static methods are commonly used for utility functions and global operations. While convenient, static methods have several drawbacks:
- Testing Difficulties: Static methods are hard to mock in unit tests
- Tight Coupling: Code using static calls is tightly coupled to the implementation
- Hidden Dependencies: Static dependencies aren't explicit in class constructors
The Static Resolver Bundle addresses these issues by wrapping static calls in service classes that can be properly injected and mocked.
Architecture
The bundle follows a consistent pattern for each static class it wraps:
- Contract Interfaces: Define the methods that will be available (e.g.,
DbResolverContractInterface
) - Contract Implementations: Implement the interfaces by wrapping static calls (e.g.,
DbResolverContract
) - Bundle-specific Interfaces: Extend the contract interfaces and are marked as internal (e.g.,
DbResolverInterface
) - Bundle-specific Implementations: Extend the contract implementations and implement the bundle-specific interfaces (e.g.,
DbResolver
)
This layered approach allows for flexibility and maintainability while keeping the public API clean.
How to Use the Static Resolver Bundle
Installation
-
Install via Composer:
- Enable the bundle in
config/bundles.php
:
Using Resolver Services
Instead of using static calls directly in your code, inject the appropriate resolver service and use its methods:
Before (with static calls):
After (with resolver service):
Available Resolver Services
The bundle provides resolver services for various Pimcore components:
-
Database Operations:
Pimcore\Bundle\StaticResolverBundle\Contract\Db\DbResolverContractInterface
-
Model Operations:
- Various resolvers for DataObject, Asset, Document, etc.
- Library Tools:
- Authentication, Console, Email, etc.
Benefits of Using Resolver Services
- Improved Testability: Services can be easily mocked in unit tests
- Explicit Dependencies: Dependencies are clearly visible in constructor parameters
- Loose Coupling: Code depends on interfaces rather than concrete implementations
- Consistent API: The resolver services provide a consistent API for static functionality
Example Use Cases
Database Operations
Instead of using Pimcore\Db
static methods:
Use the DbResolver service:
Authentication
Instead of using Pimcore\Tool\Authentication
static methods:
Use the AuthenticationResolver service:
Internal Use Examples
For internal Pimcore use, you can use the Bundle-specific Interfaces (marked as @internal
). These interfaces extend the Contract Interfaces and may provide additional functionality specific to Pimcore's internal needs.
Database Operations (Internal Use)
Authentication (Internal Use)
Important Notes
- All Contract Interfaces in this bundle are designed for third-party developers to use
- Bundle-specific Interfaces (marked as
@internal
) are intended for internal Pimcore use only - The bundle provides a transition path from static methods to a more service-oriented architecture
Documentation Overview
- Installation
- Resolver Service Usage
- Event Proxy Service Usage (deprecated)
- Interceptor Proxy Service Usage (deprecated)
- Proxy Service Usage (deprecated)
- Upgrade Notes
All versions of static-resolver-bundle with dependencies
pimcore/pimcore Version ^12.0
friendsofphp/proxy-manager-lts Version ^1