kamailio中的lua路由脚本

发布于:2025-02-11 ⋅ 阅读:(10) ⋅ 点赞:(0)
-- kamailio-test.lua

-- 定义主请求路由函数
function request_route()
    -- 获取 SIP 请求方法(如 INVITE、REGISTER 等)
    local method = KSR.pv.get("$rm")
    -- 记录日志,输出接收到的 SIP 方法
    KSR.log(LOG_NOTICE, "Received " .. method .. " request")

    -- 检查 Max-Forwards 头字段,防止请求无限循环
    -- KSR.maxfwd.process_maxfwd(10) 会递减 Max-Forwards 的值
    -- 如果 Max-Forwards 的值小于 10,返回 -1
    if KSR.maxfwd.process_maxfwd(10) < 0 then
        -- 如果 Max-Forwards 值不合法,发送 483 Too Many Hops 响应
        KSR.sl.send_reply(483, "Too Many Hops")
        -- 终止脚本执行,不再处理该请求
        return
    end

    -- 处理 REGISTER 请求
    -- 检查 SIP 方法是否为 REGISTER
    if KSR.pv.is_method("REGISTER") then
        -- 调用 registrar 模块的 save 函数,保存用户位置信息
        -- 如果保存失败(返回 -1),发送错误响应
        if KSR.registrar.save("location") < 0 then
            KSR.sl.reply_error()
        end
        -- 终止脚本执行,不再处理该请求
        return
    end

    -- 处理 INVITE 请求
    -- 检查 SIP 方法是否为 INVITE
    if KSR.pv.is_method("INVITE") then
        -- 调用 registrar 模块的 lookup 函数,查找被叫用户的位置
        -- 如果查找失败(返回 -1),发送 404 User Not Found 响应
        if KSR.registrar.lookup("location") < 0 then
            KSR.sl.send_reply(404, "User Not Found")
            -- 终止脚本执行,不再处理该请求
            return
        end
        -- 如果查找成功,调用 tm 模块的 t_relay 函数,转发请求
        KSR.tm.t_relay()
    end

    -- 处理其他 SIP 方法(如 BYE、ACK 等)
    -- 如果不是 REGISTER 或 INVITE 请求,发送 405 Method Not Allowed 响应
    KSR.sl.send_reply(405, "Method Not Allowed")
end

注释说明

1. 函数定义
function request_route()
  • 定义了一个名为 request_route 的函数,这是 Kamailio 调用 Lua 脚本的入口函数。
2. 获取 SIP 方法
local method = KSR.pv.get("$rm")
  • 使用 KSR.pv.get("$rm") 获取 SIP 请求的方法(如 INVITEREGISTER 等)。
  • $rm 是 Kamailio 的伪变量,表示 SIP 请求方法。
3. 记录日志
KSR.log(LOG_NOTICE, "Received " .. method .. " request")
  • 使用 KSR.log() 记录日志,输出接收到的 SIP 方法。
  • LOG_NOTICE 是日志级别,表示普通信息。
4. 检查最大跳数
if KSR.maxfwd.process_maxfwd(10) < 0 then
    KSR.sl.send_reply(483, "Too Many Hops")
    return
end
  • 调用 KSR.maxfwd.process_maxfwd(10) 检查并递减 Max-Forwards 的值。
  • 如果 Max-Forwards 的值小于 10,发送 483 Too Many Hops 响应并终止脚本执行。
5. 处理 REGISTER 请求
if KSR.pv.is_method("REGISTER") then
    if KSR.registrar.save("location") < 0 then
        KSR.sl.reply_error()
    end
    return
end
  • 使用 KSR.pv.is_method("REGISTER") 检查是否为 REGISTER 请求。
  • 如果是 REGISTER 请求,调用 KSR.registrar.save("location") 保存用户位置信息。
  • 如果保存失败,发送错误响应并终止脚本执行。
6. 处理 INVITE 请求
if KSR.pv.is_method("INVITE") then
    if KSR.registrar.lookup("location") < 0 then
        KSR.sl.send_reply(404, "User Not Found")
        return
    end
    KSR.tm.t_relay()
end
  • 使用 KSR.pv.is_method("INVITE") 检查是否为 INVITE 请求。
  • 如果是 INVITE 请求,调用 KSR.registrar.lookup("location") 查找被叫用户的位置。
  • 如果查找失败,发送 404 User Not Found 响应并终止脚本执行。
  • 如果查找成功,调用 KSR.tm.t_relay() 转发请求。
7. 处理其他请求
KSR.sl.send_reply(405, "Method Not Allowed")
  • 如果不是 REGISTERINVITE 请求,发送 405 Method Not Allowed 响应。


网站公告

今日签到

点亮在社区的每一天
去签到