i am trying to add a second module to my supervisor but i get the following error:
** (Mix) Could not start application cloner_worker: exited in: ClonerWorker.Application.start(:normal, )
** (EXIT) an exception was raised:
** (ArgumentError) The module ClonerWorker.Worker was given as a child to a supervisor but it does not exist.
(elixir 1.11.2) lib/supervisor.ex:631: Supervisor.init_child/1
(elixir 1.11.2) lib/enum.ex:1399: Enum.“-map/2-lists^map/1-0-”/2
(elixir 1.11.2) lib/supervisor.ex:617: Supervisor.init/2
(elixir 1.11.2) lib/supervisor.ex:556: Supervisor.start_link/2
(kernel 7.1) application_master.erl:277: :application_master.start_it_old/4
this is my application.ex
defmodule ClonerWorker.Application do
# See https://hexdocs.pm/elixir/Application.html
# for more information on OTP Applications
@moduledoc false
use Application
import Supervisor.Spec
def start(_type, _args) do
genconsumer_impl = ClonerWorker
genconsumer_group_name = "cloners"
genconsumer_group_opts = []
topic_names = ["todo-chunks"]
children = [
ClonerWorker.Worker,
supervisor(
KafkaEx.ConsumerGroup,
[genconsumer_impl,genconsumer_group_name,topic_names,genconsumer_group_opts]
)
# Starts a worker by calling: ClonerWorker.Worker.start_link(arg)
]
# See https://hexdocs.pm/elixir/Supervisor.html
# for other strategies and supported options
opts = [strategy: :one_for_one, name: ClonerWorker.Supervisor]
Supervisor.start_link(children, opts)
end
end
this is my module worker.ex
defmodule ClonerWorker.Worker do
use GenServer
use Tesla
require Logger
require IEx
@base_url "https://poloniex.com/public?command=returnTradeHistory"
def start_link(_module,args) do
GenServer.start_link(__MODULE__, args, name: __MODULE__)
end
def init(_module,args) do
{:ok, args}
end
def get_history_for(currency_pair, from_unix, until_unix) do
from_unix = from_unix * 1000
until_unix = until_unix * 1000
url = "#{url}¤cyPair=#{currency_pair}&start=#{from_unix}&end=#{until_unix}"
result = send_request(url)
if (Enum.count(result) < 1000) do
Logger.info("Result is lesser than 1000")
for item <- result do
IO.inspect(item)
end
else
Logger.warn("Result is greater than 1000")
end
end
defp send_request(url) do
timestamp = DateTime.to_unix(DateTime.utc_now())
key = Application.get_env(:cloner_worker,:key)
secret = Application.get_env(:cloner_worker,:secret)
passphrase = Application.get_env(:cloner_worker,:passphrase)
sign = sign(key,timestamp,url)
headers = [{"PF-API-KEY",key},
{"PF-API-SIGN",sign},
{"PF-API-TIMESTAMP",timestamp},
{"PF-API-PASSPHRASE", passphrase}]
{:ok, result} = Tesla.get(url,headers)
Logger.info(result.status)
result = Jason.decode!(result.body)
end
defp sign(key, timestamp, endpoint, method \\ "GET", body \\ "") do
value = "#{timestamp}#{method}#{endpoint}#{body}"
:crypto.hmac(:sha256, key,value) |> Base.encode64
end
end
thanks in advance for any help you can offer me