jl777 7 years ago
parent
commit
84bd4d730b
  1. 12
      crypto777/iguana_OS.c
  2. 4
      iguana/exchanges/LP_include.h
  3. 17
      iguana/exchanges/LP_nativeDEX.c
  4. 64
      iguana/exchanges/LP_prices.c
  5. 25
      iguana/exchanges/LP_socket.c
  6. 22
      iguana/exchanges/LP_transaction.c
  7. 118
      iguana/exchanges/LP_utxo.c
  8. 49
      iguana/exchanges/LP_utxos.c

12
crypto777/iguana_OS.c

@ -297,11 +297,11 @@ void *queue_dequeue(queue_t *queue)//,int32_t offsetflag)
void *queue_delete(queue_t *queue,struct queueitem *copy,int32_t copysize,int32_t freeitem) void *queue_delete(queue_t *queue,struct queueitem *copy,int32_t copysize,int32_t freeitem)
{ {
struct allocitem *ptr; struct allocitem *ptr;
struct queueitem *item = 0; struct queueitem *tmp,*item = 0;
lock_queue(queue); lock_queue(queue);
if ( queue->list != 0 ) if ( queue->list != 0 )
{ {
DL_FOREACH(queue->list,item) DL_FOREACH_SAFE(queue->list,item,tmp)
{ {
ptr = (void *)((long)item - sizeof(struct allocitem)); ptr = (void *)((long)item - sizeof(struct allocitem));
if ( item == copy || (ptr->allocsize == copysize && memcmp((void *)((long)item + sizeof(struct queueitem)),(void *)((long)item + sizeof(struct queueitem)),copysize) == 0) ) if ( item == copy || (ptr->allocsize == copysize && memcmp((void *)((long)item + sizeof(struct queueitem)),(void *)((long)item + sizeof(struct queueitem)),copysize) == 0) )
@ -321,11 +321,11 @@ void *queue_delete(queue_t *queue,struct queueitem *copy,int32_t copysize,int32_
void *queue_free(queue_t *queue) void *queue_free(queue_t *queue)
{ {
struct queueitem *item = 0; struct queueitem *tmp,*item = 0;
lock_queue(queue); lock_queue(queue);
if ( queue->list != 0 ) if ( queue->list != 0 )
{ {
DL_FOREACH(queue->list,item) DL_FOREACH_SAFE(queue->list,item,tmp)
{ {
DL_DELETE(queue->list,item); DL_DELETE(queue->list,item);
myfree(item,sizeof(struct queueitem)); myfree(item,sizeof(struct queueitem));
@ -338,11 +338,11 @@ void *queue_free(queue_t *queue)
void *queue_clone(queue_t *clone,queue_t *queue,int32_t size) void *queue_clone(queue_t *clone,queue_t *queue,int32_t size)
{ {
struct queueitem *ptr,*item = 0; struct queueitem *ptr,*tmp,*item = 0;
lock_queue(queue); lock_queue(queue);
if ( queue->list != 0 ) if ( queue->list != 0 )
{ {
DL_FOREACH(queue->list,item) DL_FOREACH_SAFE(queue->list,item,tmp)
{ {
ptr = mycalloc('c',1,sizeof(*ptr)); ptr = mycalloc('c',1,sizeof(*ptr));
memcpy(ptr,item,size); memcpy(ptr,item,size);

4
iguana/exchanges/LP_include.h

@ -192,7 +192,7 @@ struct iguana_info
uint8_t pubkey33[33]; uint8_t pubkey33[33];
}; };
struct _LP_utxoinfo { bits256 txid; uint64_t value; int32_t vout; }; struct _LP_utxoinfo { bits256 txid; uint64_t value; int32_t vout,height; };
struct LP_utxostats { uint32_t sessionid,lasttime,errors,swappending,spentflag,lastspentcheck,bestflag; }; struct LP_utxostats { uint32_t sessionid,lasttime,errors,swappending,spentflag,lastspentcheck,bestflag; };
@ -209,7 +209,6 @@ struct LP_utxoinfo
struct _LP_utxoinfo payment,deposit,fee; struct _LP_utxoinfo payment,deposit,fee;
struct LP_utxostats T; struct LP_utxostats T;
struct LP_utxoswap S; struct LP_utxoswap S;
//struct LP_utxonetwork N;
int32_t iambob,iamlp; int32_t iambob,iamlp;
uint8_t key[sizeof(bits256) + sizeof(int32_t)]; uint8_t key[sizeof(bits256) + sizeof(int32_t)];
uint8_t key2[sizeof(bits256) + sizeof(int32_t)]; uint8_t key2[sizeof(bits256) + sizeof(int32_t)];
@ -303,6 +302,7 @@ struct LP_transaction *LP_transactionfind(struct iguana_info *coin,bits256 txid)
int32_t LP_transactioninit(struct iguana_info *coin,bits256 txid,int32_t iter); int32_t LP_transactioninit(struct iguana_info *coin,bits256 txid,int32_t iter);
int32_t LP_mempoolscan(char *symbol,bits256 searchtxid); int32_t LP_mempoolscan(char *symbol,bits256 searchtxid);
int32_t LP_txheight(struct iguana_info *coin,bits256 txid); int32_t LP_txheight(struct iguana_info *coin,bits256 txid);
void LP_address_utxoadd(struct iguana_info *coin,char *coinaddr,bits256 txid,int32_t vout,uint64_t value,int32_t height);
#endif #endif

17
iguana/exchanges/LP_nativeDEX.c

@ -420,30 +420,27 @@ int32_t LP_mainloop_iter(void *ctx,char *myipaddr,struct LP_peerinfo *mypeer,int
} }
HASH_ITER(hh,LP_coins,coin,ctmp) // firstrefht,firstscanht,lastscanht HASH_ITER(hh,LP_coins,coin,ctmp) // firstrefht,firstscanht,lastscanht
{ {
int32_t height; bits256 zero; //struct LP_address *ap,*atmp; struct LP_address_utxo *up; int32_t height; bits256 zero; struct LP_address *ap,*atmp; struct LP_address_utxo *up,*utmp;
//printf("%s ref.%d scan.%d to %d, longest.%d\n",coin->symbol,coin->firstrefht,coin->firstscanht,coin->lastscanht,coin->longestchain); //printf("%s ref.%d scan.%d to %d, longest.%d\n",coin->symbol,coin->firstrefht,coin->firstscanht,coin->lastscanht,coin->longestchain);
if ( coin->inactive != 0 || coin->electrum != 0 ) if ( coin->inactive != 0 || coin->electrum != 0 )
continue; continue;
/*if ( time(NULL) > coin->lastmonitor+60 ) if ( time(NULL) > coin->lastmonitor+60 )
{ {
portable_mutex_lock(&coin->txmutex); portable_mutex_lock(&coin->txmutex);
HASH_ITER(hh,coin->addresses,ap,atmp) HASH_ITER(hh,coin->addresses,ap,atmp)
{ {
if ( ap->monitor != 0 ) DL_FOREACH_SAFE(ap->utxos,up,utmp)
{ {
DL_FOREACH(ap->utxos,up) if ( up->spentflag == 0 )
{ {
if ( up->spentflag == 0 ) if ( LP_txvalue(0,coin->symbol,up->U.txid,up->U.vout) == 0 )
{ up->spentflag = (uint32_t)time(NULL);
if ( LP_txvalue(0,coin->symbol,up->U.txid,up->U.vout) == 0 )
up->spentflag = (uint32_t)time(NULL);
}
} }
} }
} }
portable_mutex_unlock(&coin->txmutex); portable_mutex_unlock(&coin->txmutex);
coin->lastmonitor = (uint32_t)time(NULL); coin->lastmonitor = (uint32_t)time(NULL);
}*/ }
memset(zero.bytes,0,sizeof(zero)); memset(zero.bytes,0,sizeof(zero));
if ( time(NULL) > coin->lastgetinfo+LP_GETINFO_INCR ) if ( time(NULL) > coin->lastgetinfo+LP_GETINFO_INCR )
{ {

64
iguana/exchanges/LP_prices.c

@ -55,70 +55,6 @@ struct LP_pubkeyinfo
uint8_t rmd160[20]; uint8_t rmd160[20];
} *LP_pubkeyinfos; } *LP_pubkeyinfos;
struct LP_address *_LP_addressfind(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
HASH_FIND(hh,coin->addresses,coinaddr,strlen(coinaddr),ap);
return(ap);
}
struct LP_address *_LP_addressadd(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
ap = calloc(1,sizeof(*ap));
safecopy(ap->coinaddr,coinaddr,sizeof(ap->coinaddr));
HASH_ADD_KEYPTR(hh,coin->addresses,ap->coinaddr,strlen(ap->coinaddr),ap);
return(ap);
}
struct LP_address *_LP_address(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
if ( (ap= _LP_addressfind(coin,coinaddr)) == 0 )
ap = _LP_addressadd(coin,coinaddr);
return(ap);
}
/*void LP_address_utxoadd(struct iguana_info *coin,char *coinaddr,bits256 txid,int32_t vout,uint64_t value)
{
struct LP_address *ap; struct LP_address_utxo *up;
portable_mutex_lock(&coin->txmutex);
if ( (ap= _LP_address(coin,coinaddr)) != 0 )
{
up = calloc(1,sizeof(*up));
up->U.txid = txid;
up->U.vout = vout;
up->U.value = value;
DL_APPEND(ap->utxos,up);
}
portable_mutex_unlock(&coin->txmutex);
}
void LP_address_monitor(struct LP_pubkeyinfo *pubp)
{
struct iguana_info *coin,*tmp; char coinaddr[64]; cJSON *retjson; struct LP_address *ap;
return;
HASH_ITER(hh,LP_coins,coin,tmp)
{
bitcoin_address(coinaddr,coin->taddr,coin->pubtype,pubp->rmd160,sizeof(pubp->rmd160));
portable_mutex_lock(&coin->txmutex);
if ( (ap= _LP_address(coin,coinaddr)) != 0 )
{
ap->monitor = (uint32_t)time(NULL);
}
portable_mutex_unlock(&coin->txmutex);
if ( coin->electrum != 0 )
{
if ( (retjson= electrum_address_subscribe(coin->symbol,coin->electrum,&retjson,coinaddr)) != 0 )
{
printf("%s MONITOR.(%s) -> %s\n",coin->symbol,coinaddr,jprint(retjson,0));
free_json(retjson);
}
}
}
}*/
int32_t LP_pricevalid(double price) int32_t LP_pricevalid(double price)
{ {
if ( price > SMALLVAL && isnan(price) == 0 && price < SATOSHIDEN ) if ( price > SMALLVAL && isnan(price) == 0 && price < SATOSHIDEN )

25
iguana/exchanges/LP_socket.c

@ -304,7 +304,7 @@ struct electrum_info *electrum_server(char *symbol,struct electrum_info *ep)
return(ep); return(ep);
} }
void electrum_process_array(struct iguana_info *coin,cJSON *array) void electrum_process_array(struct iguana_info *coin,char *coinaddr,cJSON *array)
{ {
int32_t i,v,n; char str[65]; uint64_t value; bits256 txid; cJSON *item; struct LP_transaction *tx; int32_t i,v,n; char str[65]; uint64_t value; bits256 txid; cJSON *item; struct LP_transaction *tx;
if ( array != 0 && coin != 0 && (n= cJSON_GetArraySize(array)) > 0 ) if ( array != 0 && coin != 0 && (n= cJSON_GetArraySize(array)) > 0 )
@ -333,6 +333,7 @@ void electrum_process_array(struct iguana_info *coin,cJSON *array)
{ {
printf(">>>>>>>>>> set %s/v%d <- %.8f vs %.8f\n",bits256_str(str,txid),v,dstr(value),dstr(tx->outpoints[v].value)); printf(">>>>>>>>>> set %s/v%d <- %.8f vs %.8f\n",bits256_str(str,txid),v,dstr(value),dstr(tx->outpoints[v].value));
tx->outpoints[v].value = value; tx->outpoints[v].value = value;
LP_address_utxoadd(coin,coinaddr,txid,v,value,tx->height);
} }
} }
printf("v.%d numvouts.%d %.8f (%s)\n",jint(item,"tx_pos"),tx->numvouts,dstr(tx->outpoints[jint(item,"tx_pos")].value),jprint(item,0)); printf("v.%d numvouts.%d %.8f (%s)\n",jint(item,"tx_pos"),tx->numvouts,dstr(tx->outpoints[jint(item,"tx_pos")].value),jprint(item,0));
@ -443,7 +444,7 @@ cJSON *electrum_address_gethistory(char *symbol,struct electrum_info *ep,cJSON *
cJSON *retjson; struct iguana_info *coin = LP_coinfind(symbol); cJSON *retjson; struct iguana_info *coin = LP_coinfind(symbol);
retjson = electrum_strarg(symbol,ep,retjsonp,"blockchain.address.get_history",addr,ELECTRUM_TIMEOUT); retjson = electrum_strarg(symbol,ep,retjsonp,"blockchain.address.get_history",addr,ELECTRUM_TIMEOUT);
printf("history.(%s)\n",jprint(retjson,0)); printf("history.(%s)\n",jprint(retjson,0));
electrum_process_array(coin,retjson); electrum_process_array(coin,addr,retjson);
return(retjson); return(retjson);
} }
@ -452,7 +453,7 @@ cJSON *electrum_address_getmempool(char *symbol,struct electrum_info *ep,cJSON *
cJSON *retjson; struct iguana_info *coin = LP_coinfind(symbol); cJSON *retjson; struct iguana_info *coin = LP_coinfind(symbol);
retjson = electrum_strarg(symbol,ep,retjsonp,"blockchain.address.get_mempool",addr,ELECTRUM_TIMEOUT); retjson = electrum_strarg(symbol,ep,retjsonp,"blockchain.address.get_mempool",addr,ELECTRUM_TIMEOUT);
printf("MEMPOOL.(%s)\n",jprint(retjson,0)); printf("MEMPOOL.(%s)\n",jprint(retjson,0));
electrum_process_array(coin,retjson); electrum_process_array(coin,addr,retjson);
return(retjson); return(retjson);
} }
@ -465,7 +466,7 @@ cJSON *electrum_address_listunspent(char *symbol,struct electrum_info *ep,cJSON
if ( (retjson= electrum_strarg(symbol,ep,retjsonp,"blockchain.address.listunspent",addr,ELECTRUM_TIMEOUT)) != 0 ) if ( (retjson= electrum_strarg(symbol,ep,retjsonp,"blockchain.address.listunspent",addr,ELECTRUM_TIMEOUT)) != 0 )
{ {
printf("LISTUNSPENT.(%s)\n",jprint(retjson,0)); printf("LISTUNSPENT.(%s)\n",jprint(retjson,0));
electrum_process_array(coin,retjson); electrum_process_array(coin,addr,retjson);
strcpy(coin->lastunspent,addr); strcpy(coin->lastunspent,addr);
coin->unspenttime = (uint32_t)time(NULL); coin->unspenttime = (uint32_t)time(NULL);
} }
@ -608,7 +609,7 @@ struct electrum_info *LP_electrum_info(int32_t *alreadyp,char *symbol,char *ipad
int32_t LP_recvfunc(struct electrum_info *ep,char *str,int32_t len) int32_t LP_recvfunc(struct electrum_info *ep,char *str,int32_t len)
{ {
cJSON *strjson,*errjson,*resultjson,*paramsjson; char *method; int32_t i,n,height; uint32_t idnum=0; struct stritem *stritem; struct queueitem *item = 0; cJSON *strjson,*errjson,*resultjson,*paramsjson; char *method; int32_t i,n,height; uint32_t idnum=0; struct stritem *stritem; struct queueitem *tmp,*item = 0;
ep->lasttime = (uint32_t)time(NULL); ep->lasttime = (uint32_t)time(NULL);
if ( (strjson= cJSON_Parse(str)) != 0 ) if ( (strjson= cJSON_Parse(str)) != 0 )
{ {
@ -625,11 +626,11 @@ int32_t LP_recvfunc(struct electrum_info *ep,char *str,int32_t len)
resultjson = jitem(paramsjson,i); resultjson = jitem(paramsjson,i);
} }
} }
else if ( strcmp(method,"blockchain.address.subscribe") == 0 ) /*else if ( strcmp(method,"blockchain.address.subscribe") == 0 ) never is called
{ {
printf("recv addr subscribe.(%s)\n",jprint(resultjson,0)); printf("recv addr subscribe.(%s)\n",jprint(resultjson,0));
electrum_process_array(ep->coin,resultjson); electrum_process_array(ep->coin,resultjson);
} }*/
} }
if ( resultjson != 0 ) if ( resultjson != 0 )
{ {
@ -644,11 +645,9 @@ int32_t LP_recvfunc(struct electrum_info *ep,char *str,int32_t len)
portable_mutex_lock(&ep->pendingQ.mutex); portable_mutex_lock(&ep->pendingQ.mutex);
if ( ep->pendingQ.list != 0 ) if ( ep->pendingQ.list != 0 )
{ {
DL_FOREACH(ep->pendingQ.list,item) DL_FOREACH_SAFE(ep->pendingQ.list,item,tmp)
{ {
stritem = (struct stritem *)item; stritem = (struct stritem *)item;
if ( *stritem->retptrp != 0 )
continue;
if ( item->type == idnum ) if ( item->type == idnum )
{ {
//printf("matched idnum.%d result.%p\n",idnum,resultjson); //printf("matched idnum.%d result.%p\n",idnum,resultjson);
@ -660,13 +659,13 @@ int32_t LP_recvfunc(struct electrum_info *ep,char *str,int32_t len)
} }
if ( stritem->expiration < ep->lasttime ) if ( stritem->expiration < ep->lasttime )
{ {
//DL_DELETE(ep->pendingQ.list,item); DL_DELETE(ep->pendingQ.list,item);
printf("expired (%s)\n",stritem->str); printf("expired (%s)\n",stritem->str);
errjson = cJSON_CreateObject(); errjson = cJSON_CreateObject();
jaddnum(errjson,"id",item->type); jaddnum(errjson,"id",item->type);
jaddstr(errjson,"error","timeout"); jaddstr(errjson,"error","timeout");
*((cJSON **)stritem->retptrp) = errjson; *((cJSON **)stritem->retptrp) = errjson;
//free(item); free(item);
} }
} }
} }
@ -708,7 +707,7 @@ void LP_dedicatedloop(void *arg)
if ( ep->pendingQ.list != 0 ) if ( ep->pendingQ.list != 0 )
{ {
printf("list %p\n",ep->pendingQ.list); printf("list %p\n",ep->pendingQ.list);
DL_FOREACH(ep->pendingQ.list,item) DL_FOREACH_SAFE(ep->pendingQ.list,item,tmp)
{ {
printf("item.%p\n",item); printf("item.%p\n",item);
if ( item->type == 0xffffffff ) if ( item->type == 0xffffffff )

22
iguana/exchanges/LP_transaction.c

@ -795,33 +795,13 @@ char *basilisk_swap_Aspend(char *name,char *symbol,uint64_t Atxfee,uint8_t wifta
return(signedtx); return(signedtx);
} }
int32_t LP_swap_txdestaddr(char *destaddr,bits256 txid,int32_t vout,cJSON *txobj)
{
int32_t n,m,retval = -1; cJSON *vouts,*item,*addresses,*skey; char *addr;
if ( (vouts= jarray(&n,txobj,"vout")) != 0 && vout < n )
{
item = jitem(vouts,vout);
if ( (skey= jobj(item,"scriptPubKey")) != 0 && (addresses= jarray(&m,skey,"addresses")) != 0 )
{
item = jitem(addresses,0);
if ( (addr= jstr(item,0)) != 0 )
{
safecopy(destaddr,addr,64);
retval = 0;
}
//printf("item.(%s) -> dest.(%s)\n",jprint(item,0),destaddr);
}
}
return(retval);
}
int32_t LP_swap_getcoinaddr(char *symbol,char *coinaddr,bits256 txid,int32_t vout) int32_t LP_swap_getcoinaddr(char *symbol,char *coinaddr,bits256 txid,int32_t vout)
{ {
cJSON *retjson; cJSON *retjson;
coinaddr[0] = 0; coinaddr[0] = 0;
if ( (retjson= LP_gettx(symbol,txid)) != 0 ) if ( (retjson= LP_gettx(symbol,txid)) != 0 )
{ {
LP_swap_txdestaddr(coinaddr,txid,vout,retjson); LP_txdestaddr(coinaddr,txid,vout,retjson);
free_json(retjson); free_json(retjson);
} }
return(coinaddr[0] != 0); return(coinaddr[0] != 0);

118
iguana/exchanges/LP_utxo.c

@ -18,6 +18,16 @@
// marketmaker // marketmaker
// //
// listunspent: valid for local node, mostly valid for electrum
// full node + electrum for external listunspent, gettxout to validate
// pruned node + electrum for external listunspent, gettxout to validate
// full node, network for external listunspent, gettxout to validate
// pruned node, network for external listunspent, gettxout to validate
// electrum only, network for gettxout
// locally track spends, height
uint64_t LP_value_extract(cJSON *obj) uint64_t LP_value_extract(cJSON *obj)
{ {
double val = 0.; uint64_t value; double val = 0.; uint64_t value;
@ -29,6 +39,85 @@ uint64_t LP_value_extract(cJSON *obj)
return(value); return(value);
} }
struct LP_address *_LP_addressfind(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
HASH_FIND(hh,coin->addresses,coinaddr,strlen(coinaddr),ap);
return(ap);
}
struct LP_address *_LP_addressadd(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
ap = calloc(1,sizeof(*ap));
safecopy(ap->coinaddr,coinaddr,sizeof(ap->coinaddr));
HASH_ADD_KEYPTR(hh,coin->addresses,ap->coinaddr,strlen(ap->coinaddr),ap);
return(ap);
}
struct LP_address *_LP_address(struct iguana_info *coin,char *coinaddr)
{
struct LP_address *ap;
if ( (ap= _LP_addressfind(coin,coinaddr)) == 0 )
ap = _LP_addressadd(coin,coinaddr);
return(ap);
}
void LP_address_utxoadd(struct iguana_info *coin,char *coinaddr,bits256 txid,int32_t vout,uint64_t value,int32_t height)
{
struct LP_address *ap; struct LP_address_utxo *up,*tmp; int32_t flag;
portable_mutex_lock(&coin->txmutex);
if ( (ap= _LP_address(coin,coinaddr)) != 0 )
{
flag = 0;
DL_FOREACH_SAFE(ap->utxos,up,tmp)
{
if ( vout == up->U.vout && bits256_cmp(up->U.txid,txid) == 0 )
{
if ( up->U.height <= 0 && height > 0 )
up->U.height = height;
flag = 1;
break;
}
}
if ( flag == 0 )
{
up = calloc(1,sizeof(*up));
up->U.txid = txid;
up->U.vout = vout;
up->U.height = height;
up->U.value = value;
DL_APPEND(ap->utxos,up);
}
}
portable_mutex_unlock(&coin->txmutex);
}
/*void LP_address_monitor(struct LP_pubkeyinfo *pubp)
{
struct iguana_info *coin,*tmp; char coinaddr[64]; cJSON *retjson; struct LP_address *ap;
return;
HASH_ITER(hh,LP_coins,coin,tmp)
{
bitcoin_address(coinaddr,coin->taddr,coin->pubtype,pubp->rmd160,sizeof(pubp->rmd160));
portable_mutex_lock(&coin->txmutex);
if ( (ap= _LP_address(coin,coinaddr)) != 0 )
{
ap->monitor = (uint32_t)time(NULL);
}
portable_mutex_unlock(&coin->txmutex);
if ( coin->electrum != 0 )
{
if ( (retjson= electrum_address_subscribe(coin->symbol,coin->electrum,&retjson,coinaddr)) != 0 )
{
printf("%s MONITOR.(%s) -> %s\n",coin->symbol,coinaddr,jprint(retjson,0));
free_json(retjson);
}
}
}
}
*/
void LP_utxosetkey(uint8_t *key,bits256 txid,int32_t vout) void LP_utxosetkey(uint8_t *key,bits256 txid,int32_t vout)
{ {
memcpy(key,txid.bytes,sizeof(txid)); memcpy(key,txid.bytes,sizeof(txid));
@ -270,9 +359,33 @@ int64_t basilisk_txvalue(char *symbol,bits256 txid,int32_t vout)
return(value + interest); return(value + interest);
} }
int32_t LP_destaddr(char *destaddr,cJSON *item)
{
int32_t m,retval = -1; cJSON *addresses,*skey; char *addr;
if ( (skey= jobj(item,"scriptPubKey")) != 0 && (addresses= jarray(&m,skey,"addresses")) != 0 )
{
item = jitem(addresses,0);
if ( (addr= jstr(item,0)) != 0 )
{
safecopy(destaddr,addr,64);
retval = 0;
}
//printf("item.(%s) -> dest.(%s)\n",jprint(item,0),destaddr);
}
return(retval);
}
int32_t LP_txdestaddr(char *destaddr,bits256 txid,int32_t vout,cJSON *txobj)
{
int32_t n,retval = -1; cJSON *vouts;
if ( (vouts= jarray(&n,txobj,"vout")) != 0 && vout < n )
retval = LP_destaddr(destaddr,jitem(vouts,vout));
return(retval);
}
uint64_t LP_txvalue(char *coinaddr,char *symbol,bits256 txid,int32_t vout) uint64_t LP_txvalue(char *coinaddr,char *symbol,bits256 txid,int32_t vout)
{ {
struct LP_transaction *tx; cJSON *txobj; uint64_t value; struct iguana_info *coin; char str[65],str2[65]; struct LP_transaction *tx; cJSON *txobj; uint64_t value; struct iguana_info *coin; char str[65],str2[65],_coinaddr[65];
if ( bits256_nonz(txid) == 0 ) if ( bits256_nonz(txid) == 0 )
return(0); return(0);
if ( (coin= LP_coinfind(symbol)) == 0 || coin->inactive != 0 ) if ( (coin= LP_coinfind(symbol)) == 0 || coin->inactive != 0 )
@ -312,6 +425,9 @@ uint64_t LP_txvalue(char *coinaddr,char *symbol,bits256 txid,int32_t vout)
if ( (txobj= LP_gettxout(coin->symbol,txid,vout)) != 0 ) if ( (txobj= LP_gettxout(coin->symbol,txid,vout)) != 0 )
{ {
value = SATOSHIDEN * jdouble(txobj,"value"); value = SATOSHIDEN * jdouble(txobj,"value");
if ( coinaddr == 0 )
coinaddr = _coinaddr;
LP_destaddr(coinaddr,txobj);
free_json(txobj); free_json(txobj);
printf("pruned node? LP_txvalue couldnt find %s tx %s, but gettxout %.8f\n",coin->symbol,bits256_str(str,txid),dstr(value)); printf("pruned node? LP_txvalue couldnt find %s tx %s, but gettxout %.8f\n",coin->symbol,bits256_str(str,txid),dstr(value));
return(value); return(value);

49
iguana/exchanges/LP_utxos.c

@ -537,11 +537,6 @@ struct LP_utxoinfo *LP_utxoadd(int32_t iambob,int32_t mypubsock,char *symbol,bit
if ( _LP_utxo2find(iambob,txid2,vout2) == 0 ) if ( _LP_utxo2find(iambob,txid2,vout2) == 0 )
HASH_ADD_KEYPTR(hh2,LP_utxoinfos2[iambob],utxo->key2,sizeof(utxo->key2),utxo); HASH_ADD_KEYPTR(hh2,LP_utxoinfos2[iambob],utxo->key2,sizeof(utxo->key2),utxo);
portable_mutex_unlock(&LP_utxomutex); portable_mutex_unlock(&LP_utxomutex);
/*if ( 0 && coin->electrum == 0 )
{
LP_address_utxoadd(coin,coinaddr,txid,vout,value);
LP_address_utxoadd(coin,coinaddr,txid2,vout2,value2);
}*/
if ( iambob != 0 ) if ( iambob != 0 )
{ {
if ( LP_mypeer != 0 ) if ( LP_mypeer != 0 )
@ -715,7 +710,7 @@ int32_t LP_nearestvalue(int32_t iambob,uint64_t *values,int32_t n,uint64_t targe
uint64_t LP_privkey_init(int32_t mypubsock,struct iguana_info *coin,bits256 myprivkey,bits256 mypub) uint64_t LP_privkey_init(int32_t mypubsock,struct iguana_info *coin,bits256 myprivkey,bits256 mypub)
{ {
char *script,destaddr[64]; struct LP_utxoinfo *utxo; cJSON *array,*item; bits256 txid,deposittxid; int32_t used,i,n,cmpflag,iambob,vout,depositvout; uint64_t *values=0,satoshis,txfee,depositval,value,total = 0; int64_t targetval; char *script,destaddr[64]; struct LP_utxoinfo *utxo; cJSON *array,*item; bits256 txid,deposittxid; int32_t used,i,height,n,cmpflag,iambob,vout,depositvout; uint64_t *values=0,satoshis,txfee,depositval,value,total = 0; int64_t targetval;
if ( coin == 0 ) if ( coin == 0 )
{ {
printf("coin not active\n"); printf("coin not active\n");
@ -732,41 +727,33 @@ uint64_t LP_privkey_init(int32_t mypubsock,struct iguana_info *coin,bits256 mypr
if ( iambob == 0 ) if ( iambob == 0 )
values = calloc(n,sizeof(*values)); values = calloc(n,sizeof(*values));
else memset(values,0,n * sizeof(*values)); else memset(values,0,n * sizeof(*values));
//if ( iambob == 0 && IAMLP != 0 )
// continue;
used = 0; used = 0;
for (i=0; i<n; i++) for (i=0; i<n; i++)
{ {
item = jitem(array,i); item = jitem(array,i);
if ( coin->electrum == 0 ) if ( coin->electrum == 0 )
{ {
//satoshis = SATOSHIDEN * jdouble(item,"amount"); txid = jbits256(item,"txid");
//if ( satoshis == 0 ) vout = juint(item,"vout");
// satoshis = SATOSHIDEN * jdouble(item,"value"); value = LP_value_extract(item);
satoshis = LP_txvalue(destaddr,coin->symbol,jbits256(item,"txid"),juint(item,"vout")); height = coin->height - jint(item,"confirmations");
if ( LP_inventory_prevent(iambob,coin->symbol,jbits256(item,"txid"),juint(item,"vout")) == 0 && jint(item,"confirmations") > 0 )
{
//printf("%s\n",jprint(item,0));
values[i] = satoshis;
} else used++;
} }
else else
{ {
//{"value":1000000,"tx_hash":"4e4f818c53486c0576693b4cd379849e5ff95538b38e4100f48884073a4e7636","tx_pos":0,"height":484877} txid = jbits256(item,"tx_hash");
satoshis = j64bits(item,"value"); vout = juint(item,"tx_pos");
satoshis = LP_txvalue(destaddr,coin->symbol,jbits256(item,"tx_hash"),juint(item,"tx_pos")); value = j64bits(item,"value");
if ( LP_inventory_prevent(iambob,coin->symbol,jbits256(item,"tx_hash"),juint(item,"tx_pos")) == 0 && jint(item,"height") < coin->height ) height = jint(item,"height");
{
//printf("%s\n",jprint(item,0));
values[i] = satoshis;
}
else
{
printf("skip.(%s) coinht.%d\n",jprint(item,0),coin->height);
used++;
}
} }
//printf("%.8f ",dstr(satoshis)); satoshis = LP_txvalue(destaddr,coin->symbol,txid,vout);
if ( satoshis != value )
printf("unexpected privkey_init value mismatch %.8f vs %.8f (%s)\n",dstr(satoshis),dstr(value),jprint(item,0));
if ( LP_inventory_prevent(iambob,coin->symbol,txid,vout) == 0 && height > 0 )
{
//printf("%s\n",jprint(item,0));
values[i] = satoshis;
LP_address_utxoadd(coin,destaddr,txid,vout,satoshis,height);
} else used++;
} }
//printf("array.%d\n",n); //printf("array.%d\n",n);
while ( used < n-1 ) while ( used < n-1 )

Loading…
Cancel
Save