-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathdijnet-dump.sh
executable file
·141 lines (126 loc) · 6.75 KB
/
dijnet-dump.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#!/usr/bin/env bash
# dijnet.hu invoice downloader [https://github.com/wolandmaster/dijnet-dump]
# Copyright (c) 2016-2022 Sandor Balazsi and others
# This software may be distributed under the terms of the Apache 2.0 license
if ! type xmllint wget xxd &>/dev/null || [[ ${BASH_VERSINFO[0]} < 4 ]]; then
echo "Dependency missing! Please install them:" >&2
echo "- debian/ubuntu: apt-get install wget xxd libxml2-utils" >&2
echo "- fedora: dnf install wget vim-common findutils" >&2
echo "- openwrt/lede: opkg install bash wget xxd libxml2-utils" >&2
echo "- macos: brew install bash wget libxml2" >&2
echo "- cygwin: setup-x86.exe -qP wget,xxd,libxml2" >&2
exit 1
fi
die() {
EXIT_CODE="$?" && printf "$*" >&2 && exit 1
}
absolute_path() {
pushd . >/dev/null && cd "$(dirname "$1")" && pwd -P && popd >/dev/null
}
xpath() {
sed 's/;[[:space:]]*charset=[Ii][Ss][Oo]-8859-2//g' | xmllint --html --xpath "$1" - 2>/dev/null
}
unaccent() {
xxd -ps | tr -d '\n' | sed -E 's/(..)/ \1/g
s/e1/61/g;s/c1/41/g;s/e9/65/g;s/c9/45/g;s/ed/69/g;s/cd/49/g;s/f3/6f/g;s/d3/4f/g;s/f5/6f/g
s/d5/4f/g;s/f6/6f/g;s/d6/4f/g;s/fa/75/g;s/da/55/g;s/fb/75/g;s/db/55/g;s/fc/75/g;s/dc/55/g
s/c3 a1/61/g;s/c3 81/41/g;s/c3 a9/65/g;s/c3 89/45/g;s/c3 ad/69/g;s/c3 8d/49/g
s/c3 b3/6f/g;s/c3 93/4f/g;s/c3 b6/6f/g;s/c3 96/4f/g;s/c5 91/6f/g;s/c5 90/4f/g
s/c3 ba/75/g;s/c3 9a/55/g;s/c3 bc/75/g;s/c3 9c/55/g;s/c5 b1/75/g;s/c5 b0/55/g' \
| xxd -r -ps | sed -E 's/&(.)(acute|uml|dblac);/\1/g;s/ / /g'
}
dijnet() {
URL_POSTFIX="$1"; shift
wget --quiet --user-agent="" --output-document=- --no-check-certificate \
--load-cookies="${COOKIES}" --save-cookies="${COOKIES}" --keep-session-cookies $* \
"${DIJNET_BASE_URL}/${URL_POSTFIX}"
}
invoice_data() {
local IFS="|"; FILTER=$(sed 's/|/" or text()="/g' <<<"$*")
VALUE_ELEMENT=$(unaccent <<<"${DOWNLOAD_PAGE}" | xpath '//label[text()="'"${FILTER}"'"]/../following-sibling::div')
VALUE=$(xpath 'string(//input/@value)' <<<"${VALUE_ELEMENT}")
[[ -z "${VALUE}" ]] && VALUE=$(xpath '//a/text()' <<<"${VALUE_ELEMENT}")
echo "${VALUE}"
}
download_internal_links() {
HREFS=$(xpath '//div[contains(@class, "col-11")]/a/@href')
LINKS=$(tr -d '\n' <<<"${HREFS}" | sed -E $'s/[[:space:]]*href="//g;s/"[[:space:]]*/\\\n/g')
for LINK in ${LINKS}; do
grep -q "^http" <<<"${LINK}" && continue
wget --quiet --user-agent="" --load-cookies="${COOKIES}" --content-disposition --no-clobber \
--no-check-certificate --directory-prefix="${FIXED_TARGET_FOLDER}" "${DIJNET_BASE_URL}/ekonto/control/${LINK}"
done
}
progress() {
local PROVIDER_NAME=$(sed 's/ ()$//' <<<"${INVOICE_PROVIDER} (${INVOICE_PROVIDER_ALIAS})")
if type pv &>/dev/null; then
pv -N "download \"${PROVIDER_NAME}\", total: ${#INVOICES[@]}, current" \
-W -b -p -l -t -e -s "${#INVOICES[@]}" >/dev/null
else
awk -v name="${PROVIDER_NAME}" -v total="${#INVOICES[@]}" \
'{printf "\033[2K\rdownload \"%s\", total: %d, current: %d", name, total, $1; fflush(stdout)}
END {if (NR>0) printf "\n"}'
fi
}
set -o pipefail; export LANG=C LC_ALL=C
. "$(absolute_path "$0")/dijnet-dump.conf" || die "ERROR: config file (dijnet-dump.conf) missing"
[[ "$1" == "-d" ]] && DEBUG_LOG="yes" && shift
DIJNET_USERNAME="${1:-${DIJNET_USERNAME}}"
[[ -z "${DIJNET_USERNAME}" ]] && die "usage: $(basename "$0") [-d] username"
[[ -z "${DIJNET_PASSWORD}" ]] && read -r -s -p "password: " DIJNET_PASSWORD && echo
if [[ "${DEBUG_LOG}" == "yes" ]]; then
exec 3> >(sed 's/'"${DIJNET_USERNAME}"'/<USERNAME>/g;s/'"${DIJNET_PASSWORD}"'/********/g' >dijnet-dump.log)
export BASH_XTRACEFD="3"
set -x
fi
COOKIES=$(mktemp)
trap "rm ${COOKIES}" EXIT
printf "login... "
LOGIN_PAGE=$(dijnet "ekonto/login/login_check_ajax" --post-data "username=${DIJNET_USERNAME}&password=${DIJNET_PASSWORD}")
if ! grep -qi '"success": true' <<<"${LOGIN_PAGE}"; then
LOGIN_ERROR=$(unaccent <<<"${LOGIN_PAGE}" | sed -En 's/[[:space:]]*"error": "([^"]*)"/\1/p')
die "\nERROR: login failed (${LOGIN_ERROR})"
else
REDIRECT_URL=$(sed -En 's/[[:space:]]*"url": "\/([^"]*)"/\1/p' <<<"${LOGIN_PAGE}")
MAIN_PAGE=$(dijnet "${REDIRECT_URL}")
fi
echo OK
printf "query service providers... "
PROVIDERS_PAGE=$(dijnet "ekonto/control/szamla_search")
grep -c "sopts.add" <<<"${PROVIDERS_PAGE}" || die "ERROR: not able to detect service providers"
type pv &>/dev/null || echo "hint: install \"pv\" package for a nice progress bar"
unaccent <<<"${PROVIDERS_PAGE}" | sed -En 's/.*var ropts = \[(.*)\];.*/\1/p' | sed $'s/}, {/}\\\n{/g' \
| while read -r PROVIDER_JSON; do
INVOICE_SEARCH=$(dijnet "ekonto/control/szamla_search")
VFW_TOKEN=$(xpath 'string(//input[@name="vfw_token"]/@value)' <<<"${INVOICE_SEARCH}")
declare -A PROVIDER=$(sed -E 's/"([^"]+)":([^,}]+),?/ [\1]=\2/g;s/^\{/(/;s/}$/ )/' <<<"${PROVIDER_JSON}")
INVOICE_PROVIDER=$(sed 's/\.$//' <<<"${PROVIDER["szlaszolgnev"]}")
INVOICE_PROVIDER_ALIAS=$(sed 's/^null$//' <<<"${PROVIDER["alias"]}")
INVOICES_PAGE=$(dijnet "ekonto/control/szamla_search_submit" --post-data "vfw_form=szamla_search_submit"`
`"&vfw_token=${VFW_TOKEN}&vfw_coll=szamla_search_params®szolgid=${PROVIDER["regszolgid"]}"`
`"&datumtol=$(sed 's/\./-/g' <<<"${FROM_DATE}")&datumig=$(sed 's/\./-/g' <<<"${TILL_DATE}")")
IFS=$'\n' INVOICES=($(sed -En "s/.*clickSzamla\('szamla_select', ([0-9]+).*/\1/p" <<<"${INVOICES_PAGE}"))
for INVOICE_INDEX in ${INVOICES[@]}; do
INVOICE_PAGE=$(dijnet "ekonto/control/szamla_select?vfw_coll=szamla_list&vfw_rowid=${INVOICE_INDEX}")
grep -q 'href="/ekonto/control/szamla_letolt"' <<<"${INVOICE_PAGE}" || die "ERROR: not able to select invoice"
DOWNLOAD_PAGE=$(dijnet "ekonto/control/szamla_letolt")
INVOICE_NUMBER=$(invoice_data "Szamlaszam:" | sed 's/\//_/g')
INVOICE_ISSUER_ID=$(invoice_data "Szamlakibocsatoi azonosito:")
INVOICE_PAYMENT_DEADLINE=$(invoice_data "Fizetesi hatarido:" "Beerkezesi hatarido:")
INVOICE_ISSUE_DATE=$(invoice_data "Kiallitas datuma:")
INVOICE_AMOUNT=$(invoice_data "Szamla osszege:")
INVOICE_STATUS=$(invoice_data "Szamla allapota:")
. "$(absolute_path "$0")/dijnet-dump.conf"
FIXED_TARGET_FOLDER=$(sed -E 's/[[:space:]]+/_/g;s/_-_/-/g;s/[.-]+\//\//g' <<<"${TARGET_FOLDER}")
mkdir -p "${FIXED_TARGET_FOLDER}" || die "ERROR: not able to create folder: ${FIXED_TARGET_FOLDER}"
download_internal_links <<<"${DOWNLOAD_PAGE}"
if grep -q 'href="szamla_info"' <<<"${INVOICE_PAGE}"; then
INFO_PAGE=$(dijnet "ekonto/control/szamla_info") && download_internal_links <<<"${INFO_PAGE}"
fi
if grep -q 'href="szamla_reszletek"' <<<"${INVOICE_PAGE}"; then
DETAILS_PAGE=$(dijnet "ekonto/control/szamla_reszletek") && download_internal_links <<<"${DETAILS_PAGE}"
fi
echo $((INVOICE_INDEX + 1))
INVOICE_LIST_PAGE=$(dijnet "ekonto/control/szamla_list")
done | progress || exit 1
done