mirror of
https://github.com/yattee/yattee.git
synced 2024-11-10 00:08:21 +00:00
allow basic auth with auth endpoint
Signed-off-by: Toni Förster <toni.foerster@gmail.com>
This commit is contained in:
parent
cea2684a29
commit
049a42f2e8
@ -247,27 +247,27 @@ final class InvidiousAPI: Service, ObservableObject, VideosAPI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func feed(_ page: Int?) -> Resource? {
|
func feed(_ page: Int?) -> Resource? {
|
||||||
resource(baseURL: account.url, path: "\(Self.basePath)/auth/feed")
|
resourceWithAuthCheck(baseURL: account.url, path: "\(Self.basePath)/auth/feed")
|
||||||
.withParam("page", String(page ?? 1))
|
.withParam("page", String(page ?? 1))
|
||||||
}
|
}
|
||||||
|
|
||||||
var feed: Resource? {
|
var feed: Resource? {
|
||||||
resource(baseURL: account.url, path: basePathAppending("auth/feed"))
|
resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/feed"))
|
||||||
}
|
}
|
||||||
|
|
||||||
var subscriptions: Resource? {
|
var subscriptions: Resource? {
|
||||||
resource(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func subscribe(_ channelID: String, onCompletion: @escaping () -> Void = {}) {
|
func subscribe(_ channelID: String, onCompletion: @escaping () -> Void = {}) {
|
||||||
resource(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
||||||
.child(channelID)
|
.child(channelID)
|
||||||
.request(.post)
|
.request(.post)
|
||||||
.onCompletion { _ in onCompletion() }
|
.onCompletion { _ in onCompletion() }
|
||||||
}
|
}
|
||||||
|
|
||||||
func unsubscribe(_ channelID: String, onCompletion: @escaping () -> Void) {
|
func unsubscribe(_ channelID: String, onCompletion: @escaping () -> Void) {
|
||||||
resource(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/subscriptions"))
|
||||||
.child(channelID)
|
.child(channelID)
|
||||||
.request(.delete)
|
.request(.delete)
|
||||||
.onCompletion { _ in onCompletion() }
|
.onCompletion { _ in onCompletion() }
|
||||||
@ -308,11 +308,11 @@ final class InvidiousAPI: Service, ObservableObject, VideosAPI {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return resource(baseURL: account.url, path: basePathAppending("auth/playlists"))
|
return resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/playlists"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func playlist(_ id: String) -> Resource? {
|
func playlist(_ id: String) -> Resource? {
|
||||||
resource(baseURL: account.url, path: basePathAppending("auth/playlists/\(id)"))
|
resourceWithAuthCheck(baseURL: account.url, path: basePathAppending("auth/playlists/\(id)"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func playlistVideos(_ id: String) -> Resource? {
|
func playlistVideos(_ id: String) -> Resource? {
|
||||||
@ -556,6 +556,30 @@ final class InvidiousAPI: Service, ObservableObject, VideosAPI {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Determines if the request requires Basic Auth credentials to be removed
|
||||||
|
private func needsBasicAuthRemoval(for path: String) -> Bool {
|
||||||
|
return path.hasPrefix("\(Self.basePath)/auth/")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Creates a resource URL with consideration for removing Basic Auth credentials
|
||||||
|
private func createResourceURL(baseURL: URL, path: String) -> URL {
|
||||||
|
var resourceURL = baseURL
|
||||||
|
|
||||||
|
// Remove Basic Auth credentials if required
|
||||||
|
if needsBasicAuthRemoval(for: path), var urlComponents = URLComponents(url: baseURL, resolvingAgainstBaseURL: false) {
|
||||||
|
urlComponents.user = nil
|
||||||
|
urlComponents.password = nil
|
||||||
|
resourceURL = urlComponents.url ?? baseURL
|
||||||
|
}
|
||||||
|
|
||||||
|
return resourceURL.appendingPathComponent(path)
|
||||||
|
}
|
||||||
|
|
||||||
|
func resourceWithAuthCheck(baseURL: URL, path: String) -> Resource {
|
||||||
|
let sanitizedURL = createResourceURL(baseURL: baseURL, path: path)
|
||||||
|
return super.resource(absoluteURL: sanitizedURL)
|
||||||
|
}
|
||||||
|
|
||||||
private func extractThumbnails(from details: JSON) -> [Thumbnail] {
|
private func extractThumbnails(from details: JSON) -> [Thumbnail] {
|
||||||
details["videoThumbnails"].arrayValue.compactMap { json in
|
details["videoThumbnails"].arrayValue.compactMap { json in
|
||||||
guard let url = json["url"].url,
|
guard let url = json["url"].url,
|
||||||
|
Loading…
Reference in New Issue
Block a user