diff options
| author | 2021-10-24 11:57:39 +0200 | |
|---|---|---|
| committer | 2021-10-24 11:57:39 +0200 | |
| commit | 4b1d9d3780134098ff06877abc20c970c32d4aac (patch) | |
| tree | a46deccd4cdf2ddf9d0ea92f32bd8669657a4687 /internal/api/client/account | |
| parent | pregenerate RSA keys for testrig accounts. If a user is added without a key,... (diff) | |
| download | gotosocial-4b1d9d3780134098ff06877abc20c970c32d4aac.tar.xz | |
Serve `outbox` for Actor (#289)
* add statusesvisible convenience function
* add minID + onlyPublic to account statuses get
* move swagger collection stuff to common
* start working on Outbox GETting
* move functions into federationProcessor
* outboxToASCollection
* add statusesvisible convenience function
* add minID + onlyPublic to account statuses get
* move swagger collection stuff to common
* start working on Outbox GETting
* move functions into federationProcessor
* outboxToASCollection
* bit more work on outbox paging
* wrapNoteInCreate function
* test + hook up the processor functions
* don't do prev + next links on empty reply
* test get outbox through api
* don't fail on no status entries
* add outbox implementation doc
* typo
Diffstat (limited to 'internal/api/client/account')
| -rw-r--r-- | internal/api/client/account/account.go | 8 | ||||
| -rw-r--r-- | internal/api/client/account/statuses.go | 36 | 
2 files changed, 39 insertions, 5 deletions
| diff --git a/internal/api/client/account/account.go b/internal/api/client/account/account.go index bb11888d3..6e8b1e242 100644 --- a/internal/api/client/account/account.go +++ b/internal/api/client/account/account.go @@ -39,8 +39,12 @@ const (  	PinnedKey = "pinned"  	// MaxIDKey is for specifying the maximum ID of the status to retrieve.  	MaxIDKey = "max_id" -	// MediaOnlyKey is for specifying that only statuses with media should be returned in a list of returned statuses by an account. -	MediaOnlyKey = "only_media" +	// MinIDKey is for specifying the minimum ID of the status to retrieve. +	MinIDKey = "min_id" +	// OnlyMediaKey is for specifying that only statuses with media should be returned in a list of returned statuses by an account. +	OnlyMediaKey = "only_media" +	// OnlyPublicKey is for specifying that only statuses with visibility public should be returned in a list of returned statuses by account. +	OnlyPublicKey = "only_public"  	// IDKey is the key to use for retrieving account ID in requests  	IDKey = "id" diff --git a/internal/api/client/account/statuses.go b/internal/api/client/account/statuses.go index ab1d4e2e6..9a60e80ee 100644 --- a/internal/api/client/account/statuses.go +++ b/internal/api/client/account/statuses.go @@ -64,6 +64,12 @@ import (  //     Return only statuses *OLDER* than the given max status ID.  //     The status with the specified ID will not be included in the response.  //   in: query +// - name: min_id +//   type: string +//   description: |- +//     Return only statuses *NEWER* than the given min status ID. +//     The status with the specified ID will not be included in the response. +//   in: query  //   required: false  // - name: pinned_only  //   type: boolean @@ -71,12 +77,18 @@ import (  //   default: false  //   in: query  //   required: false -// - name: media_only +// - name: only_media  //   type: boolean  //   description: Show only statuses with media attachments.  //   default: false  //   in: query  //   required: false +// - name: only_public +//   type: boolean +//   description: Show only statuses with a privacy setting of 'public'. +//   default: false +//   in: query +//   required: false  //  // security:  // - OAuth2 Bearer: @@ -143,6 +155,12 @@ func (m *Module) AccountStatusesGETHandler(c *gin.Context) {  		maxID = maxIDString  	} +	minID := "" +	minIDString := c.Query(MinIDKey) +	if minIDString != "" { +		minID = minIDString +	} +  	pinnedOnly := false  	pinnedString := c.Query(PinnedKey)  	if pinnedString != "" { @@ -156,7 +174,7 @@ func (m *Module) AccountStatusesGETHandler(c *gin.Context) {  	}  	mediaOnly := false -	mediaOnlyString := c.Query(MediaOnlyKey) +	mediaOnlyString := c.Query(OnlyMediaKey)  	if mediaOnlyString != "" {  		i, err := strconv.ParseBool(mediaOnlyString)  		if err != nil { @@ -167,7 +185,19 @@ func (m *Module) AccountStatusesGETHandler(c *gin.Context) {  		mediaOnly = i  	} -	statuses, errWithCode := m.processor.AccountStatusesGet(c.Request.Context(), authed, targetAcctID, limit, excludeReplies, maxID, pinnedOnly, mediaOnly) +	publicOnly := false +	publicOnlyString := c.Query(OnlyPublicKey) +	if mediaOnlyString != "" { +		i, err := strconv.ParseBool(publicOnlyString) +		if err != nil { +			l.Debugf("error parsing public only string: %s", err) +			c.JSON(http.StatusBadRequest, gin.H{"error": "couldn't parse public only query param"}) +			return +		} +		mediaOnly = i +	} + +	statuses, errWithCode := m.processor.AccountStatusesGet(c.Request.Context(), authed, targetAcctID, limit, excludeReplies, maxID, minID, pinnedOnly, mediaOnly, publicOnly)  	if errWithCode != nil {  		l.Debugf("error from processor account statuses get: %s", errWithCode)  		c.JSON(errWithCode.Code(), gin.H{"error": errWithCode.Safe()}) | 
