Class: Takagi::Server

Inherits:
Object
  • Object
show all
Defined in:
lib/takagi/server.rb

Constant Summary collapse

LOGGER =
Takagi::Logger

Class Method Summary collapse

Class Method Details

.run!(port: 5683) ⇒ Object



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
# File 'lib/takagi/server.rb', line 9

def self.run!(port: 5683)
  server = UDPSocket.new
  server.bind("0.0.0.0", port)
  LOGGER.info("Takagi running on CoAP://0.0.0.0:#{port}")

  loop do
    data, addr = server.recvfrom(1024)
    request = Message.parse(data)

    LOGGER.info("Request: #{request[:method]} #{request[:path]}, Token: #{request[:token].unpack("H*").first}")

    route, params = Router.find_route(request[:method], request[:path])
    response = if route
                 params.merge!(JSON.parse(request[:payload])) if request[:payload]
                 route.call(params)
               else
                 LOGGER.error("Route not found: #{request[:method]} #{request[:path]}")
                 { error: "Not Found" }
               end

    response_data = Message.build_response(2.05, response, request[:token])
    LOGGER.info("Response: 2.05 Content -> #{response.to_json}")

    server.send(response_data, 0, addr[3], addr[1])
  end
end