# #
###############################################################################
+# Allow only one instance of this hook
+HOOK_UNIQUE="true"
+
hook_new() {
- cmd_not_implemented
+ local zone="${1}"
+ shift
+
+ # Check if we are allowed to have multiple configurations of $HOOK
+ if enabled HOOK_UNIQUE && zone_config_hook_is_configured "${zone}" "${HOOK}"; then
+ error "You can only have one configuration of type ${HOOK}"
+ return ${EXIT_CONF_ERROR}
+ fi
+
+ local id=$(zone_config_get_new_id ${zone})
+ log DEBUG "ID for the config is: ${id}"
+
+ # Import all default variables
+ hook_set_defaults
+
+ # Parse command line arguments
+ if ! hook_parse_cmdline "${id}" "$@"; then
+ # Return an error if the parsing of the cmd line fails
+ return ${EXIT_ERROR}
+ fi
+
+ # Write configuration to disk
+ if ! zone_config_settings_write "${zone}" "${HOOK}"; then
+ return ${EXIT_ERROR}
+ fi
+
+ return ${EXIT_OK}
}
hook_edit() {
fi
fi
- local ${HOOK_CONFIG_SETTINGS}
+ local ${HOOK_SETTINGS}
# If reading the config fails we cannot go on
if ! zone_config_settings_read "${zone}" "${config}"; then
return ${EXIT_ERROR}
fi
- if ! hook_parse_cmdline $@; then
+ if ! hook_parse_cmdline "${id}" "$@"; then
# Return an error if the parsing of the cmd line fails
return ${EXIT_ERROR}
fi
exit ${EXIT_OK}
}
+
+hook_destroy() {
+ return ${EXIT_OK}
+}
+
+
+# Returns the ID as a unique identifier
+# Should always be overwritten by a hook
+hook_hid() {
+ local zone=${1}
+ local config=${2}
+
+ config_get_id_from_config "${config}"
+}