2017-11-20 13:16:06 -08:00
|
|
|
|
//
|
|
|
|
|
// FaviconURLFinder.swift
|
|
|
|
|
// Evergreen
|
|
|
|
|
//
|
|
|
|
|
// Created by Brent Simmons on 11/20/17.
|
|
|
|
|
// Copyright © 2017 Ranchero Software. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
|
import RSParser
|
|
|
|
|
import RSWeb
|
|
|
|
|
|
|
|
|
|
// The favicon URL may be specified in the head section of the home page.
|
|
|
|
|
|
|
|
|
|
struct FaviconURLFinder {
|
|
|
|
|
|
|
|
|
|
static func findFaviconURL(_ homePageURL: String, _ callback: @escaping (String?) -> Void) {
|
|
|
|
|
|
|
|
|
|
guard let url = URL(string: homePageURL) else {
|
|
|
|
|
callback(nil)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2017-11-23 10:29:00 -08:00
|
|
|
|
downloadUsingCache(url) { (data, response, error) in
|
2017-11-20 13:16:06 -08:00
|
|
|
|
|
|
|
|
|
guard let data = data, let response = response, response.statusIsOK else {
|
|
|
|
|
callback(nil)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2017-11-25 13:46:48 -08:00
|
|
|
|
// Use the absoluteString of the response’s URL instead of the homePageURL,
|
|
|
|
|
// since the homePageURL might actually have been redirected.
|
|
|
|
|
// Example: Dr. Drang’s feed reports the homePageURL as http://www.leancrew.com/all-this —
|
|
|
|
|
// but it gets redirected to http://www.leancrew.com/all-this/ — which is correct.
|
|
|
|
|
// This way any relative link to a favicon in the page’s metadata
|
|
|
|
|
// will be made absolute correctly.
|
|
|
|
|
|
|
|
|
|
let urlToUse = response.url?.absoluteString ?? homePageURL
|
|
|
|
|
let link = faviconURL(urlToUse, data)
|
2017-11-20 13:16:06 -08:00
|
|
|
|
callback(link)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static private func faviconURL(_ url: String, _ webPageData: Data) -> String? {
|
|
|
|
|
|
|
|
|
|
let parserData = ParserData(url: url, data: webPageData)
|
|
|
|
|
let htmlMetadata = RSHTMLMetadataParser.htmlMetadata(with: parserData)
|
|
|
|
|
return htmlMetadata.faviconLink
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|