static int parse_caps(sd_bus_creds *c, unsigned offset, const char *p) {
size_t sz, max;
- unsigned i, j;
assert(c);
assert(p);
max = DIV_ROUND_UP(cap_last_cap()+1, 32U);
- p += strspn(p, WHITESPACE);
sz = strlen(p);
if (sz % 8 != 0)
return -ENOMEM;
}
- for (i = 0; i < sz; i++) {
+ for (unsigned i = 0; i < sz; i++) {
uint32_t v = 0;
- for (j = 0; j < 8; ++j) {
+ for (unsigned j = 0; j < 8; j++) {
int t;
t = unhexchar(*p++);
break;
if (missing & SD_BUS_CREDS_PPID) {
- p = startswith(line, "PPid:");
+ p = first_word(line, "PPid:");
if (p) {
- p += strspn(p, WHITESPACE);
-
/* Explicitly check for PPID 0 (which is the case for PID 1) */
if (!streq(p, "0")) {
r = parse_pid(p, &c->ppid);
if (r < 0)
return r;
-
} else
c->ppid = 0;
}
if (missing & (SD_BUS_CREDS_UID|SD_BUS_CREDS_EUID|SD_BUS_CREDS_SUID|SD_BUS_CREDS_FSUID)) {
- p = startswith(line, "Uid:");
+ p = first_word(line, "Uid:");
if (p) {
unsigned long uid, euid, suid, fsuid;
- p += strspn(p, WHITESPACE);
if (sscanf(p, "%lu %lu %lu %lu", &uid, &euid, &suid, &fsuid) != 4)
return -EIO;
}
if (missing & (SD_BUS_CREDS_GID|SD_BUS_CREDS_EGID|SD_BUS_CREDS_SGID|SD_BUS_CREDS_FSGID)) {
- p = startswith(line, "Gid:");
+ p = first_word(line, "Gid:");
if (p) {
unsigned long gid, egid, sgid, fsgid;
- p += strspn(p, WHITESPACE);
if (sscanf(p, "%lu %lu %lu %lu", &gid, &egid, &sgid, &fsgid) != 4)
return -EIO;
unsigned long g;
int n = 0;
- p += strspn(p, WHITESPACE);
+ p = skip_leading_chars(p, /* bad = */ NULL);
if (*p == 0)
break;
}
if (missing & SD_BUS_CREDS_EFFECTIVE_CAPS) {
- p = startswith(line, "CapEff:");
+ p = first_word(line, "CapEff:");
if (p) {
r = parse_caps(c, CAP_OFFSET_EFFECTIVE, p);
if (r < 0)
}
if (missing & SD_BUS_CREDS_PERMITTED_CAPS) {
- p = startswith(line, "CapPrm:");
+ p = first_word(line, "CapPrm:");
if (p) {
r = parse_caps(c, CAP_OFFSET_PERMITTED, p);
if (r < 0)
}
if (missing & SD_BUS_CREDS_INHERITABLE_CAPS) {
- p = startswith(line, "CapInh:");
+ p = first_word(line, "CapInh:");
if (p) {
r = parse_caps(c, CAP_OFFSET_INHERITABLE, p);
if (r < 0)
}
if (missing & SD_BUS_CREDS_BOUNDING_CAPS) {
- p = startswith(line, "CapBnd:");
+ p = first_word(line, "CapBnd:");
if (p) {
r = parse_caps(c, CAP_OFFSET_BOUNDING, p);
if (r < 0)
if (!c->cgroup) {
r = cg_pid_get_path(NULL, pidref->pid, &c->cgroup);
- if (r < 0) {
- if (!ERRNO_IS_PRIVILEGE(r))
- return r;
- }
+ if (r < 0 && !ERRNO_IS_NEG_PRIVILEGE(r))
+ return r;
}
if (!c->cgroup_root) {