Browse Source

test

release/v0.1
jl777 9 years ago
parent
commit
6c165fa073
  1. 3
      iguana/iguana777.h
  2. 15
      iguana/iguana_html.c
  3. 24
      iguana/iguana_json.c
  4. 7
      iguana/iguana_msg.c
  5. 11
      iguana/iguana_rpc.c

3
iguana/iguana777.h

@ -553,7 +553,8 @@ double dxblend(double *destp,double val,double decay);
// json // json
int32_t iguana_processjsonQ(struct iguana_info *coin); // reentrant, can be called during any idletime int32_t iguana_processjsonQ(struct iguana_info *coin); // reentrant, can be called during any idletime
char *iguana_JSON(char *jsonstr); char *iguana_JSON(struct iguana_info *coin,char *jsonstr,char *remoteaddr);
char *SuperNET_p2p(struct iguana_info *coin,char *ipaddr,uint8_t *data,int32_t datalen);
char *mbstr(char *str,double); char *mbstr(char *str,double);
int init_hexbytes_noT(char *hexbytes,unsigned char *message,long len); int init_hexbytes_noT(char *hexbytes,unsigned char *message,long len);

15
iguana/iguana_html.c

@ -152,12 +152,12 @@ char *HTMLfooter =
#define HTML_EMIT(str) if ( (str) != 0 && (str)[0] != 0 ) strcpy(&retbuf[size],str), size += (int32_t)strlen(str) #define HTML_EMIT(str) if ( (str) != 0 && (str)[0] != 0 ) strcpy(&retbuf[size],str), size += (int32_t)strlen(str)
char Prevjsonstr[1024],Currentjsonstr[1024]; char Prevjsonstr[1024],Currentjsonstr[1024];
char *iguana_rpc(char *agent,cJSON *json,char *data,int32_t datalen) char *iguana_rpc(char *agent,cJSON *json,char *data,int32_t datalen,char *remoteaddr)
{ {
//printf("agent.(%s) json.(%s) data[%d] %s\n",agent,jprint(json,0),datalen,data!=0?data:""); //printf("agent.(%s) json.(%s) data[%d] %s\n",agent,jprint(json,0),datalen,data!=0?data:"");
if ( data == 0 ) if ( data == 0 )
return(iguana_JSON(jprint(json,0))); return(iguana_JSON(0,jprint(json,0),remoteaddr));
else return(iguana_JSON(data)); else return(iguana_JSON(0,data,remoteaddr));
} }
void iguana_urldecode(char *str) void iguana_urldecode(char *str)
@ -578,7 +578,12 @@ char *iguana_rpcparse(char *retbuf,int32_t bufsize,int32_t *postflagp,char *json
char *key,*reststr,*str,*retstr,remoteaddr[65],porturl[65],*data = 0,*value,*agent = "SuperNET"; char *key,*reststr,*str,*retstr,remoteaddr[65],porturl[65],*data = 0,*value,*agent = "SuperNET";
//printf("rpcparse.(%s)\n",jsonstr); //printf("rpcparse.(%s)\n",jsonstr);
localaccess = 1; localaccess = 1;
strcpy(remoteaddr,"127.0.0.1"); // need to verify this if ( (str= strstr("Referer: ",jsonstr)) != 0 )
{
for (i=0; str[i]!=' '&&str[i]!=0&&str[i]!='\n'&&str[i]!='\r'; i++)
remoteaddr[i] = str[i];
remoteaddr[i] = 0;
} else strcpy(remoteaddr,"127.0.0.1"); // need to verify this
*postflagp = 0; *postflagp = 0;
if ( strncmp("POST",jsonstr,4) == 0 ) if ( strncmp("POST",jsonstr,4) == 0 )
jsonstr += 6, *postflagp = postflag = 1; jsonstr += 6, *postflagp = postflag = 1;
@ -687,7 +692,7 @@ char *iguana_rpcparse(char *retbuf,int32_t bufsize,int32_t *postflagp,char *json
} }
} }
} }
retstr = iguana_rpc(agent,json,data,datalen); retstr = iguana_rpc(agent,json,data,datalen,remoteaddr);
free_json(json); free_json(json);
return(retstr); return(retstr);
//printf("post.%d json.(%s) data[%d] %s\n",postflag,jprint(json,0),datalen,data!=0?data:""); //printf("post.%d json.(%s) data[%d] %s\n",postflag,jprint(json,0),datalen,data!=0?data:"");

