Skip to content

Commit

Permalink
fix: remove GODEBUG v2 and set UA
Browse files Browse the repository at this point in the history
reddits bot detection is no longer happy with using GODEBUG to
disabel http2, seems to be happy with enabled and setting
proper UA

related #77
  • Loading branch information
guyfedwards committed Jun 3, 2024
1 parent 57cbe22 commit 42bdbc9
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 30 deletions.
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@ dist/
.LSOverride
._*
github_token
nom
./nom
6 changes: 1 addition & 5 deletions cmd/nom/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ var (
)

func run(args []string, opts Options) error {
cfg, err := config.New(opts.ConfigPath, opts.Pager, opts.PreviewFeeds)
cfg, err := config.New(opts.ConfigPath, opts.Pager, opts.PreviewFeeds, version)
if err != nil {
return err
}
Expand Down Expand Up @@ -67,10 +67,6 @@ func run(args []string, opts Options) error {
}

func main() {
// disable http2 client as causing issues with reddit rss feed requests
// https://github.com/guyfedwards/nom/issues/7
os.Setenv("GODEBUG", "http2client=0")

var opts Options

parser := flags.NewParser(&opts, flags.Default)
Expand Down
44 changes: 22 additions & 22 deletions internal/commands/commands.go
Original file line number Diff line number Diff line change
Expand Up @@ -161,25 +161,25 @@ func (c Commands) TUI() error {
return fmt.Errorf("commands List: %w", err)
}

var errorItems []ErrorItem
// if no feeds in store, fetchAllFeeds, which will return previews
if len(c.config.PreviewFeeds) > 0 {
its, errorItems, err = c.fetchAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
// if no items, fetchAllFeeds and GetAllFeeds
} else if len(its) == 0 {
_, errorItems, err = c.fetchAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
// refetch for consistent data across calls
its, err = c.GetAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
}
var errorItems []ErrorItem
// if no feeds in store, fetchAllFeeds, which will return previews
if len(c.config.PreviewFeeds) > 0 {
its, errorItems, err = c.fetchAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
// if no items, fetchAllFeeds and GetAllFeeds
} else if len(its) == 0 {
_, errorItems, err = c.fetchAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
// refetch for consistent data across calls
its, err = c.GetAllFeeds()
if err != nil {
return fmt.Errorf("[commands.go] TUI: %w", err)
}
}

items := convertItems(its)

Expand Down Expand Up @@ -257,7 +257,7 @@ func (c Commands) fetchAllFeeds() ([]store.Item, []ErrorItem, error) {
for _, feed := range feeds {
wg.Add(1)

go fetchFeed(ch, &wg, feed)
go fetchFeed(ch, &wg, feed, c.config.Version)
}

go func() {
Expand Down Expand Up @@ -336,10 +336,10 @@ func (c Commands) GetAllFeeds() ([]store.Item, error) {
return items, nil
}

func fetchFeed(ch chan FetchResultError, wg *sync.WaitGroup, feed config.Feed) {
func fetchFeed(ch chan FetchResultError, wg *sync.WaitGroup, feed config.Feed, version string) {
defer wg.Done()

r, err := rss.Fetch(feed)
r, err := rss.Fetch(feed, version)

if err != nil {
ch <- FetchResultError{res: rss.RSS{}, err: err, url: feed.URL}
Expand Down
3 changes: 2 additions & 1 deletion internal/config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ type Config struct {
AutoRead bool `yaml:"autoread,omitempty"`
ShowFavourites bool
Openers []Opener `yaml:"openers,omitempty"`
Version string
}

func (c *Config) ToggleShowRead() {
Expand All @@ -59,7 +60,7 @@ func (c *Config) ToggleShowFavourites() {
c.ShowFavourites = !c.ShowFavourites
}

func New(configPath string, pager string, previewFeeds []string) (Config, error) {
func New(configPath string, pager string, previewFeeds []string, version string) (Config, error) {
var configDir string

if configPath == "" {
Expand Down
3 changes: 2 additions & 1 deletion internal/rss/rss.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,9 @@ type RSS struct {
Channel Channel `xml:"channel"`
}

func Fetch(f config.Feed) (RSS, error) {
func Fetch(f config.Feed, version string) (RSS, error) {
fp := gofeed.NewParser()
fp.UserAgent = fmt.Sprintf("nom/%s", version)

feed, err := fp.ParseURL(f.URL)
if err != nil {
Expand Down

0 comments on commit 42bdbc9

Please sign in to comment.