diff options
author | 2022-11-25 18:23:42 +0100 | |
---|---|---|
committer | 2022-11-25 17:23:42 +0000 | |
commit | 13e9abd02a1f4003c7be922a22e8f1d095a55d61 (patch) | |
tree | ccc7b7bbb0d040dc1db84d581849a0e443f91698 /cmd | |
parent | [bugfix] Change emailVerified to true for admin account create (#1140) (diff) | |
download | gotosocial-13e9abd02a1f4003c7be922a22e8f1d095a55d61.tar.xz |
[feature] Add `admin media prune orphaned` CLI command (#1146)
* add FilePath regex
* add `admin media prune orphaned` command
* add prune orphaned function to media manager
* don't mark flag as required
* document admin media prune orphaned cmd
* oh envparsing.sh you coy minx
Diffstat (limited to 'cmd')
-rw-r--r-- | cmd/gotosocial/action/admin/media/prune/orphaned.go | 72 | ||||
-rw-r--r-- | cmd/gotosocial/admin.go | 36 |
2 files changed, 108 insertions, 0 deletions
diff --git a/cmd/gotosocial/action/admin/media/prune/orphaned.go b/cmd/gotosocial/action/admin/media/prune/orphaned.go new file mode 100644 index 000000000..4ceb356bd --- /dev/null +++ b/cmd/gotosocial/action/admin/media/prune/orphaned.go @@ -0,0 +1,72 @@ +/* + GoToSocial + Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero 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 Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +package prune + +import ( + "context" + "fmt" + + "github.com/superseriousbusiness/gotosocial/cmd/gotosocial/action" + "github.com/superseriousbusiness/gotosocial/internal/config" + "github.com/superseriousbusiness/gotosocial/internal/db/bundb" + "github.com/superseriousbusiness/gotosocial/internal/log" + "github.com/superseriousbusiness/gotosocial/internal/media" + gtsstorage "github.com/superseriousbusiness/gotosocial/internal/storage" +) + +// Orphaned prunes orphaned media from storage. +var Orphaned action.GTSAction = func(ctx context.Context) error { + dbService, err := bundb.NewBunDBService(ctx) + if err != nil { + return fmt.Errorf("error creating dbservice: %s", err) + } + + storage, err := gtsstorage.AutoConfig() + if err != nil { + return fmt.Errorf("error creating storage backend: %w", err) + } + + manager, err := media.NewManager(dbService, storage) + if err != nil { + return fmt.Errorf("error instantiating mediamanager: %s", err) + } + + dry := config.GetAdminMediaPruneDryRun() + + pruned, err := manager.PruneOrphaned(ctx, dry) + if err != nil { + return fmt.Errorf("error pruning: %s", err) + } + + if dry { + log.Infof("DRY RUN: %d stored items are orphaned and eligible to be pruned", pruned) + } else { + log.Infof("%d stored items were orphaned and pruned", pruned) + } + + if err := storage.Close(); err != nil { + return fmt.Errorf("error closing storage backend: %w", err) + } + + if err := dbService.Stop(ctx); err != nil { + return fmt.Errorf("error closing dbservice: %s", err) + } + + return nil +} diff --git a/cmd/gotosocial/admin.go b/cmd/gotosocial/admin.go index 4bf71d612..0575452fb 100644 --- a/cmd/gotosocial/admin.go +++ b/cmd/gotosocial/admin.go @@ -21,6 +21,7 @@ package main import ( "github.com/spf13/cobra" "github.com/superseriousbusiness/gotosocial/cmd/gotosocial/action/admin/account" + "github.com/superseriousbusiness/gotosocial/cmd/gotosocial/action/admin/media/prune" "github.com/superseriousbusiness/gotosocial/cmd/gotosocial/action/admin/trans" "github.com/superseriousbusiness/gotosocial/internal/config" ) @@ -152,5 +153,40 @@ func adminCommands() *cobra.Command { config.AddAdminTrans(adminImportCmd) adminCmd.AddCommand(adminImportCmd) + /* + ADMIN MEDIA COMMANDS + */ + + adminMediaCmd := &cobra.Command{ + Use: "media", + Short: "admin commands related stored media attachments/emojis", + } + + /* + ADMIN MEDIA PRUNE COMMANDS + */ + adminMediaPruneCmd := &cobra.Command{ + Use: "prune", + Short: "admin commands for pruning unused/orphaned media from storage", + } + config.AddAdminMediaPrune(adminMediaPruneCmd) + + adminMediaPruneOrphanedCmd := &cobra.Command{ + Use: "orphaned", + Short: "prune orphaned media from storage", + PreRunE: func(cmd *cobra.Command, args []string) error { + return preRun(preRunArgs{cmd: cmd}) + }, + RunE: func(cmd *cobra.Command, args []string) error { + return run(cmd.Context(), prune.Orphaned) + }, + } + config.AddAdminMediaPrune(adminMediaPruneOrphanedCmd) + adminMediaPruneCmd.AddCommand(adminMediaPruneOrphanedCmd) + + adminMediaCmd.AddCommand(adminMediaPruneCmd) + + adminCmd.AddCommand(adminMediaCmd) + return adminCmd } |