jl777 8 years ago
parent
commit
be1358e89d
  1. 13
      iguana/iguana777.c
  2. 70
      iguana/iguana_sign.c
  3. 2
      iguana/tests/decoderawtransaction

13
iguana/iguana777.c

@ -880,6 +880,19 @@ void iguana_coinloop(void *arg)
if ( coin->started == 0 && coin->active != 0 ) if ( coin->started == 0 && coin->active != 0 )
{ {
iguana_callcoinstart(myinfo,coin); iguana_callcoinstart(myinfo,coin);
if ( 0 && strcmp("BTC",coin->symbol) == 0 )
{
cJSON *txobj = cJSON_Parse("{\"version\":1,\"locktime\":1474666158,\"vin\":[{\"userdata\":\"51\",\"txid\":\"fc97c3675c83c09723e0b14292ddec73820cb7352166ace4fe81ed62568315f2\",\"vout\":0,\"scriptPubKey\":{\"hex\":\"a914b7a2e599edb55d3f78ebcbfd49e82dd9a12adc2487\"},\"suppress\":1,\"sequence\":0,\"redeemScript\":\"6304ae9ee557b1752102a9669e63ef1ab04913615c2f3887ea3584f81e5f08feee9535b19ab3739d8afdac67a914adfad35d6646a0514011ba6ab53462319b651f96882103225046c9947222ab04acdefe2ed5dec4dcb593c5e6ae58e2c61c7ace14d81b70ac68\"}],\"vout\":[{\"satoshis\":\"36042\",\"scriptPubkey\":{\"hex\":\"76a914b7128d2ee837cf03e30a2c0e3e0181f7b9669bb688ac\"}}]}");
struct vin_info V[3]; bits256 txid,checktxid; uint8_t *extraspace; struct iguana_info *coin = iguana_coinfind("BTC");
memset(V,0,sizeof(V));
char *txbytes = bitcoin_json2hex(myinfo,coin,&txid,txobj,V);
printf("rawtx.(%s)\n",txbytes);
extraspace = calloc(1,65536);
txobj = bitcoin_hex2json(coin,coin->blocks.hwmchain.height,&checktxid,0,txbytes,extraspace,65536,0,jobj(txobj,"vin"),1);
printf("TXOBJ.(%s)\n",jprint(txobj,0));
free(extraspace);
getchar();
}
} }
now = (uint32_t)time(NULL); now = (uint32_t)time(NULL);
coin->idletime = 0; coin->idletime = 0;

70
iguana/iguana_sign.c

