X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fuimisc.c;h=63c6fdb050efa3cf8f4dcafe12695bed47a0c985;hb=d4c5deab29eaaab4b40df157b41d712caa8b2209;hp=d989e1ef7aa372e06194e0750e640b5cd9ff0328;hpb=cece2a51a8039efc3d67f37b11b7c8122641cd85;p=doldaconnect.git diff --git a/lib/uimisc.c b/lib/uimisc.c index d989e1e..63c6fdb 100644 --- a/lib/uimisc.c +++ b/lib/uimisc.c @@ -1218,14 +1218,22 @@ void dc_uimisc_handlenotify(struct dc_response *resp) 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) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) != NULL) + { + if(fn->delpeercb != NULL) + fn->delpeercb(peer); delpeer(peer); + } } break; case 632: @@ -1253,6 +1261,8 @@ void dc_uimisc_handlenotify(struct dc_response *resp) break; } } + if(fn->chpeercb != NULL) + fn->chpeercb(peer); } } break;