diff options
Diffstat (limited to 'internal/api/client/status/statusdelete.go')
-rw-r--r-- | internal/api/client/status/statusdelete.go | 100 |
1 files changed, 0 insertions, 100 deletions
diff --git a/internal/api/client/status/statusdelete.go b/internal/api/client/status/statusdelete.go deleted file mode 100644 index b37dd5f14..000000000 --- a/internal/api/client/status/statusdelete.go +++ /dev/null @@ -1,100 +0,0 @@ -/* - GoToSocial - Copyright (C) 2021-2022 GoToSocial Authors admin@gotosocial.org - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU Affero General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU Affero General Public License for more details. - - You should have received a copy of the GNU Affero General Public License - along with this program. If not, see <http://www.gnu.org/licenses/>. -*/ - -package status - -import ( - "errors" - "net/http" - - "github.com/gin-gonic/gin" - "github.com/superseriousbusiness/gotosocial/internal/api" - "github.com/superseriousbusiness/gotosocial/internal/gtserror" - "github.com/superseriousbusiness/gotosocial/internal/oauth" -) - -// StatusDELETEHandler swagger:operation DELETE /api/v1/statuses/{id} statusDelete -// -// Delete status with the given ID. The status must belong to you. -// -// The deleted status will be returned in the response. The `text` field will contain the original text of the status as it was submitted. -// This is useful when doing a 'delete and redraft' type operation. -// -// --- -// tags: -// - statuses -// -// produces: -// - application/json -// -// parameters: -// - -// name: id -// type: string -// description: Target status ID. -// in: path -// required: true -// -// security: -// - OAuth2 Bearer: -// - write:statuses -// -// responses: -// '200': -// description: "The status that was just deleted." -// schema: -// "$ref": "#/definitions/status" -// '400': -// description: bad request -// '401': -// description: unauthorized -// '403': -// description: forbidden -// '404': -// description: not found -// '406': -// description: not acceptable -// '500': -// description: internal server error -func (m *Module) StatusDELETEHandler(c *gin.Context) { - authed, err := oauth.Authed(c, true, true, true, true) - if err != nil { - api.ErrorHandler(c, gtserror.NewErrorUnauthorized(err, err.Error()), m.processor.InstanceGet) - return - } - - if _, err := api.NegotiateAccept(c, api.JSONAcceptHeaders...); err != nil { - api.ErrorHandler(c, gtserror.NewErrorNotAcceptable(err, err.Error()), m.processor.InstanceGet) - return - } - - targetStatusID := c.Param(IDKey) - if targetStatusID == "" { - err := errors.New("no status id specified") - api.ErrorHandler(c, gtserror.NewErrorBadRequest(err, err.Error()), m.processor.InstanceGet) - return - } - - apiStatus, errWithCode := m.processor.StatusDelete(c.Request.Context(), authed, targetStatusID) - if errWithCode != nil { - api.ErrorHandler(c, errWithCode, m.processor.InstanceGet) - return - } - - c.JSON(http.StatusOK, apiStatus) -} |