From 2030ef65f100e254611299bd81cf02cdc82360dd Mon Sep 17 00:00:00 2001 From: HE Chong Date: Fri, 13 Aug 2021 21:50:24 +0800 Subject: [PATCH] add user password update script for Fleet --- salt/common/tools/sbin/so-fleet-user-update | 64 +++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100755 salt/common/tools/sbin/so-fleet-user-update diff --git a/salt/common/tools/sbin/so-fleet-user-update b/salt/common/tools/sbin/so-fleet-user-update new file mode 100755 index 000000000..7d266ff2f --- /dev/null +++ b/salt/common/tools/sbin/so-fleet-user-update @@ -0,0 +1,64 @@ +#!/bin/bash +# +# Copyright 2014,2015,2016,2017,2018,2019,2020,2021 Security Onion Solutions, LLC +# +# 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 3 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, see . + +. /usr/sbin/so-common + +usage() { + echo "Usage: $0 " + echo "" + echo "Update password for an existing Fleet user. The new password will be read from STDIN." + exit 1 +} + +if [ $# -ne 1 ]; then + usage +fi + +USER=$1 + +MYSQL_PASS=$(lookup_pillar_secret mysql) +FLEET_IP=$(lookup_pillar fleet_ip) +FLEET_USER=$USER + +# Read password for new user from stdin +test -t 0 +if [[ $? == 0 ]]; then + echo "Enter new password:" +fi +read -rs FLEET_PASS + +if ! check_password "$FLEET_PASS"; then + echo "Password is invalid. Please exclude single quotes, double quotes and backslashes from the password." + exit 2 +fi + +FLEET_HASH=$(docker exec so-soctopus python -c "import bcrypt; print(bcrypt.hashpw('$FLEET_PASS'.encode('utf-8'), bcrypt.gensalt()).decode('utf-8'));" 2>&1) +if [[ $? -ne 0 ]]; then + echo "Failed to generate Fleet password hash" + exit 2 +fi + +MYSQL_OUTPUT=$(docker exec so-mysql mysql -u root --password=$MYSQL_PASS fleet -e \ + "UPDATE users SET password='$FLEET_HASH', salt='' where username='$FLEET_USER'" 2>&1) + +if [[ $? -eq 0 ]]; then + echo "Successfully updated Fleet user password" +else + echo "Unable to update Fleet user password" + echo "$MYSQL_OUTPUT" + exit 2 +fi