public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-commits] repo/gentoo:master commit in: net-dns/pdnsd/files/
@ 2016-05-03  9:47 Lars Wendler
  0 siblings, 0 replies; 3+ messages in thread
From: Lars Wendler @ 2016-05-03  9:47 UTC (permalink / raw
  To: gentoo-commits

commit:     0cc1a884a37645ec1c29e6286a5cddd8e983c418
Author:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
AuthorDate: Tue May  3 09:29:28 2016 +0000
Commit:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
CommitDate: Tue May  3 09:47:27 2016 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0cc1a884

net-dns/pdnsd: Fixed openrc init script shebang.

Package-Manager: portage-2.2.28
Signed-off-by: Lars Wendler <polynomial-c <AT> gentoo.org>

 net-dns/pdnsd/files/pdnsd.rc8 | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/net-dns/pdnsd/files/pdnsd.rc8 b/net-dns/pdnsd/files/pdnsd.rc8
index 0c10698..1e16a78 100644
--- a/net-dns/pdnsd/files/pdnsd.rc8
+++ b/net-dns/pdnsd/files/pdnsd.rc8
@@ -1,5 +1,5 @@
-#!/sbin/runscript
-# Copyright 1999-2014 Gentoo Foundation
+#!/sbin/openrc-run
+# Copyright 1999-2016 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 # $Id$
 


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* [gentoo-commits] repo/gentoo:master commit in: net-dns/pdnsd/files/
@ 2019-05-11 18:59 Lars Wendler
  0 siblings, 0 replies; 3+ messages in thread
From: Lars Wendler @ 2019-05-11 18:59 UTC (permalink / raw
  To: gentoo-commits

commit:     32cff8a391c1cfda9bfccdf42f6a72d31f85cd68
Author:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
AuthorDate: Sat May 11 18:59:41 2019 +0000
Commit:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
CommitDate: Sat May 11 18:59:41 2019 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=32cff8a3

net-dns/pdnsd: sleep only accepts integers in POSIX mode

Package-Manager: Portage-2.3.66, Repoman-2.3.12
Signed-off-by: Lars Wendler <polynomial-c <AT> gentoo.org>

 net-dns/pdnsd/files/pdnsd.online.2 | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/net-dns/pdnsd/files/pdnsd.online.2 b/net-dns/pdnsd/files/pdnsd.online.2
index 089f4e76e9c..be33bfaa03e 100644
--- a/net-dns/pdnsd/files/pdnsd.online.2
+++ b/net-dns/pdnsd/files/pdnsd.online.2
@@ -1,5 +1,5 @@
 #!/sbin/openrc-run
-# Copyright 1999-2012 Gentoo Foundation
+# Copyright 1999-2019 Gentoo Authors
 # Distributed under the terms of the GNU General Public License v2
 
 command="/usr/sbin/pdnsd-ctl"
@@ -10,10 +10,10 @@ depend() {
 
 wait_for_socket() {
 	local i=0 pdnsd_socket="/var/cache/pdnsd/pdnsd.status"
-	while [ $i -lt 10 ]; do
+	while [ ${i} -lt 10 ]; do
 		[ -S "${pdnsd_socket}" ] && return 0
-		i=$(($i+1))
-		sleep 1s
+		i=$((${i}+1))
+		sleep 1
 	done
 
     	return 1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* [gentoo-commits] repo/gentoo:master commit in: net-dns/pdnsd/files/
@ 2021-02-17 19:33 Conrad Kostecki
  0 siblings, 0 replies; 3+ messages in thread
From: Conrad Kostecki @ 2021-02-17 19:33 UTC (permalink / raw
  To: gentoo-commits

commit:     58e6093d9c9898b1fd1e110536a47229ceb3cc18
Author:     Michael Mair-Keimberger <mmk <AT> levelnine <DOT> at>
AuthorDate: Wed Feb 17 16:13:34 2021 +0000
Commit:     Conrad Kostecki <conikost <AT> gentoo <DOT> org>
CommitDate: Wed Feb 17 19:32:52 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=58e6093d

net-dns/pdnsd: remove unused patch

Closes: https://github.com/gentoo/gentoo/pull/19501
Package-Manager: Portage-3.0.14, Repoman-3.0.2
Signed-off-by: Michael Mair-Keimberger <mmk <AT> levelnine.at>
Signed-off-by: Conrad Kostecki <conikost <AT> gentoo.org>

 net-dns/pdnsd/files/pdnsd.resolvconf-r1 | 631 --------------------------------
 1 file changed, 631 deletions(-)

diff --git a/net-dns/pdnsd/files/pdnsd.resolvconf-r1 b/net-dns/pdnsd/files/pdnsd.resolvconf-r1
deleted file mode 100644
index edc1c9994f0..00000000000
--- a/net-dns/pdnsd/files/pdnsd.resolvconf-r1
+++ /dev/null
@@ -1,631 +0,0 @@
-#!/bin/bash
-# Copyright 2006 Gentoo Foundation
-# Distributed under the terms of the GNU General Public License v2
-
-# /etc/pdnsd/pdnsd.conf updater
-# Written by Oldrich Jedlicka (oldium.pro@seznam.cz)
-
-# Implementation notes:
-# * The assumptions are same as for other scripts like bind and dnsmasq:
-#   - We assume that we are a local dns cache - after all, why would a server
-#     use resolvconf?
-#   - Now that we have assumed this, we also assume that generic DHCP clients
-#     will enter their domains and search domains ONLY in the "search" field
-#     in their resolv.confs and VPN clients will put the domain they are for
-#     into the domain field only.
-#   - This allows pdnsd to forward domains for a specific VPN domain to the
-#     VPN nameserver and everything else to the standard name servers.
-#
-# HOW-TO CONFIGURE:
-#
-# To get this working, you need to do only two steps
-#
-# 1. Create a basic configuration of /etc/pdnsd/pdnsd.conf, you can use
-#    /etc/pdnsd/pdnsd.conf.example to start.
-#
-#    Additional configuration will be created automatically be resolvconf.
-#    The generated server sections has labels starting with "resolvconf", so
-#
-#        DO NOT USE "resolvconf" IN YOUR LABELS!
-#
-#    Check if the status_ctl is set to "on", otherwise the configuration
-#    will not be automatically reloaded - see sample config file.
-#
-#    You are free to edit automatically created server sections, but always
-#    write one option per line. There are few options that are always recreated
-#    and your changes in them will be lost. Here is the list (with example
-#    values):
-#
-#        preset=on;
-#        ip="192.168.0.1","192.168.0.2";
-#        include=".net",".com";'
-#
-#    The exclude directive in "resolvconf" server section is partly recreated.
-#    Known (configured) domains in the form ".<domain>" or ".<domain>." are
-#    added and removed automatically, unknown domains (also those not in 
-#    the format above) found in this directive are kept.
-#
-#    The sample configuration file /etc/pdnsd/pdnsd.conf prepared to work
-#    with resolvconf would look like this:
-#
-#global {
-#	perm_cache=2048;
-#	run_as="pdnsd";
-#	status_ctl = on;   # Important to enable status control
-#	run_ipv4=on;
-#	par_queries=2;     # How many servers are probed in parallel
-#	interface = "lo";  # Interface on which the pdnsd listens
-#}
-#
-# 2. The last step is to configure dns configuration for /etc/resolv.conf
-#    for the lo interface. In Gentoo we set it up like so in /etc/conf.d/net
-#
-#      dns_servers_lo=( "127.0.0.1" )
-
-# pdnsd config file
-PDNSDCONFIG="/etc/pdnsd/pdnsd.conf"
-
-# Backup suffix
-BACKUPSUFFIX=".backup"
-
-# Load our variables from resolvconf
-VARS="$(resolvconf -v)"
-eval "${VARS}"
-
-COMMENT='
-# Automatically generated by resolvconf.
-#
-# Following server sections are automatically enabled and disabled.
-#
-# !!! WARNING !!!
-# DO NOT RENAME LABELS!
-#
-# No section will be deleted and only some options are automatically changed.
-# Feel free to add your own options, but do not use pair comments /* */ as they
-# are not recognised.
-#
-# DO NOT USE resolvconf ANYWHERE IN YOUR LABELS!
-#
-# Automatically changed options are (with examples):
-#   preset=on;
-#   ip="192.168.0.1","192.168.0.2";
-#   include=".net",".com";
-#   exclude=".domain.net",".domain.com";
-#   policy=excluded;
-#
-# The exclude directive is changed automatically only in "resolvconf" server
-# section. Not handled servers are kept in the directive.
-#'
-BASIC_SETTINGS='server {
-	label="resolvconf";
-	preset=off;
-}'
-
-INSTALLATION_CHECK='^[[:space:]]*label[[:space:]]*=[[:space:]]*"resolvconf"'
-
-###
-# Sed script configuration
-#
-# Composed sequence of lines:
-#
-# (1) SED_LOOP with @MATCH_LABELS@ substituted by several SED_MATCH_ONE_LABEL
-# (2) SED_EDIT_ONE_SERVER several times
-# (3) SED_ADDING with new servers
-#
-# Notes:
-#
-# * @LABEL@ is a string "resolvconf-<domain>" or "resolvconf" for global
-#   section
-# * @RULE@ is @LABEL@ with translated characters '-' and '.' into '_'.
-###
-
-###
-# Main loop with label match - it will redirect the processing to
-# SED_EDIT_ONE_SERVER, when the label match is found. Special match is
-# for "resolvconf" label - the control flow is redirected to SED_ADDING to
-# allow adding new sections.
-#
-# To summarize: Old sections are edited as they appear in the file and new
-# sections are added before the "resolvconf" section.
-SED_LOOP=\
-'/^[[:space:]]*server[[:space:]]*[\{]/ b server;
-p; d;
-:server; h;
-:server_loop; n;
-/^[[:space:]]*server[[:space:]]*[\{]/ { x; p; b server_loop; };
-@MATCH_LABELS@
-/^[[:space:]]*label[[:space:]]*=[[:space:]]*"resolvconf"/ { H; b adding; };
-/^[[:space:]]*[\}]/ { H; x; p; d; };
-H;
-b server_loop;
-'
-
-###
-# Match for one label with a jump to SED_EDIT_ONE_SERVER
-SED_MATCH_ONE_LABEL=\
-'/^[[:space:]]*label[[:space:]]*=[[:space:]]*"@LABEL@"/ { H; x; b main_@RULE@; };
-'
-
-###
-# Editing one server. New lines are put into @SETUP@, lines are composed
-# in function compose_lines(). After the new lines are added, all "preset",
-# "ip" and "include" options are removed (not printed).
-#
-# Sanity checks: Check if there is a second label or another server directive.
-# In both cases, there is some error in the file, so go to the beginning by
-# jumping to SED_LOOP's :server.
-SED_EDIT_ONE_SERVER=\
-':main_@RULE@;
-p; @SETUP@
-:loop_@RULE@;
-n;
-/^[[:space:]]*server[[:space:]]*[\{]/ b server;
-/^[[:space:]]*label[[:space:]]*=/ b server;
-/^[[:space:]]*preset[[:space:]]*=/ b loop_@RULE@;
-/^[[:space:]]*ip[[:space:]]*=/ b loop_@RULE@;
-/^[[:space:]]*include[[:space:]]*=/ b loop_@RULE@;
-/^[[:space:]]*policy[[:space:]]*=/ b loop_@RULE@;
-/^[[:space:]]*exclude[[:space:]]*=/ b exclude_logic_@RULE;
-p;
-/^[[:space:]]*[\}]/ d;
-b loop_@RULE@;
-
-:exclude_logic_@RULE;
-@EXCLUDE_LOGIC@
-b loop_@RULE@;
-'
-
-###
-# Add new servers. All lines composed by function compose_lines() are put into
-# @SETUP@. Then the control flow is returned to one special SED_EDIT_ONE_SERVER
-# section with label "resolvconf".
-SED_ADDING=\
-':adding;
-@SETUP@
-x; b main_resolvconf;
-'
-
-
-###
-# Edit the domain list (include/exclude). All empty fields and matching domains
-# are removed. Unmaintained domains (not in resolvconf-<domain>) are kept. All
-# domains should be in a pipe (|) separated list and should begin, but not end
-# with a dot. The list is put into @DOMAINS@. The control flow continues, where
-# it ended in SED_EDIT_ONE_SERVER.
-#
-SED_DOMAIN_LIST_LOGIC=\
-'h;
-s/^([[:space:]]*@DIRECTIVE@[[:space:]]*=[[:space:]]*).*/\\1/;
-x;
-s/^[[:space:]]*@DIRECTIVE@[[:space:]]*=[[:space:]]*//;
-
-:@DIRECTIVE@_loop_@RULE@;
-/([[:space:]]*("[^"]"*|[^,;]*)[[:space:]]*,)*[[:space:]]*("(@DOMAINS@|)\.?"|(@DOMAINS@)\.?|,)[[:space:]]*[,;]/ {
-	s/(([[:space:]]*("[^"]"*|[^,;]*)[[:space:]]*,)*[[:space:]]*)("(@DOMAINS@|)\.?"|(@DOMAINS@)\.?|,)[[:space:]]*([,;])/\\1\\7/;
-	b @DIRECTIVE@_loop_@RULE@;
-};
-	
-s/^[,;]//g;
-/^[[:space:]]*$/ b @DIRECTIVE@_end_@RULE@;
-H; x; s/\\n//; p;
-:@DIRECTIVE@_end_@RULE@;
-'
-
-################################################################################
-# Functions
-
-###
-# char* [] uniqify(char* list[])
-#
-# Uniqify the items in the list
-uniqify() {
-	local result=
-	while [ -n "$1" ] ; do
-		case " ${result} " in
-			*" $1 "*) ;;
-			*) result="${result} $1" ;;
-		esac
-		shift
-	done
-	echo "${result# *}"
-}
-
-###
-# char *make_pdnsd_label(char *domain)
-#
-# Translate domain name into pdnsd's label
-make_pdnsd_label() {
-	local domain=$1
-	if [[ -n ${domain} ]] ; then
-		echo -n "resolvconf-${domain}"
-	else
-		echo -n "resolvconf"
-	fi
-}
-
-###
-# char *make_sed_label(char *pdnsd_label)
-#
-# Translate pdnsd's label into sed's label
-make_sed_label() {
-	local label="$1"
-	label="${label//-/_}"
-	label="${label//./_}"
-	echo -n "${label}"
-}
-
-# char *compose_lines(...)
-#
-# Compose a sed command that prints lines
-compose_lines() {
-	local line result
-	for line in "$@" ; do
-		result="${result}i\\\\\\n${line//	/\\t}\\n"
-	done
-	echo "${result}"
-}
-
-###
-# char *build_settings(char *nameservers, char *domains, char *directive)
-#
-# Builds configuration part @SETUP@ of sed script. The directive parameter denotes
-# if the domains are to be included ("include") or excluded ("exclude"). This
-# involves options like
-#
-# (1) # [nameserver list is empty]
-#     preset=off;
-#
-# (2) # [domain list is empty]
-#     preset=on;
-#     ip="address","address"...;
-#
-# (3) # [directive=="include"]
-#     preset=on;
-#     ip="address","address"...;
-#     include=".domain.",".domain."...;
-#     policy=excluded;
-#
-# (4) # [directive=="exclude"]
-#     preset=on;
-#     ip="address","address"...;
-#     exclude=".domain.",".domain."...;
-#     policy=included;
-#
-# Note: Currently there will always be only one domain in "include" directive.
-#
-build_settings() {
-	local ns="$1" domains="$2" directive="$3"
-	if [[ -n ${ns} ]] ; then
-		local x list_ns list_domains
-		for x in ${ns} ; do
-			list_ns="${list_ns},\"${x}\""
-		done
-		list_ns="${list_ns#,}"
-		if [[ -n ${domains} ]] ; then
-			for x in ${domains} ; do
-				list_domains="${list_domains},\".${x}.\""
-			done
-			list_domains="${list_domains#,}"
-			if [[ $directive == "include" ]]; then
-				compose_lines \
-					"	preset=on;" \
-					"	ip=${list_ns};" \
-					"	include=${list_domains};" \
-					"	policy=excluded;"
-			else
-				compose_lines \
-					"	preset=on;" \
-					"	ip=${list_ns};" \
-					"	exclude=${list_domains};" \
-					"	policy=included;"
-			fi
-		else
-			compose_lines \
-				"	preset=on;" \
-				"	ip=${list_ns};"
-		fi
-	else
-		compose_lines \
-			"	preset=off;"
-	fi
-}
-
-###
-# char *build_match_labels(char *domains...)
-#
-# Build the label match part of the sed script
-#
-build_match_labels() {
-	local domain result label destination new_match
-	for domain in "$@" ; do
-		label="$(make_pdnsd_label "${domain}")"
-		rule="$(make_sed_label "${label}")"
-		new_match="${SED_MATCH_ONE_LABEL//@LABEL@/${label}}"
-		new_match="${new_match//@RULE@/${rule}}"
-		result="${result}${new_match}"
-	done
-	echo "${result}"
-}
-
-###
-# char *build_domain_list_logic(char *domains, char *directive)
-#
-# Build a logic for changing (removing) domains from a directive.
-#
-build_domain_list_logic() {
-	local domains="$1" directive="$2"
-	local x domain_list logic
-	
-	# Domains should be pipe separated list
-	for x in ${domains}; do
-		x=".${x%.}"
-		x="${x//./\.}"
-		domain_list="${domain_list}|${x}"
-	done
-	domain_list="${domain_list#|}"
-	
-	if [[ -z ${domain_list} ]]; then
-		logic="p;"
-	else
-		logic="${SED_DOMAIN_LIST_LOGIC//@DOMAINS@/${domain_list}}"
-		logic="${logic//@DIRECTIVE@/${directive}}"
-	fi
-	echo "${logic}"
-}
-
-###
-# char *build_edit_part(char *domain, char *nameservers, \
-#                       char *add_domains, char *remove_domains,
-#                       char *directive)
-#
-# Build edit part of the sed script for a particular domain. Domain can be
-# empty in the case it is the "resolvconf" server part.
-#
-build_edit_part() {
-	local domain="$1" nameservers="$2" add_domains="$3" remove_domains="$4"
-	local directive="$5"
-	local setup label rule logic result
-	
-	setup="$(build_settings "${nameservers}" "${add_domains}" "${directive}")"
-	label="$(make_pdnsd_label "${domain}")"
-	rule="$(make_sed_label "${label}")"
-	logic="$(build_domain_list_logic "${remove_domains}" "${directive}")"
-	result="${SED_EDIT_ONE_SERVER//@SETUP@/${setup}}"
-	result="${result//@EXCLUDE_LOGIC@/${logic}}"
-	result="${result//@RULE@/${rule}}"
-	echo "${result}"
-}
-
-###
-# char *get_domain_nameservers(char *domain, char *domain_config...)
-#
-# Get the list of nameservers belonging to one particular domain.
-#
-# Domain configuration is a space separated list of pair <domain>,<ip>.
-#
-get_domain_nameservers() {
-	local domain="$1" ns
-	shift
-	for x in "$@" ; do
-		if [[ ${x%,*} == ${domain} ]] ; then
-			ns="${ns} ${x#*,}"
-		fi
-	done
-	ns="$(uniqify ${ns})"
-	echo -n "${ns}"
-}
-
-###
-# char *build_domain_edit_part(char *domain, char *domain_config...)
-#
-# Parse the list of domain configurations and build settings for one particular
-# domain for the sed script.
-#
-# Domain configuration is a space separated list of pair <domain>,<ip>.
-#
-build_domain_edit_part() {
-	local domain="$1" ns
-	shift
-	ns="$(get_domain_nameservers "${domain}" "$@")"
-	build_edit_part "${domain}" "${ns}" "${domain}" "" "include"
-}
-
-###
-# char *build_add_part(char *add, char *domains...)
-#
-# Build add part of the sed script for all domains that needs to be added
-#
-build_add_part() {
-	local add="$1" x label rule add_part new_part result
-	shift
-	for x in ${add} ; do
-		local domain="${x}" ns
-		ns="$(get_domain_nameservers "${domain}" "$@")"
-		label="$(make_pdnsd_label "${domain}")"
-		rule="$(make_sed_label ${label})"
-		new_part="$(compose_lines "server {" "	label=\"${label}\";")"
-		new_part="${new_part}$(build_settings "${ns}" "${domain}" "include")"
-		new_part="${new_part}$(compose_lines "}" "")"
-		add_part="${add_part}${new_part}"
-	done
-	result="${SED_ADDING//@SETUP@/${add_part}}"
-	echo "${result}"
-}
-
-###
-# char *build_sed_script(char *nameservers, char *domain_config, 
-#                        char *change, char *add,
-#                        char *active_domains, char *known_domains)
-#
-# Build the full sed script from the list of nameservers, list of domains
-# (in format <domain>,<ip>), list of changed domains, list of added domains,
-# list of activly used domains and a list of all known domains.
-#
-build_sed_script() {
-	local ns="$1" domain_config="$2" change="$3" add="$4"
-	local active_domains="$5" known_domains="$6"
-
-	local match_labels="$(build_match_labels ${change})"
-	
-	local edit_changed x
-	for x in ${change} ; do
-		edit_changed="${edit_changed}$( \
-			build_domain_edit_part "${x}" ${domain_config})"
-	done
-	edit_changed="${edit_changed}$( \
-		build_edit_part "" "${ns}" "${active_domains}" "${known_domains}" "exclude")"
-	
-	local added
-	added="$(build_add_part "${add}" ${domain_config})"
-	
-	local full
-	full="${SED_LOOP//@MATCH_LABELS@/${match_labels}}"
-	echo -ne "${full}"
-	echo -ne "${edit_changed}"
-	echo -ne "${added}"
-}
-
-###
-# char *read_configured_domains(char *config_file)
-#
-# Reads labels of servers starting with resolvconf* from the configuration file.
-#
-read_configured_domains() {
-	local config_file="$1" result
-	result="\
-		$(sed -nre 's/^[[:space:]]+label=\"?resolvconf-([^;\"]*)\";.*/\1/p' \
-		${config_file})"
-	echo -n "${result}"
-}
-
-###
-# void installation_check(char *config_file)
-#
-# Check if the pdnsd is installed and can be configured. Prepare also the file
-# for resolvconf.
-#
-installation_check() {
-	local config_file="$1"
-	if [[ -e ${config_file} ]] ; then
-		if ! grep ${INSTALLATION_CHECK} ${config_file} &>/dev/null ; then
-			echo -e "${COMMENT}" >> ${config_file}
-			echo -e "\n${BASIC_SETTINGS}" >> ${config_file}
-		fi
-		return 0
-	else
-		return 1
-	fi
-}
-
-###
-# void initialization(char *config_file)
-#
-# Setup basic variables NAMESERVERS, DOMAINS an CONFIGURED_DOMAINS
-#
-initialization() {
-	local config_file="$1"
-	
-	for N in ${NEWNS} ; do
-		NAMESERVERS="${NAMESERVERS} ${N}"
-	done
-	
-	for N in ${NEWSEARCH} ; do
-		NAMESERVERS="${NAMESERVERS} ${N#*,}"
-	done
-	
-	for DN in ${NEWDOMAIN} ; do
-		DOMAINS="${DOMAINS} ${DN%,*}"
-	done
-
-	CONFIGURED_DOMAINS=$(read_configured_domains ${config_file})
-
-	NAMESERVERS=$(uniqify ${NAMESERVERS})
-	DOMAINS=$(uniqify ${DOMAINS})
-	CONFIGURED_DOMAINS=$(uniqify ${CONFIGURED_DOMAINS})
-}
-
-###
-# void find_changed_and_added(char *configured, char *domains)
-#
-# Find already configured and newly added domains. Sets variables
-# CHANGE_DOMAINS, ADD_DOMAINS and KNOWN_DOMAINS.
-#
-find_changed_and_added() {
-	local configured="$1" domains="$2" x
-	
-	KNOWN_DOMAINS="${CONFIGURED_DOMAINS} ${DOMAINS}"
-	
-	# Find what has to be disabled
-	for x in ${configured} ; do
-		if [[ " ${domains} " != *" ${x} "* ]] ; then
-			CHANGE_DOMAINS="${CHANGE_DOMAINS} ${x}"
-		fi
-	done
-
-	# Find what has to be added
-	for x in ${domains} ; do
-		if [[ " ${configured} " != *" ${x} "* ]] ; then
-			ADD_DOMAINS="${ADD_DOMAINS} ${x}"
-		else
-			CHANGE_DOMAINS="${CHANGE_DOMAINS} ${x}"
-		fi
-	done
-
-	ADD_DOMAINS=$(uniqify ${ADD_DOMAINS})
-	CHANGE_DOMAINS=$(uniqify ${CHANGE_DOMAINS})
-	KNOWN_DOMAINS=$(uniqify ${KNOWN_DOMAINS})
-}
-
-###
-# bool make_configuration_change(char *config_file, char *backup_suffix,
-#                                char *sed_script)
-#
-# Applies any configuration change. Returns true, if there was a change.
-#
-make_configuration_change() {
-	local config_file="$1" backup_suffix="$2" sed_script="$3"
-	local old_config new_config
-
-	old_config=$(< ${config_file})
-	
-	# Sanity check: add '}' at the end of the file
-	new_config=$( (echo -n "${old_config}" && echo -ne "\n}" ) | \
-		sed -nre "${sed_script}")
-	# Now remove what we added
-	new_config=${new_config%?\}}
-
-	if [[ "${old_config}" != "${new_config}" ]] ; then
-		cp ${config_file} ${config_file}${backup_suffix}
-		echo "${new_config}" > "${config_file}"
-		return 0
-	else
-		return 1
-	fi
-}
-
-################################################################################
-# Main part
-
-# Check, if pdnsd configuration file is installed and possibly prepare it
-installation_check "${PDNSDCONFIG}" || exit 0
-
-# Basic initialization of NAMESERVERS, DOMAINS and CONFIGURED_DOMAINS
-initialization "${PDNSDCONFIG}"
-
-find_changed_and_added "${CONFIGURED_DOMAINS}" "${DOMAINS}"
-
-sed_script="$(build_sed_script "${NAMESERVERS}" "${NEWDOMAIN}" \
-	"${CHANGE_DOMAINS}" "${ADD_DOMAINS}" \
-	"${DOMAINS}" "${KNOWN_DOMAINS}")"
-
-# Check if the config changed
-if make_configuration_change "${PDNSDCONFIG}" "${BACKUPSUFFIX}" "${sed_script}" ; then
-	# Checks for running pdnsd
-	[ -x /usr/sbin/pdnsd-ctl ] || exit 0
-	[ -e /var/cache/pdnsd/pdnsd.status ] || exit 0
-
-	# Reload config files
-	/usr/sbin/pdnsd-ctl config &>/dev/null
-fi
-
-exit 0


^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-02-17 19:33 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-05-03  9:47 [gentoo-commits] repo/gentoo:master commit in: net-dns/pdnsd/files/ Lars Wendler
  -- strict thread matches above, loose matches on Subject: below --
2019-05-11 18:59 Lars Wendler
2021-02-17 19:33 Conrad Kostecki

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox