|
|
@ -2,6 +2,8 @@ |
|
|
|
|
|
|
|
|
typedef enum memberstate { |
|
|
typedef enum memberstate { |
|
|
ON, |
|
|
ON, |
|
|
|
|
|
ISSUERPUB, |
|
|
|
|
|
RCVPUBLIC, |
|
|
JOIN, |
|
|
JOIN, |
|
|
APPEND, |
|
|
APPEND, |
|
|
JOINPROCEED, |
|
|
JOINPROCEED, |
|
|
@ -17,18 +19,24 @@ typedef struct member { |
|
|
uint8_t nonce[NONCE_SIZE]; |
|
|
uint8_t nonce[NONCE_SIZE]; |
|
|
struct ecdaa_credential_FP256BN cred; |
|
|
struct ecdaa_credential_FP256BN cred; |
|
|
struct ecdaa_credential_FP256BN_signature cred_sig; |
|
|
struct ecdaa_credential_FP256BN_signature cred_sig; |
|
|
|
|
|
struct ecdaa_issuer_public_key_FP256BN ipk; |
|
|
} member_t; |
|
|
} member_t; |
|
|
|
|
|
|
|
|
member_t member; |
|
|
member_t member; |
|
|
|
|
|
|
|
|
int member_join(char* buffer); |
|
|
int member_join(char *buffer); |
|
|
int member_attest(char* buffer); |
|
|
|
|
|
int member_publish(char* buffer); |
|
|
int member_attest(char *buffer); |
|
|
int member_joinappend(char* buffer); |
|
|
|
|
|
int member_joinfinish(char* buffer); |
|
|
int member_publish(char *buffer); |
|
|
|
|
|
|
|
|
|
|
|
int member_getpublic(char *buffer); |
|
|
|
|
|
|
|
|
|
|
|
int member_joinappend(char *buffer); |
|
|
|
|
|
|
|
|
|
|
|
int member_joinfinish(char *buffer); |
|
|
|
|
|
|
|
|
int main() { |
|
|
int main() { |
|
|
int err = 0; |
|
|
|
|
|
|
|
|
|
|
|
if (2 != server_start(&process_member, MEMBERPORT)) { |
|
|
if (2 != server_start(&process_member, MEMBERPORT)) { |
|
|
printf("server failed\n"); |
|
|
printf("server failed\n"); |
|
|
@ -41,18 +49,26 @@ int process_member(char *buffer) { |
|
|
|
|
|
|
|
|
printf("> MEMBER: %s\n", buffer); |
|
|
printf("> MEMBER: %s\n", buffer); |
|
|
|
|
|
|
|
|
if (0 == strncasecmp("ATTEST", buffer, 6)) { |
|
|
if (member.state == JOINED && 0 == strncasecmp("ATTEST", buffer, 6)) { |
|
|
printf("attest()\n"); |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
strncpy(buffer, "ATTEST ", 7); |
|
|
strncpy(buffer, "ATTEST ", 7); |
|
|
member_attest(buffer); |
|
|
member_attest(buffer); |
|
|
|
|
|
} else if (member.state == ON && 0 == strncasecmp("GETPUBLIC", buffer, 9)) { |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
ret = client_connect(&member_getpublic, ISSUERIP, ISSUERPORT); |
|
|
|
|
|
if (0 >= ret || RCVPUBLIC != member.state) { |
|
|
|
|
|
printf("process_member: issuer connection failed\n"); |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
strncpy(buffer, "ERR\n", 4); |
|
|
|
|
|
} else { |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
strncpy(buffer, "OK\n", 3); |
|
|
|
|
|
} |
|
|
|
|
|
ret = 0; |
|
|
} else if (0 == strncasecmp("PUBLISH", buffer, 7)) { |
|
|
} else if (0 == strncasecmp("PUBLISH", buffer, 7)) { |
|
|
printf("publish()\n"); |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
strncpy(buffer, "PUBLISH ", 8); |
|
|
|
|
|
member_publish(buffer); |
|
|
member_publish(buffer); |
|
|
} else if (member.state != JOINED && 0 == strncasecmp("JOIN", buffer, 4)) { |
|
|
} else if (member.state == RCVPUBLIC && 0 == strncasecmp("JOIN", buffer, 4)) { |
|
|
printf("join()\n"); |
|
|
|
|
|
member.state = JOIN; |
|
|
member.state = JOIN; |
|
|
ret = client_connect(&member_join, ISSUERIP, ISSUERPORT); |
|
|
ret = client_connect(&member_join, ISSUERIP, ISSUERPORT); |
|
|
if (0 >= ret || JOINED != member.state) { |
|
|
if (0 >= ret || JOINED != member.state) { |
|
|
@ -65,7 +81,6 @@ int process_member(char *buffer) { |
|
|
} |
|
|
} |
|
|
ret = 0; |
|
|
ret = 0; |
|
|
} else if (0 == strncasecmp("EXIT", buffer, 4)) { |
|
|
} else if (0 == strncasecmp("EXIT", buffer, 4)) { |
|
|
printf("exit()\n"); |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
strncpy(buffer, "OK\n", 3); |
|
|
strncpy(buffer, "OK\n", 3); |
|
|
ret = 1; |
|
|
ret = 1; |
|
|
@ -74,7 +89,6 @@ int process_member(char *buffer) { |
|
|
strncpy(buffer, "OK\n", 3); |
|
|
strncpy(buffer, "OK\n", 3); |
|
|
ret = 2; |
|
|
ret = 2; |
|
|
} else { |
|
|
} else { |
|
|
printf("error()\n"); |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
strncpy(buffer, "ERR\n", 4); |
|
|
strncpy(buffer, "ERR\n", 4); |
|
|
ret = 0; |
|
|
ret = 0; |
|
|
@ -87,7 +101,6 @@ int process_member(char *buffer) { |
|
|
int member_join(char *buffer) { |
|
|
int member_join(char *buffer) { |
|
|
int ret = 0; |
|
|
int ret = 0; |
|
|
|
|
|
|
|
|
printf("ISSUER > MEMBER: %s", buffer); |
|
|
|
|
|
switch (member.state) { |
|
|
switch (member.state) { |
|
|
case JOIN: |
|
|
case JOIN: |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
@ -96,46 +109,99 @@ int member_join(char *buffer) { |
|
|
break; |
|
|
break; |
|
|
case APPEND: |
|
|
case APPEND: |
|
|
if (0 == strncasecmp("JOINSTART", buffer, 9)) { |
|
|
if (0 == strncasecmp("JOINSTART", buffer, 9)) { |
|
|
|
|
|
printf("ISSUER > MEMBER: %s", buffer); |
|
|
member_joinappend(buffer); |
|
|
member_joinappend(buffer); |
|
|
member.state = JOINPROCEED; |
|
|
member.state = JOINPROCEED; |
|
|
} |
|
|
} |
|
|
break; |
|
|
break; |
|
|
case JOINPROCEED: |
|
|
case JOINPROCEED: |
|
|
if (0 == strncasecmp("JOINPROCEED", buffer, 11)) { |
|
|
if (0 == strncasecmp("JOINPROCEED", buffer, 11)) { |
|
|
|
|
|
printf("ISSUER > MEMBER: %s", buffer); |
|
|
member_joinfinish(buffer); |
|
|
member_joinfinish(buffer); |
|
|
member.state = JOINED; |
|
|
member.state = JOINED; |
|
|
ret = 1; |
|
|
ret = 1; |
|
|
} |
|
|
} |
|
|
break; |
|
|
break; |
|
|
default: |
|
|
default: |
|
|
ret -1; |
|
|
ret - 1; |
|
|
} |
|
|
} |
|
|
if(0 == ret) { |
|
|
if (0 == ret) { |
|
|
printf("ISSUER < MEMBER: %s", buffer); |
|
|
printf("ISSUER < MEMBER: %s", buffer); |
|
|
} |
|
|
} |
|
|
return ret; |
|
|
return ret; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
int member_attest(char* buffer) { |
|
|
int member_getpublic(char *buffer) { |
|
|
|
|
|
int ret = 0; |
|
|
|
|
|
|
|
|
|
|
|
switch (member.state) { |
|
|
|
|
|
case ON: |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
strncpy(buffer, "PUBLISH\n", 8); |
|
|
|
|
|
member.state = ISSUERPUB; |
|
|
|
|
|
break; |
|
|
|
|
|
case ISSUERPUB: |
|
|
|
|
|
if (0 == strncasecmp("PUBLISH", buffer, 7)) { |
|
|
|
|
|
printf("ISSUER > MEMBER: %s", buffer); |
|
|
|
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
|
|
|
char *current = &buffer[8]; |
|
|
|
|
|
ecdaa_hextobin(current, binbuf, ECDAA_ISSUER_PUBLIC_KEY_FP256BN_LENGTH); |
|
|
|
|
|
ret = ecdaa_issuer_public_key_FP256BN_deserialize(&member.ipk, binbuf); |
|
|
|
|
|
if (-1 == ret) { |
|
|
|
|
|
printf("member_getpublic: issuer public key is malformed!\n"); |
|
|
|
|
|
ret = -1; |
|
|
|
|
|
} else if (-2 == ret) { |
|
|
|
|
|
printf("member_getpublic: signature of issuer public key is invalid\n"); |
|
|
|
|
|
ret = -1; |
|
|
|
|
|
} else { |
|
|
|
|
|
member.state = RCVPUBLIC; |
|
|
|
|
|
ret = 1; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
break; |
|
|
|
|
|
default: |
|
|
|
|
|
ret = -1; |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
if (0 == ret) { |
|
|
|
|
|
printf("ISSUER < MEMBER: %s", buffer); |
|
|
|
|
|
} |
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//"ATTEST" > "ATTEST <attestval>"
|
|
|
|
|
|
int member_attest(char *buffer) { |
|
|
strncat(buffer, "<attestval>\n", 13); |
|
|
strncat(buffer, "<attestval>\n", 13); |
|
|
return 0; |
|
|
return 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//"PUBLISH" > "PUBLISH <member.mpk>"
|
|
|
//"PUBLISH" > "PUBLISH <member.mpk>"
|
|
|
int member_publish(char* buffer) { |
|
|
int member_publish(char *buffer) { |
|
|
strncat(buffer, "<publicval>\n", 12); |
|
|
char *current; |
|
|
|
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
|
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
|
|
|
|
|
|
strncpy(buffer, "PUBLISH ", 8); |
|
|
|
|
|
|
|
|
|
|
|
current = &buffer[8]; |
|
|
|
|
|
bzero(binbuf, MAX_BUFSIZE); |
|
|
|
|
|
ecdaa_member_public_key_FP256BN_serialize(binbuf, &member.mpk); |
|
|
|
|
|
ecdaa_bintohex(binbuf, ECDAA_MEMBER_PUBLIC_KEY_FP256BN_LENGTH, current); |
|
|
|
|
|
|
|
|
|
|
|
buffer[2 * ECDAA_MEMBER_PUBLIC_KEY_FP256BN_LENGTH + 8] = '\n'; |
|
|
|
|
|
|
|
|
return 0; |
|
|
return 0; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//"JOINSTART <issuer.nonce>" > "APPEND <member.mpk>"
|
|
|
//"JOINSTART <issuer.nonce>" > "APPEND <member.mpk>"
|
|
|
int member_joinappend(char* buffer) { |
|
|
int member_joinappend(char *buffer) { |
|
|
char *current = &buffer[10]; |
|
|
char *current = &buffer[10]; |
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
ecdaa_hextobin(current, member.nonce, NONCE_SIZE); |
|
|
ecdaa_hextobin(current, member.nonce, NONCE_SIZE); |
|
|
|
|
|
|
|
|
if (0 != ecdaa_member_key_pair_FP256BN_generate(&member.mpk, &member.msk, member.nonce, NONCE_SIZE, ecdaa_rand)) { |
|
|
if (0 != ecdaa_member_key_pair_FP256BN_generate(&member.mpk, &member.msk, member.nonce, NONCE_SIZE, ecdaa_rand)) { |
|
|
fprintf(stderr, "Error generating member key-pair\n"); |
|
|
fprintf(stderr, "Error generating member key-pair\n"); |
|
|
return 1; |
|
|
return -1; |
|
|
} |
|
|
} |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
strncpy(buffer, "APPEND ", 7); |
|
|
strncpy(buffer, "APPEND ", 7); |
|
|
@ -148,12 +214,25 @@ int member_joinappend(char* buffer) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
//"JOINPROCEED <member.cred><member.cred_sig>" > ""
|
|
|
//"JOINPROCEED <member.cred><member.cred_sig>" > ""
|
|
|
int member_joinfinish(char* buffer) { |
|
|
int member_joinfinish(char *buffer) { |
|
|
char *current = &buffer[12]; |
|
|
char *current = &buffer[12]; |
|
|
|
|
|
uint8_t *bincur; |
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
uint8_t binbuf[MAX_BUFSIZE]; |
|
|
ecdaa_credential_FP256BN_deserialize(binbuf, &member.cred); |
|
|
int ret = 0; |
|
|
current = &buffer[12 + 2 * ECDAA_CREDENTIAL_FP256BN_LENGTH]; |
|
|
bzero(binbuf, MAX_BUFSIZE); |
|
|
//ecdaa_credential_FP256BN_signature_deserialize(current, &member.cred_sig);
|
|
|
ecdaa_hextobin(current, binbuf, ECDAA_CREDENTIAL_FP256BN_LENGTH); |
|
|
bzero(buffer, MAX_BUFSIZE); |
|
|
|
|
|
return 0; |
|
|
current = &buffer[12 + 2 * ECDAA_CREDENTIAL_FP256BN_LENGTH + 1]; |
|
|
|
|
|
bincur = &binbuf[ECDAA_CREDENTIAL_FP256BN_LENGTH]; |
|
|
|
|
|
ecdaa_hextobin(current, bincur, ECDAA_CREDENTIAL_FP256BN_SIGNATURE_LENGTH); |
|
|
|
|
|
ret = ecdaa_credential_FP256BN_deserialize_with_signature(&member.cred, &member.mpk, &member.ipk.gpk, binbuf, bincur); |
|
|
|
|
|
if(-1 == ret) { |
|
|
|
|
|
printf("member_joinfinish: credential is malformed!\n"); |
|
|
|
|
|
ret = -1; |
|
|
|
|
|
} else if(-2 == ret) { |
|
|
|
|
|
printf("member_joinfinish: siganture of credential is invalid"); |
|
|
|
|
|
ret = -1; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return ret; |
|
|
} |
|
|
} |