aboutsummaryrefslogtreecommitdiff
path: root/init.d/urandom.in
blob: cda431fdb3f41e282fdc3e4c4da90fd919db96e9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!@SBINDIR@/openrc-run
# Copyright (c) 2007-2022 The OpenRC Authors.
# See the Authors file at the top-level directory of this distribution and
# https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS
#
# This file is part of OpenRC. 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/OpenRC/openrc/blob/HEAD/LICENSE
# This file may not be copied, modified, propagated, or distributed
# except according to the terms contained in the LICENSE file.

export SEEDRNG_SEED_DIR="${seed_dir:-/var/lib/seedrng}"
export SEEDRNG_LOCK_FILE="${lock_file:-/var/run/seedrng.lock}"
export SEEDRNG_SKIP_CREDIT="${skip_credit:-false}"
: ${urandom_seed:=${SEEDRNG_SEED_DIR}/../misc/random-seed}
description="Initializes the random number generator."

depend()
{
	after clock
	need localmount
	keyword -docker -jail -lxc -openvz -prefix -systemd-nspawn
}

save_seed()
{
	(	# sub shell to prevent umask pollution
		umask 077
		dd if=/dev/urandom of="$urandom_seed" count=1 2>/dev/null
	)
}

start()
{
	if [ "$RC_UNAME" = Linux ]; then
		seedrng
	else
		[ -c /dev/urandom ] || return
		if [ -f "$urandom_seed" ]; then
			ebegin "Initializing random number generator"
			cat "$urandom_seed" > /dev/urandom
			eend $? "Error initializing random number generator"
		fi
		rm -f "$urandom_seed" && save_seed
	fi
	return 0
}

stop()
{
	if [ "$RC_UNAME" = Linux ]; then
		seedrng
	else
		ebegin "Saving random seed"
		save_seed
		eend $? "Failed to save random seed"
	fi
}