From 932fea1d1c978637fa8f032447f8863594dfb560 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ren=C3=A9=20=27Necoro=27=20Neumann?= Date: Sat, 22 Aug 2020 21:21:28 +0200 Subject: [PATCH] #151: Support for atom update date --- ...dated_-_rss_channel_item_updated_atom.json | 24 +++++++++++++++++++ ...pdated_-_rss_channel_item_updated_atom.xml | 10 ++++++++ translator.go | 12 ++++++---- 3 files changed, 42 insertions(+), 4 deletions(-) create mode 100644 testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.json create mode 100644 testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.xml diff --git a/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.json b/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.json new file mode 100644 index 00000000..256bea65 --- /dev/null +++ b/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.json @@ -0,0 +1,24 @@ +{ + "items": [ + { + "updated": "Thu, 01 Jan 2004 19:48:21 GMT", + "updatedParsed": "2004-01-01T19:48:21Z", + "extensions": { + "atom": { + "updated": [ + { + "name": "updated", + "value": "", + "parsed": { + "updated": "Thu, 01 Jan 2004 19:48:21 GMT", + "updatedParsed": "2004-01-01T19:48:21Z" + } + } + ] + } + } + } + ], + "feedType": "rss", + "feedVersion": "2.0" +} diff --git a/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.xml b/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.xml new file mode 100644 index 00000000..8706e4d6 --- /dev/null +++ b/testdata/translator/rss/feed_item_updated_-_rss_channel_item_updated_atom.xml @@ -0,0 +1,10 @@ + + + + + Thu, 01 Jan 2004 19:48:21 GMT + + + diff --git a/translator.go b/translator.go index 04c39e8c..6b18755b 100644 --- a/translator.go +++ b/translator.go @@ -74,6 +74,8 @@ func (t *DefaultRSSTranslator) translateFeedItem(rssItem *rss.Item) (item *Item) item.Links = t.translateItemLinks(rssItem) item.Published = t.translateItemPublished(rssItem) item.PublishedParsed = t.translateItemPublishedParsed(rssItem) + item.Updated = t.translateItemUpdated(rssItem) + item.UpdatedParsed = t.translateItemUpdatedParsed(rssItem) item.Author = t.translateItemAuthor(rssItem) item.Authors = t.translateItemAuthors(rssItem) item.GUID = t.translateItemGUID(rssItem) @@ -332,18 +334,20 @@ func (t *DefaultRSSTranslator) translateItemLinks(rssItem *rss.Item) (links []st } func (t *DefaultRSSTranslator) translateItemUpdated(rssItem *rss.Item) (updated string) { - if rssItem.DublinCoreExt != nil && rssItem.DublinCoreExt.Date != nil { + if updatedVal, ok := t.hasAtomExtensionsForKey(rssItem, "updated"); ok { + updated = t.atomTranslator.translateItemUpdated(updatedVal) + } else if rssItem.DublinCoreExt != nil && rssItem.DublinCoreExt.Date != nil { updated = t.firstEntry(rssItem.DublinCoreExt.Date) } return updated } func (t *DefaultRSSTranslator) translateItemUpdatedParsed(rssItem *rss.Item) (updated *time.Time) { - if rssItem.DublinCoreExt != nil && rssItem.DublinCoreExt.Date != nil { - updatedText := t.firstEntry(rssItem.DublinCoreExt.Date) + if updatedText := t.translateItemUpdated(rssItem); updatedText != "" { updatedDate, err := shared.ParseDate(updatedText) if err == nil { - updated = &updatedDate + utcDate := updatedDate.UTC() + updated = &utcDate } } return