about summary refs log tree commit diff stats
path: root/src/tools/aesgcm_download.h
diff options
context:
space:
mode:
authorIsaacM88 <izack23@gmail.com>2023-03-09 13:16:42 -0700
committerIsaacM88 <izack23@gmail.com>2023-03-09 15:02:26 -0700
commitd043d53948284ab7d1f3ae92c891703033cc98b1 (patch)
tree498b87e4012f5ae1f1a4b7ea1f5770ef26f889c2 /src/tools/aesgcm_download.h
parent4887d21a119ed67756a1544ec953aa010257bcb1 (diff)
downloadprofani-tty-d043d53948284ab7d1f3ae92c891703033cc98b1.tar.gz
Fix duplicate download IDs.
Fixes https://github.com/profanity-im/profanity/issues/1794

Explanation
The problem is the download's identifier. Downloads are given an ID so they can be referenced later when their progress changes. Currently, the download's ID is the download's URL. When you download the same file twice, you have two downloads with the same ID. Download progress updates are shown on the first of both downloads with the same ID.

Solution
Change the download's ID from its URL to a random number. A random ID is generated when get_random_string() is called from cmd_funcs.c. Several other functions are updated to cope with the new ID format.
Diffstat (limited to 'src/tools/aesgcm_download.h')
-rw-r--r--src/tools/aesgcm_download.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/src/tools/aesgcm_download.h b/src/tools/aesgcm_download.h
index c0096f1d..796b9389 100644
--- a/src/tools/aesgcm_download.h
+++ b/src/tools/aesgcm_download.h
@@ -50,6 +50,7 @@
 
 typedef struct aesgcm_download_t
 {
+    char* id;
     char* url;
     char* filename;
     char* cmd_template;