Moved 1.9 branch to trunk
[gnupg.git] / common / asshelp.c
1 /* asshelp.c - Helper functions for Assuan
2  * Copyright (C) 2002, 2004 Free Software Foundation, Inc.
3  *
4  * This file is part of GnuPG.
5  *
6  * GnuPG is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * GnuPG is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19  * USA.
20  */
21
22 #include <config.h>
23 #include <stdio.h>
24 #include <stdlib.h>
25 #include <string.h>
26 #include <unistd.h>
27 #include <errno.h>
28 #ifdef HAVE_LOCALE_H
29 #include <locale.h>
30 #endif
31
32 #include "util.h"
33
34 #include "asshelp.h"
35
36
37 static gpg_error_t
38 send_one_option (assuan_context_t ctx, gpg_err_source_t errsource,
39                  const char *name, const char *value)
40 {
41   gpg_error_t err;
42   char *optstr;
43
44   if (!value || !*value)
45     err = 0;  /* Avoid sending empty strings.  */
46   else if (asprintf (&optstr, "OPTION %s=%s", name, value ) < 0)
47     err = gpg_error_from_errno (errno);
48   else
49     {
50       assuan_error_t ae;
51
52       ae = assuan_transact (ctx, optstr, NULL, NULL, NULL, NULL, NULL, NULL);
53       err = ae? map_assuan_err_with_source (errsource, ae) : 0;
54       free (optstr);
55     }
56
57   return err;
58 }
59
60
61 /* Send the assuan commands pertaining to the pinenry environment.  The
62    OPT_* arguments are optional and may be used to override the
63    defaults taken from the current locale. */
64 gpg_error_t
65 send_pinentry_environment (assuan_context_t ctx,
66                            gpg_err_source_t errsource,
67                            const char *opt_display,
68                            const char *opt_ttyname,
69                            const char *opt_ttytype,
70                            const char *opt_lc_ctype,
71                            const char *opt_lc_messages)
72 {
73   gpg_error_t err = 0;
74   char *dft_display = NULL;
75   char *dft_ttyname = NULL;
76   char *dft_ttytype = NULL;
77   char *old_lc = NULL; 
78   char *dft_lc = NULL;
79
80   /* Send the DISPLAY variable.  */
81   dft_display = getenv ("DISPLAY");
82   if (opt_display || dft_display)
83     {
84       err = send_one_option (ctx, errsource, "display", 
85                              opt_display ? opt_display : dft_display);
86       if (err)
87         return err;
88     }
89
90   /* Send the name of the TTY.  */
91   if (!opt_ttyname)
92     {
93       dft_ttyname = getenv ("GPG_TTY");
94       if ((!dft_ttyname || !*dft_ttyname) && ttyname (0))
95         dft_ttyname = ttyname (0);
96     }
97   if (opt_ttyname || dft_ttyname)
98     {
99       err = send_one_option (ctx, errsource, "ttyname", 
100                              opt_ttyname ? opt_ttyname : dft_ttyname);
101       if (err)
102         return err;
103     }
104
105   /* Send the type of the TTY.  */
106   dft_ttytype = getenv ("TERM");
107   if (opt_ttytype || (dft_ttyname && dft_ttytype))
108     {
109       err = send_one_option (ctx, errsource, "ttytype", 
110                              opt_ttyname ? opt_ttytype : dft_ttytype);
111       if (err)
112         return err;
113     }
114
115   /* Send the value for LC_CTYPE.  */
116 #if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
117   old_lc = setlocale (LC_CTYPE, NULL);
118   if (old_lc)
119     {
120       old_lc = strdup (old_lc);
121       if (!old_lc)
122         return gpg_error_from_errno (errno);
123     }
124   dft_lc = setlocale (LC_CTYPE, "");
125 #endif
126   if (opt_lc_ctype || (dft_ttyname && dft_lc))
127     {
128       err = send_one_option (ctx, errsource, "lc-ctype", 
129                              opt_lc_ctype ? opt_lc_ctype : dft_lc);
130     }
131 #if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
132   if (old_lc)
133     {
134       setlocale (LC_CTYPE, old_lc);
135       free (old_lc);
136     }
137 #endif
138   if (err)
139     return err;
140
141   /* Send the value for LC_MESSAGES.  */
142 #if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
143   old_lc = setlocale (LC_MESSAGES, NULL);
144   if (old_lc)
145     {
146       old_lc = strdup (old_lc);
147       if (!old_lc)
148         return gpg_error_from_errno (errno);
149     }
150   dft_lc = setlocale (LC_MESSAGES, "");
151 #endif
152   if (opt_lc_messages || (dft_ttyname && dft_lc))
153     {
154       err = send_one_option (ctx, errsource, "lc-messages", 
155                              opt_lc_messages ? opt_lc_messages : dft_lc);
156     }
157 #if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
158   if (old_lc)
159     {
160       setlocale (LC_MESSAGES, old_lc);
161       free (old_lc);
162     }
163 #endif
164   if (err)
165     return err;
166
167   return 0;
168 }
169