kindwolf.org Git repositories yamltab / master keytab-editor
master

Tree @master (Download .tar.gz)

keytab-editor @masterraw · history · blame

#!/usr/bin/env bash

# Copyright © 2020-2025 Xavier G. <xavier.yamltab@kindwolf.org>
# This work is free. You can redistribute it and/or modify it under the
# terms of the Do What The Fuck You Want To Public License, Version 2,
# as published by Sam Hocevar. See the COPYING file for more details.

# Helper variables:
yamltab="${YAMLTAB_PATH:-yamltab}"

# Helper functions:
function edit {
	if `which editor > /dev/null`; then
		editor "$@"
	else
		"${EDITOR:-vi}" "$@"
	fi
}

function cleanup {
	[ -f "${tmp_file}" ] && unlink "${tmp_file}"
	[ -f "${tmp_file}.yaml" ] && unlink "${tmp_file}.yaml"
	[ -d "${tmp_dir}" ] && rmdir "${tmp_dir}"
}

function exit {
	cleanup
	builtin exit $1
}

# Expect a keytab file as single argument:
keytab="${1:?Usage: $0 keytab}"
keytab_filename="$(basename "${keytab}")"

# Redundant with the chmod below; might compensate for some whacky editors?
umask 0077

# Prepare temporary files:
tmp_dir="$(mktemp --directory)" || exit $?
tmp_file="${tmp_dir}/${keytab_filename}"
touch "${tmp_file}" "${tmp_file}.yaml" || exit $?
chmod go-rwx "${tmp_file}" "${tmp_file}.yaml" || exit $?

# Dump the given keytab as YAML:
"${yamltab}" "${keytab}" > "${tmp_file}.yaml" || exit $?
md5_before="$(md5sum "${tmp_file}.yaml")"

# Edit the keytab as YAML:
edit "${tmp_file}.yaml"
rc=$?

# If the YAML dump was not modified, leave the keytab untouched:
md5_after="$(md5sum "${tmp_file}.yaml")"
if [ "${md5_before}" == "${md5_after}" ]; then
	echo "No changes detected, ${keytab} left untouched."
	exit 0
else
	# Convert the YAML into a binary keytab:
	"${yamltab}" "${tmp_file}.yaml" > "${tmp_file}" || exit $?
	# Replace the old keytab with the new one:
	cat "${tmp_file}" > "${keytab}" || exit $?
fi
exit $rc