mirror of
https://github.com/processone/ejabberd.git
synced 2024-11-24 16:23:40 +01:00
* src/mod_irc/: Still not completed...
SVN Revision: 76
This commit is contained in:
parent
1e1f02db98
commit
597c935661
@ -34,9 +34,9 @@
|
|||||||
{normal, all}]}.
|
{normal, all}]}.
|
||||||
|
|
||||||
|
|
||||||
{host, "localhost"}.
|
{host, "e.localhost"}.
|
||||||
|
|
||||||
{listen, [{5222, ejabberd_c2s, start, [{access, c2s},
|
{listen, [{5522, ejabberd_c2s, start, [{access, c2s},
|
||||||
{shaper, c2s_shaper}]},
|
{shaper, c2s_shaper}]},
|
||||||
%{5523, ejabberd_c2s, start,
|
%{5523, ejabberd_c2s, start,
|
||||||
% [{access, c2s}, {ssl, [{certfile, "./ssl.pem"}]}]},
|
% [{access, c2s}, {ssl, [{certfile, "./ssl.pem"}]}]},
|
||||||
@ -46,7 +46,7 @@
|
|||||||
]}.
|
]}.
|
||||||
|
|
||||||
% This value (5569) is only for debugging, must be 5269
|
% This value (5569) is only for debugging, must be 5269
|
||||||
{outgoing_s2s_port, 5269}.
|
{outgoing_s2s_port, 5569}.
|
||||||
|
|
||||||
{modules, [
|
{modules, [
|
||||||
{mod_register, []},
|
{mod_register, []},
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
-export([start/1, init/1, stop/0, closed_conection/2]).
|
-export([start/1, init/1, stop/0, closed_conection/2]).
|
||||||
|
|
||||||
-include("ejabberd.hrl").
|
-include("ejabberd.hrl").
|
||||||
|
-include("namespaces.hrl").
|
||||||
|
|
||||||
-record(irc_connection, {userserver, pid}).
|
-record(irc_connection, {userserver, pid}).
|
||||||
|
|
||||||
@ -52,9 +53,32 @@ do_route(Host, From, To, Packet) ->
|
|||||||
{ChanServ, _, Resource} = To,
|
{ChanServ, _, Resource} = To,
|
||||||
case ChanServ of
|
case ChanServ of
|
||||||
"" ->
|
"" ->
|
||||||
% TODO
|
case Resource of
|
||||||
Err = jlib:make_error_reply(Packet, "406", "Not Acceptable"),
|
"" ->
|
||||||
ejabberd_router:route(To, From, Err);
|
case jlib:iq_query_info(Packet) of
|
||||||
|
{iq, ID, get, ?NS_DISCO_INFO = XMLNS, SubEl} ->
|
||||||
|
Res = {iq, ID, result, XMLNS,
|
||||||
|
[{xmlelement, "query",
|
||||||
|
[{"xmlns", XMLNS}],
|
||||||
|
[{xmlelement, "identity",
|
||||||
|
[{"category", "conference"},
|
||||||
|
{"type", "irc"},
|
||||||
|
{"name", "ejabberd"}], []},
|
||||||
|
{xmlelement, "feature",
|
||||||
|
[{"var", ?NS_MUC}], []}]}]},
|
||||||
|
ejabberd_router:route(To,
|
||||||
|
From,
|
||||||
|
jlib:iq_to_xml(Res));
|
||||||
|
_ ->
|
||||||
|
Err = jlib:make_error_reply(
|
||||||
|
Packet, "503", "Service Unavailable"),
|
||||||
|
ejabberd_router:route(To, From, Err)
|
||||||
|
end;
|
||||||
|
_ ->
|
||||||
|
Err = jlib:make_error_reply(Packet,
|
||||||
|
"406", "Not Acceptable"),
|
||||||
|
ejabberd_router:route(To, From, Err)
|
||||||
|
end;
|
||||||
_ ->
|
_ ->
|
||||||
case string:tokens(ChanServ, "%") of
|
case string:tokens(ChanServ, "%") of
|
||||||
[[_ | _] = Channel, [_ | _] = Server] ->
|
[[_ | _] = Channel, [_ | _] = Server] ->
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
%% gen_fsm callbacks
|
%% gen_fsm callbacks
|
||||||
-export([init/1,
|
-export([init/1,
|
||||||
open_socket/2,
|
open_socket/2,
|
||||||
%wait_for_registration/2,
|
wait_for_registration/2,
|
||||||
stream_established/2,
|
stream_established/2,
|
||||||
handle_event/3,
|
handle_event/3,
|
||||||
handle_sync_event/4,
|
handle_sync_event/4,
|
||||||
@ -109,6 +109,19 @@ open_socket(init, StateData) ->
|
|||||||
{stop, normal, StateData}
|
{stop, normal, StateData}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
|
wait_for_registration(closed, StateData) ->
|
||||||
|
bounce_messages("Server Connect Failed"),
|
||||||
|
lists:foreach(
|
||||||
|
fun(Chan) ->
|
||||||
|
ejabberd_router:route(
|
||||||
|
{lists:concat([Chan, "%", StateData#state.server]),
|
||||||
|
StateData#state.myname, StateData#state.nick},
|
||||||
|
StateData#state.user,
|
||||||
|
{xmlelement, "presence", [{"type", "error"}],
|
||||||
|
[{xmlelement, "error", [{"code", "502"}],
|
||||||
|
[{xmlcdata, "Server Connect Failed"}]}]})
|
||||||
|
end, ?SETS:to_list(StateData#state.channels)),
|
||||||
|
{stop, normal, StateData}.
|
||||||
|
|
||||||
stream_established({xmlstreamend, Name}, StateData) ->
|
stream_established({xmlstreamend, Name}, StateData) ->
|
||||||
{stop, normal, StateData};
|
{stop, normal, StateData};
|
||||||
@ -208,9 +221,21 @@ handle_info({route, Channel, Resource,
|
|||||||
{lists:concat([Channel, "%", StateData#state.server]),
|
{lists:concat([Channel, "%", StateData#state.server]),
|
||||||
StateData#state.myname, StateData#state.nick},
|
StateData#state.myname, StateData#state.nick},
|
||||||
StateData#state.user, El),
|
StateData#state.user, El),
|
||||||
% TODO: remove newlines from body
|
|
||||||
Body = xml:get_path_s(El, [{elem, "body"}, cdata]),
|
Body = xml:get_path_s(El, [{elem, "body"}, cdata]),
|
||||||
?SEND(io_lib:format("PRIVMSG #~s :~s\r\n", [Channel, Body]));
|
Body1 = case Body of
|
||||||
|
[$/, $m, $e, $ | Rest] ->
|
||||||
|
"\001ACTION " ++ Rest ++ "\001";
|
||||||
|
_ ->
|
||||||
|
Body
|
||||||
|
end,
|
||||||
|
Strings = string:tokens(Body1, "\n"),
|
||||||
|
Res = lists:concat(
|
||||||
|
lists:map(
|
||||||
|
fun(S) ->
|
||||||
|
io_lib:format("PRIVMSG #~s :~s\r\n",
|
||||||
|
[Channel, S])
|
||||||
|
end, Strings)),
|
||||||
|
?SEND(Res);
|
||||||
_ -> StateData
|
_ -> StateData
|
||||||
end,
|
end,
|
||||||
{next_state, StateName, NewStateData};
|
{next_state, StateName, NewStateData};
|
||||||
@ -231,7 +256,10 @@ handle_info({ircstring, [$: | String]}, StateName, StateData) ->
|
|||||||
process_channel_list(StateData, Items),
|
process_channel_list(StateData, Items),
|
||||||
StateData;
|
StateData;
|
||||||
[From, "PRIVMSG", [$# | Chan] | _] ->
|
[From, "PRIVMSG", [$# | Chan] | _] ->
|
||||||
process_privmsg(StateData, Chan, From, String),
|
process_chanprivmsg(StateData, Chan, From, String),
|
||||||
|
StateData;
|
||||||
|
[From, "PRIVMSG", Nick, ":\001VERSION\001" | _] ->
|
||||||
|
process_version(StateData, Nick, From),
|
||||||
StateData;
|
StateData;
|
||||||
[From, "PART", [$# | Chan] | _] ->
|
[From, "PART", [$# | Chan] | _] ->
|
||||||
process_part(StateData, Chan, From, String),
|
process_part(StateData, Chan, From, String),
|
||||||
@ -338,14 +366,14 @@ send_text(Socket, Text) ->
|
|||||||
send_element(Socket, El) ->
|
send_element(Socket, El) ->
|
||||||
send_text(Socket, xml:element_to_string(El)).
|
send_text(Socket, xml:element_to_string(El)).
|
||||||
|
|
||||||
send_queue(Socket, Q) ->
|
%send_queue(Socket, Q) ->
|
||||||
case queue:out(Q) of
|
% case queue:out(Q) of
|
||||||
{{value, El}, Q1} ->
|
% {{value, El}, Q1} ->
|
||||||
send_element(Socket, El),
|
% send_element(Socket, El),
|
||||||
send_queue(Socket, Q1);
|
% send_queue(Socket, Q1);
|
||||||
{empty, Q1} ->
|
% {empty, Q1} ->
|
||||||
ok
|
% ok
|
||||||
end.
|
% end.
|
||||||
|
|
||||||
bounce_messages(Reason) ->
|
bounce_messages(Reason) ->
|
||||||
receive
|
receive
|
||||||
@ -414,7 +442,7 @@ process_channel_list_user(StateData, Chan, User) ->
|
|||||||
[]}]}]}).
|
[]}]}]}).
|
||||||
|
|
||||||
|
|
||||||
process_privmsg(StateData, Chan, From, String) ->
|
process_chanprivmsg(StateData, Chan, From, String) ->
|
||||||
[FromUser | _] = string:tokens(From, "!"),
|
[FromUser | _] = string:tokens(From, "!"),
|
||||||
Msg = lists:last(string:tokens(String, ":")),
|
Msg = lists:last(string:tokens(String, ":")),
|
||||||
Msg1 = case Msg of
|
Msg1 = case Msg of
|
||||||
@ -439,6 +467,25 @@ process_privmsg(StateData, Chan, From, String) ->
|
|||||||
{xmlelement, "message", [{"type", "groupchat"}],
|
{xmlelement, "message", [{"type", "groupchat"}],
|
||||||
[{xmlelement, "body", [], [{xmlcdata, Msg2}]}]}).
|
[{xmlelement, "body", [], [{xmlcdata, Msg2}]}]}).
|
||||||
|
|
||||||
|
process_version(StateData, Nick, From) ->
|
||||||
|
case StateData#state.nick of
|
||||||
|
Nick ->
|
||||||
|
[FromUser | _] = string:tokens(From, "!"),
|
||||||
|
send_text(
|
||||||
|
StateData#state.socket,
|
||||||
|
io_lib:format("NOTICE ~s :\001VERSION "
|
||||||
|
"ejabberd IRC transport ~s (c) Alexey Shchepin"
|
||||||
|
"\001\r\n",
|
||||||
|
[FromUser, ?VERSION]) ++
|
||||||
|
io_lib:format("NOTICE ~s :\001VERSION "
|
||||||
|
"http://www.jabber.ru/projects/ejabberd/"
|
||||||
|
"\001\r\n",
|
||||||
|
[FromUser]));
|
||||||
|
_ ->
|
||||||
|
ok
|
||||||
|
end.
|
||||||
|
|
||||||
|
|
||||||
process_part(StateData, Chan, From, String) ->
|
process_part(StateData, Chan, From, String) ->
|
||||||
[FromUser | _] = string:tokens(From, "!"),
|
[FromUser | _] = string:tokens(From, "!"),
|
||||||
%Msg = lists:last(string:tokens(String, ":")),
|
%Msg = lists:last(string:tokens(String, ":")),
|
||||||
|
Loading…
Reference in New Issue
Block a user