diff options
author | Dobroslaw Kijowski <dobo90@gmail.com> | 2021-01-27 20:50:51 +0100 |
---|---|---|
committer | Dobroslaw Kijowski <dobo90@gmail.com> | 2021-01-27 21:24:38 +0100 |
commit | 218b7521aa5ba2a365190d016eac3dadb56cb1f3 (patch) | |
tree | 2c64d78aa06eeadb056d5ccde8faaeaedc971bba /net/socat/files | |
parent | 37730ae7f41b41e6149d9b4a24f9ab2d314092db (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.init | 18 |
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 } |