glacier-old/scripts/glacier

234 lines
9.4 KiB
Plaintext
Raw Normal View History

2022-05-31 09:20:51 -04:00
#!/bin/sh
# Glacier - A source based package manager written in POSIX sh
# (C) 2022 Everest Developers
# This program is free software: see the GNU GPL v3.0 for details.
# Preloading
source /etc/glacier/hooks.sh
while [[ $# -gt 0 ]]; do
case $1 in
-h|--help)
2022-06-10 10:03:44 -04:00
printf "$blue [ * ] Glacier - A source based package manager written in POSIX sh [ * ] $reset\n"
2022-06-10 08:58:44 -04:00
printf "$ glacier {-h --help} show this message and exit\n"
printf "$ glacier {--version} display the current Glacier version and exit\n"
printf "# glacier {install -f} install a package\n"
printf "# glacier {update -u} update a package\n"
printf "# glacier {remove -x} remove a package\n"
printf "$ glacier {query -q} query a package\n"
printf "# glacier {cache -c} cache a package\n"
printf "# glacier {cache-install -ci} install a cached package\n"
printf "# glacier {cache-clear -cc} clear the package cache\n"
2022-05-31 09:20:51 -04:00
printf "\n"
printf "This program is free software: see the GNU GPL v3.0 for details.\n"
exit 0
;;
--version)
2022-06-08 08:54:50 -04:00
printf "$blue Glacier v2.1 $reset\n"
2022-05-31 09:20:51 -04:00
exit 0
;;
install|-f)
# Require the script to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ \xE2\x9C\x95 ] \033[m Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
2022-06-02 10:44:50 -04:00
# Get package name and download package archive
2022-05-31 09:20:51 -04:00
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
printf "\033[1;34m [ i ] \033[m Installing $input.tar.gz...\n"
printf "\033[1;34m [ i ] \033[m Checking databases... " && wget $GREPO1/$input.tar.gz -q --show-progress || wget $GREPO2/$input.tar.gz -q --show-progress || wget $GREPO3/$input.tar.gz -q --show-progress || wget $GREPO4/$input.tar.gz -q --show-progress || wget $GREPO5/$input.tar.gz -q --show-progress || wget $GREPO6/$input.tar.gz -q --show-progress || wget $GREPO7/$input.tar.gz -q --show-progress || wget $GREPO8/$input.tar.gz -q --show-progress
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ \xE2\x9C\x95 ] \033[m Package not found.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
2022-06-02 10:44:50 -04:00
# Unpack Tarball
2022-05-31 09:20:51 -04:00
printf "\033[1;34m [ i ] \033[m Unpacking $input.tar.gz...\n"
mkdir $input && mv $input.tar.gz $input && cd $input
2022-06-08 08:54:10 -04:00
printf "$blue [ i ]$reset Verifying integrity of package...\n"
2022-06-08 08:57:46 -04:00
sha256sum $input.tar.gz
2022-05-31 09:20:51 -04:00
tar -xf $input.tar.gz
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ \xE2\x9C\x95 ] \033[m Could not unpack $input.tar.gz.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
2022-06-02 10:44:50 -04:00
# Run installation hooks
2022-05-31 09:20:51 -04:00
chmod +x INSTALL.sh
chmod +x $input.ts.sh
2022-06-01 11:34:41 -04:00
printf "$blue [ i ]$reset The following instruction set will be executed:\n"
2022-06-01 11:32:04 -04:00
cat INSTALL.sh
2022-05-31 09:20:51 -04:00
printf "\033[1;34m [ i ] \033[m Executing installation instructions...\n"
2022-06-02 10:44:50 -04:00
./INSTALL.sh
2022-05-31 09:20:51 -04:00
./$input.ts.sh
2022-06-02 10:44:50 -04:00
# Clean up
printf "\033[1;34m [ i ] \033[m Cleaning up...\n"
2022-05-31 09:20:51 -04:00
mv $input-pkginfo.json /etc/glacier/pkginfo
cd ..
rm -rf $input
printf "\033[1;32m [ \xE2\x9C\x93 ] \033[m Operation completed.\n"
exit 0
;;
update|-u)
# Require Glacier to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
printf "\033[1;34m [ i ] \033[m Installing $input.tar.gz...\n"
printf "\033[1;34m [ i ] \033[m Checking databases... " && wget $GREPO1/$input.tar.gz -q --show-progress || wget $GREPO2/$input.tar.gz -q --show-progress || wget $GREPO3/$input.tar.gz -q --show-progress || wget $GREPO4/$input.tar.gz -q --show-progress || wget $GREPO5/$input.tar.gz -q --show-progress || wget $GREPO6/$input.tar.gz -q --show-progress || wget $GREPO7/$input.tar.gz -q --show-progress || wget $GREPO8/$input.tar.gz -q --show-progress
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Package not found.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
printf "\033[1;34m [ i ] \033[m Unpacking $input.tar.gz...\n"
mkdir $input && mv $input.tar.gz $input && cd $input
2022-06-08 08:54:10 -04:00
printf "$blue [ i ]$reset Verifying integrity of package...\n"
2022-06-08 08:57:46 -04:00
sha256sum $input.tar.gz
2022-05-31 09:20:51 -04:00
tar -xf $input.tar.gz
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Could not unpack $input.tar.gz.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
rm /var/log/glacier/$input.timestamp
chmod +x UPDATE.sh
chmod +x $input.ts.sh
2022-06-01 11:32:04 -04:00
printf "$blue [ i ]$reset The following instruction set will be executed:\n"
cat UPDATE.sh
printf "\033[1;34m [ i ] \033[m Executing update instructions...\n"
2022-05-31 09:20:51 -04:00
./UPDATE.sh
./$input.ts.sh
printf "\033[1;34m [ i ] \033[m Cleaning up...\n"
mv $input-pkginfo.json /etc/glacier/pkginfo
cd ..
rm -rf $input
printf "\033[1;32m [ $check ] \033[m Operation completed.\n"
exit 0
;;
remove|-x)
# Require the script to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
printf "\033[1;34m [ i ] \033[m Removing $input.tar.gz...\n"
printf "\033[1;34m [ i ] \033[m Checking databases... " && wget $GREPO1/$input.tar.gz -q --show-progress || wget $GREPO2/$input.tar.gz -q --show-progress || wget $GREPO3/$input.tar.gz -q --show-progress || wget $GREPO4/$input.tar.gz -q --show-progress || wget $GREPO5/$input.tar.gz -q --show-progress || wget $GREPO6/$input.tar.gz -q --show-progress || wget $GREPO7/$input.tar.gz -q --show-progress || wget $GREPO8/$input.tar.gz -q --show-progress
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Package not found.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
printf "\033[1;34m [ i ] \033[m Unpacking $input.tar.gz...\n"
mkdir $input && mv $input.tar.gz $input && cd $input
2022-06-08 08:54:10 -04:00
printf "$blue [ i ]$reset Verifying integrity of package...\n"
2022-06-08 08:57:46 -04:00
sha256sum $input.tar.gz
2022-05-31 09:20:51 -04:00
tar -xf $input.tar.gz
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Could not unpack $input.tar.gz.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
chmod +x REMOVE.sh
2022-06-01 11:34:41 -04:00
printf "$blue [ i ] $reset The following instruction set will be executed:\n"
2022-06-01 11:32:04 -04:00
cat REMOVE.sh
2022-06-01 11:34:41 -04:00
printf "$blue [ i ] $reset Executing removal instructions...\n"
2022-05-31 09:20:51 -04:00
./REMOVE.sh
rm /var/log/glacier/$input.timestamp
printf "\033[1;34m [ i ] \033[m Cleaning up... \n" # Status message
cd ..
rm -rf $input
rm /etc/glacier/pkginfo/$input-pkginfo.json
printf "\033[1;32m [ $check ] \033[m Operation completed.\n"
exit 0
;;
query|-q)
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
cat /etc/glacier/pkginfo/$input-pkginfo.json
cat /var/log/glacier/$input.timestamp
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Package not found.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
exit 0
;;
cache|-c)
# Require the script to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
printf "\033[1;34m [ i ] \033[m Caching $input.tar.gz...\n"
printf "\033[1;34m [ i ] \033[m Checking databases... " && wget $GREPO1/$input.tar.gz -q --show-progress || wget $GREPO2/$input.tar.gz -q --show-progress || wget $GREPO3/$input.tar.gz -q --show-progress || wget $GREPO4/$input.tar.gz -q --show-progress || wget $GREPO5/$input.tar.gz -q --show-progress || wget $GREPO6/$input.tar.gz -q --show-progress || wget $GREPO7/$input.tar.gz -q --show-progress || wget $GREPO8/$input.tar.gz -q --show-progress
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Package not found.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
2022-06-08 08:54:10 -04:00
printf "$blue [ i ]$reset Verifying integrity of package...\n"
2022-06-08 08:57:46 -04:00
sha256sum $input.tar.gz
2022-05-31 09:20:51 -04:00
mv $input.tar.gz /var/cache/glacier
2022-06-10 10:06:21 -04:00
printf "\033[1;32m [ $check ] \033[m Operation completed.\n"
2022-05-31 09:20:51 -04:00
exit 0
;;
cache-install|-ci)
# Require the script to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
echo "$red[ $error ]$reset Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
printf "\033[1;34m [ ? ] \033[m Enter package name: " && read input
2022-06-10 10:06:21 -04:00
printf "\033[1;34m [ i ] \033[m Checking cache for $input.tar.gz...\n"
2022-05-31 09:20:51 -04:00
cd /var/cache/glacier && cp $input.tar.gz /tmp && cd /tmp
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Could not fetch package from cache.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
2022-06-10 10:06:21 -04:00
printf "\033[1;34m [ i ] \033[m Unpacking $input.tar.gz...\n"
2022-05-31 09:20:51 -04:00
mkdir $input && mv $input.tar.gz $input && cd $input
tar -xf $input.tar.gz
if [ "$?" != "0" ]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Could not unpack $input.tar.gz.\n" 1>&2
2022-05-31 09:20:51 -04:00
exit 1
fi
chmod +x INSTALL.sh
chmod +x $input.ts.sh
./INSTALL.sh # Actually executes installation script
./$input.ts.sh
printf "\033[1;34m [ i ] \033[m Cleaning up... " # Status message
mv -v $input-pkginfo.json /etc/glacier/pkginfo
cd ..
rm -rvf $input
printf "\033[1;32m [ $check ] \033[m Operation completed."
exit 0
;;
cache-clear|-cc)
# Require the script to be run as root
if [[ $(/usr/bin/id -u) -ne 0 ]]; then
2022-06-07 10:43:25 -04:00
printf "\033[1;31m [ $error ] \033[m Please run Glacier as root.\n"
2022-05-31 09:20:51 -04:00
exit
fi
2022-06-09 10:05:35 -04:00
printf "\033[1;34m [ i ] \033[m Clearing cache...\n"
2022-06-07 10:43:25 -04:00
cd /var/cache/glacier && rm -rf *
if [ "$?" != "0" ]; then
printf "\033[1;31m [ $error ] \033[m Some items could not be cleared.\n" 1>&2
exit 1
fi
2022-06-09 10:05:35 -04:00
printf "\033[1;32m [ $check ] \033[m Cache cleared.\n"
2022-05-31 09:20:51 -04:00
exit 0
;;
-*|--*)
2022-06-08 08:01:20 -04:00
printf "$red [ $error ]$reset Unknown option, use 'glacier -h' to see usage.\n"
2022-06-03 08:57:22 -04:00
exit 1
;;
*)
2022-06-08 08:01:20 -04:00
printf "$red [ $error ]$reset Unknown option, use 'glacier -h' to see usage.\n"
2022-05-31 09:20:51 -04:00
exit 1
;;
esac
done