mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-08 12:44:23 +01:00
2004-07-19 Moritz Schulte <moritz@g10code.com>
* command-ssh.c: Only log debugging message if asked to do so. * command-ssh.c (gpg_stream_copy): Remove function. Update Libgpg-stream.
This commit is contained in:
parent
1a9a732165
commit
57f0fbdaf2
@ -1,5 +1,10 @@
|
|||||||
2004-07-19 Moritz Schulte <moritz@g10code.com>
|
2004-07-19 Moritz Schulte <moritz@g10code.com>
|
||||||
|
|
||||||
|
* command-ssh.c: Only log debugging message if asked to do so.
|
||||||
|
|
||||||
|
* command-ssh.c (gpg_stream_copy): Remove function.
|
||||||
|
Update Libgpg-stream.
|
||||||
|
|
||||||
* command-ssh.c: Fix handling of iqmp vs. u.
|
* command-ssh.c: Fix handling of iqmp vs. u.
|
||||||
|
|
||||||
* command-ssh.c (ssh_identity_register): passphrase must not be freed.
|
* command-ssh.c (ssh_identity_register): passphrase must not be freed.
|
||||||
|
@ -157,6 +157,9 @@ buffer_read (buffer_t buffer,
|
|||||||
size_t data_read = 0;
|
size_t data_read = 0;
|
||||||
size_t data_to_copy = 0;
|
size_t data_to_copy = 0;
|
||||||
|
|
||||||
|
if (! (buffer->flags & BUFFER_FLAG_DIRTY))
|
||||||
|
err = buffer_flush_do (buffer);
|
||||||
|
|
||||||
while ((bytes_to_read - data_read) && (! err))
|
while ((bytes_to_read - data_read) && (! err))
|
||||||
{
|
{
|
||||||
if (buffer->buffer_in.data_offset == buffer->buffer_in.data_size)
|
if (buffer->buffer_in.data_offset == buffer->buffer_in.data_size)
|
||||||
|
@ -158,27 +158,6 @@ static uint32_t lifetime_default;
|
|||||||
|
|
||||||
/* Primitive I/O functions. */
|
/* Primitive I/O functions. */
|
||||||
|
|
||||||
static gpg_err_code_t
|
|
||||||
gpg_stream_copy (gpg_stream_t dest, gpg_stream_t src)
|
|
||||||
{
|
|
||||||
gpg_err_code_t err = GPG_ERR_NO_ERROR;
|
|
||||||
unsigned char buffer[STREAM_BLOCK_SIZE];
|
|
||||||
size_t bytes_read = 0;
|
|
||||||
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
err = gpg_stream_read (src, buffer, sizeof (buffer), &bytes_read);
|
|
||||||
if (err || (! bytes_read))
|
|
||||||
break;
|
|
||||||
|
|
||||||
err = gpg_stream_write (dest, buffer, bytes_read, NULL);
|
|
||||||
if (err)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static gpg_err_code_t
|
static gpg_err_code_t
|
||||||
gpg_stream_read_byte (gpg_stream_t stream, byte_t *b)
|
gpg_stream_read_byte (gpg_stream_t stream, byte_t *b)
|
||||||
{
|
{
|
||||||
@ -648,10 +627,6 @@ ssh_extract_key_public_from_blob (unsigned char *blob, size_t blob_size,
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
err = gpg_stream_flush (blob_stream);
|
|
||||||
if (err)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
err = gpg_stream_seek (blob_stream, 0, SEEK_SET);
|
err = gpg_stream_seek (blob_stream, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -687,10 +662,6 @@ ssh_convert_key_to_blob (unsigned char **blob, size_t *blob_size,
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
err = gpg_stream_flush (blob_stream);
|
|
||||||
if (err)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
err = gpg_stream_seek (blob_stream, 0, SEEK_SET);
|
err = gpg_stream_seek (blob_stream, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -959,9 +930,6 @@ ssh_handler_request_identities (ctrl_t ctrl,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = gpg_stream_flush (key_blobs);
|
|
||||||
if (err)
|
|
||||||
goto out;
|
|
||||||
err = gpg_stream_seek (key_blobs, 0, SEEK_SET);
|
err = gpg_stream_seek (key_blobs, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -1063,10 +1031,6 @@ data_sign (CTRL ctrl, unsigned char **sig, size_t *sig_n)
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
err = gpg_stream_flush (stream);
|
|
||||||
if (err)
|
|
||||||
goto out;
|
|
||||||
|
|
||||||
err = gpg_stream_seek (stream, 0, SEEK_SET);
|
err = gpg_stream_seek (stream, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -1126,6 +1090,7 @@ ssh_handler_sign_request (ctrl_t ctrl,
|
|||||||
size_t sig_n = 0;
|
size_t sig_n = 0;
|
||||||
uint32_t flags = 0;
|
uint32_t flags = 0;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] sign request\n");
|
log_debug ("[ssh-agent] sign request\n");
|
||||||
|
|
||||||
/* Receive key. */
|
/* Receive key. */
|
||||||
@ -1295,6 +1260,7 @@ ssh_identity_register (ssh_key_secret_t *key, int ttl)
|
|||||||
char passphrase[100] = { 0 };
|
char passphrase[100] = { 0 };
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] registering identity `%s'\n", key_grip);
|
log_debug ("[ssh-agent] registering identity `%s'\n", key_grip);
|
||||||
|
|
||||||
err = ssh_key_grip (NULL, key, key_grip);
|
err = ssh_key_grip (NULL, key, key_grip);
|
||||||
@ -1340,6 +1306,7 @@ ssh_identity_drop (ssh_key_public_t *key)
|
|||||||
|
|
||||||
/* FIXME */
|
/* FIXME */
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] dropping identity `%s'\n", key_grip);
|
log_debug ("[ssh-agent] dropping identity `%s'\n", key_grip);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
@ -1358,6 +1325,7 @@ ssh_handler_add_identity (ctrl_t ctrl,
|
|||||||
int confirm = 0;
|
int confirm = 0;
|
||||||
int death = 0;
|
int death = 0;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] add identity\n");
|
log_debug ("[ssh-agent] add identity\n");
|
||||||
|
|
||||||
err = ssh_receive_key_secret (request, &key);
|
err = ssh_receive_key_secret (request, &key);
|
||||||
@ -1434,6 +1402,7 @@ ssh_handler_remove_identity (ctrl_t ctrl,
|
|||||||
|
|
||||||
/* Receive key. */
|
/* Receive key. */
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] remove identity\n");
|
log_debug ("[ssh-agent] remove identity\n");
|
||||||
|
|
||||||
err = gpg_stream_read_string (request, &key_blob, NULL);
|
err = gpg_stream_read_string (request, &key_blob, NULL);
|
||||||
@ -1463,6 +1432,7 @@ ssh_identities_remove_all (void)
|
|||||||
{
|
{
|
||||||
gpg_err_code_t err = GPG_ERR_NO_ERROR;
|
gpg_err_code_t err = GPG_ERR_NO_ERROR;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] remove all identities\n");
|
log_debug ("[ssh-agent] remove all identities\n");
|
||||||
|
|
||||||
/* FIXME: shall we remove _all_ cache entries or only those
|
/* FIXME: shall we remove _all_ cache entries or only those
|
||||||
@ -1490,6 +1460,7 @@ ssh_lock (void)
|
|||||||
{
|
{
|
||||||
gpg_err_code_t err = GPG_ERR_NOT_IMPLEMENTED;
|
gpg_err_code_t err = GPG_ERR_NOT_IMPLEMENTED;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] lock\n");
|
log_debug ("[ssh-agent] lock\n");
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
@ -1500,6 +1471,7 @@ ssh_unlock (void)
|
|||||||
{
|
{
|
||||||
gpg_err_code_t err = GPG_ERR_NOT_IMPLEMENTED;
|
gpg_err_code_t err = GPG_ERR_NOT_IMPLEMENTED;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] unlock\n");
|
log_debug ("[ssh-agent] unlock\n");
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
@ -1563,6 +1535,7 @@ ssh_request_process (ctrl_t ctrl, gpg_stream_t request, gpg_stream_t response)
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] request: %u\n", request_type);
|
log_debug ("[ssh-agent] request: %u\n", request_type);
|
||||||
|
|
||||||
for (i = 0; i < DIM (request_specs); i++)
|
for (i = 0; i < DIM (request_specs); i++)
|
||||||
@ -1609,6 +1582,7 @@ start_command_handler_ssh (int sock_client)
|
|||||||
|
|
||||||
/* Setup control structure. */
|
/* Setup control structure. */
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] Starting command handler\n");
|
log_debug ("[ssh-agent] Starting command handler\n");
|
||||||
|
|
||||||
ctrl.connection_fd = sock_client;
|
ctrl.connection_fd = sock_client;
|
||||||
@ -1645,26 +1619,21 @@ start_command_handler_ssh (int sock_client)
|
|||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
log_debug ("[ssh-agent] Received request of length: %u\n", request_size);
|
if (DBG_COMMAND)
|
||||||
|
log_debug ("[ssh-agent] Received request of length: %u\n",
|
||||||
|
request_size);
|
||||||
|
|
||||||
/* Write request data to request stream. */
|
/* Write request data to request stream. */
|
||||||
err = gpg_stream_write (stream_request, request, request_size, NULL);
|
err = gpg_stream_write (stream_request, request, request_size, NULL);
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
err = gpg_stream_flush (stream_request);
|
|
||||||
if (err)
|
|
||||||
break;
|
|
||||||
|
|
||||||
err = gpg_stream_seek (stream_request, 0, SEEK_SET);
|
err = gpg_stream_seek (stream_request, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Process request. */
|
/* Process request. */
|
||||||
err = ssh_request_process (&ctrl, stream_request, stream_response);
|
err = ssh_request_process (&ctrl, stream_request, stream_response);
|
||||||
if (err)
|
|
||||||
break;
|
|
||||||
err = gpg_stream_flush (stream_response);
|
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1672,7 +1641,7 @@ start_command_handler_ssh (int sock_client)
|
|||||||
err = gpg_stream_seek (stream_response, 0, SEEK_SET);
|
err = gpg_stream_seek (stream_response, 0, SEEK_SET);
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
err = gpg_stream_peek (stream_response, NULL, &size);
|
err = gpg_stream_stat (stream_response, &size);
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1687,7 +1656,6 @@ start_command_handler_ssh (int sock_client)
|
|||||||
err = gpg_stream_flush (stream_sock);
|
err = gpg_stream_flush (stream_sock);
|
||||||
if (err)
|
if (err)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
};
|
};
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -1700,6 +1668,7 @@ start_command_handler_ssh (int sock_client)
|
|||||||
gpg_stream_destroy (stream_response);
|
gpg_stream_destroy (stream_response);
|
||||||
free (request);
|
free (request);
|
||||||
|
|
||||||
|
if (DBG_COMMAND)
|
||||||
log_debug ("[ssh-agent] Leaving ssh command handler: %s\n", gpg_strerror (err));
|
log_debug ("[ssh-agent] Leaving ssh command handler: %s\n", gpg_strerror (err));
|
||||||
|
|
||||||
/* fixme: make sure that stream_destroy closes client socket. */
|
/* fixme: make sure that stream_destroy closes client socket. */
|
||||||
|
@ -912,3 +912,37 @@ gpg_stream_stat (gpg_stream_t stream,
|
|||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static gpg_error_t
|
||||||
|
gpg_stream_copy_do (gpg_stream_t dst,
|
||||||
|
gpg_stream_t src)
|
||||||
|
{
|
||||||
|
gpg_error_t err = GPG_ERR_NO_ERROR;
|
||||||
|
unsigned char buffer[STREAM_BLOCK_SIZE];
|
||||||
|
size_t bytes_read = 0;
|
||||||
|
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
err = gpg_stream_read (src, buffer, sizeof (buffer), &bytes_read);
|
||||||
|
if (err || (! bytes_read))
|
||||||
|
break;
|
||||||
|
|
||||||
|
err = gpg_stream_write (dst, buffer, bytes_read, NULL);
|
||||||
|
if (err)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpg_error_t
|
||||||
|
gpg_stream_copy (gpg_stream_t dst,
|
||||||
|
gpg_stream_t src)
|
||||||
|
{
|
||||||
|
gpg_error_t err = GPG_ERR_NO_ERROR;
|
||||||
|
|
||||||
|
err = gpg_stream_copy_do (dst, src);
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
@ -121,6 +121,9 @@ gpg_error_t gpg_stream_seek (gpg_stream_t stream,
|
|||||||
gpg_error_t gpg_stream_stat (gpg_stream_t stream,
|
gpg_error_t gpg_stream_stat (gpg_stream_t stream,
|
||||||
size_t *size);
|
size_t *size);
|
||||||
|
|
||||||
|
gpg_error_t gpg_stream_copy (gpg_stream_t dst,
|
||||||
|
gpg_stream_t src);
|
||||||
|
|
||||||
typedef struct gpg_stream_spec_mem
|
typedef struct gpg_stream_spec_mem
|
||||||
{
|
{
|
||||||
char *memory;
|
char *memory;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user