diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2017-03-03 00:36:47 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-03 00:36:47 +0800 |
commit | ef13bbaf7de048ecf71f1ca5f15818e417a744b3 (patch) | |
tree | 2d6a726d6acf25b2ca71459534110983bcb3823f /models/ssh_key.go | |
parent | 341b3a034974ea24535eef12ec2832a6d89cb282 (diff) | |
download | gitea-ef13bbaf7de048ecf71f1ca5f15818e417a744b3.tar.gz gitea-ef13bbaf7de048ecf71f1ca5f15818e417a744b3.zip |
Don't rewrite non-gitea public keys (#906)
* don't rewrite non-gitea public keys
* add comment for public key
Diffstat (limited to 'models/ssh_key.go')
-rw-r--r-- | models/ssh_key.go | 34 |
1 files changed, 30 insertions, 4 deletions
diff --git a/models/ssh_key.go b/models/ssh_key.go index e82fd3aad3..802333f48c 100644 --- a/models/ssh_key.go +++ b/models/ssh_key.go @@ -5,6 +5,7 @@ package models import ( + "bufio" "encoding/base64" "encoding/binary" "errors" @@ -28,7 +29,8 @@ import ( ) const ( - tplPublicKey = `command="%s serv key-%d --config='%s'",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty %s` + "\n" + tplCommentPrefix = `# gitea public key` + tplPublicKey = tplCommentPrefix + "\n" + `command="%s serv key-%d --config='%s'",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty %s` + "\n" ) var sshOpLocker sync.Mutex @@ -553,22 +555,46 @@ func RewriteAllPublicKeys() error { if err != nil { return err } - defer os.Remove(tmpPath) + defer func() { + f.Close() + os.Remove(tmpPath) + }() err = x.Iterate(new(PublicKey), func(idx int, bean interface{}) (err error) { _, err = f.WriteString((bean.(*PublicKey)).AuthorizedString()) return err }) - f.Close() if err != nil { return err } if com.IsExist(fpath) { - if err = os.Remove(fpath); err != nil { + bakPath := fpath + fmt.Sprintf("_%d.gitea_bak", time.Now().Unix()) + if err = com.Copy(fpath, bakPath); err != nil { + return err + } + + p, err := os.Open(bakPath) + if err != nil { return err } + defer p.Close() + + scanner := bufio.NewScanner(p) + for scanner.Scan() { + line := scanner.Text() + if strings.HasPrefix(line, tplCommentPrefix) { + scanner.Scan() + continue + } + _, err = f.WriteString(line + "\n") + if err != nil { + return err + } + } } + + f.Close() if err = os.Rename(tmpPath, fpath); err != nil { return err } |