74 lines
2.5 KiB
Clojure
74 lines
2.5 KiB
Clojure
; Licensed to the Apache Software Foundation (ASF) under one
|
|
; or more contributor license agreements. See the NOTICE file
|
|
; distributed with this work for additional information
|
|
; regarding copyright ownership. The ASF licenses this file
|
|
; to you under the Apache License, Version 2.0 (the
|
|
; "License"); you may not use this file except in compliance
|
|
; with the License. You may obtain a copy of the License at
|
|
;
|
|
; http://www.apache.org/licenses/LICENSE-2.0
|
|
;
|
|
; Unless required by applicable law or agreed to in writing, software
|
|
; distributed under the License is distributed on an "AS IS" BASIS,
|
|
; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
; See the License for the specific language governing permissions and
|
|
; limitations under the License.
|
|
(ns dda.masto-embed.api
|
|
(:require
|
|
["mastodon-api" :as Mastodon]
|
|
[dda.masto-embed.infra :as infra]
|
|
[cljs-time.format :as t]
|
|
[clojure.spec.alpha :as s]
|
|
[orchestra.core :refer-macros [defn-spec]]))
|
|
|
|
(s/def ::account-id string?)
|
|
(s/def ::host-url string?)
|
|
|
|
(defn mastojs->edn [response]
|
|
(-> response .-data infra/js->edn))
|
|
|
|
(defn mastocard->html [card]
|
|
(when (some? card)
|
|
(let [{:keys [title description image url]} card]
|
|
[:div {:class "card" :url url}
|
|
(when (some? image)
|
|
[:img {:class "card-img-top" :src image}])
|
|
[:h3 {:class "card-title"} title]
|
|
[:p {:class "card-body"} description]])))
|
|
|
|
(defn masto->html [statuses]
|
|
[:ul {:class "list-group"}
|
|
(map (fn [status]
|
|
(let [{:keys [created_at card]} status
|
|
date (t/parse created_at)]
|
|
[:li {:class "list-group-item, card"}
|
|
[:div {:class "card-body"}
|
|
[:h2 {:class "card-title"}
|
|
[:a {:href (get-in status [:account :url])}
|
|
(t/unparse (t/formatters :date) date) " "
|
|
(t/unparse (t/formatters :hour-minute-second) date)]]
|
|
[:p {:class "card-text"}
|
|
(:content status)
|
|
(mastocard->html card)]]]))
|
|
statuses)])
|
|
|
|
|
|
(defn-spec mastodon-client any?
|
|
[host-url ::host-url]
|
|
(let [mastodon-config
|
|
{:access_token "unused"
|
|
:api_url (str host-url "/api/v1/")}]
|
|
(some-> mastodon-config clj->js Mastodon.)))
|
|
|
|
(defn-spec get-account-statuses any?
|
|
[host-url ::host-url
|
|
account-id ::account-id]
|
|
(.get (mastodon-client host-url)
|
|
(str "accounts/" account-id "/statuses")
|
|
#js {}))
|
|
|
|
(defn-spec get-directory any?
|
|
[host-url ::host-url]
|
|
(.get (mastodon-client host-url)
|
|
(str "directory?local=true")
|
|
#js {}))
|