123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- /*
- *
- * Copyright 2021 gRPC authors.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- */
- // Package admin contains internal implementation for admin service.
- package admin
- import "google.golang.org/grpc"
- // services is a map from name to service register functions.
- var services []func(grpc.ServiceRegistrar) (func(), error)
- // AddService adds a service to the list of admin services.
- //
- // NOTE: this function must only be called during initialization time (i.e. in
- // an init() function), and is not thread-safe.
- //
- // If multiple services with the same service name are added (e.g. two services
- // for `grpc.channelz.v1.Channelz`), the server will panic on `Register()`.
- func AddService(f func(grpc.ServiceRegistrar) (func(), error)) {
- services = append(services, f)
- }
- // Register registers the set of admin services to the given server.
- func Register(s grpc.ServiceRegistrar) (cleanup func(), _ error) {
- var cleanups []func()
- for _, f := range services {
- cleanup, err := f(s)
- if err != nil {
- callFuncs(cleanups)
- return nil, err
- }
- if cleanup != nil {
- cleanups = append(cleanups, cleanup)
- }
- }
- return func() {
- callFuncs(cleanups)
- }, nil
- }
- func callFuncs(fs []func()) {
- for _, f := range fs {
- f()
- }
- }
|