summaryrefslogtreecommitdiff
path: root/app/relay/index.js
blob: eaec38b4aec6e07205057a5e3fe8e5dc38dd83fa (plain)
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
require('dotenv').config()

const io = require('socket.io-client')
const ss = require('socket.io-stream')
const zerorpc = require('zerorpc')
const Readable = require('stream').Readable;

let remote = io.connect(process.env.SOCKETIO_REMOTE);

remote.on('cmd', (data) => {
  console.log('cmd data', data)
  if (! data.cmd) {
    console.log('malformed param...?')
    return
  }
  console.log('got', data.cmd)
  switch (data.cmd) {
    case 'send_param':
      if (! data.payload) return
      rpc.invoke(data.cmd, data.payload.key, data.payload.value, (err, res, more) => {
        console.log('sent param, got response', res)
      })
      break
    case 'get_params':
    case 'get_last_frame':
      rpc.invoke(data.cmd, (err, res, more) => {
        console.log('got params', res)
        remote.emit('res', {
          cmd: data.cmd,
          res: res,
        })
      })
      break
  }
})

let rpc = new zerorpc.Client()
rpc.connect("tcp://127.0.0.1:" + process.env.RPC_PORT)
rpc.on("error", function(error) {
  console.error("RPC server error:", error)
})
console.log('RPC listening on port ' + process.env.RPC_PORT)

let relay = new zerorpc.Server({
  // Called when the worker starts up and is ready to receive params.
  connected: function (msg, reply) {
    reply()
    console.log("got connect from " + msg)
    return true
  },

  send_frame: function (fn, frame, reply) {
    reply()
    console.log('got frame, ' + frame.length + ' bytes')
    remote.emit('frame', fn, frame)
    // var stream = ss.createStream()
    // stream.on('data', () => { console.log('stream data...') })
    // // console.log(stream)

    // var rs = new Readable()
    // rs.on('data', (d) => { console.log('rs data...', d.length) })
    // rs._read = function noop() {}
    // rs.pipe(stream)
    // rs.push(frame)
    // rs.push(null)
    // ss(remote).on('frame', () => console.log('frame??'))
    // ss(remote).emit('frame', stream, {name: fn}, function(){ console.log('where am i') })
  }
})
relay.on("error", function(error) {
  console.error("Relay server error:", error)
})
relay.bind("tcp://0.0.0.0:" + process.env.RELAY_PORT);
console.log('Relay listening on port ' + process.env.RELAY_PORT)

module.exports = { relay: relay, remote: remote, }