Adaptadores adicionales para el componente Phalcon Logger.
composer require phalcon/incubator-logger
Adaptador para almacenar registros en AWS ClodWatch:
Nota: el nombre del grupo y el nombre de la transmisión deben crearse antes de llamar a cualquier registro. Puede hacerlo dentro de la consola de AWS.
use Aws CloudWatchLogs CloudWatchLogsClient ;
use Phalcon Incubator Logger Adapter CloudWatch ;
use Phalcon Logger Logger ;
$ di -> set (
' logger ' ,
function () {
$ client = new CloudWatchLogsClient ([
' credentials ' => [
' key ' => ' AMAZON_CLOUDWATCH_KEY ' ,
' secret ' => ' AMAZON_CLOUDWATCH_SECRET ' ,
],
' region ' => ' AMAZON_CLOUDWATCH_REGION ' ,
' version ' => ' latest ' , // Or any specific
]);
$ adapter = new CloudWatch ( $ client , ' /group/name ' , ' stream-name ' );
return new Logger ( ' messages ' , [ ' main ' => $ adapter ]);
}
);
Adaptador para almacenar registros en una tabla de base de datos:
use Phalcon Db Adapter Pdo Mysql ;
use Phalcon Incubator Logger Adapter Database as DbLogger ;
$ di -> set (
' logger ' ,
function () {
$ connection = new Mysql (
[
' host ' => ' localhost ' ,
' username ' => ' root ' ,
' password ' => ' secret ' ,
' dbname ' => ' audit ' ,
]
);
$ logsName = ' errors ' ;
$ tableName = ' logs ' ;
return new DbLogger ( $ connection , $ logsName , $ tableName );
}
);
La siguiente tabla se utiliza para almacenar los registros:
CREATE TABLE IF NOT EXISTS ` logs ` (
` id ` INT ( 10 ) unsigned NOT NULL AUTO_INCREMENT,
` name ` VARCHAR ( 32 ) DEFAULT NULL ,
` type ` INT ( 3 ) NOT NULL ,
` content ` text ,
` created_at ` BIGINT unsigned NOT NULL ,
PRIMARY KEY ( ` id ` )
) ENGINE = InnoDB DEFAULT CHARSET = utf8
Adaptador para enviar mensajes por protocolo UDP a servidor externo
use Phalcon Incubator Logger Adapter Udp as UdpLogger ;
$ di -> set (
' logger ' ,
function () {
$ host = ' 192.168.1.2 ' ;
$ port = 65000 ;
return new UdpLogger ( ' errors ' , $ host , $ port );
}
);
Adaptador para escribir mensajes en un canal de Slack
$ adapter = new Phalcon Incubator Logger Adapter Slack ( ' api-token ' , ' channel-name ' );
$ logger = new Phalcon Logger Logger ( ' logger-name ' , [ ' main-slack ' => $ adapter ]);
$ logger -> info ( ' Information message to log in the channel channel-name ' );
Acceda a esta página para crear una application
(después de elegir/crear un espacio de trabajo)
Vaya a Features > OAuth & Permissions
y en la sección Scopes
-> Add an oauth scope
y seleccione los siguientes derechos:
Ahora puede generar un token para su bot/usuario en la sección Install App
, que se parece a esto:
xoxp-1111111-22222222-33333333-aaaaaaaaaaaaaaaaaaaaaa