RSSPAPER/src/rsspaper/feeds.clj

40 lines
1.1 KiB
Clojure
Raw Normal View History

2021-06-02 07:35:26 +02:00
(ns rsspaper.feeds
(:require
[rsspaper.config :refer [config]]
2021-07-01 21:59:50 +02:00
[clj-time.coerce :as c]
[clj-time.format :as f]
2021-06-02 07:35:26 +02:00
[remus :refer [parse-url]]))
2021-07-01 21:59:50 +02:00
(def date-custom-formatter (f/formatter "dd MM yyyy"))
(defn datetimes-to-unixtime
[data]
(map (fn [blog]
(assoc-in blog [:feed :entries]
(map (fn [article]
(assoc article :published-date (c/to-long (:published-date article))))
(get-in blog [:feed :entries])))) data))
(defn add-datetimes-formatter
[data]
(map (fn [blog]
(assoc-in blog [:feed :entries]
(map (fn [article]
(assoc article :published-date-formatter (f/unparse date-custom-formatter (c/from-long (:published-date article)))))
(get-in blog [:feed :entries])))) data))
2021-06-02 07:35:26 +02:00
(defn get-feeds
[]
;; Get all feeds from config -> feeds
2021-07-01 21:59:50 +02:00
(->
(reduce
(fn [feeds feed-url]
(conj feeds
(parse-url feed-url {:insecure? true :throw-exceptions false}))
) [] (:feeds config))
datetimes-to-unixtime
add-datetimes-formatter))