From: Jiri Slachta Date: Thu, 4 Apr 2013 16:15:12 +0000 (+0200) Subject: Add siproxd package. X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=992a5fd8eb16d6c693581e9e812cb0503aee2371;p=feed%2Ftelephony.git Add siproxd package. Signed-off-by: Jiri Slachta --- diff --git a/siproxd/Makefile b/siproxd/Makefile new file mode 100644 index 0000000..6b08d05 --- /dev/null +++ b/siproxd/Makefile @@ -0,0 +1,86 @@ +# +# Copyright (C) 2006-2011 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# + +include $(TOPDIR)/rules.mk + +PKG_NAME:=siproxd +PKG_VERSION:=0.8.1 +PKG_RELEASE:=3 + +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz +PKG_SOURCE_URL:=@SF/siproxd +PKG_MD5SUM:=1a6f9d13aeb2d650375c9a346ac6cbaf + +PKG_FIXUP:=autoreconf +PKG_INSTALL:=1 +PKG_BUILD_PARALLEL:=1 + +include $(INCLUDE_DIR)/package.mk + +define Package/siproxd/Default + SECTION:=net + CATEGORY:=Network + SUBMENU:=Telephony + URL:=http://siproxd.sourceforge.net/ +endef + +define Package/siproxd + $(call Package/siproxd/Default) + DEPENDS:=+libltdl +libpthread +libosip2 + TITLE:=SIP (Session Initiation Protocol) proxy + MENU:=1 +endef + +define Package/siproxd/description + Siproxd is a proxy/masquerading daemon for the SIP protocol. +endef + +define Package/siproxd/conffiles +/etc/config/siproxd +endef + +CONFIGURE_ARGS+= \ + --with-libosip-prefix="$(STAGING_DIR)/usr" \ + --disable-doc + +MAKE_FLAGS+= \ + SUBDIRS="src scripts contrib" \ + LIBLTDL="$(STAGING_DIR)/usr/lib/libltdl.la" \ + +define Package/siproxd/install + $(INSTALL_DIR) $(1)/usr/sbin + $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/siproxd $(1)/usr/sbin + $(INSTALL_DIR) $(1)/etc/config + $(INSTALL_CONF) ./files/siproxd.config $(1)/etc/config/siproxd + $(INSTALL_DIR) $(1)/etc/init.d + $(INSTALL_BIN) ./files/siproxd.init $(1)/etc/init.d/siproxd +endef + +define BuildPlugin + define Package/siproxd-mod-$(1) + $$(call Package/siproxd/Default) + TITLE:= siproxd $(1) plugin + DEPENDS:=siproxd + endef + + define Package/siproxd-mod-$(1)/install + $(INSTALL_DIR) $$(1)/usr/lib/siproxd + $(INSTALL_DATA) $(PKG_INSTALL_DIR)/usr/lib/siproxd/plugin_$(1)*.so* $$(1)/usr/lib/siproxd + endef + + $$(eval $$(call BuildPackage,siproxd-mod-$(1))) +endef + +$(eval $(call BuildPackage,siproxd)) +$(eval $(call BuildPlugin,defaulttarget)) +$(eval $(call BuildPlugin,demo)) +$(eval $(call BuildPlugin,fix_bogus_via)) +$(eval $(call BuildPlugin,logcall)) +$(eval $(call BuildPlugin,prefix)) +$(eval $(call BuildPlugin,regex)) +$(eval $(call BuildPlugin,shortdial)) +$(eval $(call BuildPlugin,stun)) diff --git a/siproxd/files/siproxd.config b/siproxd/files/siproxd.config new file mode 100644 index 0000000..b65148c --- /dev/null +++ b/siproxd/files/siproxd.config @@ -0,0 +1,3 @@ +config siproxd general + option if_inbound lan + option if_outbound wan diff --git a/siproxd/files/siproxd.init b/siproxd/files/siproxd.init new file mode 100644 index 0000000..4ecdfbb --- /dev/null +++ b/siproxd/files/siproxd.init @@ -0,0 +1,235 @@ +#!/bin/sh /etc/rc.common +# Copyright (C) 2008 Alina Friedrichsen +# Copyright (C) 2011 OpenWrt.org + +START=50 + +SERVICE_USE_PID=1 + +siproxd_bin="/usr/sbin/siproxd" +siproxd_conf_dir="/var/etc" +siproxd_conf_prefix="$siproxd_conf_dir/siproxd-" +siproxd_registration_dir="/var/lib/siproxd" +siproxd_pid_dir="/var/run/siproxd" + +deal_with_lists () { + echo "$2" = "$1" >> "$siproxd_conf_prefix$cfg" +} + +start_instance() { + local cfg="$1" + + config_get if_inbound "$cfg" if_inbound + config_get if_outbound "$cfg" if_outbound + config_get host_outbound "$cfg" host_outbound + config_get hosts_allow_reg "$cfg" hosts_allow_reg + config_get hosts_allow_sip "$cfg" hosts_allow_sip + config_get hosts_deny_sip "$cfg" hosts_deny_sip + config_get sip_listen_port "$cfg" sip_listen_port 5060 + config_get_bool daemonize "$cfg" daemonize 1 + config_get silence_log "$cfg" silence_log 4 + config_get user "$cfg" user nobody + config_get chrootjail "$cfg" chrootjail + config_get registration_file "$cfg" registration_file "$siproxd_registration_dir/siproxd_registrations-$cfg" + config_get autosave_registrations "$cfg" autosave_registrations 300 + config_get pid_file "$cfg" pid_file "$siproxd_pid_dir/siproxd-$cfg.pid" + config_get_bool rtp_proxy_enable "$cfg" rtp_proxy_enable 1 + config_get rtp_port_low "$cfg" rtp_port_low 7070 + config_get rtp_port_high "$cfg" rtp_port_high 7089 + config_get rtp_timeout "$cfg" rtp_timeout 300 + config_get rtp_dscp "$cfg" rtp_dscp 46 + config_get sip_dscp "$cfg" sip_dscp 0 + config_get rtp_input_dejitter "$cfg" rtp_input_dejitter 0 + config_get rtp_output_dejitter "$cfg" rtp_output_dejitter 0 + config_get tcp_timeout "$cfg" tcp_timeout 600 + config_get tcp_connect_timeout "$cfg" tcp_connect_timeout 500 + config_get tcp_keepalive "$cfg" tcp_keepalive 20 + config_get default_expires "$cfg" default_expires 600 + config_get proxy_auth_realm "$cfg" proxy_auth_realm + config_get proxy_auth_passwd "$cfg" proxy_auth_passwd + config_get proxy_auth_pwfile "$cfg" proxy_auth_pwfile + config_get debug_level "$cfg" debug_level 0x00000000 + config_get debug_port "$cfg" debug_port 0 + config_get mask_host "$cfg" mask_host + config_get masked_host "$cfg" masked_host + config_get ua_string "$cfg" ua_string Siproxd-UA + config_get use_rport "$cfg" use_rport 0 + config_get outbound_proxy_host "$cfg" outbound_proxy_host + config_get outbound_proxy_port "$cfg" outbound_proxy_port + config_get outbound_domain_name "$cfg" outbound_domain_name + config_get outbound_domain_host "$cfg" outbound_domain_host + config_get outbound_domain_port "$cfg" outbound_domain_port + + if [ -f "$siproxd_conf_prefix$cfg" ]; then + rm "$siproxd_conf_prefix$cfg" + fi + if [ -n "$if_inbound" ]; then + echo if_inbound = "$if_inbound" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$if_outbound" ]; then + echo if_outbound = "$if_outbound" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$host_outbound" ]; then + echo host_outbound = "$host_outbound" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$hosts_allow_reg" ]; then + echo hosts_allow_reg = "$hosts_allow_reg" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$hosts_allow_sip" ]; then + echo hosts_allow_sip = "$hosts_allow_sip" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$hosts_deny_sip" ]; then + echo hosts_deny_sip = "$hosts_deny_sip" >> "$siproxd_conf_prefix$cfg" + fi + echo sip_listen_port = "$sip_listen_port" >> "$siproxd_conf_prefix$cfg" + echo daemonize = "$daemonize" >> "$siproxd_conf_prefix$cfg" + echo silence_log = "$silence_log" >> "$siproxd_conf_prefix$cfg" + echo user = "$user" >> "$siproxd_conf_prefix$cfg" + if [ -n "$chrootjail" ]; then + if [ ! -d "$chrootjail" ]; then + mkdir -p "$chrootjail" + chmod 0755 "$chrootjail" + fi + echo chrootjail = "$chrootjail" >> "$siproxd_conf_prefix$cfg" + fi + echo registration_file = "$registration_file" >> "$siproxd_conf_prefix$cfg" + echo autosave_registrations = "$autosave_registrations" >> "$siproxd_conf_prefix$cfg" + + echo pid_file = "$pid_file" >> "$siproxd_conf_prefix$cfg" + echo rtp_proxy_enable = "$rtp_proxy_enable" >> "$siproxd_conf_prefix$cfg" + echo rtp_port_low = "$rtp_port_low" >> "$siproxd_conf_prefix$cfg" + echo rtp_port_high = "$rtp_port_high" >> "$siproxd_conf_prefix$cfg" + echo rtp_timeout = "$rtp_timeout" >> "$siproxd_conf_prefix$cfg" + echo rtp_dscp = "$rtp_dscp" >> "$siproxd_conf_prefix$cfg" + echo sip_dscp = "$sip_dscp" >> "$siproxd_conf_prefix$cfg" + echo rtp_input_dejitter = "$rtp_input_dejitter" >> "$siproxd_conf_prefix$cfg" + echo rtp_output_dejitter = "$rtp_output_dejitter" >> "$siproxd_conf_prefix$cfg" + echo tcp_timeout = "$tcp_timeout" >> "$siproxd_conf_prefix$cfg" + echo tcp_connect_timeout = "$tcp_connect_timeout" >> "$siproxd_conf_prefix$cfg" + echo tcp_keepalive = "$tcp_keepalive" >> "$siproxd_conf_prefix$cfg" + echo default_expires = "$default_expires" >> "$siproxd_conf_prefix$cfg" + if [ -n "$proxy_auth_realm" ]; then + echo proxy_auth_realm = "$proxy_auth_realm" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$proxy_auth_passwd" ]; then + echo proxy_auth_passwd = "$proxy_auth_passwd" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$proxy_auth_pwfile" ]; then + echo proxy_auth_pwfile = "$proxy_auth_pwfile" >> "$siproxd_conf_prefix$cfg" + fi + echo debug_level = "$debug_level" >> "$siproxd_conf_prefix$cfg" + echo debug_port = "$debug_port" >> "$siproxd_conf_prefix$cfg" + if [ -n "$mask_host" ]; then + echo mask_host = "$mask_host" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$masked_host" ]; then + echo masked_host = "$masked_host" >> "$siproxd_conf_prefix$cfg" + fi + echo ua_string = "$ua_string" >> "$siproxd_conf_prefix$cfg" + echo use_rport = "$use_rport" >> "$siproxd_conf_prefix$cfg" + if [ -n "$outbound_proxy_host" ]; then + echo oubound_proxy_host = "$outbound_proxy_host" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$outbound_proxy_port" ]; then + echo outbound_proxy_port = "$outbound_proxy_port" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$outbound_domain_name" ]; then + echo outbound_domain_name = "$outbound_domain_name" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$outbound_domain_host" ]; then + echo outbound_domain_host = "$outbound_domain_host" >> "$siproxd_conf_prefix$cfg" + fi + if [ -n "$outbound_domain_port" ]; then + echo outbound_domain_port = "$outbound_domain_port" >> "$siproxd_conf_prefix$cfg" + fi + + # handle plugins + config_get plugindir "$cfg" plugindir "/usr/lib/siproxd/" + echo plugindir = "$plugindir" >> "$siproxd_conf_prefix$cfg" + + config_list_foreach "$cfg" 'load_plugin' deal_with_lists "load_plugin" + + # plugin_demo.so + config_get plugin_demo_string "$cfg" plugin_demo_string + if [ -n "$plugin_demo_string" ]; then + echo plugin_demo_string = "$plugin_demo_string" >> "$siproxd_conf_prefix$cfg" + fi + + # plugin_shortdial.so + config_get plugin_shortdial_akey "$cfg" plugin_shortdial_akey + if [ -n "$plugin_shortdial_akey" ]; then + echo plugin_shortdial_akey = "$plugin_shortdial_akey" >> "$siproxd_conf_prefix$cfg" + fi + config_list_foreach "$cfg" 'plugin_shortdial_entry' deal_with_lists "plugin_shortdial_entry" + + # plugin_defaulttarget.so + config_get_bool plugin_defaulttarget_log "$cfg" plugin_defaulttarget_log + if [ -n "$plugin_defaulttarget_log" ]; then + echo plugin_defaulttarget_log = "$plugin_defaulttarget_log" >> "$siproxd_conf_prefix$cfg" + fi + config_get plugin_defaulttarget_target "$cfg" plugin_defaulttarget_target + if [ -n "$plugin_defaulttarget_target" ]; then + echo plugin_defaulttarget_target = "$plugin_defaulttarget_target" >> "$siproxd_conf_prefix$cfg" + fi + + # plugin_fix_bogus_via.so + config_get plugin_fix_bogus_via_networks "$cfg" plugin_fix_bogus_via_networks + if [ -n "$plugin_fix_bogus_via_networks" ]; then + echo plugin_fix_bogus_via_networks = "$plugin_fix_bogus_via_networks" >> "$siproxd_conf_prefix$cfg" + fi + + # plugin_stun.so + config_get plugin_stun_server "$cfg" plugin_stun_server + if [ -n "$plugin_stun_server" ]; then + echo plugin_stun_server = "$plugin_stun_server" >> "$siproxd_conf_prefix$cfg" + fi + config_get plugin_stun_port "$cfg" plugin_stun_port + if [ -n "$plugin_stun_port" ]; then + echo plugin_stun_port = "$plugin_stun_port" >> "$siproxd_conf_prefix$cfg" + fi + config_get plugin_stun_period "$cfg" plugin_stun_period + if [ -n "$plugin_stun_period" ]; then + echo plugin_stun_period = "$plugin_stun_period" >> "$siproxd_conf_prefix$cfg" + fi + + # plugin_prefix.so + config_get plugin_prefix_akey "$cfg" plugin_prefix_akey + if [ -n "$plugin_prefix_akey" ]; then + echo plugin_prefix_akey = "$plugin_prefix_akey" >> "$siproxd_conf_prefix$cfg" + fi + + # plugin_regex.so + config_list_foreach "$cfg" 'plugin_regex_desc' deal_with_lists "plugin_regex_desc" + config_list_foreach "$cfg" 'plugin_regex_pattern' deal_with_lists "plugin_regex_pattern" + config_list_foreach "$cfg" 'plugin_regex_replace' deal_with_lists "plugin_regex_replace" + + SERVICE_PID_FILE="$pid_file" \ + service_start $siproxd_bin --config "$siproxd_conf_prefix$cfg" +} + +stop_instance() { + local cfg="$1" + + config_get pid_file "$cfg" pid_file "$siproxd_pid_dir/siproxd-$cfg.pid" + + SERVICE_PID_FILE="$pid_file" \ + service_stop $siproxd_bin +} + +start() { + mkdir -m 0755 -p "$siproxd_conf_dir" + mkdir -m 0755 -p "$siproxd_registration_dir" + [ -d "$siproxd_pid_dir" ] || { + mkdir -m 0755 -p "$siproxd_pid_dir" + chmod 0750 "$siproxd_pid_dir" + chown nobody:nogroup "$siproxd_pid_dir" + } + + config_load 'siproxd' + config_foreach start_instance 'siproxd' +} + +stop() { + config_load 'siproxd' + config_foreach stop_instance 'siproxd' +} diff --git a/siproxd/patches/010-fix-bogus-libltdl-dependency.patch b/siproxd/patches/010-fix-bogus-libltdl-dependency.patch new file mode 100644 index 0000000..20f3b6b --- /dev/null +++ b/siproxd/patches/010-fix-bogus-libltdl-dependency.patch @@ -0,0 +1,26 @@ +--- a/src/Makefile.am ++++ b/src/Makefile.am +@@ -77,8 +77,8 @@ plugin_regex_la_LDFLAGS = -module -avoid + # else Cygwin goes beserk when building...) + # + sbin_PROGRAMS = siproxd +-siproxd_LDFLAGS=-export-dynamic +-siproxd_LDADD = $(LIBLTDL) $(DLOPENPLUGINS) ++siproxd_LDFLAGS=-export-dynamic -lltdl ++siproxd_LDADD = $(DLOPENPLUGINS) + siproxd_SOURCES = siproxd.c proxy.c register.c sock.c utils.c \ + sip_utils.c sip_layer.c log.c readconf.c rtpproxy.c \ + rtpproxy_relay.c accessctl.c route_processing.c \ +--- a/src/Makefile.in ++++ b/src/Makefile.in +@@ -326,8 +326,8 @@ plugin_prefix_la_LDFLAGS = -module -avoi + # + plugin_regex_la_SOURCES = plugin_regex.c + plugin_regex_la_LDFLAGS = -module -avoid-version -shrext '.so' +-siproxd_LDFLAGS = -export-dynamic +-siproxd_LDADD = $(LIBLTDL) $(DLOPENPLUGINS) ++siproxd_LDFLAGS = -export-dynamic -lltdl ++siproxd_LDADD = $(DLOPENPLUGINS) + siproxd_SOURCES = siproxd.c proxy.c register.c sock.c utils.c \ + sip_utils.c sip_layer.c log.c readconf.c rtpproxy.c \ + rtpproxy_relay.c accessctl.c route_processing.c \