defmodule NervesHubLink.Client.Default do
@moduledoc """
Default NervesHubLink.Client implementation
This client always accepts an update.
"""
@behaviour NervesHubLink.Client
require Logger
@impl NervesHubLink.Client
def update_available(_), do: :apply
@impl NervesHubLink.Client
def handle_fwup_message({:progress, percent}) do
Logger.debug("FWUP PROG: #{percent}%")
end
def handle_fwup_message({:error, _, message}) do
Logger.error("FWUP ERROR: #{message}")
end
def handle_fwup_message({:warning, _, message}) do
Logger.warn("FWUP WARN: #{message}")
end
def handle_fwup_message({:ok, status, message}) do
Logger.info("FWUP SUCCESS: #{status} #{message}")
end
def handle_fwup_message(fwup_message) do
Logger.warn("Unknown FWUP message: #{inspect(fwup_message)}")
end
@impl NervesHubLink.Client
def handle_error(error) do
Logger.warn("[NervesHubLink] error: #{inspect(error)}")
end
end