You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

options.go 1.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. // Copyright 2015 go-swagger maintainers
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package validate
  15. import "sync"
  16. // Opts specifies validation options for a SpecValidator.
  17. //
  18. // NOTE: other options might be needed, for example a go-swagger specific mode.
  19. type Opts struct {
  20. ContinueOnErrors bool // true: continue reporting errors, even if spec is invalid
  21. }
  22. var (
  23. defaultOpts = Opts{ContinueOnErrors: false} // default is to stop validation on errors
  24. defaultOptsMutex = &sync.Mutex{}
  25. )
  26. // SetContinueOnErrors sets global default behavior regarding spec validation errors reporting.
  27. //
  28. // For extended error reporting, you most likely want to set it to true.
  29. // For faster validation, it's better to give up early when a spec is detected as invalid: set it to false (this is the default).
  30. //
  31. // Setting this mode does NOT affect the validation status.
  32. //
  33. // NOTE: this method affects global defaults. It is not suitable for a concurrent usage.
  34. func SetContinueOnErrors(c bool) {
  35. defer defaultOptsMutex.Unlock()
  36. defaultOptsMutex.Lock()
  37. defaultOpts.ContinueOnErrors = c
  38. }