From feeb7602a9b386dfdd61190ce633a3b56a10c68f Mon Sep 17 00:00:00 2001 From: Bent Bisballe Nyeng Date: Sun, 5 Jul 2020 16:46:27 +0200 Subject: Add tool for creating argon2 hased passwords. --- src/muniapwd.cc | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 src/muniapwd.cc (limited to 'src/muniapwd.cc') diff --git a/src/muniapwd.cc b/src/muniapwd.cc new file mode 100644 index 0000000..26b8eeb --- /dev/null +++ b/src/muniapwd.cc @@ -0,0 +1,73 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set et sw=2 ts=2: */ +/*************************************************************************** + * muniapwd.cc + * + * Sun Jul 5 09:22:22 CEST 2020 + * Copyright 2020 Bent Bisballe Nyeng + * deva@aasimon.org + ****************************************************************************/ + +/* + * This file is part of Munia. + * + * Munia is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * Munia is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Munia; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. + */ +#include + +#include "salt.h" +#include "hash.h" + +int main(int argc, char* argv[]) +{ + if(argc != 2) + { + printf("Usage: %s \n", argv[0]); + return 1; + } + + const char* user = argv[1]; + + std::string password = getpass("Type password: "); + std::string passwordAgain = getpass("Type password (again): "); + if(password != passwordAgain) + { + printf("Passwords don't match.\n"); + return 1; + } + + try + { + auto encoded = getEncoded(getSalt(), password); + printf("%s:%s\n", user, encoded.data()); + + if(verifyEncoded(encoded, password)) + { + printf("Verification ok\n"); + } + else + { + printf("Verification failed\n"); + return 1; + } + } + catch(char* msg) + { + printf("Error: %s\n", msg); + return 1; + } + + return 0; +} -- cgit v1.2.3