@ -26,26 +26,26 @@ int32_t iguana_vinparse(struct iguana_info *coin,int32_t rwflag,uint8_t *seriali
if ( rwflag == 1 ) if ( rwflag == 1 )
{ {
tmp = msg->scriptlen + msg->userdatalen + msg->p2shlen; tmp = msg->scriptlen + msg->userdatalen + msg->p2shlen;
if ( msg->p2shlen != 0 ) /*if ( msg->p2shlen != 0 )
{ {
if ( msg->p2shlen < 76 ) if ( msg->p2shlen < 76 )
tmp++; tmp++;
else if ( msg->p2shlen < 0x100 ) else if ( msg->p2shlen < 0x100 )
tmp += 2; tmp += 2;
else tmp += 3; else tmp += 3;
} }*/
} }
len += iguana_rwvarint32(rwflag,&serialized[len],&tmp); len += iguana_rwvarint32(rwflag,&serialized[len],&tmp);
if ( rwflag == 0 ) if ( rwflag == 0 )
{ {
if ( msg->p2shlen != 0 ) /*if ( msg->p2shlen != 0 )
{ {
if ( msg->p2shlen < 76 ) if ( msg->p2shlen < 76 )
tmp++; tmp++;
else if ( msg->p2shlen < 0x100 ) else if ( msg->p2shlen < 0x100 )
tmp += 2; tmp += 2;
else tmp += 3; else tmp += 3;
} }*/
msg->scriptlen = tmp; msg->scriptlen = tmp;
} }
if ( msg->scriptlen > IGUANA_MAXSCRIPTSIZE ) if ( msg->scriptlen > IGUANA_MAXSCRIPTSIZE )
@ -53,7 +53,7 @@ int32_t iguana_vinparse(struct iguana_info *coin,int32_t rwflag,uint8_t *seriali
printf("iguana_vinparse illegal scriptlen.%d\n",msg->scriptlen); printf("iguana_vinparse illegal scriptlen.%d\n",msg->scriptlen);
return(-1); return(-1);
} }
//printf("len.%d scriptlen.%d user.%d p2sh.%d\n",len,msg->scriptlen,msg->userdatalen,msg->p2shlen); printf("len.%d scriptlen.%d user.%d p2sh.%d\n",len,msg->scriptlen,msg->userdatalen,msg->p2shlen);
if ( rwflag == 0 ) if ( rwflag == 0 )
{ {
msg->vinscript = &serialized[len]; msg->vinscript = &serialized[len];
@ -88,6 +88,7 @@ int32_t iguana_vinparse(struct iguana_info *coin,int32_t rwflag,uint8_t *seriali
memcpy(&serialized[len],msg->redeemscript,p2shlen), len += p2shlen; memcpy(&serialized[len],msg->redeemscript,p2shlen), len += p2shlen;
} }
} }
printf("sequence starts.%d\n",len);
len += iguana_rwnum(rwflag,&serialized[len],sizeof(msg->sequence),&msg->sequence); len += iguana_rwnum(rwflag,&serialized[len],sizeof(msg->sequence),&msg->sequence);
if ( 0 ) if ( 0 )
{ {
@ -139,13 +140,13 @@ cJSON *iguana_vinjson(struct iguana_info *coin,struct iguana_msgvin *vin,bits256
jaddnum(json,"vout",vout); jaddnum(json,"vout",vout);
if ( bits256_nonz(sigtxid) != 0 ) if ( bits256_nonz(sigtxid) != 0 )
jaddbits256(json,"sigtxid",sigtxid); jaddbits256(json,"sigtxid",sigtxid);
if ( vin->scriptlen > 0 ) // sigs if ( vin->scriptlen > 0 && vin->vinscript != 0 ) // sigs
iguana_addscript(coin,json,vin->vinscript,vin->scriptlen,"scriptSig"); iguana_addscript(coin,json,vin->vinscript,vin->scriptlen,"scriptSig");
if ( vin->userdatalen > 0 && vin->userdata != 0 ) if ( vin->userdatalen > 0 && vin->userdata != 0 )
iguana_addscript(coin,json,vin->userdata,vin->userdatalen,"userdata"); iguana_addscript(coin,json,vin->userdata,vin->userdatalen,"userdata");
if ( vin->p2shlen > 0 ) if ( vin->p2shlen > 0 && vin->redeemscript != 0 )
iguana_addscript(coin,json,vin->redeemscript,vin->p2shlen,"redeemScript"); iguana_addscript(coin,json,vin->redeemscript,vin->p2shlen,"redeemScript");
if ( vin->spendlen > 0 ) if ( vin->spendlen > 0 && vin->spendscript != 0 )
iguana_addscript(coin,json,vin->spendscript,vin->spendlen,"scriptPubKey"); iguana_addscript(coin,json,vin->spendscript,vin->spendlen,"scriptPubKey");
} }
return(json); return(json);
@ -177,7 +178,7 @@ int32_t iguana_parsehexstr(uint8_t **destp,uint16_t *lenp,uint8_t *dest2,int32_t
int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin,uint8_t *serialized,int32_t maxsize,struct iguana_msgvin *vin,cJSON *vinobj,struct vin_info *V) int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin,uint8_t *serialized,int32_t maxsize,struct iguana_msgvin *vin,cJSON *vinobj,struct vin_info *V)
{ {
struct iguana_outpoint outpt; struct iguana_waddress *waddr; struct iguana_waccount *wacct; uint8_t lastbyte; uint32_t tmp=0; int32_t i,n,starti,suppress_pubkeys,siglen,plen,m,rwflag=1,need_op0=0,len = 0; char *userdata=0,*pubkeystr,*hexstr = 0,*redeemstr = 0,*spendstr = 0; cJSON *scriptjson = 0,*obj,*pubkeysjson = 0; struct iguana_outpoint outpt; struct iguana_waddress *waddr; struct iguana_waccount *wacct; uint8_t lastbyte,spendscript[8192]; uint32_t tmp=0; int32_t i,n,starti,spendlen,suppress_pubkeys,siglen,plen,m,endi,rwflag=1,need_op0=0,len = 0; char *userdata=0,*pubkeystr,*hexstr = 0,*redeemstr = 0,*spendstr = 0; cJSON *scriptjson = 0,*obj,*pubkeysjson = 0;
//printf("PARSEVIN.(%s) vin.%p\n",jprint(vinobj,0),vin); //printf("PARSEVIN.(%s) vin.%p\n",jprint(vinobj,0),vin);
if ( V == 0 ) if ( V == 0 )
memset(vin,0,sizeof(*vin)); memset(vin,0,sizeof(*vin));
@ -229,7 +230,7 @@ int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin
{ {
if ( vin->vinscript == 0 ) if ( vin->vinscript == 0 )
{ {
if ( iguana_RTunspentindfind(myinfo,coin,&outpt,V->coinaddr,V->spendscript,&V->spendlen,&V->amount,&V->height,vin->prev_hash,vin->prev_vout,coin->bundlescount-1,0) == 0 ) if ( iguana_RTunspentindfind(myinfo,coin,&outpt,V->coinaddr,spendscript,&spendlen,&V->amount,&V->height,vin->prev_hash,vin->prev_vout,coin->bundlescount-1,0) == 0 )
{ {
V->unspentind = outpt.unspentind; V->unspentind = outpt.unspentind;
if ( V->coinaddr[0] != 0 && (waddr= iguana_waddresssearch(myinfo,&wacct,V->coinaddr)) != 0 ) if ( V->coinaddr[0] != 0 && (waddr= iguana_waddresssearch(myinfo,&wacct,V->coinaddr)) != 0 )
@ -238,11 +239,18 @@ int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin
} }
//printf("V %.8f (%s) spendscript.[%d]\n",dstr(V->amount),V->coinaddr,V->spendlen); //printf("V %.8f (%s) spendscript.[%d]\n",dstr(V->amount),V->coinaddr,V->spendlen);
} }
if ( spendlen != 0 && V->spendlen == 0 )
{
V->spendlen = spendlen;
memcpy(V->spendscript,spendscript,spendlen);
}
} }
} }
tmp = IGUANA_MAXSCRIPTSIZE; tmp = IGUANA_MAXSCRIPTSIZE;
len += iguana_rwvarint32(rwflag,&serialized[len],&tmp);
starti = len; starti = len;
len += iguana_rwvarint32(rwflag,&serialized[len],&tmp);
endi = len;
printf("rwflag.%d len.%d tmp.%d\n",rwflag,len,tmp);
if ( need_op0 != 0 ) if ( need_op0 != 0 )
serialized[len++] = 0; // hack for bug for bug backward compatibility serialized[len++] = 0; // hack for bug for bug backward compatibility
if ( hexstr != 0 ) if ( hexstr != 0 )
@ -295,14 +303,14 @@ int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin
} }
} }
} }
//printf("len.%d: ",len); //printf("userdata len.%d: ",len);
if ( userdata != 0 ) if ( userdata != 0 )
{ {
n = iguana_parsehexstr(&vin->userdata,&vin->userdatalen,V!=0?V->userdata:0,V!=0?&V->userdatalen:0,&serialized[len],userdata); n = iguana_parsehexstr(&vin->userdata,&vin->userdatalen,V!=0?V->userdata:0,V!=0?&V->userdatalen:0,&serialized[len],userdata);
//printf("parsed userdata.%d\n",n); //printf("parsed userdata.%d\n",n);
len += n; len += n;
} }
//printf("len.%d: ",len); //printf("redeemlen.%d: ",len);
if ( redeemstr != 0 ) if ( redeemstr != 0 )
{ {
n = (int32_t)strlen(redeemstr) >> 1; n = (int32_t)strlen(redeemstr) >> 1;
@ -322,31 +330,32 @@ int32_t iguana_parsevinobj(struct supernet_info *myinfo,struct iguana_info *coin
n = iguana_parsehexstr(&vin->redeemscript,&vin->p2shlen,V!=0?V->p2shscript:0,V!=0?&V->p2shlen:0,&serialized[len],redeemstr); n = iguana_parsehexstr(&vin->redeemscript,&vin->p2shlen,V!=0?V->p2shscript:0,V!=0?&V->p2shlen:0,&serialized[len],redeemstr);
len += n; len += n;
} }
tmp = (len - starti); tmp = (len - endi);
if ( tmp < 76 ) if ( tmp < 0x100 )
{ {
serialized[starti-3] = tmp; serialized[starti] = tmp;
for (i=starti-2; i<starti-2+tmp; i++) for (i=starti+1; i<starti+1+tmp; i++)
serialized[i] = serialized[i+2]; serialized[i] = serialized[i+2];
printf("tmp.%d (len.%d - starti.%d) i.%d\n",tmp,len,starti,i);
len -= 2; len -= 2;
} }
else if ( tmp < 0x100 ) /*else if ( tmp < 0x10000 )
{ {
serialized[starti-3] = 0xfc; serialized[starti] = 0xfc;
serialized[starti-2] = tmp; serialized[starti+1] = tmp;
for (i=starti-1; i<starti-1+tmp; i++) for (i=starti+2; i<starti+2+tmp; i++)
serialized[i] = serialized[i+1]; serialized[i] = serialized[i+1];
len--; len--;
} }*/
else else
{ {
//for (i=0; i<len; i++) //for (i=0; i<len; i++)
// printf("%02x",serialized[i]); // printf("%02x",serialized[i]);
//printf(" <- offset.%d tmp.%d starti.%d\n",len,tmp,starti); //printf(" <- offset.%d tmp.%d starti.%d\n",len,tmp,starti);
serialized[starti-2] = (tmp & 0xff); serialized[starti+1] = (tmp & 0xff);
serialized[starti-1] = ((tmp >> 8) & 0xff); serialized[starti+2] = ((tmp >> 8) & 0xff);
} }
//printf("output sequence.[%d] <- %x\n",len,vin->sequence); printf("len.%d tmp.%d output sequence.[%d] <- %x\n",len,tmp,len,vin->sequence);
len += iguana_rwnum(rwflag,&serialized[len],sizeof(vin->sequence),&vin->sequence); len += iguana_rwnum(rwflag,&serialized[len],sizeof(vin->sequence),&vin->sequence);
if ( 0 && spendstr != 0 ) if ( 0 && spendstr != 0 )
{ {
@ -472,7 +481,7 @@ bits256 bitcoin_sigtxid(struct iguana_info *coin,int32_t height,uint8_t *seriali
int32_t iguana_rwmsgtx(struct iguana_info *coin,int32_t height,int32_t rwflag,cJSON *json,uint8_t *serialized,int32_t maxsize,struct iguana_msgtx *msg,bits256 *txidp,char *vpnstr,uint8_t *extraspace,int32_t extralen,cJSON *vins,int32_t suppress_pubkeys) int32_t iguana_rwmsgtx(struct iguana_info *coin,int32_t height,int32_t rwflag,cJSON *json,uint8_t *serialized,int32_t maxsize,struct iguana_msgtx *msg,bits256 *txidp,char *vpnstr,uint8_t *extraspace,int32_t extralen,cJSON *vins,int32_t suppress_pubkeys)
{ {
int32_t i,n,len = 0,extraused=0; uint8_t *txstart = serialized,*sigser=0; char txidstr[65]; cJSON *array=0; bits256 sigtxid; int32_t i,n,len = 0,extraused=0; uint8_t *txstart = serialized,*sigser=0; char txidstr[65],*redeemstr; cJSON *vin,*array=0; bits256 sigtxid;
len += iguana_rwnum(rwflag,&serialized[len],sizeof(msg->version),&msg->version); len += iguana_rwnum(rwflag,&serialized[len],sizeof(msg->version),&msg->version);
if ( json != 0 ) if ( json != 0 )
{ {
@ -507,10 +516,15 @@ int32_t iguana_rwmsgtx(struct iguana_info *coin,int32_t height,int32_t rwflag,cJ
} }
for (i=0; i<msg->tx_in; i++) for (i=0; i<msg->tx_in; i++)
{ {
//printf("vin.%d starts offset.%d\n",i,len); printf("vin.%d starts offset.%d\n",i,len);
if ( vins != 0 && (vin= jitem(vins,i)) != 0 )
{
if ( (redeemstr= jstr(vin,"redeemScript")) != 0 && is_hexstr(redeemstr,0) > 0 )
msg->vins[i].p2shlen = (int32_t)strlen(redeemstr) >> 1;
}
if ( (n= iguana_vinparse(coin,rwflag,&serialized[len],&msg->vins[i])) < 0 ) if ( (n= iguana_vinparse(coin,rwflag,&serialized[len],&msg->vins[i])) < 0 )
return(-1); return(-1);
//printf("vin.%d n.%d len.%d\n",i,n,len); printf("vin.%d n.%d len.%d\n",i,n,len);
len += n; len += n;
if ( len > maxsize ) if ( len > maxsize )
{ {

2
iguana/tests/decoderawtransaction

@ -1 +1 @@
curl --url "http://127.0.0.1:7778" --data "{\"coin\":\"SYS\",\"method\":\"decoderawtransaction\",\"params\":[\"0100000002836a9affa9b868cd4da9598f9a311bc8315dd0beafcdc4066f7eb4a55d19fae8010000006b483045022100f892c8848a9b9cbc97cc6558b088a4d00ef7da574be31558a252b7ba394d388302205b2a2f9b50bdf7f970fc6c1da5cb4d07a7a1a1e6dfd6f37692f01ad466cade4c012102743d2afdb88ede68fb5938e961b1f41c2b6267b3286516543eb4e4ab87ad0d0affffffffd7bcb83647bdcf661a4e71e96ee0ee84f77f09e278120a9479e19c709238963d000000006a47304402206e9393c76191d9c1383765eae918f91b5977d3eb5dcf63168c14d2a8d37e479c022003a6fd30ee59b9e330b4d18b4c1318ccafde6e0edff836e230bf792f017d73c7012102743d2afdb88ede68fb5938e961b1f41c2b6267b3286516543eb4e4ab87ad0d0affffffff02204e0000000000001976a914d93f7d2bd03a6f9f83ccbd06ec277b4549aff73988accc5d0100000000001976a9142f4c0f91fc06ac228c120aee41741d0d3909683288ac00000000\", 1]}" curl --url "http://127.0.0.1:7778" --data "{\"coin\":\"BTC\",\"method\":\"decoderawtransaction\",\"params\":[\"0100000001f215835662ed81fee4ac662135b70c8273ecdd9242b1e02397c0835c67c397fc00000000fc6a514c676304ae9ee557b1752102a9669e63ef1ab04913615c2f3887ea3584f81e5f08feee9535b19ab3739d8afdac67a914adfad35d6646a0514011ba6ab53462319b651f96882103225046c9947222ab04acdefe2ed5dec4dcb593c5e6ae58e2c61c7ace14d81b70ac680000000001ca8c0000000000001976a914b7128d2ee837cf03e30a2c0e3e0181f7b9669bb688acae9ee557\", 1]}"

Loading…
Cancel
Save