You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
lua-ngcp-kamailio/ngcp/ngcp.lua

210 lines
5.8 KiB

#!/usr/bin/env lua5.1
require 'ngcp.pp'
require 'ngcp.dp'
require 'ngcp.up'
require 'ngcp.rp'
-- load drivers
local driver = require "luasql.mysql"
if not luasql then
luasql = driver
end
-- class NGCPConfig
NGCPConfig = {
__class__ = 'NGCPConfig'
}
NGCPConfig_MT = { __index = NGCPConfig }
function NGCPConfig:new()
local t = {
db_host = "127.0.0.1",
db_port = 3306,
db_username = "kamailio",
db_pass = "somepasswd",
db_database = "kamailio",
default = {
peer = {
sst_enable = "yes",
sst_expires = 300,
sst_min_timer = 90,
sst_max_timer = 7200,
sst_refresh_method = "UPDATE_FALLBACK_INVITE",
outbound_from_user = "npn",
inbound_upn = "from_user",
inbound_npn = "from_user",
inbound_uprn = "from_user",
ip_header = "P-NGCP-Src-Ip",
},
dom = {
sst_enable = "yes",
sst_expires = 300,
sst_min_timer = 90,
sst_max_timer = 7200,
sst_refresh_method = "UPDATE_FALLBACK_INVITE",
outbound_from_user = "npn",
inbound_upn = "from_user",
inbound_uprn = "from_user",
ip_header = "P-NGCP-Src-Ip",
},
-- just for prefs that are only on usr level
usr = {
account_id = 0,
ext_subscriber_id = "",
ext_contract_id = "",
ringtimeout = 180,
}
}
}
setmetatable( t, NGCPConfig_MT )
return t
end
function NGCPConfig:getDBConnection()
local env = assert (luasql.mysql())
sr.log("dbg","connecting to mysql")
return env:connect( self.db_database,
self.db_username, self.db_pass, self.db_host, self.db_port)
end
function NGCPConfig:get_defaults(vtype)
local k,v
local defs = {}
if self.default.vtype then
for k,v in pairs(default.vtype) do
defs[k] = v
end
end
return defs
end
-- class
-- class NGCP
NGCP = {
__class__ = 'NGCP'
}
NGCP_MT = { __index = NGCP }
NGCP_MT.__tostring = function (t)
local k,v
output = ''
for k,v in pairs(t.prefs) do
output = output .. tostring(v)
end
return output
end
function NGCP:new()
local t = NGCP.init()
setmetatable( t, NGCP_MT )
return t
end
function NGCP.init()
local t = {
config = NGCPConfig:new()
}
t.prefs = {
dom = NGCPDomainPrefs:new(t.config),
usr = NGCPUserPrefs:new(t.config),
peer = NGCPPeerPrefs:new(t.config),
real = NGCPRealPrefs:new(t.config),
}
return t
end
function NGCP:caller_peer_load(peer)
local _,v, xvap
local keys = self.prefs.peer:caller_load(peer)
self.prefs.real:caller_peer_load(keys)
return keys
end
function NGCP:callee_peer_load(peer)
local _,v, xvap
local keys = self.prefs.peer:callee_load(peer)
self.prefs.real:callee_peer_load(keys)
return keys
end
function NGCP:caller_usr_load(uuid, domain)
local _,v
local keys = {
domain = self.prefs.dom:caller_load(domain),
user = self.prefs.usr:caller_load(uuid)
}
local unique_keys = table.deepcopy(keys.domain)
for _,v in pairs(keys.user) do
table.add(unique_keys, v)
end
self.prefs.real:caller_usr_load(unique_keys)
local xavp = NGCPXAvp:new('caller', 'dom')
return unique_keys
end
function NGCP:callee_usr_load(uuid, domain)
local _,v
local keys = {
domain = self.prefs.dom:callee_load(domain),
user = self.prefs.usr:callee_load(uuid)
}
local unique_keys = table.deepcopy(keys.domain)
for _,v in pairs(keys.user) do
table.add(unique_keys, v)
end
self.prefs.real:callee_usr_load(unique_keys)
return unique_keys
end
function NGCP:log_pref(level, vtype)
local _,pref,xavp,xavp_log
if not level then
level = "dbg"
end
if not vtype then
for _,pref in pairs(self.prefs) do
xavp = pref:xavp("caller")
xavp_log = tostring(xavp)
sr.log(level, string.format("%s:%s\n", xavp.name, xavp_log))
xavp = pref:xavp("callee")
xavp_log = tostring(xavp)
sr.log(level, string.format("%s:%s\n", xavp.name, xavp_log))
end
else
if self.prefs[vtype] then
xavp = self.prefs[vtype]:xavp("caller")
xavp_log = tostring(xavp)
sr.log(level, string.format("%s:%s\n", xavp.name, xavp_log))
xavp = self.prefs[vtype]:xavp("callee")
xavp_log = tostring(xavp)
sr.log(level, string.format("%s:%s\n", xavp.name, xavp_log))
else
error(string.format("there is no prefs for %s", vtype))
end
end
end
function NGCP:clean(vtype, group)
local _,k,v
if not group then
for k,v in pairs(self.prefs) do
v:clean(vtype)
end
else
if self.prefs[group] then
self.prefs[group]:clean(vtype)
else
error(string.format("unknown group:%s", group))
end
end
end
-- class
--EOF