some work

This commit is contained in:
Nazar Kanaev 2020-07-01 21:13:53 +01:00
parent e72956ebac
commit 8ed55fe1e7
3 changed files with 41 additions and 14 deletions

View File

@ -13,6 +13,7 @@ import (
"mime" "mime"
"strings" "strings"
"path/filepath" "path/filepath"
"strconv"
) )
func IndexHandler(rw http.ResponseWriter, req *http.Request) { func IndexHandler(rw http.ResponseWriter, req *http.Request) {
@ -86,7 +87,7 @@ func FeedListHandler(rw http.ResponseWriter, req *http.Request) {
} }
contentType := res.Header.Get("Content-Type") contentType := res.Header.Get("Content-Type")
if strings.HasPrefix(contentType, "text/html") { if strings.HasPrefix(contentType, "text/html") || contentType == "" {
sources, err := worker.FindFeeds(res) sources, err := worker.FindFeeds(res)
if err != nil { if err != nil {
log.Print(err) log.Print(err)
@ -102,11 +103,13 @@ func FeedListHandler(rw http.ResponseWriter, req *http.Request) {
}) })
} else if len(sources) == 1 { } else if len(sources) == 1 {
feedUrl = sources[0].Url feedUrl = sources[0].Url
fmt.Println("feedUrl:", feedUrl)
err = createFeed(db(req), feedUrl, feed.FolderID) err = createFeed(db(req), feedUrl, feed.FolderID)
if err == nil { if err != nil {
writeJSON(rw, map[string]string{"status": "success"}) log.Print(err)
rw.WriteHeader(http.StatusBadRequest)
return
} }
writeJSON(rw, map[string]string{"status": "success"})
} }
} else if strings.HasPrefix(contentType, "text/xml") || strings.HasPrefix(contentType, "application/xml") { } else if strings.HasPrefix(contentType, "text/xml") || strings.HasPrefix(contentType, "application/xml") {
err = createFeed(db(req), feedUrl, feed.FolderID) err = createFeed(db(req), feedUrl, feed.FolderID)
@ -121,17 +124,20 @@ func FeedListHandler(rw http.ResponseWriter, req *http.Request) {
} }
func createFeed(s *storage.Storage, url string, folderId *int64) error { func createFeed(s *storage.Storage, url string, folderId *int64) error {
fmt.Println(s, url)
fp := gofeed.NewParser() fp := gofeed.NewParser()
feed, err := fp.ParseURL(url) feed, err := fp.ParseURL(url)
if err != nil { if err != nil {
return err return err
} }
feedLink := feed.FeedLink
if len(feedLink) == 0 {
feedLink = url
}
entry := s.CreateFeed( entry := s.CreateFeed(
feed.Title, feed.Title,
feed.Description, feed.Description,
feed.Link, feed.Link,
feed.FeedLink, feedLink,
"", "",
folderId, folderId,
) )
@ -141,4 +147,13 @@ func createFeed(s *storage.Storage, url string, folderId *int64) error {
} }
func FeedHandler(rw http.ResponseWriter, req *http.Request) { func FeedHandler(rw http.ResponseWriter, req *http.Request) {
if req.Method == "DELETE" {
id, err := strconv.ParseInt(Vars(req)["id"], 10, 64)
if err != nil {
rw.WriteHeader(http.StatusBadRequest)
return
}
db(req).DeleteFeed(id)
rw.WriteHeader(http.StatusNoContent)
}
} }

View File

@ -2,28 +2,32 @@
(function() { (function() {
var api = function(method, endpoint, data) { var api = function(method, endpoint, data) {
var promise = fetch(endpoint, { return fetch(endpoint, {
method: method, method: method,
headers: {'content-type': 'application/json'}, headers: {'content-type': 'application/json'},
body: JSON.stringify(data), body: JSON.stringify(data),
}) })
return promise.then(function(res) { }
if (res.ok) return res.json()
}) var json = function(res) {
return res.json()
} }
window.api = { window.api = {
feeds: { feeds: {
list: function() { list: function() {
return api('get', '/api/feeds') return api('get', '/api/feeds').then(json)
}, },
create: function(data) { create: function(data) {
return api('post', '/api/feeds', data) return api('post', '/api/feeds', data).then(json)
}, },
delete: function(id) {
return api('delete', '/api/feeds/' + id)
}
}, },
folders: { folders: {
list: function() { list: function() {
return api('get', '/api/folders') return api('get', '/api/folders').then(json)
}, },
} }
} }

View File

@ -89,7 +89,12 @@ var vm = new Vue({
}, },
deleteFeed: function(feed) { deleteFeed: function(feed) {
if (confirm('Are you sure you want to delete ' + feed.title + '?')) { if (confirm('Are you sure you want to delete ' + feed.title + '?')) {
this.feeds = this.feeds.filter(function(f) { f.id != feed.id }) var vm = this
api.feeds.delete(feed.id).then(function() {
api.feeds.list().then(function(feeds) {
vm.feeds = feeds
})
})
} }
}, },
createFeed: function(event) { createFeed: function(event) {
@ -102,6 +107,9 @@ var vm = new Vue({
var vm = this var vm = this
api.feeds.create(data).then(function(result) { api.feeds.create(data).then(function(result) {
if (result.status === 'success') { if (result.status === 'success') {
api.feeds.list().then(function(feeds) {
vm.feeds = feeds
})
vm.$bvModal.hide('settings-modal') vm.$bvModal.hide('settings-modal')
} }
vm.loading.newfeed = false vm.loading.newfeed = false