summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorUnknown <joe2010xtmf@163.com>2014-03-10 20:48:58 -0400
committerUnknown <joe2010xtmf@163.com>2014-03-10 20:48:58 -0400
commit897329a64416dd46b9e4f5a81c3c7a1666fc1173 (patch)
treeced28c8cea44742e091a38370414453b6c172ade /modules
parentefa039a0f75ff9ba9376af1cbd3d948752c074fc (diff)
downloadgitea-897329a64416dd46b9e4f5a81c3c7a1666fc1173.tar.gz
gitea-897329a64416dd46b9e4f5a81c3c7a1666fc1173.zip
Add add and delete SSH key
Diffstat (limited to 'modules')
-rw-r--r--modules/auth/auth.go (renamed from modules/auth/form.go)0
-rw-r--r--modules/auth/setting.go55
2 files changed, 55 insertions, 0 deletions
diff --git a/modules/auth/form.go b/modules/auth/auth.go
index b085527554..b085527554 100644
--- a/modules/auth/form.go
+++ b/modules/auth/auth.go
diff --git a/modules/auth/setting.go b/modules/auth/setting.go
new file mode 100644
index 0000000000..0bc6afd4a6
--- /dev/null
+++ b/modules/auth/setting.go
@@ -0,0 +1,55 @@
+// Copyright 2014 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package auth
+
+import (
+ "net/http"
+ "reflect"
+ "strings"
+
+ "github.com/codegangsta/martini"
+
+ "github.com/gogits/binding"
+
+ "github.com/gogits/gogs/modules/base"
+ "github.com/gogits/gogs/modules/log"
+)
+
+type AddSSHKeyForm struct {
+ KeyName string `form:"keyname" binding:"Required"`
+ KeyContent string `form:"key_content" binding:"Required"`
+}
+
+func (f *AddSSHKeyForm) Name(field string) string {
+ names := map[string]string{
+ "KeyName": "SSH key name",
+ "KeyContent": "SSH key content",
+ }
+ return names[field]
+}
+
+func (f *AddSSHKeyForm) Validate(errors *binding.Errors, req *http.Request, context martini.Context) {
+ data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData)
+ AssignForm(f, data)
+
+ if req.Method == "GET" || errors.Count() == 0 {
+ if req.Method == "POST" &&
+ (len(f.KeyContent) < 100 || !strings.HasPrefix(f.KeyContent, "ssh-rsa")) {
+ data["HasError"] = true
+ data["ErrorMsg"] = "SSH key content is not valid"
+ }
+ return
+ }
+
+ data["HasError"] = true
+ if len(errors.Overall) > 0 {
+ for _, err := range errors.Overall {
+ log.Error("AddSSHKeyForm.Validate: %v", err)
+ }
+ return
+ }
+
+ validate(errors, data, f)
+}