24
iguana/iguana_json.c

@ -452,14 +452,16 @@ char *iguana_blockingjsonstr(struct iguana_info *coin,char *jsonstr,uint64_t tag
} }
} }
char *iguana_JSON(char *jsonstr) char *iguana_JSON(struct iguana_info *coin,char *jsonstr,char *remoteaddr)
{ {
cJSON *json,*retjson; uint64_t tag; uint32_t timeout; int32_t retval; cJSON *json,*retjson; uint64_t tag; uint32_t timeout; int32_t retval,localaccess = 0;
struct iguana_info *coin; char *method,*retjsonstr,*symbol,*retstr = 0; char *method,*retjsonstr,*symbol,*retstr = 0;
printf("iguana_JSON.(%s)\n",jsonstr); if ( remoteaddr == 0 || strcmp(remoteaddr,"127.0.0.1") == 0 ) // || strcmp(remoteaddr,myipaddr) == 0 )
localaccess = 1;
printf("iguana_JSON.(%s) from %s\n",jsonstr,localaccess==0?remoteaddr:"local access");
if ( (json= cJSON_Parse(jsonstr)) != 0 ) if ( (json= cJSON_Parse(jsonstr)) != 0 )
{ {
if ( (method= jstr(json,"method")) != 0 && strcmp(method,"addcoin") == 0 ) if ( localaccess != 0 && (method= jstr(json,"method")) != 0 && strcmp(method,"addcoin") == 0 )
{ {
if ( (retval= iguana_launchcoin(jstr(json,"coin"),json)) > 0 ) if ( (retval= iguana_launchcoin(jstr(json,"coin"),json)) > 0 )
return(clonestr("{\"result\":\"launched coin\"}")); return(clonestr("{\"result\":\"launched coin\"}"));
@ -470,10 +472,10 @@ char *iguana_JSON(char *jsonstr)
OS_randombytes((uint8_t *)&tag,sizeof(tag)); OS_randombytes((uint8_t *)&tag,sizeof(tag));
if ( (symbol= jstr(json,"coin")) != 0 ) if ( (symbol= jstr(json,"coin")) != 0 )
{ {
if ( (coin= iguana_coinfind(symbol)) != 0 && coin->launched == 0 ) coin = iguana_coinfind(symbol);
if ( coin != 0 && localaccess != 0 && coin->launched == 0 )
iguana_launchcoin(symbol,json); iguana_launchcoin(symbol,json);
} }
else coin = 0;
if ( (timeout= juint(json,"timeout")) == 0 ) if ( (timeout= juint(json,"timeout")) == 0 )
timeout = IGUANA_JSONTIMEOUT; timeout = IGUANA_JSONTIMEOUT;
if ( (retjsonstr= iguana_blockingjsonstr(coin,jsonstr,tag,timeout)) != 0 ) if ( (retjsonstr= iguana_blockingjsonstr(coin,jsonstr,tag,timeout)) != 0 )
@ -496,7 +498,7 @@ char *iguana_JSON(char *jsonstr)
return(retstr); return(retstr);
} }
void iguana_issuejsonstrM(void *arg) /*void iguana_issuejsonstrM(void *arg)
{ {
cJSON *json; int32_t fd; char *retjsonstr,*jsonstr = arg; cJSON *json; int32_t fd; char *retjsonstr,*jsonstr = arg;
retjsonstr = iguana_JSON(jsonstr); retjsonstr = iguana_JSON(jsonstr);
@ -512,7 +514,7 @@ void iguana_issuejsonstrM(void *arg)
printf("%s\n",retjsonstr); printf("%s\n",retjsonstr);
free(retjsonstr);//,strlen(retjsonstr)+1); free(retjsonstr);//,strlen(retjsonstr)+1);
free(jsonstr);//,strlen(jsonstr)+1); free(jsonstr);//,strlen(jsonstr)+1);
} }*/
void iguana_main(void *arg) void iguana_main(void *arg)
{ {
@ -563,11 +565,11 @@ void iguana_main(void *arg)
{ {
#ifdef __APPLE__ #ifdef __APPLE__
sleep(1); sleep(1);
iguana_JSON("{\"agent\":\"iguana\",\"method\":\"addcoin\",\"services\":0,\"maxpeers\":4,\"coin\":\"BTCD\",\"active\":1}"); iguana_JSON(iguana_coinfind("BTCD"),"{\"agent\":\"iguana\",\"method\":\"addcoin\",\"services\":0,\"maxpeers\":4,\"coin\":\"BTCD\",\"active\":1}",0);
#endif #endif
} }
if ( arg != 0 ) if ( arg != 0 )
iguana_JSON(arg); iguana_JSON(0,arg,0);
//init_InstantDEX(); //init_InstantDEX();
while ( 1 ) while ( 1 )
{ {

7
iguana/iguana_msg.c

@ -399,7 +399,7 @@ int32_t iguana_send_hashes(struct iguana_info *coin,char *command,struct iguana_
int32_t iguana_parser(struct iguana_info *coin,struct iguana_peer *addr,struct OS_memspace *rawmem,struct OS_memspace *txmem,struct OS_memspace *hashmem,struct iguana_msghdr *H,uint8_t *data,int32_t recvlen) int32_t iguana_parser(struct iguana_info *coin,struct iguana_peer *addr,struct OS_memspace *rawmem,struct OS_memspace *txmem,struct OS_memspace *hashmem,struct iguana_msghdr *H,uint8_t *data,int32_t recvlen)
{ {
uint8_t serialized[512]; uint8_t serialized[512]; char *retstr;
int32_t i,retval,srvmsg,bloom,intvectors,len= -100; uint64_t nonce,x; uint32_t type; bits256 hash2; int32_t i,retval,srvmsg,bloom,intvectors,len= -100; uint64_t nonce,x; uint32_t type; bits256 hash2;
bloom = intvectors = srvmsg = -1; bloom = intvectors = srvmsg = -1;
if ( addr != 0 ) if ( addr != 0 )
@ -412,6 +412,11 @@ int32_t iguana_parser(struct iguana_info *coin,struct iguana_peer *addr,struct O
if ( strcmp(H->command,"SuperNET") == 0 ) if ( strcmp(H->command,"SuperNET") == 0 )
{ {
printf("GOT.(%s) len.%d from %s\n",H->command,recvlen,addr->ipaddr); printf("GOT.(%s) len.%d from %s\n",H->command,recvlen,addr->ipaddr);
len = recvlen;
if ( (retstr= SuperNET_p2p(coin,addr->ipaddr,data,recvlen)) != 0 )
{
free(retstr); // dont respond immediate due to privacy
}
} }
else if ( strcmp(H->command,"version") == 0 ) else if ( strcmp(H->command,"version") == 0 )
{ {

11
iguana/iguana_rpc.c

@ -499,3 +499,14 @@ char *ramchain_parser(struct iguana_agent *agent,struct iguana_info *coin,char *
return(ramchain_coinparser(coin,method,json)); return(ramchain_coinparser(coin,method,json));
} }
char *SuperNET_p2p(struct iguana_info *coin,char *ipaddr,uint8_t *data,int32_t datalen)
{
cJSON *json; char *retstr = 0;
if ( (json= cJSON_Parse((char *)data)) != 0 )
{
printf("SUPERNET P2P.(%s)\n",(char *)data);
retstr = iguana_JSON(coin,(char *)data,ipaddr);
free_json(json);
}
return(retstr);
}

Loading…
Cancel
Save