You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
1.0 KiB
36 lines
1.0 KiB
#!/bin/bash |
|
source config.sh |
|
source functions.sh |
|
|
|
username=$(echap "$username") |
|
password=$(echap "$password") |
|
|
|
if [ "$USELDAP" == 0 ]; then |
|
# Authentication |
|
user_pass=$(mysql -h$HOST -P$PORT -u$USER -p$PASS $DB -sN -e "SELECT user_pass FROM user WHERE user_id = '$username' AND user_enable=1 AND (TO_DAYS(now()) >= TO_DAYS(user_start_date) OR user_start_date IS NULL) AND (TO_DAYS(now()) <= TO_DAYS(user_end_date) OR user_end_date IS NULL)") |
|
|
|
# Check the user |
|
if [ "$user_pass" == '' ]; then |
|
echo "$username: bad account." |
|
exit 1 |
|
fi |
|
|
|
result=$(php -r "if(password_verify('$password', '$user_pass') == true) { echo 'ok'; } else { echo 'ko'; }") |
|
|
|
if [ "$result" == "ok" ]; then |
|
echo "$username: authentication ok." |
|
exit 0 |
|
else |
|
echo "$username: authentication failed." |
|
exit 1 |
|
fi |
|
else |
|
result=$( ldapsearch -x -h "$SERVER" -D "uid=$username,$CONNECTIONSTR" -w $pasword -b "$CONNECTIONSTR" ) |
|
if [[ $result == *"result: 0 Success"* ]]; then |
|
#echo "Logged In!" |
|
exit 0 |
|
else |
|
#echo "Invalid Creds!" |
|
exit 1 |
|
fi |
|
fi
|
|
|