summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNIIBE Yutaka <gniibe@fsij.org>2024-06-26 04:13:05 +0200
committerNIIBE Yutaka <gniibe@fsij.org>2024-06-26 04:13:05 +0200
commitd98521b934ec6a5abb0ad18e39a26009a8806c52 (patch)
treef2e298a6f4474718dcd3e28d23b43540a4379c49
parentpo: Update Dutch translation (diff)
downloadgnupg2-d98521b934ec6a5abb0ad18e39a26009a8806c52.tar.xz
gnupg2-d98521b934ec6a5abb0ad18e39a26009a8806c52.zip
scd: Restrict use of DEVINFO --watch command for socket connection.
* scd/app.c (app_send_devinfo): Return GPG_ERR_INV_HANDLE when it's not socket when KEEP_LOOPING != 0. -- GnuPG-bug-id: 7151 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
-rw-r--r--scd/app.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/scd/app.c b/scd/app.c
index fe94cdcbd..926ab7925 100644
--- a/scd/app.c
+++ b/scd/app.c
@@ -484,7 +484,7 @@ app_dump_state (void)
*
* With KEEP_LOOPING=0, it only outputs once.
* With KEEP_LOOPING<0, it keeps looping, until it detects no device.
- * With KEEP_LOOPING>0, it keeps looping forever.
+ * With KEEP_LOOPING>0, it keeps looping forever (until connection close).
*/
gpg_error_t
app_send_devinfo (ctrl_t ctrl, int keep_looping)
@@ -493,6 +493,13 @@ app_send_devinfo (ctrl_t ctrl, int keep_looping)
app_t a;
int no_device;
+ /* The connection from client should be by a socket. This is needed
+ for Windows using the select function. And it's not good to use
+ the primary pipe connection of gpg-agent for watching
+ devinfo. */
+ if (keep_looping && ctrl->thread_startup.fd == GNUPG_INVALID_FD)
+ return gpg_error (GPG_ERR_INV_HANDLE);
+
card_list_w_lock ();
while (1)
{