mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-15 17:30:05 +00:00
131 lines
4.5 KiB
C
131 lines
4.5 KiB
C
|
#include <stdio.h>
|
||
|
#include <time.h>
|
||
|
#include <sys/types.h>
|
||
|
#include <sys/stat.h>
|
||
|
#include <fcntl.h>
|
||
|
#include <unistd.h>
|
||
|
#include <stdlib.h>
|
||
|
#include <strings.h>
|
||
|
#include <string.h>
|
||
|
|
||
|
#include "crypto_box_curve25519xsalsa20poly1305.h"
|
||
|
#include "crypto_sign_edwards25519sha512batch.h"
|
||
|
|
||
|
struct agent {
|
||
|
unsigned char box_pk[crypto_box_curve25519xsalsa20poly1305_PUBLICKEYBYTES];
|
||
|
unsigned char box_sk[crypto_box_curve25519xsalsa20poly1305_SECRETKEYBYTES];
|
||
|
|
||
|
unsigned char sign_pk[crypto_sign_edwards25519sha512batch_PUBLICKEYBYTES];
|
||
|
unsigned char sign_sk[crypto_sign_edwards25519sha512batch_SECRETKEYBYTES];
|
||
|
};
|
||
|
|
||
|
struct agent *newAgent()
|
||
|
{
|
||
|
struct agent *a;
|
||
|
|
||
|
a=calloc(sizeof(struct agent),1);
|
||
|
if (!a) { perror("calloc() failed"); exit(-3); }
|
||
|
|
||
|
// Generate keys required for various crypto functions.
|
||
|
|
||
|
if (crypto_box_curve25519xsalsa20poly1305_keypair(a->box_pk,a->box_sk))
|
||
|
{ fprintf(stderr,"crypto_box_curve25519xsalsa20poly1305_keypair() failed.\n"); exit(-1); }
|
||
|
|
||
|
if (crypto_sign_edwards25519sha512batch_keypair(a->sign_pk,a->sign_sk))
|
||
|
{ fprintf(stderr,"crypto_box_curve25519xsalsa20poly1305_keypair() failed.\n"); exit(-1); }
|
||
|
|
||
|
return a;
|
||
|
}
|
||
|
|
||
|
#define MESSAGE "Ketchup is a vegetable"
|
||
|
|
||
|
void dump(char *m,unsigned char *c,int l)
|
||
|
{
|
||
|
fprintf(stderr,"%s: (%d bytes)\n",m,l);
|
||
|
int i,j;
|
||
|
|
||
|
for(i=0;i<l;i+=16)
|
||
|
{
|
||
|
fprintf(stderr,"%06x:",i);
|
||
|
for(j=0;j<16;j++)
|
||
|
if ((i+j)<l) fprintf(stderr," %02x",c[i+j]); else fprintf(stderr," ");
|
||
|
fprintf(stderr," ");
|
||
|
for(j=0;j<16;j++)
|
||
|
if ((i+j)<l) {
|
||
|
unsigned char sanitised=c[i+j];
|
||
|
if (sanitised<' '||sanitised>0x7d) sanitised='.';
|
||
|
fprintf(stderr,"%c",sanitised);
|
||
|
}
|
||
|
fprintf(stderr,"\n");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
int main()
|
||
|
{
|
||
|
int r,i;
|
||
|
|
||
|
// Make Alice and Bob's keys
|
||
|
struct agent *alice = newAgent();
|
||
|
struct agent *bob = newAgent();
|
||
|
fprintf(stderr,"crypto_box_keypair() and crypto_sign_keypair() succeeded.\n");
|
||
|
|
||
|
// Make a handy nonce
|
||
|
char nonce[1024];
|
||
|
time_t t=time(0);
|
||
|
snprintf(nonce,1024,"%s",ctime(&t));
|
||
|
|
||
|
char plainTextIn[1024];
|
||
|
char cipherText[1024];
|
||
|
char plainTextOut[1024];
|
||
|
|
||
|
long long plainLenIn;
|
||
|
long long cipherLen;
|
||
|
long long plainLenOut;
|
||
|
|
||
|
/* Crypto box test */
|
||
|
bzero(&plainTextIn[0],crypto_box_curve25519xsalsa20poly1305_ZEROBYTES);
|
||
|
snprintf(&plainTextIn[crypto_box_curve25519xsalsa20poly1305_ZEROBYTES],1024-crypto_box_curve25519xsalsa20poly1305_ZEROBYTES,"%s",MESSAGE);
|
||
|
plainLenIn=crypto_box_curve25519xsalsa20poly1305_ZEROBYTES+strlen(MESSAGE)+1;
|
||
|
r=crypto_box_curve25519xsalsa20poly1305(cipherText,plainTextIn,plainLenIn,nonce,bob->box_pk,alice->box_sk);
|
||
|
dump("crypto_box plain text in",plainTextIn,plainLenIn);
|
||
|
dump("crypto_box cipher text",cipherText,plainLenIn);
|
||
|
if (r) { fprintf(stderr,"crypto_box() failed.\n"); exit(-1); }
|
||
|
fprintf(stderr,"crypto_box() call succeeded.\n");
|
||
|
|
||
|
bzero(&plainTextOut,1024); plainLenOut=0;
|
||
|
r=crypto_box_curve25519xsalsa20poly1305_open(plainTextOut,cipherText,plainLenIn,nonce,alice->box_pk,bob->box_sk);
|
||
|
dump("crypto_box recovered text",plainTextOut,plainLenIn);
|
||
|
if (r) { fprintf(stderr,"crypto_box_open() failed (r=%d).\n",r); exit(-1); }
|
||
|
fprintf(stderr,"crypto_box_open() call succeeded.\n");
|
||
|
|
||
|
cipherText[33]^=1;
|
||
|
bzero(&plainTextOut,1024); plainLenOut=0;
|
||
|
r=crypto_box_curve25519xsalsa20poly1305_open(plainTextOut,cipherText,plainLenIn,nonce,alice->box_pk,bob->box_sk);
|
||
|
if (!r) { fprintf(stderr,"crypto_box_open() failed to detect modification.\n",r); exit(-1); }
|
||
|
fprintf(stderr,"crypto_box_open() call succeeded in detecting modification.\n");
|
||
|
|
||
|
/* Crypto sign test */
|
||
|
snprintf(&plainTextIn[0],1024,"%s",MESSAGE);
|
||
|
plainLenIn=strlen(MESSAGE)+1;
|
||
|
r=crypto_sign_edwards25519sha512batch(cipherText,&cipherLen,plainTextIn,plainLenIn,alice->sign_sk);
|
||
|
dump("crypto_sign cipher text",cipherText,cipherLen);
|
||
|
if (r) { fprintf(stderr,"crypto_sign() failed.\n"); exit(-1); }
|
||
|
fprintf(stderr,"crypto_sign() call succeeded.\n");
|
||
|
|
||
|
bzero(&plainTextOut,1024); plainLenOut=0;
|
||
|
r=crypto_sign_edwards25519sha512batch_open(plainTextOut,&plainLenOut,cipherText,cipherLen,alice->sign_pk);
|
||
|
dump("crypto_sign recovered text",plainTextOut,plainLenOut);
|
||
|
if (r) { fprintf(stderr,"crypto_sign_open() failed (r=%d).\n",r); exit(-1); }
|
||
|
fprintf(stderr,"crypto_sign_open() call succeeded.\n");
|
||
|
|
||
|
cipherText[33]^=1;
|
||
|
bzero(&plainTextOut,1024); plainLenOut=0;
|
||
|
r=crypto_sign_edwards25519sha512batch_open(plainTextOut,&plainLenOut,cipherText,cipherLen,alice->sign_pk);
|
||
|
if (!r) { fprintf(stderr,"crypto_sign_open() failed to detect modification.\n",r); exit(-1); }
|
||
|
fprintf(stderr,"crypto_sign_open() call succeeded in detecting modification.\n");
|
||
|
|
||
|
|
||
|
|
||
|
return 0;
|
||
|
}
|