fetcher refact
This commit is contained in:
@@ -16,22 +16,24 @@ type GiteaResponse []struct {
|
||||
}
|
||||
|
||||
type GiteaFetcher struct {
|
||||
BaseURL string
|
||||
Token string
|
||||
Repos []string
|
||||
Cache *Cache
|
||||
BaseFetcher
|
||||
Repos []string
|
||||
}
|
||||
|
||||
func (f GiteaFetcher) Fetch() []Entry {
|
||||
var messages []Entry
|
||||
func (f *GiteaFetcher) Name() string {
|
||||
return "Gitea"
|
||||
}
|
||||
|
||||
func (f *GiteaFetcher) Fetch() []Entry {
|
||||
var entries []Entry
|
||||
|
||||
for _, repo := range f.Repos {
|
||||
repo = strings.TrimSpace(repo)
|
||||
if repo == "" {
|
||||
continue
|
||||
}
|
||||
|
||||
repo = strings.TrimSpace(repo)
|
||||
path := fmt.Sprintf("/api/v1/repos/%s/commits", repo)
|
||||
path := fmt.Sprintf("/api/v1/repos/%s/commits?limit=1", repo)
|
||||
|
||||
headers := map[string]string{}
|
||||
if f.Token != "" {
|
||||
@@ -45,25 +47,29 @@ func (f GiteaFetcher) Fetch() []Entry {
|
||||
Headers: headers,
|
||||
}
|
||||
|
||||
var r GiteaResponse
|
||||
|
||||
if err := req.Run(&r); err != nil {
|
||||
var resp GiteaResponse
|
||||
if err := req.Run(&resp); err != nil {
|
||||
continue
|
||||
}
|
||||
|
||||
if len(r) == 0 {
|
||||
if len(resp) == 0 {
|
||||
continue
|
||||
}
|
||||
|
||||
commit := r[0]
|
||||
commit := resp[0]
|
||||
cacheKey := "gitea_" + url.QueryEscape(f.BaseURL+path)
|
||||
|
||||
if f.Cache.TryUpdate(cacheKey, commit.Sha) {
|
||||
messages = append(messages, Entry{
|
||||
Title: fmt.Sprintf("📝 [Gitea] - (%s) %s", repo, commit.Commit.Message),
|
||||
URL: commit.HTMLURL,
|
||||
})
|
||||
entry := f.TryCreateEntry(
|
||||
cacheKey,
|
||||
commit.Sha,
|
||||
fmt.Sprintf("📝 [%s] - (%s) %s", f.Name(), repo, commit.Commit.Message),
|
||||
commit.HTMLURL,
|
||||
)
|
||||
|
||||
if entry != nil {
|
||||
entries = append(entries, *entry)
|
||||
}
|
||||
}
|
||||
return messages
|
||||
|
||||
return entries
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user