/****************************************************************************** * Icinga 2 * * Copyright (C) 2012-2017 Icinga Development Team (https://www.icinga.com/) * * * * This program 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. * * * * This program 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 this program; if not, write to the Free Software Foundation * * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. * ******************************************************************************/ #include "cli/apiusercommand.hpp" #include "base/logger.hpp" #include "base/tlsutility.hpp" #include "remote/apiuser.hpp" #include using namespace icinga; namespace po = boost::program_options; REGISTER_CLICOMMAND("api/user", ApiUserCommand); String ApiUserCommand::GetDescription(void) const { return "Create a hashed user and password string for the Icinga 2 API"; } String ApiUserCommand::GetShortDescription(void) const { return "API user creation helper"; } void ApiUserCommand::InitParameters(boost::program_options::options_description& visibleDesc, boost::program_options::options_description& hiddenDesc) const { visibleDesc.add_options() ("user", po::value(), "API username") ("passwd", po::value(), "Password in clear text") ("salt", po::value(), "Optional salt (default: 8 random chars)"); } /** * The entry point for the "api user" CLI command. * * @returns An exit status. */ int ApiUserCommand::Run(const boost::program_options::variables_map& vm, const std::vector& ap) const { if (!vm.count("user")) { Log(LogCritical, "cli", "Username (--user) must be specified."); return 1; } if (!vm.count("passwd")) { Log(LogCritical, "cli", "Password (--passwd) must be specified."); return 1; } String user = vm["user"].as(); String passwd = vm["passwd"].as(); String salt = vm.count("salt") ? String(vm["salt"].as()) : RandomString(8); String hashedPassword = ApiUser::CreateHashedPasswordString(passwd, salt, true); std::cout << "object ApiUser \"" << user << "\" {\n" << " password_hash =\"" << hashedPassword << "\"\n" << " // client_cn = \"\"\n" << "\n" << " permissions = [ \"*\" ]\n" << "}\n"; return 0; }