git: 57f92b10c34c - main - net/netatalk3: fix parsing of macOS created AppleDouble files

From: Joe Marcus Clarke <marcus_at_FreeBSD.org>
Date: Tue, 02 Jan 2024 07:49:50 UTC
The branch main has been updated by marcus:

URL: https://cgit.FreeBSD.org/ports/commit/?id=57f92b10c34cccaa7285d639707294c50daa8aa3

commit 57f92b10c34cccaa7285d639707294c50daa8aa3
Author:     Joe Marcus Clarke <marcus@FreeBSD.org>
AuthorDate: 2024-01-02 07:48:52 +0000
Commit:     Joe Marcus Clarke <marcus@FreeBSD.org>
CommitDate: 2024-01-02 07:48:52 +0000

    net/netatalk3: fix parsing of macOS created AppleDouble files
    
    Obtained from:  https://github.com/Netatalk/netatalk/commit/a0d2bb957ba097849748c0febcac7e9ef041c65a?diff=unified&w=0
---
 net/netatalk3/Makefile                             |  1 +
 .../files/patch-libatalk_adouble_ad__open.c        | 43 ++++++++++++++++++++++
 2 files changed, 44 insertions(+)

diff --git a/net/netatalk3/Makefile b/net/netatalk3/Makefile
index acacf59363ea..a297d24722ee 100644
--- a/net/netatalk3/Makefile
+++ b/net/netatalk3/Makefile
@@ -1,5 +1,6 @@
 PORTNAME=	netatalk
 PORTVERSION=	3.1.18
+PORTREVISION=	1
 PORTEPOCH=	1
 CATEGORIES=	net
 MASTER_SITES=	SF/${PORTNAME}/${PORTNAME}-${PORTVERSION:S/./-/g}
diff --git a/net/netatalk3/files/patch-libatalk_adouble_ad__open.c b/net/netatalk3/files/patch-libatalk_adouble_ad__open.c
new file mode 100644
index 000000000000..05102b8d34df
--- /dev/null
+++ b/net/netatalk3/files/patch-libatalk_adouble_ad__open.c
@@ -0,0 +1,43 @@
+--- libatalk/adouble/ad_open.c.orig	2024-01-02 07:44:09 UTC
++++ libatalk/adouble/ad_open.c
+@@ -668,6 +668,11 @@ reread:
+     int                 retry_read = 0;
+ 
+ reread:
++    if (hst == NULL) {
++        hst = &st;
++        EC_NEG1( fstat(ad_reso_fileno(ad), hst) );
++    }
++
+     LOG(log_debug, logtype_ad, "ad_header_read_osx: %s", path ? fullpathname(path) : "");
+     ad_init_old(&adosx, AD_VERSION_EA, ad->ad_options);
+     buf = &adosx.ad_data[0];
+@@ -707,7 +712,7 @@ reread:
+         return -1;
+     }
+ 
+-    if (parse_entries(&adosx, nentries, header_len) != 0) {
++    if (parse_entries(&adosx, nentries, hst->st_size) != 0) {
+         LOG(log_warning, logtype_ad, "ad_header_read(%s): malformed AppleDouble",
+             path ? fullpathname(path) : "");
+             errno = EIO;
+@@ -725,6 +730,7 @@ reread:
+         }
+         retry_read++;
+         if (ad_convert_osx(path, &adosx) == 1) {
++	    hst = NULL;
+             goto reread;
+         }
+         errno = EIO;
+@@ -738,11 +744,6 @@ reread:
+         LOG(log_error, logtype_ad, "ad_header_read_osx: problem with rfork entry offset.");
+         errno = EIO;
+         return -1;
+-    }
+-
+-    if (hst == NULL) {
+-        hst = &st;
+-        EC_NEG1( fstat(ad_reso_fileno(ad), &st) );
+     }
+ 
+     ad_setentryoff(ad, ADEID_RFORK, ad_getentryoff(&adosx, ADEID_RFORK));