summaryrefslogtreecommitdiffstats
path: root/src/globals
blob: af411fee16beb3c5bd87ffed9f032e2d9024dbed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# /usr/lib/networks/globals
#
# All +x files in /usr/lib/network/hooks will be sourced when this file is.
# Hook files can override any of the utility functions defined here for custom
# behavior (such as logging error messages to syslog). This lets us keep netcfg
# simple but gives it the flexibility for users to make modular use of it to do
# more complex things


### Globals
PROFILE_DIR="/etc/network.d"
IFACE_DIR="$PROFILE_DIR/interfaces"
SUBR_DIR="/usr/lib/network"
HOOKS_DIR="$SUBR_DIR/hooks"
CONN_DIR="$SUBR_DIR/connections"
STATE_DIR="/run/network"



### Logging/Error reporting

function report_err {
    echo "$*"
}

function report_notice {
    echo "$*"
}

function report_debug {
    checkyesno "$NETCFG_DEBUG" && echo "DEBUG: $*" >&2
}

function report_try {
    # This needs -n and a trailing space.
    echo -n ":: $* "
    REPORT_TRYING=1
}

function report_fail {
    if [[ -n "$*" ]]; then
        if (( REPORT_TRYING )); then
            echo "- $* [fail]"
            REPORT_TRYING=
        else
            echo "$*"
        fi
    elif (( REPORT_TRYING )); then
        echo "[fail]"
        REPORT_TRYING=
    fi
}

function report_success {
    if [[ -n "$*" ]]; then
        # This needs -n and a trailing space.
        echo -n "- $* "
    fi
    echo "[done]"
    REPORT_TRYING=
}

### For calling scripts only; don't use in library functions
function exit_stderr { echo "$*" >&2; exit 1; }
function exit_err { report_err "$*"; exit 1; }
function exit_fail { report_fail "$*"; exit 1; }


### From FreeBSD's /etc/rc.subr
##
# checkyesno var
#    Test $1 variable, and warn if not set to YES or NO.
#    Return 0 if it's "yes" (et al), nonzero otherwise.
#    To default to yes, do: "checkyesno ${VAR:-yes}".
#
function checkyesno() {
    local _value="$1"
    #debug "checkyesno: $1 is set to $_value."
    case "$_value" in

        #    "yes", "true", "on", or "1"
    [Yy][Ee][Ss]|[Tt][Rr][Uu][Ee]|[Oo][Nn]|1)
        return 0
        ;;

        #    "no", "false", "off", or "0"
    [Nn][Oo]|[Ff][Aa][Ll][Ss][Ee]|[Oo][Ff][Ff]|0)
        return 1
        ;;
    *)
        #warn "\$${1} is not set properly - see rc.conf(5)."
        return 1
        ;;
    esac
}


## Waits until a statement succeeds or a timeout occurs
# $1: timeout in seconds
# $2...: condition command
function timeout_wait() {
    local timeout="$1"
    shift
    while ! eval "$*"; do
        (( timeout-- > 0 )) || return 1
        sleep 1
    done
    return 0
}


### Load all +x files in $HOOKS_DIR
function load_hooks() {
    local hook
    for hook in $(find -L "$HOOKS_DIR/" -maxdepth 1 -type f -executable | sort -u); do
        source "$hook"
    done
}

load_hooks

# vim: ft=sh ts=4 et sw=4: