]> source.dussan.org Git - gitea.git/commitdiff
Show user OpenID URIs in their profile (#1314)
authorSandro Santilli <strk@kbt.io>
Mon, 20 Mar 2017 08:31:08 +0000 (09:31 +0100)
committerKim "BKC" Carlbäcker <kim.carlbacker@gmail.com>
Mon, 20 Mar 2017 08:31:08 +0000 (09:31 +0100)
cmd/web.go
models/fixtures/user_open_id.yml [new file with mode: 0644]
models/migrations/migrations.go
models/migrations/v25.go [new file with mode: 0644]
models/user_openid.go
models/user_openid_test.go [new file with mode: 0644]
options/locale/locale_en-US.ini
routers/user/profile.go
routers/user/setting_openid.go
templates/user/profile.tmpl
templates/user/settings/openid.tmpl

index d50ee62a7619c9d99d425282de2a24c74acf8b4f..15cec05b02621bb0838318f81a3ac2dff880b329 100644 (file)
@@ -248,6 +248,7 @@ func runWeb(ctx *cli.Context) error {
                                m.Combo("").Get(user.SettingsOpenID).
                                        Post(bindIgnErr(auth.AddOpenIDForm{}), user.SettingsOpenIDPost)
                                m.Post("/delete", user.DeleteOpenID)
+                               m.Post("/toggle_visibility", user.ToggleOpenIDVisibility)
                        })
                }
 
diff --git a/models/fixtures/user_open_id.yml b/models/fixtures/user_open_id.yml
new file mode 100644 (file)
index 0000000..d3a367b
--- /dev/null
@@ -0,0 +1,17 @@
+-
+  id: 1
+  uid: 1
+  uri: https://user1.domain1.tld/
+  show: false
+
+-
+  id: 2
+  uid: 1
+  uri: http://user1.domain2.tld/
+  show: true
+
+-
+  id: 3
+  uid: 2
+  uri: https://domain1.tld/user2/
+  show: true
index d06a4473b8343b0ff8d19ee0a9f3974ed8e278fa..f651a9b7875623afbb13c4bfb19fc9c8f906c510 100644 (file)
@@ -98,6 +98,8 @@ var migrations = []Migration{
        NewMigration("add user openid table", addUserOpenID),
        // v24 -> v25
        NewMigration("change the key_id and primary_key_id type", changeGPGKeysColumns),
+       // v25 -> v26
+       NewMigration("add show field in user openid table", addUserOpenIDShow),
 }
 
 // Migrate database to current version
diff --git a/models/migrations/v25.go b/models/migrations/v25.go
new file mode 100644 (file)
index 0000000..a8d7465
--- /dev/null
@@ -0,0 +1,18 @@
+// 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"
+
+       "github.com/go-xorm/xorm"
+)
+
+func addUserOpenIDShow(x *xorm.Engine) error {
+       if err := x.Sync2(new(UserOpenID)); err != nil {
+               return fmt.Errorf("Sync2: %v", err)
+       }
+       return nil
+}
index a5c88e9009d76f834910258c1f699b559b36917e..18e847d89ddc479bed9e618a6e8a9291ccbc995d 100644 (file)
@@ -21,6 +21,7 @@ type UserOpenID struct {
        ID          int64  `xorm:"pk autoincr"`
        UID         int64  `xorm:"INDEX NOT NULL"`
        URI         string `xorm:"UNIQUE NOT NULL"`
+       Show        bool   `xorm:"DEFAULT false"`
 }
 
 // GetUserOpenIDs returns all openid addresses that belongs to given user.
