38 Commits
v0.1.7 ... dev

Author SHA1 Message Date
obarun
ae2e097a6b earlier tty start now at tty6 2018-01-18 14:17:20 +11:00
obarun
77057205d7 allow to start multiple tty at boot time 2018-01-18 14:16:56 +11:00
obarun
4d67a11ce9 disable parsing environment 2018-01-12 17:00:50 +11:00
obarun
a66aea9840 append MASTER name with a suffix 2018-01-12 15:15:31 +11:00
obarun
6712d7bef0 update user.sh to master.sh 2018-01-12 14:22:22 +11:00
obarun
731f9414f1 rebuild database 2018-01-12 13:57:44 +11:00
obarun
e02c2138db shutdown the rc database coming grom root 2018-01-12 13:56:26 +11:00
obarun
1f6ec5f2f2 allow to change the name for root user 2018-01-12 13:56:06 +11:00
obarun
2632e962ea call master.sh instead of user.sh 2018-01-12 13:55:46 +11:00
obarun
c09e70e9e2 split file for creation of supervision tree,root in now independant, user.sh pass now to s6opts 2018-01-12 13:55:15 +11:00
obarun
d628070a7a Merge branch 'master' into dev 2018-01-11 09:17:50 +11:00
obarun
ad09fc9981 update copyright 2018-01-11 08:24:52 +11:00
obarun
20d43abe7f rofs-cgroups : fix umounting cgroups at shutdown 2018-01-10 23:27:18 +11:00
obarun
fea3b2675c Bump 0.2.0 2018-01-04 15:50:31 +11:00
obarun
2dfb3ac0ad rebuild database 2018-01-04 15:36:08 +11:00
obarun
fb924ced4f merge branch dev 2018-01-04 15:34:28 +11:00
obarun
7008745393 rebuild database 2018-01-04 15:26:26 +11:00
obarun
5a93f2ca81 fix output message of iptables6 at shutdown 2018-01-04 15:23:08 +11:00
obarun
3cd9f46117 umount nfs if exist 2018-01-04 15:19:10 +11:00
obarun
f88b0f4eac rebuild database 2018-01-04 15:03:28 +11:00
obarun
1c6c1ff259 improve udevd and udevadm service 2018-01-04 15:01:57 +11:00
obarun
f5217e18ef oops wrong variable 2017-12-13 15:34:02 +11:00
obarun
051dacc843 bump 0.1.9 2017-12-13 15:12:05 +11:00
obarun
d3ec2f001e rebuild database 2017-12-13 15:11:32 +11:00
obarun
0594295927 fix svscanctl command 2017-12-13 15:01:34 +11:00
obarun
95e074768e stage2.tini : umount Nfs filesystem if exist 2017-10-11 09:39:33 +11:00
obarun
dbc7e4d1af NEWS : oops forget to push before tagging 2017-10-11 09:16:51 +11:00
obarun
4e1e004af7 Makefile : fix version 2017-10-11 09:16:26 +11:00
obarun
53bc1c3f84 rofs-cgroups: add -R at umount command 2017-10-11 09:15:59 +11:00
obarun
ea871d703a Makefile : install tmpfiles.sh and modules.sh script 2017-10-03 10:16:26 +11:00
obarun
2b6b36c265 rebuild database 2017-10-03 10:11:46 +11:00
obarun
9acfccfad5 NEWS : new version 2017-10-03 10:09:28 +11:00
obarun
32eaffc776 rwfs-end : fix it 2017-10-03 10:09:13 +11:00
obarun
de179883e4 fix BINDIR_EXECLINE 2017-10-03 10:08:51 +11:00
obarun
59f5925d6b add data/scripts/tmpfiles.sh : this scripts parse and apply files founded at /usr/lib/tmpfiles.d 2017-10-03 10:08:24 +11:00
obarun
b5f41908b3 wrap systemd modules-load.d/ directory to load modules 2017-09-30 09:05:25 +11:00
obarun
a72258985a rwfs-ip6tables : fix down file 2017-09-30 09:04:39 +11:00
obarun
9f81864f69 add modules.sh script to load modules from /etc,/run,/usr/lib/modules-load.d 2017-09-29 18:50:49 +11:00
75 changed files with 773 additions and 390 deletions

View File

@@ -1,4 +1,4 @@
Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
All rights reserved.
Permission to use, copy, modify, and/or distribute this software for any

View File

@@ -1,6 +1,6 @@
# Makefile for s6-boot
VERSION = $(git describe --tags| sed 's/-.*//g;s/^v//;')
VERSION = $$(git describe --tags| sed 's/-.*//g;s/^v//;')
PKGNAME = s6-boot
BINDIR_EXECLINE = /usr/local/bin
@@ -56,7 +56,9 @@ install:
install -m755 data/scripts/s6.local $(DESTDIR)/etc/s6/data/scripts/s6.local
ln -sf /etc/s6/data/scripts/s6.local $(DESTDIR)/etc/s6.local
install -m755 data/scripts/user.sh $(DESTDIR)/etc/s6/data/scripts/user.sh
install -m755 data/scripts/master.sh $(DESTDIR)/etc/s6/data/scripts/master.sh
install -m755 data/scripts/modules.sh $(DESTDIR)/etc/s6/data/scripts/modules.sh
install -m755 data/scripts/tmpfiles.sh $(DESTDIR)/etc/s6/data/scripts/tmpfiles.sh
cp -P -a compiled/default $(DESTDIR)/etc/s6/compiled/default
ln -sf /etc/s6/compiled/default $(DESTDIR)/etc/s6/compiled/current

