Browse Source

Test

etomic
jl777 8 years ago
parent
commit
562342d7fa
  1. 18
      iguana/exchanges/LP_nativeDEX.c
  2. 9
      iguana/exchanges/LP_ordermatch.c

18
iguana/exchanges/LP_nativeDEX.c

@ -199,12 +199,13 @@ char *LP_process_message(void *ctx,char *typestr,char *myipaddr,int32_t pubsock,
{ {
if ( (method= jstr(argjson,"method")) != 0 && strcmp(method,"encrypted") == 0 ) if ( (method= jstr(argjson,"method")) != 0 && strcmp(method,"encrypted") == 0 )
{ {
free_json(argjson);
argjson = 0;
cipherlen >>= 1; cipherlen >>= 1;
decode_hex(decoded,cipherlen,cipherstr); decode_hex(decoded,cipherlen,cipherstr);
crc32 = calc_crc32(0,&decoded[2],cipherlen-2); crc32 = calc_crc32(0,&decoded[2],cipherlen-2);
if ( (jsonstr= LP_decrypt(decoded,&cipherlen)) != 0 ) if ( (jsonstr= LP_decrypt(decoded,&cipherlen)) != 0 )
{ {
free_json(argjson);
argjson = cJSON_Parse(jsonstr); argjson = cJSON_Parse(jsonstr);
recvlen = cipherlen; recvlen = cipherlen;
encrypted = 1; encrypted = 1;
@ -215,14 +216,21 @@ char *LP_process_message(void *ctx,char *typestr,char *myipaddr,int32_t pubsock,
LP_crc32find(&duplicate,i,crc32); LP_crc32find(&duplicate,i,crc32);
} }
printf("%02x %02x %08x duplicate.%d decrypted.(%s)\n",decoded[0],decoded[1],crc32,duplicate,jsonstr); printf("%02x %02x %08x duplicate.%d decrypted.(%s)\n",decoded[0],decoded[1],crc32,duplicate,jsonstr);
} else printf("error null jsonstr\n"); }
else
{
printf("packet not for this node\n");
}
} else printf("error method is %s\n",method); } else printf("error method is %s\n",method);
} //else printf("error cipherlen.%d\n",cipherlen); } //else printf("error cipherlen.%d\n",cipherlen);
len = (int32_t)strlen(jsonstr) + 1; if ( jsonstr != 0 )
if ( (retstr= LP_command_process(ctx,myipaddr,pubsock,argjson,&((uint8_t *)ptr)[len],recvlen - len)) != 0 )
{ {
len = (int32_t)strlen(jsonstr) + 1;
if ( (retstr= LP_command_process(ctx,myipaddr,pubsock,argjson,&((uint8_t *)ptr)[len],recvlen - len)) != 0 )
{
}
free_json(argjson);
} }
free_json(argjson);
} }
} //else printf("DUPLICATE.(%s)\n",(char *)ptr); } //else printf("DUPLICATE.(%s)\n",(char *)ptr);
portable_mutex_unlock(&LP_commandmutex); portable_mutex_unlock(&LP_commandmutex);

9
iguana/exchanges/LP_ordermatch.c

