toggly / feature-management-php
Toggly Feature Management library for PHP with Laravel and WordPress support
Package info
github.com/ops-ai/Toggly.FeatureManagement.PHP
pkg:composer/toggly/feature-management-php
Requires
- php: ^7.4|^8.0|^8.1|^8.2|^8.3
- psr/container: ^1.0|^2.0
- psr/http-client: ^1.0
- psr/http-factory: ^1.0
- psr/log: ^1.0|^2.0|^3.0
- psr/simple-cache: ^1.0|^2.0|^3.0
Requires (Dev)
- illuminate/cache: ^11.47
- illuminate/contracts: ^11.0
- mongodb/mongodb: ^2.0
- phpunit/phpunit: ^9.0|^10.0
- textalk/websocket: ^1.6
Suggests
- guzzlehttp/guzzle: PSR-18 HTTP client implementation
- illuminate/cache: For Laravel cache storage provider (^10.0|^11.0|^12.0)
- illuminate/http: For Laravel HTTP integration (^10.0|^11.0|^12.0)
- illuminate/support: For Laravel integration (^10.0|^11.0|^12.0)
- mongodb/mongodb: For MongoDB storage provider (^2.0)
- react/socket: For WebSocket support
- symfony/http-client: Alternative PSR-18 HTTP client
This package is auto-updated.
Last update: 2026-03-04 22:18:16 UTC
README
A comprehensive PHP library for Toggly feature management with native Laravel and WordPress support.
Features
- Full Feature Parity: Matches the functionality of the .NET Toggly.FeatureManagement library
- Signed Definitions: ECDSA signature verification for secure feature definitions
- Real-time Updates: WebSocket support for instant feature updates (with polling fallback)
- Usage Statistics: Automatic tracking of feature usage and user analytics
- Metrics Collection: Support for measurements, observations, and counters
- Snapshot Providers: Cache, database, and file-based snapshot storage
- Laravel Integration: Native Laravel service provider, facade, and middleware
- WordPress Plugin: Full WordPress plugin with admin interface and hooks
- PSR Standards: Built on PSR-4, PSR-11, PSR-16, PSR-18, and PSR-17
Installation
Composer
composer require toggly/feature-management-php
Quick Start
Laravel
- Register the service provider in
config/app.php:
'providers' => [ // ... Toggly\Laravel\ServiceProvider::class, ],
- Publish the configuration:
php artisan vendor:publish --tag=toggly-config
- Configure in
.env:
TOGGLY_APP_KEY=your-app-key TOGGLY_ENVIRONMENT=Production TOGGLY_USE_SIGNED_DEFINITIONS=false
- Use in your code:
use Toggly\Laravel\Facades\Toggly; // Check if feature is enabled if (Toggly::isEnabled('new-checkout')) { return view('checkout.v2'); } // With context $enabled = Toggly::isEnabledFor('premium-feature', [ 'userId' => $user->id, 'plan' => $user->plan ]); // State change handler Toggly::whenFeatureTurnsOn('new-api', function() { // Initialize new API }); // Record usage Toggly::recordUsage('feature-key'); // Record metrics Toggly::measure('checkout-completed', 125.50); Toggly::observe('active-users', 1500); Toggly::incrementCounter('api-calls', 1);
- Use middleware in routes:
Route::get('/new-feature', function () { return view('new-feature'); })->middleware('feature:new-feature');
WordPress
-
Install the plugin by copying to
wp-content/plugins/toggly/ -
Activate the plugin in WordPress admin
-
Configure in Settings > Toggly:
- App Key
- Environment
- Base URL (optional)
- Use Signed Definitions (optional)
-
Use in templates:
<?php if (toggly_is_enabled('new-header')): ?> <?php get_template_part('header', 'new'); ?> <?php endif; ?>
- Use shortcode:
[toggly_feature name="premium-content"]
<!-- Premium content here -->
[/toggly_feature]
- Use hooks in
functions.php:
add_action('toggly_feature_turns_on', function($featureKey) { if ($featureKey === 'new-theme') { // Activate new theme } });
Core Library Usage
Basic Usage
use Toggly\FeatureManagement\Config\TogglySettings; use Toggly\FeatureManagement\Core\FeatureProvider; use Toggly\FeatureManagement\Core\FeatureManager; use Toggly\FeatureManagement\Http\TogglyHttpClient; $settings = new TogglySettings([ 'app_key' => 'your-app-key', 'environment' => 'Production', ]); $httpClient = new TogglyHttpClient(/* PSR-18 client */, /* PSR-17 factory */, $settings->getBaseUrl()); $featureProvider = new FeatureProvider($settings, $httpClient, /* state service */); $featureManager = new FeatureManager($featureProvider, /* usage stats */, /* secure provider */); // Check feature if ($featureManager->isEnabled('my-feature')) { // Feature is enabled }
Snapshot Providers
Cache Provider (PSR-16)
use Toggly\FeatureManagement\Storage\SnapshotProviders\CacheSnapshotProvider; use Toggly\FeatureManagement\Storage\SnapshotSettings; $snapshotProvider = new CacheSnapshotProvider( $cache, // PSR-16 cache implementation new SnapshotSettings(['document_name' => 'toggly_features']), 86400 // TTL in seconds );
Database Provider (PDO)
use Toggly\FeatureManagement\Storage\SnapshotProviders\DatabaseSnapshotProvider; $snapshotProvider = new DatabaseSnapshotProvider( $pdo, // PDO instance new SnapshotSettings(['document_name' => 'toggly_features']) );
File Provider
use Toggly\FeatureManagement\Storage\SnapshotProviders\FileSnapshotProvider; $snapshotProvider = new FileSnapshotProvider( '/path/to/snapshots', new SnapshotSettings(['document_name' => 'toggly_features.json']) );
Configuration
TogglySettings
$settings = new TogglySettings([ 'app_key' => 'your-app-key', 'environment' => 'Production', 'base_url' => 'https://app.toggly.io/', 'use_signed_definitions' => true, 'allowed_key_ids' => ['key-id-1', 'key-id-2'], 'refresh_interval' => 300, // 5 minutes 'app_version' => '1.0.0', 'instance_name' => 'server-1', 'undefined_enabled_on_development' => false, ]);
Advanced Features
Feature State Change Handlers
$stateService = $container->get(FeatureStateServiceInterface::class); // Register callback $id = $stateService->whenFeatureTurnsOn('new-feature', function() { // Initialize feature }); // Unregister $stateService->unregisterFeatureStateChange('new-feature', $id);
Custom Metrics
$metricsService = $container->get(MetricsServiceInterface::class); // Record measurement (aggregated over time) $metricsService->measure('revenue', 1250.50); // Record observation (point-in-time) $metricsService->observe('active-users', 1500); // Increment counter $metricsService->incrementCounter('api-calls', 1);
Custom Context Provider
class MyContextProvider implements FeatureContextProviderInterface { public function getContextIdentifier(): ?string { // Return unique user identifier return $this->getCurrentUserId(); } // ... implement other methods }
Requirements
- PHP 7.4 or higher (8.1+ recommended)
- PSR-18 HTTP client (e.g., Guzzle, Symfony HTTP Client)
- PSR-16 cache (optional, for snapshot provider)
- PSR-11 container (optional, for dependency injection)
Laravel Requirements
- Laravel 8.0 or higher
illuminate/supportilluminate/http
WordPress Requirements
- WordPress 5.0 or higher
- No external dependencies (uses WordPress APIs)
License
MIT
Architecture
The library follows a modular architecture:
- Core Library: Framework-agnostic core functionality
- Laravel Integration: Service provider, facade, middleware, and filters
- WordPress Plugin: Full plugin with admin interface
Core Components
FeatureProvider: Fetches and manages feature definitionsFeatureManager: Evaluates features with stats trackingFeatureStateService: Manages state change notificationsUsageStatsProvider: Collects and sends usage statisticsMetricsService: Collects custom metrics for experimentsEcdsaSignatureVerifier: Verifies signed definitionsJwkManager: Manages JSON Web Keys for signature verification
Snapshot Providers
Three snapshot provider implementations are available:
- CacheSnapshotProvider: Uses PSR-16 cache (Redis, Memcached, etc.)
- DatabaseSnapshotProvider: Uses PDO (MySQL, PostgreSQL, SQLite)
- FileSnapshotProvider: Uses file system storage
Development
Running Tests
composer test
Code Style
The project follows PSR-12 coding standards.
Contributing
Contributions are welcome! Please read our contributing guidelines first.
License
MIT License - see LICENSE file for details.
Support
For support, visit https://toggly.io or open an issue.