gopass/internal/store/root/convert.go
Dominik Schulz 154d7d47e0
Improve error handling for gopass convert (#2548)
* Improve error handling for gopass convert

Fixes #2520

RELEASE_NOTES=[BUGFIX] Improve error handling for gopass convert

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

* Ignore cyclop for convert

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>

---------

Signed-off-by: Dominik Schulz <dominik.schulz@gauner.org>
2023-02-09 15:48:05 +01:00

35 lines
934 B
Go

package root
import (
"context"
"fmt"
"github.com/gopasspw/gopass/internal/backend"
"github.com/gopasspw/gopass/pkg/debug"
)
// Convert will try to convert a given mount to a different set of
// backends.
func (r *Store) Convert(ctx context.Context, name string, cryptoBe backend.CryptoBackend, storageBe backend.StorageBackend, move bool) error {
sub, err := r.GetSubStore(name)
if err != nil {
return fmt.Errorf("mount %q not found: %w", name, err)
}
debug.Log("converting %s to crypto: %s, storage: %s", name, cryptoBe, storageBe)
if err := sub.Convert(ctx, cryptoBe, storageBe, move); err != nil {
return fmt.Errorf("conversion failed: %w", err)
}
if name == "" {
debug.Log("success. updating root path to %s", sub.Path())
return r.cfg.Set("", "mounts.path", sub.Path())
}
debug.Log("success. updating path for %s to %s", name, sub.Path())
return r.cfg.Set("", "mounts."+name+".path", sub.Path())
}