Fix stupid bug.
[doldaconnect.git] / daemon / ui.c
index c6d6e77..9be2c75 100644 (file)
@@ -742,7 +742,7 @@ static void cmd_download(struct socket *sk, struct uidata *data, int argc, wchar
        {
            if(!wcscmp(argv[i], L"hash"))
            {
-               transfer->hash = parsehash(argv[i + 1]);
+               transfersethash(transfer, parsehash(argv[i + 1]));
            } else {
                transferaddarg(transfer, argv[i], argv[i + 1]);
            }
@@ -996,7 +996,7 @@ static void cmd_lssr(struct socket *sk, struct uidata *data, int argc, wchar_t *
        for(sr = srch->results; sr != NULL; sr = sr->next)
        {
            swprintf(buf, 64, L"%f", sr->time);
-           sq(sk, (sr->next != NULL)?1:0, L"200", L"%%ls", sr->filename, sr->fnet->name, L"%%ls", sr->peerid, L"%%i", sr->size, L"%%i", sr->slots, L"%%i", (sr->fn == NULL)?-1:(sr->fn->id), buf, NULL);
+           sq(sk, (sr->next != NULL)?1:0, L"200", L"%%ls", sr->filename, sr->fnet->name, L"%%ls", sr->peerid, L"%%i", sr->size, L"%%i", sr->slots, L"%%i", (sr->fn == NULL)?-1:(sr->fn->id), buf, L"%%ls", (sr->hash == NULL)?L"":unparsehash(sr->hash), NULL);
        }
     }
 }
@@ -1787,6 +1787,12 @@ static int transferchattr(struct transfer *transfer, wchar_t *attrib, void *uuda
            if(haspriv(data, PERM_TRANS) && data->notify.b.tract && ((transfer->owner == 0) || (transfer->owner == data->uid)))
                newnotif(data, 616, NOTIF_ID, transfer->id, NOTIF_STR, transfer->path, NOTIF_END);
        }
+    } else if(!wcscmp(attrib, L"hash")) {
+       for(data = actives; data != NULL; data = data->next)
+       {
+           if(haspriv(data, PERM_TRANS) && data->notify.b.tract && ((transfer->owner == 0) || (transfer->owner == data->uid)))
+               newnotif(data, 618, NOTIF_ID, transfer->id, NOTIF_STR, (transfer->hash == NULL)?L"":unparsehash(transfer->hash), NOTIF_END);
+       }
     }
     return(0);
 }