Page Menu
Home
WickedGov Phorge
Search
Configure Global Search
Log In
Files
F1431847
ElasticaHandler.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
3 KB
Referenced Files
None
Subscribers
None
ElasticaHandler.php
View Options
<?php
declare
(
strict_types
=
1
);
/*
* This file is part of the Monolog package.
*
* (c) Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace
Monolog\Handler
;
use
Elastica\Document
;
use
Monolog\Formatter\FormatterInterface
;
use
Monolog\Formatter\ElasticaFormatter
;
use
Monolog\Logger
;
use
Elastica\Client
;
use
Elastica\Exception\ExceptionInterface
;
/**
* Elastic Search handler
*
* Usage example:
*
* $client = new \Elastica\Client();
* $options = array(
* 'index' => 'elastic_index_name',
* 'type' => 'elastic_doc_type', Types have been removed in Elastica 7
* );
* $handler = new ElasticaHandler($client, $options);
* $log = new Logger('application');
* $log->pushHandler($handler);
*
* @author Jelle Vink <jelle.vink@gmail.com>
*/
class
ElasticaHandler
extends
AbstractProcessingHandler
{
/**
* @var Client
*/
protected
$client
;
/**
* @var mixed[] Handler config options
*/
protected
$options
=
[];
/**
* @param Client $client Elastica Client object
* @param mixed[] $options Handler configuration
*/
public
function
__construct
(
Client
$client
,
array
$options
=
[],
$level
=
Logger
::
DEBUG
,
bool
$bubble
=
true
)
{
parent
::
__construct
(
$level
,
$bubble
);
$this
->
client
=
$client
;
$this
->
options
=
array_merge
(
[
'index'
=>
'monolog'
,
// Elastic index name
'type'
=>
'record'
,
// Elastic document type
'ignore_error'
=>
false
,
// Suppress Elastica exceptions
],
$options
);
}
/**
* {@inheritDoc}
*/
protected
function
write
(
array
$record
):
void
{
$this
->
bulkSend
([
$record
[
'formatted'
]]);
}
/**
* {@inheritDoc}
*/
public
function
setFormatter
(
FormatterInterface
$formatter
):
HandlerInterface
{
if
(
$formatter
instanceof
ElasticaFormatter
)
{
return
parent
::
setFormatter
(
$formatter
);
}
throw
new
\InvalidArgumentException
(
'ElasticaHandler is only compatible with ElasticaFormatter'
);
}
/**
* @return mixed[]
*/
public
function
getOptions
():
array
{
return
$this
->
options
;
}
/**
* {@inheritDoc}
*/
protected
function
getDefaultFormatter
():
FormatterInterface
{
return
new
ElasticaFormatter
(
$this
->
options
[
'index'
],
$this
->
options
[
'type'
]);
}
/**
* {@inheritDoc}
*/
public
function
handleBatch
(
array
$records
):
void
{
$documents
=
$this
->
getFormatter
()->
formatBatch
(
$records
);
$this
->
bulkSend
(
$documents
);
}
/**
* Use Elasticsearch bulk API to send list of documents
*
* @param Document[] $documents
*
* @throws \RuntimeException
*/
protected
function
bulkSend
(
array
$documents
):
void
{
try
{
$this
->
client
->
addDocuments
(
$documents
);
}
catch
(
ExceptionInterface
$e
)
{
if
(!
$this
->
options
[
'ignore_error'
])
{
throw
new
\RuntimeException
(
"Error sending messages to Elasticsearch"
,
0
,
$e
);
}
}
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sat, May 16, 21:07 (1 d, 16 h)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
94/1f/fdfa35dc363bca844af9da8d0216
Default Alt Text
ElasticaHandler.php (3 KB)
Attached To
Mode
rMWPROD MediaWiki Production
Attached
Detach File
Event Timeline
Log In to Comment