X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=dummy%2Fnetifd-proto.sh;h=c27d56253ed1a955cbd2db704697b62ef3a29d27;hp=0af99b2dbcb6e5ff91f379e596ba7853abb8f525;hb=14f7651a6e61ccd870be78dd6b303057ea982414;hpb=b021a49efe0641f7c5ca763bc43e5ba73b7a1b5f diff --git a/dummy/netifd-proto.sh b/dummy/netifd-proto.sh index 0af99b2..c27d562 100755 --- a/dummy/netifd-proto.sh +++ b/dummy/netifd-proto.sh @@ -33,6 +33,8 @@ _proto_do_teardown() { _proto_do_setup() { json_load "$data" + _EXPORT_VAR=0 + _EXPORT_VARS= eval "$1_setup \"$interface\" \"$ifname\"" } @@ -59,6 +61,12 @@ proto_add_dns_server() { jshn_append PROTO_DNS "$address" } +proto_add_dns_search() { + local address="$1" + + jshn_append PROTO_DNS_SEARCH "$address" +} + proto_add_ipv4_address() { local address="$1" local mask="$2" @@ -100,11 +108,11 @@ _proto_push_route() { local mask="${str%%/*}" local gw="${str#*/}" - json_add_table "" + json_add_object "" json_add_string target "$target" - json_add_integer mask "$mask" + json_add_string netmask "$mask" json_add_string gateway "$gw" - json_close_table + json_close_object } _proto_push_array() { @@ -130,12 +138,20 @@ proto_send_update() { _proto_push_array "ipaddr" "$PROTO_IPADDR" _proto_push_ip _proto_push_array "ip6addr" "$PROTO_IP6ADDR" _proto_push_ip - _proto_push_array "route" "$PROTO_ROUTE" _proto_push_route - _proto_push_array "route6" "$PROTO_ROUTE6" _proto_push_route + _proto_push_array "routes" "$PROTO_ROUTE" _proto_push_route + _proto_push_array "routes6" "$PROTO_ROUTE6" _proto_push_route _proto_push_array "dns" "$PROTO_DNS" _proto_push_ip + _proto_push_array "dns_search" "$PROTO_DNS_SEARCH" _proto_push_ip _proto_notify "$interface" } +proto_export() { + local var="VAR${_EXPORT_VAR}" + _EXPORT_VAR="$(($_EXPORT_VAR + 1))" + export -- "$var=$1" + jshn_append _EXPORT_VARS "$var" +} + proto_run_command() { local interface="$1"; shift @@ -146,6 +162,14 @@ proto_run_command() { json_add_string "" "$1" shift done + json_close_array + [ -n "$_EXPORT_VARS" ] && { + json_add_array env + for var in $_EXPORT_VARS; do + eval "json_add_string \"\" \"\${$var}\"" + done + json_close_array + } _proto_notify "$interface" } @@ -158,6 +182,28 @@ proto_kill_command() { _proto_notify "$interface" } +proto_notify_error() { + local interface="$1"; shift + + json_init + json_add_int action 3 + json_add_array error + while [ $# -gt 0 ]; do + json_add_string "" "$1" + shift + done + json_close_array + _proto_notify "$interface" +} + +proto_block_restart() { + local interface="$1"; shift + + json_init + json_add_int action 4 + _proto_notify "$interface" +} + init_proto() { proto="$1"; shift cmd="$1"; shift