X-Git-Url: https://git.distorted.org.uk/u/mdw/putty/blobdiff_plain/ff2ae36762dccc463baba86bf9d39de1a57a70e1..125105d16c788398562ac03e91ce7a0dc0292492:/console.c diff --git a/console.c b/console.c index 2a7efdcb..90b5fa4e 100644 --- a/console.c +++ b/console.c @@ -15,7 +15,28 @@ int console_batch_mode = FALSE; -void verify_ssh_host_key(char *host, int port, char *keytype, +static void *console_logctx = NULL; + +/* + * Clean up and exit. + */ +void cleanup_exit(int code) +{ + /* + * Clean up. + */ + sk_cleanup(); + WSACleanup(); + + random_save_seed(); +#ifdef MSCRYPTOAPI + crypto_wrapup(); +#endif + + exit(code); +} + +void verify_ssh_host_key(void *frontend, char *host, int port, char *keytype, char *keystr, char *fingerprint) { int ret; @@ -86,7 +107,7 @@ void verify_ssh_host_key(char *host, int port, char *keytype, if (ret == 2) { /* key was different */ if (console_batch_mode) { fprintf(stderr, wrongmsg_batch, fingerprint); - exit(1); + cleanup_exit(1); } fprintf(stderr, wrongmsg, fingerprint); fflush(stderr); @@ -94,7 +115,7 @@ void verify_ssh_host_key(char *host, int port, char *keytype, if (ret == 1) { /* key was absent */ if (console_batch_mode) { fprintf(stderr, absentmsg_batch, fingerprint); - exit(1); + cleanup_exit(1); } fprintf(stderr, absentmsg, fingerprint); fflush(stderr); @@ -112,16 +133,20 @@ void verify_ssh_host_key(char *host, int port, char *keytype, store_host_key(host, port, keytype, keystr); } else { fprintf(stderr, abandoned); - exit(0); + cleanup_exit(0); } } +void update_specials_menu(void *frontend) +{ +} + /* * Ask whether the selected cipher is acceptable (since it was * below the configured 'warn' threshold). * cs: 0 = both ways, 1 = client->server, 2 = server->client */ -void askcipher(char *ciphername, int cs) +void askcipher(void *frontend, char *ciphername, int cs) { HANDLE hin; DWORD savemode, i; @@ -143,7 +168,7 @@ void askcipher(char *ciphername, int cs) (cs == 0) ? "" : (cs == 1) ? "client-to-server " : "server-to-client ", ciphername); - exit(1); + cleanup_exit(1); } fprintf(stderr, msg, @@ -163,7 +188,7 @@ void askcipher(char *ciphername, int cs) return; } else { fprintf(stderr, abandoned); - exit(0); + cleanup_exit(0); } } @@ -171,7 +196,7 @@ void askcipher(char *ciphername, int cs) * Ask whether to wipe a session log file before writing to it. * Returns 2 for wipe, 1 for append, 0 for cancel (don't log). */ -int askappend(char *filename) +int askappend(void *frontend, Filename filename) { HANDLE hin; DWORD savemode, i; @@ -192,11 +217,11 @@ int askappend(char *filename) char line[32]; if (console_batch_mode) { - fprintf(stderr, msgtemplate_batch, FILENAME_MAX, filename); + fprintf(stderr, msgtemplate_batch, FILENAME_MAX, filename.path); fflush(stderr); return 0; } - fprintf(stderr, msgtemplate, FILENAME_MAX, filename); + fprintf(stderr, msgtemplate, FILENAME_MAX, filename.path); fflush(stderr); hin = GetStdHandle(STD_INPUT_HANDLE); @@ -216,6 +241,13 @@ int askappend(char *filename) /* * Warn about the obsolescent key file format. + * + * Uniquely among these functions, this one does _not_ expect a + * frontend handle. This means that if PuTTY is ported to a + * platform which requires frontend handles, this function will be + * an anomaly. Fortunately, the problem it addresses will not have + * been present on that platform, so it can plausibly be + * implemented as an empty function. */ void old_keyfile_warning(void) { @@ -233,11 +265,16 @@ void old_keyfile_warning(void) fputs(message, stderr); } -void logevent(char *string) +void console_provide_logctx(void *logctx) { + console_logctx = logctx; } -char *console_password = NULL; +void logevent(void *frontend, char *string) +{ + if (console_logctx) + log_eventlog(console_logctx, string); +} int console_get_line(const char *prompt, char *str, int maxlen, int is_pw) @@ -245,19 +282,6 @@ int console_get_line(const char *prompt, char *str, HANDLE hin, hout; DWORD savemode, newmode, i; - if (is_pw && console_password) { - static int tried_once = 0; - - if (tried_once) { - return 0; - } else { - strncpy(str, console_password, maxlen); - str[maxlen - 1] = '\0'; - tried_once = 1; - return 1; - } - } - if (console_batch_mode) { if (maxlen > 0) str[0] = '\0'; @@ -266,7 +290,7 @@ int console_get_line(const char *prompt, char *str, hout = GetStdHandle(STD_OUTPUT_HANDLE); if (hin == INVALID_HANDLE_VALUE || hout == INVALID_HANDLE_VALUE) { fprintf(stderr, "Cannot get standard input/output handles\n"); - exit(1); + cleanup_exit(1); } GetConsoleMode(hin, &savemode); @@ -294,3 +318,11 @@ int console_get_line(const char *prompt, char *str, } return 1; } + +void frontend_keypress(void *handle) +{ + /* + * This is nothing but a stub, in console code. + */ + return; +}