forked from mcrapet/plowshare-modules-legacy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgo4up.sh
328 lines (269 loc) · 10.8 KB
/
go4up.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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
# Plowshare go4up.com module
# Copyright (c) 2012-2015 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_GO4UP_REGEXP_URL='http://\(www\.\)\?go4up\.com'
MODULE_GO4UP_UPLOAD_OPTIONS="
AUTH_FREE,b,auth-free,a=EMAIL:PASSWORD,Free account
INCLUDE,,include,l=LIST,Provide list of host site (comma separated)
COUNT,,count,n=COUNT,Take COUNT mirrors (hosters) from the available list. Default is 5.
API,,api,,Use public API (recommended)"
MODULE_GO4UP_UPLOAD_REMOTE_SUPPORT=yes
MODULE_GO4UP_DELETE_OPTIONS="
AUTH_FREE,b,auth-free,a=EMAIL:PASSWORD,Free account (mandatory)"
MODULE_GO4UP_LIST_OPTIONS=""
MODULE_GO4UP_LIST_HAS_SUBFOLDERS=no
# Static function. Proceed with login
# $1: authentication
# $2: cookie file
# $3: base URL
go4up_login() {
local AUTH_FREE=$1
local COOKIE_FILE=$2
local BASE_URL=$3
local LOGIN_DATA PAGE NAME
LOGIN_DATA='email=$USER&password=$PASSWORD&signin_go='
PAGE=$(post_login "$AUTH_FREE" "$COOKIE_FILE" "$LOGIN_DATA" \
"$BASE_URL/login.php" -b "$COOKIE_FILE") || return
if match 'Bad email/password.' "$PAGE" || \
match 'Please enter a valid email address' "$PAGE"; then
return $ERR_LOGIN_FAILED
fi
PAGE=$(curl -b "$COOKIE_FILE" "$BASE_URL/account.php")
# The new password will be confirmed at : <b>USER_MAIL</b>
NAME=$(echo "$PAGE" | parse_tag \
'The new password will be confirmed at' b) || return
log_debug "Successfully logged in as member '$NAME'"
}
# Upload a file to go4up.com
# $1: cookie file (for account only)
# $2: input file (with full path)
# $3: remote filename
# stdout: go4up.com download link
go4up_upload() {
local COOKIE_FILE=$1
local FILE=$2
local DESTFILE=$3
local BASE_URL='http://go4up.com'
local PAGE LINK FORM UPLOAD_ID USER_ID UPLOAD_BASE_URL
local SITE HOST SITES_ALL SITES_SEL SITES_FORM SITES_MULTI
if [ -n "$API" ]; then
log_debug 'using public API'
# Check if API can handle this upload
if [ -z "$AUTH_FREE" ]; then
log_error 'Public API is only available for registered users.'
return $ERR_BAD_COMMAND_LINE
fi
if [ -n "$COUNT" -o "${#INCLUDE[@]}" -gt 0 ]; then
log_error 'Public API does not support hoster selection.'
return $ERR_BAD_COMMAND_LINE
fi
if match_remote_url "$FILE"; then
log_error 'Public API does not support remote upload.'
return $ERR_BAD_COMMAND_LINE
fi
local USER PASSWORD
split_auth "$AUTH_FREE" USER PASSWORD || return
# http://go4up.com/wiki/index.php/API_doc
PAGE=$(curl -F "user=$USER" -F "pass=$PASSWORD" \
-F "filedata=@$FILE" "$BASE_URL/api/upload.php")
if match '<link>' "$PAGE"; then
: # Nothing to do, just catch the "good" case
elif match '>Invalid login/password<' "$PAGE"; then
return $ERR_LOGIN_FAILED
# Invalid post data count
# Choose host to upload in your account
else
local ERR=$(echo "$PAGE" | parse_tag error)
log_error "Remote error: $ERR"
return $ERR_FATAL
fi
echo "$PAGE" | parse_tag 'link'
return 0
fi
# Public API not used
# Login needs to go before retrieving hosters because accounts
# have a individual hoster lists
if [ -n "$AUTH_FREE" ]; then
go4up_login "$AUTH_FREE" "$COOKIE_FILE" "$BASE_URL" || return
fi
# Retrieve complete hosting site list
# Note: This can be either our first contact with Go4Up (no login)
# or the second (with login), so we need both -b and -c.
if match_remote_url "$FILE"; then
PAGE=$(curl -b "$COOKIE_FILE" -c "$COOKIE_FILE" \
"$BASE_URL/remote.php") || return
FORM=$(grep_form_by_id "$PAGE" 'form_upload' | break_html_lines) || return
UPLOAD_BASE_URL=$(echo "$FORM" | parse_form_action) || return
else
PAGE=$(curl -b "$COOKIE_FILE" -c "$COOKIE_FILE" \
"$BASE_URL") || return
UPLOAD_BASE_URL=$(echo "$PAGE" | parse_attr iframe src) || return
PAGE=$(curl "$UPLOAD_BASE_URL") || return
FORM=$(grep_form_by_id "$PAGE" 'ubr_upload_form' | break_html_lines) || return
fi
UPLOAD_BASE_URL=$(basename_url "$UPLOAD_BASE_URL") || return
log_debug "Upload base URL: $UPLOAD_BASE_URL"
# When logged into account all form fields are on a single line
if [ -n "$AUTH_FREE" ]; then
FORM=$(echo "$FORM" | break_html_lines)
fi
USER_ID=$(echo "$FORM" | parse_form_input_by_name_quiet 'id_user')
SITES_ALL=$(echo "$FORM" | parse_all_attr checkbox value) || return
# Code copied from mirrorcreator module
if [ -z "$SITES_ALL" ]; then
log_error 'Empty list, site updated?'
return $ERR_FATAL
fi
log_debug "Available sites:" $SITES_ALL
if [ -n "$COUNT" ]; then
#if (( COUNT > 10 )); then
# COUNT=10
# log_error "Too big integer value for --count, set it to $COUNT"
#fi
for SITE in $SITES_ALL; do
(( COUNT-- > 0 )) || break
SITES_SEL="$SITES_SEL $SITE"
done
elif [ "${#INCLUDE[@]}" -gt 0 ]; then
for SITE in "${INCLUDE[@]}"; do
# FIXME: Should match word boundary (\< & \> are GNU grep extensions)
if match "$SITE" "$SITES_ALL"; then
SITES_SEL="$SITES_SEL $SITE"
else
log_error "Host not supported: $SITE, ignoring"
fi
done
else
# Default hosting sites selection
SITES_SEL=$(echo "$FORM" | parse_all_attr checked value) || return
fi
if [ -z "$SITES_SEL" ]; then
log_debug 'Empty site selection. Nowhere to upload!'
return $ERR_FATAL
fi
# End of code copy
# Prepare lists of hosts to mirror to
for HOST in $SITES_SEL; do
log_debug "selected site: $HOST"
SITES_FORM="$SITES_FORM -d box%5B%5D=$HOST"
SITES_MULTI="$SITES_MULTI -F box[]=$HOST"
done
# Proceed with upload
if match_remote_url "$FILE"; then
if [ "$DESTFILE" != 'dummy' ]; then
log_error 'Remote filename ignored, not supported by site'
fi
UPLOAD_ID=$(echo "$FORM" | \
parse_form_input_by_id 'progress_key') || return
PAGE=$(curl_with_log -b "$COOKIE_FILE" \
-F "APC_UPLOAD_PROGRESS=$UPLOAD_ID" \
-F "id_user=$USER_ID" \
-F "url=$FILE" \
$SITES_MULTI \
"$UPLOAD_BASE_URL/copy_remote.php") || return
if ! match 'Your link' "$PAGE"; then
log_error 'Error uploading to server'
return $ERR_FATAL
fi
LINK="http://www.go4up.com/dl/$UPLOAD_ID"
else
local UPLOAD_URL1 UPLOAD_URL2
# Site uses UberUpload for direct upload
UPLOAD_URL1=$(echo "$PAGE" | \
parse 'path_to_link_script' '"\([^"]\+\)"') || return
UPLOAD_URL2=$(echo "$PAGE" | \
parse 'path_to_upload_script' '"\([^"]\+\)"') || return
PAGE=$(curl -b "$COOKIE_FILE" \
$SITES_FORM \
-d "id_user=$USER_ID" \
-d "upload_file[]=$DESTFILE" \
"$UPLOAD_BASE_URL$UPLOAD_URL1") || return
# if(typeof UberUpload.startUpload == 'function')
# { UberUpload.startUpload("f7c3511c7eac0716dc64bba7e32ef063",0,0); }
UPLOAD_ID=$(echo "$PAGE" | parse 'startUpload(' '"\([^"]\+\)"') || return
log_debug "Upload ID: $UPLOAD_ID"
# Note: No need to call ubr_set_progress.php, ubr_get_progress.php
PAGE=$(curl_with_log -b "$COOKIE_FILE" \
-F "id_user=$USER_ID" \
-F "upfile_$(date +%s)000=@$FILE;filename=$DESTFILE" \
$SITES_MULTI \
"$UPLOAD_BASE_URL$UPLOAD_URL2?upload_id=$UPLOAD_ID") || return
# parent.UberUpload.redirectAfterUpload('../../uploaded.php?upload_id=9f07...
UPLOAD_URL1=$(echo "$PAGE" | \
parse 'redirectAfter' "('\([^']\+\)'") || return
PAGE=$(curl -b "$COOKIE_FILE" "$UPLOAD_URL1") || return
LINK=$(echo "$PAGE" | parse_attr '/dl/' href) || return
fi
echo "$LINK"
}
# List links from a go4up link
# $1: go4up link
# $2: recurse subfolders (ignored here)
# stdout: list of links
go4up_list() {
local URL=$1
local BASE_URL='http://go4up.com'
local PAGE INFO_URL LINKS NAME
PAGE=$(curl -L "$URL") || return
if match 'The file is being uploaded on mirror websites' "$PAGE"; then
return $ERR_LINK_TEMP_UNAVAILABLE
elif match 'File not Found' "$PAGE"; then
return $ERR_LINK_DEAD
fi
# url: "/download/gethosts/<ID>/<Name>",
INFO_URL=$(parse '^[[:space:]]*url:' '"\(.\+\)"' <<< "$PAGE") || return
NAME=$(parse '<h3' '<h3[[:space:]]*>\(.\+\)[[:space:]]\+([[:alnum:]]\+' <<< "$PAGE") || return
PAGE=$(curl "$BASE_URL$INFO_URL" | break_html_lines) || return
LINKS=$(parse_all_attr 'href' <<< "$PAGE") || return
while read INFO_URL; do
[[ "$INFO_URL" = http://* ]] && continue
PAGE=$(curl "$BASE_URL$INFO_URL") || return
parse_attr '<b>' 'href' <<< "$PAGE" || return
echo "$NAME"
done <<< "$LINKS"
}
# Delete a file on go4up.com
# $1: cookie file
# $2: file URL
go4up_delete() {
local COOKIE_FILE=$1
local URL=$2
local BASE_URL='http://go4up.com'
local PAGE FILE_ID
test "$AUTH_FREE" || return $ERR_LINK_NEED_PERMISSIONS
# Parse URL
# http://go4up.com/link.php?id=1Ddupi2qxbwl
# http://go4up.com/dl/1Ddupi2qxbwl
FILE_ID=$(echo "$URL" | parse . '[=/]\([[:alnum:]]\+\)$') || return
log_debug "File ID: $FILE_ID"
# Check link
PAGE=$(curl "$URL") || return
match 'does not exist or has been removed' "$PAGE" && \
return $ERR_LINK_DEAD
go4up_login "$AUTH_FREE" "$COOKIE_FILE" "$BASE_URL" || return
PAGE=$(curl -b "$COOKIE_FILE" -d "id=$FILE_ID" \
"$BASE_URL/delete.php") || return
# Note: Go4up will *always* send this reply
match 'Your link has been deleted from our database' "$PAGE" || \
return $ERR_FATAL
# Check if link is really gone
PAGE=$(curl "$URL") || return
if ! match 'does not exist or has been removed' "$PAGE"; then
log_error 'File NOT removed. Correct account?'
return $ERR_LINK_NEED_PERMISSIONS
fi
}