serviceconfig.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. *
  3. * Copyright 2019 gRPC authors.
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. *
  17. */
  18. // Package serviceconfig defines types and methods for operating on gRPC
  19. // service configs.
  20. //
  21. // This package is EXPERIMENTAL.
  22. package serviceconfig
  23. import (
  24. "google.golang.org/grpc/internal"
  25. )
  26. // Config represents an opaque data structure holding a service config.
  27. type Config interface {
  28. isConfig()
  29. }
  30. // LoadBalancingConfig represents an opaque data structure holding a load
  31. // balancer config.
  32. type LoadBalancingConfig interface {
  33. isLoadBalancingConfig()
  34. }
  35. // Parse parses the JSON service config provided into an internal form or
  36. // returns an error if the config is invalid.
  37. func Parse(ServiceConfigJSON string) (Config, error) {
  38. c, err := internal.ParseServiceConfig(ServiceConfigJSON)
  39. if err != nil {
  40. return nil, err
  41. }
  42. return c.(Config), err
  43. }