27
NEWS
View File

@@ -1,5 +1,32 @@
Changelog for s6-boot
In 0.2.0
--------
- Bugs fix
- Improve udevd and udevadm service
- Umount NFS4 system if exist on stage2.tini
In 0.1.9
--------
- Bugs fix
In 0.1.8
--------
- add data/scripts/modules.sh : the variable MODULES at s6.conf was
removed. Modules are now loaded by this file with the rofs-modules
oneshot service which run the scripts data/scripts/modules.sh. This
scripts read, parse and load modules founded in files
/usr/lib/modules-load.d, /run/modules-load.d, and /etc/modules-load.d
the last supersedes the previous one.
- fix bug at rwfs-ip6tables at the shutdown process
- add rwfs-tmpfiles services : the file founded at /usr/lib/tmpfiles.d
is now parsed and applied at boot time. Those files create sub-directories
at /run directories.
- fix rwfs-end oneshot service
In 0.1.7
--------

View File

@@ -1,5 +1,5 @@
#compdef s6-svc
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -S0
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,14 +0,0 @@
#!@BINDIR@/bash
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
source /etc/obarun/s6opts.conf
if s6-svok ${LIVE_CLASSIC_PATH}/s6rc-fdholder; then
exec -c /usr/bin/agetty -J 38400 tty1
fi

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -8,4 +8,4 @@
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
/usr/bin/agetty --delay 02 -J 38400 tty2
/usr/bin/agetty --delay 02 -J 38400 tty6

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@@ -1,5 +1,5 @@
#!/usr/local/bin/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,14 +0,0 @@
#!/usr/local/bin/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
if { s6-echo -- udevd-udevadm started }
s6-devd
/usr/bin/udevadm settle

114
data/scripts/master.sh Executable file
View File

@@ -0,0 +1,114 @@
#!@BINDIR@/bash
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
exec 2>&1
exec 1>/var/log/master.log
log(){
printf "%s %s %s\n" "$(date +"%Y-%m-%d %H:%M:%S")" "${FUNCNAME[1]} ::" "${@}"
}
ENV="/etc/s6/env"
DEST=$(<${ENV}/DEST) #/run/boot
if ! source /etc/obarun/s6opts.conf; then
out_error "/etc/obarun/s6opts.conf not found, existing"
exit 1
else
SOURCE="/etc/obarun/s6opts.conf"
fi
GEN_NAME=$(<${ENV}/MASTER)
DEST_USER=$(<${ENV}/DEST)
LIVE_CLASSIC_PATH=${DEST_USER}/service
LIVE_RC_PATH=${DEST_USER}
LIST_SERV=$(ls ${CLASSIC_ENABLED})
add_env() {
local -a list_env=$(printenv)
local var value line list
log "mkdir ${DEST}/env"
mkdir -p -m 0755 ${DEST}/env
while read line;do
if [[ "${line:0:1}" == "#" ]] || [[ -z "${line}" ]];then
continue
fi
var=$(awk -F"=" '{print $1}' <<< "${line}")
value=${!var}
log "create new file ${var} with ${value} at ${DEST}/env/"
touch ${DEST}/env/"${var}"
echo "${value}" > ${DEST}/env/"${var}"
done < "${SOURCE}"
# need improvement
for list in ${list_env[@]};do
while read line;do
var=$(awk -F"=" '{print $1}' <<< "${line}")
value=${!var}
case "${var}" in
_|?|PWD|G_DEBUG) continue
;;
*)
log "create new file ${var} with ${value} at ${DEST}/env/"
touch ${DEST}/env/"${var}"
echo "${value}" > ${DEST}/env/"${var}"
;;
esac
done <<< "${list}"
done
for tidy_loop in GEN_NAME DEST_USER LIVE_CLASSIC_PATH LIVE_RC_PATH;do
var=${!tidy_loop}
log "create new file ${tidy_loop} with ${var} at ${DEST}/env"
touch ${DEST}/env/"${tidy_loop}"
echo "${var}" > ${DEST}/env/"${tidy_loop}"
done
unset list_env var value line list
}
# copy daemon enabled by USER
enabled_daemon() {
for serv in ${LIST_SERV[@]};do
log "enable daemon for ${serv}"
ln -sfT ${CLASSIC_ENABLED}/${serv} ${LIVE_CLASSIC_PATH}/${serv}
done
}
start_database() {
log "init s6-rc database with -l ${LIVE_RC_PATH}/${GEN_NAME} -c ${RC_DATABASE_COMPILED}/current ${LIVE_CLASSIC_PATH}"
s6-rc-init -l ${LIVE_RC_PATH}/${GEN_NAME} -c ${RC_DATABASE_COMPILED}/current -p ${GEN_NAME} ${LIVE_CLASSIC_PATH}
s6-rc -v 3 -l ${LIVE_RC_PATH}/${GEN_NAME} -u change All
}
start() {
#add_env || exit 1
enabled_daemon || exit 1
svscanctl -an "${LIVE_CLASSIC_PATH}" 2>/dev/null
start_database || exit 1
}
start

71
data/scripts/modules.sh Executable file
View File

