mirror of
ssh://git.janware.com/srv/git/janware/proj/jw-pkg
synced 2026-01-22 14:10:39 +01:00
dpm.sh: Add support for more rpm commands to dpm.sh
Signed-off-by: Jan Lindemann <jan@janware.com>
This commit is contained in:
parent
07582a3f6e
commit
04bdfdc0e8
1 changed files with 76 additions and 6 deletions
|
|
@ -1,4 +1,36 @@
|
||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
|
|
||||||
|
log_dpkg()
|
||||||
|
{
|
||||||
|
echo dpkg $@
|
||||||
|
/usr/bin/dpkg $@
|
||||||
|
}
|
||||||
|
|
||||||
|
# to be used on debian prior to jessie
|
||||||
|
dpkg_verify()
|
||||||
|
{
|
||||||
|
local exitcode file pkg hashfile rfile phash hash
|
||||||
|
exitcode=0
|
||||||
|
for file in $*; do
|
||||||
|
pkg=`dpkg -S "$file" | cut -d: -f 1`
|
||||||
|
hashfile="/var/lib/dpkg/info/$pkg.md5sums"
|
||||||
|
if [ -s "$hashfile" ]; then
|
||||||
|
rfile=`echo "$file" | cut -d/ -f 2-`
|
||||||
|
phash=`grep -E "$rfile\$" "$hashfile" | cut -d\ -f 1`
|
||||||
|
hash=`md5sum "$file" | cut -d\ -f 1`
|
||||||
|
if [ "$hash" = "$phash" ]; then
|
||||||
|
echo "$file: ok"
|
||||||
|
else
|
||||||
|
echo "$file: CHANGED"
|
||||||
|
exitcode=1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "$file: UNKNOWN"
|
||||||
|
exitcode=1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
return $exitcode
|
||||||
|
}
|
||||||
|
|
||||||
cmd_install()
|
cmd_install()
|
||||||
{
|
{
|
||||||
|
|
@ -24,8 +56,36 @@ cmd_erase()
|
||||||
|
|
||||||
cmd_query()
|
cmd_query()
|
||||||
{
|
{
|
||||||
[ "$query_cmd" ] && {
|
[ "$query_cmds" ] && {
|
||||||
eval cmd_query_\$query_cmd $1
|
local cmd installed
|
||||||
|
local id=name
|
||||||
|
if [ "`echo $query_cmds | sed 's/.*p.*//'`" ]; then
|
||||||
|
id=pkg
|
||||||
|
query_cmds=`echo $query_cmds | sed 's/p//'`
|
||||||
|
elif [ "`echo $query_cmds | sed 's/.*f.*//'`" ]; then
|
||||||
|
id=file
|
||||||
|
query_cmds=`echo $query_cmds | sed 's/f//'`
|
||||||
|
fi
|
||||||
|
for cmd in $query_cmds; do
|
||||||
|
case $cmd in
|
||||||
|
V)
|
||||||
|
$dpkg --verify $1
|
||||||
|
;;
|
||||||
|
i)
|
||||||
|
case $id in
|
||||||
|
file)
|
||||||
|
$dpkg -p $1;;
|
||||||
|
name)
|
||||||
|
$dpkg -I $1;;
|
||||||
|
pkg)
|
||||||
|
$dpkg -S $1;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
a)
|
||||||
|
$dpkg -L $1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
return $?
|
return $?
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -59,10 +119,10 @@ fatal()
|
||||||
|
|
||||||
# -- here we go
|
# -- here we go
|
||||||
myname=`basename $0`
|
myname=`basename $0`
|
||||||
dpkg=/usr/bin/dpkg
|
dpkg=log_dpkg
|
||||||
cmd=""
|
cmd=""
|
||||||
|
|
||||||
set -- `getopt hqiUe "$@"`
|
set -- `getopt hqiUeVfap "$@"`
|
||||||
while [ "$1" != -- ]; do
|
while [ "$1" != -- ]; do
|
||||||
case $1 in
|
case $1 in
|
||||||
-h)
|
-h)
|
||||||
|
|
@ -72,8 +132,18 @@ case $1 in
|
||||||
[ "$cmd" ] && usage 1
|
[ "$cmd" ] && usage 1
|
||||||
cmd=query
|
cmd=query
|
||||||
;;
|
;;
|
||||||
|
-V|-f|-a|-p)
|
||||||
|
[ "$cmd" ] && {
|
||||||
|
[ "$cmd" = query ] || usage 1
|
||||||
|
query_cmds="$cmd ${1:1:1}"
|
||||||
|
}
|
||||||
|
;;
|
||||||
-i)
|
-i)
|
||||||
[ "$cmd" ] && usage 1
|
[ "$cmd" ] && {
|
||||||
|
[ "$cmd" = query ] || usage 1
|
||||||
|
query_cmds="$cmd ${1:1:1}"
|
||||||
|
continue
|
||||||
|
}
|
||||||
cmd=install
|
cmd=install
|
||||||
;;
|
;;
|
||||||
-U)
|
-U)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue