vikunja-api/vendor/code.vikunja.io/web/handler/helper.go

51 lines
1.6 KiB
Go
Raw Normal View History

2018-12-02 19:30:42 +01:00
// Copyright (c) 2018 Vikunja and contributors.
2018-11-26 21:17:33 +01:00
//
// This program is free software: you can redistribute it and/or modify
2018-12-02 19:30:42 +01:00
// it under the terms of the GNU Lesser General Public License as published by
2018-11-26 21:17:33 +01:00
// 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
2018-12-02 19:30:42 +01:00
// GNU Lesser General Public License for more details.
2018-11-26 21:17:33 +01:00
//
2018-12-02 19:30:42 +01:00
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
2018-11-26 21:17:33 +01:00
2018-12-01 00:26:56 +01:00
package handler
import (
2018-12-01 00:26:56 +01:00
"code.vikunja.io/web"
2018-10-06 15:04:14 +02:00
"github.com/labstack/echo"
2018-12-01 00:26:56 +01:00
"github.com/op/go-logging"
2018-10-06 15:04:14 +02:00
"net/http"
)
2018-07-10 14:02:23 +02:00
// WebHandler defines the webhandler object
// This does web stuff, aka returns json etc. Uses CRUDable Methods to get the data
2018-07-10 14:02:23 +02:00
type WebHandler struct {
EmptyStruct func() CObject
}
// CObject is the definition of our object, holds the structs
type CObject interface {
2018-12-01 00:26:56 +01:00
web.CRUDable
web.Rights
}
2018-10-06 15:04:14 +02:00
// HandleHTTPError does what it says
2018-12-01 00:26:56 +01:00
func HandleHTTPError(err error, ctx echo.Context) *echo.HTTPError {
if a, has := err.(web.HTTPErrorProcessor); has {
2018-10-06 15:04:14 +02:00
errDetails := a.HTTPError()
2018-10-11 18:18:44 +02:00
return echo.NewHTTPError(errDetails.HTTPCode, errDetails)
2018-10-06 15:04:14 +02:00
}
2019-01-25 12:40:54 +01:00
getLogger(ctx).Error(err.Error())
2018-10-06 15:04:14 +02:00
return echo.NewHTTPError(http.StatusInternalServerError)
}
2019-01-25 12:40:54 +01:00
// Helper function to get the logger
func getLogger(ctx echo.Context) *logging.Logger {
return ctx.Get("LoggingProvider").(*logging.Logger)
}