// // // Copyright 2015 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. // // #ifndef GRPC_SRC_CORE_LIB_TRANSPORT_CONNECTIVITY_STATE_H #define GRPC_SRC_CORE_LIB_TRANSPORT_CONNECTIVITY_STATE_H #include <grpc/support/port_platform.h> #include <atomic> #include <map> #include <memory> #include <utility> #include "absl/status/status.h" #include <grpc/impl/connectivity_state.h> #include "src/core/lib/debug/trace.h" #include "src/core/lib/gprpp/orphanable.h" #include "src/core/lib/gprpp/work_serializer.h" namespace grpc_core { extern TraceFlag grpc_connectivity_state_trace; // Enum to string conversion. const char* ConnectivityStateName(grpc_connectivity_state state); // Interface for watching connectivity state. // Subclasses must implement the Notify() method. // // Note: Most callers will want to use // AsyncConnectivityStateWatcherInterface instead. class ConnectivityStateWatcherInterface : public InternallyRefCounted<ConnectivityStateWatcherInterface> { … }; // An alternative watcher interface that performs notifications via an // asynchronous callback scheduled on the ExecCtx. // Subclasses must implement the OnConnectivityStateChange() method. class AsyncConnectivityStateWatcherInterface : public ConnectivityStateWatcherInterface { … }; // Tracks connectivity state. Maintains a list of watchers that are // notified whenever the state changes. // // Note that once the state becomes SHUTDOWN, watchers will be notified // and then automatically orphaned (i.e., RemoveWatcher() does not need // to be called). class ConnectivityStateTracker { … }; } // namespace grpc_core #endif // GRPC_SRC_CORE_LIB_TRANSPORT_CONNECTIVITY_STATE_H