Blame SOURCES/0032-autofs-correlate-errors-for-different-protocol-versi.patch

b833e0
From 8a22d4ad45f5fc8e888be693539495093c2b3c35 Mon Sep 17 00:00:00 2001
b833e0
From: =?UTF-8?q?Pavel=20B=C5=99ezina?= <pbrezina@redhat.com>
b833e0
Date: Wed, 4 Nov 2020 14:20:10 +0100
b833e0
Subject: [PATCH 17/18] autofs: correlate errors for different protocol
b833e0
 versions
b833e0
b833e0
Reviewed-by: Alexey Tikhonov <atikhono@redhat.com>
b833e0
---
b833e0
 src/sss_client/autofs/autofs_test_client.c | 12 ++++++++
b833e0
 src/sss_client/autofs/sss_autofs.c         | 35 +++++++++++++++++++---
b833e0
 src/sss_client/autofs/sss_autofs.exports   |  9 +++---
b833e0
 src/sss_client/autofs/sss_autofs_private.h |  5 ++++
b833e0
 4 files changed, 53 insertions(+), 8 deletions(-)
b833e0
b833e0
diff --git a/src/sss_client/autofs/autofs_test_client.c b/src/sss_client/autofs/autofs_test_client.c
b833e0
index c5358233f..4b285151e 100644
b833e0
--- a/src/sss_client/autofs/autofs_test_client.c
b833e0
+++ b/src/sss_client/autofs/autofs_test_client.c
b833e0
@@ -45,10 +45,14 @@ int main(int argc, const char *argv[])
b833e0
     char *value = NULL;
b833e0
     char *pc_key = NULL;
b833e0
     int pc_setent = 0;
b833e0
+    int pc_protocol = 1;
b833e0
+    unsigned int protocol;
b833e0
+    unsigned int requested_protocol = 1;
b833e0
     struct poptOption long_options[] = {
b833e0
         POPT_AUTOHELP
b833e0
         { "by-name",  'n', POPT_ARG_STRING, &pc_key, 0, "Request map by name", NULL },
b833e0
         { "only-setent",  's', POPT_ARG_VAL, &pc_setent, 1, "Run only setent, do not enumerate", NULL },
b833e0
+        { "protocol",  'p', POPT_ARG_INT, &pc_protocol, 0, "Protocol version", NULL },
b833e0
         POPT_TABLEEND
b833e0
     };
b833e0
     poptContext pc = NULL;
b833e0
@@ -69,6 +73,14 @@ int main(int argc, const char *argv[])
b833e0
 
b833e0
     poptFreeContext(pc);
b833e0
 