@@ -0,0 +1,71 @@
#!@BINDIR@/bash
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
# Configuration files are read from directories in
# /usr/lib/modules-load.d, /run/modules-load.d, and /etc/modules-load.d,
# in order of precedence
MODULES_PATH=( "/etc/modules-load.d" "/run/modules-load.d" "/usr/lib/modules-load.d" )
MODULES_NAME=""
MODULES_RESULT=""
check_elements(){
for e in "${@:2}"; do [[ $e == $1 ]] && return 0; done; return 1;
}
check_file(){
local tidy_loop conf
for tidy_loop in ${MODULES_PATH[@]}; do
if [[ -d "${tidy_loop}" ]]; then
for conf in "${tidy_loop}"/*.conf ; do
check_elements ${conf##*/} ${MODULES_NAME[@]}
if (( $? )); then
MODULES_NAME+=("${conf##*/}")
fi
done
fi
done
unset tidy_loop conf
}
check_path(){
local path tidy_loop
for path in ${MODULES_PATH[@]}; do
for tidy_loop in ${MODULES_NAME[@]}; do
if [[ -f "${path}/${tidy_loop}" ]]; then
check_elements "${tidy_loop}" ${MODULES_RESULT[@]##*/}
if (( $? ));then
MODULES_RESULT+=("${path}/${tidy_loop}")
fi
fi
done
done
}
check_file
if [[ -n ${MODULES_NAME[@]} ]]; then
check_path
else
echo "rofs-modules :: Nothing to do"
exit 0
fi
for mod in ${MODULES_RESULT[@]}; do
while read line; do
if [[ "${line:0:1}" == "#" ]] || [[ -z "${line}" ]];then
continue
fi
for check in ${line};do
modprobe -b "${check}" -v | sed 's:insmod [^ ]*/:Load modules :g; s:\.ko\(\.gz\)\? ::g'
done
done < "${mod}"
done
exit 0

View File

@@ -1,4 +1,4 @@
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

411
data/scripts/tmpfiles.sh Executable file
View File

@@ -0,0 +1,411 @@
#!@BINDIR@/sh
# This is a reimplementation of the systemd tmpfiles.d code
# Control creation, deletion, and cleaning of volatile and temporary files
#
# Copyright (c) 2012 Gentoo Foundation
# Released under the 2-clause BSD license.
#
# This instance is a pure-POSIX sh version, written by Robin H Johnson
# <robbat2@gentoo.org>, based on the Arch Linux version as of 2012/01/01:
# http://projects.archlinux.org/initscripts.git/tree/arch-tmpfiles
#
# See the tmpfiles.d manpage as well:
# http://0pointer.de/public/systemd-man/tmpfiles.d.html
# This script should match the manpage as of 2012/03/12
#
# This file was modified by Eric Vidal <eric@obarun.org> for Obarun
DRYRUN=0
checkprefix() {
n=$1
shift
for x in $@; do
case $n in
${x}*) return 0 ;;
esac
done
return 1
}
warninvalid() {
printf "tmpfiles: ignoring invalid entry on line %d of \`%s'\n" "$LINENUM" "$FILE"
error=$(( error+1 ))
} >&2
dryrun_or_real() {
local dryrun=
[ $DRYRUN -eq 1 ] && dryrun=echo
$dryrun "$@"
}
relabel() {
local path
local paths=$1 mode=$2 uid=$3 gid=$4
for path in ${paths}; do
if [ -e "$path" ]; then
[ -x /sbin/restorecon ] && dryrun_or_real restorecon $CHOPTS "$path"
[ $uid != '-' ] && dryrun_or_real chown $CHOPTS "$uid" "$path"
[ $gid != '-' ] && dryrun_or_real chgrp $CHOPTS "$gid" "$path"
[ $mode != '-' ] && dryrun_or_real chmod $CHOPTS "$mode" "$path"
fi
done
}
splitpath() {
local path=$1
while [ -n "$path" ]; do
echo $path
path=${path%/*}
done
}
_restorecon() {
local path=$1
if [ -x /sbin/restorecon ]; then
dryrun_or_real restorecon -F $(splitpath "$path")
fi
}
_b() {
# Create a block device node if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
if [ ! -e "$path" ]; then
dryrun_or_real mknod -m $mode $path b ${arg%:*} ${arg#*:}
_restorecon "$path"
dryrun_or_real chown $uid:$gid $path
fi
}
_c() {
# Create a character device node if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
if [ ! -e "$path" ]; then
dryrun_or_real mknod -m $mode $path c ${arg%:*} ${arg#*:}
_restorecon "$path"
dryrun_or_real chown $uid:$gid $path
fi
}
_C() {
# recursively copy a file or directory
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
if [ ! -e "$path" ]; then
dryrun_or_real cp -r "$arg" "$path"
_restorecon "$path"
[ $uid != '-' ] && dryrun_or_real chown "$uid" "$path"
[ $gid != '-' ] && dryrun_or_real chgrp "$gid" "$path"
[ $mode != '-' ] && dryrun_or_real chmod "$mode" "$path"
fi
}
_f() {
# Create a file if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
[ $CREATE -gt 0 ] || return 0
if [ ! -e "$path" ]; then
#dryrun_or_real $CHECKPATH -fq -m "$mode" -o "$uid:$gid" "$path"
dryrun_or_real touch "$path"
dryrun_or_real chmod "$mode" "$path"
dryrun_or_real chown "$uid:$gid" "$path"
[ -z "$arg" ] || _w "$@"
fi
}
_F() {
# Create or truncate a file
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
[ $CREATE -gt 0 ] || return 0
if [ -e "$path" ]; then
[ -z "$arg" ] || _w "$@"
else
#dryrun_or_real $CHECKPATH -Fq -m "$mode" -o "$uid:$gid" "$path"
dryrun_or_real touch "$path"
dryrun_or_real chmod "$mode" "$path"
dryrun_or_real chown "$uid:$gid" "$path"
[ -z "$arg" ] || _w "$@"
fi
}
_d() {
# Create a directory if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4
[ $CREATE -gt 0 ] || return 0
if [ ! -d "$path" ]; then
dryrun_or_real mkdir -p "$path" 2>/dev/null
_restorecon "$path"
#dryrun_or_real $CHECKPATH -dq -m "$mode" -o "$uid:$gid" "$path"
dryrun_or_real chmod "$mode" "$path"
dryrun_or_real chown "$uid:$gid" "$path"
fi
}
_D() {
# Create or empty a directory
local path=$1 mode=$2 uid=$3 gid=$4
if [ -d "$path" ] && [ $REMOVE -gt 0 ]; then
dryrun_or_real find "$path" -mindepth 1 -maxdepth 1 -xdev -exec rm -rf {} +
_restorecon "$path"
fi
if [ $CREATE -gt 0 ]; then
dryrun_or_real mkdir -p "$path" 2>/dev/null
_restorecon "$path"
#dryrun_or_real $CHECKPATH -Dq -m "$mode" -o "$uid:$gid" "$path"
dryrun_or_real chmod "$mode" "$path"
dryrun_or_real chown "$uid:$gid" "$path"
fi
}
_v() {
# Create a subvolume if the path does not exist yet and the file system
# supports this (btrfs). Otherwise create a normal directory.
# TODO: Implement btrfs subvol creation.
_d "$@"
}
_L() {
# Create a symlink if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
[ ! -e "$path" ] && dryrun_or_real ln -s "$arg" "$path"
_restorecon "$path"
}
_p() {
# Create a named pipe (FIFO) if it doesn't exist yet
local path=$1 mode=$2 uid=$3 gid=$4
[ $CREATE -gt 0 ] || return 0
if [ ! -p "$path" ]; then
#dryrun_or_real $CHECKPATH -pq -m $mode -o "$uid:$gid" "$path"
dryrun_or_real mkfifo -m "$mode" "$path"
dryrun_or_real chown "$uid:$gid" "$path"
fi
}
_x() {
# Ignore a path during cleaning. Use this type to exclude paths from clean-up as
# controlled with the Age parameter. Note that lines of this type do not
# influence the effect of r or R lines. Lines of this type accept shell-style
# globs in place of of normal path names.
:
# XXX: we don't implement this
}
_X() {
# Ignore a path during cleanup. Use this type to prevent path
# removal as controled with the age parameter. Note that if path is
# a directory, the content of the directory is not excluded from
# clean-up, only the directory itself.
# Lines of this type accept shell-style globs in place of normal path names.
:
# XXX: we don't implement this
}
_r() {
# Remove a file or directory if it exists. This may not be used to remove
# non-empty directories, use R for that. Lines of this type accept shell-style
# globs in place of normal path names.
local path
local paths=$1
[ $REMOVE -gt 0 ] || return 0
for path in ${paths}; do
if [ -f "$path" ]; then
dryrun_or_real rm -f "$path"
elif [ -d "$path" ]; then
dryrun_or_real rmdir "$path"
fi
done
}
_R() {
# Recursively remove a path and all its subdirectories (if it is a directory).
# Lines of this type accept shell-style globs in place of normal path names.
local path
local paths=$1
[ $REMOVE -gt 0 ] || return 0
for path in ${paths}; do
[ -d "$path" ] && dryrun_or_real rm -rf --one-file-system "$path"
done
}
_w() {
# Write the argument parameter to a file, if it exists.
local path=$1 mode=$2 uid=$3 gid=$4 age=$5 arg=$6
if [ -f "$path" ]; then
if [ $DRYRUN -eq 1 ]; then
echo "echo \"$arg\" >>\"$path\""
else
echo "$arg" >>"$path"
fi
fi
}
_z() {
# Set ownership, access mode and relabel security context of a file or
# directory if it exists. Lines of this type accept shell-style globs in
# place of normal path names.
[ $CREATE -gt 0 ] || return 0
relabel "$@"
}
_Z() {
# Recursively set ownership, access mode and relabel security context of a
# path and all its subdirectories (if it is a directory). Lines of this type
# accept shell-style globs in place of normal path names.
[ $CREATE -gt 0 ] || return 0
CHOPTS=-R relabel "$@"
}
BOOT=0 CREATE=0 REMOVE=0 CLEAN=0 VERBOSE=0 DRYRUN=0 error=0 LINENO=0
EXCLUDE=
PREFIX=
FILE=
fragments=
# XXX: The harcoding of /usr/lib/ is an explicit choice by upstream
tmpfiles_dirs='/usr/lib/tmpfiles.d/ /run/tmpfiles.d/ /etc/tmpfiles.d/'
tmpfiles_basenames=''
tmpfiles_d=''
# Build a list of sorted unique basenames
# directories declared later in the tmpfiles_d array will override earlier
# directories, on a per file basename basis.
# `/etc/tmpfiles.d/foo.conf' supersedes `/usr/lib/tmpfiles.d/foo.conf'.
# `/run/tmpfiles/foo.conf' will always be read after `/etc/tmpfiles.d/bar.conf'
for d in ${tmpfiles_dirs} ; do
[ -d $d ] && for f in ${d}/*.conf ; do
case "${f##*/}" in
systemd.conf|systemd-*.conf) continue;;
esac
[ -f $f ] && tmpfiles_basenames="${tmpfiles_basenames}\n${f##*/}"
done # for f in ${d}
done # for d in ${tmpfiles_dirs}
tmpfiles_basenames="$(printf "${tmpfiles_basenames}\n" | sort -u )"
for b in $tmpfiles_basenames ; do
real_f=''
for d in $tmpfiles_dirs ; do
f=${d}/${b}
[ -f "${f}" ] && real_f=$f
done
[ -f "${real_f}" ] && tmpfiles_d="${tmpfiles_d} ${real_f}"
done
while [ $# -gt 0 ]; do
case $1 in
--boot) BOOT=1 ;;
--create) CREATE=1 ;;
--remove) REMOVE=1 ;;
--clean) CLEAN=1 ;; # TODO: Not implemented
--verbose) VERBOSE=1 ;;
--dryrun|--dry-run) DRYRUN=1 ;;
--exclude-prefix=*) EXCLUDE="${EXCLUDE}${1##--exclude-prefix=} " ;;
--prefix=*) PREFIX="${PREFIX}${1##--prefix=} " ;;
esac
shift
done
if [ $(( CLEAN )) -eq 1 ] ; then
printf '%s clean mode is not implemented\n' "${0##*/}"
exit 1
fi
if [ "$CREATE$REMOVE" = '00' ]; then
printf 'usage: %s [--exclude-prefix=path] [--prefix=path] [--boot] [--create] [--remove] [--clean] [--verbose] [--dry-run]\n' "${0##*/}"
exit 1
fi
error=0
# loop through the gathered fragments, sorted globally by filename.
# `/run/tmpfiles/foo.conf' will always be read after `/etc/tmpfiles.d/bar.conf'
for FILE in $tmpfiles_d ; do
LINENUM=0
### FILE FORMAT ###
# XXX: We ignore the 'Age' parameter
# 1 2 3 4 5 6 7
# Cmd Path Mode UID GID Age Argument
# d /run/user 0755 root root 10d -
# Mode, UID, GID, Age, Argument may be omitted!
# If Cmd ends with !, the line is only processed if --boot is passed
# XXX: Upstream says whitespace is NOT permitted in the Path argument.
# But IS allowed when globs are expanded for the x/r/R/z/Z types.
while read cmd path mode uid gid age arg; do
LINENUM=$(( LINENUM+1 ))
FORCE=0
# Unless we have both command and path, skip this line.
if [ -z "$cmd" -o -z "$path" ]; then
continue
fi
case $cmd in
\#*) continue ;;
esac
while [ ${#cmd} -gt 1 ]; do
case $cmd in
*!) cmd=${cmd%!}; [ "$BOOT" -eq "1" ] || continue 2 ;;
*+) cmd=${cmd%+}; FORCE=1; ;;
*) warninvalid ; continue 2 ;;
esac
done
# whine about invalid entries
case $cmd in
f|F|w|d|D|v|p|L|c|C|b|x|X|r|R|z|Z) ;;
*) warninvalid ; continue ;;
esac
# fall back on defaults when parameters are passed as '-'
if [ "$mode" = '-' -o "$mode" = '' ]; then
case "$cmd" in
p|f|F) mode=0644 ;;
d|D|v) mode=0755 ;;
C|z|Z|x|r|R|L) ;;
esac
fi
[ "$uid" = '-' -o "$uid" = '' ] && uid=0
[ "$gid" = '-' -o "$gid" = '' ] && gid=0
[ "$age" = '-' -o "$age" = '' ] && age=0
[ "$arg" = '-' -o "$arg" = '' ] && arg=''
set -- "$path" "$mode" "$uid" "$gid" "$age" "$arg"
[ -n "$EXCLUDE" ] && checkprefix $path $EXCLUDE && continue
[ -n "$PREFIX" ] && ! checkprefix $path $PREFIX && continue
if [ $FORCE -gt 0 ]; then
case $cmd in
p|L|c|b) [ -f "$path" ] && dryrun_or_real rm -f "$path"
esac
fi
[ "$VERBOSE" -eq "1" ] && echo _$cmd "$@"
_$cmd "$@"
rc=$?
if [ "${DRYRUN}" -eq "0" ]; then
[ $rc -ne 0 ] && error=$((error + 1))
fi
done <$FILE
done
exit $error
# vim: set ts=2 sw=2 sts=2 noet ft=sh:

