jl777 7 years ago
parent
commit
419af7d841
  1. 10
      iguana/exchanges/LP_network.c
  2. 15
      iguana/exchanges/LP_peers.c

10
iguana/exchanges/LP_network.c

@ -460,7 +460,7 @@ void LP_psockloop(void *_ptr)
if ( iter == 0 ) if ( iter == 0 )
{ {
pfds[n].fd = ptr->publicsock; pfds[n].fd = ptr->publicsock;
printf("check sock.%d\n",ptr->publicsock); //printf("check sock.%d\n",ptr->publicsock);
pfds[n].events = POLLIN; pfds[n].events = POLLIN;
} }
else else
@ -787,7 +787,6 @@ int32_t LP_initpublicaddr(void *ctx,uint16_t *mypullportp,char *publicaddr,char
{ {
int32_t nntype,pullsock,timeout; char bindaddr[128],connectaddr[128]; int32_t nntype,pullsock,timeout; char bindaddr[128],connectaddr[128];
*mypullportp = mypullport; *mypullportp = mypullport;
//connectaddr2[0] = 0;
if ( ispaired == 0 ) if ( ispaired == 0 )
{ {
if ( LP_canbind != 0 ) if ( LP_canbind != 0 )
@ -798,7 +797,6 @@ int32_t LP_initpublicaddr(void *ctx,uint16_t *mypullportp,char *publicaddr,char
{ {
nanomsg_transportname(0,publicaddr,myipaddr,mypullport); nanomsg_transportname(0,publicaddr,myipaddr,mypullport);
nanomsg_transportname(1,bindaddr,myipaddr,mypullport); nanomsg_transportname(1,bindaddr,myipaddr,mypullport);
//nanomsg_transportname2(1,bindaddr2,myipaddr,mypullport);
} }
else else
{ {
@ -829,8 +827,6 @@ int32_t LP_initpublicaddr(void *ctx,uint16_t *mypullportp,char *publicaddr,char
} }
else else
{ {
//if ( connectaddr2[0] != 0 && nn_connect(pullsock,connectaddr2) > 0 )
// printf("%s ",connectaddr2);
printf("nntype.%d NN_PAIR.%d connect to %s connectsock.%d\n",nntype,NN_PAIR,connectaddr,pullsock); printf("nntype.%d NN_PAIR.%d connect to %s connectsock.%d\n",nntype,NN_PAIR,connectaddr,pullsock);
} }
} }
@ -841,14 +837,10 @@ int32_t LP_initpublicaddr(void *ctx,uint16_t *mypullportp,char *publicaddr,char
printf("bind to %s error for %s: %s\n",bindaddr,publicaddr,nn_strerror(nn_errno())); printf("bind to %s error for %s: %s\n",bindaddr,publicaddr,nn_strerror(nn_errno()));
exit(-1); exit(-1);
} }
//if ( nn_bind(pullsock,bindaddr2) >= 0 )
// printf("bound to %s\n",bindaddr2);
} }
timeout = 100; timeout = 100;
nn_setsockopt(pullsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout)); nn_setsockopt(pullsock,NN_SOL_SOCKET,NN_RCVTIMEO,&timeout,sizeof(timeout));
nn_setsockopt(pullsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout)); nn_setsockopt(pullsock,NN_SOL_SOCKET,NN_SNDTIMEO,&timeout,sizeof(timeout));
//maxsize = 2 * 1024 * 1024;
//nn_setsockopt(pullsock,NN_SOL_SOCKET,NN_RCVBUF,&maxsize,sizeof(maxsize));
if ( nntype == NN_SUB ) if ( nntype == NN_SUB )
nn_setsockopt(pullsock,NN_SUB,NN_SUB_SUBSCRIBE,"",0); nn_setsockopt(pullsock,NN_SUB,NN_SUB_SUBSCRIBE,"",0);
} }

15
iguana/exchanges/LP_peers.c

@ -59,22 +59,21 @@ char *LP_peers()
void LP_cmdchannel(struct LP_peerinfo *peer) void LP_cmdchannel(struct LP_peerinfo *peer)
{ {
char *hellostr = "{\"method\":\"hello\"}"; char *hellostr = "{\"method\":\"hello\"}";
char connectaddr[128],publicaddr[128],*retstr; int32_t i,pubsock,sentbytes=-2; uint16_t cmdport; char connectaddr[128],publicaddr[128],*retstr; int32_t pairsock=-1,pubsock,sentbytes=-2; uint16_t cmdport;
if ( bits256_nonz(G.LP_mypub25519) == 0 || strcmp(G.USERPASS,"1d8b27b21efabcd96571cd56f91a40fb9aa4cc623d273c63bf9223dc6f8cd81f") == 0 ) if ( bits256_nonz(G.LP_mypub25519) == 0 || strcmp(G.USERPASS,"1d8b27b21efabcd96571cd56f91a40fb9aa4cc623d273c63bf9223dc6f8cd81f") == 0 )
return; return;
if ( (cmdport= LP_psock_get(connectaddr,publicaddr,1,1,peer->ipaddr)) != 0 ) if ( (cmdport= LP_psock_get(connectaddr,publicaddr,1,1,peer->ipaddr)) != 0 )
{ {
if ( (retstr= _LP_psock_create(&peer->pairsock,&pubsock,peer->ipaddr,cmdport,cmdport,1,1,G.LP_mypub25519)) != 0 ) if ( (retstr= _LP_psock_create(&pairsock,&pubsock,peer->ipaddr,cmdport,cmdport,1,1,G.LP_mypub25519)) != 0 )
{ {
for (i=0; i<30; i++) if ( nn_connect(pairsock,connectaddr) < 0 )
printf("error connecting cmdchannel with %s\n",connectaddr);
else
{ {
sentbytes = nn_send(peer->pairsock,hellostr,(int32_t)strlen(hellostr)+1,0); sentbytes = nn_send(peer->pairsock,hellostr,(int32_t)strlen(hellostr)+1,0);
if ( sentbytes > 0 )
break;
printf("sentbytes.%d %s\n",sentbytes,nn_strerror(nn_errno()));
sleep(1);
}
printf("cmdchannel %d created %s sent.%d\n",peer->pairsock,retstr,sentbytes); printf("cmdchannel %d created %s sent.%d\n",peer->pairsock,retstr,sentbytes);
peer->pairsock = pairsock;
}
free(retstr); free(retstr);
} }
} else printf("error getting cmdchannel with %s\n",peer->ipaddr); } else printf("error getting cmdchannel with %s\n",peer->ipaddr);

Loading…
Cancel
Save