mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 05:52:25 -05:00 
			
		
		
		
	* start work on admin domain blocking * move stuff around + further work on domain blocks * move + restructure processor * prep work for deleting account * tidy * go fmt * formatting * domain blocking more work * check domain blocks way earlier on * progress on delete account * delete more stuff when an account is gone * and more... * domain blocky block block * get individual domain block, delete a block
		
			
				
	
	
		
			54 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package user
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"net/http"
 | |
| 
 | |
| 	"github.com/gin-gonic/gin"
 | |
| 	"github.com/sirupsen/logrus"
 | |
| 	"github.com/superseriousbusiness/gotosocial/internal/util"
 | |
| )
 | |
| 
 | |
| // StatusGETHandler serves the target status as an activitystreams NOTE so that other AP servers can parse it.
 | |
| func (m *Module) StatusGETHandler(c *gin.Context) {
 | |
| 	l := m.log.WithFields(logrus.Fields{
 | |
| 		"func": "StatusGETHandler",
 | |
| 		"url":  c.Request.RequestURI,
 | |
| 	})
 | |
| 
 | |
| 	requestedUsername := c.Param(UsernameKey)
 | |
| 	if requestedUsername == "" {
 | |
| 		c.JSON(http.StatusBadRequest, gin.H{"error": "no username specified in request"})
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	requestedStatusID := c.Param(StatusIDKey)
 | |
| 	if requestedStatusID == "" {
 | |
| 		c.JSON(http.StatusBadRequest, gin.H{"error": "no status id 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)
 | |
| 
 | |
| 	// 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)
 | |
| 	}
 | |
| 
 | |
| 	status, err := m.processor.GetFediStatus(ctx, requestedUsername, requestedStatusID, c.Request.URL) // 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, status)
 | |
| }
 |