File: command_config.go

package info (click to toggle)
gopass 1.5.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 356 kB
  • sloc: makefile: 26
file content (93 lines) | stat: -rw-r--r-- 2,643 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
//    Copyright (C) 2018 Alexandre Viau <alexandre@alexandreviau.net>
//
//    This file is part of gopass.
//
//    gopass 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.
//
//    gopass 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 gopass.  If not, see <http://www.gnu.org/licenses/>.

package cli

import (
	"io"
	"os"
	"path"

	"github.com/aviau/gopass/pkg/store"
)

// CommandConfig contains everything that commands needs to run.
type CommandConfig interface {
	WriterOutput() io.Writer
	WriterError() io.Writer
	ReaderInput() io.Reader
	Editor() string
	PasswordStoreDir() string
	PasswordStore() *store.PasswordStore
}

// DefaultConfig is a default CommandConfig implementation.
type DefaultConfig struct {
	writerOutput io.Writer // The writer to use for output
	writerError  io.Writer // The writer to use for errors
	readerInput  io.Reader // The reader to use for input
}

// NewCommandConfig creates a CommandConfig.
func NewCommandConfig(writerOutput, writerError io.Writer, readerInput io.Reader) CommandConfig {
	cfg := DefaultConfig{
		writerOutput: writerOutput,
		writerError:  writerError,
		readerInput:  readerInput,
	}
	return &cfg
}

// WriterOutput returns the output writer
func (cfg *DefaultConfig) WriterOutput() io.Writer {
	return cfg.writerOutput
}

// WriterError returns the output writer
func (cfg *DefaultConfig) WriterError() io.Writer {
	return cfg.writerError
}

// ReaderInput returns the input reader
func (cfg *DefaultConfig) ReaderInput() io.Reader {
	return cfg.readerInput
}

// PasswordStoreDir returns the password store directory.
func (cfg *DefaultConfig) PasswordStoreDir() string {
	storePath := os.Getenv("PASSWORD_STORE_DIR")
	if storePath == "" {
		storePath = path.Join(os.Getenv("HOME"), ".password-store")
	}
	return storePath
}

// Editor returns the configured editor.
func (cfg *DefaultConfig) Editor() string {
	editor := os.Getenv("EDITOR")
	if editor == "" {
		editor = "editor"
	}
	return editor
}

// PasswordStore returns the PasswordStore.
func (cfg *DefaultConfig) PasswordStore() *store.PasswordStore {
	storePath := cfg.PasswordStoreDir()
	s := store.NewPasswordStore(storePath)
	return s
}