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