Merge in metadata support into master
[fnpeditor.git] / src / fnpjs / logging / handlers.js
index c15d17f..f6f0509 100644 (file)
@@ -3,6 +3,39 @@ define(function() {
 'use strict';
 
 
 'use strict';
 
 
-return {};
+return {
+    console: function(record) {
+        /* global console */
+        var method;
+        if(console) {
+            method = (typeof console[record.level] === 'function') ? record.level : 'log';
+            console[method](record.message);
+        }
+    },
+    raven: function(record) {
+        /* global window */
+        if(!window.Raven) {
+            return;
+        }
+
+        var ravenData = {
+            level: record.level,
+            logger: record.loggerName,
+            tags: {}
+        };
+
+        Object.keys(record.data || {})
+            .filter(function(key) {return key !== 'exception';})
+            .forEach(function(key) {
+                ravenData.tags[key] = record.data[key];
+            });
+
+        if(record.data && record.data.exception) {
+            window.Raven.captureException(record.data.exception, ravenData);
+        } else {
+            window.Raven.captureMessage(record.message, ravenData);
+        }
+    }
+};
 
 });
\ No newline at end of file
 
 });
\ No newline at end of file