/* delimited, authenticated, encrypted connection */ enum{ Maxmsg=4096 }; /* messages > Maxmsg bytes are truncated */ typedef struct SConn SConn; extern SConn* newSConn(int); /* arg is open file descriptor */ struct SConn{ void *chan; int secretlen; int (*secret)(SConn*, uchar*, int);/* */ int (*read)(SConn*, uchar*, int); /* <0 if error; errmess in buffer */ int (*write)(SConn*, uchar*, int); void (*free)(SConn*); /* also closes file descriptor */ }; /* secret(s,b,dir) sets secret for digest, encrypt, using the secretlen */ /* bytes in b to form keys for the two directions; */ /* set dir=0 in client, dir=1 in server */ /* error convention: write !message in-band */ extern void writerr(SConn*, char*); extern int readstr(SConn*, char*); /* call with buf of size Maxmsg+1 */ /* returns -1 upon error, with error message in buf */ extern void *emalloc(ulong); /* dies on failure; clears memory */ extern void *erealloc(void *, ulong); extern char *estrdup(char *);