Browse Source

test

release/v0.1
jl777 9 years ago
parent
commit
e87f53c46e
  1. 15
      deprecated/obsolete.h
  2. 1
      iguana/SuperNET.h
  3. 17
      iguana/iguana777.h
  4. 16
      iguana/iguana_unspents.c
  5. 329
      iguana/iguana_wallet.c
  6. 2
      iguana/main.c
  7. 6
      iguana/ramchain_api.c
  8. 0
      iguana/tests/backupwallet
  9. 1
      iguana/tests/dumpprivkey
  10. 2
      iguana/tests/getnewaddress
  11. 2
      iguana/tests/gettxout
  12. 1
      iguana/tests/importprivkey
  13. 1
      iguana/tests/setaccount

15
deprecated/obsolete.h

@ -16245,6 +16245,21 @@ len = 0;
if ( rmdarray != 0 ) if ( rmdarray != 0 )
free(rmdarray); free(rmdarray);
return(jprint(retjson,1));*/ return(jprint(retjson,1));*/
char *iguana_payloadsave(char *filename,cJSON *wallet)
{
FILE *fp;
if ( (fp= fopen(filename,"wb")) != 0 )
{
if ( fwrite(payloadstr,1,strlen(payloadstr),fp) != strlen(payloadstr) )
{
fclose(fp);
return(clonestr("{\"error\":\"couldnt save wallet backup\"}"));
}
fclose(fp);
return(0);
} else return(clonestr("{\"error\":\"couldnt save wallet backup\"}"));
}
#endif #endif
#endif #endif

1
iguana/SuperNET.h

@ -87,6 +87,7 @@ struct supernet_info
struct supernet_agent agents[SUPERNET_MAXAGENTS]; queue_t acceptQ; struct supernet_agent agents[SUPERNET_MAXAGENTS]; queue_t acceptQ;
int32_t numagents,numexchanges; int32_t numagents,numexchanges;
struct exchange_info *tradingexchanges[SUPERNET_MAXEXCHANGES]; struct exchange_info *tradingexchanges[SUPERNET_MAXEXCHANGES];
struct iguana_waccount *wallet;
char handle[1024],*decryptstr; char handle[1024],*decryptstr;
}; };

17
iguana/iguana777.h

