2023-02-26 22:49:45 +00:00
|
|
|
#!/bin/bash -
|
|
|
|
#===============================================================================
|
|
|
|
#
|
|
|
|
# FILE: lib_utils.sh
|
|
|
|
#
|
|
|
|
# USAGE: ./lib_utils.sh
|
|
|
|
#
|
|
|
|
# DESCRIPTION: functions for scripts used to update local HPR installations
|
|
|
|
# using the HPR static site generator
|
|
|
|
#
|
|
|
|
# OPTIONS: ---
|
|
|
|
# REQUIREMENTS: mysql2sqlite (https://github.com/dumblob/mysql2sqlite)
|
|
|
|
# BUGS: ---
|
|
|
|
# NOTES: ---
|
|
|
|
# AUTHOR: Roan "Rho`n" Horning <roan.horning@gmail.com>
|
|
|
|
# CREATED: 02/26/2023 03:27:08 PM -5 UTC
|
|
|
|
# REVISION: ---
|
|
|
|
# LICENSE: GNU AGPLv3
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 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 Affero General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
#===============================================================================
|
|
|
|
|
|
|
|
set -o nounset # Treat unset variables as an error
|
|
|
|
|
|
|
|
#--- FUNCTION ----------------------------------------------------------------
|
|
|
|
# NAME: make_working_dir
|
|
|
|
# DESCRIPTION: Creates a local temporary working directory
|
|
|
|
# SEE: https://stackoverflow.com/questions/4632028/how-to-create-a-temporary-directory#answer-34676160
|
|
|
|
# PARAMETERS:
|
|
|
|
# RETURNS: The path to the working directory
|
|
|
|
#-------------------------------------------------------------------------------
|
2023-02-28 04:27:26 +00:00
|
|
|
function make_working_dir {
|
|
|
|
# the directory of the script
|
|
|
|
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
|
|
|
|
|
|
# the temp directory used, within $DIR
|
|
|
|
# omit the -p parameter to create a temporal directory in the default location
|
|
|
|
WORK_DIR=`mktemp -d -p "$DIR"`
|
|
|
|
|
|
|
|
# check if tmp dir was created
|
|
|
|
if [[ ! "$WORK_DIR" || ! -d "$WORK_DIR" ]]; then
|
|
|
|
echo "Could not create temp dir"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
echo $WORK_DIR
|
|
|
|
}
|
2023-02-26 22:49:45 +00:00
|
|
|
|
|
|
|
#--- FUNCTION ----------------------------------------------------------------
|
|
|
|
# NAME: clean_working_dir
|
|
|
|
# DESCRIPTION: Remove local temporary working directory
|
2023-02-28 04:30:24 +00:00
|
|
|
# PARAMETERS: WORK_DIR -- Temporay directory to be delted
|
2023-02-26 22:49:45 +00:00
|
|
|
# RETURNS:
|
|
|
|
#-------------------------------------------------------------------------------
|
2023-02-28 04:30:24 +00:00
|
|
|
function clean_working_dir {
|
|
|
|
if [[ -d $1 ]] && expr $1 : '.*/tmp.*' ; then
|
|
|
|
rm -rf $1
|
|
|
|
echo "Deleted temp working directory $1"
|
|
|
|
else
|
|
|
|
echo "Not a temporary directory: $1"
|
|
|
|
fi
|
|
|
|
|
|
|
|
}
|
2023-02-26 22:49:45 +00:00
|
|
|
|
|
|
|
#--- FUNCTION ----------------------------------------------------------------
|
|
|
|
# NAME: download_hpr_sql
|
|
|
|
# DESCRIPTION: Download the HPR SQL dump file into a working directory
|
|
|
|
# PARAMETERS:
|
|
|
|
# RETURNS:
|
|
|
|
#-------------------------------------------------------------------------------
|
2023-03-04 01:41:29 +00:00
|
|
|
function download_hpr_sql {
|
|
|
|
|
|
|
|
if [[ ! -d $1 ]] || ! expr $1 : '.*/tmp.*' ;
|
|
|
|
then
|
|
|
|
echo "Please provide the temporary directory when calling this function"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
local CURL=`which curl`
|
|
|
|
local WGET=`which wget`
|
|
|
|
local HPR_URL=https://www.hackerpublicradio.org/hpr.sql
|
|
|
|
|
|
|
|
if [ -f $1/hpr.sql ];
|
|
|
|
then
|
|
|
|
echo "Removing temporary hpr.sql"
|
|
|
|
rm $1/hpr.sql
|
|
|
|
else
|
|
|
|
echo "No temporary hpr.sql found"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "$CURL" != "" ];
|
|
|
|
then
|
|
|
|
curl $HPR_URL --output $1/hpr.sql
|
|
|
|
elif [ "$WGET" != "" ];
|
|
|
|
then
|
|
|
|
wget --directory-prefix=$1 $HPR_URL
|
|
|
|
else
|
|
|
|
echo "Could not download file. Please install either curl or wget."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
}
|
2023-02-26 22:49:45 +00:00
|
|
|
|
|
|
|
#--- FUNCTION ----------------------------------------------------------------
|
|
|
|
# NAME: make_hpr_sqlite_db
|
|
|
|
# DESCRIPTION: Converts the hpr sql file into an sqlite db file
|
|
|
|
# PARAMETERS:
|
|
|
|
# RETURNS:
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
function make_hpr_sqlite_db { echo; }
|
|
|
|
|
|
|
|
#--- FUNCTION ----------------------------------------------------------------
|
|
|
|
# NAME: copy_to_public_dir
|
|
|
|
# DESCRIPTION: Move HPR sql and db files to public website folder
|
|
|
|
# PARAMETERS:
|
|
|
|
# RETURNS:
|
|
|
|
#-------------------------------------------------------------------------------
|
|
|
|
function copy_to_public_dir { echo; }
|
|
|
|
|