# #
###############################################################################
-zone_dir() {
- local zone=${1}
-
- echo "${NETWORK_ZONE_DIR}/zones/${zone}"
-}
-
zone_exists() {
local zone=${1}
assert isset zone
- [ -d "$(zone_dir ${zone})" ]
+ [ -d "${NETWORK_ZONES_DIR}/${zone}" ]
}
zone_match() {
local zone=${1}
assert isset zone
- config_get_hook $(zone_dir ${zone})/settings
+ config_get_hook "${NETWORK_ZONES_DIR}/${zone}/settings"
}
zone_start() {
return ${EXIT_ERROR}
fi
- mkdir -p $(zone_dir ${zone})
-
# Create directories for configs and ports
- mkdir -p $(zone_dir ${zone})/{configs,ports}
+ local what
+ for what in configs ports; do
+ make_directory "${NETWORK_ZONES_DIR}/${zone}/${what}"
+ done
hook_zone_exec "${hook}" "new" "${zone}" "$@"
local ret=$?
zone_disable "${zone}"
# Rename the configuration files
- mv -f "$(zone_dir "${zone}")" "$(zone_dir "${name}")"
+ mv -f "${NETWORK_ZONES_DIR}/${zone}" "${NETWORK_ZONES_DIR}/${name}"
# Enable the zone if it was enabled before
[ ${zone_was_enabled} -eq ${EXIT_TRUE} ] && zone_enable "${name}"
return ${EXIT_ERROR}
fi
- log INFO "Destroying zone ${zone}"
-
# Force the zone down.
zone_is_active "${zone}" && zone_stop "${zone}"
# Disable zone auto-start
zone_disable "${zone}"
- rm -rf "$(zone_dir "${zone}")"
+ if ! rm -rf "${NETWORK_ZONES_DIR}/${zone}"; then
+ log ERROR "Could not destroy zone ${zone}"
+ return ${EXIT_ERROR}
+ fi
+
+ log INFO "Destroyed zone ${zone}"
+ return ${EXIT_OK}
}
zone_up() {
assert isset zone
local port
- for port in $(zone_dir ${zone})/ports/*; do
- port=$(basename ${port})
-
- if port_exists ${port}; then
+ for port in $(list_directory "${NETWORK_ZONES_DIR}/${zone}/ports"); do
+ if port_exists "${port}"; then
echo "${port}"
fi
done
local counter=0
local port
- for port in $(zone_dir "${zone}")/ports/*; do
- port="$(basename "${port}")"
-
+ for port in $(list_directory "${NETWORK_ZONES_DIR}/${zone}/ports"); do
if port_exists "${port}"; then
counter=$(( ${counter} + 1 ))
fi
assert isset zone
assert isset port
- [ -e "$(zone_dir ${zone})/ports/${port}" ]
+ [ -e "${NETWORK_ZONES_DIR}/${zone}/ports/${port}" ]
}
zone_config() {
return ${EXIT_FALSE}
}
-zone_show() {
- local zone=${1}
-
- echo "${zone}"
- echo " Type: $(zone_get_hook ${zone})"
- echo
-}
-
-zones_show() {
- local zone
-
- for zone in $(zones_get "$@"); do
- zone_show ${zone}
- done
-}
-
zones_get_all() {
local zone
- for zone in $(zone_dir)/*; do
- zone=$(basename ${zone})
- zone_exists ${zone} || continue
-
- echo "${zone}"
+ for zone in $(list_directory "${NETWORK_ZONES_DIR}"); do
+ if zone_exists ${zone}; then
+ echo "${zone}"
+ fi
done
}
zone_ports_list() {
local zone=${1}
- local port
- for port in $(zone_dir ${zone})/ports/*; do
- [ -e "${port}" ] || continue
-
- echo $(basename ${port})
- done
+ list_directory "${NETWORK_ZONES_DIR}/${zone}/ports"
}
zone_port_attach() {
zone_configs_list() {
local zone=${1}
- local config
- for config in $(zone_dir ${zone})/configs/*; do
- [ -e "${config}" ] || continue
-
- basename ${config}
- done
+ list_directory "${NETWORK_ZONES_DIR}/${zone}/configs"
}
zone_config_get_new_id() {
assert [ $# -eq 1 ]
local zone=${1}
- local zone_path=$(zone_dir ${zone})
+ local zone_path="${NETWORK_ZONES_DIR}/${zone}"
local i=0
while true; do
# with the same setting is already configured for this zone.
# Returns True when yes and False when no.
- assert [ $# -eq 4 ]
+ assert [ $# -eq 5 ]
local zone=${1}
local hook=${2}
- local key=${3}
- local value=${4}
+ local id=${3}
+ local key=${4}
+ local value=${5}
# The key should be local for this function
local ${key}
local config
for config in $(zone_configs_list ${zone}); do
+ # Check if the config is eqal with the config we want to edit, when continue
+ if [[ "${config}" = "${hook}.${id}" ]]; then
+ continue
+ fi
+
# Check if the config is from the given hook, when not continue
if [[ $(zone_config_get_hook "${zone}" "${config}") != ${hook} ]]; then
continue
fi
+
# Get the value of the key for a given function
zone_config_settings_read "${zone}" "${config}" \
--ignore-superfluous-settings "${key}"
local zone=${1}
local id=${2}
- local zone_path=$(zone_dir ${zone})
+ local zone_path="${NETWORK_ZONES_DIR}/${zone}"
[ -f ${zone_path}/configs/*.${id} ];
}
hook_config_get_all
}
-zone_file() {
- local zone=${1}
-
- assert isset zone
-
- echo "$(zone_dir ${zone})/settings"
-}
-
zone_settings_read() {
local zone=${1}
assert isset zone
# Save the HOOK variable.
local hook="${HOOK}"
- settings_read "$(zone_file "${zone}")" ${args}
+ settings_read "${NETWORK_ZONES_DIR}/${zone}/settings" ${args}
# Restore hook.
HOOK="${hook}"
fi
list_append args ${HOOK_SETTINGS}
- settings_write "$(zone_file ${zone})" ${args}
+ settings_write "${NETWORK_ZONES_DIR}/${zone}/settings" ${args}
}
zone_settings_set() {
list_append args "$@"
fi
- local path="$(zone_dir "${zone}")/configs/${config}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/configs/${config}"
settings_read "${path}" ${args}
}
local hook="${2}"
local id=${3}
- if ! isset id; then
- id=$(zone_config_get_new_id ${zone})
- log DEBUG "ID for the config is: ${id}"
- fi
+ assert isset id
local args
if function_exists "hook_check_config_settings"; then
fi
list_append args ${HOOK_CONFIG_SETTINGS}
- local path="$(zone_dir "${zone}")/configs/${hook}.${id}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/configs/${hook}.${id}"
settings_write "${path}" ${args}
}
local zone="${1}"
local config="${2}"
- local path="$(zone_dir "${zone}")/configs/${config}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/configs/${config}"
# Check if path is valid
if [ ! -f ${path} ]; then
rm -f "${path}"
}
+
+zone_config_find_by_hook() {
+ local zone="${1}"
+ assert isset zone
+
+ local hook="${2}"
+ assert isset hook
+
+ local config
+ for config in $(zone_configs_list "${zone}"); do
+ local h="$(zone_config_get_hook "${zone}" "${config}")"
+
+ [[ "${hook}" = "${h}" ]] && echo "${config}"
+ done
+
+ return ${EXIT_OK}
+}
+
+zone_config_settings_read_by_hook() {
+ local zone="${1}"
+ assert isset zone
+
+ local hook="${2}"
+ assert isset hook
+
+ local config
+ for config in $(zone_config_find_by_hook "${zone}" "${hook}"); do
+ zone_config_settings_read "${zone}" "${config}"
+ done
+
+ return ${EXIT_OK}
+}
+
zone_port_settings_read() {
assert [ $# -ge 2 ]
list_append args "$@"
fi
- local path="$(zone_dir "${zone}")/ports/${port}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/ports/${port}"
settings_read "${path}" ${args}
}
fi
list_append args ${HOOK_PORT_SETTINGS}
- local path="$(zone_dir "${zone}")/ports/${port}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/ports/${port}"
settings_write "${path}" ${args}
}
local zone="${1}"
local port="${2}"
- local path="$(zone_dir "${zone}")/ports/${port}"
+ local path="${NETWORK_ZONES_DIR}/${zone}/ports/${port}"
settings_remove "${path}"
}