Package Data | |
---|---|
Maintainer Username: | thieule |
Maintainer Contact: | quangthieuagu@gmail.com (Thieu Le Quang) |
Package Create Date: | 2017-05-27 |
Package Last Update: | 2017-05-30 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-22 03:11:12 |
Package Statistics | |
---|---|
Total Downloads: | 29 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 2 |
Total Watchers: | 2 |
Total Forks: | 1 |
Total Open Issues: | 0 |
This is code copy and reference from goaop/framework and goaop/goaop-laravel-bridge, support for Lumen
The GoAopLumen adds support for Aspect-Oriented Programming via Go! AOP Framework for Lumen 5.4.* applications.
Aspect-Oriented Paradigm allows to extend the standard Object-Oriented Paradigm with special instruments for effective solving of cross-cutting concerns in your application. This code is typically present everywhere in your application (for example, logging, caching, monitoring, etc) and there is no easy way to fix this without AOP.
AOP defines new instruments for developers, they are:
\Closure
instance, wrapped into the interceptor object.You can read more about AOP in different sources, there are good articles for Java language and they can be applied for PHP too, because it's general paradigm. Alternatively, you can watch a nice presentation about AOP in Laravel
GoAopBridge can be easily installed with composer. Just ask a composer to download the bundle with dependencies by running the command:
$ composer require thieule/goaop-lumen
Add the Go\Lumen\GoAopBridge\GoAopServiceProvider
to your bootstrap/app.php providers
array:
// bootstrap/app.php
$app->register(Go\Lumen\GoAopBridge\GoAopServiceProvider::class);
Make sure that this service provider is the first item in this list. This is required for the AOP engine to work correctly.
The default configuration in the config/go_aop.php
file. Copy this file to your own config directory to modify the values.
Configuration can be used for additional tuning of AOP kernel and source code whitelistsing/blacklisting.
// config/go_aop.php
return [
/*
|--------------------------------------------------------------------------
| AOP Debug Mode
|--------------------------------------------------------------------------
|
| When AOP is in debug mode, then breakpoints in the original source code
| will work. Also engine will refresh cache files if the original files were
| changed.
| For production mode, no extra filemtime checks and better integration with opcache
|
*/
'debug' => env('APP_DEBUG', false),
/*
|--------------------------------------------------------------------------
| Application root directory
|--------------------------------------------------------------------------
|
| AOP will be applied only to the files in this directory, change it to app_path()
| if needed
*/
'appDir' => base_path(),
/*
|--------------------------------------------------------------------------
| AOP cache directory
|--------------------------------------------------------------------------
|
| AOP engine will put all transformed files and caches in that directory
*/
'cacheDir' => storage_path('app/aspect'),
/*
|--------------------------------------------------------------------------
| Cache file mode
|--------------------------------------------------------------------------
|
| If configured then will be used as cache file mode for chmod
*/
'cacheFileMode' => 511,
/*
|--------------------------------------------------------------------------
| Controls miscellaneous features of AOP engine
|--------------------------------------------------------------------------
|
| See \Go\Aop\Features enumeration for bit mask
*/
'features' => 0,
/*
|--------------------------------------------------------------------------
| White list of directories
|--------------------------------------------------------------------------
|
| AOP will check this list to apply an AOP to selected directories only,
| leave it empty if you want AOP to be applied to all files in the appDir
*/
'includePaths' => [
__DIR__.'/../app'
],
/*
|--------------------------------------------------------------------------
| Black list of directories
|--------------------------------------------------------------------------
|
| AOP will check this list to disable AOP for selected directories
*/
'excludePaths' => [],
/*
|--------------------------------------------------------------------------
| AOP container class
|--------------------------------------------------------------------------
|
| This option can be useful for extension and fine-tuning of services
*/
'containerClass' => GoAspectContainer::class,
];
Aspects are services in the Lumen application and loaded into the AOP container with the help of service provider that collects all services tagged with goaop.aspect
tag in the container. Here is an example how to implement a logging aspect that will log information about public method invocations in the app/ directory.
Definition of aspect class with pointuct and logging advice
<?php
namespace App\Aspect;
use Go\Aop\Aspect;
use Go\Aop\Intercept\MethodInvocation;
use Go\Lang\Annotation\Before;
use Psr\Log\LoggerInterface;
/**
* Application logging aspect
*/
class LoggingAspect implements Aspect
{
/**
* @var LoggerInterface
*/
private $logger;
public function __construct(LoggerInterface $logger)
{
$this->logger = $logger;
}
/**
* Writes a log info before method execution
*
* @param MethodInvocation $invocation
* @Before("execution(public **->*(*))")
*/
public function beforeMethod(MethodInvocation $invocation)
{
$this->logger->info($invocation, $invocation->getArguments());
}
}
Add LoggingAspect service to register()
method in App service provider, add declaration of aspect and tag it with goaop.aspect
tag:
namespace App\Providers;
use App\Aspect\LoggingAspect;
use Illuminate\Support\ServiceProvider;
use Psr\Log\LoggerInterface;
class AppServiceProvider extends ServiceProvider
{
/**
* Register the application services.
*
* @return void
*/
public function register()
{
$this->app->singleton(LoggingAspect::class, function ($app) {
return new LoggingAspect($app->make(LoggerInterface::class));
});
$this->app->tag([LoggingAspect::class], 'goaop.aspect');
}
You can add new Provider and LoggingAspect to register function!!
This bridge is under the MIT license. See the complete LICENSE in the root directory