1From 54b2ed18ca52fa682ade2fe84e1b0d19d1b78cc4 Mon Sep 17 00:00:00 2001 2From: Kai Kang <kai.kang@windriver.com> 3Date: Mon, 11 Jan 2021 16:48:26 +0800 4Subject: [PATCH 5/8] ui.c: handle password-expire and update-new-password 5 6Upstream-Status: Submitted [https://sourceforge.net/p/lxdm/code/merge-requests/1/] 7 8Signed-off-by: Kai Kang <kai.kang@windriver.com> 9--- 10 src/ui.c | 20 ++++++++++++++++++++ 11 1 file changed, 20 insertions(+) 12 13diff --git a/src/ui.c b/src/ui.c 14index f233589..3ddb484 100644 15--- a/src/ui.c 16+++ b/src/ui.c 17@@ -161,6 +161,9 @@ static gboolean on_greeter_input(GIOChannel *source, GIOCondition condition, gpo 18 ui_drop(); 19 lxdm_do_login(pw, session, lang,NULL); 20 } 21+ else if (AUTH_PASSWD_EXPIRE == ret) { 22+ xwrite(greeter_pipe[0], "password-expire\n", 16); 23+ } 24 else 25 { 26 if(pass!=NULL) 27@@ -205,6 +208,23 @@ static gboolean on_greeter_input(GIOChannel *source, GIOCondition condition, gpo 28 g_free(session); 29 g_free(lang); 30 } 31+ else if (!strncmp(str, "update-new-password", 19)) { 32+ xwrite(greeter_pipe[0], "update-new-password\n", 20); 33+ char *user = greeter_param(str, "user"); 34+ char *pass = greeter_param(str, "newpass"); 35+ char *session = greeter_param(str, "session"); 36+ char *lang = greeter_param(str, "lang"); 37+ 38+ int ret = lxdm_change_passwd(user, pass); 39+ if (ret) { 40+ xwrite(greeter_pipe[0], "invalid-new-password\n", 21); 41+ } else { 42+ struct passwd *pw; 43+ ret = lxdm_auth_user(AUTH_TYPE_NORMAL, user, pass, &pw); 44+ ui_drop(); 45+ lxdm_do_login(pw, session, lang, NULL); 46+ } 47+ } 48 g_free(str); 49 return TRUE; 50 } 51-- 522.25.1 53 54