2014-11-28 16:46:24 +00:00
|
|
|
_ = require('lodash')
|
|
|
|
PubNub = require('pubnub')
|
|
|
|
resin = require('../resin')
|
2014-11-28 19:36:03 +00:00
|
|
|
helpers = require('../helpers/helpers')
|
2014-11-28 16:46:24 +00:00
|
|
|
|
|
|
|
LOGS_HISTORY_COUNT = 200
|
|
|
|
|
2014-11-29 00:51:03 +00:00
|
|
|
getLogData = (logs) ->
|
|
|
|
return logs[0] if _.isArray(logs)
|
|
|
|
return logs
|
|
|
|
|
|
|
|
printLogs = (logs, number) ->
|
|
|
|
logs = getLogData(logs)
|
|
|
|
logs = _.last(logs, number) if _.isNumber(number)
|
|
|
|
resin.log.array(logs, resin.log.out)
|
|
|
|
|
2014-11-28 16:46:24 +00:00
|
|
|
exports.logs = (uuid) ->
|
2014-11-29 00:51:03 +00:00
|
|
|
numberOfLines = resin.cli.getArgument('num', _.parseInt)
|
|
|
|
tailOutput = resin.cli.getArgument('tail') or false
|
|
|
|
|
|
|
|
if numberOfLines? and not _.isNumber(numberOfLines)
|
|
|
|
resin.errors.handle(new Error('n/num should be a number'))
|
|
|
|
|
2014-11-28 19:36:03 +00:00
|
|
|
helpers.isDeviceUUIDValid uuid, (error, isValidUUID) ->
|
2014-11-28 16:46:24 +00:00
|
|
|
resin.errors.handle(error) if error?
|
|
|
|
|
2014-11-28 19:36:03 +00:00
|
|
|
if not isValidUUID
|
2014-11-28 16:46:24 +00:00
|
|
|
return resin.errors.handle(new Error('Invalid UUID'))
|
|
|
|
|
|
|
|
# PubNub needs to be initialised after logs
|
|
|
|
# action was called, otherwise it prevents
|
|
|
|
# all other actions from exiting on completion
|
|
|
|
pubnub = PubNub.init(resin.config.pubnub)
|
|
|
|
|
2014-12-01 14:06:03 +00:00
|
|
|
channel = _.template(resin.config.events.deviceLogs, { uuid })
|
2014-11-28 16:46:24 +00:00
|
|
|
|
|
|
|
pubnub.history
|
|
|
|
count: LOGS_HISTORY_COUNT
|
|
|
|
channel: channel
|
2014-11-29 00:51:03 +00:00
|
|
|
callback: (logs) ->
|
|
|
|
printLogs(logs, numberOfLines)
|
|
|
|
if not tailOutput or numberOfLines?
|
|
|
|
process.exit(0)
|
2014-11-28 16:46:24 +00:00
|
|
|
|
2014-11-29 00:51:03 +00:00
|
|
|
if tailOutput
|
2014-11-29 00:18:59 +00:00
|
|
|
pubnub.subscribe
|
|
|
|
channel: channel
|
|
|
|
callback: printLogs
|