aboutsummaryrefslogtreecommitdiff
path: root/src/librc/librc.c
diff options
context:
space:
mode:
authorAnna (navi) Figueiredo Gomes <navi@vlhl.dev>2024-07-18 17:29:21 +0200
committerAnna (navi) Figueiredo Gomes <navi@vlhl.dev>2024-07-20 03:15:17 +0200
commitc3ccaeeddc4d92bfe34cedaa6b71cb6e830fe280 (patch)
tree926df7c4c604381f4d7b7b9ebccfa13bacefa3d7 /src/librc/librc.c
parent18be0d77dc00d2e9faa7d8718e80a2f137ec0bf7 (diff)
librc, openrc-pam: instantiate user.<username> service automatically
it's created in /run/openrc/dynamic and linked to the service in /etc at login. Signed-off-by: Anna (navi) Figueiredo Gomes <navi@vlhl.dev>
Diffstat (limited to 'src/librc/librc.c')
-rw-r--r--src/librc/librc.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/librc/librc.c b/src/librc/librc.c
index d218c8be..ee728b30 100644
--- a/src/librc/librc.c
+++ b/src/librc/librc.c
@@ -1317,6 +1317,35 @@ rc_service_delete(const char *runlevel, const char *service)
return (r == 0);
}
+char *
+rc_service_base(const char *service)
+{
+ char *dot = strchr(service, '.');
+ if (!dot)
+ return NULL;
+ return xstrndup(service, dot - service);
+}
+
+char *
+rc_service_dylink(const char *service, const char *target)
+{
+ char *file = rc_service_resolve(service);
+ char *target_file = NULL;
+ if (!exists(file))
+ goto out;
+
+ xasprintf(&target_file, "%s/dynamic/%s", rc_service_dir(), target);
+ if (!exists(target_file) && symlink(file, target_file) == -1) {
+ free(target_file);
+ target_file = NULL;
+ goto out;
+ }
+
+out:
+ free(file);
+ return target_file;
+}
+
RC_STRINGLIST *
rc_services_scheduled_by(const char *service)
{