- GRAYBYTE UNDETECTABLE CODES -

403Webshell
Server IP : 184.154.167.98  /  Your IP : 3.145.35.4
Web Server : Apache
System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
User : puertode ( 1767)
PHP Version : 8.2.26
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /usr/libexec/pcp/bin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /usr/libexec/pcp/bin/install-sh
#!/bin/sh
#
# Copyright (c) 2013,2020 Red Hat.
# Copyright (c) 2004 Silicon Graphics, Inc.  All Rights Reserved.
#
# 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 2 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.
#
# This script emulates bsd install and also recognises
# two environment variables, with the following semantics :-
#
# $DIST_MANIFEST - if set, the name of the file to append manifest
#                  information in the following format:
#                  File      : f mode owner group src target
#                  Directory : d mode owner group target
#                  Symlink   : l linkval target
# $DIST_TMPFILES - if set, the name of the file to append tmpfiles
#                  information (-t option) in tmpfiles.d format:
#                  #Type Path                    Mode User Group Age Argument
#                  L+    /symlink/to/[re]create  -    -    -     -   symlink/target/path
#
# $DIST_ROOT     - if set, prepend to target
#
# The sematics of all combinations of these two variables
# are as follows:
#
# $DIST_MANIFEST?  $DIST_ROOT? |   Copy?  Append Manifest?
# -----------------------------+--------------------------
#       not set       not set  |    yes        no
#       not set       set      |    yes        no
#       set           not set  |    no         yes
#       set           set      |    yes        yes

_usage()
{
    echo "Usage: $prog [-o owner] [-g group] [-m mode] -d directory"
    echo "or     $prog [-o owner] [-g group] [-m mode] [-t path | -f] file directory/file"
    echo "or     $prog [-o owner] [-g group] [-m mode] [-t path | -f] file file [file ...] directory"
    echo "or     $prog -S file target  (creates \"target\" symlink)"
    echo ""
    echo "The \$DIST_MANIFEST, \$DIST_TMPFILES and \$DIST_ROOT environment variables"
    echo "affect the behaviour of this command - see comments in the script."
    echo ""
    exit 1
}

