232 lines
11 KiB
Bash
232 lines
11 KiB
Bash
#!/bin/sh
|
|
# TODO:
|
|
# - Alguna manera de buscar el lenguaje del sistema para pasarlo en set_lang
|
|
# - Extraer fichero y automatizar el proceso de instalación descrito en:
|
|
# https://fran.cr/instalar-firma-digital-costa-rica-gnu-linux-ubuntu-debian/
|
|
|
|
urlencode() {
|
|
ENCODEDURL="$(curl -Gs -w %{url_effective} --data-urlencode @- ./ ||: )"
|
|
printf '%s' "$ENCODEDURL" | sed 's/%0[aA]$//;s/^.*[?]//'
|
|
}
|
|
|
|
get_asp_var() {
|
|
VARS="$@" ; i=0
|
|
for VAR in $VARS ; do
|
|
VAL="$(printf '%s' "$RESPONSE" | grep "id=\"$VAR\"" | cut -d '"' -f 8 | urlencode)"
|
|
[ "$i" != 0 ] && printf '&'
|
|
printf '%s=%s' "$VAR" "$VAL"
|
|
i=+1
|
|
done
|
|
}
|
|
|
|
download_iso() {
|
|
SN="$1"
|
|
URL="https://soportefirmadigital.com/sfdj/dl.aspx"
|
|
|
|
alias curl="curl \
|
|
-H 'Pragma: no-cache' \
|
|
-H 'Connection: keep-alive' \
|
|
-H 'Cache-Control: no-cache' \
|
|
-H 'Upgrade-Insecure-Requests: 1' \
|
|
-H 'User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/128.0' \
|
|
-H 'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8' \
|
|
-H 'Accept-Encoding: gzip, deflate, br' \
|
|
-H 'Accept-Language: es-ES,es;q=0.8,en-US;q=0.5,en;q=0.3' \
|
|
-H 'Referer: https://www.soportefirmadigital.com/sfdj/dl.aspx?lang=en' \
|
|
-H 'Content-Type: application/x-www-form-urlencoded' \
|
|
-H 'Sec-Fetch-Dest: document' \
|
|
-H 'Sec-Fetch-Mode: navigate' \
|
|
-H 'Sec-Fetch-Site: same-origin' \
|
|
-H 'Sec-Fetch-User: ?1' \
|
|
"
|
|
|
|
RESPONSE="$(curl -s --compressed "$URL" -o -)"
|
|
|
|
ASP_VARS="$(get_asp_var __VIEWSTATE __VIEWSTATEGENERATOR __EVENTVALIDATION)"
|
|
RESPONSE="$(curl -Ls --compressed "$URL" \
|
|
--data-raw "__EVENTTARGET=ctl00%24certContents%24ddlInstaladores" \
|
|
--data-raw "__EVENTARGUMENT=" \
|
|
--data-raw "__LASTFOCUS=" \
|
|
--data-raw "$ASP_VARS" \
|
|
--data-raw "ctl00%24certContents%24hiddenISO=Windows_rev62.exe" \
|
|
--data-raw "ctl00%24certContents%24hidden_ISO_URL=-" \
|
|
--data-raw "ctl00%24certContents%24txtSerialNumber=" \
|
|
--data-raw "ctl00%24certContents%24ddlInstaladores=$ddlInstaladores" \
|
|
--data-raw "ctl00%24certContents%24txtDescripcion=$txtDescripcion" \
|
|
--data-raw "ctl00%24certContents%24chkConfirmo=" \
|
|
--data-raw "ctl00%24certContents%24hiddenABID=" \
|
|
-o -)"
|
|
|
|
ASP_VARS="$(get_asp_var __VIEWSTATE __VIEWSTATEGENERATOR __EVENTVALIDATION)"
|
|
RESPONSE="$(curl -H "Set-Cookie: SN=$SN" -s --compressed "$URL" \
|
|
--cookie "SN=$SN" \
|
|
--data-raw "__EVENTTARGET=ctl00%24certContents%24LinkButton3" \
|
|
--data-raw "__EVENTARGUMENT=" \
|
|
--data-raw "__LASTFOCUS=" \
|
|
--data-raw "$ASP_VARS" \
|
|
--data-raw "ctl00%24certContents%24hiddenISO=$hiddenISO" \
|
|
--data-raw "ctl00%24certContents%24hidden_ISO_URL=-" \
|
|
--data-raw "ctl00%24certContents%24txtSerialNumber=$SN" \
|
|
--data-raw "ctl00%24certContents%24ddlInstaladores=$ddlInstaladores" \
|
|
--data-raw "ctl00%24certContents%24txtDescripcion=$txtDescripcion" \
|
|
--data-raw "ctl00%24certContents%24chkConfirmo=on" \
|
|
--data-raw "ctl00%24certContents%24hiddenABID=" \
|
|
-o -)"
|
|
|
|
printf '%s' "$RESPONSE"
|
|
}
|
|
|
|
term_prompt() {
|
|
TITLE="$1" ; PROMPT="$2" ; MODE="$3" ; LIST="$4"
|
|
|
|
if [ "$MODE" = "info" ] ; then
|
|
printf '\n\033[1m\033[34m=== %s ===\033[0m\n%s ENTER' "$TITLE" "$PROMPT"
|
|
fi
|
|
|
|
if [ "$MODE" = "entry" ] ; then
|
|
printf '\n\033[1m\033[34m=== %s ===\033[0m\n%s\n -> ' "$TITLE" "$PROMPT"
|
|
fi
|
|
|
|
if [ "$MODE" = "list" ] ; then
|
|
printf '\n\033[1m\033[34m=== %s ===\033[0m\n%s (1, 2, 3, ...)\n%s\n -> ' "$TITLE" "$PROMPT" "$LIST"
|
|
fi
|
|
|
|
if [ "$MODE" = "error" ] ; then
|
|
printf '\n\033[1m\033[31m=== %s ===\033[0m\n%s\n' "$TITLE" "$PROMPT"
|
|
fi
|
|
}
|
|
|
|
set_file() {
|
|
FILE="$1"
|
|
|
|
[ "$FILE" = "ClientesMac_rev34.zip" ] && hiddenISO="ClientesMac_rev34.zip"
|
|
[ "$FILE" = "ClientesMac_rev34.zip" ] && ddlInstaladores="Usuarios+MAC"
|
|
[ "$FILE" = "ClientesMac_rev34.zip" ] && txtDescripcion="Drivers%2C+Certificados+y+Librerias+para+macOS%0D%0ASISTEMAS+OPERATIVOS+HOMOLOGADOS%0D%0A%0D%0AmacOSX+10.14+o+superior.%0D%0A%0D%0ASoporte+%C3%BAnicamente+en+m%C3%A1quinas+F%C3%ADsicas.%0D%0AMD5%3Aa0dee949d20b41a11ab6d4cc727d94bb"
|
|
[ "$FILE" = "ClientesMac_rev34.zip" ] && SIZE=150252
|
|
|
|
[ "$FILE" = "ClientesLinux_DEB64_Rev25.zip" ] && hiddenISO="ClientesLinux_DEB64_Rev25.zip"
|
|
[ "$FILE" = "ClientesLinux_DEB64_Rev25.zip" ] && ddlInstaladores="Usuarios+Linux+%28DEB+64bits%29"
|
|
[ "$FILE" = "ClientesLinux_DEB64_Rev25.zip" ] && txtDescripcion="Distribuciones+basadas+en+DEB+x64.%0D%0AVersiones+Homologadas%0D%0A-Ubuntu+18.04+LTS+o+superior%28solo+versiones+LTS%29%0D%0A-Debian+10%0D%0A%0D%0ASoporte+%C3%BAnicamente+en+m%C3%A1quinas+F%C3%ADsicas.%0D%0AMD5%3A3a8c11d0273daee7bfc63a17615a8dc9"
|
|
[ "$FILE" = "ClientesLinux_DEB64_Rev25.zip" ] && SIZE=108200
|
|
|
|
[ "$FILE" = "ClientesLinux_CentOS7_Rev6.zip" ] && hiddenISO="ClientesLinux_CentOS7_Rev6.zip"
|
|
[ "$FILE" = "ClientesLinux_CentOS7_Rev6.zip" ] && ddlInstaladores="Usuarios+Linux+RPM+%28CentOS+7%29"
|
|
[ "$FILE" = "ClientesLinux_CentOS7_Rev6.zip" ] && txtDescripcion="Distribuciones+basadas+en+RPM.%0D%0AVersiones+Homologadas%0D%0A-CentOS+7.%0D%0A%0D%0ASoporte+%C3%BAnicamente+en+m%C3%A1quinas+F%C3%ADsicas.%0D%0AMD5%3Aeae741aa8bf16e16a349f0e2ad3b7e64"
|
|
[ "$FILE" = "ClientesLinux_CentOS7_Rev6.zip" ] && SIZE=114344
|
|
|
|
[ "$FILE" = "ClientesLinux_RPM64_Rev24.zip" ] && hiddenISO="ClientesLinux_RPM64_Rev24.zip"
|
|
[ "$FILE" = "ClientesLinux_RPM64_Rev24.zip" ] && ddlInstaladores="Usuarios+Linux+%28RPM+64bits%29"
|
|
[ "$FILE" = "ClientesLinux_RPM64_Rev24.zip" ] && txtDescripcion="Distribuciones+basadas+en+RPM+x64.%0D%0AVersiones+Homologadas%0D%0A-Fedora+34+o+superior%0D%0A-CentOS+Stream+9+%0D%0A%0D%0ASoporte+%C3%BAnicamente+en+m%C3%A1quinas+F%C3%ADsicas.%0D%0AMD5%3A6180c4708fb183c8f452240a7c8c01d0"
|
|
[ "$FILE" = "ClientesLinux_RPM64_Rev24.zip" ] && SIZE=114348
|
|
}
|
|
|
|
set_lang() {
|
|
# See: /var/lib/AccountsService/users/
|
|
[ -z "$SLANG" ] && SLANG="es"
|
|
|
|
if [ "$SLANG" = "es" ] ; then
|
|
TITLE="Instalador firma digital"
|
|
|
|
PROMPT_WELCOME="Bienvenido al asistente de instalación de certificados para firma digial."
|
|
|
|
PROMPT_FILE="Seleccione el fichero que corresponde a su sistema operativo."
|
|
FILENAME="Archivo"
|
|
FILEDESC="Sistema"
|
|
|
|
PROMPT_SERIAL="Para continuar con la descarga del fichero del Centro de Soporte Firma Digital, por favor, ingrese el número serial que se encuentra al reverso de la tarjeta."
|
|
PROMPT_ERR_SERIAL="Error al obtener el número serial de la tarjeta, abortando."
|
|
PROMPT_ERR_DOWNLOAD="Error al descargar el fichero desde Centro de Soporte Firma Digital, abortando."
|
|
|
|
PROMPT_DIR_FILE="A continuación, deberá seleccionar la carpeta donde quiere que se descargue y se extraigan los contenidos del fichero seleccionado"
|
|
PROMPT_ERR_DIR_FILE="Error al seleccionar la carpeta de descarga para el fichero, abortando."
|
|
|
|
PROMPT_DOWNLOAD="Descargando el fichero $FILE desde Centro de Soporte Firma Digital..."
|
|
PROMPT_ERR_DOWN_FILE="Error al descargar el fichero, abortando."
|
|
fi
|
|
|
|
if [ "$SLANG" = "en" ] ; then
|
|
TITLE="Digital signature installer"
|
|
fi
|
|
|
|
if [ "$SLANG" = "fr" ] ; then
|
|
TITLE="Installation de signature"
|
|
fi
|
|
}
|
|
|
|
# main
|
|
|
|
set_lang
|
|
|
|
if [ -e "/bin/zenity" ] ; then
|
|
# Welcome
|
|
zenity --title "$TITLE" --text "$PROMPT_WELCOME" --info
|
|
|
|
# Select file to be downloaded
|
|
FILE="$(zenity --title "$TITLE" --text "$PROMPT_FILE" --list \
|
|
--column "$FILENAME" --column "$FILEDESC" \
|
|
"ClientesMac_rev34.zip" "macOSX 10.14 o superior" \
|
|
"ClientesLinux_DEB64_Rev25.zip" "Ubuntu 18.04 LTS o superior, Debian 10" \
|
|
"ClientesLinux_CentOS7_Rev6.zip" "CentOS 7" \
|
|
"ClientesLinux_RPM64_Rev24.zip" "Fedora 34 o superior, CentOS Stream 9" \
|
|
--print-column=1)"
|
|
|
|
# Set file to be downloaded
|
|
set_file "$FILE"
|
|
|
|
# Ask for serial number
|
|
SERIAL="$(zenity --title "$TITLE" --text "$PROMPT_SERIAL" --entry)"
|
|
[ -z "$SERIAL" ] && zenity --title "$TITLE" --text "$PROMPT_ERR_SERIAL" --error && exit 1
|
|
|
|
# Generate tempkey & Define DOWNLOAD_URL
|
|
TEMPKEY="$(download_iso "$SERIAL" | sed '/tempkey/!d;s/.*tempkey=//g;s/".*$//g')"
|
|
[ -z "$TEMPKEY" ] && zenity --title "$TITLE" --text "$PROMPT_ERR_DOWNLOAD" --error && exit 1
|
|
DOWNLOAD_URL="https://soportefirmadigital.com/sfdj/getiso.aspx?tempkey=$TEMPKEY"
|
|
|
|
# Define where to save file
|
|
zenity --title "$TITLE" --text "$PROMPT_DIR_FILE" --info
|
|
SAVE_FILE="$(zenity --file-selection --directory)"
|
|
[ -z "$SAVE_FILE" ] && zenity --title "$TITLE" --text "$PROMPT_ERR_DIR_FILE" --error && exit 1
|
|
SAVE_FILE="$SAVE_FILE/$FILE"
|
|
|
|
# Download file & show progress
|
|
(while true ; do
|
|
DOWN="$(du "$SAVE_FILE" 2>/dev/null | awk '{print $1}')"
|
|
r=$(((DOWN*10000)/SIZE))
|
|
printf '%d\n' ${r%??}
|
|
sleep 0.5
|
|
done | zenity --title "$TITLE" --text "$PROMPT_DOWNLOAD" --progress) & curl "$DOWNLOAD_URL" -o "$SAVE_FILE"
|
|
else
|
|
# Welcome
|
|
term_prompt "$TITLE" "$PROMPT_WELCOME" info && read -r NULL
|
|
|
|
# Select file to be downloaded
|
|
LIST="$(printf '\033[4m1\033[0m - ClientesMac_rev34.zip | macOSX 10.14 o superior
|
|
\033[4m2\033[0m - ClientesLinux_DEB64_Rev25.zip | Ubuntu 18.04 LTS o superior, Debian 10
|
|
\033[4m3\033[0m - ClientesLinux_CentOS7_Rev6.zip | CentOS 7
|
|
\033[4m4\033[0m - ClientesLinux_RPM64_Rev24.zip | Fedora 34 o superior, CentOS Stream 9')"
|
|
term_prompt "$TITLE" "$PROMPT_FILE" list "$LIST" && read -r FILE
|
|
[ "$FILE" = "1" ] && FILE="ClientesMac_rev34.zip"
|
|
[ "$FILE" = "2" ] && FILE="ClientesLinux_DEB64_Rev25.zip"
|
|
[ "$FILE" = "3" ] && FILE="ClientesLinux_CentOS7_Rev6.zip"
|
|
[ "$FILE" = "4" ] && FILE="ClientesLinux_RPM64_Rev24.zip"
|
|
|
|
# Set file to be downloaded
|
|
set_file "$FILE"
|
|
|
|
# Ask for serial number
|
|
term_prompt "$TITLE" "$PROMPT_SERIAL" entry && read -r SERIAL
|
|
[ -z "$SERIAL" ] && term_prompt "$TITLE" "$PROMPT_ERR_SERIAL" error && exit 1
|
|
|
|
# Generate tempkey & Define DOWNLOAD_URL
|
|
TEMPKEY="$(download_iso "$SERIAL" | sed '/tempkey/!d;s/.*tempkey=//g;s/".*$//g')"
|
|
[ -z "$TEMPKEY" ] && term_prompt "$TITLE" "$PROMPT_ERR_DOWNLOAD" error && exit 1
|
|
DOWNLOAD_URL="https://soportefirmadigital.com/sfdj/getiso.aspx?tempkey=$TEMPKEY"
|
|
|
|
# Define where to save file
|
|
mkdir -p "$HOME/Library/Caches/TemporaryItems/instalador-firma-digital"
|
|
SAVE_FILE="$HOME/Library/Caches/TemporaryItems/instalador-firma-digital/$FILE"
|
|
|
|
# Download file & show progress
|
|
term_prompt "$TITLE" "$PROMPT_DOWNLOAD" info && echo
|
|
curl "$DOWNLOAD_URL" -o "$SAVE_FILE" --progress-bar
|
|
fi
|