/* $NetBSD: skey.h,v 1.10 2016/01/22 23:25:51 dholland Exp $ */ /* * S/KEY v1.1b (skey.h) * * Authors: * Neil M. Haller * Philip R. Karn * John S. Walden * * Modifications: * Scott Chasin * Todd C. Miller * * Main client header */ #include /* Server-side data structure for reading keys file during login */ struct skey { FILE *keyfile; char buf[256]; char *logname; int n; char *seed; char *val; long recstart; /* needed so reread of buffer is efficient */ }; /* Client-side structure for scanning data stream for challenge */ struct mc { char buf[256]; int skip; int cnt; }; /* Maximum sequence number we allow */ #ifndef SKEY_MAX_SEQ #define SKEY_MAX_SEQ 10000 #endif /* Minimum secret password length (rfc2289) */ #ifndef SKEY_MIN_PW_LEN #define SKEY_MIN_PW_LEN 10 #endif /* Max secret password length (rfc2289 says 63 but allows more) */ #ifndef SKEY_MAX_PW_LEN #define SKEY_MAX_PW_LEN 255 #endif /* Max length of an S/Key seed (rfc2289) */ #ifndef SKEY_MAX_SEED_LEN #define SKEY_MAX_SEED_LEN 16 #endif /* Max length of S/Key challenge (otp-???? 9999 seed) */ #ifndef SKEY_MAX_CHALLENGE #define SKEY_MAX_CHALLENGE (11 + SKEY_MAX_HASHNAME_LEN + SKEY_MAX_SEED_LEN) #endif /* Max length of hash algorithm name (md4/md5/sha1/rmd160) */ #define SKEY_MAX_HASHNAME_LEN 6 /* Size of a binary key (not NULL-terminated) */ #define SKEY_BINKEY_SIZE 8 /* Location of random file for bogus challenges */ #define _SKEY_RAND_FILE_PATH_ "/var/db/host.random" /* Prototypes */ void f(char *); int keycrunch(char *, const char *, const char *); char *btoe(char *, const char *); char *put8(char *, const char *); int etob(char *, const char *); void rip(char *); int skeychallenge(struct skey *, const char *, char *, size_t); int skeylookup(struct skey *, const char *); int skeyverify(struct skey *, char *); void sevenbit(char *); void backspace(char *); const char *skipspace(const char *); char *readpass(char *, int); char *readskey(char *, int); int skey_authenticate(const char *); int skey_passcheck(const char *, char *); const char *skey_keyinfo(const char *); int skey_haskey(const char *); int getskeyprompt(struct skey *, char *, char *); int atob8(char *, const char *); int btoa8(char *, const char *); int htoi(int); const char *skey_get_algorithm(void); const char *skey_set_algorithm(const char *); int skeygetnext(struct skey *); int skeyzero(struct skey *, char *);