git: 5034aa0f705a - 2022Q3 - security/kdbxviewer: Update to 0.1.11

From: Nuno Teixeira <eduardo_at_FreeBSD.org>
Date: Tue, 06 Sep 2022 22:55:00 UTC
The branch 2022Q3 has been updated by eduardo:

URL: https://cgit.FreeBSD.org/ports/commit/?id=5034aa0f705a4fec4a26b9bd5e41802d2ba2626c

commit 5034aa0f705a4fec4a26b9bd5e41802d2ba2626c
Author:     Robert Clausecker <fuz@fuz.su>
AuthorDate: 2022-09-06 22:42:46 +0000
Commit:     Nuno Teixeira <eduardo@FreeBSD.org>
CommitDate: 2022-09-06 22:47:32 +0000

    security/kdbxviewer: Update to 0.1.11
    
     - patch two instances of undefined behaviour
     - patch a potential buffer overflow
    
    Changelog:      https://github.com/pepa65/kdbxviewer/releases/tag/v0.1.11
    PR:             266258
    MFH:            2022Q3
    (cherry picked from commit cc0b41d49276447c1bbd052df4181829d44fe653)
---
 security/kdbxviewer/Makefile                   |  2 +-
 security/kdbxviewer/distinfo                   |  6 ++---
 security/kdbxviewer/files/patch-libcx9r_kdbx.c | 32 ++++++++++++++++++++++++++
 security/kdbxviewer/files/patch-src_main.c     | 29 +++++++++++++++++++++++
 4 files changed, 65 insertions(+), 4 deletions(-)

diff --git a/security/kdbxviewer/Makefile b/security/kdbxviewer/Makefile
index b6c319dfff13..1a81e40fa5df 100644
--- a/security/kdbxviewer/Makefile
+++ b/security/kdbxviewer/Makefile
@@ -1,7 +1,7 @@
 # Created by: Ben Woods <woodsb02@FreeBSD.org>
 
 PORTNAME=	kdbxviewer
-PORTVERSION=	0.1.10
+PORTVERSION=	0.1.11
 DISTVERSIONPREFIX=v
 CATEGORIES=	security
 
diff --git a/security/kdbxviewer/distinfo b/security/kdbxviewer/distinfo
index 98e9295e771f..a2b1cac88dec 100644
--- a/security/kdbxviewer/distinfo
+++ b/security/kdbxviewer/distinfo
@@ -1,3 +1,3 @@
-TIMESTAMP = 1635952892
-SHA256 (pepa65-kdbxviewer-v0.1.10_GH0.tar.gz) = 0ef77f637b34cb603634b7c2f8247fb5f38e12951961c8e2ae6b7dbf7858fc6d
-SIZE (pepa65-kdbxviewer-v0.1.10_GH0.tar.gz) = 140203
+TIMESTAMP = 1662483072
+SHA256 (pepa65-kdbxviewer-v0.1.11_GH0.tar.gz) = de714ca964d637bcb83f591729fc2e9e6a1100d549278f4315129ec4ceb743d0
+SIZE (pepa65-kdbxviewer-v0.1.11_GH0.tar.gz) = 140203
diff --git a/security/kdbxviewer/files/patch-libcx9r_kdbx.c b/security/kdbxviewer/files/patch-libcx9r_kdbx.c
new file mode 100644
index 000000000000..a09c9cc7fbe4
--- /dev/null
+++ b/security/kdbxviewer/files/patch-libcx9r_kdbx.c
@@ -0,0 +1,32 @@
+--- libcx9r/kdbx.c.orig	2022-09-06 17:07:27 UTC
++++ libcx9r/kdbx.c
+@@ -112,22 +112,25 @@ static cx9r_err kdbx_read_magic(cx9r_stream_t *stream)
+ 	uint8_t const kdbx_magic[KDBX_MAGIC_LENGTH] = { 0x03, 0xd9, 0xa2, 0x9a,
+ 			0x67, 0xfb, 0x4b, 0xb5 };
+ DEBUG("Reading magic...\n");
+-	uint8_t magic[KDBX_MAGIC_LENGTH];
++	union {
++		uint8_t magic[KDBX_MAGIC_LENGTH];
++		uint64_t joined;
++	} m;
+ 
+ 	// default return value
+ 	cx9r_err err = CX9R_OK;
+ 	// read magic bytes
+-	CHECK((cx9r_sread(magic, 1, KDBX_MAGIC_LENGTH, stream) == KDBX_MAGIC_LENGTH),
++	CHECK((cx9r_sread(m.magic, 1, KDBX_MAGIC_LENGTH, stream) == KDBX_MAGIC_LENGTH),
+ 			err, CX9R_FILE_READ_ERR, kdbx_magic_bail);
+ DEBUG("Proper magic length\n");
+ 
+ 	// compare magic bytes to expected
+-	CHECK((memcmp(magic, kdbx_magic, KDBX_MAGIC_LENGTH) == 0), err,
++	CHECK((memcmp(m.magic, kdbx_magic, KDBX_MAGIC_LENGTH) == 0), err,
+ 			CX9R_BAD_MAGIC, kdbx_magic_bail);
+ DEBUG("Proper magic content\n");
+ 
+ 	kdbx_magic_bail:
+-DEBUG("%016lX  (%d)\n", *(uint64_t*)&magic, err);
++DEBUG("%016llX  (%d)\n", (unsigned long long)m.joined, err);
+ 	return err;
+ }
+ 
diff --git a/security/kdbxviewer/files/patch-src_main.c b/security/kdbxviewer/files/patch-src_main.c
new file mode 100644
index 000000000000..8ab02829a5de
--- /dev/null
+++ b/security/kdbxviewer/files/patch-src_main.c
@@ -0,0 +1,29 @@
+--- src/main.c.orig	2022-09-06 17:00:52 UTC
++++ src/main.c
+@@ -159,7 +159,7 @@ void print_key_table(cx9r_kt_group *g, int level) {
+ 
+ // Process commandline
+ int main(int argc, char **argv) {
+-	long unsigned int len = PATHLEN, opt, flags = 0;
++	size_t len = PATHLEN, opt, flags = 0;
+ 	char *kdbxfilename = malloc(len), *filename = malloc(len), command = 0,
+ 		*password = NULL, *self = argv[0] + strlen(argv[0]),
+ 		*configfilename = strcat(getenv("HOME"), CONFIGFILENAME);
+@@ -246,14 +246,14 @@ int main(int argc, char **argv) {
+ 		*filename = 0;
+ 		if ((configfile = fopen(configfilename, "r")) != NULL)
+ 			while (getline(&filename, &len, configfile) != -1) {
+-				*(filename+strlen(filename)-1) = 0;
++				filename[strcspn(filename, "\n")] = '\0';
+ 				// Check the latest found file
+-				if ((kdbxfile = fopen(filename, "r")) != NULL) strcpy(kdbxfilename, filename);
++				if ((kdbxfile = fopen(filename, "r")) != NULL) kdbxfilename = strdup(filename);
+ 				*filename = 0;
+ 			}
+ 		if (*kdbxfilename == 0)
+ 			abort(-7, "No database specified on commandline or in configfile\n");
+-		else strcpy(filename, kdbxfilename);
++		else filename = strdup(kdbxfilename);
+ 	}
+ 
+ 	// Set default mode depending on search