View File

@@ -1,254 +0,0 @@
#!@BINDIR@/bash
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
exec 2>&1
exec 1>>/var/log/user.log
log(){
printf "%s %s %s\n" "$(date +"%Y-%m-%d %H:%M:%S")" "${FUNCNAME[1]} ::" "${@}"
}
# ${1} user name
# ${2} action to do, add or del
if [[ -z "${1}" ]] || [[ -z "${2}" ]];then
log "handle-user :: Missing arguments, existing"
exit 1
fi
if [[ "${1}" == "root" ]]; then
log "root user, nothing to do, exiting 0"
exit 0
fi
ENV="/etc/s6/env"
DEST=$(head -n1 ${ENV}/DEST) #/run/boot
TEMPLATE=$(head -n1 ${ENV}/TEMPLATE) #/usr/share/obarun/s6opts/template
SOURCE=""
USER="${1}"
# special case here, adduser scipts call
# user.sh with boot as user, but this user
# doesn't exist, wrap the uid,gid to root
if [[ "${USER}" == "boot" ]]; then
_UID=$(id -u 0)
_GID=$(id -g 0)
else
_UID=$(id -u ${USER})
_GID=$(id -g ${USER})
fi
# overwrite conf if connected with user
if ! (( "${_UID}" == 0 )); then
if ! source $(getent passwd ${USER}|cut -d : -f 6)/service/service.conf 2>/dev/null; then
out_error "$(getent passwd ${USER}|cut -d : -f 6)/service/service.conf doesn't exist"
out_error "Use s6opts user command first"
exit 1
else
SOURCE="$(getent passwd ${USER}|cut -d : -f 6)/service/service.conf"
fi
elif ! source /etc/obarun/s6opts.conf; then
out_error "/etc/obarun/s6opts.conf not found, existing"
exit 1
else
SOURCE="/etc/obarun/s6opts.conf"
fi
# at this point, the good .conf file is sourced
# we know all needed variables
# do not pass if DEST_USER already exist
if [[ -d "${DEST_USER}" ]] && [[ "${2}" == "add" ]]; then
log "${DEST_USER} already exist, nothing to do"
exit 0
fi
LIST_SERV=$(ls ${CLASSIC_ENABLED})
# coming from boot time? so respect the choice of the .conf files
# and change the name of USER variable.
if [[ "${USER}" == "boot" ]]; then
USER="${DEST_USER##*/}"
fi
copy_template() {
log "mkdir ${DEST}/service/${USER}/{log,env}"
mkdir -p -m 0755 ${DEST}/service/${USER}/{log,env}
log "s6-hiercopy from ${TEMPLATE}/base/ to ${DEST}/service/${USER}"
/usr/bin/s6-hiercopy ${TEMPLATE}/base/run ${DEST}/service/${USER}/run
/usr/bin/s6-hiercopy ${TEMPLATE}/base/log ${DEST}/service/${USER}/log
/usr/bin/s6-hiercopy ${TEMPLATE}/base/env ${DEST}/service/${USER}/env
}
parse_env() {
local named
log "replace base by ${USER} at LOG,run,log/run files"
for named in ${DEST}/service/${USER}/env/LOG ${DEST}/service/${USER}/{run,log/run}; do
sed -i "s:base:${USER}:g" $named
done
unset named
}
add_env() {
local -a list_env=$(printenv)
local var value line list
while read line;do
if [[ "${line:0:1}" == "#" ]] || [[ -z "${line}" ]];then
continue
fi
var=$(awk -F"=" '{print $1}' <<< "${line}")
value=$(echo ${!var})
log "create new file ${var} with ${value} at ${DEST}/service/${USER}/env/"
touch ${DEST}/service/${USER}/env/"${var}"
echo "${value}" > ${DEST}/service/${USER}/env/"${var}"
done < "${SOURCE}"
#special env need to be create
log "create new file USER with ${USER} at ${DEST}/service/${USER}/env/"
touch ${DEST}/service/${USER}/env/USER
echo "${USER}" > ${DEST}/service/${USER}/env/USER
log "create new file UID with ${_UID} at ${DEST}/service/${USER}/env/"
touch ${DEST}/service/${USER}/env/UID
echo "${_UID}" > ${DEST}/service/${USER}/env/UID
log "create new file GID with ${_GID} at ${DEST}/service/${USER}/env/"
touch ${DEST}/service/${USER}/env/UID
echo "${_GID}" > ${DEST}/service/${USER}/env/GID
#su -l "${USER}" -c 'env'
# need improvement
for list in ${list_env[@]};do
while read line;do
var=$(awk -F"=" '{print $1}' <<< "${line}")
value=$(echo ${!var})
case "${var}" in
_|?|GID|UID|PWD|G_DEBUG|LOG) continue
;;
*)
log "create new file ${var} with ${value} at ${DEST}/service/${USER}/env/"
touch ${DEST}/service/${USER}/env/"${var}"
echo "${value}" > ${DEST}/service/${USER}/env/"${var}"
;;
esac
done <<< "${list}"
done
unset list_env var value line list
}
create_destuser() {
local tidy
log "create ${DEST_USER} directory"
mkdir -p ${DEST_USER}
log "create ${LIVE_CLASSIC_PATH} directory"
mkdir -p ${LIVE_CLASSIC_PATH}/.s6-svscan
log "create ${LIVE_RC_PATH} directory"
mkdir -p ${LIVE_RC_PATH}
log "copy ${TEMPLATE}/base/.s6-svscan to ${LIVE_CLASSIC_PATH}}/.s6-svscan"
/usr/bin/s6-hiercopy ${TEMPLATE}/base/.s6-svscan ${LIVE_CLASSIC_PATH}/.s6-svscan
# parse all SIG* file to point to the right place
for tidy in ${LIVE_CLASSIC_PATH}/.s6-svscan/{SIG{HUP,INT,QUIT,TERM,USR1,USR2},finish,crash}; do
log "change base by ${USER} at $tidy"
sed -i "s:base:${USER}:g" $tidy
done
log "change owner and permissions of ${DEST_USER} directory"
chown -R ${_UID}:root ${DEST_USER}
chmod 755 -R ${DEST_USER}
unset tidy
}
# copy daemon enabled by USER
enabled_daemon() {
log "enable daemon for $USER"
for serv in ${LIST_SERV[@]};do
ln -sfT ${CLASSIC_ENABLED}/${serv} ${LIVE_CLASSIC_PATH}/${serv}
done
}
start_database() {
log "init s6-rc database"
if [[ "${_UID}" == 0 ]]; then
s6-rc-init -l ${LIVE_RC_PATH}/${LIVE_RC_NAME} -c ${RC_DATABASE_COMPILED}/current ${LIVE_CLASSIC_PATH}
s6-rc -v 3 -l ${LIVE_RC_PATH}/${LIVE_RC_NAME} -u change All
else
su ${USER} -c "s6-rc-init -l ${LIVE_RC_PATH}/${LIVE_RC_NAME} -c ${RC_DATABASE_COMPILED}/current ${LIVE_CLASSIC_PATH}"
su ${USER} -c "s6-rc -v 3 -l ${LIVE_RC_PATH}/${LIVE_RC_NAME} -u change All"
fi
}
# ${1} s6 program
# ${2} command to pass
# ${3} target
s6_cmd() {
local prog="${1}" cmd="${2}" target="${3}"
log "do a s6-${prog} -${cmd} ${target} command"
eval s6-"${prog}" -"${cmd}" "${target}"
unset prog cmd target
}
add() {
copy_template || exit 1
parse_env || exit 1
add_env || exit 1
create_destuser || exit 1
s6_cmd "svscanctl" "an" "${DEST}/service" || exit 1
enabled_daemon || exit 1
s6_cmd "svscanctl" "an" "${DESTUSER}/${USER}/${DESTCLASSIC}" 2>/dev/null || exit 1
start_database || exit 1
}
del() {
s6_cmd "svc" "wD -d -T2000" "${DEST}/service/${USER}"
if ! [[ -z $(s6-svstat ${DEST}/service/${USER}|grep down) ]];then
s6_cmd "svc" "kO" "${DEST}/service/${USER}"
fi
log "remove ${DEST}/service/${USER} directory"
rm -rf "${DEST}/service/${USER}/"
s6_cmd "svscanctl" "an" "${DEST}/service/"
log "remove ${DEST_USER} directory"
rm -rf "${DEST_USER}"
}
case "${2}" in
add)
add
;;
del)
del
;;
*)
exit 1
;;
esac

