Merge pull request #6 from xethyrion/master

Misc fixes
This commit is contained in:
John M. Jones 2017-02-22 00:50:24 -05:00 committed by GitHub
commit ba234206a2
4 changed files with 65 additions and 32 deletions

View file

@ -5,32 +5,30 @@ multiaddr for IPFS in C.
# Usage: # Usage:
#### All you need to include is multiaddr.h #### All you need to include is multiaddr.h
## Maddr struct: ## Maddr struct:
* char string[]; // String that contains addresses such as /ip4/192.168.1.1/ * char * string; // String that contains addresses such as /ip4/192.168.1.1/
* uint8_t bytes; //String that contains the enecoded address * uint8_t * bytes; // uint8_t * that contains the enecoded address
* int bsize[]; //int[1] that contains the real bytes size (Use it whenever using the bytes so you don't input trash!) * size_t bsize; //size_t that contains the real bytes size (Use it whenever using the bytes so you don't input trash!)
## New Multi Address From String(new_maddr_fs) ## New Multi Address From String(multiaddress_new_from_string)
char addrstr[] = "/ip4/192.168.1.1/" struct MultiAddress* a = multiaddress_new_from_string("/ip4/127.0.0.1/tcp/8080/");
struct maddr a;
a=new_maddr_fs(addrstr);
## Obtaining the byte buffer(.bytes, .bsize[0]): ## Obtaining the byte buffer(.bytes, .bsize[0]):
printf("TEST BYTES: %s\n",Var_To_Hex(a.bsize[0], a.bytes)); printf("TEST BYTES: %s\n",Var_To_Hex(a->bsize, a->bytes));
Var_To_Hex = Byte Buffer to Hex String Var_To_Hex = Byte Buffer to Hex String
Hex_To_Var = Hex String to Byte Buffer Hex_To_Var = Hex String to Byte Buffer
## Encapsulation & Decapsulation(m_encapsulate, m_decapsulate) ## Encapsulation & Decapsulation(m_encapsulate, m_decapsulate)
#### Remember, Decapsulation happens from right to left, never in reverse, if you have /ip4/udp/ipfs/ if you decapsulate "udp" you will also take out ipfs! #### Remember, Decapsulation happens from right to left, never in reverse, if you have /ip4/udp/ipfs/ if you decapsulate "udp" you will also take out ipfs!
* Now the string is: /ip4/192.168.1.1/ * Now the string is: /ip4/192.168.1.1/
* m_encapsulate(&a,"/udp/3333/"); //Adds udp/3333/ to char addrstr * multiaddress_encapsulate(a,"/udp/3333/"); //Adds udp/3333/
* Now the string is: /ip4/192.168.1.1/udp/3333/ * Now the string is: /ip4/192.168.1.1/udp/3333/
* m_decapsulate(&a,"udp"); //Removes udp protocol and its address * multiaddress_decapsulate(a,"udp"); //Removes udp protocol and its address
* Now the string is: /ip4/192.168.1.1/ * Now the string is: /ip4/192.168.1.1/
* m_encapsulate(&a,"/tcp/8080"); * multiaddress_encapsulate(a,"/tcp/8080");
* Now the string is: /ip4/192.168.1.1/tcp/8080/ * Now the string is: /ip4/192.168.1.1/tcp/8080/
# Constructing a multiaddress from bytes: # Constructing a multiaddress from bytes:
* struct maddr beta; * struct MultiAddress* beta;
* beta=new_maddr_fb(a.bytes,a.bsize[0]); //This will already construct back to the string too! * beta = multiaddress_new_from_bytes(a->bytes,a->bsize); //This will already construct back to the string too!
* printf("B STRING: %s\n",beta.string); //So after encapsulation and decapsulation atm this string would * printf("B STRING: %s\n",beta->string); //So after encapsulation and decapsulation atm this string would
* contain: /ip4/192.168.1.1/tcp/8080/ * contain: /ip4/192.168.1.1/tcp/8080/

View file

