logster 1.4.0.pre → 2.0.0.pre

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 704e5f54b6fb95470fcf7389710c45e899f22ea7da2bcc65639fb79512d3e374
4
- data.tar.gz: 673fd0c04c7e048dee1bf24025d9e2324a9c367a90bde080f49138d03cf45d4d
3
+ metadata.gz: 18cfb59f0fc2db337d3efc3b5d26b5ede5ac681cc599227b1564f500c17e5946
4
+ data.tar.gz: def563ba311997843ad3c30d8520e93d50b708f8d514ca180ad9fa20020a5ea6
5
5
  SHA512:
6
- metadata.gz: 370a818a8bdddb495be4f4cf1aa2a3666d761ce28acc2e20b79a76c289acb3829f410b96078d6b5b0d70b813aada7a6242466a62c19d173b1ed42df14c84f1f0
7
- data.tar.gz: 10fd9f0292116941dcbc0180ff0534895ea2b9688997840d24021bcb2aa88163f7947f66f9684c4ab78aef81a1bcfb77fab2f9a67c78b5432762425f81200a18
6
+ metadata.gz: 6351baad87ed818542d852e2b8c372231759cd508c8f5a6034e215ad585c3c9d81dc6d1865f0f343d6c5d39364efd1b10352abfa25c72a5099738d3525a6dc81
7
+ data.tar.gz: 8a81f0243db890dcb706c5bed34e286ebea5ed85132afcea112a7c3b12894997d1153bedeac7c44b7e44de7b29085730d945a610f2ff69cbc1b76f7b9a6dca2c
data/.gitignore CHANGED
@@ -16,3 +16,4 @@ test/tmp
16
16
  test/version_tmp
17
17
  tmp
18
18
  .byebug_history
19
+ .rubocop-https---raw-githubusercontent-com-discourse-discourse-master--rubocop-yml
@@ -0,0 +1 @@
1
+ inherit_from: https://raw.githubusercontent.com/discourse/discourse/master/.rubocop.yml
@@ -1,6 +1,12 @@
1
1
  # CHANGELOG
2
2
 
3
- - 2019-01-09: Version 1.4.0
3
+ - 2019-01-17: Version 2.0.0.pre
4
+ - FIX: don't merge any new env samples if there are 50 samples (1.4.0.pre regression)
5
+ - UX: make env navigation controls stick to the top when scrolled
6
+ - PERF: store env samples separately from the rest of message data
7
+ - DEV: Rubocop
8
+
9
+ - 2019-01-09: Version 1.4.0.pre
4
10
  - FEATURE: allow navigation through merged errors
5
11
  - FEATURE: search should look at env
6
12
  - FIX: deselect message if new filtering doesn't include selected message
@@ -97,4 +97,4 @@ this.refreshInterval=setInterval(function(){a+=1
97
97
  var e=(0,n.isHidden)(),i=!e
98
98
  e&&a%s==0&&(i=!0,s<20&&s++),i&&(t.loadMore(),e||(s=1))},3e3),this.events.on("panelResized",function(t){e.resizePanels(t)})},deactivate:function(){clearInterval(this.refreshInterval)}})}),define("client-app/routes/show",["exports","client-app/models/message","client-app/lib/utilities"],function(e,t,n){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.Route.extend({model:function(e){return(0,n.preloadOrAjax)("/show/"+e.id+".json")},setupController:function(e,n){this._super.apply(this,arguments),e.set("model",t.default.create(n))}})})
