1
1

pki: Use ssh_string_get_char().

Этот коммит содержится в:
Andreas Schneider 2011-09-08 15:47:30 +02:00
родитель c1f8b38b78
Коммит 4a5b72a535

Просмотреть файл

@ -661,7 +661,6 @@ int ssh_pki_import_pubkey_blob(const ssh_string key_blob,
ssh_key *pkey) { ssh_key *pkey) {
ssh_buffer buffer; ssh_buffer buffer;
ssh_string type_s = NULL; ssh_string type_s = NULL;
char *type_c = NULL;
enum ssh_keytypes_e type; enum ssh_keytypes_e type;
int rc; int rc;
@ -688,15 +687,8 @@ int ssh_pki_import_pubkey_blob(const ssh_string key_blob,
goto fail; goto fail;
} }
type_c = ssh_string_to_char(type_s); type = ssh_key_type_from_name(ssh_string_get_char(type_s));
if (type_c == NULL) {
ssh_pki_log("Out of memory!");
goto fail;
}
ssh_string_free(type_s); ssh_string_free(type_s);
type = ssh_key_type_from_name(type_c);
free(type_c);
if (type == SSH_KEYTYPE_UNKNOWN) { if (type == SSH_KEYTYPE_UNKNOWN) {
ssh_pki_log("Unknown key type found!"); ssh_pki_log("Unknown key type found!");
goto fail; goto fail;
@ -710,7 +702,6 @@ int ssh_pki_import_pubkey_blob(const ssh_string key_blob,
fail: fail:
ssh_buffer_free(buffer); ssh_buffer_free(buffer);
ssh_string_free(type_s); ssh_string_free(type_s);
free(type_c);
return SSH_ERROR; return SSH_ERROR;
} }
@ -1030,7 +1021,6 @@ int ssh_pki_import_signature_blob(const ssh_string sig_blob,
enum ssh_keytypes_e type; enum ssh_keytypes_e type;
ssh_string str; ssh_string str;
ssh_buffer buf; ssh_buffer buf;
char *type_c;
int rc; int rc;
if (sig_blob == NULL || psig == NULL) { if (sig_blob == NULL || psig == NULL) {
@ -1056,15 +1046,8 @@ int ssh_pki_import_signature_blob(const ssh_string sig_blob,
return SSH_ERROR; return SSH_ERROR;
} }
type_c = ssh_string_to_char(str); type = ssh_key_type_from_name(ssh_string_get_char(str));
ssh_string_free(str); ssh_string_free(str);
if (type_c == NULL) {
ssh_buffer_free(buf);
return SSH_ERROR;
}
type = ssh_key_type_from_name(type_c);
SAFE_FREE(type_c);
str = buffer_get_ssh_string(buf); str = buffer_get_ssh_string(buf);
ssh_buffer_free(buf); ssh_buffer_free(buf);