@ -314,7 +314,6 @@ double LP_query(void *ctx,char *myipaddr,int32_t mypubsock,char *method,struct L
reqjson = LP_quotejson(qp); reqjson = LP_quotejson(qp);
if ( bits256_nonz(qp->desthash) != 0 ) if ( bits256_nonz(qp->desthash) != 0 )
flag = 1; flag = 1;
//printf("QUERY.(%s)\n",jprint(reqjson,0));
/*if ( IAMLP != 0 ) /*if ( IAMLP != 0 )
{ {
jaddstr(reqjson,"method",method); jaddstr(reqjson,"method",method);
@ -328,8 +327,10 @@ double LP_query(void *ctx,char *myipaddr,int32_t mypubsock,char *method,struct L
jaddbits256(reqjson,"pubkey",qp->srchash); jaddbits256(reqjson,"pubkey",qp->srchash);
/LP_forward(ctx,myipaddr,mypubsock,qp->srchash,jprint(reqjson,1),1); /LP_forward(ctx,myipaddr,mypubsock,qp->srchash,jprint(reqjson,1),1);
}*/ }*/
jaddbits256(reqjson,"pubkey",qp->srchash);
jaddstr(reqjson,"method",method); jaddstr(reqjson,"method",method);
msg = jprint(reqjson,1); msg = jprint(reqjson,1);
printf("QUERY.(%s)\n",msg);
LP_broadcast_message(LP_mypubsock,qp->srccoin,qp->destcoin,qp->srchash,msg); LP_broadcast_message(LP_mypubsock,qp->srccoin,qp->destcoin,qp->srchash,msg);
for (i=0; i<30; i++) for (i=0; i<30; i++)
{ {
@ -337,7 +338,7 @@ double LP_query(void *ctx,char *myipaddr,int32_t mypubsock,char *method,struct L
{ {
if ( flag == 0 || bits256_nonz(qp->desthash) != 0 ) if ( flag == 0 || bits256_nonz(qp->desthash) != 0 )
{ {
//printf("break out of loop.%d price %.8f\n",i,price); printf("break out of loop.%d price %.8f %s/%s\n",i,price,qp->srccoin,qp->destcoin);
break; break;
} }
} }
@ -508,7 +509,7 @@ int32_t LP_tradecommand(void *ctx,char *myipaddr,int32_t pubsock,cJSON *argjson,
char *method,*msg; cJSON *retjson; double qprice,price,bid,ask; struct LP_utxoinfo *autxo,*butxo; int32_t retval = -1; struct LP_quoteinfo Q; char *method,*msg; cJSON *retjson; double qprice,price,bid,ask; struct LP_utxoinfo *autxo,*butxo; int32_t retval = -1; struct LP_quoteinfo Q;
if ( (method= jstr(argjson,"method")) != 0 && (strcmp(method,"request") == 0 ||strcmp(method,"connect") == 0) ) if ( (method= jstr(argjson,"method")) != 0 && (strcmp(method,"request") == 0 ||strcmp(method,"connect") == 0) )
{ {
//printf("TRADECOMMAND.(%s)\n",jprint(argjson,0)); printf("TRADECOMMAND.(%s)\n",jprint(argjson,0));
retval = 1; retval = 1;
if ( LP_quoteparse(&Q,argjson) == 0 && bits256_cmp(LP_mypub25519,Q.srchash) == 0 ) if ( LP_quoteparse(&Q,argjson) == 0 && bits256_cmp(LP_mypub25519,Q.srchash) == 0 )
{ {
@ -553,9 +554,9 @@ int32_t LP_tradecommand(void *ctx,char *myipaddr,int32_t pubsock,cJSON *argjson,
jaddstr(retjson,"method","forward"); jaddstr(retjson,"method","forward");
/LP_forward(ctx,myipaddr,pubsock,butxo->S.otherpubkey,jprint(retjson,1),1);*/ /LP_forward(ctx,myipaddr,pubsock,butxo->S.otherpubkey,jprint(retjson,1),1);*/
msg = jprint(retjson,1); msg = jprint(retjson,1);
printf("set swappending.%u accept qprice %.8f, min %.8f\n(%s)",butxo->T.swappending,qprice,price,msg);
LP_broadcast_message(pubsock,Q.srccoin,Q.destcoin,butxo->S.otherpubkey,msg); LP_broadcast_message(pubsock,Q.srccoin,Q.destcoin,butxo->S.otherpubkey,msg);
butxo->T.lasttime = (uint32_t)time(NULL); butxo->T.lasttime = (uint32_t)time(NULL);
printf("set swappending.%u accept qprice %.8f, min %.8f\n",butxo->T.swappending,qprice,price);
} else printf("warning swappending.%u swap.%p\n",butxo->T.swappending,butxo->S.swap); } else printf("warning swappending.%u swap.%p\n",butxo->T.swappending,butxo->S.swap);
} }
else if ( strcmp(method,"connect") == 0 ) // bob else if ( strcmp(method,"connect") == 0 ) // bob

Loading…
Cancel
Save