vikunja/pkg/modules/parse-time/errors.go

52 lines
1.7 KiB
Go

// Vikunja is a to-do list application to facilitate your life.
// Copyright 2018-2022 Vikunja and contributors. All rights reserved.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public Licensee 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 Licensee for more details.
//
// You should have received a copy of the GNU Affero General Public Licensee
// along with this program. If not, see <https://www.gnu.org/licenses/>.
package parse_time
import (
"fmt"
"net/http"
"code.vikunja.io/web"
)
// ErrInvalidTimeRange represents a "InvalidTimeRange" kind of error. Used if the provided time range is invalid.
type ErrInvalidTimeRange struct {
Range string
}
// IsErrInvalidTimeRange checks if an error is a ErrInvalidTimeRange.
func IsErrInvalidTimeRange(err error) bool {
_, ok := err.(*ErrInvalidTimeRange)
return ok
}
func (err *ErrInvalidTimeRange) Error() string {
return fmt.Sprintf("Time range '%s' is invalid", err.Range)
}
// ErrCodeInvalidTimeRange holds the unique world-error code of this error
const ErrCodeInvalidTimeRange = 14001
// HTTPError holds the http error description
func (err *ErrInvalidTimeRange) HTTPError() web.HTTPError {
return web.HTTPError{
HTTPCode: http.StatusPreconditionFailed,
Code: ErrCodeInvalidTimeRange,
Message: "The time range is invalid.",
}
}