server/src/util/password.c

40 lines
1,004 B
C
Raw Normal View History

#ifdef _MSC_VER
#include <platform.h>
#endif
#include "password.h"
#include "crypto/bcrypt.h"
#include <assert.h>
#include <string.h>
#include <stdio.h>
bool password_is_implemented(cryptalgo_t algo) {
if (algo == PASSWORD_BCRYPT) return true;
2016-07-13 19:10:22 +02:00
return algo == PASSWORD_PLAINTEXT;
}
const char * password_encode(const char * passwd, cryptalgo_t algo) {
if (algo == PASSWORD_BCRYPT) {
char salt[BCRYPT_HASHSIZE];
static char hash[BCRYPT_HASHSIZE];
int ret;
bcrypt_gensalt(12, salt);
ret = bcrypt_hashpw(passwd, salt, hash);
assert(ret == 0);
return hash;
}
2016-07-13 19:10:22 +02:00
return passwd;
}
int password_verify(const char * pwhash, const char * passwd) {
if (pwhash[0] == '$') {
if (pwhash[1] == '2') {
int ret = bcrypt_checkpw(passwd, pwhash);
assert(ret != -1);
return (ret == 0) ? VERIFY_OK : VERIFY_FAIL;
}
}
2016-07-13 19:10:22 +02:00
return (strcmp(passwd, pwhash) == 0) ? VERIFY_OK : VERIFY_FAIL;
}