forked from GinjaNinja32/bot32
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcore.erl
More file actions
79 lines (74 loc) · 2.49 KB
/
core.erl
File metadata and controls
79 lines (74 loc) · 2.49 KB
1
2
3
4
5
6
7
8
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
-module(core).
-compile(export_all).
-define(SOCK_OPTIONS, [list, {packet, line}, {active, true}]).
-include("definitions.hrl").
init() ->
config:start(config),
util:waitfor(config),
Server = config:require_value(config, [core, server]),
Port = config:require_value(config, [core, port]),
Transport = config:require_value(config, [core, transport]),
init(Server, Transport, Port).
init(Server, Transport, Port) ->
case config:is_started(config) of
false -> config:start(config);
true -> ok
end,
config:start(data),
config:start_transient(temp),
case Transport of
ssl -> ssl:start();
_ -> ok
end,
{ok, Sock} = Transport:connect(Server, Port, ?SOCK_OPTIONS),
register(core, self()),
logging:log(info, "CORE", "starting"),
loop(Sock, Transport),
logging:log(info, "CORE", "quitting"),
Transport:close(Sock),
case Transport of
ssl -> ssl:stop();
_ -> ok
end,
case whereis(bot) of
undefined -> ok;
Pid -> Pid ! quit, ok
end.
loop(Sock, Transport) ->
case receive
{ssl, Sock, RawMessage} -> self() ! {tcp, Sock, RawMessage}, ok;
{ssl_closed, Sock} -> self() ! {tcp_closed, Sock}, ok;
{ssl_error, Sock, Reason} -> self() ! {tcp_error, Sock, Reason}, ok;
{tcp, Sock, RawMessage} ->
Message = lists:reverse(tl(tl(lists:reverse(RawMessage)))),
case common:tcp_parse(Sock, Transport, Message) of
{irc, T} ->
case whereis(bot) of
undefined ->
case T of
{msg, {_User, _Channel, ["##SPAWN"]}} -> logging:log(info, "CORE", "Spawn request received, spawning!"), spawn(bot,init,[]), ok;
_ -> logging:log(error, "CORE", "could not find bot PID!")
end;
Pid -> Pid ! {irc, T}, ok
end;
T when is_atom(T) -> T;
T -> logging:log(error, "CORE", "unknown return value ~p from tcp_parse", [T])
end;
{tcp_closed, Sock} -> logging:log(error, "CORE", "Socket closed, quitting"), quit;
{tcp_error, Sock, Reason} -> logging:log(error, "CORE", "Socket error: ~p", [Reason]), quit;
{raw, Message} -> common:raw_send(Sock, Transport, Message), ok;
{irc, Message} -> common:tcp_send(Sock, Transport, Message), ok;
T when is_atom(T) -> T;
X -> logging:log(error, "CORE", "Received unknown message ~p", [X])
after
30 * 1000 -> % 30 seconds without a message
common:raw_send(Sock, Transport, "PING bot32"), ok
end of
quit -> ok;
error -> error;
ok -> loop(Sock, Transport);
update -> core:loop(Sock, Transport);
S ->
logging:log(error, "CORE", "unknown message ~p, continuing", [S]),
loop(Sock, Transport)
end.