Browse Source

- remove isalphanumeric() and replace it with a shell pattern, that

tries a bit harder to identify invalid interface names and in
this case emit an error message.
- use [[ $1 == autoboot ]] to avoid a shell error message due to
possible spaces in first argument
- no change in functionality
discussed with krw and halex
ok ("I like this") krw
OPENBSD_5_3
rpe 12 years ago
parent
commit
d83e309127
1 changed files with 4 additions and 17 deletions
  1. +4
    -17
      src/etc/netstart

+ 4
- 17
src/etc/netstart View File

@ -1,6 +1,6 @@
#!/bin/sh - #!/bin/sh -
# #
# $OpenBSD: netstart,v 1.134 2011/10/07 16:36:26 deraadt Exp $
# $OpenBSD: netstart,v 1.135 2012/12/02 16:19:18 rpe Exp $
# Strip comments (and leading/trailing whitespace if IFS is set) # Strip comments (and leading/trailing whitespace if IFS is set)
# from a file and spew to stdout # from a file and spew to stdout
@ -12,26 +12,13 @@ stripcom() {
done<$1 done<$1
} }
# Returns true if $1 contains only alphanumerics
isalphanumeric() {
local _n
_n=$1
while [ ${#_n} != 0 ]; do
case $_n in
[A-Za-z0-9]*) ;;
*) return 1;;
esac
_n=${_n#?}
done
return 0
}
# Start the $1 interface # Start the $1 interface
ifstart() { ifstart() {
if=$1 if=$1
# Interface names must be alphanumeric only. We check to avoid # Interface names must be alphanumeric only. We check to avoid
# configuring backup or temp files, and to catch the "*" case. # configuring backup or temp files, and to catch the "*" case.
if ! isalphanumeric "$if"; then
if [[ $if != +([[:alpha:]])+([[:digit:]]) ]]; then
echo "netstart: $if: Invalid interface name"
return return
fi fi
@ -174,7 +161,7 @@ ifmstart() {
# If we were invoked with a list of interface names, just reconfigure these # If we were invoked with a list of interface names, just reconfigure these
# interfaces (or bridges) and return. # interfaces (or bridges) and return.
if [ $1x = autobootx ]; then
if [[ $1 == autoboot ]]; then
shift shift
fi fi
if [ $# -gt 0 ]; then if [ $# -gt 0 ]; then


Loading…
Cancel
Save