X-Git-Url: http://www.average.org/gitweb/?p=pam_pcsc_cr.git;a=blobdiff_plain;f=authobj.h;h=b0756542671a0f68ff759e4d8b582b9c58283757;hp=c2da50450adb4b13858de0b9ab1bb68c30bf626c;hb=88e11a960fb7287c3c5f542cd5199cc899f137f2;hpb=8e164eeff8c7d7f08b473d37ebb01093f574d6a2 diff --git a/authobj.h b/authobj.h index c2da504..b075654 100644 --- a/authobj.h +++ b/authobj.h @@ -1,13 +1,30 @@ #ifndef _AUTHOBJ_H #define _AUTHOBJ_H -int make_authobj(const char *id, const char *pass, const char *nonce, - const unsigned char *secret, const int secsize, - const unsigned char *payload, const int paysize, - unsigned char *buffer, int *bufsize); -int parse_authobj(const unsigned char *hmacdata, const int hmacdatasize, - const unsigned char *buffer, const int bufsize, - unsigned char *secret, int *secsize, - unsigned char *payload, int *paysize); +struct _auth_obj { + unsigned char *buffer; /* to be free()'d if not NULL */ + const char *err; /* non-NULL if failed */ + unsigned char *authobj; + int authsize; + unsigned char *payload; + int paylsize; +}; + +/* Construct new authobj from the given secret and other data */ +struct _auth_obj new_authobj(const char *userid, const char *password, + const char *nonce, + const unsigned char *secret, const int secsize, + const unsigned char *payload, const int paysize); + +/* Unwrap old authobj, extract payload, construct new one with newnonce */ +struct _auth_obj verify_authobj(const char *userid, const char *password, + const char *oldnonce, const char *newnonce, + const unsigned char *authobj, const int authsize); + +/* Unwrap old authobj, replace the payload, construct new one with newnonce */ +struct _auth_obj reload_authobj(const char *userid, const char *password, + const char *oldnonce, const char *newnonce, + const unsigned char *authobj, const int authsize, + const unsigned char *payload, const int paysize); #endif