_chown()
{
    _st=255
    if [ $# -eq 3 ] ; then
	chown "$1:$2" "$3"
	_st=$?
	if [ $_st -ne 0 ] ; then
	    if [ $REAL_UID != '0' ] ; then
		if [ ! -f "$DIST_ROOT"/.chown.quiet ] ; then
		    echo '==============================================='
		    echo Ownership of files under ${DIST_ROOT:-/}
		    echo cannot be changed
		    echo '==============================================='
		    if [ -n "$DIST_ROOT" ] ; then
			touch "$DIST_ROOT"/.chown.quiet
		    fi
		fi
	       _st=0
	    fi
	fi
    fi

    return $_st
}

_ln()
{
    if uname -s | tr 'A-Z' 'a-z' | grep mingw >/dev/null
    then
	/bin/true
    else
	ln -s -f "$1" "$2"
    fi
}

_manifest()
{
    echo $* | sed -e 's/\/\//\//g' >>${DIST_MANIFEST:-/dev/null}
}

_symlink()
{
    __target="$1"
    __symlink="$2"

    $RM -f "$__symlink"
    __dir=`dirname "$__symlink" | sed -e 's;//*;/;g'`
    [ ! -d "$__dir" ] && mkdir -p "$__dir"

    __rel=`echo "$__target" | sed -e 's;^/;;'`	# remove leading slash
    if [ "$__rel" = "$__target" ]
    then
	$LN "$__target" "$__symlink"
	status=$?
	$MANIFEST l "$__target" `echo "$__symlink" | sed -e "s;^$DIST_ROOT;;"`
    else
	__dlist=`dirname "$__symlink" | sed -e "s;^$DIST_ROOT;;" -e 's;/; ;g'`
	__tpath=""
	for d in $__dlist
	do
	    __tpath="../${__tpath}"	# constructing a relative path
	done
	cd "${__dir}"
	$LN "${__tpath}${__rel}" "$__symlink"
	status=$?
	cd "$HERE"
	$MANIFEST l "${__tpath}${__rel}" `echo "$__symlink" | sed -e "s;^$DIST_ROOT;;"`
    fi
}

_tmpfiles()
{
    __target=`echo "$1" | sed -e "s;^$DIST_ROOT;;" -e 's;//*;/;g'`
    __symlink=`echo "$2" | sed -e "s;^$DIST_ROOT;;" -e 's;//*;/;g'`

    __rel=`echo "$__symlink" | sed -e 's;^/;;'`	# remove leading slash
    __dlist=`dirname "$__target" | sed -e 's;/; ;g'`
    __tpath=""
    for d in $__dlist
    do
        __tpath="../${__tpath}"	# constructing a relative path
    done
    echo "L+ $__target - - - - ${__tpath}${__rel}" >>${DIST_TMPFILES:-/dev/null}
}

_varcheck()
{
    __target=`echo "$1" | sed -e "s;^$DIST_ROOT;;"`

    echo "$__target" | grep ^/var >/dev/null 2>&1
    if [ $? -eq 0 -a $CHECK = "true" ]
    then
	echo "ERROR: attempted /var install below $__target"
	_usage
	exit 1
    fi
}

ID=id
# Test to use the functional id on Solaris
test -f /usr/xpg4/bin/id && ID=/usr/xpg4/bin/id

# Allow for overridding /var files checking (for QA only);
# default is failure when regular files installed to /var.
CHECK=true

prog=`basename $0`
HERE=`pwd`
dflag=false
Sflag=false
tflag=false
DIRMODE=755
FILEMODE=644
OWNER=`$ID -u 2>/dev/null`
GROUP=`$ID -g 2>/dev/null`
if [ -z "$OWNER" -o -z "$GROUP" ]
then
    # do it the hardway
    #
    OWNER=`$ID | sed -e 's/.*uid=[^(]*(//' -e 's/).*//'`
    GROUP=`$ID | sed -e 's/.*gid=[^(]*(//' -e 's/).*//'`
fi
REAL_UID=$OWNER

# default is to install and don't append manifest/tmpfiles
INSTALL=true
MANIFEST=:
TMPFILES=:

[ -n "$DIST_MANIFEST" -a -z "$DIST_ROOT" ] && INSTALL=false
[ -n "$DIST_MANIFEST" ] && MANIFEST="_manifest"
[ -n "$DIST_TMPFILES" ] && TMPFILES="_tmpfiles"

[ $# -eq 0 ] && _usage

if $INSTALL
then
    RM=rm; CP=cp; LN=_ln; MKDIR=mkdir; CHMOD=chmod; CHOWN=_chown
else
    RM=true; CP=true; LN=true; MKDIR=true; CHMOD=true; CHOWN=true
fi


test $REAL_UID -ne 0 && CHOWN=true
test "$NO_CHOWN" = "true" && CHOWN=true

while getopts "d:fg:m:o:S:t:" c
do
   case $c in
   d)
	dir=`echo "$DIST_ROOT/$OPTARG" | sed -e 's;//*;/;g'`
	dflag=true
	;;
   f)
	CHECK=false
	;;
   g)
	GROUP=$OPTARG
	;;
   m)
	DIRMODE=`expr $OPTARG`
	FILEMODE=$DIRMODE
	;;
   o)
	OWNER=$OPTARG
	;;
   S)
	symlink=$OPTARG
	Sflag=true
	;;
   t)
	tmpfile=`echo "$DIST_ROOT/$OPTARG" | sed -e 's;//*;/;g'`
	tflag=true
	;;
   *)
   	_usage
	;;
   esac
done

shift `expr $OPTIND - 1`

status=0
if $dflag
then
    #
    # first usage
    #
    $tflag && _usage
    $MKDIR -p "$dir"
    status=$?
    if [ $status -eq 0 ]
    then
	$CHMOD $DIRMODE "$dir"
	status=$?
    fi
    if [ $status -eq 0 ]
    then
	$CHOWN $OWNER $GROUP "$dir"
	status=$?
    fi
    $MANIFEST d $DIRMODE $OWNER $GROUP `echo "$dir" | sed -e "s;^$DIST_ROOT;;"`
