s3:winbind: simplify wb_seqnums_done a bit
authorVolker Lendecke <vl@samba.org>
Tue, 25 Aug 2009 10:38:47 +0000 (12:38 +0200)
committerVolker Lendecke <vl@samba.org>
Sat, 29 Aug 2009 17:42:26 +0000 (19:42 +0200)
source3/winbindd/wb_seqnums.c

index e6efb9b99ab5b6c7f20735884e497bf81858aff2..604ba00505e571b5807c8880b29103eef5b30f36 100644 (file)
@@ -98,24 +98,33 @@ static void wb_seqnums_done(struct tevent_req *subreq)
 
        for (i=0; i<state->num_domains; i++) {
                if (subreq == state->subreqs[i]) {
-                       state->subreqs[i] = NULL;
-                       state->stati[i] = status;
-                       if (NT_STATUS_IS_OK(status)) {
-                               state->seqnums[i] = seqnum;
-
-                               /*
-                                * This first assignment might be removed
-                                * later
-                                */
-                               state->domains[i]->sequence_number = seqnum;
-
-                               wcache_store_seqnum(state->domains[i]->name,
-                                                   state->seqnums[i],
-                                                   time(NULL));
-                       }
                        break;
                }
        }
+       if (i < state->num_domains) {
+               /* found one */
+
+               state->subreqs[i] = NULL;
+               state->stati[i] = status;
+               if (NT_STATUS_IS_OK(status)) {
+                       state->seqnums[i] = seqnum;
+
+                       /*
+                        * This first assignment might be removed
+                        * later
+                        */
+                       state->domains[i]->sequence_number = seqnum;
+
+                       if (!wcache_store_seqnum(state->domains[i]->name,
+                                                state->seqnums[i],
+                                                time(NULL))) {
+                               DEBUG(1, ("wcache_store_seqnum failed for "
+                                         "domain %s\n",
+                                         state->domains[i]->name));
+                       }
+               }
+       }
+
        TALLOC_FREE(subreq);
 
        state->num_received += 1;