mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 14:22:25 -05:00 
			
		
		
		
	federated authentication better logging + tidying (#232)
* change trace logging in authenticator * messing about * lil changes * go fmt * error fix * Fix broken test
This commit is contained in:
		
					parent
					
						
							
								2e5dcc2929
							
						
					
				
			
			
				commit
				
					
						92186c8c6f
					
				
			
		
					 13 changed files with 134 additions and 123 deletions
				
			
		|  | @ -19,14 +19,12 @@ | |||
| package user | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/sirupsen/logrus" | ||||
| 	"github.com/superseriousbusiness/gotosocial/internal/util" | ||||
| ) | ||||
| 
 | ||||
| // UsersGETHandler should be served at https://example.org/users/:username. | ||||
|  | @ -50,25 +48,19 @@ func (m *Module) UsersGETHandler(c *gin.Context) { | |||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	// make sure this actually an AP request | ||||
| 	format := c.NegotiateFormat(ActivityPubAcceptHeaders...) | ||||
| 	if format == "" { | ||||
| 		c.JSON(http.StatusNotAcceptable, gin.H{"error": "could not negotiate format with given Accept header(s)"}) | ||||
| 	format, err := negotiateFormat(c) | ||||
| 	if err != nil { | ||||
| 		c.JSON(http.StatusNotAcceptable, gin.H{"error": fmt.Sprintf("could not negotiate format with given Accept header(s): %s", err)}) | ||||
| 		return | ||||
| 	} | ||||
| 	l.Tracef("negotiated format: %s", format) | ||||
| 
 | ||||
| 	// transfer the signature verifier from the gin context to the request context | ||||
| 	ctx := c.Request.Context() | ||||
| 	verifier, signed := c.Get(string(util.APRequestingPublicKeyVerifier)) | ||||
| 	if signed { | ||||
| 		ctx = context.WithValue(ctx, util.APRequestingPublicKeyVerifier, verifier) | ||||
| 	} | ||||
| 	ctx := populateContext(c) | ||||
| 
 | ||||
| 	user, err := m.processor.GetFediUser(ctx, requestedUsername, c.Request.URL) // GetFediUser handles auth as well | ||||
| 	if err != nil { | ||||
| 		l.Info(err.Error()) | ||||
| 		c.JSON(err.Code(), gin.H{"error": err.Safe()}) | ||||
| 	user, errWithCode := m.processor.GetFediUser(ctx, requestedUsername, c.Request.URL) // GetFediUser handles auth as well | ||||
| 	if errWithCode != nil { | ||||
| 		l.Info(errWithCode.Error()) | ||||
| 		c.JSON(errWithCode.Code(), gin.H{"error": errWithCode.Safe()}) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue