######## Presence query server module ######## ####### SQL OPS module ########## #!ifndef SQLOPS_LOADED loadmodule "sqlops.so" #!trydef SQLOPS_LOADED #!endif modparam("sqlops","sqlcon", "cb=>KAZOO_DB_URL") route[PRESENCE_SEARCH_SUMMARY] { xlog("L_INFO", "processing search subscriptions for $(kzE{kz.json,Realm})\n"); $var(Queue) = $(kzE{kz.json,Server-ID}); $var(Event) = $(kzE{kz.json,Event-Package}); $var(Domain) = $(kzE{kz.json,Realm}); $var(Username) = $(kzE{kz.json,Username}); $var(Now) = $TS; $var(Items) = ""; $var(Query) = $_s(select * from active_watchers where watcher_domain = "$var(Domain)"); if($var(Event) != "") { $var(Query) = $var(Query) + $_s( and event = "$var(Event)"); } if($var(Username) != "") { $var(Query) = $var(Query) + $_s( and watcher_username = "$var(Username)"); } $var(Query) = $var(Query) + " order by to_user, event, watcher_username, callid"; xlog("L_DEBUG", "$ci| QUERY $var(Query)\n"); if (sql_xquery("cb", "$var(Query)", "ra") == 1) { $var(Subs) = ""; $var(Sep1) = ""; while($xavp(ra) != $null) { $var(Username) = $xavp(ra=>to_user); $var(Sep2)=""; $var(Evt)=""; while($xavp(ra) != $null && $var(Username) == $xavp(ra=>to_user)) { $var(Event) = $xavp(ra=>event); $var(Sep3)=""; $var(Sub)=""; $var(Count) = 0; while($xavp(ra) != $null && $var(Username) == $xavp(ra=>to_user) && $var(Event) == $xavp(ra=>event)) { $var(Count) = $var(Count) + 1; pv_unset("$xavp(ra)"); } $var(Evt) = $var(Evt) + $var(Sep2) + $_s("$var(Event)" : $var(Count)); $var(Sep2)=", "; } $var(Subs) = $var(Subs) + $var(Sep1) + $_s("$var(Username)") + " : { " + $var(Evt) + " }"; $var(Sep1)=", "; } } xlog("L_DEBUG", "$ci| RESULT \"Subscriptions\" : { $var(Subs) }\n"); $var(amqp_payload_request) = '{"Event-Category" : "presence", "Event-Name" : "search_resp", "Msg-ID" : "$(kzE{kz.json,Msg-ID})", "Subscriptions" : { $var(Subs) } }'; kazoo_publish("targeted", "$var(Queue)", $var(amqp_payload_request)); } route[PRESENCE_SEARCH_DETAIL] { xlog("L_INFO", "processing status for $(kzE{kz.json,Username}) in realm $(kzE{kz.json,Realm})\n"); $var(Queue) = $(kzE{kz.json,Server-ID}); $var(Event) = $(kzE{kz.json,Event-Package}); $var(Domain) = $(kzE{kz.json,Realm}); $var(Username) = $(kzE{kz.json,Username}); $var(Now) = $TS; $var(Items) = ""; $var(Query) = $_s(select * from active_watchers_log where presentity_uri = "sip:$var(Username)@$var(Domain)"); if($var(Event) != "") { $var(Query) = $var(Query) + $_s( and event = "$var(Event)"); } $var(Query) = $var(Query) + " order by event, watcher_username, callid"; xlog("L_DEBUG", "$ci| STATUS QUERY $var(Query)\n"); if (sql_xquery("cb", "$var(Query)", "ra") == 1) { while($xavp(ra) != $null) { $var(Event) = $xavp(ra=>event); while($xavp(ra) != $null && $var(Event) == $xavp(ra=>event)) { $var(Sub) = $_s("$var(Username)" : {"$xavp(ra=>event)" : { "$xavp(ra=>watcher_username)" : {"kamailio@MY_HOSTNAME" : {"call_id" : "$xavp(ra=>callid)", "time" : $xavp(ra=>time), "result" : $xavp(ra=>result), "sent" : "$(xavp(ra=>sent_msg){s.escape.common})", "received" : "$(xavp(ra=>received_msg){s.escape.common})", "User-Agent" : "$(xavp(ra=>user_agent){s.escape.common}{s.replace,\','}{s.replace,$$,})"}}}}); xlog("L_DEBUG", "$ci| RESULT \"Subscriptions\" : { $var(Sub) }\n"); $var(amqp_payload_request) = '{"Event-Category" : "presence", "Event-Name" : "search_partial_resp", "Msg-ID" : "$(kzE{kz.json,Msg-ID})", "Subscriptions" : { $var(Sub) } }'; kazoo_publish("targeted", "$var(Queue)", $var(amqp_payload_request)); pv_unset("$xavp(ra)"); } } } $var(amqp_payload_request) = '{"Event-Category" : "presence", "Event-Name" : "search_resp", "Msg-ID" : "$(kzE{kz.json,Msg-ID})" }'; kazoo_publish("targeted", "$var(Queue)", $var(amqp_payload_request)); } event_route[kazoo:consumer-event-presence-search-req] { switch($(kzE{kz.json,Search-Type})) { case "summary": route(PRESENCE_SEARCH_SUMMARY); break; case "detail": route(PRESENCE_SEARCH_DETAIL); break; default: xlog("L_INFO", "$ci|search type '$(kzE{kz.json,Search-Type})' not handled\n"); } } # vim: tabstop=4 softtabstop=4 shiftwidth=4 expandtab