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/migrations | |
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/migrations')
-rw-r--r-- | models/migrations/migrations.go | 2 | ||||
-rw-r--r-- | models/migrations/v21.go | 53 |
2 files changed, 55 insertions, 0 deletions
diff --git a/models/migrations/migrations.go b/models/migrations/migrations.go index b3e7fcc8c6..bcf6285923 100644 --- a/models/migrations/migrations.go +++ b/models/migrations/migrations.go @@ -90,6 +90,8 @@ var migrations = []Migration{ NewMigration("generate and migrate Git hooks", generateAndMigrateGitHooks), // v20 -> v21 NewMigration("use new avatar path name for security reason", useNewNameAvatars), + // v21 -> v22 + NewMigration("rewrite authorized_keys file via new format", useNewPublickeyFormat), } // Migrate database to current version diff --git a/models/migrations/v21.go b/models/migrations/v21.go new file mode 100644 index 0000000000..f7f01f062b --- /dev/null +++ b/models/migrations/v21.go @@ -0,0 +1,53 @@ +// Copyright 2017 Gitea. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package migrations + +import ( + "fmt" + "os" + "path/filepath" + + "code.gitea.io/gitea/modules/setting" + + "github.com/go-xorm/xorm" +) + +const ( + 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" +) + +func useNewPublickeyFormat(x *xorm.Engine) error { + fpath := filepath.Join(setting.SSH.RootPath, "authorized_keys") + tmpPath := fpath + ".tmp" + f, err := os.OpenFile(tmpPath, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0600) + if err != nil { + return err + } + defer func() { + f.Close() + os.Remove(tmpPath) + }() + + type PublicKey struct { + ID int64 + Content string + } + + err = x.Iterate(new(PublicKey), func(idx int, bean interface{}) (err error) { + key := bean.(*PublicKey) + _, err = f.WriteString(fmt.Sprintf(tplPublicKey, setting.AppPath, key.ID, setting.CustomConf, key.Content)) + return err + }) + if err != nil { + return err + } + + f.Close() + if err = os.Rename(tmpPath, fpath); err != nil { + return err + } + return nil +} |