b833e0
+    requested_protocol = pc_protocol;
b833e0
+    protocol = _sss_auto_protocol_version(requested_protocol);
b833e0
+    if (protocol != requested_protocol) {
b833e0
+        fprintf(stderr, "Unsupported protocol version: %d -> %d\n",
b833e0
+                requested_protocol, protocol);
b833e0
+        exit(EXIT_FAILURE);
b833e0
+    }
b833e0
+
b833e0
     ret = _sss_setautomntent(mapname, &ctx;;
b833e0
     if (ret) {
b833e0
         fprintf(stderr, "setautomntent failed [%d]: %s\n",
b833e0
diff --git a/src/sss_client/autofs/sss_autofs.c b/src/sss_client/autofs/sss_autofs.c
b833e0
index 482ff2c40..ef27cf895 100644
b833e0
--- a/src/sss_client/autofs/sss_autofs.c
b833e0
+++ b/src/sss_client/autofs/sss_autofs.c
b833e0
@@ -20,6 +20,7 @@
b833e0
 
b833e0
 #include <errno.h>
b833e0
 #include <stdlib.h>
b833e0
+#include <stdatomic.h>
b833e0
 
b833e0
 #include "sss_client/autofs/sss_autofs_private.h"
b833e0
 #include "sss_client/sss_cli.h"
b833e0
@@ -33,6 +34,32 @@
b833e0
 /* How many entries shall _sss_getautomntent_r retrieve at once */
b833e0
 #define GETAUTOMNTENT_MAX_ENTRIES   512
b833e0
 
b833e0
+static atomic_uint _protocol = 0;
b833e0
+
b833e0
+unsigned int _sss_auto_protocol_version(unsigned int requested)
b833e0
+{
b833e0
+    switch (requested) {
b833e0
+    case 0:
b833e0
+        /* EHOSTDOWN will be translated to ENOENT */
b833e0
+        _protocol = 0;
b833e0
+        return 0;
b833e0
+    default:
b833e0
+        /* There is no other protocol version at this point. */
b833e0
+        _protocol = 1;
b833e0
+        return 1;
b833e0
+    }
b833e0
+}
b833e0
+
b833e0
+/* Returns correct errno based on autofs version expectations. */
b833e0
+static errno_t errnop_to_errno(int errnop)
b833e0
+{
b833e0
+    if (errnop == EHOSTDOWN && _protocol == 0) {
b833e0
+        return ENOENT;
b833e0
+    }
b833e0
+
b833e0
+    return errnop;
b833e0
+}
b833e0
+
b833e0
 struct automtent {
b833e0
     char *mapname;
b833e0
     size_t cursor;
b833e0
@@ -93,7 +120,7 @@ _sss_setautomntent(const char *mapname, void **context)
b833e0
                                   &repbuf, &replen, &errnop);
b833e0
     if (ret != SSS_STATUS_SUCCESS) {
b833e0
         free(name);
b833e0
-        ret = errnop;
b833e0
+        ret = errnop_to_errno(errnop);
b833e0
         goto out;
b833e0
     }
b833e0
 
b833e0
@@ -310,7 +337,7 @@ _sss_getautomntent_r(char **key, char **value, void *context)
b833e0
                                   &repbuf, &replen, &errnop);
b833e0
     free(data);
b833e0
     if (ret != SSS_STATUS_SUCCESS) {
b833e0
-        ret = errnop;
b833e0
+        ret = errnop_to_errno(errnop);
b833e0
         goto out;
b833e0
     }
b833e0
 
b833e0
@@ -408,7 +435,7 @@ _sss_getautomntbyname_r(const char *key, char **value, void *context)
b833e0
                                   &repbuf, &replen, &errnop);
b833e0
     free(data);
b833e0
     if (ret != SSS_STATUS_SUCCESS) {
b833e0
-        ret = errnop;
b833e0
+        ret = errnop_to_errno(errnop);
b833e0
         goto out;
b833e0
     }
b833e0
 
b833e0
@@ -467,7 +494,7 @@ _sss_endautomntent(void **context)
b833e0
     ret = sss_autofs_make_request(SSS_AUTOFS_ENDAUTOMNTENT,
b833e0
                                   NULL, NULL, NULL, &errnop);
b833e0
     if (ret != SSS_STATUS_SUCCESS) {
b833e0
-        ret = errnop;
b833e0
+        ret = errnop_to_errno(errnop);
b833e0
         goto out;
b833e0
     }
b833e0
 
b833e0
diff --git a/src/sss_client/autofs/sss_autofs.exports b/src/sss_client/autofs/sss_autofs.exports
b833e0
index f9ce8f5b2..ec61f715e 100644
b833e0
--- a/src/sss_client/autofs/sss_autofs.exports
b833e0
+++ b/src/sss_client/autofs/sss_autofs.exports
b833e0
@@ -2,10 +2,11 @@ EXPORTED {
b833e0
 
b833e0
     # public functions
b833e0
     global:
b833e0
-                _sss_setautomntent;
b833e0
-                _sss_getautomntent_r;
b833e0
-                _sss_getautomntbyname_r;
b833e0
-                _sss_endautomntent;
b833e0
+        _sss_auto_protocol_version;
b833e0
+        _sss_setautomntent;
b833e0
+        _sss_getautomntent_r;
b833e0
+        _sss_getautomntbyname_r;
b833e0
+        _sss_endautomntent;
b833e0
 
b833e0
     # everything else is local
b833e0
     local:
b833e0
diff --git a/src/sss_client/autofs/sss_autofs_private.h b/src/sss_client/autofs/sss_autofs_private.h
b833e0
index 6459c1cc7..7fd49db1d 100644
b833e0
--- a/src/sss_client/autofs/sss_autofs_private.h
b833e0
+++ b/src/sss_client/autofs/sss_autofs_private.h
b833e0
@@ -21,6 +21,11 @@
b833e0
 #include <errno.h>
b833e0
 #include "util/util.h"
b833e0
 
b833e0
+/**
b833e0
+ * Choose an autofs protocol version to be used between autofs and sss_autofs.
b833e0
+ */
b833e0
+unsigned int _sss_auto_protocol_version(unsigned int requested);
b833e0
+
b833e0
 /**
b833e0
  * Selects a map for processing.
b833e0
  */
b833e0
-- 
b833e0
2.21.3
b833e0