FreeSWITCH添加自定義endpoint之api及app開發

来源:https://www.cnblogs.com/MikeZhang/archive/2023/10/28/fsAddApiApp20231028.html
-Advertisement-
Play Games

操作系統 :CentOS 7.6_x64 FreeSWITCH版本 :1.10.9 之前寫過FreeSWITCH添加自定義endpoint的文章,今天整理下api及app開發的筆記。歷史文章可參考如下鏈接: FreeSWITCH添加自定義endpointFreeSWITCH添加自定義endpoint ...


操作系統 :CentOS 7.6_x64

FreeSWITCH版本 :1.10.9

之前寫過FreeSWITCH添加自定義endpoint的文章,今天整理下api及app開發的筆記。歷史文章可參考如下鏈接:

FreeSWITCH添加自定義endpoint
FreeSWITCH添加自定義endpoint之媒體交互

一、常用函數介紹

這裡列舉下開發過程中常用的函數。

1、根據uuid查詢session

使用switch_core_session_locate巨集進行查詢。

定義如下:

#define switch_core_session_locate(uuid_str) switch_core_session_perform_locate(uuid_str, FILE, SWITCH_FUNC, LINE)

示例如下:

switch_core_session_t *session;
if ((session = switch_core_session_locate(uuid))) {
switch_channel_t *tchannel = switch_core_session_get_channel(session);
val = switch_channel_get_variable(tchannel, varname);
switch_core_session_rwunlock(session);
}

查詢session後,需要使用switch_core_session_rwunlock函數釋放鎖。

2、獲取session的uuid

使用 switch_core_session_get_uuid 函數根據session查詢uuid。定義如下:

SWITCH_DECLARE(char *) switch_core_session_get_uuid(_In_ switch_core_session_t *session);

示例如下:

const char *uuid = switch_core_session_get_uuid(session);

3、根據session獲取channel

 使用 switch_core_session_get_channel 函數根據session查詢channel。定義如下:
_Ret_ SWITCH_DECLARE(switch_channel_t *) switch_core_session_get_channel(_In_ switch_core_session_t *session);

示例如下:

switch_channel_t *tchannel = switch_core_session_get_channel(session);

4、channel操作

  • switch_channel_set_name

  設置通道名稱,通常以 endpoint 類型作為首碼,比如"sofia/1001"、"rtc/1002"等。

  • switch_channel_get_name

  獲取通道名稱。

  • switch_channel_set_variable

  設置通道變數的值。

  • switch_channel_get_variable

  獲取通道變數的值。

  • switch_channel_set_flag

  設置channel的標記

  • switch_channel_ready

  判斷channel是否就緒

  • switch_channel_set_caller_profile

  設置profile屬性


更多內容channel操作可參考 switch_channel.h 文件。

二、查看已有api及app

使用 show modules 顯示所有api、app及mod對應關係。

效果如下:

 如需查看單個模塊包含的api及app,可以在後面加上模塊名稱,比如:

show modules mod_db

三、新增api命令

通過SWITCH_STANDARD_API進行添加。

比如添加如下命令:

ctest_update_token <uuid> <token>

示例代碼如下:

/* <uuid> <token> */
SWITCH_STANDARD_API(ctest_update_token_function)
{
    char *argv[3];
    char *mydata;
    char *uuid, *token;

    if (zstr(cmd)) {
        stream->write_function(stream, "-ERR Parameter missing\n");
        return SWITCH_STATUS_SUCCESS;
    }
    if (!(mydata = strdup(cmd))) {
        return SWITCH_STATUS_FALSE;
    }

    if (!switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0]))) || !argv[0]) {
        goto end;
    }

    uuid = argv[0];
    token = argv[1];

    if (zstr(uuid) || zstr(token)) {
        goto end;
    }

    switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO,"uuid : %s , token : %s\n",uuid,token); 

end:
    switch_safe_free(mydata);
    return SWITCH_STATUS_SUCCESS;
}

在模塊載入函數(mod_ctest_load)添加入口:

