| /* |
| * |
| * Copyright (c) 2020-2021 Project CHIP Authors |
| * All rights reserved. |
| * |
| * 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. |
| */ |
| |
| #pragma once |
| |
| #include <app/CASEClientPool.h> |
| #include <app/OperationalDeviceProxy.h> |
| #include <app/OperationalDeviceProxyPool.h> |
| #include <lib/core/CHIPConfig.h> |
| #include <lib/core/CHIPCore.h> |
| #include <lib/dnssd/DnssdCache.h> |
| #include <lib/support/Pool.h> |
| #include <platform/CHIPDeviceLayer.h> |
| #include <transport/SessionDelegate.h> |
| |
| #include <lib/dnssd/ResolverProxy.h> |
| |
| namespace chip { |
| |
| struct CASESessionManagerConfig |
| { |
| DeviceProxyInitParams sessionInitParams; |
| Dnssd::DnssdCache<CHIP_CONFIG_MDNS_CACHE_SIZE> * dnsCache = nullptr; |
| OperationalDeviceProxyPoolDelegate * devicePool = nullptr; |
| Dnssd::ResolverProxy * dnsResolver = nullptr; |
| }; |
| |
| /** |
| * This class provides the following |
| * 1. Manage a pool of operational device proxy objects for peer nodes that have active message exchange with the local node. |
| * 2. The pool contains atmost one device proxy object for a given peer node. |
| * 3. API to lookup an existing proxy object, or allocate a new one by triggering session establishment with the peer node. |
| * 4. During session establishment, trigger node ID resolution (if needed), and update the DNS-SD cache (if resolution is |
| * successful) |
| */ |
| class CASESessionManager : public Dnssd::ResolverDelegate |
| { |
| public: |
| CASESessionManager() = delete; |
| |
| CASESessionManager(const CASESessionManagerConfig & params) |
| { |
| VerifyOrDie(params.sessionInitParams.Validate() == CHIP_NO_ERROR); |
| |
| mConfig = params; |
| } |
| |
| CHIP_ERROR Init() |
| { |
| if (mConfig.dnsResolver == nullptr) |
| { |
| ReturnErrorOnFailure(mDNSResolver.Init(DeviceLayer::UDPEndPointManager())); |
| mDNSResolver.SetResolverDelegate(this); |
| mConfig.dnsResolver = &mDNSResolver; |
| } |
| return CHIP_NO_ERROR; |
| } |
| |
| virtual ~CASESessionManager() { mDNSResolver.Shutdown(); } |
| |
| /** |
| * Find an existing session for the given node ID, or trigger a new session request. |
| * The caller can optionally provide `onConnection` and `onFailure` callback objects. If provided, |
| * these will be used to inform the caller about successful or failed connection establishment. |
| * If the connection is already established, the `onConnection` callback will be immediately called. |
| */ |
| CHIP_ERROR FindOrEstablishSession(PeerId peerId, Callback::Callback<OnDeviceConnected> * onConnection, |
| Callback::Callback<OnDeviceConnectionFailure> * onFailure); |
| |
| OperationalDeviceProxy * FindExistingSession(PeerId peerId); |
| |
| void ReleaseSession(PeerId peerId); |
| |
| /** |
| * This API triggers the DNS-SD resolution for the given node ID. The node ID will be looked up |
| * on the fabric that was configured for the CASESessionManager object. |
| * |
| * The results of the DNS-SD resolution request is provided to the class via `ResolverDelegate` |
| * implementation of CASESessionManager. |
| */ |
| CHIP_ERROR ResolveDeviceAddress(FabricInfo * fabric, NodeId nodeId); |
| |
| /** |
| * This API returns the address for the given node ID. |
| * If the CASESessionManager is configured with a DNS-SD cache, the cache is looked up |
| * for the node ID. |
| * If the DNS-SD cache is not available, the CASESessionManager looks up the list for |
| * an ongoing session with the peer node. If the session doesn't exist, the API will return |
| * `CHIP_ERROR_NOT_CONNECTED` error. |
| */ |
| CHIP_ERROR GetPeerAddress(PeerId peerId, Transport::PeerAddress & addr); |
| |
| //////////// ResolverDelegate Implementation /////////////// |
| void OnNodeIdResolved(const Dnssd::ResolvedNodeData & nodeData) override; |
| void OnNodeIdResolutionFailed(const PeerId & peerId, CHIP_ERROR error) override; |
| void OnNodeDiscoveryComplete(const Dnssd::DiscoveredNodeData & nodeData) override {} |
| |
| private: |
| OperationalDeviceProxy * FindSession(const SessionHandle & session); |
| void ReleaseSession(OperationalDeviceProxy * device); |
| |
| CASESessionManagerConfig mConfig; |
| Dnssd::ResolverProxy mDNSResolver; |
| }; |
| |
| } // namespace chip |