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
|
--- a/sapi/fpm/fpm/fpm_unix.c
+++ b/sapi/fpm/fpm/fpm_unix.c
@@ -165,27 +165,35 @@
#endif
if (c->listen_owner && *c->listen_owner) {
- struct passwd *pwd;
+ if (strlen(c->listen_owner) == strspn(c->listen_owner, "0123456789")) {
+ wp->socket_uid = strtoul(c->listen_owner, 0, 10);
+ } else {
+ struct passwd *pwd;
- pwd = getpwnam(c->listen_owner);
- if (!pwd) {
- zlog(ZLOG_SYSERROR, "[pool %s] cannot get uid for user '%s'", wp->config->name, c->listen_owner);
- return -1;
- }
+ pwd = getpwnam(c->listen_owner);
+ if (!pwd) {
+ zlog(ZLOG_SYSERROR, "[pool %s] cannot get uid for user '%s'", wp->config->name, c->listen_owner);
+ return -1;
+ }
- wp->socket_uid = pwd->pw_uid;
- wp->socket_gid = pwd->pw_gid;
+ wp->socket_uid = pwd->pw_uid;
+ wp->socket_gid = pwd->pw_gid;
+ }
}
if (c->listen_group && *c->listen_group) {
- struct group *grp;
+ if (strlen(c->listen_group) == strspn(c->listen_group, "0123456789")) {
+ wp->socket_gid = strtoul(c->listen_group, 0, 10);
+ } else {
+ struct group *grp;
- grp = getgrnam(c->listen_group);
- if (!grp) {
- zlog(ZLOG_SYSERROR, "[pool %s] cannot get gid for group '%s'", wp->config->name, c->listen_group);
- return -1;
+ grp = getgrnam(c->listen_group);
+ if (!grp) {
+ zlog(ZLOG_SYSERROR, "[pool %s] cannot get gid for group '%s'", wp->config->name, c->listen_group);
+ return -1;
+ }
+ wp->socket_gid = grp->gr_gid;
}
- wp->socket_gid = grp->gr_gid;
}
return 0;
|