mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-24 19:12:24 +00:00 
			
		
		
		
	(cherry picked from commit7b0549cd70) (cherry picked from commit13e10a65d9) (cherry picked from commit65bdd73cf2) (cherry picked from commit64eba8bb92) (cherry picked from commit4c49b1a759) (cherry picked from commit93b4d06406) (cherry picked from commite2bc5f36d9) (cherry picked from commit2bee76f9df) (cherry picked from commit3d8a1b4a9f) (cherry picked from commit99dd092cd0) (cherry picked from commit0fdbd02204) (cherry picked from commit70b277a183) (cherry picked from commit3eece7fbb4) (cherry picked from commit4838fc9e11) (cherry picked from commitb76ed541cf) (cherry picked from commitdcdfb5b65c) (cherry picked from commit377dc48cdc) (cherry picked from commitacc862f411) (cherry picked from commitac75ef101f) (cherry picked from commit08f2d9f7c5) (cherry picked from commite4096f0b64) (cherry picked from commitbf5876f062) (cherry picked from commit7dc60637e5) (cherry picked from commitef3101774b) (cherry picked from commitecb9e8867c) (cherry picked from commit64f0ae72fe) (cherry picked from commit8dd6ec7862) (cherry picked from commitb36723e52b) Conflicts: modules/context/api.go https://codeberg.org/forgejo/forgejo/pulls/1466 (cherry picked from commit5c378e0cb8) (cherry picked from commit1d87602819) (cherry picked from commit0f72002d66) (cherry picked from commitda2556eb13) (cherry picked from commitc01688cd90) (cherry picked from commitaf4bba8329) (cherry picked from commit33ca322c2e) Conflicts: modules/context/api.go https://codeberg.org/forgejo/forgejo/pulls/1739 (cherry picked from commitc18e374d44) (cherry picked from commit27c4797c9f) (cherry picked from commit46588e0fea) (cherry picked from commitb8a02ef220) (cherry picked from commit05e2f49b78) (cherry picked from commite4df86d312) (cherry picked from commitf36e06da43) (cherry picked from commit64d336c287) (cherry picked from commit2af1cbb017) (cherry picked from commit920741a9d6) (cherry picked from commit6cbb37c8c4) (cherry picked from commit539cceca39)
		
			
				
	
	
		
			60 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package integration
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	auth_model "code.gitea.io/gitea/models/auth"
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	"code.gitea.io/gitea/models/unittest"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/tests"
 | |
| 
 | |
| 	"github.com/pquerna/otp/totp"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestAPITwoFactor(t *testing.T) {
 | |
| 	defer tests.PrepareTestEnv(t)()
 | |
| 
 | |
| 	user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 16})
 | |
| 
 | |
| 	req := NewRequest(t, "GET", "/api/v1/user").
 | |
| 		AddBasicAuth(user.Name)
 | |
| 	MakeRequest(t, req, http.StatusOK)
 | |
| 
 | |
| 	otpKey, err := totp.Generate(totp.GenerateOpts{
 | |
| 		SecretSize:  40,
 | |
| 		Issuer:      "gitea-test",
 | |
| 		AccountName: user.Name,
 | |
| 	})
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	tfa := &auth_model.TwoFactor{
 | |
| 		UID: user.ID,
 | |
| 	}
 | |
| 	assert.NoError(t, tfa.SetSecret(otpKey.Secret()))
 | |
| 
 | |
| 	assert.NoError(t, auth_model.NewTwoFactor(db.DefaultContext, tfa))
 | |
| 
 | |
| 	req = NewRequest(t, "GET", "/api/v1/user").
 | |
| 		AddBasicAuth(user.Name)
 | |
| 	MakeRequest(t, req, http.StatusUnauthorized)
 | |
| 
 | |
| 	passcode, err := totp.GenerateCode(otpKey.Secret(), time.Now())
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	req = NewRequest(t, "GET", "/api/v1/user").
 | |
| 		AddBasicAuth(user.Name)
 | |
| 	req.Header.Set("X-Gitea-OTP", passcode)
 | |
| 	MakeRequest(t, req, http.StatusOK)
 | |
| 
 | |
| 	req = NewRequestf(t, "GET", "/api/v1/user").
 | |
| 		AddBasicAuth(user.Name)
 | |
| 	req.Header.Set("X-Forgejo-OTP", passcode)
 | |
| 	MakeRequest(t, req, http.StatusOK)
 | |
| }
 |