forked from pimatic/pimatic
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstartup.coffee
82 lines (72 loc) · 2.51 KB
/
startup.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# #Framwork start up
assert = require 'cassert'
fs = require 'fs'
path = require 'path'
Promise = require 'bluebird'
# Setup the environment
env = { logger: require './lib/logger' }
env.api = require('./lib/api')
env.users = require('./lib/users') env
env.devices = require('./lib/devices') env
env.matcher = require './lib/matcher'
env.variables = require('./lib/variables') env
env.actions = require('./lib/actions') env
env.predicates = require('./lib/predicates') env
env.rules = require('./lib/rules') env
env.plugins = require('./lib/plugins') env
env.database = require('./lib/database') env
env.groups = require('./lib/groups') env
env.pages = require('./lib/pages') env
env.require = (args...) -> module.require args...
startup = =>
# set the config file to
configFile = (
# PIMATIC_CONFIG envirement variable if it is set
if process.env.PIMATIC_CONFIG? then process.env.PIMATIC_CONFIG
# or get the config the parent folder of node_modules
else path.resolve __dirname, '../../config.json'
)
exit = (code) ->
env.logger.info "exiting..."
if process.logStream?
# close logstream first
process.stdout.write = process.stdout.writeOut
process.stderr.write = process.stderr.writeOut
process.logStream.writer.on 'finish', ->
process.exit(code)
process.logStream.end()
else
process.exit(code)
# Setup the framework
env.framework = (require './lib/framework') env
return Promise.try( =>
framework = new env.framework.Framework configFile
promise = framework.init().then( ->
onKill = ->
framework.destroy().then( -> exit(0) )
uncaughtException = (err) ->
unless err.silent
env.logger.error(
"A uncaught exception occured: #{err.stack}\n
This is most probably a bug in pimatic or in a module, please report it!"
)
if process.env['PIMATIC_DAEMONIZED']
env.logger.warn(
"Keeping pimatic alive, but could be in an undefined state,
please restart pimatic so soon as possible!"
)
else
env.logger.warn("shutting pimatic down...")
framework.destroy().then( -> exit(1) )
process.on('SIGINT', onKill)
process.on('SIGTERM', onKill)
process.on('uncaughtException', uncaughtException)
)
return promise.then( => framework )
).catch( (err) =>
unless err.silent
env.logger.error "Startup error: #{err.stack}"
exit(1)
)
module.exports.startup = startup
module.exports.env = env