/usr/share/plowshare/modules/hotlink_cc.sh is in plowshare-modules 0~git20171112.e94a905-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 142 143 144 145 146 147 148 149 | # Plowshare hotlink.cc module
# Copyright (c) 2016 Plowshare team
#
# This file is part of Plowshare.
#
# Plowshare 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 3 of the License, or
# (at your option) any later version.
#
# Plowshare 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 Plowshare. If not, see <http://www.gnu.org/licenses/>.
MODULE_HOTLINK_CC_REGEXP_URL='https\?://\(www\.\)\?hotlink\.cc/'
MODULE_HOTLINK_CC_DOWNLOAD_OPTIONS=""
MODULE_HOTLINK_CC_DOWNLOAD_RESUME=yes
MODULE_HOTLINK_CC_DOWNLOAD_FINAL_LINK_NEEDS_COOKIE=no
MODULE_HOTLINK_CC_DOWNLOAD_SUCCESSIVE_INTERVAL=
MODULE_HOTLINK_CC_PROBE_OPTIONS=""
# Output a hotlink.cc file download URL
# $1: cookie file
# $2: hotlink.cc url
# stdout: real file download link
hotlink_cc_download() {
local -r COOKIE_FILE=$1
local URL=$2
local PAGE WAIT_TIME FORM_HTML FORM_OP FORM_ID FORM_RAND FORM_REFERER FORM_METHOD_F FORM_METHOD_P
local CAPTCHA CODE DIGIT XCOORD LINE ERR
PAGE=$(curl -c "$COOKIE_FILE" -b 'lang=english' "$URL") || return
# <div class="err textq"><p style="font-size:20px;">You have to wait ... till next download<br>
if match '>You have to wait .* till next download<' "$PAGE"; then
local HOURS MINS SECS
HOURS=$(parse_quiet '>You have to wait' \
'[^[:digit:]]\([[:digit:]]\+\) hours\?' <<< "$PAGE")
MINS=$(parse_quiet '>You have to wait' \
'[^[:digit:]]\([[:digit:]]\+\) minutes\?' <<< "$PAGE")
SECS=$(parse_quiet '>You have to wait' \
'[^[:digit:]]\([[:digit:]]\+\) seconds\?' <<< "$PAGE")
log_error 'Download limit reached.'
# Note: Always use decimal base instead of octal if there are leading zeros.
echo $(( (( 10#$HOURS * 60 ) + 10#$MINS ) * 60 + 10#$SECS ))
return $ERR_LINK_TEMP_UNAVAILABLE
elif match '>File Not Found</' "$PAGE"; then
return $ERR_LINK_DEAD
fi
# <span id="countdown" style="display:none;font-size:25px">Wait: <span class="seconds yellow"><b>60</b>
WAIT_TIME=$(parse_tag 'id="countdown"' 'b' <<< "$PAGE")
wait $((WAIT_TIME)) || return
FORM_HTML=$(grep_form_by_name "$PAGE" 'F1') || return
FORM_OP=$(parse_form_input_by_name 'op' <<< "$FORM_HTML") || return
FORM_ID=$(parse_form_input_by_name 'id' <<< "$FORM_HTML") || return
FORM_RAND=$(parse_form_input_by_name 'rand' <<< "$FORM_HTML") || return
FORM_REFERER=$(parse_form_input_by_name_quiet 'referer' <<< "$FORM_HTML")
FORM_METHOD_F=$(parse_form_input_by_name_quiet 'method_free' <<< "$FORM_HTML")
FORM_METHOD_P=$(parse_form_input_by_name_quiet 'method_premium' <<< "$FORM_HTML")
# Funny captcha, this is text (4 digits)!
CODE=0
CAPTCHA=$(echo "$FORM_HTML" | parse_tag 'direction:ltr' div | \
replace_all '/span>' '/span>'$'\n') || return
while read LINE; do
DIGIT=$(parse 'padding-' '>&#\([[:digit:]]\+\);<' <<< "$LINE") || return
XCOORD=$(parse 'padding-' '-left:\([[:digit:]]\+\)p' <<< "$LINE") || return
# Depending x, guess digit rank
if (( XCOORD < 15 )); then
(( CODE = CODE + 1000 * (DIGIT-48) ))
elif (( XCOORD < 30 )); then
(( CODE = CODE + 100 * (DIGIT-48) ))
elif (( XCOORD < 50 )); then
(( CODE = CODE + 10 * (DIGIT-48) ))
else
(( CODE = CODE + (DIGIT-48) ))
fi
done <<< "$CAPTCHA"
PAGE=$(curl -b "$COOKIE_FILE" -b 'lang=english' --referer "$URL" \
-d "op=$FORM_OP" \
-d "id=$FORM_ID" \
-d "rand=$FORM_RAND" \
-d "referer=$FORM_REFERER" \
-d "method_free=$FORM_METHOD_F" \
-d "method_premium=$FORM_METHOD_P" \
-d "code=$CODE" \
"$URL") || return
# Get error message, if any
# <div class="err textq"><p style="font-size:20px;"> ... </p></div><br>
ERR=$(parse_tag_quiet '<div class="err ' p <<< "$PAGE")
if [ -n "$ERR" ]; then
if match 'Skipped countdown\|Expired download session\|Wrong captcha' "$ERR"; then
log_error "Remote error: $ERR"
return $ERR_LINK_TEMP_UNAVAILABLE
else
log_error "Remote error: $ERR"
return $ERR_FATAL
fi
fi
# <h2>File Download Link Generated</h2>
# This direct link will be available for your IP next 8 hours<br><br>
parse_attr 'hotlink.cc:' href <<< "$PAGE"
parse_tag '>Filename:[[:space:]]*<' b <<< "$PAGE"
}
# Probe a download URL
# $1: cookie file (unused here)
# $2: hotlink.cc url
# $3: requested capability list
# stdout: 1 capability per line
hotlink_cc_probe() {
local -r URL=$2
local -r REQ_IN=$3
local PAGE FILE_NAME REQ_OUT
PAGE=$(curl "$URL") || return
if match '>File Not Found</' "$PAGE"; then
return $ERR_LINK_DEAD
fi
REQ_OUT=c
# FIXME: Filenames with more than 55 characters are truncated
if [[ $REQ_IN = *f* ]]; then
FILE_NAME=$(parse 'class="dfilename"' '>\([^<]\+\)<' <<< "$PAGE") &&
echo "${FILE_NAME/%…/.truncatedname}" && REQ_OUT="${REQ_OUT}f"
fi
if [[ $REQ_IN = *i* ]]; then
parse_form_input_by_name 'id' <<< "$PAGE" && REQ_OUT="${REQ_OUT}i"
fi
echo $REQ_OUT
}
|