mirror of
https://github.com/ipfs/kubo.git
synced 2025-06-28 00:39:31 +08:00
core/cmds/config: do not show privkey on the network
License: MIT Signed-off-by: Jakub Sztandera <kubuxu@protonmail.ch>
This commit is contained in:
@ -58,6 +58,14 @@ Set the value of the 'datastore.path' key:
|
||||
args := req.Arguments()
|
||||
key := args[0]
|
||||
|
||||
// This is a temporary fix until we move the private key out of the config file
|
||||
switch key {
|
||||
case "Identity", "Identity.PrivKey":
|
||||
res.SetError(fmt.Errorf("cannot show or change private key through API"), cmds.ErrNormal)
|
||||
return
|
||||
default:
|
||||
}
|
||||
|
||||
r, err := fsrepo.Open(req.InvocContext().ConfigRoot)
|
||||
if err != nil {
|
||||
res.SetError(err, cmds.ErrNormal)
|
||||
@ -134,18 +142,34 @@ included in the output of this command.
|
||||
},
|
||||
|
||||
Run: func(req cmds.Request, res cmds.Response) {
|
||||
filename, err := config.Filename(req.InvocContext().ConfigRoot)
|
||||
fname, err := config.Filename(req.InvocContext().ConfigRoot)
|
||||
if err != nil {
|
||||
res.SetError(err, cmds.ErrNormal)
|
||||
return
|
||||
}
|
||||
|
||||
output, err := showConfig(filename)
|
||||
data, err := ioutil.ReadFile(fname)
|
||||
if err != nil {
|
||||
res.SetError(err, cmds.ErrNormal)
|
||||
return
|
||||
}
|
||||
res.SetOutput(output)
|
||||
|
||||
var cfg map[string]interface{}
|
||||
err = json.Unmarshal(data, &cfg)
|
||||
if err != nil {
|
||||
res.SetError(err, cmds.ErrNormal)
|
||||
return
|
||||
}
|
||||
|
||||
cfg["Identity"].(map[string]interface{})["PrivKey"] = nil
|
||||
|
||||
output, err := config.HumanOutput(cfg)
|
||||
if err != nil {
|
||||
res.SetError(err, cmds.ErrNormal)
|
||||
return
|
||||
}
|
||||
|
||||
res.SetOutput(bytes.NewReader(output))
|
||||
},
|
||||
}
|
||||
|
||||
@ -219,22 +243,20 @@ func getConfig(r repo.Repo, key string) (*ConfigField, error) {
|
||||
}
|
||||
|
||||
func setConfig(r repo.Repo, key string, value interface{}) (*ConfigField, error) {
|
||||
err := r.SetConfigKey(key, value)
|
||||
keyF, err := getConfig(r, "Identity.PrivKey")
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("Failed to get PrivKey")
|
||||
}
|
||||
privkey := keyF.Value
|
||||
err = r.SetConfigKey(key, value)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("Failed to set config value: %s (maybe use --json?)", err)
|
||||
}
|
||||
return getConfig(r, key)
|
||||
}
|
||||
|
||||
func showConfig(filename string) (io.Reader, error) {
|
||||
// TODO maybe we should omit privkey so we don't accidentally leak it?
|
||||
|
||||
data, err := ioutil.ReadFile(filename)
|
||||
err = r.SetConfigKey("Identity.PrivKey", privkey)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
return nil, fmt.Errorf("Failed to set PrivKey")
|
||||
}
|
||||
|
||||
return bytes.NewReader(data), nil
|
||||
return getConfig(r, key)
|
||||
}
|
||||
|
||||
func editConfig(filename string) error {
|
||||
@ -254,5 +276,11 @@ func replaceConfig(r repo.Repo, file io.Reader) error {
|
||||
return errors.New("Failed to decode file as config")
|
||||
}
|
||||
|
||||
keyF, err := getConfig(r, "Identity.PrivKey")
|
||||
if err != nil {
|
||||
return fmt.Errorf("Failed to get PrivKey")
|
||||
}
|
||||
cfg.Identity.PrivKey = keyF.Value.(string)
|
||||
|
||||
return r.SetConfig(&cfg)
|
||||
}
|
||||
|
@ -71,6 +71,23 @@ test_config_cmd() {
|
||||
grep "\"beep2\": false," actual &&
|
||||
grep "\"beep3\": false," actual
|
||||
'
|
||||
|
||||
test_expect_success "'ipfs config Identity' fails" '
|
||||
test_expect_code 1 ipfs config Identity 2> ident_out
|
||||
'
|
||||
|
||||
test_expect_success "output looks good" '
|
||||
echo "Error: cannot show private key through API" > ident_exp &&
|
||||
test_cmp ident_exp ident_out
|
||||
'
|
||||
|
||||
test_expect_success "'ipfs config Identity.PrivKey' fails" '
|
||||
test_expect_code 1 ipfs config Identity.PrivKey 2> ident_out
|
||||
'
|
||||
|
||||
test_expect_success "output looks good" '
|
||||
test_cmp ident_exp ident_out
|
||||
'
|
||||
}
|
||||
|
||||
test_init_ipfs
|
||||
|
Reference in New Issue
Block a user