@ -141,15 +141,34 @@ int multiaddress_encapsulate(struct MultiAddress* result, char* string)
free(result->bytes); free(result->bytes);
result->bytes = NULL; result->bytes = NULL;
result->bsize = 0; result->bsize = 0;
char * exstr;
if(string[0] == '/')
{
exstr = (char *) malloc(strlen(result->string)+1);
}
else
{
exstr = (char *) malloc(strlen(result->string));
}
strcpy(exstr, result->string);
free(result->string); free(result->string);
// insert the new values // insert the new values
result->string = malloc(strlen(string) + 1); result->string = malloc(strlen(string) + strlen(exstr) + 1);
if (result->string == NULL) { if (result->string == NULL) {
multiaddress_free(result); multiaddress_free(result);
return 0; return 0;
} }
strcpy(result->string, string); strcpy(result->string, exstr);
if(string_to_bytes(&result->bytes, &result->bsize, result->string, sizeof(result->string)) == 0) free(exstr);
if(string[0] == '/')
{
strcat(result->string, string+1);
}
else
{
strcat(result->string, string);
}
if(string_to_bytes(&result->bytes, &result->bsize, result->string, strlen(result->string)+1) == 0)
{ {
multiaddress_free(result); multiaddress_free(result);
return 0; return 0;
@ -196,6 +215,16 @@ int multiaddress_decapsulate(struct MultiAddress * result, char * srci)
procstr[i] = '/'; procstr[i] = '/';
} }
} }
//Bytes update
if (result->bytes != NULL)
free(result->bytes);
result->bytes = NULL;
result->bsize = 0;
if(string_to_bytes(&result->bytes, &result->bsize, result->string, strlen(result->string)+1) == 0)
{
multiaddress_free(result);
return 0;
}
return 1; return 1;
} }
else else

View file

