#include "networkd-manager.h"
#include "socket-util.h"
#include "tuntap.h"
-#include "user-util.h"
+#include "userdb.h"
#define TUN_DEV "/dev/net/tun"
return log_netdev_error_errno(netdev, errno, "TUNSETQUEUE failed: %m");
}
- if (t->user_name) {
- const char *user = t->user_name;
- uid_t uid;
-
- r = get_user_creds(&user, &uid, NULL, NULL, NULL, USER_CREDS_ALLOW_MISSING);
- if (r < 0)
- return log_netdev_error_errno(netdev, r, "Cannot resolve user name %s: %m", t->user_name);
-
- if (ioctl(fd, TUNSETOWNER, uid) < 0)
+ if (t->uid != 0)
+ if (ioctl(fd, TUNSETOWNER, t->uid) < 0)
return log_netdev_error_errno(netdev, errno, "TUNSETOWNER failed: %m");
- }
-
- if (t->group_name) {
- const char *group = t->group_name;
- gid_t gid;
-
- r = get_group_creds(&group, &gid, USER_CREDS_ALLOW_MISSING);
- if (r < 0)
- return log_netdev_error_errno(netdev, r, "Cannot resolve group name %s: %m", t->group_name);
- if (ioctl(fd, TUNSETGROUP, gid) < 0)
+ if (t->gid != 0)
+ if (ioctl(fd, TUNSETGROUP, t->gid) < 0)
return log_netdev_error_errno(netdev, errno, "TUNSETGROUP failed: %m");
- }
-
if (ioctl(fd, TUNSETPERSIST, 1) < 0)
return log_netdev_error_errno(netdev, errno, "TUNSETPERSIST failed: %m");
}
static int tuntap_verify(NetDev *netdev, const char *filename) {
+ TunTap *t = TUNTAP(netdev);
+ int r;
+
assert(netdev);
if (netdev->mtu != 0)
"Please set it in the corresponding .network file.",
netdev_kind_to_string(netdev->kind), filename);
+ if (t->user_name) {
+ _cleanup_(user_record_unrefp) UserRecord *ur = NULL;
+
+ r = userdb_by_name(t->user_name, /* match = */ NULL, USERDB_PARSE_NUMERIC, &ur);
+ if (r < 0)
+ log_netdev_warning_errno(netdev, r, "Cannot resolve user name %s, ignoring: %m", t->user_name);
+ else
+ t->uid = ur->uid;
+ }
+
+ if (t->group_name) {
+ _cleanup_(group_record_unrefp) GroupRecord *gr = NULL;
+
+ r = groupdb_by_name(t->group_name, /* match = */ NULL, USERDB_PARSE_NUMERIC, &gr);
+ if (r < 0)
+ log_netdev_warning_errno(netdev, r, "Cannot resolve group name %s, ignoring: %m", t->group_name);
+ else
+ t->gid = gr->gid;
+ }
+
return 0;
}