blob: 0b9ed0a6c5dbd242600feaca67cb56c748c3b3bd (
plain)
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
|
(ns tubo.downloader-impl
(:import
[org.schabi.newpipe.extractor.downloader Response]
[okhttp3 Request$Builder OkHttpClient$Builder RequestBody]))
(gen-class
:name tubo.DownloaderImpl
:constructors {[okhttp3.OkHttpClient$Builder] []}
:extends org.schabi.newpipe.extractor.downloader.Downloader
:init downloader-impl)
(gen-class
:name tubo.DownloaderImpl
:constructors {[okhttp3.OkHttpClient$Builder] []}
:extends org.schabi.newpipe.extractor.downloader.Downloader
:prefix "-"
:main false
:state state
:init downloader-impl
:methods [#^{:static true} [init [] tubo.DownloaderImpl]
#^{:static true} [getInstance [] tubo.DownloaderImpl]])
(def user-agent
"Mozilla/5.0 (Windows NT 10.0; rv:128.0) Gecko/20100101 Firefox/128.0")
(def instance (atom nil))
(defn -downloader-impl
[builder]
[[]
(atom {:client
(.. builder
(readTimeout 30 java.util.concurrent.TimeUnit/SECONDS)
(build))})])
(defn -init
([]
(-init (OkHttpClient$Builder.)))
([builder]
(reset! instance (tubo.DownloaderImpl. builder))))
(defn -getInstance
[]
(or @instance (-init)))
(defn -execute
[this request]
(let [http-method (.httpMethod request)
url (.url request)
headers (.headers request)
data-to-send (.dataToSend request)
request-body (and data-to-send (RequestBody/create nil data-to-send))
request-builder (.. (Request$Builder.)
(method http-method request-body)
(url url)
(addHeader "User-Agent" user-agent))]
(doseq [pair (.entrySet headers)]
(let [header-name (.getKey pair)
header-value-list (.getValue pair)]
(if (> (.size header-value-list) 1)
(do
(.removeHeader request-builder header-name)
(doseq [header-value header-value-list]
(.addHeader request-builder header-name header-value)))
(when (= (.size header-value-list) 1)
(.header request-builder header-name (.get header-value-list 0))))))
(let [response (.. (@(.state this) :client)
(newCall (.build request-builder))
(execute))
body (.body response)
response-body-to-return (and body (.string body))
latest-url (.. response (request) (url) (toString))]
(when (= (.code response) 429)
(.close response))
(Response. (.code response)
(.message response)
(.. response (headers) (toMultimap))
response-body-to-return
latest-url))))
(comment
(compile 'tubo.downloader-impl))
|