X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=windows%2Fwinstore.c;h=26cbf63496e9fdbb2c04d439c810144c2738738a;hb=095072fa46b2d7b8beafaddb2f873d2f500a1e10;hp=ce5dae61da56070ad8676d309cffd425954e7099;hpb=f9f93584c29d9e327985d3c695b87f9b981de7be;p=PuTTY.git diff --git a/windows/winstore.c b/windows/winstore.c index ce5dae61..26cbf634 100644 --- a/windows/winstore.c +++ b/windows/winstore.c @@ -6,6 +6,7 @@ #include #include #include +#include #include "putty.h" #include "storage.h" @@ -109,7 +110,7 @@ void *open_settings_w(const char *sessionname, char **errmsg) void write_setting_s(void *handle, const char *key, const char *value) { if (handle) - RegSetValueEx((HKEY) handle, key, 0, REG_SZ, value, + RegSetValueEx((HKEY) handle, key, 0, REG_SZ, (CONST BYTE *)value, 1 + strlen(value)); } @@ -152,7 +153,7 @@ void *open_settings_r(const char *sessionname) char *read_setting_s(void *handle, const char *key) { - DWORD type, size; + DWORD type, allocsize, size; char *ret; if (!handle) @@ -164,13 +165,17 @@ char *read_setting_s(void *handle, const char *key) type != REG_SZ) return NULL; - ret = snewn(size+1, char); + allocsize = size+1; /* allow for an extra NUL if needed */ + ret = snewn(allocsize, char); if (RegQueryValueEx((HKEY) handle, key, 0, - &type, ret, &size) != ERROR_SUCCESS || + &type, (BYTE *)ret, &size) != ERROR_SUCCESS || type != REG_SZ) { sfree(ret); return NULL; } + assert(size < allocsize); + ret[size] = '\0'; /* add an extra NUL in case RegQueryValueEx + * didn't supply one */ return ret; } @@ -367,7 +372,8 @@ int verify_host_key(const char *hostname, int port, readlen = len; otherstr = snewn(len, char); - ret = RegQueryValueEx(rkey, regname, NULL, &type, otherstr, &readlen); + ret = RegQueryValueEx(rkey, regname, NULL, + &type, (BYTE *)otherstr, &readlen); if (ret != ERROR_SUCCESS && ret != ERROR_MORE_DATA && !strcmp(keytype, "rsa")) { @@ -380,7 +386,7 @@ int verify_host_key(const char *hostname, int port, char *oldstyle = snewn(len + 10, char); /* safety margin */ readlen = len; ret = RegQueryValueEx(rkey, justhost, NULL, &type, - oldstyle, &readlen); + (BYTE *)oldstyle, &readlen); if (ret == ERROR_SUCCESS && type == REG_SZ) { /* @@ -426,7 +432,7 @@ int verify_host_key(const char *hostname, int port, * wrong, and hyper-cautiously do nothing. */ if (!strcmp(otherstr, key)) - RegSetValueEx(rkey, regname, 0, REG_SZ, otherstr, + RegSetValueEx(rkey, regname, 0, REG_SZ, (BYTE *)otherstr, strlen(otherstr) + 1); } @@ -449,6 +455,16 @@ int verify_host_key(const char *hostname, int port, return 0; /* key matched OK in registry */ } +int have_ssh_host_key(const char *hostname, int port, + const char *keytype) +{ + /* + * If we have a host key, verify_host_key will return 0 or 2. + * If we don't have one, it'll return 1. + */ + return verify_host_key(hostname, port, keytype, "") != 1; +} + void store_host_key(const char *hostname, int port, const char *keytype, const char *key) { @@ -461,7 +477,7 @@ void store_host_key(const char *hostname, int port, if (RegCreateKey(HKEY_CURRENT_USER, PUTTY_REG_POS "\\SshHostKeys", &rkey) == ERROR_SUCCESS) { - RegSetValueEx(rkey, regname, 0, REG_SZ, key, strlen(key) + 1); + RegSetValueEx(rkey, regname, 0, REG_SZ, (BYTE *)key, strlen(key) + 1); RegCloseKey(rkey); } /* else key does not exist in registry */ @@ -521,7 +537,7 @@ static HANDLE access_random_seed(int action) if (RegOpenKey(HKEY_CURRENT_USER, PUTTY_REG_POS, &rkey) == ERROR_SUCCESS) { int ret = RegQueryValueEx(rkey, "RandSeedFile", - 0, &type, seedpath, &size); + 0, &type, (BYTE *)seedpath, &size); if (ret != ERROR_SUCCESS || type != REG_SZ) seedpath[0] = '\0'; RegCloseKey(rkey); @@ -642,7 +658,7 @@ static int transform_jumplist_registry int ret; HKEY pjumplist_key, psettings_tmp; DWORD type; - int value_length; + DWORD value_length; char *old_value, *new_value; char *piterator_old, *piterator_new, *piterator_tmp; @@ -657,7 +673,7 @@ static int transform_jumplist_registry value_length = 200; old_value = snewn(value_length, char); ret = RegQueryValueEx(pjumplist_key, reg_jumplist_value, NULL, &type, - old_value, &value_length); + (BYTE *)old_value, &value_length); /* When the passed buffer is too small, ERROR_MORE_DATA is * returned and the required size is returned in the length * argument. */ @@ -665,7 +681,7 @@ static int transform_jumplist_registry sfree(old_value); old_value = snewn(value_length, char); ret = RegQueryValueEx(pjumplist_key, reg_jumplist_value, NULL, &type, - old_value, &value_length); + (BYTE *)old_value, &value_length); } if (ret == ERROR_FILE_NOT_FOUND) { @@ -739,7 +755,7 @@ static int transform_jumplist_registry /* Save the new list to the registry. */ ret = RegSetValueEx(pjumplist_key, reg_jumplist_value, 0, REG_MULTI_SZ, - new_value, piterator_new - new_value); + (BYTE *)new_value, piterator_new - new_value); sfree(old_value); old_value = new_value;