1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-05 12:31:50 +01:00

* assuan-handler.c (assuan_set_okay_line): New.

(process_request): And use it here.
This commit is contained in:
Werner Koch 2002-01-10 19:46:04 +00:00
parent 6fd5b6d5ed
commit 489207db37
6 changed files with 56 additions and 5 deletions

View File

@ -1,3 +1,14 @@
2002-01-03 Werner Koch <wk@gnupg.org>
* assuan-handler.c (assuan_set_okay_line): New.
(process_request): And use it here.
2002-01-02 Werner Koch <wk@gnupg.org>
* assuan-inquire.c (init_membuf,put_membuf,get_membuf): Apply a
hidden 0 behind the buffer so that the buffer can be used as a
string in certain contexts.
2001-12-14 Marcus Brinkmann <marcus@g10code.de> 2001-12-14 Marcus Brinkmann <marcus@g10code.de>
* assuan-connect.c (assuan_pipe_connect): New argument * assuan-connect.c (assuan_pipe_connect): New argument
@ -90,7 +101,7 @@
* You may find it source-copied in other packages. * * You may find it source-copied in other packages. *
*********************************************************** ***********************************************************
Copyright 2001 Free Software Foundation, Inc. Copyright 2001, 2002 Free Software Foundation, Inc.
This file is free software; as a special exception the author gives This file is free software; as a special exception the author gives
unlimited permission to copy and/or distribute it, with or without unlimited permission to copy and/or distribute it, with or without

View File

@ -39,6 +39,7 @@ struct assuan_context_s {
int is_server; /* set if this is context belongs to a server */ int is_server; /* set if this is context belongs to a server */
int in_inquire; int in_inquire;
char *hello_line; char *hello_line;
char *okay_line; /* see assan_set_okay_line() */
void *user_pointer; /* for assuan_[gs]et_pointer () */ void *user_pointer; /* for assuan_[gs]et_pointer () */

View File

@ -382,7 +382,7 @@ process_request (ASSUAN_CONTEXT ctx)
/* Error handling */ /* Error handling */
if (!rc) if (!rc)
{ {
rc = assuan_write_line (ctx, "OK"); rc = assuan_write_line (ctx, ctx->okay_line? ctx->okay_line : "OK");
} }
else if (rc == -1) else if (rc == -1)
{ /* No error checking because the peer may have already disconnect */ { /* No error checking because the peer may have already disconnect */
@ -405,6 +405,11 @@ process_request (ASSUAN_CONTEXT ctx)
rc = assuan_write_line (ctx, errline); rc = assuan_write_line (ctx, errline);
} }
if (ctx->okay_line)
{
xfree (ctx->okay_line);
ctx->okay_line = NULL;
}
return rc; return rc;
} }
@ -522,6 +527,35 @@ assuan_get_data_fp (ASSUAN_CONTEXT ctx)
} }
/* Set the text used for the next OK reponse. This string is
automatically reset to NULL after the next command. */
AssuanError
assuan_set_okay_line (ASSUAN_CONTEXT ctx, const char *line)
{
if (!ctx)
return ASSUAN_Invalid_Value;
if (!line)
{
xfree (ctx->okay_line);
ctx->okay_line = NULL;
}
else
{
/* FIXME: we need to use gcry_is_secure() to test whether
we should allocate the entire line in secure memory */
char *buf = xtrymalloc (3+strlen(line)+1);
if (!buf)
return ASSUAN_Out_Of_Core;
strcpy (buf, "OK ");
strcpy (buf+3, line);
xfree (ctx->okay_line);
ctx->okay_line = buf;
}
return 0;
}
void void
assuan_write_status (ASSUAN_CONTEXT ctx, const char *keyword, const char *text) assuan_write_status (ASSUAN_CONTEXT ctx, const char *keyword, const char *text)
{ {

View File

@ -1,5 +1,5 @@
/* assuan-inquire.c - handle inquire stuff /* assuan-inquire.c - handle inquire stuff
* Copyright (C) 2001 Free Software Foundation, Inc. * Copyright (C) 2001, 2002 Free Software Foundation, Inc.
* *
* This file is part of GnuPG. * This file is part of GnuPG.
* *
@ -56,7 +56,8 @@ init_membuf (struct membuf *mb, int initiallen, size_t maxlen)
mb->out_of_core = 0; mb->out_of_core = 0;
mb->too_large = 0; mb->too_large = 0;
mb->maxlen = maxlen; mb->maxlen = maxlen;
mb->buf = xtrymalloc (initiallen); /* we need to allocate one byte more for get_membuf */
mb->buf = xtrymalloc (initiallen+1);
if (!mb->buf) if (!mb->buf)
mb->out_of_core = 1; mb->out_of_core = 1;
} }
@ -78,7 +79,8 @@ put_membuf (struct membuf *mb, const void *buf, size_t len)
char *p; char *p;
mb->size += len + 1024; mb->size += len + 1024;
p = xtryrealloc (mb->buf, mb->size); /* we need to allocate one byte more for get_membuf */
p = xtryrealloc (mb->buf, mb->size+1);
if (!p) if (!p)
{ {
mb->out_of_core = 1; mb->out_of_core = 1;
@ -102,6 +104,7 @@ get_membuf (struct membuf *mb, size_t *len)
return NULL; return NULL;
} }
mb->buf[mb->len] = 0; /* there is enough space for the hidden eos */
p = mb->buf; p = mb->buf;
*len = mb->len; *len = mb->len;
mb->buf = NULL; mb->buf = NULL;

View File

@ -58,6 +58,7 @@ assuan_deinit_pipe_server (ASSUAN_CONTEXT ctx)
if (ctx) if (ctx)
{ {
xfree (ctx->hello_line); xfree (ctx->hello_line);
xfree (ctx->okay_line);
xfree (ctx); xfree (ctx);
} }
} }

View File

@ -127,6 +127,7 @@ int assuan_get_active_fds (ASSUAN_CONTEXT ctx, int what,
FILE *assuan_get_data_fp (ASSUAN_CONTEXT ctx); FILE *assuan_get_data_fp (ASSUAN_CONTEXT ctx);
AssuanError assuan_set_okay_line (ASSUAN_CONTEXT ctx, const char *line);
void assuan_write_status (ASSUAN_CONTEXT ctx, void assuan_write_status (ASSUAN_CONTEXT ctx,
const char *keyword, const char *text); const char *keyword, const char *text);