diff --git a/basilisk/basilisk.c b/basilisk/basilisk.c index f2371c801..0b8d7bc95 100755 --- a/basilisk/basilisk.c +++ b/basilisk/basilisk.c @@ -94,6 +94,21 @@ cJSON *basilisk_resultsjson(struct supernet_info *myinfo,char *symbol,char *remo return(retjson); }*/ +struct basilisk_item *basilisk_itemcreate(struct supernet_info *myinfo,uint32_t basilisktag,int32_t minresults,cJSON *vals,int32_t timeoutmillis,void *metricfunc,char *symbol) +{ + struct basilisk_item *ptr; + ptr = calloc(1,sizeof(*ptr)); + ptr->basilisktag = basilisktag; + if ( (ptr->numrequired= minresults) == 0 ) + ptr->numrequired = 1; + if ( (ptr->metricfunc= metricfunc) != 0 ) + ptr->vals = jduplicate(vals); + strcpy(ptr->symbol,symbol); + ptr->expiration = OS_milliseconds() + timeoutmillis; + queue_enqueue("submitQ",&myinfo->basilisks.submitQ,&ptr->DL,0); + return(ptr); +} + #include "basilisk_bitcoin.c" #include "basilisk_nxt.c" #include "basilisk_ether.c" @@ -135,40 +150,43 @@ int32_t basilisk_submit(struct supernet_info *myinfo,cJSON *reqjson,int32_t time return(n); } -struct basilisk_item *basilisk_issueremote(struct supernet_info *myinfo,char *methodstr,char *symbol,cJSON *vals,int32_t timeoutmillis,int32_t fanout,int32_t minresults,uint32_t basilisktag,void *metricfunc) +struct basilisk_item *basilisk_issueremote(struct supernet_info *myinfo,char *methodstr,char *symbol,cJSON *vals,int32_t timeoutmillis,int32_t fanout,int32_t minresults,uint32_t basilisktag,void *_metricfunc,char *retstr) { - struct basilisk_item *ptr; cJSON *hexjson; + struct basilisk_item *ptr; cJSON *hexjson; basilisk_metricfunc metricfunc = _metricfunc; if ( basilisktag == 0 ) basilisktag = rand(); - hexjson = cJSON_CreateObject(); - jaddstr(hexjson,"agent","basilisk"); - jaddnum(hexjson,"basilisktag",basilisktag); - jaddstr(hexjson,"method",methodstr); - jaddstr(hexjson,"activecoin",symbol); - jaddnum(hexjson,"timeout",timeoutmillis); - if ( vals != 0 ) - jadd(hexjson,"vals",jduplicate(vals)); - //printf("issue.(%s) timeout.%d\n",jprint(hexjson,0),timeoutmillis); - ptr = calloc(1,sizeof(*ptr)); - ptr->basilisktag = basilisktag; - if ( (ptr->numrequired= minresults) == 0 ) - ptr->numrequired = 1; - if ( (ptr->metricfunc= metricfunc) != 0 ) - ptr->vals = jduplicate(vals); - strcpy(ptr->symbol,symbol); - ptr->expiration = OS_milliseconds() + timeoutmillis; - queue_enqueue("submitQ",&myinfo->basilisks.submitQ,&ptr->DL,0); - if ( basilisk_submit(myinfo,hexjson,timeoutmillis,fanout,ptr) > 0 ) + ptr = basilisk_itemcreate(myinfo,basilisktag,minresults,vals,timeoutmillis,metricfunc,symbol); + if ( retstr != 0 ) { - /*if ( timeoutmillis > 0 ) + ptr->retstr = retstr; + ptr->results[0] = retstr; + ptr->numresults = ptr->numrequired; + ptr->metrics[0] = (*metricfunc)(myinfo,ptr,retstr); + ptr->finished = (uint32_t)time(NULL); + } + else + { + hexjson = cJSON_CreateObject(); + jaddstr(hexjson,"agent","basilisk"); + jaddnum(hexjson,"basilisktag",basilisktag); + jaddstr(hexjson,"method",methodstr); + jaddstr(hexjson,"activecoin",symbol); + jaddnum(hexjson,"timeout",timeoutmillis); + if ( vals != 0 ) + jadd(hexjson,"vals",jduplicate(vals)); + printf("issue.(%s) timeout.%d\n",jprint(hexjson,0),timeoutmillis); + if ( basilisk_submit(myinfo,hexjson,timeoutmillis,fanout,ptr) > 0 ) { - printf("unexpected blocking\n"); - expiration = OS_milliseconds() + ((timeoutmillis == 0) ? BASILISK_TIMEOUT : timeoutmillis); - while ( OS_milliseconds() < expiration && ptr->finished == 0 && ptr->numresults < ptr->numrequired ) - usleep(timeoutmillis/100 + 1); - }*/ + /*if ( timeoutmillis > 0 ) + { + printf("unexpected blocking\n"); + expiration = OS_milliseconds() + ((timeoutmillis == 0) ? BASILISK_TIMEOUT : timeoutmillis); + while ( OS_milliseconds() < expiration && ptr->finished == 0 && ptr->numresults < ptr->numrequired ) + usleep(timeoutmillis/100 + 1); + }*/ + } + free_json(hexjson); } - free_json(hexjson); return(ptr); } @@ -265,6 +283,7 @@ char *basilisk_block(struct supernet_info *myinfo,struct iguana_info *coin,char { if ( (retstr= Lptr->retstr) == 0 ) retstr = clonestr("{\"result\":\"null return from local basilisk_issuecmd\"}"); + ptr = basilisk_itemcreate(myinfo,Lptr->basilisktag,Lptr->numrequired,Lptr->vals,OS_milliseconds() - Lptr->expiration,Lptr->metricfunc,Lptr->symbol); //printf("block got local.(%s)\n",retstr); } else @@ -520,6 +539,7 @@ void basilisks_loop(void *arg) if ( ptr->finished == 0 ) HASH_ADD(hh,myinfo->basilisks.issued,basilisktag,sizeof(ptr->basilisktag),ptr); else free(ptr); + continue; } if ( (ptr= queue_dequeue(&myinfo->basilisks.resultsQ,0)) != 0 ) { @@ -531,12 +551,14 @@ void basilisks_loop(void *arg) pending->numresults++; if ( (metricfunc= pending->metricfunc) == 0 ) pending->metrics[n] = n + 1; - else pending->metrics[n] = (*metricfunc)(myinfo,pending,ptr->retstr); + else if ( (pending->metrics[n]= (*metricfunc)(myinfo,pending,ptr->retstr)) != 0. ) + pending->childrendone++; printf("%u Add results[%d] <- (%s) metric %f\n",pending->basilisktag,n,ptr->retstr,pending->metrics[n]); pending->results[n] = ptr->retstr; } } free(ptr); + continue; } flag = 0; HASH_ITER(hh,myinfo->basilisks.issued,pending,tmp) @@ -547,7 +569,8 @@ void basilisks_loop(void *arg) for (i=0; inumresults; i++) if ( pending->metrics[i] == 0. && pending->results[i] != 0 ) { - pending->metrics[i] = (*metricfunc)(myinfo,pending,pending->results[i]); + if ( (pending->metrics[i]= (*metricfunc)(myinfo,pending,pending->results[i])) != 0 ) + pending->childrendone++; // printf("iter.%d %p.[%d] poll metrics.%u metric %f\n",iter,pending,i,pending->basilisktag,pending->metrics[i]); flag++; } @@ -590,8 +613,8 @@ void basilisks_loop(void *arg) } } if ( flag == 0 ) - usleep(100000); - else usleep(25000); + usleep(50000); + else usleep(10000); } } diff --git a/basilisk/basilisk.h b/basilisk/basilisk.h index 36f82418a..c6d0a60f1 100755 --- a/basilisk/basilisk.h +++ b/basilisk/basilisk.h @@ -39,7 +39,7 @@ struct basilisk_info struct basilisk_value values[8192]; int32_t numvalues; }; -struct basilisk_item *basilisk_issueremote(struct supernet_info *myinfo,char *methodstr,char *symbol,cJSON *vals,int32_t timeoutmillis,int32_t fanout,int32_t minresults,uint32_t basilisktag,void *metricfunc); +struct basilisk_item *basilisk_issueremote(struct supernet_info *myinfo,char *methodstr,char *symbol,cJSON *vals,int32_t timeoutmillis,int32_t fanout,int32_t minresults,uint32_t basilisktag,void *metricfunc,char *retstr); void basilisks_init(struct supernet_info *myinfo); #endif diff --git a/basilisk/basilisk_bitcoin.c b/basilisk/basilisk_bitcoin.c index cd4ad7bd2..6d4b20327 100755 --- a/basilisk/basilisk_bitcoin.c +++ b/basilisk/basilisk_bitcoin.c @@ -425,14 +425,13 @@ void *basilisk_bitcoinvalue(struct basilisk_item *Lptr,struct supernet_info *myi { if ( v->vout == vout && bits256_cmp(txid,v->txid) == 0 && strcmp(v->coinaddr,coinaddr) == 0 ) { - //printf("bitcoinvalue local\n"); - Lptr->retstr = basilisk_valuestr(coin,coinaddr,v->value,v->height,txid,vout); - return(Lptr); + printf("bitcoinvalue local ht.%d %s %.8f\n",v->height,v->coinaddr,dstr(v->value)); + return(basilisk_issueremote(myinfo,"value",coin->symbol,valsobj,timeoutmillis,juint(valsobj,"fanout"),juint(valsobj,"minresults"),basilisktag,coin->basilisk_valuemetric,basilisk_valuestr(coin,v->coinaddr,v->value,v->height,txid,vout))); } } } printf("bitcoinvalue issue remote\n"); - return(basilisk_issueremote(myinfo,"value",coin->symbol,valsobj,timeoutmillis,juint(valsobj,"fanout"),juint(valsobj,"minresults"),basilisktag,coin->basilisk_valuemetric)); + return(basilisk_issueremote(myinfo,"value",coin->symbol,valsobj,timeoutmillis,juint(valsobj,"fanout"),juint(valsobj,"minresults"),basilisktag,coin->basilisk_valuemetric,0)); } double basilisk_bitcoin_rawtxmetric_dependents(struct supernet_info *myinfo,struct iguana_info *coin,struct basilisk_item *ptr,struct bitcoin_rawtxdependents *dependents) @@ -691,6 +690,6 @@ void *basilisk_bitcoinrawtx(struct basilisk_item *Lptr,struct supernet_info *myi Lptr->retstr = clonestr("{\"error\":\"couldnt create rawtx\"}"); return(Lptr); } - return(basilisk_issueremote(myinfo,"rawtx",coin->symbol,valsobj,timeoutmillis,juint(valsobj,"fanout"),juint(valsobj,"minresults"),basilisktag,coin->basilisk_rawtxmetric)); + return(basilisk_issueremote(myinfo,"rawtx",coin->symbol,valsobj,timeoutmillis,juint(valsobj,"fanout"),juint(valsobj,"minresults"),basilisktag,coin->basilisk_rawtxmetric,0)); } diff --git a/iguana/exchanges777.h b/iguana/exchanges777.h index c415e56fd..567c36828 100755 --- a/iguana/exchanges777.h +++ b/iguana/exchanges777.h @@ -24,7 +24,7 @@ #define INSTANTDEX_DECKSIZE 777 #define INSTANTDEX_HOPS 2 -#define INSTANTDEX_DURATION 60 +#define INSTANTDEX_DURATION 30 #define INSTANTDEX_ORDERSTATE_IDLE 0 #define INSTANTDEX_ORDERSTATE_HAVEOTHERFEE 1 @@ -41,8 +41,8 @@ #define INSTANTDEX_BTCD "RThtXup6Zo7LZAi8kRWgjAyi1s4u6U9Cpf" #define INSTANTDEX_MINPERC 50 -#define INSTANTDEX_OFFERDURATION 300 -#define INSTANTDEX_LOCKTIME 3600 +#define INSTANTDEX_OFFERDURATION 60 +#define INSTANTDEX_LOCKTIME 360 #define EXCHANGES777_MINPOLLGAP 1 #define EXCHANGES777_MAXDEPTH 200 diff --git a/iguana/swaps/iguana_BTCswap.c b/iguana/swaps/iguana_BTCswap.c index 591cfe389..c2207f739 100755 --- a/iguana/swaps/iguana_BTCswap.c +++ b/iguana/swaps/iguana_BTCswap.c @@ -170,7 +170,7 @@ void iguana_addinputs(struct iguana_info *coin,struct bitcoin_spend *spend,cJSON struct bitcoin_statetx *instantdex_signtx(char *str,struct supernet_info *myinfo,struct iguana_info *coin,uint32_t locktime,char *scriptstr,int64_t satoshis,int64_t txfee,int32_t minconf,int32_t myside) { - struct iguana_waddress *waddr; struct iguana_waccount *wacct; struct bitcoin_statetx *tx=0; uint8_t pubkey33[33]; char coinaddr[64],wifstr[64]; char *rawtx,*signedtx,*retstr; bits256 signedtxid; uint32_t basilisktag; int32_t flag,completed; cJSON *valsobj,*vins,*retjson=0,*privkey,*addresses; + struct iguana_waddress *waddr; struct iguana_waccount *wacct; struct bitcoin_statetx *tx=0; uint8_t pubkey33[33]; char coinaddr[64],wifstr[64]; char *rawtx=0,*signedtx,*retstr; bits256 signedtxid; uint32_t basilisktag; int32_t flag,completed; cJSON *valsobj,*vins=0,*retjson=0,*privkey,*addresses; if ( (waddr= iguana_getaccountaddress(myinfo,coin,0,0,coin->changeaddr,"change")) == 0 ) { printf("no change addr error\n"); @@ -209,7 +209,8 @@ struct bitcoin_statetx *instantdex_signtx(char *str,struct supernet_info *myinfo { if ( (rawtx= jstr(retjson,"rawtx")) != 0 && (vins= jobj(retjson,"vins")) != 0 ) flag = 1; - } + else printf("missing rawtx.%p or vins.%p\n",rawtx,vins); + } else printf("error parsing.(%s)\n",retstr); if ( flag != 0 && vins != 0 ) { //printf("vins.(%s)\n",jprint(vins,0));