99
99
  define("client-app/services/ajax",["exports","ember-ajax/services/ajax"],function(e,t){Object.defineProperty(e,"__esModule",{value:!0}),Object.defineProperty(e,"default",{enumerable:!0,get:function(){return t.default}})}),define("client-app/templates/application",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"yOsrYpw5",block:'{"symbols":[],"statements":[[1,[21,"update-time"],false],[0,"\\n"],[1,[21,"outlet"],false],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/application.hbs"}})}),define("client-app/templates/components/actions-menu",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"ebB3+Z4x",block:'{"symbols":["&default"],"statements":[[4,"if",[[23,["actionsInMenu"]]],null,{"statements":[[4,"if",[[23,["showMenu"]]],null,{"statements":[[0," "],[7,"div"],[11,"class","actions-menu"],[9],[0,"\\n "],[14,1],[0,"\\n "],[10],[0,"\\n"]],"parameters":[]},null],[0," "],[7,"button"],[11,"class","expand btn no-text"],[3,"action",[[22,0,[]],"expandMenu"]],[9],[7,"i"],[11,"class","fa fa-ellipsis-h"],[9],[10],[10],[0,"\\n "],[7,"button"],[11,"class","share btn"],[3,"action",[[22,0,[]],"share"]],[9],[7,"i"],[11,"class","fa fa-share"],[9],[10],[7,"span"],[9],[0,"Share"],[10],[10],[0,"\\n"]],"parameters":[]},{"statements":[[0," "],[14,1],[0,"\\n "],[7,"button"],[11,"class","share btn"],[3,"action",[[22,0,[]],"share"]],[9],[7,"i"],[11,"class","fa fa-share"],[9],[10],[7,"span"],[9],[0,"Share"],[10],[10],[0,"\\n"]],"parameters":[]}]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/actions-menu.hbs"}})}),define("client-app/templates/components/env-tab",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"5078JpTW",block:'{"symbols":[],"statements":[[4,"if",[[23,["isEnvArray"]]],null,{"statements":[[0," "],[7,"div"],[11,"class","nav-controls"],[9],[0,"\\n "],[7,"button"],[12,"disabled",[21,"disableBackButtons"]],[11,"class","btn nav-btn no-text"],[3,"action",[[22,0,[]],"bigJump","back"]],[9],[7,"i"],[11,"class","fa fa-fast-backward"],[9],[10],[10],[0,"\\n "],[7,"button"],[12,"disabled",[21,"disableBackButtons"]],[11,"class","btn nav-btn no-text"],[3,"action",[[22,0,[]],"takeStep","back"]],[9],[7,"i"],[11,"class","fa fa-backward"],[9],[10],[10],[0,"\\n "],[7,"span"],[11,"class","env-number"],[9],[1,[21,"current"],false],[0,"/"],[1,[23,["message","env","length"]],false],[10],[0,"\\n "],[7,"button"],[12,"disabled",[21,"disableForwardButtons"]],[11,"class","btn nav-btn no-text"],[3,"action",[[22,0,[]],"takeStep","front"]],[9],[7,"i"],[11,"class","fa fa-forward"],[9],[10],[10],[0,"\\n "],[7,"button"],[12,"disabled",[21,"disableForwardButtons"]],[11,"class","btn nav-btn no-text"],[3,"action",[[22,0,[]],"bigJump","front"]],[9],[7,"i"],[11,"class","fa fa-fast-forward"],[9],[10],[10],[0,"\\n "],[10],[0,"\\n"]],"parameters":[]},null],[1,[21,"html"],true],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/env-tab.hbs"}})}),define("client-app/templates/components/message-info",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"SK12lkYh",block:'{"symbols":["btn"],"statements":[[7,"div"],[11,"class","message-info"],[9],[0,"\\n"],[4,"tabbed-section",null,null,{"statements":[[4,"tab-contents",null,[["name","hint","currentMessage"],["info","show info",[23,["currentMessage"]]]],{"statements":[[4,"if",[[23,["showTitle"]]],null,{"statements":[[0," "],[7,"h3"],[9],[0,"Message\\n"],[4,"if",[[23,["currentMessage","showCount"]]],null,{"statements":[[0," ("],[1,[23,["currentMessage","count"]],false],[0," copies reported)\\n"]],"parameters":[]},null],[0," "],[10],[0,"\\n"]],"parameters":[]},null],[0," "],[7,"pre"],[9],[1,[23,["currentMessage","message"]],false],[10],[0,""]],"parameters":[]},null],[4,"tab-contents",null,[["name","defaultTab","hint","currentMessage"],["backtrace","true","show backtrace",[23,["currentMessage"]]]],{"statements":[[4,"if",[[23,["showTitle"]]],null,{"statements":[[0," "],[7,"h3"],[9],[0,"Backtrace"],[10],[0,"\\n"]],"parameters":[]},null],[0," "],[7,"pre"],[9],[1,[23,["currentMessage","backtrace"]],false],[10],[0,""]],"parameters":[]},null],[4,"if",[[23,["currentMessage","env"]]],null,{"statements":[[4,"tab-contents",null,[["className","name","hint","currentMessage"],["env","env","show environment",[23,["currentMessage"]]]],{"statements":[[4,"if",[[23,["showTitle"]]],null,{"statements":[[0," "],[7,"h3"],[9],[0,"Env"],[10],[0,"\\n"]],"parameters":[]},null],[0," "],[1,[27,"env-tab",null,[["message"],[[23,["currentMessage"]]]]],false],[0,"\\n"]],"parameters":[]},null]],"parameters":[]},null]],"parameters":[]},null],[0,"\\n"],[4,"if",[[23,["currentMessage"]]],null,{"statements":[[0," "],[7,"div"],[11,"class","message-actions"],[9],[0,"\\n"],[4,"actions-menu",null,[["actionsInMenu","share"],[[23,["actionsInMenu"]],[27,"action",[[22,0,[]],"share"],null]]],{"statements":[[4,"each",[[23,["buttons"]]],null,{"statements":[[0," "],[7,"button"],[12,"class",[28,[[22,1,["klass"]]," btn ",[27,"if",[[22,1,["danger"]],"danger",""],null]]]],[3,"action",[[22,0,[]],[22,1,["action"]]]],[9],[0,"\\n "],[7,"i"],[12,"class",[28,["fa fa-",[22,1,["icon"]]]]],[9],[10],[0,"\\n "],[7,"span"],[9],[1,[22,1,["label"]],false],[10],[0,"\\n "],[10],[0,"\\n"]],"parameters":[1]},null]],"parameters":[]},null],[0," "],[10],[0,"\\n"]],"parameters":[]},null],[10],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/message-info.hbs"}})}),define("client-app/templates/components/message-row",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"pF0hQ9a+",block:'{"symbols":[],"statements":[[7,"div"],[11,"class","count"],[9],[0,"\\n"],[4,"if",[[23,["model","showCount"]]],null,{"statements":[[0," "],[1,[23,["model","count"]],false],[0,"\\n"]],"parameters":[]},null],[10],[0,"\\n"],[7,"div"],[11,"class","severity"],[9],[1,[23,["model","glyph"]],true],[10],[0,"\\n"],[7,"div"],[11,"class","message-body"],[9],[0,"\\n "],[1,[23,["model","displayMessage"]],false],[0,"\\n"],[10],[0,"\\n"],[7,"div"],[11,"class","protected"],[9],[0,"\\n"],[4,"if",[[23,["model","protected"]]],null,{"statements":[[0," "],[7,"i"],[11,"title","message is protected, clearing will not remove it"],[11,"class","fa fa-lock"],[9],[10],[0,"\\n"]],"parameters":[]},null],[10],[0,"\\n"],[7,"div"],[11,"class","time"],[9],[1,[27,"time-formatter",null,[["timestamp"],[[23,["model","timestamp"]]]]],false],[10],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/message-row.hbs"}})}),define("client-app/templates/components/panel-resizer",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"FLUzT7ST",block:'{"symbols":[],"statements":[[7,"div"],[11,"class","line-1"],[9],[10],[0,"\\n"],[7,"div"],[11,"class","line-2"],[9],[10],[0,"\\n"],[7,"div"],[11,"class","line-3"],[9],[10],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/panel-resizer.hbs"}})}),define("client-app/templates/components/tabbed-section",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"nreTgL17",block:'{"symbols":["tab","&default"],"statements":[[14,2],[0,"\\n"],[7,"ul"],[11,"class","tabs"],[9],[0,"\\n"],[4,"each",[[23,["tabs"]]],null,{"statements":[[0," "],[7,"li"],[9],[0,"\\n "],[7,"a"],[12,"title",[28,[[27,"unbound",[[22,1,["hint"]]],null]]]],[11,"href","#"],[12,"class",[28,[[27,"if",[[22,1,["active"]],"active"],null]]]],[3,"action",[[22,0,[]],[23,["selectTab"]],[22,1,[]]]],[9],[0,"\\n "],[1,[27,"unbound",[[22,1,["name"]]],null],false],[0,"\\n "],[10],[0,"\\n "],[10],[0,"\\n"]],"parameters":[1]},null],[10],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/tabbed-section.hbs"}})}),define("client-app/templates/components/time-formatter",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"sp53cTcH",block:'{"symbols":[],"statements":[[1,[21,"time"],false],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/components/time-formatter.hbs"}})}),define("client-app/templates/index",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"whComJMa",block:'{"symbols":["message"],"statements":[[7,"div"],[11,"id","top-panel"],[9],[0,"\\n "],[7,"div"],[11,"id","log-table"],[9],[0,"\\n"],[4,"if",[[23,["model","moreBefore"]]],null,{"statements":[[0," "],[7,"div"],[11,"class","show-more"],[3,"action",[[22,0,[]],"showMoreBefore"]],[9],[0,"\\n"],[4,"if",[[23,["model","hideCountInLoadMore"]]],null,{"statements":[[0," Load more\\n"]],"parameters":[]},{"statements":[[0," Select to see "],[1,[23,["model","totalBefore"]],false],[0," more\\n"]],"parameters":[]}],[0," "],[10],[0,"\\n"]],"parameters":[]},null],[4,"each",[[23,["model","messages"]]],null,{"statements":[[0," "],[1,[27,"message-row",null,[["model","selectedMessage"],[[22,1,[]],[27,"action",[[22,0,[]],"selectMessage"],null]]]],false],[0,"\\n"]],"parameters":[1]},null],[0," "],[10],[0,"\\n"],[10],[0,"\\n"],[7,"div"],[11,"id","bottom-panel"],[9],[0,"\\n "],[1,[27,"message-info",null,[["currentMessage","removeMessage","solveMessage","actionsInMenu"],[[23,["currentMessage"]],[27,"action",[[22,0,[]],"removeMessage"],null],[27,"action",[[22,0,[]],"solveMessage"],null],[23,["actionsInMenu"]]]]],false],[0,"\\n\\n "],[7,"div"],[11,"class","action-panel"],[9],[0,"\\n "],[7,"div"],[11,"class","severity-filters"],[9],[0,"\\n "],[7,"div"],[11,"class","more-wrapping"],[9],[0,"\\n "],[7,"label"],[11,"class","debug"],[9],[0,"\\n "],[1,[27,"input",null,[["type","checked"],["checkbox",[23,["showDebug"]]]]],false],[0,"\\n "],[7,"span"],[9],[0,"Debug"],[10],[0,"\\n "],[10],[0,"\\n "],[7,"label"],[11,"class","info"],[9],[0,"\\n "],[1,[27,"input",null,[["type","checked"],["checkbox",[23,["showInfo"]]]]],false],[0,"\\n "],[7,"span"],[9],[0,"Info"],[10],[0,"\\n "],[10],[0,"\\n "],[7,"label"],[11,"class","warn"],[9],[0,"\\n "],[1,[27,"input",null,[["type","checked"],["checkbox",[23,["showWarn"]]]]],false],[0,"\\n "],[7,"i"],[11,"class","fa fa-exclamation-circle warning"],[9],[10],[0,"\\n "],[7,"span"],[9],[0,"Warning"],[10],[0,"\\n "],[10],[0,"\\n "],[7,"label"],[11,"class","error"],[9],[0,"\\n "],[1,[27,"input",null,[["type","checked"],["checkbox",[23,["showErr"]]]]],false],[0,"\\n "],[7,"i"],[11,"class","fa fa-times-circle error"],[9],[10],[0,"\\n "],[7,"span"],[9],[0,"Error"],[10],[0,"\\n "],[10],[0,"\\n "],[7,"label"],[11,"class","fatal"],[9],[0,"\\n "],[1,[27,"input",null,[["type","checked"],["checkbox",[23,["showFatal"]]]]],false],[0,"\\n "],[7,"i"],[11,"class","fa fa-times-circle fatal"],[9],[10],[0,"\\n "],[7,"span"],[9],[0,"Fatal"],[10],[0,"\\n "],[10],[0,"\\n "],[10],[0,"\\n "],[10],[0,"\\n "],[7,"div"],[11,"class","search-clear-all"],[9],[0,"\\n "],[1,[27,"input",null,[["type","class","placeholder","value"],["textfield","search","Search",[23,["search"]]]]],false],[0,"\\n "],[7,"button"],[11,"class","clear btn danger"],[3,"action",[[22,0,[]],"clear"]],[9],[7,"i"],[11,"class","fa fa-times"],[9],[10],[7,"span"],[9],[0,"Clear logs"],[10],[10],[0,"\\n "],[10],[0,"\\n "],[10],[0,"\\n"],[10],[0,"\\n"],[1,[21,"panel-resizer"],false],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/index.hbs"}})}),define("client-app/templates/show",["exports"],function(e){Object.defineProperty(e,"__esModule",{value:!0}),e.default=Ember.HTMLBars.template({id:"V916vpg9",block:'{"symbols":[],"statements":[[4,"link-to",["index"],null,{"statements":[[0,"Recent"]],"parameters":[]},null],[0,"\\n"],[7,"div"],[11,"id","bottom-panel"],[11,"class","full"],[9],[0,"\\n "],[1,[27,"message-info",null,[["currentMessage","showTitle","actionsInMenu"],[[23,["model"]],"true",false]]],false],[0,"\\n"],[10],[0,"\\n"]],"hasEval":false}',meta:{moduleName:"client-app/templates/show.hbs"}})}),define("client-app/config/environment",[],function(){try{var e="client-app/config/environment",t=document.querySelector('meta[name="'+e+'"]').getAttribute("content"),n={default:JSON.parse(unescape(t))}
100
- return Object.defineProperty(n,"__esModule",{value:!0}),n}catch(a){throw new Error('Could not read config from meta tag with name "'+e+'".')}}),runningTests||require("client-app/app").default.create({name:"client-app",version:"0.0.0+9e5a1fad"})
100
+ return Object.defineProperty(n,"__esModule",{value:!0}),n}catch(a){throw new Error('Could not read config from meta tag with name "'+e+'".')}}),runningTests||require("client-app/app").default.create({name:"client-app",version:"0.0.0+8710f335"})
@@ -1 +1 @@
1
- .divider,.message-info{border-bottom:1px solid #ddd}body{font-family:Roboto,Arial,"Liberation Sans","DejaVu Sans",sans-serif;font-size:12px}body.mobile,body.mobile .message{font-size:14px}pre{font-family:"Roboto Mono",Consolas,Monaco,Ubuntu Mono,monospace}table.env-table tbody tr td{border-top:none;line-height:18px;vertical-align:top}table.env-table,table.env-table table{border-spacing:0;border-collapse:collapse}table.env-table td{padding-right:5px}tbody tr{width:98%}.message-row{display:flex}.message-row .protected,.message-row .severity{text-align:center;width:25px;flex-grow:0;flex-shrink:0;font-size:12px}.message-row div{border-top:.5px #e9e9e9 solid;padding-top:1px;padding-bottom:1px;line-height:25px}.message-row .count{width:30px;flex-grow:0;flex-shrink:0;padding-right:4px;box-sizing:border-box;font-size:11px;font-weight:700;text-align:right}.message-row .message-body{flex-grow:1;flex-shrink:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:13px}.message-row .time{flex-grow:0;flex-shrink:0;color:#999;vertical-align:top;font-size:12px;padding-right:8px}.action-panel .clear,.action-panel .search,.action-panel i.fa,.btn .fa,.btn span,input,label span{vertical-align:middle}.message-row:hover{background-color:#f8f8f8;cursor:pointer}.message-row.selected{background-color:#dfdfdf}i.fatal{color:#e00}i.error{color:#900}i.warning{color:#feb800}.debug{color:#777}.btn,.tabs a{text-decoration:none;color:#333}.action-panel .search{border:1px solid #ddd;padding:3px;box-sizing:border-box}#log-table .show-more{text-align:center;height:30px;line-height:30px;text-decoration:none;background-color:#ddd;cursor:pointer;margin-top:8px}#overlay,.divider{cursor:row-resize}#bottom-panel{position:fixed;bottom:0;left:0;right:0;height:300px;background-color:#f1f1f1;padding:0 8px 8px;z-index:2}#bottom-panel.full{position:static;background-color:inherit;height:90%}#bottom-panel.full>div{padding-bottom:40px}#bottom-panel.full .tabs{display:none}#bottom-panel.full .message-info{position:static}#bottom-panel.full .message-info .content{display:block;position:static}#bottom-panel.full button.delete,.hidden{display:none}#bottom-panel.full .save,#bottom-panel.full .share{bottom:10px}#bottom-panel.full .message-actions button{margin-top:8px}#bottom-panel.full .message-actions{position:fixed;height:40px;width:100%;left:0;bottom:0;background-color:#eee;border-top:1px solid #dfdfdf;padding-left:10px}.divider,.tabs{border-top:1px solid #ddd}.message-actions{position:absolute;bottom:5px;right:0;margin-right:10px}.message-actions button{margin-left:5px}.divider{position:fixed;bottom:310px;left:0;right:0;height:15px;background-color:#fafafa}.divider div{margin:auto;width:24px;height:1px;background-color:#ccc;position:relative}.divider .line-1{top:5px}.divider .line-2{top:6px}.divider .line-3{top:7px}#top-panel{position:fixed;top:0;left:0;right:0;bottom:320px;overflow:auto}.action-panel,.message-info{position:absolute;left:0;right:0}.message-info{top:0}.action-panel{bottom:0;font-weight:700}.action-panel input{margin:0}.severity-filters label{margin-right:18px}.action-panel .clear{float:right}#log-table{margin:auto;width:99%}.message-info .env-table,.message-info pre{position:relative;margin:10px}#overlay{position:fixed;z-index:99999;top:0;bottom:0;left:0;right:0;opacity:0}.message-info .content,.tabs{position:absolute;left:0;right:0}.message-info .content{top:0;bottom:35px;overflow:auto;display:none}.message-info .content.active{display:block}.tabs{bottom:13px;list-style-type:none;margin:0 0 5px;padding:0 0 0 10px}.tabs a,.tabs li{position:relative}.tabs li{float:left;padding-right:5px;margin:0}.tabs a{top:6px;border:1px solid #ddd;border-top:none;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:6px;background-color:#e1e1e1}.tabs a.active{border-top:1px solid #f1f1f1;background-color:#f1f1f1}.btn{display:inline-block;margin:0;padding:5px 12px;font-size:1em;line-height:0;text-align:center;cursor:pointer;transition:all .25s;background-color:#ddd;border:none;font-weight:400}.btn:hover{color:#000;background-color:#ccc}.btn .fa{margin-right:7px}.btn:active{text-shadow:none}.btn.danger:hover{background-color:#c63c1b;color:#eee}.search-clear-all .clear,.search-clear-all .search{height:24px}.search-clear-all .clear,.search-clear-all .search,.severity-filters label{align-self:center}.search-clear-all .clear{margin-left:auto}@media (min-width:701px){.search-clear-all,.severity-filters{height:100%}.more-wrapping,.search-clear-all,.severity-filters{display:flex}.severity-filters{float:left}.action-panel{padding:10px;box-sizing:border-box;height:42px}.message-info{bottom:42px}}@media (max-width:700px){.severity-filters{padding:10px}.search-clear-all{padding:0 10px 10px}.action-panel{height:69px}.message-info{bottom:69px}}@media (max-width:415px){.severity-filters{overflow-x:scroll;overflow-y:hidden;white-space:nowrap}.more-wrapping:after,.more-wrapping:before{content:"";position:absolute;height:18px}.more-wrapping:before{width:15px;margin-left:-10px;background:linear-gradient(to right,#f1f1f1 0,rgba(241,241,241,.001) 100%)}.more-wrapping:after{right:0;width:23px;background:linear-gradient(to left,#f1f1f1 0,rgba(241,241,241,.001) 100%)}}.btn.no-text .fa{margin:0}.btn[disabled]{opacity:.5}.actions-menu{position:absolute;background:#fafafa;display:inline-flex;flex-direction:column;bottom:27px;right:45px;width:115px;padding:5px 5px 0;box-shadow:0 4px 14px rgba(0,0,0,.15)}.actions-menu button{margin:0 0 5px;height:27px}.nav-controls{margin:10px}.env-number{margin:0 7px}
1
+ .divider,.message-info{border-bottom:1px solid #ddd}body{font-family:Roboto,Arial,"Liberation Sans","DejaVu Sans",sans-serif;font-size:12px}body.mobile,body.mobile .message{font-size:14px}pre{font-family:"Roboto Mono",Consolas,Monaco,Ubuntu Mono,monospace}table.env-table tbody tr td{border-top:none;line-height:18px;vertical-align:top}table.env-table,table.env-table table{border-spacing:0;border-collapse:collapse}table.env-table td{padding-right:5px}tbody tr{width:98%}.message-row{display:flex}.message-row .protected,.message-row .severity{text-align:center;width:25px;flex-grow:0;flex-shrink:0;font-size:12px}.message-row div{border-top:.5px #e9e9e9 solid;padding-top:1px;padding-bottom:1px;line-height:25px}.message-row .count{width:30px;flex-grow:0;flex-shrink:0;padding-right:4px;box-sizing:border-box;font-size:11px;font-weight:700;text-align:right}.message-row .message-body{flex-grow:1;flex-shrink:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:13px}.message-row .time{flex-grow:0;flex-shrink:0;color:#999;vertical-align:top;font-size:12px;padding-right:8px}.action-panel .clear,.action-panel .search,.action-panel i.fa,.btn .fa,.btn span,input,label span{vertical-align:middle}.message-row:hover{background-color:#f8f8f8;cursor:pointer}.message-row.selected{background-color:#dfdfdf}i.fatal{color:#e00}i.error{color:#900}i.warning{color:#feb800}.debug{color:#777}.btn,.tabs a{text-decoration:none;color:#333}.action-panel .search{border:1px solid #ddd;padding:3px;box-sizing:border-box}#log-table .show-more{text-align:center;height:30px;line-height:30px;text-decoration:none;background-color:#ddd;cursor:pointer;margin-top:8px}#overlay,.divider{cursor:row-resize}#bottom-panel{position:fixed;bottom:0;left:0;right:0;height:300px;background-color:#f1f1f1;padding:0 8px 8px;z-index:2}#bottom-panel.full{position:static;background-color:inherit;height:90%}#bottom-panel.full>div{padding-bottom:40px}#bottom-panel.full .tabs{display:none}#bottom-panel.full .message-info{position:static}#bottom-panel.full .message-info .content{display:block;position:static}#bottom-panel.full button.delete,.hidden{display:none}#bottom-panel.full .save,#bottom-panel.full .share{bottom:10px}#bottom-panel.full .message-actions button{margin-top:8px}#bottom-panel.full .message-actions{position:fixed;height:40px;width:100%;left:0;bottom:0;background-color:#eee;border-top:1px solid #dfdfdf;padding-left:10px}.divider,.tabs{border-top:1px solid #ddd}.message-actions{position:absolute;bottom:5px;right:0;margin-right:10px}.message-actions button{margin-left:5px}.divider{position:fixed;bottom:310px;left:0;right:0;height:15px;background-color:#fafafa}.divider div{margin:auto;width:24px;height:1px;background-color:#ccc;position:relative}.divider .line-1{top:5px}.divider .line-2{top:6px}.divider .line-3{top:7px}#top-panel{position:fixed;top:0;left:0;right:0;bottom:320px;overflow:auto}.action-panel,.message-info{position:absolute;left:0;right:0}.message-info{top:0}.action-panel{bottom:0;font-weight:700}.action-panel input{margin:0}.severity-filters label{margin-right:18px}.action-panel .clear{float:right}#log-table{margin:auto;width:99%}.message-info .env-table,.message-info pre{position:relative;margin:5px 10px 10px}#overlay{position:fixed;z-index:99999;top:0;bottom:0;left:0;right:0;opacity:0}.message-info .content,.tabs{position:absolute;left:0;right:0}.message-info .content{top:0;bottom:35px;overflow:auto;display:none}.message-info .content.active{display:block}.tabs{bottom:13px;list-style-type:none;margin:0 0 5px;padding:0 0 0 10px}.tabs a,.tabs li{position:relative}.tabs li{float:left;padding-right:5px;margin:0}.tabs a{top:6px;border:1px solid #ddd;border-top:none;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:6px;background-color:#e1e1e1}.tabs a.active{border-top:1px solid #f1f1f1;background-color:#f1f1f1}.btn{display:inline-block;margin:0;padding:5px 12px;font-size:1em;line-height:0;text-align:center;cursor:pointer;transition:all .25s;background-color:#ddd;border:none;font-weight:400}.btn:hover{color:#000;background-color:#ccc}.btn .fa{margin-right:7px}.btn:active{text-shadow:none}.btn.danger:hover{background-color:#c63c1b;color:#eee}.search-clear-all .clear,.search-clear-all .search{height:24px}.search-clear-all .clear,.search-clear-all .search,.severity-filters label{align-self:center}.search-clear-all .clear{margin-left:auto}@media (min-width:701px){.search-clear-all,.severity-filters{height:100%}.more-wrapping,.search-clear-all,.severity-filters{display:flex}.severity-filters{float:left}.action-panel{padding:10px;box-sizing:border-box;height:42px}.message-info{bottom:42px}}@media (max-width:700px){.severity-filters{padding:10px}.search-clear-all{padding:0 10px 10px}.action-panel{height:69px}.message-info{bottom:69px}}@media (max-width:415px){.severity-filters{overflow-x:scroll;overflow-y:hidden;white-space:nowrap}.more-wrapping:after,.more-wrapping:before{content:"";position:absolute;height:18px}.more-wrapping:before{width:15px;margin-left:-10px;background:linear-gradient(to right,#f1f1f1 0,rgba(241,241,241,.001) 100%)}.more-wrapping:after{right:0;width:23px;background:linear-gradient(to left,#f1f1f1 0,rgba(241,241,241,.001) 100%)}}.btn.no-text .fa{margin:0}.btn[disabled]{opacity:.5}.actions-menu{position:absolute;background:#fafafa;display:inline-flex;flex-direction:column;bottom:27px;right:45px;width:115px;padding:5px 5px 0;box-shadow:0 4px 14px rgba(0,0,0,.15);z-index:3}.actions-menu button{margin:0 0 5px;height:27px}.nav-controls{padding:10px}#bottom-panel:not(.full) .nav-controls{position:sticky;top:0;background:#f1f1f1;z-index:1;border-bottom:1px solid #ddd}.env-number{margin:0 7px}
@@ -289,6 +289,7 @@ label span {
289
289
  .message-info .env-table {
290
290
  position: relative;
291
291
  margin: 10px;
292
+ margin-top: 5px;
292
293
  }
293
294
 
294
295
  #overlay {
@@ -490,6 +491,7 @@ label span {
490
491
  padding: 5px;
491
492
  padding-bottom: 0px;
492
493
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
494
+ z-index: 3;
493
495
  }
494
496
 
495
497
  .actions-menu button {
@@ -498,7 +500,15 @@ label span {
498
500
  }
499
501
 
500
502
  .nav-controls {
501
- margin: 10px 10px;
503
+ padding: 10px;
504
+ }
505
+
506
+ #bottom-panel:not(.full) .nav-controls {
507
+ position: sticky;
508
+ top: 0;
509
+ background: #f1f1f1;
510
+ z-index: 1;
511
+ border-bottom: 1px solid #ddd;
502
512
  }
503
513
 
504
514
  .env-number {
@@ -1,5 +1,5 @@
1
1
  class SidekiqLogsterReporter
2
- def call(ex, context={})
2
+ def call(ex, context = {})
3
3
  # Pass context to Logster
4
4
  fake_env = {}
5
5
  context.each do |key, value|
@@ -21,7 +21,7 @@ module Logster
21
21
  end
22
22
 
23
23
  def self.store=(store)
24
- @store=store
24
+ @store = store
25
25
  end
26
26
 
27
27
  def self.store
@@ -14,7 +14,7 @@ module Logster
14
14
  end
15
15
 
16
16
  # Modify the saved message to the given one (identified by message.key) and bump it to the top of the latest list
17
- def replace_and_bump(message)
17
+ def replace_and_bump(message, save_env: true)
18
18
  not_implemented
19
19
  end
20
20
 
@@ -40,7 +40,17 @@ module Logster
40
40
  end
41
41
 
42
42
  # Get a message by its message_key
43
- def get(message_key)
43
+ def get(message_key, load_env: true)
44
+ not_implemented
45
+ end
46
+
47
+ # Get a group of messages by their message_keys
48
+ def bulk_get(message_keys)
49
+ not_implemented
50
+ end
51
+
52
+ # Get a message's env by its message_key
53
+ def get_env(message_key)
44
54
  not_implemented
45
55
  end
46
56
 
@@ -98,19 +108,23 @@ module Logster
98
108
  message.backtrace = caller.join("\n")
99
109
  end
100
110
 
101
- return if ignore && ignore.any? { |pattern| message =~ pattern}
111
+ return if ignore && ignore.any? { |pattern| message =~ pattern }
102
112
 
103
113
  similar = nil
104
114
 
105
115
  if Logster.config.allow_grouping
106
116
  key = self.similar_key(message)
107
- similar = get key if key
117
+ similar = get(key, load_env: false) if key
108
118
  end
109
119
 
110
120
  if similar
111
- similar.merge_similar_message(message)
121
+ has_env = !similar.env.nil? && !similar.env.empty?
122
+ if similar.count < Logster::MAX_GROUPING_LENGTH && !has_env
123
+ similar.env = get_env(similar.key) || {}
124
+ end
125
+ save_env = similar.merge_similar_message(message)
112
126
 
113
- replace_and_bump similar
127
+ replace_and_bump(similar, save_env: save_env || has_env)
114
128
  similar
115
129
  else
116
130
  save message
@@ -7,7 +7,7 @@ module Logster
7
7
 
8
8
  def initialize
9
9
  # lambda |env,block|
10
- @current_context = lambda{ |_, &block| block.call }
10
+ @current_context = lambda { |_, &block| block.call }
11
11
  @environments = [:development, :production]
12
12
  @subdirectory = nil
13
13
 
@@ -1,13 +1,13 @@
1
1
  module Logster
2
2
  class IgnorePattern
3
3
 
4
- def initialize(message_pattern=nil, env_patterns=nil)
4
+ def initialize(message_pattern = nil, env_patterns = nil)
5
5
  @msg_match = message_pattern
6
6
  @env_match = env_patterns
7
7
  end
8
8
 
9
9
  def self.from_message_and_request_uri(msg, request)
10
- IgnorePattern.new(msg, {REQUEST_URI: request})
10
+ IgnorePattern.new(msg, REQUEST_URI: request)
11
11
  end
12
12
 
13
13
  def matches?(message)
@@ -32,18 +32,18 @@ module Logster
32
32
  return false unless message && pattern
33
33
 
34
34
  case pattern
35
- when Regexp
36
- message.to_s =~ pattern
37
- when String
38
- message.to_s =~ Regexp.new(pattern, Regexp::IGNORECASE)
39
- when Hash
40
- if Hash === message
41
- compare_hash(message, pattern)
42
- else
43
- false
44
- end
35
+ when Regexp
36
+ message.to_s =~ pattern
37
+ when String
38
+ message.to_s =~ Regexp.new(pattern, Regexp::IGNORECASE)
39
+ when Hash
40
+ if Hash === message
41
+ compare_hash(message, pattern)
45
42
  else
46
43
  false
44
+ end
45
+ else
46
+ false
47
47
  end
48
48
  end
49
49
 
@@ -31,7 +31,7 @@ module Logster
31
31
  @chained << logger
32
32
  end
33
33
 
34
- def add_to_chained(logger, severity, message, progname, opts=nil, &block)
34
+ def add_to_chained(logger, severity, message, progname, opts = nil, &block)
35
35
  if logger.respond_to? :skip_store
36
36
  old = logger.skip_store
37
37
  logger.skip_store = @skip_store
@@ -49,7 +49,7 @@ module Logster
49
49
  end
50
50
 
51
51
  def add(*args, &block)
52
- add_with_opts(*args,&block)
52
+ add_with_opts(*args, &block)
53
53
  end
54
54
 
55
55
  def level
@@ -57,7 +57,7 @@ module Logster
57
57
  (ol && ol[Thread.current.object_id]) || @level
58
58
  end
59
59
 
60
- def add_with_opts(severity, message, progname=progname(), opts=nil, &block)
60
+ def add_with_opts(severity, message, progname = progname(), opts = nil, &block)
61
61
  if severity < level
62
62
  return true
63
63
  end
@@ -35,7 +35,7 @@ module Logster
35
35
  @first_timestamp = nil
36
36
  end
37
37
 
38
- def to_h
38
+ def to_h(exclude_env: false)
39
39
  h = {
40
40
  message: @message,
41
41
  progname: @progname,
@@ -44,28 +44,27 @@ module Logster
44
44
  key: @key,
45
45
  backtrace: @backtrace,
46
46
  count: @count,
47
- env: @env,
48
47
  protected: @protected
49
48
  }
50
49
 
51
- if @first_timestamp
52
- h[:first_timestamp] = @first_timestamp
53
- end
50
+ h[:first_timestamp] = @first_timestamp if @first_timestamp
51
+ h[:env] = @env unless exclude_env
54
52
 
55
53
  h
56
54
  end
57
55
 
58
56
  def to_json(opts = nil)
59
- JSON.fast_generate(to_h, opts)
57
+ exclude_env = Hash === opts && opts.delete(:exclude_env)
58
+ JSON.fast_generate(to_h(exclude_env: exclude_env), opts)
60
59
  end
61
60
 
62
61
  def self.from_json(json)
63
62
  parsed = ::JSON.parse(json)
64
- msg = new( parsed["severity"],
63
+ msg = new(parsed["severity"],
65
64
  parsed["progname"],
66
65
  parsed["message"],
67
66
  parsed["timestamp"],
68
- parsed["key"] )
67
+ parsed["key"])
69
68
  msg.backtrace = parsed["backtrace"]
70
69
  msg.env = parsed["env"]
71
70
  msg.count = parsed["count"]
@@ -132,8 +131,10 @@ module Logster
132
131
 
133
132
  def merge_similar_message(other)
134
133
  self.first_timestamp ||= self.timestamp
135
- self.timestamp = [self.timestamp,other.timestamp].max
134
+ self.timestamp = [self.timestamp, other.timestamp].max
135
+
136
136
  self.count += other.count || 1
137
+ return false if self.count > Logster::MAX_GROUPING_LENGTH
137
138
 
138
139
  other_env = JSON.load JSON.fast_generate other.env
139
140
  if Array === self.env
@@ -141,6 +142,7 @@ module Logster
141
142
  else
142
143
  Array === other_env ? self.env = [self.env, *other_env] : self.env = [self.env, other_env]
143
144
  end
145
+ true
144
146
  end
145
147
 
146
148
  def self.populate_from_env(env)
@@ -162,7 +164,7 @@ module Logster
162
164
  scrubbed = default_env
163
165
  request = Rack::Request.new(env)
164
166
  params = {}
165
- request.params.each do |k,v|
167
+ request.params.each do |k, v|
166
168
  if k.include? "password"
167
169
  params[k] = "[redacted]"
168
170
  elsif Array === v
@@ -172,8 +174,8 @@ module Logster
172
174
  end
173
175
  end
174
176
  scrubbed["params"] = params if params.length > 0
175
- ALLOWED_ENV.map{ |k|
176
- scrubbed[k] = env[k] if env[k]
177
+ ALLOWED_ENV.map { |k|
178
+ scrubbed[k] = env[k] if env[k]
177
179
  }
178
180
  scrubbed
179
181
  end
@@ -188,16 +190,16 @@ module Logster
188
190
 
189
191
  def =~(pattern)
190
192
  case pattern
191
- when Hash
192
- IgnorePattern.new(nil, pattern).matches? self
193
- when String
194
- IgnorePattern.new(pattern, nil).matches? self
195
- when Regexp
196
- IgnorePattern.new(pattern, nil).matches? self
197
- when IgnorePattern
198
- pattern.matches? self
193
+ when Hash
194
+ IgnorePattern.new(nil, pattern).matches? self
195
+ when String
196
+ IgnorePattern.new(pattern, nil).matches? self
197
+ when Regexp
198
+ IgnorePattern.new(pattern, nil).matches? self
199
+ when IgnorePattern
200
+ pattern.matches? self
199
201
  else
200
- nil
202
+ nil
201
203
  end
202
204
  end
203
205
 
@@ -206,48 +208,5 @@ module Logster
206
208
  def get_timestamp
207
209
  (Time.new.to_f * 1000).to_i
208
210
  end
209
-
210
- private
211
-
212
- def self.env_merge_helper(self_value, other_value)
213
- other_value = other_value.to_s if Symbol === other_value
214
-
215
- if (Hash === self_value || self_value.nil?) && (Hash === other_value || other_value.nil?) && (!self_value.nil? || !other_value.nil?)
216
- # one or both is a hash but not neither -> recurse on the keys
217
- self_value = {} unless self_value
218
- other_value = {} unless other_value
219
- shared_keys = self_value.keys | (other_value.keys rescue [])
220
- shared_keys.each do |key|
221
- self_value[key] = env_merge_helper(self_value[key], other_value[key])
222
- end
223
- self_value
224
- elsif self_value.is_a?(Array) && !other_value.is_a?(Array)
225
- # Already have grouped data, so append to array (it's actually a set)
226
- self_value << other_value unless self_value.include?(other_value) || self_value.length >= Logster::MAX_GROUPING_LENGTH
227
- self_value
228
- elsif !self_value.is_a?(Array)
229
- if self_value == other_value
230
- self_value
231
- else
232
- [self_value, other_value]
233
- end
234
- else
235
- # They're both arrays.
236
- # Three cases:
237
- # self = [1,2,3] and other = [1,2,4] -> make into array of array
238
- # self = [] and other = [1,2,4] -> make into array of array
239
- # self = [[1,2,3], [1,2,5]] and other = [1,2,4] -> append to array
240
- if self_value.length > 0 && self_value[0].is_a?(Array)
241
- self_value << other_value unless self_value.include?(other_value) || self_value.length >= Logster::MAX_GROUPING_LENGTH
242
- self_value
243
- else
244
- if self_value == other_value
245
- self_value
246
- else
247
- [self_value, other_value]
248
- end
249
- end
250
- end
251
- end
252
211
  end
253
212
  end
@@ -5,7 +5,7 @@ module Logster
5
5
  PATH_INFO = "PATH_INFO".freeze
6
6
  SCRIPT_NAME = "SCRIPT_NAME".freeze
7
7
 
8
- def initialize(app, config={})
8
+ def initialize(app, config = {})
9
9
  @app = app
10
10
  @error_path = Logster.config.subdirectory + '/report_js_error'
11
11
  end
@@ -13,7 +13,6 @@ module Logster
13
13
  def call(env)
14
14
  Thread.current[Logster::Logger::LOGSTER_ENV] = env
15
15
 
16
-
17
16
  path = env[PATH_INFO]
18
17
  script_name = env[SCRIPT_NAME]
19
18
 
@@ -25,7 +24,7 @@ module Logster
25
24
  Logster.config.current_context.call(env) do
26
25
  report_js_error(env)
27
26
  end
28
- return [200,{},["OK"]]
27
+ return [200, {}, ["OK"]]
29
28
  end
30
29
 
31
30
  @app.call(env)
@@ -13,7 +13,7 @@ module Logster
13
13
 
14
14
  @logs_path = Logster.config.subdirectory
15
15
  @path_regex = Regexp.new("^(#{@logs_path}$)|^(#{@logs_path}(/.*))$")
16
- @store = Logster.store or raise ArgumentError.new("store")
16
+ (@store = Logster.store) || raise(ArgumentError.new("store"))
17
17
 
18
18
  @assets_path = File.expand_path("../../../../assets", __FILE__)
19
19
  @fileserver = Rack::File.new(@assets_path)
@@ -46,7 +46,7 @@ module Logster
46
46
  end
47
47
 
48
48
  Logster.store.delete(message)
49
- return [301, {"Location" => "#{@logs_path}/"}, []]
49
+ return [301, { "Location" => "#{@logs_path}/" }, []]
50
50
 
51
51
  elsif resource =~ /\/(un)?protect\/([0-9a-f]+)$/
52
52
  off = $1 == "un"
@@ -59,13 +59,13 @@ module Logster
59
59
 
60
60
  if off
61
61
  if Logster.store.unprotect(key)
62
- return [301, {"Location" => "#{@logs_path}/show/#{key}?protected=false"}, []]
62
+ return [301, { "Location" => "#{@logs_path}/show/#{key}?protected=false" }, []]
63
63
  else
64
64
  return [500, {}, ["Failed"]]
65
65
  end
66
66
  else
67
67
  if Logster.store.protect(key)
68
- return [301, {"Location" => "#{@logs_path}/show/#{key}?protected=true"}, []]
68
+ return [301, { "Location" => "#{@logs_path}/show/#{key}?protected=true" }, []]
69
69
  else
70
70
  return [500, {}, ["Failed"]]
71
71
  end
@@ -81,7 +81,7 @@ module Logster
81
81
 
82
82
  Logster.store.solve(key)
83
83
 
84
- return [301, {"Location" => "#{@logs_path}"}, []]
84
+ return [301, { "Location" => "#{@logs_path}" }, []]
85
85
 
86
86
  elsif resource =~ /\/clear$/
87
87
  if env[REQUEST_METHOD] != "POST"
@@ -100,14 +100,14 @@ module Logster
100
100
  end
101
101
 
102
102
  if json
103
- [200, {"Content-Type" => "application/json; charset=utf-8"}, [message.to_json]]
103
+ [200, { "Content-Type" => "application/json; charset=utf-8" }, [message.to_json]]
104
104
  else
105
- preload = preload_json({"/show/#{key}" => message})
106
- [200, {"Content-Type" => "text/html; charset=utf-8"}, [body(preload)]]
105
+ preload = preload_json("/show/#{key}" => message)
106
+ [200, { "Content-Type" => "text/html; charset=utf-8" }, [body(preload)]]
107
107
  end
108
108
 
109
109
  elsif resource == "/"
110
- [200, {"Content-Type" => "text/html; charset=utf-8"}, [body(preload_json)]]
110
+ [200, { "Content-Type" => "text/html; charset=utf-8" }, [body(preload_json)]]
111
111
 
112
112
  else
113
113
  [404, {}, ["Not found"]]
@@ -134,8 +134,8 @@ module Logster
134
134
  after: params["after"]
135
135
  }
136
136
 
137
- if(filter = params["filter"])
138
- filter = filter.split("_").map{|s| s.to_i}
137
+ if (filter = params["filter"])
138
+ filter = filter.split("_").map { |s| s.to_i }
139
139
  opts[:severity] = filter
140
140
  end
141
141
 
@@ -152,7 +152,7 @@ module Logster
152
152
  }
153
153
 
154
154
  json = JSON.generate(payload)
155
- [200, {"Content-Type" => "application/json"}, [json]]
155
+ [200, { "Content-Type" => "application/json" }, [json]]
156
156
  end
157
157
 
158
158
  def parse_regex(string)
@@ -169,20 +169,20 @@ module Logster
169
169
  end
170
170
  end
171
171
 
172
- def preload_json(extra={})
172
+ def preload_json(extra = {})
173
173
  values = {}
174
174
  values.merge!(extra)
175
175
  end
176
176
 
177
- def css(name, attrs={})
178
- attrs = attrs.map do |k,v|
177
+ def css(name, attrs = {})
178
+ attrs = attrs.map do |k, v|
179
179
  "#{k}='#{v}'"
180
180
  end.join(" ")
181
181
 
182
182
  "<link rel='stylesheet' type='text/css' href='#{@logs_path}/stylesheets/#{name}' #{attrs}>"
183
183
  end
184
184
 
185
- def script(prod, dev=nil)
185
+ def script(prod, dev = nil)
186
186
  name = ENV['DEBUG_JS'] == "1" && dev ? dev : prod
187
187
  "<script src='#{@logs_path}/javascript/#{name}'></script>"
188
188
  end