/* Copyright © 2024 Dennis Schoepf This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ package cmd import ( "freed/internal" "github.com/pterm/pterm" "github.com/spf13/cobra" ) // addCmd represents the add command var addCmd = &cobra.Command{ Use: "add", Args: cobra.ExactArgs(1), Short: "Adds a new feed to the application.", Long: `Validates and stores a feed in the application's database. Depending on the feed type, articles, videos, or updates are fetched right away. The number of articles that are imported initially can be set with the --last flag. If it is not provided the last 10 items are imported. Supported types currently are: - RSS feeds - Atom feeds `, Example: `freed add "..." freed add "..." --last 50 <- Imports the last 50 items in the feed`, Run: func(cmd *cobra.Command, args []string) { addRecentCount := 10 addRecentCount, _ = cmd.Flags().GetInt("last") feedName, articlesCount, err := internal.AddFeed(args[0], addRecentCount) if err != nil { pterm.Error.Printf("Error adding feed: %v\n", err) return } pterm.Success.Printf("Added new feed: \"%s\" and imported %d items\n", feedName, articlesCount) }, } func init() { rootCmd.AddCommand(addCmd) }