blob: bd45ac40bfc06b760eee1c552626e1201d3293c2 [file] [log] [blame]
/*
* Copyright (c) 2025 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/data-model-provider/MetadataTypes.h>
#include <app/server-cluster/ServerClusterInterface.h>
#include <clusters/shared/Structs.h>
#include <lib/core/DataModelTypes.h>
#include <lib/support/ReadOnlyBuffer.h>
namespace chip {
namespace app {
/**
* @brief Defines the interface for an object that can provide information about a Matter endpoint.
*
* This interface is used describe the structure and capabilities of an endpoint, including its device
* types, client clusters, server clusters, and semantic tags.
*
* Implementations of this interface are responsible for providing instances of ServerClusterInterface
* for each server cluster they expose.
*/
class EndpointInterface
{
public:
virtual ~EndpointInterface() = default;
using SemanticTag = Clusters::Globals::Structs::SemanticTagStruct::Type;
virtual CHIP_ERROR DeviceTypes(ReadOnlyBufferBuilder<DataModel::DeviceTypeEntry> & out) const = 0;
virtual CHIP_ERROR ClientClusters(ReadOnlyBufferBuilder<ClusterId> & out) const = 0;
/**
* An implementation of the EndpointInterface MUST ensure that the underlying
* data returned here remains valid for the lifetime of the implementation instance.
* This is a non-owning view of the unique endpoint ID data.
*/
#if CHIP_CONFIG_USE_ENDPOINT_UNIQUE_ID
virtual CharSpan EndpointUniqueID() const = 0;
#endif
};
} // namespace app
} // namespace chip