Blame SOURCES/opencryptoki-3.18.0-fix-json-output.patch

1afaf9
commit 1600eebb422ae2a733de3a0bd47464620e39ab0d
1afaf9
Author: Ingo Franzki <ifranzki@linux.ibm.com>
1afaf9
Date:   Tue Jun 7 08:58:16 2022 +0200
1afaf9
1afaf9
    pkcsstats: Fix JSON output in case of errors
1afaf9
    
1afaf9
    Produce correct JSON output, even if an error occurs during obtaining
1afaf9
    of the statistics for a user.
1afaf9
    
1afaf9
    Signed-off-by: Ingo Franzki <ifranzki@linux.ibm.com>
1afaf9
1afaf9
diff --git a/usr/sbin/pkcsstats/pkcsstats.c b/usr/sbin/pkcsstats/pkcsstats.c
1afaf9
index 8eb049dd..65d4833f 100644
1afaf9
--- a/usr/sbin/pkcsstats/pkcsstats.c
1afaf9
+++ b/usr/sbin/pkcsstats/pkcsstats.c
1afaf9
@@ -789,7 +789,7 @@ int main(int argc, char **argv)
1afaf9
     bool reset = false, reset_all = false;
1afaf9
     bool delete = false, delete_all = false;
1afaf9
     bool slot_id_specified = false;
1afaf9
-    bool json = false;
1afaf9
+    bool json = false, json_started = false;
1afaf9
     CK_SLOT_ID slot_id = 0;
1afaf9
     void *dll = NULL;
1afaf9
     CK_FUNCTION_LIST *func_list = NULL;
1afaf9
@@ -949,8 +949,11 @@ int main(int argc, char **argv)
1afaf9
         goto done;
1afaf9
     }
1afaf9
 
1afaf9
-    if (json && print_json_start() != 0)
1afaf9
-        goto done;
1afaf9
+    if (json) {
1afaf9
+        if (print_json_start() != 0)
1afaf9
+            goto done;
1afaf9
+        json_started = true;
1afaf9
+    }
1afaf9
 
1afaf9
     dd.func_list = func_list;
1afaf9
     dd.num_slots = num_slots;
1afaf9
@@ -972,7 +975,7 @@ int main(int argc, char **argv)
1afaf9
     }
1afaf9
 
1afaf9
 done:
1afaf9
-    if (rc == 0 && json)
1afaf9
+    if (json && json_started)
1afaf9
         printf("\n\t]\n}\n");
1afaf9
 
1afaf9
     if (slots != NULL)