@ -514,7 +514,6 @@ struct iguana_info
uint64_t bloomsearches,bloomhits,bloomfalse,collisions; uint64_t bloomsearches,bloomhits,bloomfalse,collisions;
uint8_t blockspace[IGUANA_MAXPACKETSIZE + 8192]; struct OS_memspace blockMEM; uint8_t blockspace[IGUANA_MAXPACKETSIZE + 8192]; struct OS_memspace blockMEM;
struct iguana_blocks blocks; bits256 APIblockhash,APItxid; char *APIblockstr; struct iguana_blocks blocks; bits256 APIblockhash,APItxid; char *APIblockstr;
struct iguana_waccount *wallet;
struct iguana_hhutxo *utxotable; struct iguana_hhaccount *accountstable; char lastdispstr[2048]; struct iguana_hhutxo *utxotable; struct iguana_hhaccount *accountstable; char lastdispstr[2048];
double txidfind_totalmillis,txidfind_num,spendtxid_totalmillis,spendtxid_num; double txidfind_totalmillis,txidfind_num,spendtxid_totalmillis,spendtxid_num;
}; };
@ -770,11 +769,11 @@ struct iguana_ramchain *iguana_bundleload(struct iguana_info *coin,struct iguana
int32_t iguana_sendblockreq(struct iguana_info *coin,struct iguana_peer *addr,struct iguana_bundle *bp,int32_t bundlei,bits256 hash2,int32_t iamthreadsafe); int32_t iguana_sendblockreq(struct iguana_info *coin,struct iguana_peer *addr,struct iguana_bundle *bp,int32_t bundlei,bits256 hash2,int32_t iamthreadsafe);
int32_t iguana_send_supernet(struct iguana_info *coin,struct iguana_peer *addr,char *jsonstr,int32_t delay); int32_t iguana_send_supernet(struct iguana_info *coin,struct iguana_peer *addr,char *jsonstr,int32_t delay);
struct iguana_waccount *iguana_waccountfind(struct iguana_info *coin,char *account); struct iguana_waccount *iguana_waccountfind(struct supernet_info *myinfo,struct iguana_info *coin,char *account);
struct iguana_waddress *iguana_waccountadd(struct iguana_info *coin,struct iguana_waccount **wacctp,char *walletaccount,char *coinaddr); struct iguana_waddress *iguana_waccountadd(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount **wacctp,char *walletaccount,char *coinaddr);
struct iguana_waddress *iguana_waccountswitch(struct iguana_info *coin,char *account,char *coinaddr); struct iguana_waddress *iguana_waccountswitch(struct supernet_info *myinfo,struct iguana_info *coin,char *account,char *coinaddr);
struct iguana_waddress *iguana_waddresscalc(uint8_t pubval,uint8_t wiftype,struct iguana_waddress *addr,bits256 privkey); struct iguana_waddress *iguana_waddresscalc(uint8_t pubval,uint8_t wiftype,struct iguana_waddress *addr,bits256 privkey);
struct iguana_waddress *iguana_waddressfind(struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr); struct iguana_waddress *iguana_waddressfind(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr);
char *iguana_coinjson(struct iguana_info *coin,char *method,cJSON *json); char *iguana_coinjson(struct iguana_info *coin,char *method,cJSON *json);
cJSON *iguana_peersjson(struct iguana_info *coin,int32_t addronly); cJSON *iguana_peersjson(struct iguana_info *coin,int32_t addronly);
//int32_t btc_priv2wif(char *wifstr,uint8_t privkey[32],uint8_t addrtype); //int32_t btc_priv2wif(char *wifstr,uint8_t privkey[32],uint8_t addrtype);
@ -829,7 +828,7 @@ char *issue_startForging(struct supernet_info *myinfo,char *secret);
struct bitcoin_unspent *iguana_unspentsget(struct supernet_info *myinfo,struct iguana_info *coin,char **retstrp,double *balancep,int32_t *numunspentsp,double minconfirms,char *account); struct bitcoin_unspent *iguana_unspentsget(struct supernet_info *myinfo,struct iguana_info *coin,char **retstrp,double *balancep,int32_t *numunspentsp,double minconfirms,char *account);
void iguana_chainparms(struct iguana_chain *chain,cJSON *argjson); void iguana_chainparms(struct iguana_chain *chain,cJSON *argjson);
void iguana_addinputs(struct iguana_info *coin,struct bitcoin_spend *spend,cJSON *txobj,uint32_t sequence); void iguana_addinputs(struct iguana_info *coin,struct bitcoin_spend *spend,cJSON *txobj,uint32_t sequence);
int32_t iguana_pkhasharray(struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,int64_t *totalp,struct iguana_pkhash *P,int32_t max,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t lastheight); int32_t iguana_pkhasharray(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,int64_t *totalp,struct iguana_pkhash *P,int32_t max,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t lastheight);
long iguana_spentsfile(struct iguana_info *coin,int32_t n); long iguana_spentsfile(struct iguana_info *coin,int32_t n);
uint8_t *iguana_rmdarray(struct iguana_info *coin,int32_t *numrmdsp,cJSON *array,int32_t firsti); uint8_t *iguana_rmdarray(struct iguana_info *coin,int32_t *numrmdsp,cJSON *array,int32_t firsti);
int64_t iguana_unspents(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,uint8_t *rmdarray,int32_t numrmds,int32_t lastheight); int64_t iguana_unspents(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,uint8_t *rmdarray,int32_t numrmds,int32_t lastheight);
@ -919,12 +918,12 @@ uint32_t iguana_fastfindinit(struct iguana_info *coin);
int32_t iguana_unspentindfind(struct iguana_info *coin,int32_t *heightp,bits256 txid,int32_t vout,int32_t lasthdrsi); int32_t iguana_unspentindfind(struct iguana_info *coin,int32_t *heightp,bits256 txid,int32_t vout,int32_t lasthdrsi);
int32_t iguana_addressvalidate(struct iguana_info *coin,uint8_t *addrtypep,uint8_t rmd160[20],char *address); int32_t iguana_addressvalidate(struct iguana_info *coin,uint8_t *addrtypep,uint8_t rmd160[20],char *address);
int32_t bitcoin_sign(uint8_t *sig,int32_t maxlen,uint8_t *data,int32_t datalen,bits256 privkey); int32_t bitcoin_sign(uint8_t *sig,int32_t maxlen,uint8_t *data,int32_t datalen,bits256 privkey);
bits256 iguana_str2priv(struct iguana_info *coin,char *str); bits256 iguana_str2priv(struct supernet_info *myinfo,struct iguana_info *coin,char *str);
int32_t iguana_spentflag(struct iguana_info *coin,int64_t *RTspendp,int32_t *spentheightp,struct iguana_ramchain *ramchain,int16_t spent_hdrsi,uint32_t spent_unspentind,int32_t height,int32_t minconf,int32_t maxconf,uint64_t amount); int32_t iguana_spentflag(struct iguana_info *coin,int64_t *RTspendp,int32_t *spentheightp,struct iguana_ramchain *ramchain,int16_t spent_hdrsi,uint32_t spent_unspentind,int32_t height,int32_t minconf,int32_t maxconf,uint64_t amount);
int32_t iguana_voutscript(struct iguana_info *coin,struct iguana_bundle *bp,uint8_t *scriptspace,char *asmstr,struct iguana_unspent *u,struct iguana_pkhash *p,int32_t txi); int32_t iguana_voutscript(struct iguana_info *coin,struct iguana_bundle *bp,uint8_t *scriptspace,char *asmstr,struct iguana_unspent *u,struct iguana_pkhash *p,int32_t txi);
cJSON *iguana_unspentjson(struct iguana_info *coin,int32_t hdrsi,uint32_t unspentind,struct iguana_txid *T,struct iguana_unspent *up,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33); cJSON *iguana_unspentjson(struct supernet_info *myinfo,struct iguana_info *coin,int32_t hdrsi,uint32_t unspentind,struct iguana_txid *T,struct iguana_unspent *up,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33);
int32_t bitcoin_standardspend(uint8_t *script,int32_t n,uint8_t rmd160[20]); int32_t bitcoin_standardspend(uint8_t *script,int32_t n,uint8_t rmd160[20]);
struct iguana_waddress *iguana_waddresssearch(struct iguana_info *coin,struct iguana_waccount **wacctp,char *coinaddr); struct iguana_waddress *iguana_waddresssearch(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount **wacctp,char *coinaddr);
int64_t iguana_addressreceived(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *json,char *remoteaddr,cJSON *txids,cJSON *vouts,char *coinaddr,int32_t minconf); int64_t iguana_addressreceived(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *json,char *remoteaddr,cJSON *txids,cJSON *vouts,char *coinaddr,int32_t minconf);
extern int32_t HDRnet,netBLOCKS; extern int32_t HDRnet,netBLOCKS;

16
iguana/iguana_unspents.c

@ -1092,7 +1092,7 @@ cJSON *ramchain_unspentjson(struct iguana_unspent *up,uint32_t unspentind)
return(item); return(item);
} }
cJSON *iguana_unspentjson(struct iguana_info *coin,int32_t hdrsi,uint32_t unspentind,struct iguana_txid *T,struct iguana_unspent *up,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33) cJSON *iguana_unspentjson(struct supernet_info *myinfo,struct iguana_info *coin,int32_t hdrsi,uint32_t unspentind,struct iguana_txid *T,struct iguana_unspent *up,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33)
{ {
/*{ /*{
"txid" : "d54994ece1d11b19785c7248868696250ab195605b469632b7bd68130e880c9a", "txid" : "d54994ece1d11b19785c7248868696250ab195605b469632b7bd68130e880c9a",
@ -1118,7 +1118,7 @@ cJSON *iguana_unspentjson(struct iguana_info *coin,int32_t hdrsi,uint32_t unspen
jaddnum(item,"confirmations",coin->blocks.hwmchain.height - height); jaddnum(item,"confirmations",coin->blocks.hwmchain.height - height);
jaddnum(item,"checkind",checkind); jaddnum(item,"checkind",checkind);
} }
if ( (waddr= iguana_waddresssearch(coin,&wacct,coinaddr)) != 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,coinaddr)) != 0 )
{ {
jaddstr(item,"account",wacct->account); jaddstr(item,"account",wacct->account);
jadd(item,"spendable",jtrue()); jadd(item,"spendable",jtrue());
@ -1204,7 +1204,7 @@ int32_t iguana_uheight(struct iguana_info *coin,int32_t bundleheight,struct igua
else return(bundleheight); else return(bundleheight);
} }
int64_t iguana_pkhashbalance(struct iguana_info *coin,cJSON *array,int64_t *spentp,int32_t *nump,struct iguana_ramchain *ramchain,struct iguana_pkhash *p,uint32_t lastunspentind,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t hdrsi,int32_t lastheight,int32_t minconf,int32_t maxconf) int64_t iguana_pkhashbalance(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *array,int64_t *spentp,int32_t *nump,struct iguana_ramchain *ramchain,struct iguana_pkhash *p,uint32_t lastunspentind,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t hdrsi,int32_t lastheight,int32_t minconf,int32_t maxconf)
{ {
struct iguana_unspent *U; struct iguana_utxo *U2; struct iguana_spend *S; int32_t uheight,spentheight; uint32_t pkind=0,unspentind; int64_t spent = 0,checkval,deposits = 0; struct iguana_txid *T; struct iguana_account *A2; struct iguana_ramchaindata *rdata = 0; int64_t RTspend = 0; struct iguana_unspent *U; struct iguana_utxo *U2; struct iguana_spend *S; int32_t uheight,spentheight; uint32_t pkind=0,unspentind; int64_t spent = 0,checkval,deposits = 0; struct iguana_txid *T; struct iguana_account *A2; struct iguana_ramchaindata *rdata = 0; int64_t RTspend = 0;
*spentp = *nump = 0; *spentp = *nump = 0;
@ -1234,7 +1234,7 @@ int64_t iguana_pkhashbalance(struct iguana_info *coin,cJSON *array,int64_t *spen
if ( lastheight < 0 || iguana_spentflag(coin,&RTspend,&spentheight,ramchain,hdrsi,unspentind,lastheight,minconf,maxconf,U[unspentind].value) == 0 ) if ( lastheight < 0 || iguana_spentflag(coin,&RTspend,&spentheight,ramchain,hdrsi,unspentind,lastheight,minconf,maxconf,U[unspentind].value) == 0 )
{ {
if ( array != 0 ) if ( array != 0 )
jaddi(array,iguana_unspentjson(coin,hdrsi,unspentind,T,&U[unspentind],rmd160,coinaddr,pubkey33)); jaddi(array,iguana_unspentjson(myinfo,coin,hdrsi,unspentind,T,&U[unspentind],rmd160,coinaddr,pubkey33));
} else spent += U[unspentind].value; } else spent += U[unspentind].value;
if ( p->pkind != U[unspentind].pkind ) if ( p->pkind != U[unspentind].pkind )
printf("warning: [%d] p->pkind.%u vs U->pkind.%u for u%d\n",hdrsi,p->pkind,U[unspentind].pkind,unspentind); printf("warning: [%d] p->pkind.%u vs U->pkind.%u for u%d\n",hdrsi,p->pkind,U[unspentind].pkind,unspentind);
@ -1265,7 +1265,7 @@ int64_t iguana_pkhashbalance(struct iguana_info *coin,cJSON *array,int64_t *spen
return(deposits - spent); return(deposits - spent);
} }
int32_t iguana_pkhasharray(struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,int64_t *totalp,struct iguana_pkhash *P,int32_t max,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t lastheight) int32_t iguana_pkhasharray(struct supernet_info *myinfo,struct iguana_info *coin,cJSON *array,int32_t minconf,int32_t maxconf,int64_t *totalp,struct iguana_pkhash *P,int32_t max,uint8_t rmd160[20],char *coinaddr,uint8_t *pubkey33,int32_t lastheight)
{ {
int32_t i,n,m; int64_t spent,deposits,netbalance,total; uint32_t lastunspentind; struct iguana_ramchain *ramchain; struct iguana_bundle *bp; int32_t i,n,m; int64_t spent,deposits,netbalance,total; uint32_t lastunspentind; struct iguana_ramchain *ramchain; struct iguana_bundle *bp;
if ( 0 && coin->RTramchain_busy != 0 ) if ( 0 && coin->RTramchain_busy != 0 )
@ -1287,7 +1287,7 @@ int32_t iguana_pkhasharray(struct iguana_info *coin,cJSON *array,int32_t minconf
break; break;
if ( iguana_pkhashfind(coin,&ramchain,&deposits,&lastunspentind,&P[n],rmd160,i,i) != 0 ) if ( iguana_pkhashfind(coin,&ramchain,&deposits,&lastunspentind,&P[n],rmd160,i,i) != 0 )
{ {
if ( (netbalance= iguana_pkhashbalance(coin,array,&spent,&m,ramchain,&P[n],lastunspentind,rmd160,coinaddr,pubkey33,i,lastheight,minconf,maxconf)) != deposits-spent && lastheight == IGUANA_MAXHEIGHT && minconf == 1 && maxconf > coin->blocks.hwmchain.height ) if ( (netbalance= iguana_pkhashbalance(myinfo,coin,array,&spent,&m,ramchain,&P[n],lastunspentind,rmd160,coinaddr,pubkey33,i,lastheight,minconf,maxconf)) != deposits-spent && lastheight == IGUANA_MAXHEIGHT && minconf == 1 && maxconf > coin->blocks.hwmchain.height )
{ {
printf("pkhash balance mismatch from m.%d check %.8f vs %.8f spent %.8f [%.8f]\n",m,dstr(netbalance),dstr(deposits),dstr(spent),dstr(deposits)-dstr(spent)); printf("pkhash balance mismatch from m.%d check %.8f vs %.8f spent %.8f [%.8f]\n",m,dstr(netbalance),dstr(deposits),dstr(spent),dstr(deposits)-dstr(spent));
} }
@ -1322,7 +1322,7 @@ int64_t iguana_unspents(struct supernet_info *myinfo,struct iguana_info *coin,cJ
for (i=0; i<numrmds; i++) for (i=0; i<numrmds; i++)
{ {
bitcoin_address(coinaddr,addrtypes[i],&rmdarray[i * 20],20); bitcoin_address(coinaddr,addrtypes[i],&rmdarray[i * 20],20);
iguana_pkhasharray(coin,array,minconf,maxconf,&total,P,coin->bundlescount,&rmdarray[i * 20],coinaddr,&pubkeys[33*i],lastheight); iguana_pkhasharray(myinfo,coin,array,minconf,maxconf,&total,P,coin->bundlescount,&rmdarray[i * 20],coinaddr,&pubkeys[33*i],lastheight);
printf("i.%d of %d: %s %.8f\n",i,numrmds,coinaddr,dstr(total)); printf("i.%d of %d: %s %.8f\n",i,numrmds,coinaddr,dstr(total));
sum += total; sum += total;
} }
@ -2659,7 +2659,7 @@ TWOSTRINGS_AND_INT(iguana,balance,activecoin,address,lastheight)
printf("Start %s balance.(%s) height.%d\n",coin->symbol,address,lastheight); printf("Start %s balance.(%s) height.%d\n",coin->symbol,address,lastheight);
if ( lastheight == 0 ) if ( lastheight == 0 )
lastheight = IGUANA_MAXHEIGHT; lastheight = IGUANA_MAXHEIGHT;
iguana_pkhasharray(coin,array,minconf,maxconf,&total,P,coin->bundlescount,rmd160,address,pubkey33,lastheight); iguana_pkhasharray(myinfo,coin,array,minconf,maxconf,&total,P,coin->bundlescount,rmd160,address,pubkey33,lastheight);
free(P); free(P);
jadd(retjson,"unspents",array); jadd(retjson,"unspents",array);
jaddnum(retjson,"balance",dstr(total)); jaddnum(retjson,"balance",dstr(total));

329
iguana/iguana_wallet.c

@ -15,33 +15,85 @@
#include "iguana777.h" #include "iguana777.h"
struct iguana_waddress *iguana_waddressfind(struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr) void scrubfree(char *sensitivestr)
{ {
struct iguana_waddress *waddr; long len,i;
HASH_FIND(hh,wacct,coinaddr,strlen(coinaddr)+1,waddr); if ( sensitivestr != 0 )
return(waddr); {
len = strlen(sensitivestr);
memset(sensitivestr,0,len);
for (i=0; i<len; i++)
sensitivestr[i] = rand();
free(sensitivestr);
}
}
void iguana_walletdelete(struct supernet_info *myinfo,int32_t deleteflag)
{
struct iguana_waccount *wacct,*tmp; struct iguana_waddress *waddr,*tmp2; int32_t i;
HASH_ITER(hh,myinfo->wallet,wacct,tmp)
{
HASH_ITER(hh,wacct->waddr,waddr,tmp2)
{
memset(&waddr->privkey,0,sizeof(waddr->privkey));
memset(waddr->wifstr,0,sizeof(waddr->wifstr));
for (i=0; i<sizeof(waddr->privkey); i++)
waddr->privkey.bytes[i] = rand();
for (i=0; i<sizeof(waddr->wifstr); i++)
waddr->wifstr[i] = rand();
if ( deleteflag != 0 )
{
HASH_DELETE(hh,wacct->waddr,waddr);
free(waddr);
}
}
if ( deleteflag != 0 )
{
HASH_DELETE(hh,myinfo->wallet,wacct);
free(wacct);
}
}
} }
struct iguana_waddress *iguana_waddresscreate(struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr) struct iguana_waddress *iguana_waddressfind(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr)
{ {
struct iguana_waddress *waddr; int32_t len = (int32_t)strlen(coinaddr)+1; struct iguana_waddress *waddr; int32_t len = (int32_t)strlen(coinaddr)+1;
HASH_FIND(hh,wacct,coinaddr,len,waddr); HASH_FIND(hh,wacct->waddr,coinaddr,len,waddr);
//printf("%s (%s).%d in (%s)\n",waddr==0?"couldnt find":"found",coinaddr,len,wacct->account);
return(waddr);
}
struct iguana_waddress *iguana_waddresscreate(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr)
{
struct iguana_waddress *waddr,*ptr; int32_t len = (int32_t)strlen(coinaddr)+1;
HASH_FIND(hh,wacct->waddr,coinaddr,len,waddr);
if ( waddr == 0 ) if ( waddr == 0 )
{ {
waddr = mycalloc('w',1,sizeof(*waddr) + len); waddr = mycalloc('w',1,sizeof(*waddr));
strcpy(waddr->coinaddr,coinaddr); strcpy(waddr->coinaddr,coinaddr);
strcpy(waddr->symbol,coin->symbol); strcpy(waddr->symbol,coin->symbol);
HASH_ADD_KEYPTR(hh,wacct,waddr->coinaddr,len,wacct); HASH_ADD_KEYPTR(hh,wacct->waddr,waddr->coinaddr,len,waddr);
} printf("create (%s).%d -> (%s)\n",coinaddr,len,wacct->account);
} //else printf("have (%s) in (%s)\n",coinaddr,wacct->account);
if ( (ptr= iguana_waddressfind(myinfo,coin,wacct,coinaddr)) != waddr )
printf("iguana_waddresscreate verify error %p vs %p\n",ptr,waddr);
return(waddr); return(waddr);
} }
struct iguana_waddress *iguana_waddressadd(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,struct iguana_waddress *addwaddr) struct iguana_waddress *iguana_waddressadd(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,struct iguana_waddress *addwaddr)
{ {
struct iguana_waddress *waddr; int32_t len = (int32_t)strlen(addwaddr->coinaddr)+1; struct iguana_waddress *waddr,*ptr; int32_t len = (int32_t)strlen(addwaddr->coinaddr)+1;
HASH_FIND(hh,wacct,addwaddr->coinaddr,len,waddr); HASH_FIND(hh,wacct->waddr,addwaddr->coinaddr,len,waddr);
if ( waddr == 0 ) if ( waddr == 0 )
HASH_ADD_KEYPTR(hh,wacct->waddr,addwaddr->coinaddr,len,addwaddr); {
waddr = mycalloc('w',1,sizeof(*waddr));
memcpy(waddr,addwaddr,sizeof(*waddr));
addwaddr = waddr;
HASH_ADD_KEYPTR(hh,wacct->waddr,waddr->coinaddr,len,waddr);
printf("add (%s).%d -> (%s)\n",waddr->coinaddr,len,wacct->account);
} //else printf("have (%s) in (%s)\n",waddr->coinaddr,wacct->account);
if ( (ptr= iguana_waddressfind(myinfo,coin,wacct,waddr->coinaddr)) != waddr )
printf("iguana_waddressadd verify error %p vs %p\n",ptr,waddr);
if ( waddr != 0 && waddr != addwaddr ) if ( waddr != 0 && waddr != addwaddr )
{ {
waddr->privkey = addwaddr->privkey; waddr->privkey = addwaddr->privkey;
@ -51,27 +103,27 @@ struct iguana_waddress *iguana_waddressadd(struct supernet_info *myinfo,struct i
strcpy(waddr->wifstr,addwaddr->wifstr); strcpy(waddr->wifstr,addwaddr->wifstr);
waddr->wiftype = addwaddr->wiftype; waddr->wiftype = addwaddr->wiftype;
waddr->type = addwaddr->type; waddr->type = addwaddr->type;
} else waddr = addwaddr; }
if ( waddr != 0 ) if ( waddr != 0 && waddr->symbol[0] == 0 )
strcpy(waddr->symbol,coin->symbol); strcpy(waddr->symbol,coin->symbol);
return(waddr); return(waddr);
} }
struct iguana_waddress *iguana_waddressdelete(struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr) struct iguana_waddress *iguana_waddressdelete(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount *wacct,char *coinaddr)
{ {
struct iguana_waddress *waddr = 0; int32_t len = (int32_t)strlen(coinaddr)+1; struct iguana_waddress *waddr = 0; int32_t len = (int32_t)strlen(coinaddr)+1;
HASH_FIND(hh,wacct,coinaddr,len,waddr); HASH_FIND(hh,wacct->waddr,coinaddr,len,waddr);
if ( waddr != 0 ) if ( waddr != 0 )
HASH_DELETE(hh,wacct,waddr); HASH_DELETE(hh,wacct->waddr,waddr);
return(waddr); return(waddr);
} }
struct iguana_waddress *iguana_waddresssearch(struct iguana_info *coin,struct iguana_waccount **wacctp,char *coinaddr) struct iguana_waddress *iguana_waddresssearch(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount **wacctp,char *coinaddr)
{ {
struct iguana_waccount *wacct,*tmp; struct iguana_waddress *waddr; struct iguana_waccount *wacct,*tmp; struct iguana_waddress *waddr;
HASH_ITER(hh,coin->wallet,wacct,tmp) HASH_ITER(hh,myinfo->wallet,wacct,tmp)
{ {
if ( (waddr= iguana_waddressfind(coin,wacct,coinaddr)) != 0 ) if ( (waddr= iguana_waddressfind(myinfo,coin,wacct,coinaddr)) != 0 )
{ {
(*wacctp) = wacct; (*wacctp) = wacct;
return(waddr); return(waddr);
@ -80,37 +132,40 @@ struct iguana_waddress *iguana_waddresssearch(struct iguana_info *coin,struct ig
return(0); return(0);
} }
struct iguana_waccount *iguana_waccountfind(struct iguana_info *coin,char *account) struct iguana_waccount *iguana_waccountfind(struct supernet_info *myinfo,struct iguana_info *coin,char *account)
{ {
struct iguana_waccount *wacct; struct iguana_waccount *wacct;
HASH_FIND(hh,coin->wallet,account,strlen(account)+1,wacct); HASH_FIND(hh,myinfo->wallet,account,strlen(account)+1,wacct);
//printf("waccountfind.(%s) -> wacct.%p\n",account,wacct); //printf("waccountfind.(%s) -> wacct.%p\n",account,wacct);
return(wacct); return(wacct);
} }
struct iguana_waccount *iguana_waccountcreate(struct iguana_info *coin,char *account) struct iguana_waccount *iguana_waccountcreate(struct supernet_info *myinfo,struct iguana_info *coin,char *account)
{ {
struct iguana_waccount *wacct; int32_t len = (int32_t)strlen(account)+1; struct iguana_waccount *wacct,*ptr; int32_t len = (int32_t)strlen(account)+1;
HASH_FIND(hh,coin->wallet,account,len,wacct); HASH_FIND(hh,myinfo->wallet,account,len,wacct);
if ( wacct == 0 ) if ( wacct == 0 )
{ {
wacct = mycalloc('w',1,sizeof(*wacct) + len); wacct = mycalloc('w',1,sizeof(*wacct));
strcpy(wacct->account,account); strcpy(wacct->account,account);
HASH_ADD_KEYPTR(hh,coin->wallet,wacct->account,len,wacct); HASH_ADD_KEYPTR(hh,myinfo->wallet,wacct->account,len,wacct);
//printf("waccountcreate.(%s) -> wacct.%p\n",account,wacct); //printf("waccountcreate.(%s) -> wacct.%p\n",account,wacct);
if ( (ptr= iguana_waccountfind(myinfo,coin,account)) != wacct )
printf("iguana_waccountcreate verify error %p vs %p\n",ptr,wacct);
} }
return(wacct); return(wacct);
} }
struct iguana_waddress *iguana_waccountswitch(struct iguana_info *coin,char *account,char *coinaddr) struct iguana_waddress *iguana_waccountswitch(struct supernet_info *myinfo,struct iguana_info *coin,char *account,char *coinaddr)
{ {
struct iguana_waccount *wacct = 0; struct iguana_waddress *waddr = 0; struct iguana_waccount *wacct = 0; struct iguana_waddress *waddr = 0;
if ( (waddr= iguana_waddresssearch(coin,&wacct,coinaddr)) != 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,coinaddr)) != 0 )
{ {
HASH_DELETE(hh,wacct,waddr); iguana_waddressdelete(myinfo,coin,wacct,coinaddr);
if ( (wacct= iguana_waccountcreate(coin,account)) != 0 ) //HASH_DELETE(hh,wacct,waddr);
waddr = iguana_waddresscreate(coin,wacct,coinaddr);
} }
if ( (wacct= iguana_waccountcreate(myinfo,coin,account)) != 0 )
waddr = iguana_waddresscreate(myinfo,coin,wacct,coinaddr);
return(waddr); return(waddr);
} }
@ -119,7 +174,7 @@ uint8_t *iguana_walletrmds(struct supernet_info *myinfo,struct iguana_info *coin
int32_t iter,n,m; struct iguana_waccount *acct,*tmp; uint8_t *pubkeys,*addrtypes,*rmdarray = 0; struct iguana_waddress *waddr,*tmp2; int32_t iter,n,m; struct iguana_waccount *acct,*tmp; uint8_t *pubkeys,*addrtypes,*rmdarray = 0; struct iguana_waddress *waddr,*tmp2;
for (iter=n=m=0; iter<2; iter++) for (iter=n=m=0; iter<2; iter++)
{ {
HASH_ITER(hh,coin->wallet,acct,tmp) HASH_ITER(hh,myinfo->wallet,acct,tmp)
{ {
HASH_ITER(hh,acct->waddr,waddr,tmp2) HASH_ITER(hh,acct->waddr,waddr,tmp2)
{ {
@ -149,7 +204,7 @@ cJSON *getaddressesbyaccount(struct supernet_info *myinfo,struct iguana_info *co
struct iguana_waccount *subset; struct iguana_waddress *waddr,*tmp; cJSON *retjson,*array; struct iguana_waccount *subset; struct iguana_waddress *waddr,*tmp; cJSON *retjson,*array;
retjson = cJSON_CreateObject(); retjson = cJSON_CreateObject();
array = cJSON_CreateArray(); array = cJSON_CreateArray();
if ( (subset= iguana_waccountfind(coin,account)) != 0 ) if ( (subset= iguana_waccountfind(myinfo,coin,account)) != 0 )
{ {
HASH_ITER(hh,subset->waddr,waddr,tmp) HASH_ITER(hh,subset->waddr,waddr,tmp)
{ {
@ -159,13 +214,13 @@ cJSON *getaddressesbyaccount(struct supernet_info *myinfo,struct iguana_info *co
return(array); return(array);
} }
struct iguana_waddress *iguana_waccountadd(struct iguana_info *coin,struct iguana_waccount **wacctp,char *walletaccount,char *coinaddr) struct iguana_waddress *iguana_waccountadd(struct supernet_info *myinfo,struct iguana_info *coin,struct iguana_waccount **wacctp,char *walletaccount,char *coinaddr)
{ {
struct iguana_waccount *wacct; struct iguana_waddress *waddr = 0; struct iguana_waccount *wacct; struct iguana_waddress *waddr = 0;
if ( (wacct= iguana_waccountfind(coin,walletaccount)) == 0 ) if ( (wacct= iguana_waccountfind(myinfo,coin,walletaccount)) == 0 )
wacct = iguana_waccountcreate(coin,walletaccount); wacct = iguana_waccountcreate(myinfo,coin,walletaccount);
if ( wacct != 0 ) if ( wacct != 0 )
waddr = iguana_waddresscreate(coin,wacct,coinaddr); waddr = iguana_waddresscreate(myinfo,coin,wacct,coinaddr);
return(waddr); return(waddr);
} }
@ -190,9 +245,10 @@ void iguana_walletlock(struct supernet_info *myinfo)
memset(myinfo->secret,0,sizeof(myinfo->secret)); memset(myinfo->secret,0,sizeof(myinfo->secret));
memset(myinfo->permanentfile,0,sizeof(myinfo->permanentfile)); memset(myinfo->permanentfile,0,sizeof(myinfo->permanentfile));
if ( myinfo->decryptstr != 0 ) if ( myinfo->decryptstr != 0 )
free(myinfo->decryptstr), myinfo->decryptstr = 0; scrubfree(myinfo->decryptstr), myinfo->decryptstr = 0;
myinfo->expiration = 0; myinfo->expiration = 0;
//printf("wallet locked\n"); iguana_walletdelete(myinfo,0);
//printf("wallet locked\n");
} }
uint8_t *iguana_rmdarray(struct iguana_info *coin,int32_t *numrmdsp,cJSON *array,int32_t firsti) uint8_t *iguana_rmdarray(struct iguana_info *coin,int32_t *numrmdsp,cJSON *array,int32_t firsti)
@ -219,11 +275,11 @@ uint8_t *iguana_rmdarray(struct iguana_info *coin,int32_t *numrmdsp,cJSON *array
return(rmdarray); return(rmdarray);
} }
struct iguana_waddress *iguana_ismine(struct iguana_info *coin,uint8_t addrtype,uint8_t pubkey[65],uint8_t rmd160[20]) struct iguana_waddress *iguana_ismine(struct supernet_info *myinfo,struct iguana_info *coin,uint8_t addrtype,uint8_t pubkey[65],uint8_t rmd160[20])
{ {
char coinaddr[65]; struct iguana_waccount *wacct; struct iguana_waddress *waddr = 0; char coinaddr[65]; struct iguana_waccount *wacct; struct iguana_waddress *waddr = 0;
if ( bitcoin_address(coinaddr,addrtype,rmd160,20) > 0 ) if ( bitcoin_address(coinaddr,addrtype,rmd160,20) > 0 )
waddr = iguana_waddresssearch(coin,&wacct,coinaddr); waddr = iguana_waddresssearch(myinfo,coin,&wacct,coinaddr);
return(waddr); return(waddr);
} }
@ -259,7 +315,7 @@ char *setaccount(struct supernet_info *myinfo,struct iguana_info *coin,char *acc
{ {
if ( iguana_addressvalidate(coin,&addrtype,rmd160,coinaddr) < 0 ) if ( iguana_addressvalidate(coin,&addrtype,rmd160,coinaddr) < 0 )
return(clonestr("{\"error\":\"invalid coin address\"}")); return(clonestr("{\"error\":\"invalid coin address\"}"));
if ( (waddr= iguana_waccountswitch(coin,account,coinaddr)) != 0 ) if ( (waddr= iguana_waccountswitch(myinfo,coin,account,coinaddr)) != 0 )
return(clonestr("{\"result\":\"success\"}")); return(clonestr("{\"result\":\"success\"}"));
else return(clonestr("{\"error\":\"couldnt set account\"}")); else return(clonestr("{\"error\":\"couldnt set account\"}"));
} }
@ -271,7 +327,7 @@ char *getaccount(struct supernet_info *myinfo,struct iguana_info *coin,char *coi
struct iguana_waccount *wacct; struct iguana_waddress *waddr; uint8_t addrtype,rmd160[20]; cJSON *retjson; struct iguana_waccount *wacct; struct iguana_waddress *waddr; uint8_t addrtype,rmd160[20]; cJSON *retjson;
if ( iguana_addressvalidate(coin,&addrtype,rmd160,coinaddr) < 0 ) if ( iguana_addressvalidate(coin,&addrtype,rmd160,coinaddr) < 0 )
return(clonestr("{\"error\":\"invalid coin address\"}")); return(clonestr("{\"error\":\"invalid coin address\"}"));
if ( (waddr= iguana_waddresssearch(coin,&wacct,coinaddr)) == 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,coinaddr)) == 0 )
return(clonestr("{\"result\":\"no account for address\"}")); return(clonestr("{\"result\":\"no account for address\"}"));
if ( wacct != 0 ) if ( wacct != 0 )
{ {
@ -304,7 +360,7 @@ char *jsuccess()
return(jprint(retjson,1)); return(jprint(retjson,1));
} }
bits256 iguana_str2priv(struct iguana_info *coin,char *str) bits256 iguana_str2priv(struct supernet_info *myinfo,struct iguana_info *coin,char *str)
{ {
bits256 privkey; int32_t n; uint8_t addrtype; struct iguana_waccount *wacct=0; struct iguana_waddress *waddr; bits256 privkey; int32_t n; uint8_t addrtype; struct iguana_waccount *wacct=0; struct iguana_waddress *waddr;
memset(&privkey,0,sizeof(privkey)); memset(&privkey,0,sizeof(privkey));
@ -315,7 +371,7 @@ bits256 iguana_str2priv(struct iguana_info *coin,char *str)
decode_hex(privkey.bytes,sizeof(privkey),str); decode_hex(privkey.bytes,sizeof(privkey),str);
else if ( bitcoin_wif2priv(&addrtype,&privkey,str) != sizeof(bits256) ) else if ( bitcoin_wif2priv(&addrtype,&privkey,str) != sizeof(bits256) )
{ {
if ( (waddr= iguana_waddresssearch(coin,&wacct,str)) != 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,str)) != 0 )
privkey = waddr->privkey; privkey = waddr->privkey;
} }
} }
@ -379,17 +435,12 @@ int32_t iguana_payloadupdate(struct supernet_info *myinfo,struct iguana_info *co
cJSON *iguana_walletadd(struct supernet_info *myinfo,struct iguana_waddress **waddrp,struct iguana_info *coin,char *retstr,char *account,struct iguana_waddress *refwaddr,int32_t setcurrent) cJSON *iguana_walletadd(struct supernet_info *myinfo,struct iguana_waddress **waddrp,struct iguana_info *coin,char *retstr,char *account,struct iguana_waddress *refwaddr,int32_t setcurrent)
{ {
cJSON *retjson=0; struct iguana_waccount *wacct; struct iguana_waddress *waddr; cJSON *retjson=0; struct iguana_waccount *wacct; struct iguana_waddress *waddr;
if ( (wacct= iguana_waccountfind(coin,account)) == 0 ) if ( (wacct= iguana_waccountfind(myinfo,coin,account)) == 0 )
wacct = iguana_waccountcreate(coin,account); wacct = iguana_waccountcreate(myinfo,coin,account);
if ( wacct != 0 ) if ( wacct != 0 )
{ {
waddr = iguana_waddressfind(coin,wacct,refwaddr->coinaddr); //waddr = iguana_waddressfind(myinfo,coin,wacct,refwaddr->coinaddr);
if ( waddr != refwaddr ) waddr = iguana_waddressadd(myinfo,coin,wacct,refwaddr);
{
waddr = mycalloc('w',1,sizeof(*waddr));
memcpy(waddr,refwaddr,sizeof(*waddr));
}
iguana_waddressadd(myinfo,coin,wacct,waddr);
if ( setcurrent != 0 ) if ( setcurrent != 0 )
wacct->current = waddr; wacct->current = waddr;
if ( iguana_payloadupdate(myinfo,coin,retstr,waddr,account) < 0 ) if ( iguana_payloadupdate(myinfo,coin,retstr,waddr,account) < 0 )
@ -441,7 +492,7 @@ STRING_ARG(bitcoinrpc,validateaddress,address)
jaddnum(retjson,"addrtype",addrtype); jaddnum(retjson,"addrtype",addrtype);
init_hexbytes_noT(str,rmd160,sizeof(rmd160)); init_hexbytes_noT(str,rmd160,sizeof(rmd160));
jaddstr(retjson,"rmd160",str); jaddstr(retjson,"rmd160",str);
if ( iguana_ismine(coin,addrtype,pubkey,rmd160) > 0 ) if ( iguana_ismine(myinfo,coin,addrtype,pubkey,rmd160) > 0 )
{ {
init_hexbytes_noT(str,pubkey,bitcoin_pubkeylen(pubkey)); init_hexbytes_noT(str,pubkey,bitcoin_pubkeylen(pubkey));
jaddstr(retjson,"pubkey",str); jaddstr(retjson,"pubkey",str);
@ -508,7 +559,7 @@ STRING_ARG(bitcoinrpc,getnewaddress,account)
retstr = myinfo->decryptstr, myinfo->decryptstr = 0; retstr = myinfo->decryptstr, myinfo->decryptstr = 0;
newretstr = getnewaddress(myinfo,&waddr,coin,account,retstr); newretstr = getnewaddress(myinfo,&waddr,coin,account,retstr);
if ( retstr != 0 ) if ( retstr != 0 )
free(retstr); scrubfree(retstr);
return(newretstr); return(newretstr);
} }
else return(clonestr("{\"error\":\"no wallet payload\"}")); else return(clonestr("{\"error\":\"no wallet payload\"}"));
@ -523,8 +574,8 @@ STRING_ARG(bitcoinrpc,getaccountaddress,account)
return(clonestr("{\"error\":\"need to unlock wallet\"}")); return(clonestr("{\"error\":\"need to unlock wallet\"}"));
if ( account != 0 && account[0] != 0 ) if ( account != 0 && account[0] != 0 )
{ {
if ( (wacct= iguana_waccountfind(coin,account)) == 0 ) if ( (wacct= iguana_waccountfind(myinfo,coin,account)) == 0 )
wacct = iguana_waccountcreate(coin,account); wacct = iguana_waccountcreate(myinfo,coin,account);
if ( wacct != 0 ) if ( wacct != 0 )
{ {
if ( (waddr= wacct->current) == 0 ) if ( (waddr= wacct->current) == 0 )
@ -536,7 +587,7 @@ STRING_ARG(bitcoinrpc,getaccountaddress,account)
printf("loginstr.(%s)\n",retstr); printf("loginstr.(%s)\n",retstr);
newstr = getnewaddress(myinfo,&waddr,coin,account,retstr); newstr = getnewaddress(myinfo,&waddr,coin,account,retstr);
if ( retstr != 0 ) if ( retstr != 0 )
free(retstr); scrubfree(retstr);
retstr = newstr; retstr = newstr;
} else return(clonestr("{\"error\":\"no wallet payload\"}")); } else return(clonestr("{\"error\":\"no wallet payload\"}"));
} }
@ -559,6 +610,104 @@ ZERO_ARGS(bitcoinrpc,walletlock)
return(jsuccess()); return(jsuccess());
} }
void iguana_walletinitcheck(struct supernet_info *myinfo,struct iguana_info *coin)
{
// "wallet":{"test":{"R9S7zZzzvgb4CkiBH1i7gnFcwJuL1MYbxN":"18ab9c89ce83929db720cf26b663bf762532276146cd9d3e1f89086fcdf00053"}}
cJSON *payload,*item,*array,*child; char *account,*coinaddr,*privkeystr; int32_t i,j,n,len; struct iguana_waccount *wacct,*tmp; struct iguana_waddress waddr; bits256 privkey;
if ( myinfo->wallet == 0 && myinfo->decryptstr != 0 && (payload= cJSON_Parse(myinfo->decryptstr)) != 0 )
{
if ( (array= jobj(payload,"wallet")) != 0 )
{
n = cJSON_GetArraySize(array);
//printf("item.(%s) size.%d\n",jprint(array,0),n);
item = array->child;
for (i=0; i<n; i++)
{
if ( item != 0 && (account= item->string) != 0 )
{
child = item->child;
while ( child != 0 )
{
coinaddr = child->string;
privkeystr = child->valuestring;
if ( coinaddr != 0 && privkeystr != 0 )
{
if ( (wacct= iguana_waccountcreate(myinfo,coin,account)) != 0 )
{
if ( iguana_waddresssearch(myinfo,coin,&tmp,coinaddr) == 0 )
{
privkey = bits256_conv(privkeystr);
if ( iguana_waddresscalc(coin->chain->pubtype,coin->chain->wiftype,&waddr,privkey) != 0 )
{
strcpy(waddr.coinaddr,coinaddr);
iguana_waddressadd(myinfo,coin,wacct,&waddr);
//iguana_waccountswitch(myinfo,coin,account,coinaddr);
}
} else printf("dup.(%s) ",coinaddr);
}
len = (int32_t)strlen(privkeystr);
for (j=0; j<len; j++)
privkeystr[j] = 0;
for (j=0; j<len; j++)
privkeystr[j] = 0x20 + (rand() % 64);
privkey = rand256(0);
}
child = child->next;
}
printf("account.(%s)\n",account);
}
item = item->next;
}
}
free_json(payload);
myinfo->decryptstr = 0;
scrubfree(myinfo->decryptstr);
}
}
int32_t iguana_walletemit(struct supernet_info *myinfo,char *fname,struct iguana_info *coin,cJSON *array)
{
cJSON *item,*child; uint8_t addrtype,wiftype,rmd160[20]; char str[64],wifstr[128],*account,*coinaddr,*privkeystr; int32_t i,j,n; FILE *fp; bits256 privkey;
if ( (fp= fopen(fname,"wb")) == 0 )
return(-1);
n = cJSON_GetArraySize(array);
item = array->child;
for (i=0; i<n; i++)
{
if ( item != 0 && (account= item->string) != 0 )
{
child = item->child;
while ( child != 0 )
{
coinaddr = child->string;
privkeystr = child->valuestring;
if ( coinaddr != 0 && privkeystr != 0 )
{
// RZXuGgmzABFpXRmGJet8AbJoqVGEs27WgdvkSSXUMg7en8jjBW2m 2016-03-26T18:40:06Z reserve=1 # addr=GRVaqhY6XVWGeEabEEx5gE7mAQ7EYQi5JV
privkey = bits256_conv(privkeystr);
bitcoin_addr2rmd160(&addrtype,rmd160,coinaddr);
wiftype = 188;
for (j=0; j<IGUANA_MAXCOINS; j++)
if ( (coin= Coins[j]) != 0 && coin->chain != 0 && coin->chain->pubtype == addrtype )
{
wiftype = coin->chain->wiftype;
break;
}
if ( bitcoin_priv2wif(wifstr,privkey,wiftype) > 0 )
{
fprintf(fp,"%s %s %32s=%d # addr=%s\n",wifstr,utc_str(str,(uint32_t)time(NULL)),account,i+1,coinaddr);
}
}
child = child->next;
}
//printf("account.(%s)\n",account);
}
item = item->next;
}
fclose(fp);
return(0);
}
TWOSTRINGS_AND_INT(bitcoinrpc,walletpassphrase,password,permanentfile,timeout) TWOSTRINGS_AND_INT(bitcoinrpc,walletpassphrase,password,permanentfile,timeout)
{ {
char *retstr; char *retstr;
@ -568,6 +717,7 @@ TWOSTRINGS_AND_INT(bitcoinrpc,walletpassphrase,password,permanentfile,timeout)
return(clonestr("{\"error\":\"timeout must be positive\"}")); return(clonestr("{\"error\":\"timeout must be positive\"}"));
myinfo->expiration = (uint32_t)time(NULL) + timeout; myinfo->expiration = (uint32_t)time(NULL) + timeout;
retstr = SuperNET_login(IGUANA_CALLARGS,myinfo->handle,password,permanentfile,0); retstr = SuperNET_login(IGUANA_CALLARGS,myinfo->handle,password,permanentfile,0);
iguana_walletinitcheck(myinfo,coin);
return(retstr); return(retstr);
} }
@ -611,7 +761,7 @@ FOUR_STRINGS(bitcoinrpc,walletpassphrasechange,oldpassword,newpassword,oldperman
free_json(tmpjson); free_json(tmpjson);
} }
if ( tmpstr != 0 ) if ( tmpstr != 0 )
free(tmpstr); scrubfree(tmpstr);
} }
if ( retstr == 0 ) if ( retstr == 0 )
retstr = clonestr("{\"error\":\"error changing walletpassphrase\"}"); retstr = clonestr("{\"error\":\"error changing walletpassphrase\"}");
@ -623,16 +773,18 @@ TWOSTRINGS_AND_INT(bitcoinrpc,importprivkey,wif,account,rescan)
bits256 privkey; char *retstr; cJSON *retjson; struct iguana_waddress addr,*waddr; struct iguana_waccount *wacct = 0; bits256 privkey; char *retstr; cJSON *retjson; struct iguana_waddress addr,*waddr; struct iguana_waccount *wacct = 0;
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
privkey = iguana_str2priv(coin,wif); if ( account == 0 || account[0] == 0 )
account = "default";
privkey = iguana_str2priv(myinfo,coin,wif);
if ( bits256_nonz(privkey) == 0 ) if ( bits256_nonz(privkey) == 0 )
return(clonestr("{\"error\":\"illegal privkey\"}")); return(clonestr("{\"error\":\"illegal privkey\"}"));
memset(&addr,0,sizeof(addr)); memset(&addr,0,sizeof(addr));
if ( iguana_waddresscalc(coin->chain->pubtype,coin->chain->wiftype,&addr,privkey) != 0 ) if ( iguana_waddresscalc(coin->chain->pubtype,coin->chain->wiftype,&addr,privkey) != 0 )
{ {
if ( (waddr= iguana_waddresssearch(coin,&wacct,addr.coinaddr)) != 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,addr.coinaddr)) != 0 )
{ {
if ( account != 0 && account[0] != 0 ) if ( account != 0 && account[0] != 0 )
waddr = iguana_waccountswitch(coin,account,addr.coinaddr); waddr = iguana_waccountswitch(myinfo,coin,account,addr.coinaddr);
} }
if ( myinfo->expiration == 0 ) if ( myinfo->expiration == 0 )
return(clonestr("{\"error\":\"need to unlock wallet\"}")); return(clonestr("{\"error\":\"need to unlock wallet\"}"));
@ -640,10 +792,12 @@ TWOSTRINGS_AND_INT(bitcoinrpc,importprivkey,wif,account,rescan)
{ {
free(retstr); free(retstr);
retstr = myinfo->decryptstr, myinfo->decryptstr = 0; retstr = myinfo->decryptstr, myinfo->decryptstr = 0;
if ( waddr == 0 )
waddr = &addr;
iguana_waddresscalc(coin->chain->pubtype,coin->chain->wiftype,waddr,privkey); iguana_waddresscalc(coin->chain->pubtype,coin->chain->wiftype,waddr,privkey);
retjson = iguana_walletadd(myinfo,0,coin,retstr,account,waddr,0); retjson = iguana_walletadd(myinfo,0,coin,retstr,account,waddr,0);
if ( retstr != 0 ) if ( retstr != 0 )
free(retstr); scrubfree(retstr);
return(jprint(retjson,1)); return(jprint(retjson,1));
} }
} }
@ -655,7 +809,7 @@ STRING_ARG(bitcoinrpc,dumpprivkey,address)
cJSON *retjson; struct iguana_waddress *waddr; struct iguana_waccount *wacct; cJSON *retjson; struct iguana_waddress *waddr; struct iguana_waccount *wacct;
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
if ( (waddr= iguana_waddresssearch(coin,&wacct,address)) != 0 && waddr->wifstr[0] != 0 ) if ( (waddr= iguana_waddresssearch(myinfo,coin,&wacct,address)) != 0 && waddr->wifstr[0] != 0 )
{ {
retjson = cJSON_CreateObject(); retjson = cJSON_CreateObject();
jaddstr(retjson,"result",waddr->wifstr); jaddstr(retjson,"result",waddr->wifstr);
@ -703,6 +857,7 @@ STRING_ARG(bitcoinrpc,dumpwallet,filename)
jadd(retjson,"wallet",jduplicate(walletobj)); jadd(retjson,"wallet",jduplicate(walletobj));
free_json(strobj); free_json(strobj);
} }
scrubfree(walletstr);
} }
return(jprint(retjson,1)); return(jprint(retjson,1));
} else printf("cant parse retstr.(%s)\n",retstr); } else printf("cant parse retstr.(%s)\n",retstr);
@ -711,45 +866,27 @@ STRING_ARG(bitcoinrpc,dumpwallet,filename)
return(clonestr("{\"error\":\"wallet is locked, cant backup\"}")); return(clonestr("{\"error\":\"wallet is locked, cant backup\"}"));
} }
// RZXuGgmzABFpXRmGJet8AbJoqVGEs27WgdvkSSXUMg7en8jjBW2m 2016-03-26T18:40:06Z reserve=1 # addr=GRVaqhY6XVWGeEabEEx5gE7mAQ7EYQi5JV
char *iguana_payloadsave(char *filename,char *payloadstr)
{
FILE *fp;
if ( (fp= fopen(filename,"wb")) != 0 )
{
if ( fwrite(payloadstr,1,strlen(payloadstr),fp) != strlen(payloadstr) )
{
fclose(fp);
return(clonestr("{\"error\":\"couldnt save wallet backup\"}"));
}
fclose(fp);
return(0);
} else return(clonestr("{\"error\":\"couldnt save wallet backup\"}"));
}
STRING_ARG(bitcoinrpc,backupwallet,filename) STRING_ARG(bitcoinrpc,backupwallet,filename)
{ {
char *loginstr,*payloadstr,*retstr = 0; cJSON *retjson; char *loginstr,*retstr = 0; cJSON *retjson,*payload;
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
if ( myinfo->expiration != 0 ) if ( myinfo->expiration != 0 )
{ {
if ( (loginstr= SuperNET_login(IGUANA_CALLARGS,myinfo->handle,myinfo->secret,myinfo->permanentfile,0)) != 0 ) if ( (loginstr= SuperNET_login(IGUANA_CALLARGS,myinfo->handle,myinfo->secret,myinfo->permanentfile,0)) != 0 )
{ {
retstr = clonestr("{\"error\":\"couldnt backup wallet\"}");
free(loginstr); free(loginstr);
loginstr = myinfo->decryptstr, myinfo->decryptstr = 0; loginstr = myinfo->decryptstr, myinfo->decryptstr = 0;
if ( (retjson= cJSON_Parse(loginstr)) != 0 ) if ( (retjson= cJSON_Parse(loginstr)) != 0 )
{ {
if ( (payloadstr= jstr(retjson,"wallet")) != 0 ) if ( (payload= jobj(retjson,"wallet")) != 0 && iguana_walletemit(myinfo,filename,coin,payload) == 0 )
retstr = iguana_payloadsave(filename,payloadstr); retstr = clonestr("{\"result\":\"wallet backup saved\"}");
free_json(retjson); free_json(retjson);
} }
if ( loginstr != 0 ) if ( loginstr != 0 )
free(loginstr); scrubfree(loginstr);
if ( retstr == 0 ) return(retstr);
return(clonestr("{\"result\":\"wallet backup saved\"}"));
else return(retstr);
} else return(clonestr("{\"error\":\"no wallet payload\"}")); } else return(clonestr("{\"error\":\"no wallet payload\"}"));
} else return(clonestr("{\"error\":\"need to unlock wallet\"}")); } else return(clonestr("{\"error\":\"need to unlock wallet\"}"));
} }
@ -792,7 +929,7 @@ STRING_ARG(bitcoinrpc,importwallet,filename)
loginstr = myinfo->decryptstr, myinfo->decryptstr = 0; loginstr = myinfo->decryptstr, myinfo->decryptstr = 0;
loginjson = cJSON_Parse(loginstr); loginjson = cJSON_Parse(loginstr);
if ( loginstr != 0 ) if ( loginstr != 0 )
free(loginstr); scrubfree(loginstr);
} }
retjson = iguana_payloadmerge(loginjson,importjson); retjson = iguana_payloadmerge(loginjson,importjson);
if ( importjson != 0 && importjson != retjson ) if ( importjson != 0 && importjson != retjson )
@ -857,7 +994,7 @@ STRING_AND_INT(bitcoinrpc,getreceivedbyaccount,account,minconf)
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
retjson = cJSON_CreateObject(); retjson = cJSON_CreateObject();
if ( (wacct= iguana_waccountfind(coin,account)) != 0 ) if ( (wacct= iguana_waccountfind(myinfo,coin,account)) != 0 )
{ {
balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0); balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0);
jaddnum(retjson,"result",dstr(balance)); jaddnum(retjson,"result",dstr(balance));
@ -872,7 +1009,7 @@ STRING_AND_THREEINTS(bitcoinrpc,listtransactions,account,count,skip,includewatch
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
retjson = cJSON_CreateObject(); retjson = cJSON_CreateObject();
retarray = cJSON_CreateArray(); retarray = cJSON_CreateArray();
if ( (wacct= iguana_waccountfind(coin,account)) != 0 ) if ( (wacct= iguana_waccountfind(myinfo,coin,account)) != 0 )
{ {
if ( (array= getaddressesbyaccount(myinfo,coin,account)) != 0 ) if ( (array= getaddressesbyaccount(myinfo,coin,account)) != 0 )
{ {
@ -936,7 +1073,7 @@ THREE_INTS(bitcoinrpc,listreceivedbyaccount,minconf,includeempty,watchonly)
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
array = cJSON_CreateArray(); array = cJSON_CreateArray();
HASH_ITER(hh,coin->wallet,wacct,tmp) HASH_ITER(hh,myinfo->wallet,wacct,tmp)
{ {
balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0); balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0);
item = cJSON_CreateObject(); item = cJSON_CreateObject();
@ -956,7 +1093,7 @@ THREE_INTS(bitcoinrpc,listreceivedbyaddress,minconf,includeempty,flag)
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
array = cJSON_CreateArray(); array = cJSON_CreateArray();
HASH_ITER(hh,coin->wallet,wacct,tmp) HASH_ITER(hh,myinfo->wallet,wacct,tmp)
{ {
HASH_ITER(hh,wacct->waddr,waddr,tmp2) HASH_ITER(hh,wacct->waddr,waddr,tmp2)
{ {
@ -981,7 +1118,7 @@ TWO_INTS(bitcoinrpc,listaccounts,minconf,includewatchonly)
if ( remoteaddr != 0 ) if ( remoteaddr != 0 )
return(clonestr("{\"error\":\"no remote\"}")); return(clonestr("{\"error\":\"no remote\"}"));
array = cJSON_CreateObject(); array = cJSON_CreateObject();
HASH_ITER(hh,coin->wallet,wacct,tmp) HASH_ITER(hh,myinfo->wallet,wacct,tmp)
{ {
balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0); balance = iguana_waccountbalance(myinfo,coin,wacct,minconf,0);
jaddnum(array,wacct->account,dstr(balance)); jaddnum(array,wacct->account,dstr(balance));

2
iguana/main.c

@ -415,7 +415,7 @@ void mainloop(struct supernet_info *myinfo)
while ( 1 ) while ( 1 )
{ {
//printf("main iteration\n"); //printf("main iteration\n");
if ( myinfo->expiration != 0 && time(NULL) > myinfo->expiration && myinfo->secret[0] != 0 ) if ( myinfo->expiration != 0 && time(NULL) > myinfo->expiration )
iguana_walletlock(myinfo); iguana_walletlock(myinfo);
flag = 0; flag = 0;
isRT = 1; isRT = 1;

6
iguana/ramchain_api.c

@ -325,7 +325,7 @@ HASH_AND_TWOINTS(bitcoinrpc,gettxout,txid,vout,mempool)
if ( (scriptobj= iguana_scriptobj(coin,rmd160,coinaddr,asmstr,script,scriptlen)) != 0 ) if ( (scriptobj= iguana_scriptobj(coin,rmd160,coinaddr,asmstr,script,scriptlen)) != 0 )
jadd(retjson,"scriptPubKey",scriptobj); jadd(retjson,"scriptPubKey",scriptobj);
} }
jadd(retjson,"iguana",iguana_unspentjson(coin,bp->hdrsi,unspentind,T,&U[unspentind],rmd160,coinaddr,pubkey33)); jadd(retjson,"iguana",iguana_unspentjson(myinfo,coin,bp->hdrsi,unspentind,T,&U[unspentind],rmd160,coinaddr,pubkey33));
if ( (height % coin->chain->bundlesize) == 0 && vout == 0 ) if ( (height % coin->chain->bundlesize) == 0 && vout == 0 )
jadd(retjson,"coinbase",jtrue()); jadd(retjson,"coinbase",jtrue());
else jadd(retjson,"coinbase",jfalse()); else jadd(retjson,"coinbase",jfalse());
@ -348,7 +348,7 @@ TWO_STRINGS(bitcoinrpc,signmessage,address,messagestr)
bits256 privkey; int32_t n,len,siglen; char sigstr[256],sig64str[256]; uint8_t sig[128],*message=0; cJSON *retjson = cJSON_CreateObject(); bits256 privkey; int32_t n,len,siglen; char sigstr[256],sig64str[256]; uint8_t sig[128],*message=0; cJSON *retjson = cJSON_CreateObject();
if ( coin != 0 ) if ( coin != 0 )
{ {
privkey = iguana_str2priv(coin,address); privkey = iguana_str2priv(myinfo,coin,address);
if ( bits256_nonz(privkey) != 0 ) if ( bits256_nonz(privkey) != 0 )
{ {
n = (int32_t)strlen(messagestr) >> 1; n = (int32_t)strlen(messagestr) >> 1;
@ -517,7 +517,7 @@ STRING_ARRAY_OBJ_STRING(bitcoinrpc,signrawtransaction,rawtx,vins,privkeys,sighas
{ {
item = jitem(privkeys,i); item = jitem(privkeys,i);
privkeystr = jstr(item,0); privkeystr = jstr(item,0);
privkey = iguana_str2priv(coin,privkeystr); privkey = iguana_str2priv(myinfo,coin,privkeystr);
if ( bits256_nonz(privkey) != 0 ) if ( bits256_nonz(privkey) != 0 )
{ {
spend->inputs[0].privkeys[i] = privkey; spend->inputs[0].privkeys[i] = privkey;

0
iguana/tests/backupwallet

1
iguana/tests/dumpprivkey

@ -0,0 +1 @@
curl --url "http://127.0.0.1:7778" --data "{\"method\":\"dumpprivkey\",\"params\":[\"R9S7zZzzvgb4CkiBH1i7gnFcwJuL1MYbxN\"]}"

2
iguana/tests/getnewaddress

@ -1 +1 @@
curl --url "http://127.0.0.1:7778" --data "{\"agent\":\"bitcoinrpc\",\"method\":\"getnewaddress\",\"account\":\"test\"}" curl --url "http://127.0.0.1:7778" --data "{\"agent\":\"bitcoinrpc\",\"method\":\"getnewaddress\",\"account\":\"\"}"

2
iguana/tests/gettxout

@ -0,0 +1,2 @@
curl --url "http://127.0.0.1:7778" --data "{\"coin\":\"BTCD\",\"method\":\"gettxout\",\"params\":[\"091c99b7b7f9b83ad2385c45b342ed5dd57035d15ff812262a3ceb3f1b291a5a\", 1]}"

1
iguana/tests/importprivkey

@ -0,0 +1 @@
curl --url "http://127.0.0.1:7778" --data "{\"method\":\"importprivkey\",\"params\":[\"580a86aca8df6ffdc8794cf1fecb36707e89dd1f9ca81d221f529f22ffcca946\"]}"

1
iguana/tests/setaccount

@ -0,0 +1 @@
curl --url "http://127.0.0.1:7778" --data "{\"method\":\"setaccount\",\"params\":[\"RL47yWGZpFjGoLhtuUjshrEh8nWQY7ztdR\", \"newaccount\"]}"
Loading…
Cancel
Save