mirror of
https://github.com/processone/ejabberd.git
synced 2024-12-22 17:28:25 +01:00
* src/mod_proxy65/mod_proxy65_service.erl: if an ip option is not defined, the module takes an IP address of a local hostname.
SVN Revision: 1925
This commit is contained in:
parent
67e24366ee
commit
b766109f66
@ -1,3 +1,8 @@
|
||||
2009-02-27 Evgeniy Khramtsov <ekhramtsov@process-one.net>
|
||||
|
||||
* src/mod_proxy65/mod_proxy65_service.erl: if an 'ip' option
|
||||
is not defined, the module takes an IP address of a local hostname.
|
||||
|
||||
2009-02-26 Badlop <badlop@process-one.net>
|
||||
|
||||
* doc/guide.tex: No mention to the release date in ejabberd Guide
|
||||
|
@ -215,26 +215,22 @@ parse_options(ServerHost, Opts) ->
|
||||
ACL = gen_mod:get_opt(access, Opts, all),
|
||||
Name = gen_mod:get_opt(name, Opts, "SOCKS5 Bytestreams"),
|
||||
IP = case gen_mod:get_opt(ip, Opts, none) of
|
||||
none -> get_proxy_or_domainip(ServerHost, MyHost);
|
||||
Addr -> Addr
|
||||
end,
|
||||
none -> get_my_ip();
|
||||
Addr -> Addr
|
||||
end,
|
||||
StrIP = inet_parse:ntoa(IP),
|
||||
StreamAddr = [{"jid", MyHost}, {"host", StrIP}, {"port", integer_to_list(Port)}],
|
||||
#state{myhost = MyHost,
|
||||
serverhost = ServerHost,
|
||||
name = Name,
|
||||
port = Port,
|
||||
ip = IP,
|
||||
stream_addr = StreamAddr,
|
||||
acl = ACL}.
|
||||
serverhost = ServerHost,
|
||||
name = Name,
|
||||
port = Port,
|
||||
ip = IP,
|
||||
stream_addr = StreamAddr,
|
||||
acl = ACL}.
|
||||
|
||||
%% Return the IP of the proxy host, or if not found, the ip of the xmpp domain
|
||||
get_proxy_or_domainip(ServerHost, MyHost) ->
|
||||
case inet:getaddr(MyHost, inet) of
|
||||
get_my_ip() ->
|
||||
{ok, MyHostName} = inet:gethostname(),
|
||||
case inet:getaddr(MyHostName, inet) of
|
||||
{ok, Addr} -> Addr;
|
||||
{error, _} ->
|
||||
case inet:getaddr(ServerHost, inet) of
|
||||
{ok, Addr} -> Addr;
|
||||
{error, _} -> {127,0,0,1}
|
||||
end
|
||||
{error, _} -> {127,0,0,1}
|
||||
end.
|
||||
|
Loading…
Reference in New Issue
Block a user