2019-09-19 04:56:43 +02:00
|
|
|
|
//
|
|
|
|
|
// FeedlyEntry.swift
|
|
|
|
|
// Account
|
|
|
|
|
//
|
|
|
|
|
// Created by Kiel Gillard on 19/9/19.
|
|
|
|
|
// Copyright © 2019 Ranchero Software, LLC. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
|
|
|
|
|
|
struct FeedlyEntry: Decodable {
|
|
|
|
|
/// the unique, immutable ID for this particular article.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let id: String
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
|
|
|
|
/// the article’s title. This string does not contain any HTML markup.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let title: String?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
2020-01-17 06:47:21 +01:00
|
|
|
|
struct Content: Decodable {
|
|
|
|
|
|
|
|
|
|
enum Direction: String, Decodable {
|
|
|
|
|
case leftToRight = "ltr"
|
|
|
|
|
case rightToLeft = "rtl"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let content: String?
|
|
|
|
|
let direction: Direction?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// This object typically has two values: “content” for the content itself, and “direction” (“ltr” for left-to-right, “rtl” for right-to-left). The content itself contains sanitized HTML markup.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let content: Content?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
|
|
|
|
/// content object the article summary. See the content object above.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let summary: Content?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
|
|
|
|
/// the author’s name
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let author: String?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
2019-12-05 08:54:47 +01:00
|
|
|
|
/// the immutable timestamp, in ms, when this article was processed by the feedly Cloud servers.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let crawled: Date
|
2019-12-05 08:54:47 +01:00
|
|
|
|
|
|
|
|
|
/// the timestamp, in ms, when this article was re-processed and updated by the feedly Cloud servers.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let recrawled: Date?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
|
|
|
|
|
/// the feed from which this article was crawled. If present, “streamId” will contain the feed id, “title” will contain the feed title, and “htmlUrl” will contain the feed’s website.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let origin: FeedlyOrigin?
|
2019-10-03 05:30:43 +02:00
|
|
|
|
|
|
|
|
|
/// Used to help find the URL to visit an article on a web site.
|
|
|
|
|
/// See https://groups.google.com/forum/#!searchin/feedly-cloud/feed$20url%7Csort:date/feedly-cloud/Rx3dVd4aTFQ/Hf1ZfLJoCQAJ
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let canonical: [FeedlyLink]?
|
2019-10-03 05:30:43 +02:00
|
|
|
|
|
|
|
|
|
/// a list of alternate links for this article. Each link object contains a media type and a URL. Typically, a single object is present, with a link to the original web page.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let alternate: [FeedlyLink]?
|
|
|
|
|
|
2019-09-23 09:29:53 +02:00
|
|
|
|
/// Was this entry read by the user? If an Authorization header is not provided, this will always return false. If an Authorization header is provided, it will reflect if the user has read this entry or not.
|
2020-01-17 06:47:21 +01:00
|
|
|
|
let unread: Bool
|
|
|
|
|
|
|
|
|
|
/// a list of tag objects (“id” and “label”) that the user added to this entry. This value is only returned if an Authorization header is provided, and at least one tag has been added. If the entry has been explicitly marked as read (not the feed itself), the “global.read” tag will be present.
|
|
|
|
|
let tags: [FeedlyTag]?
|
|
|
|
|
|
|
|
|
|
/// a list of category objects (“id” and “label”) that the user associated with the feed of this entry. This value is only returned if an Authorization header is provided.
|
|
|
|
|
let categories: [FeedlyCategory]?
|
|
|
|
|
|
|
|
|
|
/// A list of media links (videos, images, sound etc) provided by the feed. Some entries do not have a summary or content, only a collection of media links.
|
|
|
|
|
let enclosure: [FeedlyLink]?
|
2019-09-19 04:56:43 +02:00
|
|
|
|
}
|