mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2024-11-08 22:00:58 +00:00
215 lines
8.7 KiB
Bash
Executable File
215 lines
8.7 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# s3fs - FUSE-based file system backed by Amazon S3
|
|
#
|
|
# Copyright(C) 2007 Takeshi Nakatani <ggtakec.com>
|
|
#
|
|
# 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.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
#
|
|
|
|
echo "${PRGNAME} [INFO] Start Linux helper for installing packages."
|
|
|
|
#-----------------------------------------------------------
|
|
# Common variables
|
|
#-----------------------------------------------------------
|
|
PRGNAME=$(basename "$0")
|
|
|
|
#-----------------------------------------------------------
|
|
# Parameter check
|
|
#-----------------------------------------------------------
|
|
#
|
|
# Usage: ${PRGNAME} "OS:VERSION"
|
|
#
|
|
if [ $# -ne 1 ]; then
|
|
echo "${PRGNAME} [ERROR] No container name options specified."
|
|
fi
|
|
|
|
#-----------------------------------------------------------
|
|
# Container OS variables
|
|
#-----------------------------------------------------------
|
|
CONTAINER_FULLNAME=$1
|
|
# shellcheck disable=SC2034
|
|
CONTAINER_OSNAME=$(echo "${CONTAINER_FULLNAME}" | sed 's/:/ /g' | awk '{print $1}')
|
|
# shellcheck disable=SC2034
|
|
CONTAINER_OSVERSION=$(echo "${CONTAINER_FULLNAME}" | sed 's/:/ /g' | awk '{print $2}')
|
|
|
|
#-----------------------------------------------------------
|
|
# Common variables for pip
|
|
#-----------------------------------------------------------
|
|
PIP_BIN="pip3"
|
|
PIP_OPTIONS="--upgrade"
|
|
INSTALL_AWSCLI_PACKAGES="awscli"
|
|
|
|
#-----------------------------------------------------------
|
|
# Parameters for configure(set environments)
|
|
#-----------------------------------------------------------
|
|
# shellcheck disable=SC2089
|
|
CONFIGURE_OPTIONS="CXXFLAGS='-O -std=c++03 -DS3FS_PTHREAD_ERRORCHECK=1' --prefix=/usr --with-openssl"
|
|
|
|
#-----------------------------------------------------------
|
|
# OS dependent variables
|
|
#-----------------------------------------------------------
|
|
if [ "${CONTAINER_FULLNAME}" = "ubuntu:21.10" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "ubuntu:20.04" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "ubuntu:18.04" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "ubuntu:16.04" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "debian:bullseye" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl procps python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "debian:buster" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl procps python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "debian:stretch" ]; then
|
|
PACKAGE_MANAGER_BIN="apt-get"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
INSTALL_PACKAGES="autoconf autotools-dev default-jre-headless fuse libfuse-dev libcurl4-openssl-dev libxml2-dev locales-all mime-support libtool pkg-config libssl-dev attr curl procps python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck shellcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "centos:centos8" ]; then
|
|
PACKAGE_MANAGER_BIN="dnf"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
# [NOTE]
|
|
# Installing ShellCheck on CentOS 8 is not easy.
|
|
# Give up to run ShellCheck on CentOS 8 as we don't have to run ShellChek on all operating systems.
|
|
#
|
|
INSTALL_PACKAGES="curl-devel fuse fuse-devel gcc libstdc++-devel gcc-c++ glibc-langpack-en java-11-openjdk-headless libxml2-devel mailcap git automake make openssl-devel attr diffutils curl python3"
|
|
INSTALL_CHECKER_PKGS="cppcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS="--enablerepo=powertools"
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "centos:centos7" ]; then
|
|
PACKAGE_MANAGER_BIN="yum"
|
|
PACKAGE_UPDATE_OPTIONS="update -y"
|
|
|
|
# [NOTE]
|
|
# ShellCheck version(0.3.8) is too low to check.
|
|
# And in this version, it cannot be passed due to following error.
|
|
# "shellcheck: ./test/integration-test-main.sh: hGetContents: invalid argument (invalid byte sequence)"
|
|
#
|
|
INSTALL_PACKAGES="curl-devel fuse fuse-devel gcc libstdc++-devel gcc-c++ glibc-langpack-en java-11-openjdk-headless libxml2-devel mailcap git automake make openssl-devel attr curl python3 epel-release"
|
|
INSTALL_CHECKER_PKGS="cppcheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS="--enablerepo=epel"
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "fedora:35" ]; then
|
|
PACKAGE_MANAGER_BIN="dnf"
|
|
PACKAGE_UPDATE_OPTIONS="update -y -qq"
|
|
|
|
# TODO: Cannot use java-latest-openjdk (17) due to modules issue in S3Proxy/jclouds/Guice
|
|
INSTALL_PACKAGES="curl-devel fuse fuse-devel gcc libstdc++-devel gcc-c++ glibc-langpack-en java-11-openjdk-headless libxml2-devel mailcap git automake make openssl-devel curl attr diffutils procps python3-pip"
|
|
INSTALL_CHECKER_PKGS="cppcheck ShellCheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
elif [ "${CONTAINER_FULLNAME}" = "opensuse/leap:15" ]; then
|
|
PACKAGE_MANAGER_BIN="zypper"
|
|
PACKAGE_UPDATE_OPTIONS="refresh"
|
|
|
|
INSTALL_PACKAGES="automake curl-devel fuse fuse-devel gcc-c++ java-11-openjdk-headless libxml2-devel make openssl-devel python3-pip curl attr ShellCheck"
|
|
INSTALL_CHECKER_PKGS="cppcheck ShellCheck"
|
|
INSTALL_CHECKER_PKG_OPTIONS=""
|
|
|
|
else
|
|
echo "No container configured for: ${CONTAINER_FULLNAME}"
|
|
exit 1
|
|
fi
|
|
|
|
#-----------------------------------------------------------
|
|
# Install
|
|
#-----------------------------------------------------------
|
|
#
|
|
# Update packages (ex. apt-get update -y -qq)
|
|
#
|
|
echo "${PRGNAME} [INFO] Updates."
|
|
/bin/sh -c "${PACKAGE_MANAGER_BIN} ${PACKAGE_UPDATE_OPTIONS}"
|
|
|
|
#
|
|
# Install packages ( with cppcheck )
|
|
#
|
|
echo "${PRGNAME} [INFO] Install packages."
|
|
/bin/sh -c "${PACKAGE_MANAGER_BIN} install -y ${INSTALL_PACKAGES}"
|
|
|
|
echo "${PRGNAME} [INFO] Install cppcheck package."
|
|
/bin/sh -c "${PACKAGE_MANAGER_BIN} ${INSTALL_CHECKER_PKG_OPTIONS} install -y ${INSTALL_CHECKER_PKGS}"
|
|
|
|
# Check Java version
|
|
java -version
|
|
|
|
#
|
|
# Install awscli
|
|
#
|
|
echo "${PRGNAME} [INFO] Install awscli package."
|
|
/bin/sh -c "${PIP_BIN} install ${PIP_OPTIONS} ${INSTALL_AWSCLI_PACKAGES}"
|
|
/bin/sh -c "${PIP_BIN} install ${PIP_OPTIONS} rsa"
|
|
|
|
#-----------------------------------------------------------
|
|
# Set environment for configure
|
|
#-----------------------------------------------------------
|
|
echo "${PRGNAME} [INFO] Set environment for configure options"
|
|
|
|
# shellcheck disable=SC2090
|
|
export CONFIGURE_OPTIONS
|
|
|
|
echo "${PRGNAME} [INFO] Finish Linux helper for installing packages."
|
|
|
|
exit 0
|
|
|
|
#
|
|
# Local variables:
|
|
# tab-width: 4
|
|
# c-basic-offset: 4
|
|
# End:
|
|
# vim600: expandtab sw=4 ts=4 fdm=marker
|
|
# vim<600: expandtab sw=4 ts=4
|
|
#
|