X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fuimisc.c;h=63c6fdb050efa3cf8f4dcafe12695bed47a0c985;hb=ee5d122f15a71fb4ca8e28a9948df65dda87d819;hp=6c799df39d56f55f3ed8f823cb48680240123f53;hpb=8be1b1e3aca9bb9cb78a7e14e0760ac7e0881592;p=doldaconnect.git diff --git a/lib/uimisc.c b/lib/uimisc.c index 6c799df..63c6fdb 100644 --- a/lib/uimisc.c +++ b/lib/uimisc.c @@ -1034,11 +1034,9 @@ static int getpeerlistcallback(struct dc_response *resp) if(!peer->found) delpeer(peer); } - fn->trackpeers = 1; } else if(resp->code == 201) { while(fn->peers != NULL) delpeer(fn->peers); - fn->trackpeers = 1; } data->callback(fn, resp->code, data->data); free(data); @@ -1217,21 +1215,29 @@ void dc_uimisc_handlenotify(struct dc_response *resp) } break; case 630: - if(((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) && fn->trackpeers) + if((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) == NULL) - addpeer(fn, ires->argv[1].val.str, ires->argv[2].val.str); + { + peer = addpeer(fn, ires->argv[1].val.str, ires->argv[2].val.str); + if(fn->newpeercb != NULL) + fn->newpeercb(peer); + } } break; case 631: - if(((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) && fn->trackpeers) + if((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) != NULL) + { + if(fn->delpeercb != NULL) + fn->delpeercb(peer); delpeer(peer); + } } break; case 632: - if(((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) && fn->trackpeers) + if((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) != NULL) { @@ -1255,6 +1261,8 @@ void dc_uimisc_handlenotify(struct dc_response *resp) break; } } + if(fn->chpeercb != NULL) + fn->chpeercb(peer); } } break;