Blame src/log/toks_log_token_info.c

5ce44d
/*********************************************************/
5ce44d
/*  toksvc: a framework-native token broker service      */
5ce44d
/*  Copyright (C) 2020  Z. Gilboa                        */
5ce44d
/*  Released under GPLv2 and GPLv3; see COPYING.TOKSVC.  */
5ce44d
/*********************************************************/
5ce44d
5ce44d
#include <psxtypes/psxtypes.h>
5ce44d
#include <ntapi/nt_tty.h>
5ce44d
5ce44d
#include <toksvc/toksvc.h>
5ce44d
#include "toksvc_driver_impl.h"
5ce44d
#include "toksvc_daemon_impl.h"
5ce44d
#include "toksvc_log_impl.h"
5ce44d
5ce44d
void toks_log_token_info(struct toks_daemon_ctx * dctx)
5ce44d
{
5ce44d
	struct toks_driver_ctx * drvctx = dctx->driver_ctx;
5ce44d
5ce44d
	TOKS_LOG_LEVEL(drvctx,1);
5ce44d
5ce44d
	int                   idx;
5ce44d
	char                  path[2048];
5ce44d
	char                  tokstr[64];
5ce44d
	struct toks_token *   token;
5ce44d
5ce44d
	toks_log_service_info(dctx);
5ce44d
5ce44d
	token = toks_get_driver_tokens(dctx->driver_ctx);
5ce44d
5ce44d
	toks_log_write(
5ce44d
		drvctx,
5ce44d
		TOKS_LOG_ENTRY_SUB_LEVEL_1,
5ce44d
		"\n",0);
5ce44d
5ce44d
	toks_log_write(
5ce44d
		drvctx,
5ce44d
		TOKS_LOG_ENTRY_SUB_LEVEL_2,
5ce44d
		"%-11s%-55s%-12s%-14s%s\n",
5ce44d
		"token no.",
5ce44d
		"token id.",
5ce44d
		"token pid",
5ce44d
		"token syspid",
5ce44d
		"token refstr",
5ce44d
		0);
5ce44d
5ce44d
	toks_log_write(
5ce44d
		drvctx,
5ce44d
		TOKS_LOG_ENTRY_SUB_LEVEL_2,
5ce44d
		"%-11s%-55s%-12s%-14s%s\n",
5ce44d
		"=========",
5ce44d
		"=========",
5ce44d
		"=========",
5ce44d
		"============",
5ce44d
		"============",
5ce44d
		0);
5ce44d
5ce44d
	for (idx=0; idx<dctx->utokens; token++) {
5ce44d
		if (token->self) {
5ce44d
			toks_log_get_process_name(
5ce44d
				token->client.hprocess,
5ce44d
				path,sizeof(path));
5ce44d
5ce44d
			ntapi->sprintf(
5ce44d
				tokstr,
5ce44d
				"%08x-%08x-%08x-%08x-%08x-%08x",
5ce44d
				token->keys.key[0],
5ce44d
				token->keys.key[1],
5ce44d
				token->keys.key[2],
5ce44d
				token->keys.key[3],
5ce44d
				token->keys.key[4],
5ce44d
				token->keys.key[5]);
5ce44d
5ce44d
			if (token->client.tokpid) {
5ce44d
				toks_log_write(
5ce44d
					drvctx,
5ce44d
					TOKS_LOG_ENTRY_SUB_LEVEL_2,
5ce44d
					"#%-10d%-55s%-12d%-14d%s\n",
5ce44d
					++idx,tokstr,
5ce44d
					token->client.tokpid,
5ce44d
					token->client.cid.process_id,
5ce44d
					token->meta.key);
5ce44d
			} else {
5ce44d
				toks_log_write(
5ce44d
					drvctx,
5ce44d
					TOKS_LOG_ENTRY_SUB_LEVEL_2,
5ce44d
					"#%-10d%-55s%-12s%-14d%s\n",
5ce44d
					++idx,tokstr,"N/A",
5ce44d
					token->client.cid.process_id,
5ce44d
					token->meta.key);
5ce44d
			}
5ce44d
5ce44d
			toks_log_write(
5ce44d
				drvctx,
5ce44d
				TOKS_LOG_ENTRY_SUB_LEVEL_2,
5ce44d
				"%-11s%s.\n",(char[]){0},path);
5ce44d
5ce44d
			toks_log_write(
5ce44d
				drvctx,
5ce44d
				TOKS_LOG_ENTRY_SUB_LEVEL_1,
5ce44d
				"\n",0);
5ce44d
		}
5ce44d
	}
5ce44d
}