/*	$OpenBSD: tcfserrors.c,v 1.6 2000/06/20 06:45:16 fgsch Exp $	*/

/*
 *	Transparent Cryptographic File System (TCFS) for NetBSD 
 *	Author and mantainer: 	Luigi Catuogno [luicat@tcfs.unisa.it]
 *	
 *	references:		http://tcfs.dia.unisa.it
 *				tcfs-bsd@tcfs.unisa.it
 */

/*
 *	Base utility set v0.1
 */

#include <stdio.h>
#include <unistd.h>
#include "tcfserrors.h"

static char *tcfs_errors_strings[]=
{
	"Ok",
	NULL,
	"unknow option.",
	"authentication error.",
	"out of memory.",
	"you do not have a TCFS key.",
	"Who are you?!",
	"ioctl error while setting permanent flag.",
	"ioctl error while sending.",
	"ioctl error while removing key.",
	"ioctl error while getting key counter."
};

void tcfs_error(int error_type, char *custom_message)
{
	if (error_type != ER_CUSTOM && error_type != OK)
		fprintf(stderr, "Error: ");
	
	switch (error_type) {
	case ER_AUTH:
	case ER_MEM:
	case ER_TCFS:
	case ER_PERM:
	case ER_ENABLE:
	case ER_DISABLE:
	case ER_COUNT:
	case ER_USER:
	case OK:
		fprintf(stderr, "%s\n", tcfs_errors_strings[error_type]);
		exit(error_type);
	case ER_CUSTOM:
		fprintf(stderr, "%s\n", custom_message);
		exit(1);
	case ER_UNKOPT:
		if (custom_message)
			fprintf(stderr, "%s: %s\n", tcfs_errors_strings[error_type], custom_message);
		else
			fprintf(stderr, "%s\n", tcfs_errors_strings[error_type]);
			
		exit(error_type);
		break; /* Useless code */
	default:
		fprintf(stderr, "internal error.\n");
		exit(1);
	}
}