1
env/MASTER vendored Normal file
View File

@@ -0,0 +1 @@
master-

8
init
View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -10,10 +10,10 @@
# Export good path
/usr/bin/s6-envdir -if /etc/s6/env
/usr/local/bin/importas -i PATH PATH
/usr/local/bin/export PATH ${PATH}
@BINDIR_EXECLINE@/importas -i PATH PATH
@BINDIR_EXECLINE@/export PATH ${PATH}
/usr/local/bin/cd /
@BINDIR_EXECLINE@/cd /
# Be clean and safe
emptyenv -p

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,3 +1,4 @@
00
all-Boot
adduser
tty

View File

@@ -11,6 +11,6 @@
fdmove -c 2 1
importas -i HANDLE HANDLE
if { s6-echo -- start adduser }
if { ${HANDLE}/user.sh "boot" add }
if { ${HANDLE}/master.sh }
s6-echo -- adduser started successfully

View File

@@ -10,3 +10,4 @@ rwfs-cleanboot
rwfs-end
rwfs-dmesglog
rwfs-s6local
rwfs-tmpfiles

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,3 +1,3 @@
udevd-udev
udevd-udevrules
udevd-udevadm

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -9,7 +9,7 @@
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
foreground {
if { s6-echo "unmounting cgroup" }
redirfd -r 0 /proc/cgroups
pipeline { s6-tail -n +2 }
pipeline { s6-cut -d"\t" -f1 }
@@ -18,5 +18,4 @@ foreground {
importas -ui i i
if { mountpoint -q /sys/fs/cgroup/${i} }
umount -R /sys/fs/cgroup/${i}
}
umount /sys/fs/cgroup

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -9,19 +9,22 @@
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
importas -i S6CONF S6CONF
if { s6-echo -- rofs-console started }
importas -i S6CONF S6CONF
s6-envdir ${S6CONF}
importas -D "" TTY TTY
importas -D "" KEYMAP KEYMAP
importas -D "" FONT FONT
importas -D "" FONT_MAP FONT_MAP
importas -D "" FONT_UNIMAP FONT_UNIMAP
foreground {
forbacktickx index { seq ${TTY} }
importas -u -D "" index index
bash -c "setfont ${FONT_MAP:+-m $FONT_MAP} ${FONT_UNIMAP:+-u $FONT_UNIMAP} $FONT -C /dev/tty${index}"
}
# special case for the earlier tty
foreground { bash -c "setfont ${FONT_MAP:+-m $FONT_MAP} ${FONT_UNIMAP:+-u $FONT_UNIMAP} $FONT -C /dev/tty6" }
foreground {
loadkeys -q -u $KEYMAP
}
foreground {
forx index { 0 1 2 3 4 5 6 7 8 9 10 }
importas -u -D "" index index
exec bash -c "setfont ${FONT_MAP:+-m $FONT_MAP} ${FONT_UNIMAP:+-u $FONT_UNIMAP} $FONT -C /dev/tty${index}"
}
s6-echo -- rofs-console successfully started

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -9,17 +9,7 @@
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
importas -i S6CONF S6CONF
ifelse -X { s6-test -e ${S6CONF}/MODULES }
{
importas -i HANDLE HANDLE
if { s6-echo -- rofs-modules started }
redirfd -r 0 ${S6CONF}/MODULES
forstdin -n -- mods
importas -ui mods mods
foreground {
if { s6-test -n $mods }
modprobe -ab $mods
}
foreground { ${HANDLE}/modules.sh }
s6-echo -- rofs-modules successfully started
}
s6-echo -- rofs-modules desactived

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -7,3 +7,4 @@
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
s6-true

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -13,9 +13,10 @@ importas -i S6CONF S6CONF
s6-envdir ${S6CONF}
importas -D "" IP6TABLES IP6TABLES
if { s6-test $IP6TABLES = yes }
foreground {
ifelse -X { s6-test $IP6TABLES = yes }
{
if { s6-echo -- Flushing ip6tables }
/usr/lib/iptables/scripts/iptables-flush 6
}
foreground { /usr/lib/iptables/scripts/iptables-flush 6 }
s6-echo -- Ip6tables flushed
}
s6-echo -- Ip6tables not actived

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -0,0 +1 @@
rwfs-s6local

View File

@@ -9,6 +9,7 @@
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
if { s6-echo -- udevd-udevadm started }
s6-devd
/usr/bin/udevadm settle
importas -i HANDLE HANDLE
if { s6-echo rwfs-tmpfiles started }
foreground { exec -c ${HANDLE}/tmpfiles.sh --create --verbose }
s6-echo -- rwfs-tmpfiles successfully started

1
rc/tty/dependencies Normal file
View File

@@ -0,0 +1 @@
adduser

1
rc/tty/type Normal file
View File

@@ -0,0 +1 @@
oneshot

30
rc/tty/up Normal file
View File

@@ -0,0 +1,30 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
# the LICENSE file found in the top-level directory of this
# distribution and at https://github.com/Obarun/s6-boot/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.
fdmove -c 2 1
if { s6-echo -- tty started }
importas -i DEST DEST
importas -i S6CONF S6CONF
s6-envdir ${S6CONF}
importas -D "" TTY TTY
foreground {
forbacktickx index { seq ${TTY} }
importas -i index index
if { mkdir -p ${DEST}/service/tty${index} }
foreground {
redirfd -a 1 ${DEST}/service/tty${index}/run
s6-echo --
"#!/usr/bin/bash
/usr/bin/agetty -J 38400 tty${index}"
}
s6-chmod 0755 ${DEST}/service/tty${index}/run
}
if { s6-svscanctl -an ${DEST}/service }
s6-echo -- tty successfully started

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,2 +1,2 @@
udevd-udev
udevd-udevrules

View File

@@ -1 +1 @@
longrun
oneshot

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -10,8 +10,9 @@
fdmove -c 2 1
if { s6-echo -- udevd-udevrules started }
foreground {
if { udevadm trigger --action=add --type=subsystems }
udevadm trigger --action=add --type=devices
if {
foreground { udevadm trigger --action=add --type=subsystems }
foreground { udevadm trigger --action=add --type=devices }
udevadm settle
}
s6-echo -- udevd-udevrules successfully started

View File

@@ -1,2 +0,0 @@
udevd-udev

2
reboot
View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -P
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,4 +1,4 @@
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -38,6 +38,10 @@ HARDWARECLOCK=UTC
# Set timezone, availables timezones at /usr/share/zoneinfo.
TZ=GMT
# Number of tty to start.
# The number MUST be included between 1-5.
TTY=2
# Keymap to load, see loadkeys(8), default us.
KEYMAP=us
@@ -50,9 +54,6 @@ FONT=lat9w-16
# Font unimap to load, see setfont(8).
#FONT_UNIMAP=
#Modules, the list must be separate by space e.g. MODULES=vboxdrv i915 loop#
#MODULES=
# Use Iptables [yes|no]
# The configuration file in /etc/iptables/iptables.rules MUST exist
IPTABLES=no

View File

@@ -1,5 +1,5 @@
#!@BINDIR@/bash
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in

View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -S0
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in
@@ -9,14 +9,17 @@
# except according to the terms contained in the LICENSE file.
s6-envdir -if /etc/s6/env
importas -i DEST DEST
importas -i DESTRC DESTRC
importas -i S6CONF S6CONF
importas -i MASTER MASTER
if { s6-echo -- "***************************************************************************" }
if { s6-echo -- "** Start Tini shutdown **" }
if { s6-echo -- "***************************************************************************" }
cd /
foreground { s6-rc -v 3 -l ${DESTRC} -da change }
foreground { s6-rc -v 3 -l ${DEST}/${MASTER} -da change }
s6-envdir -if ${S6CONF}
@@ -26,6 +29,12 @@ foreground {
if { s6-echo -- Cleaning /tmp directory }
rm -rf /tmp/
}
foreground {
if { s6-test -x /usr/bin/mountstats }
if -X { mountstats }
if { s6-echo Umount NFS filesystem }
umount -a -f -t nfs4
}
if { s6-echo -- "***************************************************************************" }
if { s6-echo -- "** Tini shutdown terminated **" }

2
stage3
View File

@@ -1,5 +1,5 @@
#!@BINDIR_EXECLINE@/execlineb -S0
# Copyright (c) 2015-2017 Eric Vidal <eric@obarun.org>
# Copyright (c) 2015-2018 Eric Vidal <eric@obarun.org>
# All rights reserved.
#
# This file is part of Obarun. It is subject to the license terms in