Dan Anglin
ccdd8b6530
Add a new internal printer package for printing resources to the screen or pager. With the new printer in place, most of the settings such as the pager command, colour theme, whether or not colour output is disabled, etc are defined in one place which saves us the trouble of passing an increasing number of parameters to an increasing number of Display methods throughout the code base. The old Displayer interface and associated Display methods in the model package are removed as this is now handled by the printer. The format functions in the utilities package has essentially been rewritten as methods to the Printer type. Additional changes: - All indentation when displaying information about resources (e.g. statuses, instance, accounts) are removed. - The application's build information now has colour output.
104 lines
2.9 KiB
Go
104 lines
2.9 KiB
Go
// SPDX-FileCopyrightText: 2024 Dan Anglin <d.n.i.anglin@gmail.com>
|
|
//
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
package executor
|
|
|
|
import (
|
|
"flag"
|
|
"fmt"
|
|
|
|
"codeflow.dananglin.me.uk/apollo/enbas/internal/client"
|
|
"codeflow.dananglin.me.uk/apollo/enbas/internal/printer"
|
|
)
|
|
|
|
type FollowOrUnfollowExecutor struct {
|
|
*flag.FlagSet
|
|
|
|
printer *printer.Printer
|
|
configDir string
|
|
resourceType string
|
|
accountName string
|
|
showReposts bool
|
|
notify bool
|
|
action string
|
|
}
|
|
|
|
func NewFollowOrUnfollowExecutor(printer *printer.Printer, configDir, name, summary string) *FollowOrUnfollowExecutor {
|
|
command := FollowOrUnfollowExecutor{
|
|
FlagSet: flag.NewFlagSet(name, flag.ExitOnError),
|
|
|
|
printer: printer,
|
|
configDir: configDir,
|
|
action: name,
|
|
}
|
|
|
|
command.StringVar(&command.resourceType, flagType, "", "Specify the type of resource to follow")
|
|
command.StringVar(&command.accountName, flagAccountName, "", "Specify the account name in full (username@domain)")
|
|
command.BoolVar(&command.showReposts, flagShowReposts, true, "Show reposts from the account you want to follow")
|
|
command.BoolVar(&command.notify, flagNotify, false, "Get notifications when the account you want to follow posts a status")
|
|
|
|
command.Usage = commandUsageFunc(name, summary, command.FlagSet)
|
|
|
|
return &command
|
|
}
|
|
|
|
func (f *FollowOrUnfollowExecutor) Execute() error {
|
|
funcMap := map[string]func(*client.Client) error{
|
|
resourceAccount: f.followOrUnfollowAccount,
|
|
}
|
|
|
|
doFunc, ok := funcMap[f.resourceType]
|
|
if !ok {
|
|
return UnsupportedTypeError{resourceType: f.resourceType}
|
|
}
|
|
|
|
gtsClient, err := client.NewClientFromConfig(f.configDir)
|
|
if err != nil {
|
|
return fmt.Errorf("unable to create the GoToSocial client: %w", err)
|
|
}
|
|
|
|
return doFunc(gtsClient)
|
|
}
|
|
|
|
func (f *FollowOrUnfollowExecutor) followOrUnfollowAccount(gtsClient *client.Client) error {
|
|
accountID, err := getAccountID(gtsClient, false, f.accountName, f.configDir)
|
|
if err != nil {
|
|
return fmt.Errorf("received an error while getting the account ID: %w", err)
|
|
}
|
|
|
|
switch f.action {
|
|
case CommandFollow:
|
|
return f.followAccount(gtsClient, accountID)
|
|
case CommandUnfollow:
|
|
return f.unfollowAccount(gtsClient, accountID)
|
|
default:
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func (f *FollowOrUnfollowExecutor) followAccount(gtsClient *client.Client, accountID string) error {
|
|
form := client.FollowAccountForm{
|
|
AccountID: accountID,
|
|
ShowReposts: f.showReposts,
|
|
Notify: f.notify,
|
|
}
|
|
|
|
if err := gtsClient.FollowAccount(form); err != nil {
|
|
return fmt.Errorf("unable to follow the account: %w", err)
|
|
}
|
|
|
|
f.printer.PrintSuccess("Successfully sent the follow request.")
|
|
|
|
return nil
|
|
}
|
|
|
|
func (f *FollowOrUnfollowExecutor) unfollowAccount(gtsClient *client.Client, accountID string) error {
|
|
if err := gtsClient.UnfollowAccount(accountID); err != nil {
|
|
return fmt.Errorf("unable to unfollow the account: %w", err)
|
|
}
|
|
|
|
f.printer.PrintSuccess("Successfully unfollowed the account.")
|
|
|
|
return nil
|
|
}
|