ubusd: attempt to create socket folder
When ubus is running as root, /var/run/ubus most likely hasn't been created as well (as that's the homedir of user ubus, and if a user ubus was found, then ubus would run being that user). Blindly attempt to create the directory (which won't do any harm if it does exist and/or ubus is not running as root) to still be able to start ubus in case of user ubus not existing. Signed-off-by: Daniel Golle <daniel@makrotopia.org>
This commit is contained in:
parent
ad0cd117db
commit
d1d9ddf98d
1 changed files with 16 additions and 0 deletions
16
ubusd_main.c
16
ubusd_main.c
|
@ -6,9 +6,11 @@
|
||||||
|
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <sys/types.h>
|
||||||
#ifdef FreeBSD
|
#ifdef FreeBSD
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include <string.h>
|
||||||
#include <syslog.h>
|
#include <syslog.h>
|
||||||
|
|
||||||
#include <libubox/usock.h>
|
#include <libubox/usock.h>
|
||||||
|
@ -229,6 +231,19 @@ static void sighup_handler(int sig)
|
||||||
ubusd_acl_load();
|
ubusd_acl_load();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void mkdir_sockdir()
|
||||||
|
{
|
||||||
|
char *ubus_sock_dir, *tmp;
|
||||||
|
|
||||||
|
ubus_sock_dir = strdup(UBUS_UNIX_SOCKET);
|
||||||
|
tmp = strrchr(ubus_sock_dir, '/');
|
||||||
|
if (tmp) {
|
||||||
|
*tmp = '\0';
|
||||||
|
mkdir(ubus_sock_dir, 0755);
|
||||||
|
}
|
||||||
|
free(ubus_sock_dir);
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
const char *ubus_socket = UBUS_UNIX_SOCKET;
|
const char *ubus_socket = UBUS_UNIX_SOCKET;
|
||||||
|
@ -254,6 +269,7 @@ int main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mkdir_sockdir();
|
||||||
unlink(ubus_socket);
|
unlink(ubus_socket);
|
||||||
umask(0111);
|
umask(0111);
|
||||||
server_fd.fd = usock(USOCK_UNIX | USOCK_SERVER | USOCK_NONBLOCK, ubus_socket, NULL);
|
server_fd.fd = usock(USOCK_UNIX | USOCK_SERVER | USOCK_NONBLOCK, ubus_socket, NULL);
|
||||||
|
|
Loading…
Reference in a new issue