AnonSec Shell
Server IP : 85.193.89.191  /  Your IP : 3.144.42.221
Web Server : Apache
System : Linux 956367-cx40159.tmweb.ru 3.10.0-1160.105.1.el7.x86_64 #1 SMP Thu Dec 7 15:39:45 UTC 2023 x86_64
User : bitrix ( 600)
PHP Version : 8.1.27
Disable Function : NONE
MySQL : OFF  |  cURL : OFF  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /proc/978/root/etc/etckeeper/post-install.d/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /proc/978/root/etc/etckeeper/post-install.d/50vcs-commit
#!/bin/sh
set -e

pl="/var/cache/etckeeper/packagelist"

# Parent process is etckeeper
# (Only procps ps is currently supported, others will fail,
# so this may end up empty.)
ETCKEEPER_PID=$( ps --no-headers -o ppid "${PPID}" 2>/dev/null | sed 's/^ *//' )

# Find the parent of etckeeper and get the command line of the process
if ! [ -z "${ETCKEEPER_PID}" ]; then
	ETCKEEPER_PPID=$( ps --no-headers -o ppid "${ETCKEEPER_PID}" | sed 's/^ *//' )
	ETCKEEPER_PARENT_COMMAND_LINE=$( ps --no-headers -o args "${ETCKEEPER_PPID}" )
fi

get_changes () {
	if [ "$VCS" = git ]; then
		git diff --stat | grep '|' | cut -d'|' -f1 | cut -b2-
		git ls-files --exclude-standard --others
	fi
	if [ "$VCS" = hg ]; then
		hg status --no-status
	fi
	if [ "$VCS" = bzr ]; then
		bzr status -S | cut -b5-
	fi
	if [ "$VCS" = darcs ]; then
		# ignore ' file -> file' lines for moved files
		# trim ' -M +N rP' from change summary
		darcs whatsnew --summary | grep -v '^ .* -> ' | cut -d' ' -f2- | sed 's/ [-+r][0-9]\+//g;s/^\.\///'
		# lines beginning with 'a' show unversioned files
		darcs whatsnew --look-for-adds --boring --summary | grep '^a' | cut -d' ' -f2- | sed 's/^\.\///'
	fi
}

get_changed_packages () {
	if [ "$LOWLEVEL_PACKAGE_MANAGER" = dpkg ]; then
		get_changes | sed 's/^/\/etc\//;s/\s*$//' | xargs -d '\n' dpkg 2>/dev/null -S | cut -d':' -f1 | sed 's/, /\n/g'
	fi
	if [ "$LOWLEVEL_PACKAGE_MANAGER" = rpm ]; then
		# if output contains file path, file was not found
		get_changes | sed 's/^/\/etc\//;s/\s*$//' | xargs -d '\n' rpm --qf '%{NAME}\n' -qf | grep -v "/etc/"
	fi
	# is it even possible to use pacmatic without pacman?
	if [ "$LOWLEVEL_PACKAGE_MANAGER" = pacman -o "$LOWLEVEL_PACKAGE_MANAGER" = pacmatic ]; then
		get_changes | sed 's/^/\/etc\//;s/\s*$//' | xargs -d '\n' pacman 2>/dev/null -Qo | rev | cut -d' ' -f1-2 | rev | cut -d' ' -f1
	fi
	if [ "$LOWLEVEL_PACKAGE_MANAGER" = pkgng ]; then
		get_changes | sed 's/^/\/etc\//;s/\s*$//' | xargs -d '\n' pkg which --quiet | rev | cut -d'-' -f2- | rev
	fi
	if [ "$LOWLEVEL_PACKAGE_MANAGER" = xbps ]; then
		get_changes | sed 's/^/\/etc\//;s/\s*$//' | xargs -d '\n' xbps-query -o | cut -d':' -f1
	fi
}

if etckeeper unclean; then
	if [ -z "${ETCKEEPER_PARENT_COMMAND_LINE}" ]; then
		message="committing changes in /etc after $HIGHLEVEL_PACKAGE_MANAGER run"
	else
		message="committing changes in /etc made by \"$ETCKEEPER_PARENT_COMMAND_LINE\""
	fi

	set +e
	if [ -e $pl.pre-install ] && [ "$(cat $pl.fmt 2>/dev/null || true)" = "$(etckeeper list-installed fmt)" ]; then
		(
			echo "$message"
			echo
			get_changed_packages | sort | uniq > $pl.found-pkgs
			if [ -s $pl.found-pkgs ]; then
				sed -i 's/^/^[-+]/;s/$/ /' $pl.found-pkgs
				etckeeper list-installed | diff -U0 $pl.pre-install - | tail -n+4 | grep -E '^[-+]' | grep -f $pl.found-pkgs > $pl.found-packages
				if [ -s $pl.found-packages ]; then
					echo "Packages with configuration changes:"
					cat $pl.found-packages || true
					echo
				fi
			fi
			echo "Package changes:"
			etckeeper list-installed | diff -U0 $pl.pre-install - | tail -n+4 | grep -E '^[-+]' || true
		) | etckeeper commit --stdin
	else
		etckeeper commit "$(printf "$message")"
	fi
	status=$?
	set -e

	if [ "$status" != 0 ]; then
		echo "warning: etckeeper failed to commit changes in /etc using $VCS" >&2
	fi
fi

rm -f $pl.pre-install $pl.fmt
rm -f $pl.found-pkgs $pl.found-packages

Anon7 - 2022
AnonSec Team