summaryrefslogtreecommitdiff
path: root/vendor/ruflin/elastica/lib/Elastica/Log.php
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/ruflin/elastica/lib/Elastica/Log.php')
-rw-r--r--vendor/ruflin/elastica/lib/Elastica/Log.php81
1 files changed, 81 insertions, 0 deletions
diff --git a/vendor/ruflin/elastica/lib/Elastica/Log.php b/vendor/ruflin/elastica/lib/Elastica/Log.php
new file mode 100644
index 00000000..c2f0c18a
--- /dev/null
+++ b/vendor/ruflin/elastica/lib/Elastica/Log.php
@@ -0,0 +1,81 @@
+<?php
+namespace Elastica;
+
+use Psr\Log\AbstractLogger;
+
+/**
+ * Elastica log object.
+ *
+ * @author Nicolas Ruflin <spam@ruflin.com>
+ */
+class Log extends AbstractLogger
+{
+ /**
+ * Log path or true if enabled.
+ *
+ * @var string|bool
+ */
+ protected $_log = true;
+
+ /**
+ * Last logged message.
+ *
+ * @var string Last logged message
+ */
+ protected $_lastMessage = '';
+
+ /**
+ * Inits log object.
+ *
+ * @param string|bool String to set a specific file for logging
+ */
+ public function __construct($log = '')
+ {
+ $this->setLog($log);
+ }
+
+ /**
+ * Log a message.
+ *
+ * @param mixed $level
+ * @param string $message
+ * @param array $context
+ *
+ * @return null|void
+ */
+ public function log($level, $message, array $context = array())
+ {
+ $context['error_message'] = $message;
+ $this->_lastMessage = JSON::stringify($context);
+
+ if (!empty($this->_log) && is_string($this->_log)) {
+ error_log($this->_lastMessage.PHP_EOL, 3, $this->_log);
+ } else {
+ error_log($this->_lastMessage);
+ }
+ }
+
+ /**
+ * Enable/disable log or set log path.
+ *
+ * @param bool|string $log Enables log or sets log path
+ *
+ * @return $this
+ */
+ public function setLog($log)
+ {
+ $this->_log = $log;
+
+ return $this;
+ }
+
+ /**
+ * Return last logged message.
+ *
+ * @return string Last logged message
+ */
+ public function getLastMessage()
+ {
+ return $this->_lastMessage;
+ }
+}