defmodule LocationSimulator.Event do
@moduledoc """
Callback api is a brigde for worker call your code.
Has three callback apis: start/2, event/2, stop/2
All these have 2 parameters is config & state.
config includes lib's config and your meta data you need pass to module.
state is data that is generated by worker. state is an Elixir map with key:
:start_time - Unix timestamp the worker start.
:success - Number of event success.
:failed - Number of event failed.
:error - Number of event error
:gps - GPS data of current state.
:stop_time - Timestamp worker done, only in stop callback api.
GPS data is map with key:
:timestamp - delta time in milisecond from start event (stored in state with key :start_time).
:lon - Longitude
:lat - Latitude
:ele - elevation (meter)
## Example
Please go to example folder in [repo](https://github.com/ohhi-vn/location_simulator)
"""
@doc """
start event will be trigger when worker start.
In this event gps & :end_time won't exist.
result return to worker for success is {:ok, new_config}. new_config will be used for next event.
if return {:error, reason} the worker will stop working.
"""
@callback start(config :: map, state :: map) :: {:ok, map} | {:error, reason :: any}
@doc """
event callback will be trigger every worker generated a new GPS data. Time between event is calculated by interval + random(random_range).
If result is {:stop, reason} the worker will stop working.
"""
@callback event(config :: map, state :: map) :: {:ok, map} | {:error, reason :: any} | {:stop, reason :: any}
@doc """
stop will be trigger when worker send all gps event. In this event you have all information for calculating time, distance, speed.
"""
@callback stop(config :: map, state :: map) :: {:ok, map} | {:error, reason :: any}
end