ref: 8173223f439546685f0cc4471efc9a9d12fccf4c
dir: /sys/src/cmd/auth/lib/readwrite.c/
#include <u.h> #include <libc.h> #include <authsrv.h> #include <bio.h> #include "authcmdlib.h" int readfile(char *file, char *buf, int n) { int fd; fd = open(file, OREAD); if(fd < 0){ werrstr("%s: %r", file); return -1; } n = read(fd, buf, n); close(fd); return n; } int writefile(char *file, char *buf, int n) { int fd; fd = open(file, OWRITE); if(fd < 0) return -1; n = write(fd, buf, n); close(fd); return n; } char* finddeskey(char *db, char *user, char *key) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/key", db, user); n = readfile(filename, key, DESKEYLEN); if(n != DESKEYLEN) return nil; else return key; } uchar* findaeskey(char *db, char *user, uchar *key) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/aeskey", db, user); n = readfile(filename, (char*)key, AESKEYLEN); if(n != AESKEYLEN) return nil; else return key; } int findkey(char *db, char *user, Authkey *key) { int ret; memset(key, 0, sizeof(Authkey)); ret = findaeskey(db, user, key->aes) != nil; if(ret){ char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/pakhash", db, user); if(readfile(filename, (char*)key->pakhash, PAKHASHLEN) != PAKHASHLEN) authpak_hash(key, user); } ret |= finddeskey(db, user, key->des) != nil; return ret; } char* findsecret(char *db, char *user, char *secret) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/secret", db, user); n = readfile(filename, secret, SECRETLEN-1); secret[n]=0; if(n <= 0) return nil; else return secret; } char* setdeskey(char *db, char *user, char *key) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/key", db, user); n = writefile(filename, key, DESKEYLEN); if(n != DESKEYLEN) return nil; else return key; } uchar* setaeskey(char *db, char *user, uchar *key) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/aeskey", db, user); n = writefile(filename, (char*)key, AESKEYLEN); if(n != AESKEYLEN) return nil; else return key; } int setkey(char *db, char *user, Authkey *key) { int ret; ret = setdeskey(db, user, key->des) != nil; ret |= setaeskey(db, user, key->aes) != nil; return ret; } char* setsecret(char *db, char *user, char *secret) { int n; char filename[Maxpath]; snprint(filename, sizeof filename, "%s/%s/secret", db, user); n = writefile(filename, secret, strlen(secret)); if(n != strlen(secret)) return nil; else return secret; }