switch_api_interface_t *api_interface;

SWITCH_ADD_API(api_interface, "ctest_update_token", "update ctest channel token", ctest_update_token_function,"<uuid> <token>");

設置自動填充uuid:

switch_console_set_complete("add ctest_update_token ::console::list_uuid");

 運行效果如下:

四、新增app命令

通過 SWITCH_STANDARD_APP 添加,這裡就不詳細描述了,具體看下 echo 這個app:

mod/applications/mod_dptools/mod_dptools.c :2317

SWITCH_STANDARD_APP(echo_function)
{
    switch_ivr_session_echo(session, NULL);
}

好,就這麼多了,希望對你有幫助。

微信公眾號:

  • E-Mail : [email protected]
  • 轉載請註明出處,謝謝!
    您的分享是我們最大的動力!

    -Advertisement-
    Play Games
    更多相關文章
    • 基礎知識 機器語言 機器語言是機器指令的集合 機器指令是一臺機器可以正確執行的命令 機器指令由一串二進位數表示 彙編語言 彙編語言的主體是彙編指令 彙編指令是機器指令便於記憶的書寫格式 彙編指令是機器指令的助記符 彙編語言的組成 彙編指令:機器碼的助記符,有對應的機器碼 偽指令::沒有對應的機器碼, ...
    • 可移動嵌入式設備是數據客戶端的一種表現形式。軟體的代碼編寫之後是運行在伺服器之上, 伺服器的數據為客戶端提供服務的模式為伺服器客戶端模式,server2client 架構。伺服器可以是大型的機器,也可以是小型機,主要看數據處理量和用戶量的大小。一臺電腦其實就是一臺簡單的伺服器,電腦的存在是使用中 ...
    • 一些研發工程師在Springboot註意點1. 正確設計代碼目錄結構雖然您有很大的自由度,但有一些基本規則值得遵循來設計您的源代碼結構。避免使用預設包。確保所有內容(包括入口點)都在命名良好的包中,這樣您就可以避免與組裝和組件掃描相關的意外情況;將 Application.java(應用程式的入口類 ...
    • 變數只在創建它的區域內可用。這被稱為作用域。 局部作用域 在函數內部創建的變數屬於該函數的局部作用域,並且只能在該函數內部使用。 示例:在函數內部創建的變數在該函數內部可用: def myfunc(): x = 300 print(x) myfunc() 函數內部的函數 如上面的示例所解釋的那樣,變 ...
    • 一.數組 數組的定義:相同類型的數據集合 go語言中數組的索引從0開始 沒有賦值的數值型數組,預設值為0 數組一旦被創建,它的大小就是不可改變的 (1)聲明數組與列印 var 變數名 [大小]變數類型 //數組的聲明 var nums [4]int //數組的賦值 nums[0] = 1 nums[ ...
    • 對於日常開發者來講很少會使用到本章節的內容,但是對框架作者等是必備知識,同時也是高頻的面試常見問題。 1.線程安全 線程安全是多線程或多進程編程中的一個概念,在擁有共用數據的多條線程並行執行的程式中,線程安全的代碼會通過同步機制保證各個線程都可以正常且正確的執行,不會出現數據污染等意外情況。 線程安 ...
    • 在寫代碼的時候,免不了要使用變數。但程式中的一個變數並不一定是在哪裡都可以被使用,根據情況不同,會有不同的“有效範圍”。 看這樣一段代碼: def func(x): print ('X in the beginning of func(x): ', x) x = 2 print ('X in the ...
    • 用go封裝一下臨時token 本篇為用go設計開發一個自己的輕量級登錄庫/框架吧 的臨時token篇,會講講臨時token的實現,給庫/框架增加新的功能。 Github:https://github.com/weloe/token-go 臨時token也算是比較常見的業務,例如登錄驗證碼信息,邀請鏈 ...
    一周排行
      -Advertisement-
      Play Games
    • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
    • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
    • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
    • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
    • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
    • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
    • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
    • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
    • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
    • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...