Add requirement into composer.json
"require": {
"naver/pinpoint-php-aop": "v1.0.0"
}
Latest PHP7:
v1.0.0
This is a plugin template for reference.
/// Placing "///@hook:" here: aop on function(method) on before,end and Exception
///@hook:app\AppDate::output
class CommonPlugin
{
//$apId: The function(method) name
//$who: If watching a method, $who is that instance
//$args: array parameters $argv = $args[0]
public function __construct($apId,$who,&...$args){
// $this->argv = $args[0];
// $this->funName =$apId;
// $this->instance = $who;
}
// watching before
///@hook:app\DBcontrol::connectDb
public function onBefore(){
}
// watching after
///@hook:app\DBcontrol::getData1 app\DBcontrol::\array_push
public function onEnd(&$ret){
}
// Exception
///@hook:app\DBcontrol::getData2
public function onException($e){
}
}
Example
https://github.com/naver/pinpoint-c-agent/tree/v0.2.2/PHP/pinpoint_php_example/Plugins
This could be found in PHP/pinpoint_php_example/app/index.php.
<?php
require_once __DIR__."/../vendor/autoload.php";
// A writable path for caching AOP code
define('AOP_CACHE_DIR',__DIR__.'/Cache/');
// Your plugins directory: All plugins must have a suffix "Plugin.php",as "CommonPlugin.php mysqlPlugin.php RPCPlugin.php"
define('PLUGINS_DIR',__DIR__.'/../Plugins/');
// since 0.2.3 supports user filter when loadering a class.
define('USER_DEFINED_CLASS_MAP_IMPLEMENT','\Plugins\ClassMapInFile.php');
// since 0.2.5+ PINPOINT_ENV = dev, auto_pinpointed.php will generate Cache/* on every request.
// Recommended in debug mode.
define('PINPOINT_ENV','dev');
// Use pinpoint-php-aop auto_pinpointed.php instead of vendor/autoload.php
require_once __DIR__. '/../vendor/eeliu/pinpoint-php-aop/auto_pinpointed.php';
pinpoint-php-aop wrappers your class with an onBefore/onEnd/onException suite.
More details please go to lib/pinpoint/test/Comparison/pinpoint/test
If you found a bug, please create an issue to us without any hesitate.
If it could help you, please give us a star as a support! Thanks!
Copyright 2020-present NAVER Corp.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.