jl777 8 years ago
parent
commit
c0bef26568
  1. 12
      iguana/dpow/dpow_rpc.c
  2. 1
      iguana/iguana_notary.c

12
iguana/dpow/dpow_rpc.c

@ -13,6 +13,8 @@
* * * *
******************************************************************************/ ******************************************************************************/
#define issue_curl(cmdstr) bitcoind_RPC(0,"curl",cmdstr,0,0,0)
int32_t komodo_notaries(uint8_t pubkeys[64][33],int32_t kmdheight) int32_t komodo_notaries(uint8_t pubkeys[64][33],int32_t kmdheight)
{ {
int32_t i,num=-1; struct iguana_info *coin; char params[256],*retstr,*pubkeystr; cJSON *retjson,*item,*array; int32_t i,num=-1; struct iguana_info *coin; char params[256],*retstr,*pubkeystr; cJSON *retjson,*item,*array;
@ -545,7 +547,6 @@ void dpow_issuer_withdraw(struct dpow_info *dp,char *coinaddr,uint64_t fiatoshis
pax->txid = txid; pax->txid = txid;
pax->vout = vout; pax->vout = vout;
HASH_ADD_KEYPTR(hh,dp->PAX,&pax->txid,sizeof(pax->txid),pax); HASH_ADD_KEYPTR(hh,dp->PAX,&pax->txid,sizeof(pax->txid),pax);
printf("ADD PAX.%p (%p %p) pax.%p\n",dp->PAX,dp->PAX->hh.next,dp->PAX->hh.prev,pax);
} }
pthread_mutex_unlock(&dp->mutex); pthread_mutex_unlock(&dp->mutex);
if ( coinaddr != 0 ) if ( coinaddr != 0 )
@ -627,16 +628,20 @@ void dpow_issuer_voutupdate(struct dpow_info *dp,char *symbol,int32_t isspecial,
int32_t dpow_issuer_tx(struct dpow_info *dp,struct iguana_info *coin,int32_t height,int32_t txi,char *txidstr,uint32_t port) int32_t dpow_issuer_tx(struct dpow_info *dp,struct iguana_info *coin,int32_t height,int32_t txi,char *txidstr,uint32_t port)
{ {
char *retstr,params[256],*hexstr; uint8_t script[10000]; cJSON *json,*result,*vouts,*item,*sobj; int32_t vout,n,len,isspecial,retval = -1; uint64_t value; bits256 txid; char *retstr,params[256],*hexstr; uint8_t script[10000]; cJSON *json,*result,*vouts,*item,*sobj; int32_t vout,n,len,isspecial,retval = -1; uint64_t value,vpub_new,vpub_old; bits256 txid;
sprintf(params,"[\"%s\", 1]",txidstr); sprintf(params,"[\"%s\", 1]",txidstr);
if ( (retstr= dpow_issuemethod(coin->chain->userpass,(char *)"getrawtransaction",params,port)) != 0 ) if ( (retstr= dpow_issuemethod(coin->chain->userpass,(char *)"getrawtransaction",params,port)) != 0 )
{ {
if ( (json= cJSON_Parse(retstr)) != 0 ) if ( (json= cJSON_Parse(retstr)) != 0 )
{ {
//printf("TX.(%s)\n",retstr); //printf("TX.(%s)\n",retstr);
if ( (result= jobj(json,(char *)"result")) != 0 && (vouts= jarray(&n,result,(char *)"vout")) != 0 ) if ( (result= jobj(json,(char *)"result")) != 0 )
{ {
vpub_old = j64bits(result,(char *)"vpub_old");
vpub_new = j64bits(result,(char *)"vpub_new");
retval = 0; retval = 0;
if ( vpub_old == 0 && vpub_new == 0 && (vouts= jarray(&n,result,(char *)"vout")) != 0 )
{
isspecial = 0; isspecial = 0;
txid = jbits256(result,(char *)"txid"); txid = jbits256(result,(char *)"txid");
for (vout=0; vout<n; vout++) for (vout=0; vout<n; vout++)
@ -658,6 +663,7 @@ int32_t dpow_issuer_tx(struct dpow_info *dp,struct iguana_info *coin,int32_t hei
} }
} }
} }
}
} else printf("error getting txids.(%s)\n",retstr); } else printf("error getting txids.(%s)\n",retstr);
free_json(json); free_json(json);
} }

1
iguana/iguana_notary.c

@ -290,7 +290,6 @@ STRING_ARG(dpow,pending,fiat)
dp = &myinfo->DPOWS[i]; dp = &myinfo->DPOWS[i];
if ( strcmp(dp->symbol,base) == 0 ) if ( strcmp(dp->symbol,base) == 0 )
return(jprint(dpow_withdraws_pending(dp),1)); return(jprint(dpow_withdraws_pending(dp),1));
else printf("mismatched i.%d %s\n",i,dp->symbol);
} }
} }
return(clonestr("[]")); return(clonestr("[]"));

Loading…
Cancel
Save