@ -314,15 +314,18 @@ int bytes_to_string(char** buffer, const uint8_t* in_bytes, int in_bytes_size)
int lastpos = 0; int lastpos = 0;
char pid[3]; char pid[3];
//Process Hex String //Process Hex String
//printf("FULL HEX: %s", hex);
NAX: NAX:
//printf("REDO!!!!!\n");
//Stage 1 ID: //Stage 1 ID:
if(lastpos!=0) if(lastpos!=0)
{ {
lastpos++; //lastpos++;
} }
pid[0] = hex[lastpos]; pid[0] = hex[lastpos];
pid[1] = hex[lastpos+1]; pid[1] = hex[lastpos+1];
pid[2] = '\0'; pid[2] = '\0';
//printf("pid: %s\n",pid);
if(proto_with_deccode(head, Hex_To_Int(pid))) if(proto_with_deccode(head, Hex_To_Int(pid)))
{ {
//////////Stage 2: Address //////////Stage 2: Address
@ -347,7 +350,7 @@ int bytes_to_string(char** buffer, const uint8_t* in_bytes, int in_bytes_size)
//printf("Protocol: %s\n", PID->name); //printf("Protocol: %s\n", PID->name);
//printf("Address : %s\n", address); //printf("Address : %s\n", address);
lastpos= lastpos+(PID->size/4); lastpos= lastpos+(PID->size/4);
//printf("lastpos: %d",lastpos); //printf("lastpos: %d\n",lastpos);
//////////Address: //////////Address:
//Keeping Valgrind happy //Keeping Valgrind happy
@ -416,7 +419,7 @@ int bytes_to_string(char** buffer, const uint8_t* in_bytes, int in_bytes_size)
unsigned char * pointyaddr = NULL; unsigned char * pointyaddr = NULL;
pointyaddr = rezultat; pointyaddr = rezultat;
int returnstatus = 0; int returnstatus = 0;
returnstatus = multiaddr_encoding_base58_encode(addrbuf, sizeof(addrbuf), &pointyaddr, &rezbuflen); returnstatus = multiaddr_encoding_base58_encode(addrbuf, sizeof(IPFS_ADDR)/2, &pointyaddr, &rezbuflen);
free(addrbuf); free(addrbuf);
if(returnstatus == 0) if(returnstatus == 0)
{ {
@ -566,16 +569,15 @@ char * address_string_to_bytes(struct Protocol * xx, const char * abc,size_t get
} }
case 42://IPFS - !!! case 42://IPFS - !!!
{ {
char * x_data = NULL; char * x_data = NULL;
x_data = (char*) abc; x_data = (char*) abc;
size_t x_data_length = strlen(x_data); size_t x_data_length = strlen(x_data);
size_t result_buffer_length = multiaddr_encoding_base58_decode_size((unsigned char*)x_data); size_t result_buffer_length = multiaddr_encoding_base58_decode_max_size((unsigned char*)x_data);
unsigned char result_buffer[result_buffer_length]; unsigned char result_buffer[result_buffer_length];
unsigned char* ptr_to_result = result_buffer; unsigned char* ptr_to_result = result_buffer;
memset(result_buffer, 0, result_buffer_length); memset(result_buffer, 0, result_buffer_length);
// now get the decoded address // now get the decoded address
int return_value = multiaddr_encoding_base58_decode(x_data, x_data_length, &ptr_to_result, &result_buffer_length); int return_value = multiaddr_encoding_base58_decode(x_data, x_data_length, &ptr_to_result, &result_buffer_length);
if (return_value == 0) if (return_value == 0)
{ {
@ -594,7 +596,7 @@ char * address_string_to_bytes(struct Protocol * xx, const char * abc,size_t get
unsigned char c = ptr_to_result[i]; unsigned char c = ptr_to_result[i];
char miu[3]; char miu[3];
bzero(miu, 3); bzero(miu, 3);
miu[3] = '\0'; miu[2] = '\0';
sprintf(miu,"%02x", c); sprintf(miu,"%02x", c);
strcat(ADDR_ENCODED, miu); strcat(ADDR_ENCODED, miu);
@ -602,7 +604,7 @@ char * address_string_to_bytes(struct Protocol * xx, const char * abc,size_t get
ilen = strlen(ADDR_ENCODED); ilen = strlen(ADDR_ENCODED);
char prefixed[3]; char prefixed[3];
strcpy(prefixed,Num_To_HexVar_32(ilen)); strcpy(prefixed,Num_To_HexVar_32(ilen));
prefixed[3] = '\0'; prefixed[2] = '\0';
strcat(returning_result, prefixed); strcat(returning_result, prefixed);
strcat(returning_result, ADDR_ENCODED); strcat(returning_result, ADDR_ENCODED);
//printf("ADDRESS: %s\nSIZEADDR: %d\n",ADDR_ENCODED,ilen); //printf("ADDRESS: %s\nSIZEADDR: %d\n",ADDR_ENCODED,ilen);

View file

@ -15,7 +15,7 @@ int test_new_from_string() {
int test_full() { int test_full() {
char addrstr[100]; char addrstr[100];
strcpy(addrstr,"/ip4/192.168.1.1/tcp/8080/"); strcpy(addrstr,"/ip4/192.168.1.1/");
printf("INITIAL: %s\n",addrstr); printf("INITIAL: %s\n",addrstr);
struct MultiAddress* a; struct MultiAddress* a;
a= multiaddress_new_from_string(addrstr); a= multiaddress_new_from_string(addrstr);
@ -24,14 +24,18 @@ int test_full() {
//Remember, Decapsulation happens from right to left, never in reverse! //Remember, Decapsulation happens from right to left, never in reverse!
printf("A STRING:%s\n",a->string); printf("A STRING:%s\n",a->string);
multiaddress_encapsulate(a,"/ip4/192.131.200.111/udp/3333/"); multiaddress_encapsulate(a,"/udp/3333/");
printf("A STRING ENCAPSULATED:%s\n",a->string); printf("A STRING ENCAPSULATED:%s\n",a->string);
printf("TEST BYTES: %s\n",Var_To_Hex(a->bsize, a->bytes));
multiaddress_decapsulate(a,"udp"); multiaddress_decapsulate(a,"udp");
printf("A STRING DECAPSULATED UDP:%s\n",a->string); printf("A STRING DECAPSULATED UDP:%s\n",a->string);
printf("TEST BYTES: %s\n",Var_To_Hex(a->bsize, a->bytes));
multiaddress_encapsulate(a,"/tcp/8080"); multiaddress_encapsulate(a,"/udp/3333/");
printf("A STRING ENCAPSULATED TCP:%s\n",a->string); printf("A STRING ENCAPSULATED UDP: %s\n",a->string);
multiaddress_encapsulate(a,"/ipfs/QmYwAPJzv5CZsnA625s3Xf2nemtYgPpHdWEz79ojWnPbdG");
printf("A STRING ENCAPSULATED IPFS:%s\n",a->string);
printf("TEST BYTES: %s\n",Var_To_Hex(a->bsize, a->bytes));
printf("TEST BYTE SIZE: %u\n",a->bsize);
struct MultiAddress* beta; struct MultiAddress* beta;
beta = multiaddress_new_from_bytes(a->bytes,a->bsize); beta = multiaddress_new_from_bytes(a->bytes,a->bsize);