mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-11-03 20:02:27 -06:00 
			
		
		
		
	
		
			
	
	
		
			46 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			46 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| 
								 | 
							
								package user
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								import (
							 | 
						||
| 
								 | 
							
									"net/http"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									"github.com/gin-gonic/gin"
							 | 
						||
| 
								 | 
							
									"github.com/sirupsen/logrus"
							 | 
						||
| 
								 | 
							
								)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// PublicKeyGETHandler should be served at eg https://example.org/users/:username/main-key.
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// The goal here is to return a MINIMAL activitypub representation of an account
							 | 
						||
| 
								 | 
							
								// in the form of a vocab.ActivityStreamsPerson. The account will only contain the id,
							 | 
						||
| 
								 | 
							
								// public key, username, and type of the account.
							 | 
						||
| 
								 | 
							
								func (m *Module) PublicKeyGETHandler(c *gin.Context) {
							 | 
						||
| 
								 | 
							
									l := m.log.WithFields(logrus.Fields{
							 | 
						||
| 
								 | 
							
										"func": "PublicKeyGETHandler",
							 | 
						||
| 
								 | 
							
										"url":  c.Request.RequestURI,
							 | 
						||
| 
								 | 
							
									})
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									requestedUsername := c.Param(UsernameKey)
							 | 
						||
| 
								 | 
							
									if requestedUsername == "" {
							 | 
						||
| 
								 | 
							
										c.JSON(http.StatusBadRequest, gin.H{"error": "no username specified in request"})
							 | 
						||
| 
								 | 
							
										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)"})
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
									l.Tracef("negotiated format: %s", format)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									// make a copy of the context to pass along so we don't break anything
							 | 
						||
| 
								 | 
							
									cp := c.Copy()
							 | 
						||
| 
								 | 
							
									user, err := m.processor.GetFediUser(requestedUsername, cp.Request) // GetFediUser handles auth as well
							 | 
						||
| 
								 | 
							
									if err != nil {
							 | 
						||
| 
								 | 
							
										l.Info(err.Error())
							 | 
						||
| 
								 | 
							
										c.JSON(err.Code(), gin.H{"error": err.Safe()})
							 | 
						||
| 
								 | 
							
										return
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									c.JSON(http.StatusOK, user)
							 | 
						||
| 
								 | 
							
								}
							 |