blob: 8f2b22c8f166c89ae80713af7b19a93b61b0db43 (
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
|
(ns tau.api.playlist
(:require
[clojure.java.data :as j]
[ring.util.codec :refer [url-decode]]
[tau.api.result :as result])
(:import
org.schabi.newpipe.extractor.playlist.PlaylistInfo
org.schabi.newpipe.extractor.Page
org.schabi.newpipe.extractor.NewPipe))
(defrecord Playlist
[id name playlist-type thumbnail-url uploader-name uploader-url
uploader-avatar banner-url next-page stream-count related-streams])
(defrecord PlaylistPage
[next-page related-streams])
(defn get-info
([url]
(let [service (NewPipe/getServiceByUrl (url-decode url))
info (PlaylistInfo/getInfo service (url-decode url))]
(map->Playlist
{:id (.getId info)
:name (.getName info)
:playlist-type (j/from-java (.getPlaylistType info))
:thumbnail-url (.getThumbnailUrl info)
:banner-url (.getBannerUrl info)
:uploader-name (.getUploaderName info)
:uploader-url (.getUploaderUrl info)
:uploader-avatar (.getUploaderAvatarUrl info)
:stream-count (.getStreamCount info)
:next-page (j/from-java (.getNextPage info))
:related-streams (result/get-results (.getRelatedItems info))})))
([url page-url]
(let [service (NewPipe/getServiceByUrl (url-decode url))
info (PlaylistInfo/getMoreItems service url (Page. (url-decode page-url)))]
(map->PlaylistPage
{:next-page (j/from-java (.getNextPage info))
:related-streams (result/get-results (.getItems info))}))))
|