2013-07-21 01:30:12 +00:00
|
|
|
fs = require('fs')
|
2013-07-20 02:57:51 +00:00
|
|
|
express = require('express')
|
2013-07-21 00:41:52 +00:00
|
|
|
async = require('async')
|
|
|
|
bootstrap = require('./bootstrap')
|
|
|
|
state = require('./state')
|
|
|
|
settings = require('./settings')
|
2013-07-21 14:21:20 +00:00
|
|
|
request = require('request')
|
2013-07-21 01:30:12 +00:00
|
|
|
Application = require('./application')
|
|
|
|
|
|
|
|
console.log('Supervisor started..')
|
|
|
|
|
|
|
|
hakiApp = null
|
2013-07-20 02:57:51 +00:00
|
|
|
|
2013-07-21 00:41:52 +00:00
|
|
|
tasks = [
|
2013-07-18 10:40:35 +00:00
|
|
|
(callback) ->
|
2013-07-21 00:41:52 +00:00
|
|
|
if state.get('virgin')
|
2013-07-21 13:32:46 +00:00
|
|
|
console.log('Device is virgin. Bootstrapping')
|
2013-07-21 00:41:52 +00:00
|
|
|
handler = (error) ->
|
|
|
|
if error
|
2013-07-21 01:30:12 +00:00
|
|
|
console.log('Bootstrapping failed with error', error)
|
|
|
|
console.log('Trying again in 10s')
|
|
|
|
setTimeout((-> bootstrap(handler)), 10000)
|
2013-07-21 00:41:52 +00:00
|
|
|
else
|
2013-07-21 13:32:46 +00:00
|
|
|
console.log('Bootstrapping successful')
|
2013-07-21 00:41:52 +00:00
|
|
|
state.set('virgin', false)
|
|
|
|
callback()
|
|
|
|
bootstrap(handler)
|
2013-07-19 00:10:43 +00:00
|
|
|
else
|
2013-07-21 01:30:12 +00:00
|
|
|
console.log("Device isn't a virgin")
|
2013-07-21 00:41:52 +00:00
|
|
|
callback()
|
2013-07-21 16:09:40 +00:00
|
|
|
(callback) ->
|
|
|
|
fs.writeFile('/sys/class/leds/led0/trigger', 'none', callback)
|
2013-07-21 01:30:12 +00:00
|
|
|
(callback) ->
|
|
|
|
hakiApp = new Application(state.get('gitUrl'), '/home/haki/hakiapp', 'haki')
|
2013-07-21 14:21:20 +00:00
|
|
|
|
|
|
|
hakiApp.on 'pre-init', ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Initialising'
|
|
|
|
)
|
|
|
|
|
|
|
|
hakiApp.on 'post-init', ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Idle'
|
|
|
|
)
|
|
|
|
|
|
|
|
hakiApp.on 'pre-update', ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Updating'
|
|
|
|
)
|
|
|
|
|
|
|
|
hakiApp.on 'post-update', (hash) ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Idle'
|
|
|
|
commit: state.get('gitHash')
|
|
|
|
)
|
|
|
|
|
|
|
|
hakiApp.on 'start', ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Running'
|
|
|
|
)
|
|
|
|
|
|
|
|
hakiApp.on 'stop', ->
|
|
|
|
request(
|
|
|
|
uri: "#{settings.API_ENDPOINT}/ewa/device?$filter=uuid eq '#{state.get('uuid')}'"
|
|
|
|
method: 'PATCH'
|
|
|
|
json:
|
|
|
|
status: 'Idle'
|
|
|
|
)
|
|
|
|
|
2013-07-21 01:30:12 +00:00
|
|
|
if not state.get('appInitialised')
|
|
|
|
console.log('Initialising app..')
|
|
|
|
hakiApp.init((error) ->
|
|
|
|
if error then return callback(error)
|
|
|
|
state.set('appInitialised', true)
|
|
|
|
callback()
|
|
|
|
)
|
|
|
|
else
|
|
|
|
console.log('App already initialised')
|
|
|
|
callback()
|
|
|
|
(callback) ->
|
|
|
|
console.log('Fetching new code..')
|
|
|
|
hakiApp.update(callback)
|
|
|
|
(callback) ->
|
|
|
|
console.log('Starting the app..')
|
|
|
|
hakiApp.start(callback)
|
2013-07-19 00:10:43 +00:00
|
|
|
]
|
2013-07-18 20:34:00 +00:00
|
|
|
|
2013-07-21 00:41:52 +00:00
|
|
|
async.series(tasks, (error) ->
|
|
|
|
if error
|
2013-07-19 00:10:43 +00:00
|
|
|
console.error(error)
|
2013-07-21 01:30:12 +00:00
|
|
|
else
|
|
|
|
console.log('Everything is fine :)')
|
2013-07-19 00:10:43 +00:00
|
|
|
)
|
2013-07-20 02:57:51 +00:00
|
|
|
|
|
|
|
app = express()
|
|
|
|
|
|
|
|
app.post('/blink', (req, res) ->
|
2013-07-23 19:40:19 +00:00
|
|
|
ledState = 0
|
2013-07-21 00:41:52 +00:00
|
|
|
toggleLed = ->
|
2013-07-23 19:40:19 +00:00
|
|
|
ledState = (ledState + 1) % 2
|
|
|
|
fs.writeFileSync(settings.LED_FILE, ledState)
|
2013-07-21 00:41:52 +00:00
|
|
|
|
|
|
|
interval = setInterval(toggleLed, settings.BLINK_STEP)
|
|
|
|
setTimeout(->
|
|
|
|
clearInterval(interval)
|
2013-07-21 01:31:21 +00:00
|
|
|
fs.writeFileSync(settings.LED_FILE, 0)
|
2013-07-21 00:41:52 +00:00
|
|
|
res.send(200)
|
|
|
|
, 5000)
|
|
|
|
)
|
|
|
|
|
|
|
|
app.post('/update', (req, res) ->
|
2013-07-21 01:31:54 +00:00
|
|
|
hakiApp.update((error) ->
|
|
|
|
if error
|
|
|
|
res.send(500)
|
|
|
|
else
|
|
|
|
res.send(204)
|
|
|
|
)
|
2013-07-20 02:57:51 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
app.listen(80)
|