refactoring
- rename bin/update-formats to bin/update-formats.sh - fix unnecessary bashisms in bin/update-formats.sh
This commit is contained in:
parent
9d645a7ba4
commit
c209a1d3a1
|
@ -127,17 +127,17 @@ The lists can be conveniently used in PHP or Node projects including this packag
|
||||||
An export module with a constant having an array value comprised of every IANA TLD.
|
An export module with a constant having an array value comprised of every IANA TLD.
|
||||||
|
|
||||||
## Updating the TLD lists
|
## Updating the TLD lists
|
||||||
* [bin/update-formats](/bin/update-formats)
|
* [bin/update-formats](/bin/update-formats.sh)
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
$ bin/update-formats
|
$ bin/update-formats.sh
|
||||||
```
|
```
|
||||||
|
|
||||||
This should be all you need to update all the list formats using the latest data from IANA.
|
This should be all you need to update all the list formats using the latest data from IANA.
|
||||||
|
|
||||||
It uses multiple "helper" scripts to generate the full set of native format lists.
|
It uses multiple "helper" scripts to generate the full set of native format lists.
|
||||||
|
|
||||||
The individual "helper" scripts do not need to be directly executed when [update-formats](/bin/update-formats)
|
The individual "helper" scripts do not need to be directly executed when [update-formats.sh](/bin/update-formats.sh)
|
||||||
runs successfully.
|
runs successfully.
|
||||||
|
|
||||||
## Legal
|
## Legal
|
||||||
|
|
|
@ -1,161 +0,0 @@
|
||||||
#!/usr/bin/env bash
|
|
||||||
################################################################################
|
|
||||||
## "update-formats"
|
|
||||||
## Updates the 'tlds.csv' file from iana.org and re-generates the native
|
|
||||||
## format files
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
################################################################################
|
|
||||||
## script localization
|
|
||||||
################################################################################
|
|
||||||
ME_NAME="update-formats"
|
|
||||||
ME_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
||||||
HELPER_DIR=$ME_DIR/helpers
|
|
||||||
################################################################################
|
|
||||||
## enforce dependencies
|
|
||||||
################################################################################
|
|
||||||
DEPENDENCY_SET=(node php)
|
|
||||||
DEPENDENCY_STATUS=0
|
|
||||||
for DEP_CMD in "${DEPENDENCY_SET[@]}"
|
|
||||||
do
|
|
||||||
which $DEP_CMD > /dev/null 2>&1
|
|
||||||
DEP_STATUS=$?
|
|
||||||
if [ "$DEP_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo -e "$ME_NAME: (NOTICE) failed dependency check for '$DEP_CMD', command is missing or inaccessible"
|
|
||||||
DEPENDENCY_STATUS=1
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [ "$DEPENDENCY_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo -e "$ME_NAME: (FATAL) one or more dependency checks failed"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
################################################################################
|
|
||||||
## read options and flags
|
|
||||||
################################################################################
|
|
||||||
QUIET_MODE=0
|
|
||||||
typeset -A SCRIPT_OPTS_MAP
|
|
||||||
SCRIPT_OPTS_MAP=(
|
|
||||||
[quiet]=q
|
|
||||||
)
|
|
||||||
SCRIPT_OPTS="::-:q"
|
|
||||||
#== parse options ==#
|
|
||||||
while getopts ${SCRIPT_OPTS} OPTION ; do
|
|
||||||
#== translate long options to short ==#
|
|
||||||
OPTREF="-$OPTARG"
|
|
||||||
if [[ "x$OPTION" == "x-" ]]; then
|
|
||||||
LONG_OPTION=$OPTARG
|
|
||||||
LONG_OPTARG=$(echo $LONG_OPTION | grep "=" | cut -d'=' -f2)
|
|
||||||
LONG_OPTIND=-1
|
|
||||||
[[ "x$LONG_OPTARG" = "x" ]] && LONG_OPTIND=$OPTIND || LONG_OPTION=$(echo $OPTARG | cut -d'=' -f1)
|
|
||||||
[[ $LONG_OPTIND -ne -1 ]] && eval LONG_OPTARG="\$$LONG_OPTIND"
|
|
||||||
OPTION=${SCRIPT_OPTS_MAP[$LONG_OPTION]}
|
|
||||||
[[ "x$OPTION" = "x" ]] && OPTION="?" OPTARG="-$LONG_OPTION"
|
|
||||||
OPTREF="--$LONG_OPTION"
|
|
||||||
if [[ $( echo "${SCRIPT_OPTS}" | grep -c "${OPTION}:" ) -eq 1 ]]; then
|
|
||||||
if [[ "x${LONG_OPTARG}" = "x" ]] || [[ "${LONG_OPTARG}" = -* ]]; then
|
|
||||||
OPTION=":" OPTARG="-$LONG_OPTION"
|
|
||||||
else
|
|
||||||
OPTARG="$LONG_OPTARG";
|
|
||||||
if [[ $LONG_OPTIND -ne -1 ]]; then
|
|
||||||
[[ $OPTIND -le $Optnum ]] && OPTIND=$(( $OPTIND+1 ))
|
|
||||||
shift $OPTIND
|
|
||||||
OPTIND=1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
#== options follow by another option instead of argument ==#
|
|
||||||
if [[ "x${OPTION}" != "x:" ]] && [[ "x${OPTION}" != "x?" ]] && [[ "${OPTARG}" = -* ]]; then
|
|
||||||
OPTARG="$OPTION" OPTION=":"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#== manage options ==#
|
|
||||||
case "$OPTION" in
|
|
||||||
q)
|
|
||||||
QUIET_MODE=1
|
|
||||||
;;
|
|
||||||
: ) >&2 echo "${ME_NAME}: (FATAL) $OPTREF option requires a value" && echo -e "$ME_USAGE" && exit 1 ;;
|
|
||||||
? ) >&2 echo "${ME_NAME}: (FATAL) $OPTREF is an unknown option" && echo -e "$ME_USAGE" && exit 1 ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
shift $((${OPTIND} - 1))
|
|
||||||
################################################################################
|
|
||||||
## display welcome message
|
|
||||||
################################################################################
|
|
||||||
if [ "$QUIET_MODE" -ne "1" ]; then
|
|
||||||
echo "update-formats"
|
|
||||||
echo " (c) 2017 Doug Bird, All Rights Reserved."
|
|
||||||
echo " see README.md for licensing and other information"
|
|
||||||
echo " https://github.com/katmore/tld-enum#readme"
|
|
||||||
echo ""
|
|
||||||
echo " Updates the 'tlds.csv' file from iana.org and re-generates the native format files"
|
|
||||||
echo ""
|
|
||||||
fi
|
|
||||||
|
|
||||||
################################################################################
|
|
||||||
## run the 'generate-tlds-csv.js' helper
|
|
||||||
################################################################################
|
|
||||||
CUR_HELPER_LABEL="new 'tlds.csv'"
|
|
||||||
CUR_HELPER_CMD=generate-tlds-csv.js
|
|
||||||
echo -e "generate $CUR_HELPER_LABEL: started\n"
|
|
||||||
$HELPER_DIR/$CUR_HELPER_CMD -q
|
|
||||||
CMD_STATUS=$?
|
|
||||||
# terminate if helper failed
|
|
||||||
if [ "$CMD_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo "$ME_NAME: (FATAL) helper for $CUR_HELPER_LABEL failed ($CUR_HELPER_CMD exit status $CMD_STATUS)"
|
|
||||||
exit $CMD_STATUS
|
|
||||||
fi
|
|
||||||
echo -e "\ngenerate new $CUR_HELPER_LABEL: success"
|
|
||||||
|
|
||||||
################################################################################
|
|
||||||
## run the 'generate-php-tld-enum.php' helper
|
|
||||||
################################################################################
|
|
||||||
CUR_HELPER_LABEL="new PHP format files"
|
|
||||||
CUR_HELPER_CMD=generate-php-tld-enum.php
|
|
||||||
echo -e "generate $CUR_HELPER_LABEL: started\n"
|
|
||||||
$HELPER_DIR/$CUR_HELPER_CMD -q
|
|
||||||
CMD_STATUS=$?
|
|
||||||
# terminate if helper failed
|
|
||||||
if [ "$CMD_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo "$ME_NAME: (FATAL) helper for $CUR_HELPER_LABEL failed ($CUR_HELPER_CMD exit status $CMD_STATUS)"
|
|
||||||
exit $CMD_STATUS
|
|
||||||
fi
|
|
||||||
echo -e "\ngenerate new $CUR_HELPER_LABEL: success"
|
|
||||||
|
|
||||||
################################################################################
|
|
||||||
## run the 'generate-js-tld-enum.js' helper
|
|
||||||
################################################################################
|
|
||||||
CUR_HELPER_LABEL="new JavaScript format files"
|
|
||||||
CUR_HELPER_CMD=generate-js-tld-enum.js
|
|
||||||
echo -e "generate $CUR_HELPER_LABEL: started\n"
|
|
||||||
$HELPER_DIR/$CUR_HELPER_CMD -q
|
|
||||||
CMD_STATUS=$?
|
|
||||||
# terminate if helper failed
|
|
||||||
if [ "$CMD_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo "$ME_NAME: (FATAL) helper for $CUR_HELPER_LABEL failed ($CUR_HELPER_CMD exit status $CMD_STATUS)"
|
|
||||||
exit $CMD_STATUS
|
|
||||||
fi
|
|
||||||
echo -e "\ngenerate new $CUR_HELPER_LABEL: success"
|
|
||||||
|
|
||||||
################################################################################
|
|
||||||
## run the 'generate-json-tld-enum.js' helper
|
|
||||||
################################################################################
|
|
||||||
CUR_HELPER_LABEL="new JSON format files"
|
|
||||||
CUR_HELPER_CMD=generate-json-tld-enum.js
|
|
||||||
echo -e "generate $CUR_HELPER_LABEL: started\n"
|
|
||||||
$HELPER_DIR/$CUR_HELPER_CMD -q
|
|
||||||
CMD_STATUS=$?
|
|
||||||
# terminate if helper failed
|
|
||||||
if [ "$CMD_STATUS" -ne "0" ]; then
|
|
||||||
>&2 echo "$ME_NAME: (FATAL) helper for $CUR_HELPER_LABEL failed ($CUR_HELPER_CMD exit status $CMD_STATUS)"
|
|
||||||
exit $CMD_STATUS
|
|
||||||
fi
|
|
||||||
echo -e "\ngenerate new $CUR_HELPER_LABEL: success"
|
|
|
@ -0,0 +1,115 @@
|
||||||
|
#!/bin/sh
|
||||||
|
################################################################################
|
||||||
|
## "update-formats"
|
||||||
|
## Updates the 'tlds.csv' file from iana.org and re-generates the native
|
||||||
|
## format files
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
################################################################################
|
||||||
|
## script localization
|
||||||
|
################################################################################
|
||||||
|
ME_NAME=$(basename $0)
|
||||||
|
ME_DIR="/$0"; ME_DIR=${ME_DIR%/*}; ME_DIR=${ME_DIR:-.}; ME_DIR=${ME_DIR#/}/; ME_DIR=$(cd "$ME_DIR"; pwd)
|
||||||
|
HELPER_DIR=$ME_DIR/helpers
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## read options and flags
|
||||||
|
################################################################################
|
||||||
|
QUIET_MODE=0
|
||||||
|
HELP_MODE=0
|
||||||
|
OPTION_STATUS=0
|
||||||
|
while getopts :?qhua-: arg; do { case $arg in
|
||||||
|
q) QUIET_MODE=1;;
|
||||||
|
h|u|a) HELP_MODE=1;;
|
||||||
|
-) LONG_OPTARG="${OPTARG#*=}"; case $OPTARG in
|
||||||
|
quiet) QUIET_MODE=1;;
|
||||||
|
help|usage|about) HELP_MODE=1;;
|
||||||
|
*) >&2 echo "$ME_NAME: unrecognized long option --$OPTARG"; OPTION_STATUS=2;;
|
||||||
|
esac ;;
|
||||||
|
*) >&2 echo "$ME_NAME: unrecognized option -$OPTARG"; OPTION_STATUS=2;;
|
||||||
|
esac } done
|
||||||
|
shift $((OPTIND-1)) # remove parsed options and args from $@ list
|
||||||
|
[ "$OPTION_STATUS" != "0" ] && { >&2 echo "$ME_NAME: (FATAL) one or more invalid options"; exit $OPTION_STATUS; }
|
||||||
|
[ -z "$@" ] || { >&2 echo "$ME_NAME: (FATAL) one or more unrecognized positional arguments ($@)"; exit 2; }
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## display welcome message
|
||||||
|
################################################################################
|
||||||
|
if ( [ "$QUIET_MODE" != "1" ] || [ "$HELP_MODE" = "1" ] ); then
|
||||||
|
echo "TLD update utility"
|
||||||
|
echo ""
|
||||||
|
echo "Updates the tlds.csv file from IANA and re-generates the native format files."
|
||||||
|
echo ""
|
||||||
|
echo "(c) 2017-2018 Doug Bird, All Rights Reserved."
|
||||||
|
echo "see README.md for licensing and other information"
|
||||||
|
echo "https://github.com/katmore/tld-enum#readme"
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## apply help mode
|
||||||
|
################################################################################
|
||||||
|
if [ "$HELP_MODE" = "1" ]; then
|
||||||
|
echo "usage:"
|
||||||
|
echo " $ME_NAME [-h] | [-q]"
|
||||||
|
echo ""
|
||||||
|
echo "options:"
|
||||||
|
echo " -h,--help: Print a help message and exit."
|
||||||
|
echo " -q,--quiet: Print less output."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## enforce dependencies
|
||||||
|
################################################################################
|
||||||
|
DEPENDENCY_STATUS=0
|
||||||
|
depcheck() { dep_cmd=$1; dep_label=$2
|
||||||
|
$dep_cmd > /dev/null 2>&1 || {
|
||||||
|
>&2 echo "$ME_NAME: failed dependency check for '$dep_label', command is missing or inaccessible"
|
||||||
|
DEPENDENCY_STATUS=1
|
||||||
|
} }
|
||||||
|
depcheck "node -v" "node"
|
||||||
|
depcheck "php -v" "php"
|
||||||
|
if [ "$DEPENDENCY_STATUS" != "0" ]; then
|
||||||
|
>&2 echo "$ME_NAME: (FATAL) one or more dependency checks failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## helper execution wrapper function
|
||||||
|
################################################################################
|
||||||
|
helper() { helper_cmd=$1; helper_label=$2
|
||||||
|
printf "generate $helper_label: started\n\n"
|
||||||
|
$HELPER_DIR/$helper_cmd -q || { cmd_status=$?
|
||||||
|
>&2 echo "$ME_NAME: (FATAL) helper for $helper_label failed ($helper_cmd exit status $cmd_status)"
|
||||||
|
exit $cmd_status
|
||||||
|
}
|
||||||
|
printf "\ngenerate new $helper_label: success\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## run the 'generate-tlds-csv.js' helper
|
||||||
|
################################################################################
|
||||||
|
helper generate-tlds-csv.js "new 'tlds.csv'"
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## run the 'generate-php-tld-enum.php' helper
|
||||||
|
################################################################################
|
||||||
|
helper generate-php-tld-enum.php "new PHP format files"
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## run the 'generate-js-tld-enum.js' helper
|
||||||
|
################################################################################
|
||||||
|
helper generate-js-tld-enum.js "new JavaScript format files"
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
## run the 'generate-json-tld-enum.js' helper
|
||||||
|
################################################################################
|
||||||
|
helper generate-json-tld-enum.js "new JSON format files"
|
Loading…
Reference in New Issue