|
@@ -24,6 +24,7 @@ source $HESTIA/conf/hestia.conf
|
|
|
# Verifications #
|
|
# Verifications #
|
|
|
#----------------------------------------------------------#
|
|
#----------------------------------------------------------#
|
|
|
|
|
|
|
|
|
|
+check_args '2' "$#" 'USER SSH_PUBLIC_KEY'
|
|
|
is_format_valid 'user'
|
|
is_format_valid 'user'
|
|
|
is_object_valid 'user' 'USER' "$user"
|
|
is_object_valid 'user' 'USER' "$user"
|
|
|
is_object_unsuspended 'user' 'USER' "$user"
|
|
is_object_unsuspended 'user' 'USER' "$user"
|
|
@@ -37,22 +38,23 @@ check_hestia_demo_mode
|
|
|
|
|
|
|
|
# Reading user values
|
|
# Reading user values
|
|
|
source $USER_DATA/user.conf
|
|
source $USER_DATA/user.conf
|
|
|
|
|
+
|
|
|
|
|
+AUTHKEY_FILE="$HOMEDIR/$user/.ssh/authorized_keys"
|
|
|
|
|
+[ -z "$(readlink -f "$AUTHKEY_FILE" | egrep "^$HOMEDIR/$user/.ssh/")" ] && check_result $E_FORBIDEN "Invalid authorized keys path"
|
|
|
|
|
+
|
|
|
#check if file exits
|
|
#check if file exits
|
|
|
-AUTHKEY_FILE=$HOMEDIR/$user/.ssh/authorized_keys
|
|
|
|
|
if [ ! -f "$AUTHKEY_FILE" ]; then
|
|
if [ ! -f "$AUTHKEY_FILE" ]; then
|
|
|
- touch "$AUTHKEY_FILE"
|
|
|
|
|
- chown ${user}: "${AUTHKEY_FILE}"
|
|
|
|
|
|
|
+ v-add-fs-file "$user" "${AUTHKEY_FILE}"
|
|
|
fi
|
|
fi
|
|
|
-TEMP=$(mktemp)
|
|
|
|
|
-echo "$key" >> "$TEMP"
|
|
|
|
|
-ssh-keygen -l -f "$TEMP"
|
|
|
|
|
-if [ ! $? -eq 0 ]; then
|
|
|
|
|
- rm "$TEMP"
|
|
|
|
|
- exit
|
|
|
|
|
|
|
+
|
|
|
|
|
+[ -z "$key" ] && check_result $E_NOTEXIST "Empty ssh public key"
|
|
|
|
|
+
|
|
|
|
|
+if ! echo "$key" | ssh-keygen -l -f - > /dev/null 2>&1; then
|
|
|
|
|
+ check_result $E_PARSING "Validating user private key"
|
|
|
fi
|
|
fi
|
|
|
-rm "$TEMP"
|
|
|
|
|
|
|
+
|
|
|
# make sure authorized_keys is ending with EOL
|
|
# make sure authorized_keys is ending with EOL
|
|
|
-sed -i '$a\' "${AUTHKEY_FILE}"
|
|
|
|
|
|
|
+[ -f "${AUTHKEY_FILE}" ] && sed -i '$a\' "${AUTHKEY_FILE}"
|
|
|
|
|
|
|
|
#append key to file
|
|
#append key to file
|
|
|
echo "$key" >> "$AUTHKEY_FILE"
|
|
echo "$key" >> "$AUTHKEY_FILE"
|
|
@@ -62,7 +64,7 @@ echo "$key" >> "$AUTHKEY_FILE"
|
|
|
#----------------------------------------------------------#
|
|
#----------------------------------------------------------#
|
|
|
|
|
|
|
|
# Logging
|
|
# Logging
|
|
|
-log_history "added ssh-key $user"
|
|
|
|
|
|
|
+log_history "Added ssh-key $user"
|
|
|
log_event "$OK" "$ARGUMENTS"
|
|
log_event "$OK" "$ARGUMENTS"
|
|
|
|
|
|
|
|
exit
|
|
exit
|