Safety check in deliver_split_address()
authorJeremy Harris <jgh146exb@wizmail.org>
Sun, 12 Jun 2016 22:12:55 +0000 (23:12 +0100)
committerJeremy Harris <jgh146exb@wizmail.org>
Sun, 12 Jun 2016 22:12:55 +0000 (23:12 +0100)
src/src/deliver.c

index b389c373121c8922e6daf4e866727ab339d9d9fc..f99aa1819e4b89991fadd3fc498aac9ea24d80e5 100644 (file)
@@ -4722,13 +4722,17 @@ Returns:    OK
 */
 
 int
-deliver_split_address(address_item *addr)
+deliver_split_address(address_item * addr)
 {
-uschar *address = addr->address;
-uschar *domain = Ustrrchr(address, '@');
-uschar *t;
-int len = domain - address;
+uschar * address = addr->address;
+uschar * domain;
+uschar * t;
+int len;
 
+if (!(domain = Ustrrchr(address, '@')))
+  return DEFER;                /* should always have a domain, but just in case... */
+
+len = domain - address;
 addr->domain = string_copylc(domain+1);    /* Domains are always caseless */
 
 /* The implication in the RFCs (though I can't say I've seen it spelled out
@@ -4740,7 +4744,7 @@ removing quoting backslashes and any unquoted doublequotes. */
 t = addr->cc_local_part = store_get(len+1);
 while(len-- > 0)
   {
-  register int c = *address++;
+  int c = *address++;
   if (c == '\"') continue;
   if (c == '\\')
     {