2014-11-26 10:32:57 -04:00
|
|
|
_ = require('lodash')
|
2014-11-24 14:00:35 -04:00
|
|
|
TypedError = require('typed-error')
|
|
|
|
log = require('../log/log')
|
|
|
|
|
|
|
|
exports.NotFound = class NotFound extends TypedError
|
2014-12-05 15:04:49 -04:00
|
|
|
|
|
|
|
# Construct a Not Found error
|
|
|
|
#
|
|
|
|
# @param {String} name name of the thing that was not found
|
|
|
|
#
|
|
|
|
# @example Application not found
|
|
|
|
# throw new resin.errors.NotFound('application')
|
|
|
|
# Error: Couldn't find application
|
|
|
|
#
|
2014-11-24 14:41:16 -04:00
|
|
|
constructor: (name) ->
|
2014-11-24 14:00:35 -04:00
|
|
|
@message = "Couldn't find #{name}"
|
2014-11-26 10:32:57 -04:00
|
|
|
|
2014-12-05 15:04:49 -04:00
|
|
|
# Error code
|
|
|
|
code: 1
|
|
|
|
|
|
|
|
exports.InvalidConfigFile = class InvalidConfigFile extends TypedError
|
|
|
|
|
|
|
|
# Construct an Invalid Config File error
|
|
|
|
#
|
|
|
|
# @param {String} file the name of the invalid configuration file
|
|
|
|
#
|
|
|
|
# @example Invalid config file error
|
|
|
|
# throw new resin.errors.InvalidConfigFile('/opt/resin.conf')
|
|
|
|
# Error: Invalid configuration file: /opt/resin.conf
|
|
|
|
#
|
2014-12-03 12:03:54 -04:00
|
|
|
constructor: (file) ->
|
|
|
|
@message = "Invalid configuration file: #{file}"
|
2014-12-05 15:04:49 -04:00
|
|
|
|
|
|
|
# Error code
|
|
|
|
code: 1
|
2014-12-03 12:03:54 -04:00
|
|
|
|
2014-12-01 10:18:39 -04:00
|
|
|
exports.InvalidCredentials = class InvalidCredentials extends TypedError
|
2014-12-05 15:04:49 -04:00
|
|
|
|
|
|
|
# Construct an Invalid Credentials error
|
|
|
|
#
|
|
|
|
# @example Invalid credentials error
|
|
|
|
# throw new resin.errors.InvalidCredentials()
|
|
|
|
# Error: Invalid credentials
|
|
|
|
#
|
2014-12-01 10:18:39 -04:00
|
|
|
constructor: ->
|
|
|
|
@message = 'Invalid credentials'
|
2014-12-05 15:04:49 -04:00
|
|
|
|
|
|
|
# Error code
|
|
|
|
code: 1
|
2014-12-01 10:18:39 -04:00
|
|
|
|
2014-12-09 09:05:37 -04:00
|
|
|
exports.InvalidKey = class InvalidKey extends TypedError
|
|
|
|
|
|
|
|
# Construct an Invalid Key error
|
|
|
|
#
|
|
|
|
# @example Invalid key error
|
|
|
|
# throw new resin.errors.InvalidKey()
|
|
|
|
# Error: Invalid key
|
|
|
|
#
|
|
|
|
constructor: ->
|
|
|
|
@message = 'Invalid key'
|
|
|
|
|
|
|
|
# Error code
|
|
|
|
code: 1
|
|
|
|
|
|
|
|
exports.InvalidPath = class InvalidPath extends TypedError
|
|
|
|
|
|
|
|
# Construct an Invalid Path error
|
|
|
|
#
|
|
|
|
# @param {String} path the name of the invalid path
|
|
|
|
#
|
|
|
|
# @example Invalid path error
|
|
|
|
# throw new resin.errors.InvalidPath('/tmp')
|
|
|
|
# Error: Invalid path: /tmp
|
|
|
|
#
|
|
|
|
constructor: (path) ->
|
|
|
|
@message = "Invalid path: #{path}"
|
|
|
|
|
|
|
|
# Error code
|
|
|
|
code: 1
|
|
|
|
|
2014-12-11 15:51:22 -04:00
|
|
|
exports.DirectoryDoesntExist = class DirectoryDoesntExist extends TypedError
|
|
|
|
|
|
|
|
# Construct a Directory Doesn't Exist error
|
|
|
|
#
|
|
|
|
# @param {String} directory the name of the directory that doesn't exist
|
|
|
|
#
|
|
|
|
# @example Directory doesn't exist error
|
|
|
|
# throw new resin.errors.DirectoryDoesntExist('/tmp')
|
|
|
|
# Error: Directory doesn't exist: /tmp
|
|
|
|
#
|
|
|
|
constructor: (directory) ->
|
|
|
|
@message = "Directory doesn't exist: #{directory}"
|
|
|
|
|
|
|
|
# Error code
|
|
|
|
code: 1
|
|
|
|
|
2014-11-26 10:32:57 -04:00
|
|
|
exports.NotAny = class NotAny extends TypedError
|
2014-12-05 15:04:49 -04:00
|
|
|
|
|
|
|
# Construct an Not Any error
|
|
|
|
#
|
|
|
|
# @param {String} name name of the thing that the user doesn't have
|
|
|
|
#
|
|
|
|
# @example Not Any applications error
|
|
|
|
# throw new resin.errors.NotAny('applications')
|
|
|
|
# Error: You don't have any applications
|
|
|
|
#
|
2014-11-26 10:32:57 -04:00
|
|
|
constructor: (name) ->
|
|
|
|
@message = "You don't have any #{name}"
|
2014-11-24 14:00:35 -04:00
|
|
|
|
2014-12-05 15:04:49 -04:00
|
|
|
# Error code
|
|
|
|
code: 0
|
|
|
|
|
|
|
|
# Handle error instances
|
|
|
|
#
|
|
|
|
# Prints the message to stderr and aborts the program with the corresponding error code, or 0 if none.
|
|
|
|
#
|
|
|
|
# @param {Error} error the error instance
|
|
|
|
# @param {Boolean} exit whether to exit or not (defaults to true)
|
|
|
|
#
|
|
|
|
# @example Handle error
|
|
|
|
# error = new Error('My Error')
|
|
|
|
# shouldExit = false
|
|
|
|
# resin.errors.handle(error, shouldExit)
|
|
|
|
#
|
2014-11-24 14:00:35 -04:00
|
|
|
exports.handle = (error, exit = true) ->
|
|
|
|
return if not error? or error not instanceof Error
|
|
|
|
|
2014-12-10 14:12:12 -04:00
|
|
|
if process.env.DEBUG
|
|
|
|
log.error(error.stack)
|
|
|
|
else
|
|
|
|
if error.message?
|
|
|
|
log.error(error.message)
|
2014-11-24 14:00:35 -04:00
|
|
|
|
2014-11-26 10:32:57 -04:00
|
|
|
if _.isNumber(error.code)
|
|
|
|
errorCode = error.code
|
|
|
|
else
|
|
|
|
errorCode = 1
|
|
|
|
|
|
|
|
process.exit(errorCode) if exit
|