1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
--- sudo.cpp.orig 2023-04-15 15:54:02 UTC
+++ sudo.cpp
@@ -44,7 +44,7 @@
#else
#include <errno.h>
#include <termios.h>
-#include <util.h>
+#include <libutil.h>
#endif
#include <unistd.h>
#include <memory>
@@ -65,6 +65,9 @@ namespace
const QString su_prog{QStringLiteral(LXQTSUDO_SU)};
const QString sudo_prog{QStringLiteral(LXQTSUDO_SUDO)};
+#ifdef __FreeBSD__
+ const QString pwd_prompt_end_c_locale{QStringLiteral(":")};
+#endif
const QString doas_prog{QStringLiteral(LXQTSUDO_DOAS)};
const QString pwd_prompt_end{QStringLiteral(": ")};
const QChar nl{QLatin1Char('\n')};
@@ -194,7 +197,9 @@ int Sudo::main()
} else if (QStringLiteral("-a") == arg1 || QStringLiteral("--doas") == arg1)
{
mBackend = BACK_DOAS;
- mArgs.removeAt(0);
+ mArgs.removeAt(0); //remove -m
+ mArgs.removeAt(1); //remove root
+ mArgs.removeAt(2); // remove -c
}
}
//any other arguments we simply forward to su/sudo
@@ -265,7 +270,7 @@ void Sudo::child()
switch (mBackend)
{
case BACK_SU:
- params_cnt += 1; // -c for su
+ params_cnt += 3; // -m root -c for su
break;
case BACK_SUDO:
params_cnt += 3; // --preserve-env=... /bin/sh -c for sudo
@@ -295,8 +300,10 @@ void Sudo::child()
break;
case BACK_DOAS:
*(param_arg++) = "/bin/sh";
- [[fallthrough]];
+ break;
case BACK_SU:
+ *(param_arg++) = "-m";
+ *(param_arg++) = "root";
case BACK_NONE:
env_workarounds();
break;
@@ -404,7 +411,8 @@ int Sudo::parent()
}
} else
{
- if (line.endsWith(pwd_prompt_end))
+ if(line.endsWith(pwd_prompt_end_c_locale) || line.endsWith(pwd_prompt_end))
+
{
//if now echo is turned off, su/sudo requests password
struct termios tios;
|