elif $Sflag
then
    #
    # fourth usage (symlink)
    #
    if [ $# -ne 1 ]
    then
    	_usage
    else
	target=`echo "$DIST_ROOT/$1" | sed -e 's;//*;/;g'`
    fi
    _varcheck "$target"
    _symlink "$symlink" "$target"
else
    list=""
    dir=""
    if [ $# -eq 2 ]
    then
	#
	# second usage: install file dir/name
	# target 'name' is not necessarily the same as 'file'
	# (Note:  install file dir  is ambiguous and not supported
	#
	f="$1"
	dir="$DIST_ROOT"/`dirname "$2"`
	dir=`echo "$dir" | sed -e 's;//*;/;g'`
	t_dir=`echo "$dir" | sed -e "s;^$DIST_ROOT;;" | sed -e 's;//*;/;g'`
	destfile=`basename "$2"`
	if [ -f "$f" -a -f "$f.exe" ]
	then
	    # Windows hack -- executables present as foo and foo.exe,
	    # the foo one is visible to test(1) and ls(1), but not to
	    # cat(1)/cp(1) ... need to $RM/$CP the foo.exe one
	    #
	    if cat "$f" >/dev/null 2>&1
	    then
		:
	    else
		f="$f.exe"
		destfile="$destfile.exe"
	    fi
	fi
	_varcheck "$dir"
	[ ! -d "$dir" ] && mkdir -p "$dir"
	if [ -d "$dir/$destfile" ]
	then
	    echo ERROR: unsupported install usage
	    _usage
	    exit 1
	else
	    $RM -f "$dir/$destfile"
	fi
	$CP "$f" "$dir/$destfile"
	status=$?

	if [ $status -eq 0 ]
	then
	    [ ! -d "$dir/$destfile" ] && $CHMOD $FILEMODE "$dir/$destfile"
	    status=$?
	    if [ $status -eq 0 ]
	    then
		$CHOWN $OWNER $GROUP "$dir/$destfile"
		status=$?
	    fi
	    $MANIFEST f $FILEMODE $OWNER $GROUP "$HERE/$f" "$t_dir/$destfile"
	    if $tflag
	    then
		_symlink "$t_dir/$destfile" "$tmpfile"
		$TMPFILES "$tmpfile" "$t_dir/$destfile"
	    fi
	fi
	[ $status -ne 0 ] && break

    else
	#
	# third usage: install file file [file ...] directory
	#
	n=1
	while [ $# -gt 0 ]
	do
	    if [ $# -gt 1 ]
	    then
		list="$list $1"
	    else
		dir=`echo "$DIST_ROOT/$1" | sed -e 's;//*;/;g'`
	    fi
	    shift
	done
	# At this stage, $list is the list of files to install
	# in $dir. We create $dir if necessary

	# t_dir is for the manifest, i.e. without $DIST_ROOT prefix
	t_dir=`echo "$dir" | sed -e "s;^$DIST_ROOT;;"`

	for f in $list
	do
	    if [ -f "$f" -a -f "$f.exe" ]
	    then
		# Windows hack -- executables present as foo and foo.exe,
		# the foo one is visible to test(1) and ls(1), but not to
		# cat(1)/cp(1) ... need to $RM/$CP the foo.exe one
		#
		if cat "$f" >/dev/null 2>&1
		then
		    :
		else
		    f="$f.exe"
		fi
	    fi

	    _varcheck "$dir"
	    [ ! -d "$dir" ] && mkdir -p "$dir"
	    $RM -f "$dir/$f"
	    $CP "$f" "$dir/$f"
	    status=$?

	    if [ $status -eq 0 ]
	    then
		$CHMOD $FILEMODE "$dir/$f"
		status=$?
		if [ $status -eq 0 ]
		then
		    $CHOWN $OWNER $GROUP "$dir/$f"
		    status=$?
		fi
		$MANIFEST f $FILEMODE $OWNER $GROUP "$HERE/$f" "$t_dir/$f"
		if $tflag
		then
		    _symlink "$t_dir/$f" "$tmpfile/$f"
		    $TMPFILES "$tmpfile/$f" "$t_dir/$f"
		fi
	    fi
	    [ $status -ne 0 ] && break
	done
    fi
fi

exit $status

Youez - 2016 - github.com/yon3zu
LinuXploit