mastodon-app-ufficiale-ipho.../MastodonSDK/Sources/MastodonSDK/API/Mastodon+API+Timeline.swift

248 lines
9.7 KiB
Swift
Raw Normal View History

2021-01-27 11:46:14 +01:00
//
// Mastodon+API+Timeline.swift
//
//
// Created by MainasuK Cirno on 2021/1/27.
//
import Foundation
import Combine
extension Mastodon.API.Timeline {
static func publicTimelineEndpointURL(domain: String) -> URL {
return Mastodon.API.endpointURL(domain: domain).appendingPathComponent("timelines/public")
}
2021-02-03 11:52:47 +01:00
static func homeTimelineEndpointURL(domain: String) -> URL {
return Mastodon.API.endpointURL(domain: domain).appendingPathComponent("timelines/home")
}
2021-03-30 08:16:08 +02:00
static func hashtagTimelineEndpointURL(domain: String, hashtag: String) -> URL {
return Mastodon.API.endpointURL(domain: domain)
2021-04-01 04:12:57 +02:00
.appendingPathComponent("timelines/tag/\(hashtag)")
2021-03-30 08:16:08 +02:00
}
2021-01-27 11:46:14 +01:00
/// View public timeline statuses
///
/// - Since: 0.0.0
/// - Version: 3.3.0
/// # Last Update
/// 2021/2/19
/// # Reference
/// [Document](https://https://docs.joinmastodon.org/methods/timelines/)
/// - Parameters:
/// - session: `URLSession`
/// - domain: Mastodon instance domain. e.g. "example.com"
/// - query: `PublicTimelineQuery` with query parameters
/// - authorization: required if the instance has disabled public preview
/// - Returns: `AnyPublisher` contains `Token` nested in the response
2021-01-27 11:52:01 +01:00
public static func `public`(
2021-01-27 11:46:14 +01:00
session: URLSession,
domain: String,
query: PublicTimelineQuery,
authorization: Mastodon.API.OAuth.Authorization?
2021-02-05 10:53:00 +01:00
) -> AnyPublisher<Mastodon.Response.Content<[Mastodon.Entity.Status]>, Error> {
2021-01-29 12:38:11 +01:00
let request = Mastodon.API.get(
2021-01-27 11:46:14 +01:00
url: publicTimelineEndpointURL(domain: domain),
query: query,
authorization: authorization
2021-01-27 11:46:14 +01:00
)
return session.dataTaskPublisher(for: request)
.tryMap { data, response in
2021-02-05 10:53:00 +01:00
let value = try Mastodon.API.decode(type: [Mastodon.Entity.Status].self, from: data, response: response)
2021-01-27 11:46:14 +01:00
return Mastodon.Response.Content(value: value, response: response)
}
.eraseToAnyPublisher()
}
/// View statuses from followed users.
///
/// - Since: 0.0.0
/// - Version: 3.3.0
/// # Last Update
/// 2021/3/3
/// # Reference
/// [Document](https://https://docs.joinmastodon.org/methods/timelines/)
/// - Parameters:
/// - session: `URLSession`
/// - domain: Mastodon instance domain. e.g. "example.com"
/// - query: `PublicTimelineQuery` with query parameters
/// - authorization: User token
/// - Returns: `AnyPublisher` contains `Token` nested in the response
2021-02-03 11:52:47 +01:00
public static func home(
session: URLSession,
domain: String,
query: HomeTimelineQuery,
authorization: Mastodon.API.OAuth.Authorization
2021-02-05 10:53:00 +01:00
) -> AnyPublisher<Mastodon.Response.Content<[Mastodon.Entity.Status]>, Error> {
2021-02-03 11:52:47 +01:00
let request = Mastodon.API.get(
url: homeTimelineEndpointURL(domain: domain),
query: query,
authorization: authorization
)
return session.dataTaskPublisher(for: request)
.tryMap { data, response in
2021-02-05 10:53:00 +01:00
let value = try Mastodon.API.decode(type: [Mastodon.Entity.Status].self, from: data, response: response)
2021-02-03 11:52:47 +01:00
return Mastodon.Response.Content(value: value, response: response)
}
.eraseToAnyPublisher()
}
2021-03-30 08:16:08 +02:00
/// View public statuses containing the given hashtag.
///
/// - Since: 0.0.0
/// - Version: 3.3.0
/// # Last Update
/// 2021/3/29
/// # Reference
/// [Document](https://https://docs.joinmastodon.org/methods/timelines/)
/// - Parameters:
/// - session: `URLSession`
/// - domain: Mastodon instance domain. e.g. "example.com"
/// - query: `HashtagTimelineQuery` with query parameters
/// - hashtag: Content of a #hashtag, not including # symbol.
2021-04-01 04:12:57 +02:00
/// - authorization: User token, auth is required if public preview is disabled
2021-03-30 08:16:08 +02:00
/// - Returns: `AnyPublisher` contains `Token` nested in the response
public static func hashtag(
session: URLSession,
domain: String,
query: HashtagTimelineQuery,
2021-04-01 04:12:57 +02:00
hashtag: String,
authorization: Mastodon.API.OAuth.Authorization?
2021-03-30 08:16:08 +02:00
) -> AnyPublisher<Mastodon.Response.Content<[Mastodon.Entity.Status]>, Error> {
let request = Mastodon.API.get(
url: hashtagTimelineEndpointURL(domain: domain, hashtag: hashtag),
query: query,
2021-04-01 04:12:57 +02:00
authorization: authorization
2021-03-30 08:16:08 +02:00
)
return session.dataTaskPublisher(for: request)
.tryMap { data, response in
let value = try Mastodon.API.decode(type: [Mastodon.Entity.Status].self, from: data, response: response)
return Mastodon.Response.Content(value: value, response: response)
}
.eraseToAnyPublisher()
}
2021-01-27 11:46:14 +01:00
}
2021-04-02 04:21:51 +02:00
public protocol PagedQueryType {
2021-02-05 10:53:00 +01:00
var maxID: Mastodon.Entity.Status.ID? { get }
var sinceID: Mastodon.Entity.Status.ID? { get }
}
2021-01-27 11:46:14 +01:00
extension Mastodon.API.Timeline {
2021-02-03 11:52:47 +01:00
2021-04-02 04:21:51 +02:00
public typealias TimelineQuery = PagedQueryType
public struct PublicTimelineQuery: Codable, TimelineQuery, GetQuery {
2021-01-27 11:46:14 +01:00
public let local: Bool?
public let remote: Bool?
public let onlyMedia: Bool?
2021-02-05 10:53:00 +01:00
public let maxID: Mastodon.Entity.Status.ID?
public let sinceID: Mastodon.Entity.Status.ID?
public let minID: Mastodon.Entity.Status.ID?
2021-01-27 11:46:14 +01:00
public let limit: Int?
2021-01-27 11:52:01 +01:00
public init(
local: Bool? = nil,
remote: Bool? = nil,
onlyMedia: Bool? = nil,
2021-02-05 10:53:00 +01:00
maxID: Mastodon.Entity.Status.ID? = nil,
sinceID: Mastodon.Entity.Status.ID? = nil,
minID: Mastodon.Entity.Status.ID? = nil,
2021-01-27 11:52:01 +01:00
limit: Int? = nil
) {
2021-01-27 11:46:14 +01:00
self.local = local
self.remote = remote
self.onlyMedia = onlyMedia
self.maxID = maxID
self.sinceID = sinceID
self.minID = minID
self.limit = limit
}
var queryItems: [URLQueryItem]? {
var items: [URLQueryItem] = []
2021-01-29 12:38:11 +01:00
local.flatMap { items.append(URLQueryItem(name: "local", value: $0.queryItemValue)) }
remote.flatMap { items.append(URLQueryItem(name: "remote", value: $0.queryItemValue)) }
onlyMedia.flatMap { items.append(URLQueryItem(name: "only_media", value: $0.queryItemValue)) }
maxID.flatMap { items.append(URLQueryItem(name: "max_id", value: $0)) }
sinceID.flatMap { items.append(URLQueryItem(name: "since_id", value: $0)) }
minID.flatMap { items.append(URLQueryItem(name: "min_id", value: $0)) }
limit.flatMap { items.append(URLQueryItem(name: "limit", value: String($0))) }
2021-01-27 11:46:14 +01:00
guard !items.isEmpty else { return nil }
return items
}
}
2021-02-03 11:52:47 +01:00
public struct HomeTimelineQuery: Codable, TimelineQuery, GetQuery {
2021-02-05 10:53:00 +01:00
public let maxID: Mastodon.Entity.Status.ID?
public let sinceID: Mastodon.Entity.Status.ID?
public let minID: Mastodon.Entity.Status.ID?
2021-02-03 11:52:47 +01:00
public let limit: Int?
public let local: Bool?
public init(
2021-02-05 10:53:00 +01:00
maxID: Mastodon.Entity.Status.ID? = nil,
sinceID: Mastodon.Entity.Status.ID? = nil,
minID: Mastodon.Entity.Status.ID? = nil,
2021-02-03 11:52:47 +01:00
limit: Int? = nil,
local: Bool? = nil
) {
self.maxID = maxID
self.sinceID = sinceID
self.minID = minID
self.limit = limit
self.local = local
}
var queryItems: [URLQueryItem]? {
var items: [URLQueryItem] = []
maxID.flatMap { items.append(URLQueryItem(name: "max_id", value: $0)) }
sinceID.flatMap { items.append(URLQueryItem(name: "since_id", value: $0)) }
minID.flatMap { items.append(URLQueryItem(name: "min_id", value: $0)) }
limit.flatMap { items.append(URLQueryItem(name: "limit", value: String($0))) }
local.flatMap { items.append(URLQueryItem(name: "local", value: $0.queryItemValue)) }
guard !items.isEmpty else { return nil }
return items
}
}
2021-03-30 08:16:08 +02:00
public struct HashtagTimelineQuery: Codable, TimelineQuery, GetQuery {
public let maxID: Mastodon.Entity.Status.ID?
public let sinceID: Mastodon.Entity.Status.ID?
public let minID: Mastodon.Entity.Status.ID?
public let limit: Int?
public let local: Bool?
public let onlyMedia: Bool?
public init(
maxID: Mastodon.Entity.Status.ID? = nil,
sinceID: Mastodon.Entity.Status.ID? = nil,
minID: Mastodon.Entity.Status.ID? = nil,
limit: Int? = nil,
local: Bool? = nil,
onlyMedia: Bool? = nil
) {
self.maxID = maxID
self.sinceID = sinceID
self.minID = minID
self.limit = limit
self.local = local
self.onlyMedia = onlyMedia
}
var queryItems: [URLQueryItem]? {
var items: [URLQueryItem] = []
maxID.flatMap { items.append(URLQueryItem(name: "max_id", value: $0)) }
sinceID.flatMap { items.append(URLQueryItem(name: "since_id", value: $0)) }
minID.flatMap { items.append(URLQueryItem(name: "min_id", value: $0)) }
limit.flatMap { items.append(URLQueryItem(name: "limit", value: String($0))) }
local.flatMap { items.append(URLQueryItem(name: "local", value: $0.queryItemValue)) }
onlyMedia.flatMap { items.append(URLQueryItem(name: "only_media", value: $0.queryItemValue)) }
guard !items.isEmpty else { return nil }
return items
}
}
2021-01-27 11:46:14 +01:00
}