forked from ungleich-public/cdist
new type: __hosts
This type adds or removes entries from /etc/hosts, ensuring that same hostname can never resolve to several different ip addresses. Signed-off-by: Dmitry Bogatov <KAction@gnu.org>
This commit is contained in:
parent
7e57575f9e
commit
88ec06d06f
4 changed files with 107 additions and 0 deletions
55
cdist/conf/type/__hosts/man.rst
Normal file
55
cdist/conf/type/__hosts/man.rst
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
cdist-type__hosts(7)
|
||||||
|
====================
|
||||||
|
|
||||||
|
NAME
|
||||||
|
----
|
||||||
|
|
||||||
|
cdist-type__hosts - manage entries in /etc/hosts
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
-----------
|
||||||
|
|
||||||
|
Add or remove entries from */etc/hosts* file.
|
||||||
|
|
||||||
|
OPTIONAL PARAMETERS
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
state
|
||||||
|
|
||||||
|
If state is ``present``, make *object_id* resolve to *ip*. If
|
||||||
|
state is ``absent``, *object_id* will no longer resolve to
|
||||||
|
anything via */etc/hosts*.
|
||||||
|
|
||||||
|
ip
|
||||||
|
|
||||||
|
IP address, to which hostname (=\ *object_id*) must resolve. If
|
||||||
|
state is ``present``, this parameter is mandatory, if state is
|
||||||
|
``absent``, this parameter is silently ignored.
|
||||||
|
|
||||||
|
EXAMPLES
|
||||||
|
--------
|
||||||
|
|
||||||
|
.. code-block:: sh
|
||||||
|
|
||||||
|
# Now `funny' resolves to 192.168.1.76,
|
||||||
|
__hosts funny --ip 192.168.1.76
|
||||||
|
# and `happy' does not resolve (at least via /etc/hosts)
|
||||||
|
__hosts happy --state absent
|
||||||
|
|
||||||
|
SEE ALSO
|
||||||
|
--------
|
||||||
|
|
||||||
|
:strong:`hosts`\ (5)
|
||||||
|
|
||||||
|
AUTHORS
|
||||||
|
-------
|
||||||
|
|
||||||
|
Dmitry Bogatov <KAction@gnu.org>
|
||||||
|
|
||||||
|
|
||||||
|
COPYING
|
||||||
|
-------
|
||||||
|
|
||||||
|
Copyright (C) 2015,2016 Dmitry Bogatov. Free use of this software is granted
|
||||||
|
under the terms of the GNU General Public License version 3 or later
|
||||||
|
(GPLv3+).
|
49
cdist/conf/type/__hosts/manifest
Executable file
49
cdist/conf/type/__hosts/manifest
Executable file
|
@ -0,0 +1,49 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2015 Bogatov Dmitry <KAction@gnu.org>
|
||||||
|
#
|
||||||
|
# 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 <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
hostname="$__object_id"
|
||||||
|
state="$(cat "$__object/parameter/state")"
|
||||||
|
|
||||||
|
# First remove all lines for given hostname and then insert again.
|
||||||
|
# Otherwise, we risk having multiple entries for same hostname.
|
||||||
|
#
|
||||||
|
# There is a corner case, which we do not handle. Namely, /etc/hosts
|
||||||
|
# format allows several host names on single line, like following:
|
||||||
|
#
|
||||||
|
# 192.168.15.16 foo bar
|
||||||
|
#
|
||||||
|
# If this type manages hostname `foo', then hostname bar will get erased.
|
||||||
|
|
||||||
|
__line "__hosts/delete/${hostname}" \
|
||||||
|
--state absent \
|
||||||
|
--regex " ${hostname}[ ]*$" \
|
||||||
|
--file /etc/hosts
|
||||||
|
export require="__line/__hosts/delete/${hostname}"
|
||||||
|
|
||||||
|
case "$state" in
|
||||||
|
absent)
|
||||||
|
: # Nothing to do
|
||||||
|
;;
|
||||||
|
present)
|
||||||
|
ip="$(cat "$__object/parameter/ip")"
|
||||||
|
__line "__hosts/insert/${hostname}" \
|
||||||
|
--line "${ip} ${hostname}" \
|
||||||
|
--file /etc/hosts
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "ERROR: type (${__type##*/}) does not support state \`$state'"
|
||||||
|
exit 1
|
||||||
|
esac
|
1
cdist/conf/type/__hosts/parameter/default/state
Normal file
1
cdist/conf/type/__hosts/parameter/default/state
Normal file
|
@ -0,0 +1 @@
|
||||||
|
present
|
2
cdist/conf/type/__hosts/parameter/optional
Normal file
2
cdist/conf/type/__hosts/parameter/optional
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
state
|
||||||
|
ip
|
Loading…
Reference in a new issue