2016-01-11 19:58:35 +00:00
/ *
Copyright 2016 Resin . io
Licensed under the Apache License , Version 2.0 ( the "License" ) ;
you may not use this file except in compliance with the License .
You may obtain a copy of the License at
http : //www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing , software
distributed under the License is distributed on an "AS IS" BASIS ,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND , either express or implied .
See the License for the specific language governing permissions and
limitations under the License .
* /
2015-02-26 15:47:56 +00:00
( function ( ) {
2015-05-18 13:37:27 +00:00
module . exports = {
2015-02-26 15:47:56 +00:00
signature : 'logs <uuid>' ,
description : 'show device logs' ,
2015-07-22 22:06:53 +00:00
help : 'Use this command to show logs for a specific device.\n\nBy default, the command prints all log messages and exit.\n\nTo continuously stream output, and see new logs in real time, use the `--tail` option.\n\nNote that for now you need to provide the whole UUID for this command to work correctly.\n\nThis is due to some technical limitations that we plan to address soon.\n\nExamples:\n\n $ resin logs 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828\n $ resin logs 23c73a12e3527df55c60b9ce647640c1b7da1b32d71e6a39849ac0f00db828 --tail' ,
2015-02-26 15:47:56 +00:00
options : [
{
signature : 'tail' ,
description : 'continuously stream output' ,
boolean : true ,
alias : 't'
}
] ,
permission : 'user' ,
2015-10-01 14:39:36 +00:00
primary : true ,
2015-02-26 15:47:56 +00:00
action : function ( params , options , done ) {
2015-12-12 00:28:29 +00:00
var _ , moment , printLine , promise , resin ;
2015-12-07 14:32:24 +00:00
_ = require ( 'lodash' ) ;
resin = require ( 'resin-sdk' ) ;
2015-12-12 00:28:29 +00:00
moment = require ( 'moment' ) ;
printLine = function ( line ) {
var timestamp ;
timestamp = moment ( line . timestamp ) . format ( 'DD.MM.YY HH:mm:ss (ZZ)' ) ;
return console . log ( timestamp + " " + line . message ) ;
} ;
promise = resin . logs . history ( params . uuid ) . each ( printLine ) ;
2015-07-22 22:06:53 +00:00
if ( ! options . tail ) {
2015-08-13 19:08:16 +00:00
return promise [ "catch" ] ( done ) [ "finally" ] ( function ( ) {
return process . exit ( 0 ) ;
} ) ;
2015-07-22 22:06:53 +00:00
}
return promise . then ( function ( ) {
return resin . logs . subscribe ( params . uuid ) . then ( function ( logs ) {
2015-12-12 00:28:29 +00:00
logs . on ( 'line' , printLine ) ;
2015-07-22 22:06:53 +00:00
return logs . on ( 'error' , done ) ;
} ) ;
} ) [ "catch" ] ( done ) ;
2015-02-26 15:47:56 +00:00
}
} ;
} ) . call ( this ) ;