aboutsummaryrefslogtreecommitdiff
path: root/net/socat/files
diff options
context:
space:
mode:
authorDobroslaw Kijowski <dobo90@gmail.com>2021-01-27 20:50:51 +0100
committerDobroslaw Kijowski <dobo90@gmail.com>2021-01-27 21:24:38 +0100
commit218b7521aa5ba2a365190d016eac3dadb56cb1f3 (patch)
tree2c64d78aa06eeadb056d5ccde8faaeaedc971bba /net/socat/files
parent37730ae7f41b41e6149d9b4a24f9ab2d314092db (diff)
socat: allow more complex command line options
Current implementation of socat's init service doesn't allow to run more complex configurations. As an example there's no possibility to execute following command: socat TCP-LISTEN:8080,fork,reuseaddr,bind=192.168.1.1 \ EXEC:"/sbin/ip netns exec somenetns socat STDIO TCP:10.0.0.1:80" In such command the first line is argv[1] and the second line is argv[2]. SocatOptions config option is a string. As as a consequence of this each word will be passed as a separate argv element. Socat won't be able to parse arguments correctly. In order to mitigate this issue, we can also accept SocatOptions as a list of strings. Following config file will work correctly: config socat 'tunnel_8080_into_somenetns' option enable '1' list SocatOptions 'TCP-LISTEN:8080,fork,reuseaddr,bind=192.168.1.1' list SocatOptions 'EXEC:"/sbin/ip netns exec somenetns socat STDIO TCP:10.0.0.1:80"' While we're at it, pass stdout and stderr into logread. Signed-off-by: Dobroslaw Kijowski <dobo90@gmail.com>
Diffstat (limited to 'net/socat/files')
-rw-r--r--net/socat/files/socat.init18
1 files changed, 16 insertions, 2 deletions
diff --git a/net/socat/files/socat.init b/net/socat/files/socat.init
index b41293573..a4d3c8224 100644
--- a/net/socat/files/socat.init
+++ b/net/socat/files/socat.init
@@ -12,11 +12,18 @@ validate_section_socat()
{
uci_load_validate socat socat "$1" "$2" \
'enable:bool:1' \
- 'SocatOptions:string'
+ 'SocatOptions:or(string, list(string))'
+}
+
+append_param_command()
+{
+ procd_append_param command "$1"
}
socat_instance()
{
+ local is_list
+
[ "$2" = 0 ] || {
echo "validation failed"
return 1
@@ -26,7 +33,14 @@ socat_instance()
procd_open_instance
procd_set_param command "$PROG"
- procd_append_param command $SocatOptions
+ config_get is_list "$1" SocatOptions_LENGTH
+ if [ -z "$is_list" ]; then
+ procd_append_param command $SocatOptions
+ else
+ config_list_foreach "$1" SocatOptions append_param_command
+ fi
+ procd_set_param stdout 1
+ procd_set_param stderr 1
procd_close_instance
}