Преглед на файлове

usrloc: do keepalive mode checks before expire processing

Daniel-Constantin Mierla преди 5 години
родител
ревизия
e67b588434
променени са 1 файла, в които са добавени 13 реда и са изтрити 11 реда
  1. 13 11
      src/modules/usrloc/ul_keepalive.c

+ 13 - 11
src/modules/usrloc/ul_keepalive.c

@@ -126,10 +126,22 @@ int ul_ka_urecord(urecord_t *ur)
 		if((ul_ka_filter&GAU_OPT_SERVER_ID) && (uc->server_id != server_id)) {
 		if((ul_ka_filter&GAU_OPT_SERVER_ID) && (uc->server_id != server_id)) {
 			continue;
 			continue;
 		}
 		}
+		if(ul_ka_mode & ULKA_NAT) {
+			/* keepalive for natted contacts only */
+			if (ul_nat_bflag == 0) {
+				continue;
+			}
+			if ((uc->cflags & ul_nat_bflag) != ul_nat_bflag) {
+				continue;
+			}
+		}
+
 		if(ul_keepalive_timeout>0 && uc->last_keepalive>0) {
 		if(ul_keepalive_timeout>0 && uc->last_keepalive>0) {
 			if(uc->last_keepalive+ul_keepalive_timeout < tnow) {
 			if(uc->last_keepalive+ul_keepalive_timeout < tnow) {
 				/* set contact as expired in 10s */
 				/* set contact as expired in 10s */
-				LM_DBG("set expired contact on keepalive - aor: %.*s c: %.*s\n",
+				LM_DBG("set expired contact on keepalive (%u + %u < %u)"
+						" - aor: %.*s c: %.*s\n", (unsigned int)uc->last_keepalive,
+						(unsigned int)ul_keepalive_timeout, (unsigned int)tnow,
 						ur->aor.len, ur->aor.s, uc->c.len, uc->c.s);
 						ur->aor.len, ur->aor.s, uc->c.len, uc->c.s);
 				if(uc->expires > tnow + 10) {
 				if(uc->expires > tnow + 10) {
 					uc->expires = tnow + 10;
 					uc->expires = tnow + 10;
@@ -137,16 +149,6 @@ int ul_ka_urecord(urecord_t *ur)
 				}
 				}
 			}
 			}
 		}
 		}
-
-		if(ul_ka_mode & ULKA_NAT) {
-			/* keepalive for natted contacts only */
-			if (ul_nat_bflag == 0) {
-				continue;
-			}
-			if ((uc->cflags & ul_nat_bflag) != ul_nat_bflag) {
-				continue;
-			}
-		}
 		if(uc->received.len > 0) {
 		if(uc->received.len > 0) {
 			sdst = uc->received;
 			sdst = uc->received;
 		} else {
 		} else {