forked from project-chip/connectedhomeip
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCommissionerDeclarationHandler.cpp
119 lines (108 loc) · 5.38 KB
/
CommissionerDeclarationHandler.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
*
* Copyright (c) 2024 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.
*/
#include "CommissionerDeclarationHandler.h"
#include "CastingPlayer.h"
#include "Types.h"
#include "support/ChipDeviceEventHandler.h"
#include <app/server/Server.h>
namespace matter {
namespace casting {
namespace core {
CommissionerDeclarationHandler * CommissionerDeclarationHandler::sCommissionerDeclarationHandler_ = nullptr;
CommissionerDeclarationHandler * CommissionerDeclarationHandler::GetInstance()
{
if (sCommissionerDeclarationHandler_ == nullptr)
{
sCommissionerDeclarationHandler_ = new CommissionerDeclarationHandler();
}
return sCommissionerDeclarationHandler_;
}
void CommissionerDeclarationHandler::OnCommissionerDeclarationMessage(
const chip::Transport::PeerAddress & source, chip::Protocols::UserDirectedCommissioning::CommissionerDeclaration cd)
{
ChipLogProgress(AppServer, "CommissionerDeclarationHandler::OnCommissionerDeclarationMessage()");
// During UDC with CastingPlayer/Commissioner-Generated Passcode, the Commissioner responds with a CommissionerDeclaration
// message with CommissionerPasscode set to true. The CommissionerPasscode flag indicates that a Passcode is now displayed for
// the user by the CastingPlayer /Commissioner. With this CommissionerDeclaration message, we also know that commissioning via
// AccountLogin cluster has failed. Therefore, we close the commissioning window. We will open a new commissioning window prior
// to sending the next/2nd IdentificationDeclaration message to the Commissioner.
if (cd.GetCommissionerPasscode())
{
ChipLogProgress(AppServer,
"CommissionerDeclarationHandler::OnCommissionerDeclarationMessage(), calling CloseCommissioningWindow()");
// Close the commissioning window.
chip::Server::GetInstance().GetCommissioningWindowManager().CloseCommissioningWindow();
support::ChipDeviceEventHandler::SetUdcStatus(false);
}
// Flag to indicate when the CastingPlayer/Commissioner user has decided to exit the commissioning process.
if (cd.GetCancelPasscode())
{
ChipLogProgress(AppServer,
"CommissionerDeclarationHandler::OnCommissionerDeclarationMessage(), Got CancelPasscode parameter, "
"CastingPlayer/Commissioner user has decided to exit the commissioning attempt. Connection aborted.");
// Close the commissioning window.
chip::Server::GetInstance().GetCommissioningWindowManager().CloseCommissioningWindow();
support::ChipDeviceEventHandler::SetUdcStatus(false);
// Since the CastingPlayer/Commissioner user has decided to exit the commissioning process, we cancel the ongoing
// connection attempt without notifying the CastingPlayer/Commissioner. Therefore the
// shouldSendIdentificationDeclarationMessage flag in the internal StopConnecting() API call is set to false. The
// CastingPlayer/Commissioner user and the Casting Client/Commissionee user are not necessarily the same user. For example,
// in an enviroment with multiple CastingPlayer/Commissioner TVs, one user 1 might be controlling the Client/Commissionee
// and user 2 might be controlling the CastingPlayer/Commissioner TV.
CastingPlayer * targetCastingPlayer = CastingPlayer::GetTargetCastingPlayer();
// Avoid crashing if we recieve this CommissionerDeclaration message when targetCastingPlayer is nullptr.
if (targetCastingPlayer != nullptr)
{
CHIP_ERROR err = targetCastingPlayer->StopConnecting(false);
if (err != CHIP_NO_ERROR)
{
ChipLogError(
AppServer,
"CommissionerDeclarationHandler::OnCommissionerDeclarationMessage() StopConnecting() failed due to error: "
"%" CHIP_ERROR_FORMAT,
err.Format());
}
}
else
{
ChipLogError(AppServer,
"CommissionerDeclarationHandler::OnCommissionerDeclarationMessage() targetCastingPlayer is nullptr");
}
}
if (mCmmissionerDeclarationCallback_)
{
mCmmissionerDeclarationCallback_(source, cd);
}
else
{
ChipLogError(AppServer,
"CommissionerDeclarationHandler::OnCommissionerDeclarationMessage() mCmmissionerDeclarationCallback_ not set");
}
}
void CommissionerDeclarationHandler::SetCommissionerDeclarationCallback(
matter::casting::core::CommissionerDeclarationCallback callback)
{
ChipLogProgress(AppServer, "CommissionerDeclarationHandler::SetCommissionerDeclarationCallback()");
if (callback != nullptr)
{
mCmmissionerDeclarationCallback_ = std::move(callback);
}
}
} // namespace core
} // namespace casting
} // namespace matter