2013-12-14 05:18:20 +00:00
|
|
|
Promise = require 'bluebird'
|
|
|
|
fs = Promise.promisifyAll(require('fs'))
|
|
|
|
os = require 'os'
|
2013-12-17 00:33:42 +00:00
|
|
|
knex = require './db'
|
2013-12-14 05:18:20 +00:00
|
|
|
utils = require './utils'
|
|
|
|
{spawn} = require 'child_process'
|
|
|
|
bootstrap = require './bootstrap'
|
|
|
|
|
2014-06-18 16:54:36 +00:00
|
|
|
utils.mixpanelTrack('Supervisor start')
|
2013-12-14 05:18:20 +00:00
|
|
|
|
2014-08-14 21:32:03 +00:00
|
|
|
connectivityState = true # Used to prevent multiple messages when disconnected
|
|
|
|
|
2014-09-15 11:31:14 +00:00
|
|
|
ensureConnected = (continuous = false) ->
|
2014-08-14 21:32:03 +00:00
|
|
|
utils.checkConnectivity()
|
|
|
|
.then (connected) ->
|
|
|
|
if not connected
|
|
|
|
if connectivityState
|
|
|
|
console.log('Waiting for connectivity...')
|
|
|
|
connectivityState = false
|
2014-08-22 12:42:17 +00:00
|
|
|
interval = setInterval(utils.blink,400)
|
|
|
|
Promise.delay(2000)
|
2014-08-14 21:32:03 +00:00
|
|
|
.then ->
|
2014-08-22 12:42:17 +00:00
|
|
|
# Clear the blinks after 2 second
|
2014-08-14 21:32:03 +00:00
|
|
|
clearInterval(interval)
|
|
|
|
ensureConnected(continuous)
|
|
|
|
else
|
|
|
|
if not connectivityState
|
|
|
|
console.log('Internet Connectivity: OK')
|
|
|
|
connectivityState = true
|
|
|
|
if continuous
|
|
|
|
setTimeout(->
|
|
|
|
ensureConnected(continuous)
|
|
|
|
, 10 * 1000) # Every 10 seconds perform this check.
|
|
|
|
|
|
|
|
|
2014-09-15 11:31:14 +00:00
|
|
|
knex('config').select('value').where(key: 'uuid').then ([ uuid ]) ->
|
2014-05-10 16:27:25 +00:00
|
|
|
if not uuid?.value
|
|
|
|
console.log('New device detected. Bootstrapping..')
|
2014-10-01 16:00:21 +00:00
|
|
|
retryingBootstrap = ->
|
2014-08-14 21:32:03 +00:00
|
|
|
utils.mixpanelTrack('Device bootstrap')
|
2014-10-01 16:00:21 +00:00
|
|
|
bootstrap().catch (err) ->
|
2014-10-01 17:37:35 +00:00
|
|
|
utils.mixpanelTrack('Device bootstrap failed, retrying', {error: err, delay: config.bootstrapRetryDelay})
|
2014-10-01 16:00:21 +00:00
|
|
|
Promise.delay(config.bootstrapRetryDelay)
|
|
|
|
.then(retryingBootstrap)
|
|
|
|
retryingBootstrap()
|
2014-06-18 16:54:36 +00:00
|
|
|
else
|
|
|
|
uuid.value
|
|
|
|
.then (uuid) ->
|
|
|
|
# Persist the uuid in subsequent metrics
|
|
|
|
utils.mixpanelProperties.uuid = uuid
|
|
|
|
|
2014-05-10 16:27:25 +00:00
|
|
|
api = require './api'
|
|
|
|
application = require './application'
|
2014-06-16 20:25:06 +00:00
|
|
|
supervisor = require './supervisor-update'
|
2014-05-10 16:27:25 +00:00
|
|
|
|
2013-12-14 05:18:20 +00:00
|
|
|
console.log('Starting OpenVPN..')
|
2014-09-15 11:31:14 +00:00
|
|
|
openvpn = spawn('openvpn', [ 'client.conf' ], cwd: '/data')
|
2013-12-14 05:18:20 +00:00
|
|
|
|
|
|
|
# Prefix and log all OpenVPN output
|
2014-03-19 19:54:39 +00:00
|
|
|
openvpn.stdout.on 'data', (data) ->
|
2013-12-14 05:18:20 +00:00
|
|
|
prefix = 'OPENVPN: '
|
2013-12-23 04:33:38 +00:00
|
|
|
console.log((prefix + data).trim().replace(/\n/gm, "\n#{prefix}"))
|
2013-12-14 05:18:20 +00:00
|
|
|
|
|
|
|
# Prefix and log all OpenVPN output
|
2014-03-19 19:54:39 +00:00
|
|
|
openvpn.stderr.on 'data', (data) ->
|
2013-12-14 05:18:20 +00:00
|
|
|
prefix = 'OPENVPN: '
|
2013-12-23 04:33:38 +00:00
|
|
|
console.log((prefix + data).trim().replace(/\n/gm, "\n#{prefix}"))
|
2013-12-14 05:18:20 +00:00
|
|
|
|
2013-12-18 00:55:47 +00:00
|
|
|
console.log('Starting API server..')
|
2013-12-14 05:18:20 +00:00
|
|
|
api.listen(80)
|
2013-12-23 04:33:16 +00:00
|
|
|
|
|
|
|
console.log('Starting Apps..')
|
2014-03-19 19:54:39 +00:00
|
|
|
knex('app').select()
|
|
|
|
.then (apps) ->
|
2014-08-08 14:25:19 +00:00
|
|
|
Promise.all(apps.map(application.start))
|
2014-03-19 19:54:39 +00:00
|
|
|
.catch (error) ->
|
2014-09-15 11:31:14 +00:00
|
|
|
console.error('Error starting apps:', error)
|
2014-03-19 19:54:39 +00:00
|
|
|
.then ->
|
2013-12-29 18:07:58 +00:00
|
|
|
console.log('Starting periodic check for updates..')
|
|
|
|
setInterval(->
|
|
|
|
application.update()
|
2014-05-04 20:22:03 +00:00
|
|
|
, 5 * 60 * 1000) # Every 5 mins
|
2013-12-29 18:07:58 +00:00
|
|
|
application.update()
|
2014-05-10 16:27:25 +00:00
|
|
|
|
2014-07-11 14:57:49 +00:00
|
|
|
updateIpAddr = ->
|
|
|
|
utils.findIpAddrs().then (ipAddrs) ->
|
|
|
|
application.updateDeviceInfo(
|
|
|
|
ip_address: ipAddrs.join(' ')
|
|
|
|
)
|
|
|
|
console.log('Starting periodic check for IP addresses..')
|
|
|
|
setInterval(updateIpAddr, 5 * 60 * 1000) # Every 5 mins
|
|
|
|
updateIpAddr()
|
|
|
|
|
2014-08-14 21:32:03 +00:00
|
|
|
console.log('Starting connectivity check..')
|
|
|
|
ensureConnected(true)
|
|
|
|
|
2014-10-01 17:26:32 +00:00
|
|
|
# Tell the supervisor updater that we have successfully started, so that it can do whatever it needs to.
|
|
|
|
supervisor.startupSuccessful()
|