summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-09-19 22:58:27 +0200
committerdefault <nobody@localhost>2022-09-19 22:58:27 +0200
commit8be433c9b65fe5f214151651055700d1fea02a56 (patch)
treef10a87901d7b2fdaab66951501b0d8dfada33e00
parentc88d4f1e152859254d28bcd6cd7ad7798f0782c4 (diff)
New function hash_password() and check_password().
-rw-r--r--main.c3
-rw-r--r--snac.c33
-rw-r--r--snac.h3
3 files changed, 39 insertions, 0 deletions
diff --git a/main.c b/main.c
index ab4093b..ab83086 100644
--- a/main.c
+++ b/main.c
@@ -16,5 +16,8 @@ int main(int argc, char *argv[])
snac_open(&snac, "mike");
snac_log(&snac, xs_str_new("ok"));
+ char *passwd = xs_dict_get(snac.config, "passwd");
+ printf("%d\n", check_password("mike", "1234", passwd));
+
return 0;
}
diff --git a/snac.c b/snac.c
index 0238b7a..dd76e06 100644
--- a/snac.c
+++ b/snac.c
@@ -90,3 +90,36 @@ void snac_debug(snac *snac, int level, d_char *str)
fprintf(stderr, "%s [%s] %s\n", tm, snac->uid, msg);
}
}
+
+
+d_char *hash_password(char *uid, char *passwd, char *nonce)
+/* hashes a password */
+{
+ xs *d_nonce = NULL;
+ xs *combi;
+ xs *hash;
+
+ if (nonce == NULL)
+ nonce = d_nonce = xs_fmt("%08x", random());
+
+ combi = xs_fmt("%s:%s:%s", nonce, uid, passwd);
+ hash = xs_sha1_hex(combi, strlen(combi));
+
+ return xs_fmt("%s:%s", nonce, hash);
+}
+
+
+int check_password(char *uid, char *passwd, char *hash)
+/* checks a password */
+{
+ int ret = 0;
+ xs *spl = xs_splitn(hash, ":", 1);
+
+ if (xs_list_len(spl) == 2) {
+ xs *n_hash = hash_password(uid, passwd, xs_list_get(spl, 0));
+
+ ret = (strcmp(hash, n_hash) == 0);
+ }
+
+ return ret;
+}
diff --git a/snac.h b/snac.h
index 03c9c7b..1c56404 100644
--- a/snac.h
+++ b/snac.h
@@ -33,3 +33,6 @@ void snac_debug(snac *snac, int level, d_char *str);
#define snac_log(snac, str) snac_debug(snac, 0, str)
int validate_uid(char *uid);
+
+d_char *hash_password(char *uid, char *passwd, char *nonce);
+int check_password(char *uid, char *passwd, char *hash);