|
@ -287,9 +287,9 @@ char *_dex_reqsend(struct supernet_info *myinfo,char *handler,uint8_t *key,int32 |
|
|
{ |
|
|
{ |
|
|
timeout = 1000; |
|
|
timeout = 1000; |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
timeout = 5000; |
|
|
//timeout = 5000;
|
|
|
nn_setsockopt(reqsock,NN_TCP,NN_RECONNECT_IVL,&timeout,sizeof(timeout)); |
|
|
//nn_setsockopt(reqsock,NN_TCP,NN_RECONNECT_IVL,&timeout,sizeof(timeout));
|
|
|
timeout = 10000; |
|
|
timeout = 1000; |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
for (i=0; i<sizeof(myinfo->dexseed_ipaddrs)/sizeof(*myinfo->dexseed_ipaddrs); i++) |
|
|
for (i=0; i<sizeof(myinfo->dexseed_ipaddrs)/sizeof(*myinfo->dexseed_ipaddrs); i++) |
|
|
if ( nn_connect(reqsock,nanomsg_tcpname(0,str,myinfo->dexseed_ipaddrs[i],REP_SOCK)) < 0 ) |
|
|
if ( nn_connect(reqsock,nanomsg_tcpname(0,str,myinfo->dexseed_ipaddrs[i],REP_SOCK)) < 0 ) |
|
@ -318,8 +318,8 @@ char *_dex_reqsend(struct supernet_info *myinfo,char *handler,uint8_t *key,int32 |
|
|
nn_setsockopt(subsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(subsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(subsock,NN_SUB,NN_SUB_SUBSCRIBE,"",0); |
|
|
nn_setsockopt(subsock,NN_SUB,NN_SUB_SUBSCRIBE,"",0); |
|
|
printf("CLIENT sockets req.%d sub.%d\n",reqsock,subsock); |
|
|
printf("CLIENT sockets req.%d sub.%d\n",reqsock,subsock); |
|
|
timeout = 5000; |
|
|
//timeout = 5000;
|
|
|
nn_setsockopt(reqsock,NN_TCP,NN_RECONNECT_IVL,&timeout,sizeof(timeout)); |
|
|
//nn_setsockopt(reqsock,NN_TCP,NN_RECONNECT_IVL,&timeout,sizeof(timeout));
|
|
|
timeout = 10000; |
|
|
timeout = 10000; |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(reqsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
} |
|
|
} |
|
@ -408,14 +408,14 @@ char *_dex_reqsend(struct supernet_info *myinfo,char *handler,uint8_t *key,int32 |
|
|
printf("%d: subscribe connect (%s)\n",myinfo->numdexipbits,str); |
|
|
printf("%d: subscribe connect (%s)\n",myinfo->numdexipbits,str); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
//#ifndef __APPLE__
|
|
|
#ifndef __APPLE__ |
|
|
if ( (rand() % 100) < 40 ) |
|
|
if ( (rand() % 100) < 40 ) |
|
|
{ |
|
|
{ |
|
|
nanomsg_tcpname(0,str,ipaddr,REP_SOCK); |
|
|
nanomsg_tcpname(0,str,ipaddr,REP_SOCK); |
|
|
nn_connect(myinfo->reqsock,str); |
|
|
nn_connect(myinfo->reqsock,str); |
|
|
printf("%d: req connect (%s)\n",myinfo->numdexipbits,str); |
|
|
printf("%d: req connect (%s)\n",myinfo->numdexipbits,str); |
|
|
} |
|
|
} |
|
|
//#endif
|
|
|
#endif |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
if ( freeptr != 0 ) |
|
|
if ( freeptr != 0 ) |
|
@ -960,6 +960,7 @@ char *_dex_sendrawtransaction(struct supernet_info *myinfo,char *symbol,char *si |
|
|
char *_dex_importaddress(struct supernet_info *myinfo,char *symbol,char *address) |
|
|
char *_dex_importaddress(struct supernet_info *myinfo,char *symbol,char *address) |
|
|
{ |
|
|
{ |
|
|
struct dex_request dexreq; |
|
|
struct dex_request dexreq; |
|
|
|
|
|
return(clonestr("{\"error\":\"importaddress deprecated\"}")); |
|
|
memset(&dexreq,0,sizeof(dexreq)); |
|
|
memset(&dexreq,0,sizeof(dexreq)); |
|
|
safecopy(dexreq.name,symbol,sizeof(dexreq.name)); |
|
|
safecopy(dexreq.name,symbol,sizeof(dexreq.name)); |
|
|
dexreq.func = 'A'; |
|
|
dexreq.func = 'A'; |
|
@ -1262,12 +1263,13 @@ void dpow_nanomsginit(struct supernet_info *myinfo,char *ipaddr) |
|
|
} |
|
|
} |
|
|
else |
|
|
else |
|
|
{ |
|
|
{ |
|
|
timeout = 500; |
|
|
timeout = 100; |
|
|
nn_setsockopt(repsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(repsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
timeout = 10; |
|
|
nn_setsockopt(pubsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); |
|
|
|
|
|
timeout = 1; |
|
|
nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
timeout = 500; |
|
|
timeout = 1; |
|
|
nn_setsockopt(repsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(repsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
maxsize = 1024 * 1024; |
|
|
maxsize = 1024 * 1024; |
|
|
printf("RCVBUF.%d\n",nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_RCVBUF,&maxsize,sizeof(maxsize))); |
|
|
printf("RCVBUF.%d\n",nn_setsockopt(dexsock,NN_SOL_SOCKET,NN_RCVBUF,&maxsize,sizeof(maxsize))); |
|
@ -1281,7 +1283,7 @@ void dpow_nanomsginit(struct supernet_info *myinfo,char *ipaddr) |
|
|
} |
|
|
} |
|
|
myinfo->dpowipbits[0] = (uint32_t)calc_ipbits(myinfo->ipaddr); |
|
|
myinfo->dpowipbits[0] = (uint32_t)calc_ipbits(myinfo->ipaddr); |
|
|
myinfo->numdpowipbits = 1; |
|
|
myinfo->numdpowipbits = 1; |
|
|
timeout = 10; |
|
|
timeout = 1; |
|
|
nn_setsockopt(dpowsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
nn_setsockopt(dpowsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); |
|
|
maxsize = 1024 * 1024; |
|
|
maxsize = 1024 * 1024; |
|
|
printf("RCVBUF.%d\n",nn_setsockopt(dpowsock,NN_SOL_SOCKET,NN_RCVBUF,&maxsize,sizeof(maxsize))); |
|
|
printf("RCVBUF.%d\n",nn_setsockopt(dpowsock,NN_SOL_SOCKET,NN_RCVBUF,&maxsize,sizeof(maxsize))); |
|
@ -1886,7 +1888,7 @@ void dpow_ipbitsadd(struct supernet_info *myinfo,struct dpow_info *dp,uint32_t * |
|
|
|
|
|
|
|
|
int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
{ |
|
|
{ |
|
|
int32_t i,n=0,num=0,size,broadcastflag,firstz = -1; char *retstr; uint32_t crc32,r,m; struct dpow_nanomsghdr *np=0; struct dpow_info *dp; struct dpow_block *bp; struct dex_nanomsghdr *dexp = 0; void *freeptr; |
|
|
int32_t i,n,num,num2,flags=0,size,iter,lastval=0,broadcastflag,firstz = -1; char *retstr; uint32_t crc32,r,m; struct dpow_nanomsghdr *np=0; struct dpow_info *dp; struct dpow_block *bp; struct dex_nanomsghdr *dexp = 0; void *freeptr; |
|
|
if ( time(NULL) < myinfo->nanoinit+5 || (myinfo->dpowsock < 0 && myinfo->dexsock < 0 && myinfo->repsock < 0) ) |
|
|
if ( time(NULL) < myinfo->nanoinit+5 || (myinfo->dpowsock < 0 && myinfo->dexsock < 0 && myinfo->repsock < 0) ) |
|
|
return(-1); |
|
|
return(-1); |
|
|
if ( myinfo->IAMNOTARY != 0 && myinfo->numnotaries <= 0 ) |
|
|
if ( myinfo->IAMNOTARY != 0 && myinfo->numnotaries <= 0 ) |
|
@ -1895,16 +1897,11 @@ int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
printf("INIT with %d notaries\n",myinfo->numnotaries); |
|
|
printf("INIT with %d notaries\n",myinfo->numnotaries); |
|
|
} |
|
|
} |
|
|
portable_mutex_lock(&myinfo->dpowmutex); |
|
|
portable_mutex_lock(&myinfo->dpowmutex); |
|
|
/*for (i=0; i<100; i++)
|
|
|
num = num2 = n = 0; |
|
|
|
|
|
for (iter=0; iter<100; iter++) |
|
|
{ |
|
|
{ |
|
|
struct nn_pollfd pfd; |
|
|
freeptr = 0; |
|
|
pfd.fd = myinfo->dpowsock; |
|
|
if ( (flags & 1) == 0 && (size= signed_nn_recv(&freeptr,myinfo->ctx,myinfo->notaries,myinfo->numnotaries,myinfo->dpowsock,&np)) > 0 ) |
|
|
pfd.events = NN_POLLIN; |
|
|
|
|
|
if ( nn_poll(&pfd,1,100) > 0 ) |
|
|
|
|
|
break; |
|
|
|
|
|
usleep(1000); |
|
|
|
|
|
}*/ |
|
|
|
|
|
while ( (size= signed_nn_recv(&freeptr,myinfo->ctx,myinfo->notaries,myinfo->numnotaries,myinfo->dpowsock,&np)) >= 0 && num < 1000 ) |
|
|
|
|
|
{ |
|
|
{ |
|
|
num++; |
|
|
num++; |
|
|
if ( size > 0 ) |
|
|
if ( size > 0 ) |
|
@ -1951,14 +1948,14 @@ int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
} //else printf("crc error from.%d %x vs %x or no dp.%p [%s]\n",np->senderind,crc32,np->crc32,dp,np->symbol);
|
|
|
} //else printf("crc error from.%d %x vs %x or no dp.%p [%s]\n",np->senderind,crc32,np->crc32,dp,np->symbol);
|
|
|
} else printf("ignore.%d np->datalen.%d %d (size %d - %ld) [%s]\n",np->senderind,np->datalen,(int32_t)(size-sizeof(*np)),size,sizeof(*np),np->symbol); |
|
|
} else printf("ignore.%d np->datalen.%d %d (size %d - %ld) [%s]\n",np->senderind,np->datalen,(int32_t)(size-sizeof(*np)),size,sizeof(*np),np->symbol); |
|
|
} //else printf("wrong version from.%d %02x %02x size.%d [%s]\n",np->senderind,np->version0,np->version1,size,np->symbol);
|
|
|
} //else printf("wrong version from.%d %02x %02x size.%d [%s]\n",np->senderind,np->version0,np->version1,size,np->symbol);
|
|
|
} //else printf("illegal size.%d\n",size);
|
|
|
} |
|
|
|
|
|
} else flags |= 1; |
|
|
if ( freeptr != 0 ) |
|
|
if ( freeptr != 0 ) |
|
|
nn_freemsg(freeptr), np = 0, freeptr = 0; |
|
|
nn_freemsg(freeptr), np = 0, freeptr = 0; |
|
|
} //else printf("no packets\n");
|
|
|
|
|
|
n = 0; |
|
|
|
|
|
if ( myinfo->dexsock >= 0 ) // from servers
|
|
|
if ( myinfo->dexsock >= 0 ) // from servers
|
|
|
{ |
|
|
{ |
|
|
while ( (size= signed_nn_recv(&freeptr,myinfo->ctx,myinfo->notaries,myinfo->numnotaries,myinfo->dexsock,&dexp)) > 0 && n < 1000 ) |
|
|
freeptr = 0; |
|
|
|
|
|
if ( (flags & 2) == 0 && (size= signed_nn_recv(&freeptr,myinfo->ctx,myinfo->notaries,myinfo->numnotaries,myinfo->dexsock,&dexp)) > 0 ) |
|
|
{ |
|
|
{ |
|
|
//fprintf(stderr,"%d ",size);
|
|
|
//fprintf(stderr,"%d ",size);
|
|
|
n++; |
|
|
n++; |
|
@ -1969,15 +1966,16 @@ int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
dex_packet(myinfo,dexp,size); |
|
|
dex_packet(myinfo,dexp,size); |
|
|
} |
|
|
} |
|
|
//printf("GOT DEX bus PACKET.%d\n",size);
|
|
|
//printf("GOT DEX bus PACKET.%d\n",size);
|
|
|
|
|
|
} else flags |= 2; |
|
|
if ( freeptr != 0 ) |
|
|
if ( freeptr != 0 ) |
|
|
nn_freemsg(freeptr), dexp = 0, freeptr = 0; |
|
|
nn_freemsg(freeptr), dexp = 0, freeptr = 0; |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
if ( myinfo->repsock >= 0 ) // from clients
|
|
|
if ( myinfo->repsock >= 0 ) // from clients
|
|
|
{ |
|
|
{ |
|
|
while ( (size= nn_recv(myinfo->repsock,&dexp,NN_MSG,0)) > 0 ) |
|
|
dexp = 0; |
|
|
|
|
|
if ( (flags & 4) == 0 && (size= nn_recv(myinfo->repsock,&dexp,NN_MSG,0)) > 0 ) |
|
|
{ |
|
|
{ |
|
|
num++; |
|
|
num2++; |
|
|
//printf("REP got %d crc.%08x\n",size,calc_crc32(0,(void *)dexp,size));
|
|
|
//printf("REP got %d crc.%08x\n",size,calc_crc32(0,(void *)dexp,size));
|
|
|
if ( (retstr= dex_response(&broadcastflag,myinfo,dexp)) != 0 ) |
|
|
if ( (retstr= dex_response(&broadcastflag,myinfo,dexp)) != 0 ) |
|
|
{ |
|
|
{ |
|
@ -1986,7 +1984,7 @@ int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
free(retstr); |
|
|
free(retstr); |
|
|
if ( broadcastflag != 0 ) |
|
|
if ( broadcastflag != 0 ) |
|
|
{ |
|
|
{ |
|
|
printf("BROADCAST dexp request.[%d]\n",size); |
|
|
//printf("BROADCAST dexp request.[%d]\n",size);
|
|
|
signed_nn_send(myinfo,myinfo->ctx,myinfo->persistent_priv,myinfo->dexsock,dexp,size); |
|
|
signed_nn_send(myinfo,myinfo->ctx,myinfo->persistent_priv,myinfo->dexsock,dexp,size); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -2009,11 +2007,17 @@ int32_t dpow_nanomsg_update(struct supernet_info *myinfo) |
|
|
//printf("GOT DEX rep PACKET.%d\n",size);
|
|
|
//printf("GOT DEX rep PACKET.%d\n",size);
|
|
|
//if ( freeptr != 0 )
|
|
|
//if ( freeptr != 0 )
|
|
|
// nn_freemsg(freeptr), dexp = 0, freeptr = 0;
|
|
|
// nn_freemsg(freeptr), dexp = 0, freeptr = 0;
|
|
|
|
|
|
//if ( num > 1000 )
|
|
|
|
|
|
// break;
|
|
|
|
|
|
} else flags |= 4; |
|
|
if ( dexp != 0 ) |
|
|
if ( dexp != 0 ) |
|
|
nn_freemsg(dexp), dexp = 0; |
|
|
nn_freemsg(dexp), dexp = 0; |
|
|
if ( num > 1000 ) |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
if ( (num + n + num2) != lastval ) |
|
|
|
|
|
{ |
|
|
|
|
|
//printf("lastval.%d: num.%d n.%d num2.%d rep packets\n",lastval,num,n,num2);
|
|
|
|
|
|
lastval = (num + n + num2); |
|
|
|
|
|
} else break; |
|
|
} |
|
|
} |
|
|
portable_mutex_unlock(&myinfo->dpowmutex); |
|
|
portable_mutex_unlock(&myinfo->dpowmutex); |
|
|
return(num); |
|
|
return(num); |
|
|