mirror of
https://github.com/pygos/init.git
synced 2024-11-21 18:59:46 +01:00
Read environment for init from config file
Signed-off-by: David Oberhollenzer <david.oberhollenzer@tele2.at>
This commit is contained in:
parent
82cd18107f
commit
55d4a328c9
7 changed files with 160 additions and 1 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -41,3 +41,5 @@ services/rootusr
|
||||||
scripts/devfs.sh
|
scripts/devfs.sh
|
||||||
scripts/overlay.sh
|
scripts/overlay.sh
|
||||||
scripts/trymount.sh
|
scripts/trymount.sh
|
||||||
|
|
||||||
|
etc/initd.env
|
||||||
|
|
|
@ -5,6 +5,7 @@ AM_CFLAGS = -std=c99 $(WARN_CFLAGS)
|
||||||
|
|
||||||
sbin_PROGRAMS =
|
sbin_PROGRAMS =
|
||||||
noinst_LIBRARIES =
|
noinst_LIBRARIES =
|
||||||
|
sysconf_DATA = etc/initd.env
|
||||||
EXTRA_DIST = README LICENSE
|
EXTRA_DIST = README LICENSE
|
||||||
|
|
||||||
helperdir = @SCRIPTDIR@
|
helperdir = @SCRIPTDIR@
|
||||||
|
|
|
@ -53,6 +53,7 @@ AC_DEFINE_DIR(SOCKDIR, localstatedir/run, [Directory for initd socket])
|
||||||
|
|
||||||
AC_DEFINE_DIR(BINPATH, bindir, [Fully evaluated bin directory])
|
AC_DEFINE_DIR(BINPATH, bindir, [Fully evaluated bin directory])
|
||||||
AC_DEFINE_DIR(SBINPATH, sbindir, [Fully evaluated sbin directory])
|
AC_DEFINE_DIR(SBINPATH, sbindir, [Fully evaluated sbin directory])
|
||||||
|
AC_DEFINE_DIR(ETCPATH, sysconfdir, [Fulle evaluated etc directory])
|
||||||
|
|
||||||
AC_CONFIG_FILES([services/agetty])
|
AC_CONFIG_FILES([services/agetty])
|
||||||
AC_CONFIG_FILES([services/hostname])
|
AC_CONFIG_FILES([services/hostname])
|
||||||
|
@ -74,5 +75,6 @@ AC_CONFIG_FILES([services/rootusr])
|
||||||
AC_CONFIG_FILES([scripts/devfs.sh])
|
AC_CONFIG_FILES([scripts/devfs.sh])
|
||||||
AC_CONFIG_FILES([scripts/overlay.sh])
|
AC_CONFIG_FILES([scripts/overlay.sh])
|
||||||
AC_CONFIG_FILES([scripts/trymount.sh])
|
AC_CONFIG_FILES([scripts/trymount.sh])
|
||||||
|
AC_CONFIG_FILES([etc/initd.env])
|
||||||
|
|
||||||
AC_OUTPUT([Makefile])
|
AC_OUTPUT([Makefile])
|
||||||
|
|
7
etc/initd.env.in
Normal file
7
etc/initd.env.in
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
##############################################################################
|
||||||
|
# initd.env #
|
||||||
|
# #
|
||||||
|
# This file contains environment variables that should be set for init. #
|
||||||
|
##############################################################################
|
||||||
|
|
||||||
|
PATH=@BINPATH@:@SBINPATH@
|
|
@ -1,5 +1,5 @@
|
||||||
init_SOURCES = initd/main.c initd/runlst.c initd/init.h
|
init_SOURCES = initd/main.c initd/runlst.c initd/init.h
|
||||||
init_SOURCES += initd/status.c initd/mksock.c initd/svclist.c
|
init_SOURCES += initd/status.c initd/mksock.c initd/svclist.c initd/env.c
|
||||||
init_CPPFLAGS = $(AM_CPPFLAGS)
|
init_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
init_CFLAGS = $(AM_CFLAGS)
|
init_CFLAGS = $(AM_CFLAGS)
|
||||||
init_LDFLAGS = $(AM_LDFLAGS)
|
init_LDFLAGS = $(AM_LDFLAGS)
|
||||||
|
|
137
initd/env.c
Normal file
137
initd/env.c
Normal file
|
@ -0,0 +1,137 @@
|
||||||
|
/* SPDX-License-Identifier: GPL-3.0-or-later */
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2018 - David Oberhollenzer
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#include "init.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
struct entry {
|
||||||
|
struct entry *next;
|
||||||
|
char data[];
|
||||||
|
};
|
||||||
|
|
||||||
|
extern char **environ;
|
||||||
|
|
||||||
|
static void free_list(struct entry *list)
|
||||||
|
{
|
||||||
|
struct entry *e;
|
||||||
|
|
||||||
|
while (list != NULL) {
|
||||||
|
e = list;
|
||||||
|
list = list->next;
|
||||||
|
free(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct entry *parse_list(rdline_t *rd)
|
||||||
|
{
|
||||||
|
struct entry *e, *list = NULL;
|
||||||
|
char *ptr;
|
||||||
|
|
||||||
|
while (rdline(rd) == 0) {
|
||||||
|
ptr = rd->buffer;
|
||||||
|
|
||||||
|
while (*ptr != '\0' && *ptr != ' ' && *ptr != '=')
|
||||||
|
++ptr;
|
||||||
|
|
||||||
|
if (*ptr == ' ')
|
||||||
|
memmove(ptr, ptr + 1, strlen(ptr + 1) + 1);
|
||||||
|
|
||||||
|
if (*(ptr++) != '=') {
|
||||||
|
fprintf(stderr, "%s: %zu: line is not of the shape "
|
||||||
|
"'key = value', skipping\n",
|
||||||
|
rd->filename, rd->lineno);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*ptr == ' ')
|
||||||
|
memmove(ptr, ptr + 1, strlen(ptr + 1) + 1);
|
||||||
|
|
||||||
|
if (unescape(ptr)) {
|
||||||
|
fprintf(stderr, "%s: %zu: malformed string constant, "
|
||||||
|
"skipping\n",
|
||||||
|
rd->filename, rd->lineno);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
e = calloc(1, sizeof(*e) + strlen(rd->buffer) + 1);
|
||||||
|
if (e == NULL)
|
||||||
|
goto fail_oom;
|
||||||
|
|
||||||
|
strcpy(e->data, rd->buffer);
|
||||||
|
e->next = list;
|
||||||
|
list = e;
|
||||||
|
}
|
||||||
|
|
||||||
|
return list;
|
||||||
|
fail_oom:
|
||||||
|
fputs("out of memory\n", stderr);
|
||||||
|
free_list(list);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct entry *list_from_file(void)
|
||||||
|
{
|
||||||
|
struct entry *list;
|
||||||
|
rdline_t rd;
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
fd = open(ENVFILE, O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror(ENVFILE);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
rdline_init(&rd, fd, ENVFILE, 0, NULL);
|
||||||
|
list = parse_list(&rd);
|
||||||
|
close(fd);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
int initenv(void)
|
||||||
|
{
|
||||||
|
struct entry *list, *e;
|
||||||
|
int i, count;
|
||||||
|
char **envp;
|
||||||
|
|
||||||
|
list = list_from_file();
|
||||||
|
if (list == NULL)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
for (count = 0, e = list; e != NULL; e = e->next)
|
||||||
|
++count;
|
||||||
|
|
||||||
|
envp = malloc((count + 1) * sizeof(char *));
|
||||||
|
if (envp == NULL) {
|
||||||
|
fputs("out of memory\n", stderr);
|
||||||
|
free_list(list);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0, e = list; e != NULL; e = e->next)
|
||||||
|
envp[i] = e->data;
|
||||||
|
|
||||||
|
envp[i] = NULL;
|
||||||
|
|
||||||
|
environ = envp;
|
||||||
|
return 0;
|
||||||
|
}
|
10
initd/init.h
10
initd/init.h
|
@ -25,6 +25,8 @@
|
||||||
#include "telinit.h"
|
#include "telinit.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
#define ENVFILE ETCPATH "/initd.env"
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
STATUS_OK = 0,
|
STATUS_OK = 0,
|
||||||
STATUS_FAIL,
|
STATUS_FAIL,
|
||||||
|
@ -107,5 +109,13 @@ void svclist_add(service_t *svc);
|
||||||
*/
|
*/
|
||||||
service_t *svclist_remove(pid_t pid);
|
service_t *svclist_remove(pid_t pid);
|
||||||
|
|
||||||
|
/********** env.c **********/
|
||||||
|
|
||||||
|
/*
|
||||||
|
Read /etc/initd.env (actually ENVFILE defined above)
|
||||||
|
and setup environment variables for init.
|
||||||
|
*/
|
||||||
|
int initenv(void);
|
||||||
|
|
||||||
#endif /* INIT_H */
|
#endif /* INIT_H */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue