mirror of
https://github.com/nkanaev/yarr.git
synced 2025-05-24 00:33:14 +00:00
some work
This commit is contained in:
parent
e72956ebac
commit
8ed55fe1e7
@ -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)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user