| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- // Copyright 2021 Frédéric Guillot. All rights reserved.
- // Use of this source code is governed by the Apache 2.0
- // license that can be found in the LICENSE file.
- package validator // import "miniflux.app/validator"
- import (
- "errors"
- "fmt"
- "net/url"
- "regexp"
- "miniflux.app/locale"
- )
- // ValidationError represents a validation error.
- type ValidationError struct {
- TranslationKey string
- }
- // NewValidationError initializes a validation error.
- func NewValidationError(translationKey string) *ValidationError {
- return &ValidationError{TranslationKey: translationKey}
- }
- func (v *ValidationError) String() string {
- return locale.NewPrinter("en_US").Printf(v.TranslationKey)
- }
- func (v *ValidationError) Error() error {
- return errors.New(v.String())
- }
- // ValidateRange makes sure the offset/limit values are valid.
- func ValidateRange(offset, limit int) error {
- if offset < 0 {
- return fmt.Errorf(`Offset value should be >= 0`)
- }
- if limit < 0 {
- return fmt.Errorf(`Limit value should be >= 0`)
- }
- return nil
- }
- // ValidateDirection makes sure the sorting direction is valid.
- func ValidateDirection(direction string) error {
- switch direction {
- case "asc", "desc":
- return nil
- }
- return fmt.Errorf(`Invalid direction, valid direction values are: "asc" or "desc"`)
- }
- // IsValidRegex verifies if the regex can be compiled.
- func IsValidRegex(expr string) bool {
- _, err := regexp.Compile(expr)
- return err == nil
- }
- // IsValidURL verifies if the provided value is a valid absolute URL.
- func IsValidURL(absoluteURL string) bool {
- _, err := url.ParseRequestURI(absoluteURL)
- return err == nil
- }
|