ubuntu 14.04でejabberdバージョンv2.1.11を使用しています。exmpp モジュールをコンパイルし、/usr/lib/ejabberd/ebin/
場所にコピーしました。以下は「my_module」コードです。
-module(my_module).
-author("John").
-include("/home/jk/src/exmpp/include/exmpp.hrl").
-include("/home/jk/src/exmpp/include/exmpp_client.hrl").
-include("ejabberd.hrl").
-export([start/2, stop/1]).
-export([on_filter_packet/1]).
-record(state, {}).
stop(_Host) -> ok.
start(Host, Opts) ->
?INFO_MSG("START MODULE LOADING", []),
ejabberd_hooks:add(filter_packet, global, ?MODULE, on_filter_packet, 0).
% gen_server:start_link(?MODULE, [Host], []).
on_filter_packet({From, To, Packet} = Input) ->
Parser = exmpp_xml:start_parser(), % FAILS HERE
Schedule = exmpp_xml:parse_final(Parser, "<schedule version='1.0' ></schedule>"),
exmpp_xml:stop_parser(Parser),
Input.
ejabberd を開始すると、次のエラーがスローされました
running hook: {filter_packet,[]}
=ERROR REPORT==== 2015-10-13 22:12:24 ===
E(<0.9790.0>:ejabberd_hooks:335) : {badarg,
[{ets,member,
[exmpp_xml_engines_registry,expat],
[]},
{exmpp_xml,is_engine_available,1,
[{file,"./core/exmpp_xml.erl"},
{line,520}]},
{exmpp_xml,get_engine_from_options,1,
[{file,"./core/exmpp_xml.erl"},
{line,4007}]},
{exmpp_xml,start_parser,1,
[{file,"./core/exmpp_xml.erl"},
{line,625}]},
{my_module,on_filter_packet,1,
[{file,"my_module.erl"},{line,52}]},
{ejabberd_hooks,run_fold1,4,
[{file,"ejabberd_hooks.erl"},
{line,331}]},
{ejabberd_router,do_route,3,
[{file,"ejabberd_router.erl"},
{line,315}]},
{ejabberd_router,route,3,
[{file,"ejabberd_router.erl"},
{line,68}]}]}
ejabberd モジュールでexmppモジュールを使用するには?
編集:
start メソッドにexmpp:start()を追加し、c_src を ejabberd lib にコピーすると、機能します。
cp -rf exmpp/c_src/ /usr/lib/ejabberd/
exmppの依存関係はすべて独自のモジュール内にあるため、exmpp_*.beam ファイルを ejabberd モジュールがアクセスできる /usr/lib/ejabberd/ebin/ の場所にコピーするだけで、ejabberd モジュールで使用するのに十分だと思いましたが、そうではありませんケース。
上記の解決策は機能しますが、exmpp モジュールをインストールして ejabberd モジュールで使用できるようにする正しい方法は何ですか。