# Buckaroo

Simple `:cowboy` (v2) webserver with support for SSE and WebSockets.

## Quick Setup

defmodule EchoSocket do
  use Buckaroo.Socket

  @impl Buckaroo.Socket
  def handle(frame, state), do: {:reply, frame, state}

defmodule TimeEventSource do
  use Buckaroo.EventSource

  @impl Buckaroo.EventSource
  def init(_conn, _opts), do: {:ok, :timer.send_interval(1_000, :time)}

  @impl Buckaroo.EventSource
  def info(:time, state),
    do: {:reply, %{event: "time", data: :os.system_time()}, state}

  def info(_message, state), do: {:ok, state}

defmodule MyRouter do
  use Buckaroo.Router

  plug :match
  plug :dispatch

  websocket "/echo", connect: EchoSocket
  sse "/sse/time", source: TimeEventSource

  get "/" do
    Plug.Conn.send_resp(conn, 200, "Welcome")

defmodule MyApp do
  use Application

  def start(_type, _args) do
    children = [Buckaroo.child_spec(plug: MyRouter)]
    Supervisor.start_link(children, strategy: :one_for_one)

with SSE it is now possible to subscribe to these time events
in the browser with the following JavaScript:

const es = new EventSource("/sse/time");

es.addEventListener("time", (event) => {
  console.log("system time",;

## Note

If connections are being disconnected,
it might be necessary to set the `:idle_timeout`
to avoid timeouts.

This will definitely be relevant when using SSE EventSources.
The `:idle_timeout` can be set to `:infinity` to avoid timeouts.


Buckaroo.child_spec(plug: MyRouter, protocol_options: [idle_timeout: :infinity])

## Installation

The package can be installed
by adding `buckaroo` to your list of dependencies in `mix.exs`:

def deps do
    {:buckaroo, "~> 0.4.0"}

The docs can be found at [](