diff options
| author | Anna (navi) Figueiredo Gomes <navi@vlhl.dev> | 2024-07-18 17:29:21 +0200 | 
|---|---|---|
| committer | Anna (navi) Figueiredo Gomes <navi@vlhl.dev> | 2024-07-20 03:15:17 +0200 | 
| commit | c3ccaeeddc4d92bfe34cedaa6b71cb6e830fe280 (patch) | |
| tree | 926df7c4c604381f4d7b7b9ebccfa13bacefa3d7 /src/librc/librc.c | |
| parent | 18be0d77dc00d2e9faa7d8718e80a2f137ec0bf7 (diff) | |
| download | openrc-c3ccaeeddc4d92bfe34cedaa6b71cb6e830fe280.tar.xz | |
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.c | 29 | 
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)  {  | 