@@ -28,6 +29,7 @@ func GetUserOpenIDs(uid int64) ([]*UserOpenID, error) {
        openids := make([]*UserOpenID, 0, 5)
        if err := x.
                Where("uid=?", uid).
+               Asc("id").
                Find(&openids); err != nil {
                return nil, err
        }
@@ -89,6 +91,12 @@ func DeleteUserOpenID(openid *UserOpenID) (err error) {
        return nil
 }
 
+// ToggleUserOpenIDVisibility toggles visibility of an openid address of given user.
+func ToggleUserOpenIDVisibility(id int64) (err error) {
+       _, err = x.Exec("update user_open_id set show = not show where id = ?", id)
+       return err
+}
+
 // GetUserByOpenID returns the user object by given OpenID if exists.
 func GetUserByOpenID(uri string) (*User, error) {
        if len(uri) == 0 {
diff --git a/models/user_openid_test.go b/models/user_openid_test.go
new file mode 100644 (file)
index 0000000..74e3cf6
--- /dev/null
@@ -0,0 +1,82 @@
+// Copyright 2017 The Gitea 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 models
+
+import (
+       "testing"
+
+       "github.com/stretchr/testify/assert"
+)
+
+func TestGetUserOpenIDs(t *testing.T) {
+       assert.NoError(t, PrepareTestDatabase())
+
+       oids, err := GetUserOpenIDs(int64(1))
+       if assert.NoError(t, err) {
+               assert.Len(t, oids, 2)
+               assert.Equal(t, oids[0].URI, "https://user1.domain1.tld/")
+               assert.False(t, oids[0].Show)
+               assert.Equal(t, oids[1].URI, "http://user1.domain2.tld/")
+               assert.True(t, oids[1].Show)
+       }
+
+       oids, err = GetUserOpenIDs(int64(2))
+       if assert.NoError(t, err) {
+               assert.Len(t, oids, 1)
+               assert.Equal(t, oids[0].URI, "https://domain1.tld/user2/")
+               assert.True(t, oids[0].Show)
+       }
+}
+
+func TestGetUserByOpenID(t *testing.T) {
+       assert.NoError(t, PrepareTestDatabase())
+
+       user, err := GetUserByOpenID("https://unknown")
+       if assert.Error(t, err) {
+               assert.True(t, IsErrUserNotExist(err))
+       }
+
+       user, err = GetUserByOpenID("https://user1.domain1.tld")
+       if assert.NoError(t, err) {
+               assert.Equal(t, user.ID, int64(1))
+       }
+
+       user, err = GetUserByOpenID("https://domain1.tld/user2/")
+       if assert.NoError(t, err) {
+               assert.Equal(t, user.ID, int64(2))
+       }
+}
+
+func TestToggleUserOpenIDVisibility(t *testing.T) {
+       assert.NoError(t, PrepareTestDatabase())
+       oids, err := GetUserOpenIDs(int64(2))
+       if ! assert.NoError(t, err) {
+               return
+       }
+       assert.Len(t, oids, 1)
+       assert.True(t, oids[0].Show)
+
+       err = ToggleUserOpenIDVisibility(oids[0].ID)
+       if ! assert.NoError(t, err) {
+               return
+       }
+
+       oids, err = GetUserOpenIDs(int64(2))
+       if assert.NoError(t, err) {
+               assert.Len(t, oids, 1)
+               assert.False(t, oids[0].Show)
+       }
+       err = ToggleUserOpenIDVisibility(oids[0].ID)
+       if ! assert.NoError(t, err) {
+               return
+       }
+
+       oids, err = GetUserOpenIDs(int64(2))
+       if ! assert.NoError(t, err) {
+               return
+       }
+       assert.Len(t, oids, 1)
+       assert.True(t, oids[0].Show)
+}
index 98dfaab5d4598072418d5ff5b0276dbde3f4a842..829c460619660b73571fb3532e073dba4f006ad2 100644 (file)
@@ -365,6 +365,8 @@ last_used = Last used on
 no_activity = No recent activity
 key_state_desc = This key is used in last 7 days
 token_state_desc = This token is used in last 7 days
+show_openid = Show on profile
+hide_openid = Hide from profile
 
 manage_social = Manage Associated Social Accounts
 social_desc = This is a list of associated social accounts. For security reasons, please make sure you recognize all of these entries, as they can be used to log in to your account.
index 89585551ad52eecec98df3eb5a09176243171570..eb862d6542f2943f43c1e86aca6c1a51ca5a0d0f 100644 (file)
@@ -75,9 +75,17 @@ func Profile(ctx *context.Context) {
                return
        }
 
+       // Show OpenID URIs
+       openIDs, err := models.GetUserOpenIDs(ctxUser.ID)
+       if err != nil {
+               ctx.Handle(500, "GetUserOpenIDs", err)
+               return
+       }
+
        ctx.Data["Title"] = ctxUser.DisplayName()
        ctx.Data["PageIsUserProfile"] = true
        ctx.Data["Owner"] = ctxUser
+       ctx.Data["OpenIDs"] = openIDs
        showPrivate := ctx.IsSigned && (ctx.User.IsAdmin || ctx.User.ID == ctxUser.ID)
 
        orgs, err := models.GetOrgsByUserID(ctxUser.ID, showPrivate)
index 5e6052d3ef4c6155e0e473e9f25b5b06eda26b5d..e33ab144ed8d099c0a10f4a21199e1297b4400bb 100644 (file)
@@ -45,6 +45,12 @@ func SettingsOpenIDPost(ctx *context.Context, form auth.AddOpenIDForm) {
        ctx.Data["PageIsSettingsOpenID"] = true
 
        if ctx.HasError() {
+               openid, err := models.GetUserOpenIDs(ctx.User.ID)
+               if err != nil {
+                       ctx.Handle(500, "GetUserOpenIDs", err)
+                       return
+               }
+               ctx.Data["OpenIDs"] = openid
                ctx.HTML(200, tplSettingsOpenID)
                return
        }
@@ -140,3 +146,13 @@ func DeleteOpenID(ctx *context.Context) {
        })
 }
 
+// ToggleOpenIDVisibility response for toggle visibility of user's openid
+func ToggleOpenIDVisibility(ctx *context.Context) {
+       if err := models.ToggleUserOpenIDVisibility(ctx.QueryInt64("id")); err != nil {
+               ctx.Handle(500, "ToggleUserOpenIDVisibility", err)
+               return
+       }
+
+       ctx.Redirect(setting.AppSubURL + "/user/settings/openid")
+}
+
index 08627616b5aa3eb1e041c0901767a05dc67742fd..a055a99a85652a4304f6540a692b942efb8c0f9c 100644 (file)
                                                                        <a target="_blank" rel="noopener" href="{{.Owner.Website}}">{{.Owner.Website}}</a>
                                                                </li>
                                                        {{end}}
+                                                       {{range .OpenIDs}}
+                                                               {{if .Show}}
+                                                                       <li>
+                                                                               <i class="fa fa-openid"></i>
+                                                                               <a target="_blank" rel="noopener" href="{{.URI}}">{{.URI}}</a>
+                                                                       </li>
+                                                               {{end}}
+                                                       {{end}}
                                                        <li><i class="octicon octicon-clock"></i> {{.i18n.Tr "user.join_on"}} {{DateFmtShort .Owner.Created}}</li>
                                                        <li>
                                                                <i class="octicon octicon-person"></i>
index a8b3a4e0f5aa9d00cdd6776f07c1f18fe2c6af18..9da4be427405304ab8b2c50f2f829d0a2c3230b0 100644 (file)
                                                                        {{$.i18n.Tr "settings.delete_key"}}
                                                                </button>
                                                        </div>
+                                                       <div class="ui right">
+                                                               <form action="{{$.Link}}/toggle_visibility" method="post">
+                                                               {{$.CsrfTokenHtml}}
+                                                               <input name="id" type="hidden" value="{{.ID}}">
+                                                               {{if .Show}}
+                                                                       <button class="ui tiny button">
+                                                                       <i class="icon fa-eye"></i>
+                                                                       {{$.i18n.Tr "settings.hide_openid"}}
+                                                                       </button>
+                                                               {{else}}
+                                                                       <button class="ui tiny button">
+                                                                       <i class="icon fa-eye-slash"></i>
+                                                                       {{$.i18n.Tr "settings.show_openid"}}
+                                                                       </button>
+                                                               {{end}}
+                                                               </button>
+                                                               </form>
+                                                       </div>
                                                </div>
                                        </div>
                                {{end}}