From 27cf04aff0691313b4788709454ca49d09bfc63e 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 6e9b8fb1..9d82283d 100644 --- a/translator.go +++ b/translator.go @@ -68,6 +68,8 @@ func (t *DefaultRSSTranslator) translateFeedItem(rssItem *rss.Item) (item *Item) item.Link = t.translateItemLink(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.GUID = t.translateItemGUID(rssItem) item.Image = t.translateItemImage(rssItem) @@ -280,18 +282,20 @@ func (t *DefaultRSSTranslator) translateItemLink(rssItem *rss.Item) (link string } 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