keyValues.go 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * Copyright (c) 2019, Psiphon Inc.
  3. * All rights reserved.
  4. *
  5. * This program is free software: you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation, either version 3 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. *
  18. */
  19. package parameters
  20. import (
  21. "encoding/json"
  22. "time"
  23. "github.com/Psiphon-Labs/psiphon-tunnel-core/psiphon/common/errors"
  24. )
  25. // KeyValues represents a set of name/JSON pairs.
  26. type KeyValues map[string]json.RawMessage
  27. // Validate checks that the JSON values are well-formed.
  28. func (keyValues KeyValues) Validate() error {
  29. for _, value := range keyValues {
  30. var v interface{}
  31. err := json.Unmarshal(value, &v)
  32. if err != nil {
  33. return errors.Trace(err)
  34. }
  35. }
  36. return nil
  37. }
  38. // KeyStrings represents a set of key/strings pairs.
  39. type KeyStrings map[string][]string
  40. // Validates that the keys and values are well formed.
  41. func (keyStrings KeyStrings) Validate() error {
  42. // Always succeeds because KeyStrings is generic and does not impose any
  43. // restrictions on keys/values. Consider imposing limits like maximum
  44. // map/array/string sizes.
  45. return nil
  46. }
  47. // KeyDurations represents a set of key/duration pairs.
  48. type KeyDurations map[string]string
  49. // Validates that the keys and durations are well formed.
  50. func (keyDurations KeyDurations) Validate() error {
  51. for _, value := range keyDurations {
  52. _, err := time.ParseDuration(value)
  53. if err != nil {
  54. return errors.Trace(err)
  55. }
  56. }
  57. return nil
  58. }