kleinweb / lib
The source code for the Klein College standard library
Installs: 931
Dependents: 2
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 6
pkg:composer/kleinweb/lib
Requires
- php: ^8.3
- alleyinteractive/wp-bulk-task: ^1.0
- archtechx/enums: ^1.1
- league/uri: ^7.0
- league/uri-components: ^7.0
- monolog/monolog: ^3.9
- nesbot/carbon: ^3.8
- roots/acorn: ^5.0
- symfony/http-foundation: ^7.1
- webmozart/assert: ^1.11
- wp-cli/wp-cli: ^2.11
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.59
- kleinweb/php-coding-standards: ^0.8.0
- php-stubs/wp-cli-stubs: ^2.11
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-webmozart-assert: ^2.0
- roave/security-advisories: dev-latest
- slevomat/coding-standard: ^8.15
- squizlabs/php_codesniffer: ^3.7.1
- szepeviktor/phpstan-wordpress: ^2.0
- wpackagist-plugin/simple-history: ^5.8
- dev-main
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.0
- 0.7.1
- 0.7.0
- 0.7.0-rc.1
- 0.6.1
- 0.6.0
- 0.5.0
- 0.4.1
- 0.4.0
- 0.3.0
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.0
- dev-renovate/biomejs-biome-2.x
- dev-renovate/webmozart-assert-2.x
- dev-renovate/major-symfony
- dev-renovate/fsfe-reuse-action-6.x
- dev-renovate/major-linters
- dev-renovate/actions-checkout-6.x
- dev-feature/feature-interfaces
- dev-licensing
This package is auto-updated.
Last update: 2026-01-24 01:03:22 UTC
README
A PHP library providing shared functionality for WordPress-based applications at Klein College (Temple University). Built on Roots Acorn to bring Laravel-style service providers, dependency injection, and Blade templating to WordPress.
Requirements
- PHP 8.2+
- WordPress with Roots Acorn 5.x
Installation
composer require kleinweb/lib
Features
Attribute-Based WordPress Hooks
Register actions and filters declaratively using PHP 8 attributes:
use Kleinweb\Lib\Hooks\Attributes\Action; use Kleinweb\Lib\Hooks\Attributes\Filter; use Kleinweb\Lib\Support\ServiceProvider; class MyServiceProvider extends ServiceProvider { #[Action('init')] public function onInit(): void { // Runs on WordPress 'init' action } #[Filter('the_content', priority: 20)] public function filterContent(string $content): string { return $content . '<p>Appended content</p>'; } }
Package Configuration
Fluent API for defining package assets, adapted from spatie/laravel-package-tools:
use Kleinweb\Lib\Package\Package; use Kleinweb\Lib\Package\PackageServiceProvider; class MyPackageServiceProvider extends PackageServiceProvider { public function configurePackage(Package $package): void { $package ->name('my-package') ->hasConfigFile() ->hasViews() ->hasMigrations('create_items_table') ->hasCommands(MyCommand::class); } }
Multisite Utilities
Helpers for WordPress multisite environments:
use Kleinweb\Lib\Tenancy\Site; Site::name(); // Current site name Site::url(); // Site URL as League\Uri instance Site::host(); // Current hostname Site::isPrimaryHost(); // Check if on main site Site::originalHost(); // Get original domain from site meta
Logging Integration
Monolog handler for Simple History plugin:
use Kleinweb\Lib\Log\SimpleHistoryHandler; use Monolog\Logger; $logger = new Logger('my-channel'); $logger->pushHandler(new SimpleHistoryHandler());
Development
This project uses Nix for reproducible development environments and just for task automation.
# Enter development shell (if using Nix) nix develop # Or use direnv direnv allow # Run all checks just check # Lint only just lint # Auto-fix issues just fix # Individual tools composer phpstan # Static analysis (level 8) composer phpcs # Code sniffer composer phpcbf # Auto-fix code sniffer issues
License
GPL-3.0-or-later