1*cfb92d14SAndroid Build Coastguard Worker /*
2*cfb92d14SAndroid Build Coastguard Worker * Copyright (c) 2023, The OpenThread Authors.
3*cfb92d14SAndroid Build Coastguard Worker * All rights reserved.
4*cfb92d14SAndroid Build Coastguard Worker *
5*cfb92d14SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
6*cfb92d14SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions are met:
7*cfb92d14SAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
8*cfb92d14SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
9*cfb92d14SAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
10*cfb92d14SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
11*cfb92d14SAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
12*cfb92d14SAndroid Build Coastguard Worker * 3. Neither the name of the copyright holder nor the
13*cfb92d14SAndroid Build Coastguard Worker * names of its contributors may be used to endorse or promote products
14*cfb92d14SAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
15*cfb92d14SAndroid Build Coastguard Worker *
16*cfb92d14SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*cfb92d14SAndroid Build Coastguard Worker * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*cfb92d14SAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*cfb92d14SAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20*cfb92d14SAndroid Build Coastguard Worker * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*cfb92d14SAndroid Build Coastguard Worker * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*cfb92d14SAndroid Build Coastguard Worker * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*cfb92d14SAndroid Build Coastguard Worker * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*cfb92d14SAndroid Build Coastguard Worker * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*cfb92d14SAndroid Build Coastguard Worker * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*cfb92d14SAndroid Build Coastguard Worker * POSSIBILITY OF SUCH DAMAGE.
27*cfb92d14SAndroid Build Coastguard Worker */
28*cfb92d14SAndroid Build Coastguard Worker
29*cfb92d14SAndroid Build Coastguard Worker /**
30*cfb92d14SAndroid Build Coastguard Worker * @file
31*cfb92d14SAndroid Build Coastguard Worker * This file implements CLI for Backbone Router.
32*cfb92d14SAndroid Build Coastguard Worker */
33*cfb92d14SAndroid Build Coastguard Worker
34*cfb92d14SAndroid Build Coastguard Worker #include "cli_bbr.hpp"
35*cfb92d14SAndroid Build Coastguard Worker
36*cfb92d14SAndroid Build Coastguard Worker #include "cli/cli.hpp"
37*cfb92d14SAndroid Build Coastguard Worker
38*cfb92d14SAndroid Build Coastguard Worker #if (OPENTHREAD_CONFIG_THREAD_VERSION >= OT_THREAD_VERSION_1_2)
39*cfb92d14SAndroid Build Coastguard Worker
40*cfb92d14SAndroid Build Coastguard Worker namespace ot {
41*cfb92d14SAndroid Build Coastguard Worker namespace Cli {
42*cfb92d14SAndroid Build Coastguard Worker
OutputConfig(const otBackboneRouterConfig & aConfig)43*cfb92d14SAndroid Build Coastguard Worker void Bbr::OutputConfig(const otBackboneRouterConfig &aConfig)
44*cfb92d14SAndroid Build Coastguard Worker {
45*cfb92d14SAndroid Build Coastguard Worker OutputLine("seqno: %u", aConfig.mSequenceNumber);
46*cfb92d14SAndroid Build Coastguard Worker OutputLine("delay: %u secs", aConfig.mReregistrationDelay);
47*cfb92d14SAndroid Build Coastguard Worker OutputLine("timeout: %lu secs", ToUlong(aConfig.mMlrTimeout));
48*cfb92d14SAndroid Build Coastguard Worker }
49*cfb92d14SAndroid Build Coastguard Worker
50*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_FTD && OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE
51*cfb92d14SAndroid Build Coastguard Worker
52*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE
53*cfb92d14SAndroid Build Coastguard Worker
Process(Arg aArgs[])54*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("mlr")>(Arg aArgs[])
55*cfb92d14SAndroid Build Coastguard Worker {
56*cfb92d14SAndroid Build Coastguard Worker otError error = OT_ERROR_INVALID_COMMAND;
57*cfb92d14SAndroid Build Coastguard Worker
58*cfb92d14SAndroid Build Coastguard Worker /**
59*cfb92d14SAndroid Build Coastguard Worker * @cli bbr mgmt mlr listener
60*cfb92d14SAndroid Build Coastguard Worker * @code
61*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt mlr listener
62*cfb92d14SAndroid Build Coastguard Worker * ff04:0:0:0:0:0:0:abcd 3534000
63*cfb92d14SAndroid Build Coastguard Worker * ff04:0:0:0:0:0:0:eeee 3537610
64*cfb92d14SAndroid Build Coastguard Worker * Done
65*cfb92d14SAndroid Build Coastguard Worker * @endcode
66*cfb92d14SAndroid Build Coastguard Worker * @par
67*cfb92d14SAndroid Build Coastguard Worker * Returns the Multicast Listeners with the #otBackboneRouterMulticastListenerInfo
68*cfb92d14SAndroid Build Coastguard Worker * `mTimeout` in seconds.
69*cfb92d14SAndroid Build Coastguard Worker * @par
70*cfb92d14SAndroid Build Coastguard Worker * Available when `OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE` and
71*cfb92d14SAndroid Build Coastguard Worker * `OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE` are enabled.
72*cfb92d14SAndroid Build Coastguard Worker * @sa otBackboneRouterMulticastListenerGetNext
73*cfb92d14SAndroid Build Coastguard Worker */
74*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0] == "listener")
75*cfb92d14SAndroid Build Coastguard Worker {
76*cfb92d14SAndroid Build Coastguard Worker if (aArgs[1].IsEmpty())
77*cfb92d14SAndroid Build Coastguard Worker {
78*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterMulticastListenerIterator iter = OT_BACKBONE_ROUTER_MULTICAST_LISTENER_ITERATOR_INIT;
79*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterMulticastListenerInfo listenerInfo;
80*cfb92d14SAndroid Build Coastguard Worker
81*cfb92d14SAndroid Build Coastguard Worker while (otBackboneRouterMulticastListenerGetNext(GetInstancePtr(), &iter, &listenerInfo) == OT_ERROR_NONE)
82*cfb92d14SAndroid Build Coastguard Worker {
83*cfb92d14SAndroid Build Coastguard Worker OutputIp6Address(listenerInfo.mAddress);
84*cfb92d14SAndroid Build Coastguard Worker OutputLine(" %lu", ToUlong(listenerInfo.mTimeout));
85*cfb92d14SAndroid Build Coastguard Worker }
86*cfb92d14SAndroid Build Coastguard Worker
87*cfb92d14SAndroid Build Coastguard Worker ExitNow(error = OT_ERROR_NONE);
88*cfb92d14SAndroid Build Coastguard Worker }
89*cfb92d14SAndroid Build Coastguard Worker
90*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE
91*cfb92d14SAndroid Build Coastguard Worker /**
92*cfb92d14SAndroid Build Coastguard Worker * @cli bbr mgmt mlr listener clear
93*cfb92d14SAndroid Build Coastguard Worker * @code
94*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt mlr listener clear
95*cfb92d14SAndroid Build Coastguard Worker * Done
96*cfb92d14SAndroid Build Coastguard Worker * @endcode
97*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
98*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterMulticastListenerClear
99*cfb92d14SAndroid Build Coastguard Worker */
100*cfb92d14SAndroid Build Coastguard Worker if (aArgs[1] == "clear")
101*cfb92d14SAndroid Build Coastguard Worker {
102*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterMulticastListenerClear(GetInstancePtr());
103*cfb92d14SAndroid Build Coastguard Worker error = OT_ERROR_NONE;
104*cfb92d14SAndroid Build Coastguard Worker }
105*cfb92d14SAndroid Build Coastguard Worker /**
106*cfb92d14SAndroid Build Coastguard Worker * @cli bbr mgmt mlr listener add
107*cfb92d14SAndroid Build Coastguard Worker * @code
108*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt mlr listener add ff04::1
109*cfb92d14SAndroid Build Coastguard Worker * Done
110*cfb92d14SAndroid Build Coastguard Worker * @endcode
111*cfb92d14SAndroid Build Coastguard Worker * @code
112*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt mlr listener add ff04::2 300
113*cfb92d14SAndroid Build Coastguard Worker * Done
114*cfb92d14SAndroid Build Coastguard Worker * @endcode
115*cfb92d14SAndroid Build Coastguard Worker * @cparam bbr mgmt mlr listener add @ca{ipaddress} [@ca{timeout-seconds}]
116*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
117*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterMulticastListenerAdd
118*cfb92d14SAndroid Build Coastguard Worker */
119*cfb92d14SAndroid Build Coastguard Worker else if (aArgs[1] == "add")
120*cfb92d14SAndroid Build Coastguard Worker {
121*cfb92d14SAndroid Build Coastguard Worker otIp6Address address;
122*cfb92d14SAndroid Build Coastguard Worker uint32_t timeout = 0;
123*cfb92d14SAndroid Build Coastguard Worker
124*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = aArgs[2].ParseAsIp6Address(address));
125*cfb92d14SAndroid Build Coastguard Worker
126*cfb92d14SAndroid Build Coastguard Worker if (!aArgs[3].IsEmpty())
127*cfb92d14SAndroid Build Coastguard Worker {
128*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = aArgs[3].ParseAsUint32(timeout));
129*cfb92d14SAndroid Build Coastguard Worker }
130*cfb92d14SAndroid Build Coastguard Worker
131*cfb92d14SAndroid Build Coastguard Worker error = otBackboneRouterMulticastListenerAdd(GetInstancePtr(), &address, timeout);
132*cfb92d14SAndroid Build Coastguard Worker }
133*cfb92d14SAndroid Build Coastguard Worker }
134*cfb92d14SAndroid Build Coastguard Worker /**
135*cfb92d14SAndroid Build Coastguard Worker * @cli bbr mgmt mlr response
136*cfb92d14SAndroid Build Coastguard Worker * @code
137*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt mlr response 2
138*cfb92d14SAndroid Build Coastguard Worker * Done
139*cfb92d14SAndroid Build Coastguard Worker * @endcode
140*cfb92d14SAndroid Build Coastguard Worker * @cparam bbr mgmt mlr response @ca{status-code}
141*cfb92d14SAndroid Build Coastguard Worker * For `status-code`, use:
142*cfb92d14SAndroid Build Coastguard Worker * * 0: ST_MLR_SUCCESS
143*cfb92d14SAndroid Build Coastguard Worker * * 2: ST_MLR_INVALID
144*cfb92d14SAndroid Build Coastguard Worker * * 3: ST_MLR_NO_PERSISTENT
145*cfb92d14SAndroid Build Coastguard Worker * * 4: ST_MLR_NO_RESOURCES
146*cfb92d14SAndroid Build Coastguard Worker * * 5: ST_MLR_BBR_NOT_PRIMARY
147*cfb92d14SAndroid Build Coastguard Worker * * 6: ST_MLR_GENERAL_FAILURE
148*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
149*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterConfigNextMulticastListenerRegistrationResponse
150*cfb92d14SAndroid Build Coastguard Worker */
151*cfb92d14SAndroid Build Coastguard Worker else if (aArgs[0] == "response")
152*cfb92d14SAndroid Build Coastguard Worker {
153*cfb92d14SAndroid Build Coastguard Worker uint8_t status;
154*cfb92d14SAndroid Build Coastguard Worker
155*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = aArgs[1].ParseAsUint8(status));
156*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterConfigNextMulticastListenerRegistrationResponse(GetInstancePtr(), status);
157*cfb92d14SAndroid Build Coastguard Worker error = OT_ERROR_NONE;
158*cfb92d14SAndroid Build Coastguard Worker
159*cfb92d14SAndroid Build Coastguard Worker #endif // OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE
160*cfb92d14SAndroid Build Coastguard Worker }
161*cfb92d14SAndroid Build Coastguard Worker
162*cfb92d14SAndroid Build Coastguard Worker exit:
163*cfb92d14SAndroid Build Coastguard Worker return error;
164*cfb92d14SAndroid Build Coastguard Worker }
165*cfb92d14SAndroid Build Coastguard Worker
166*cfb92d14SAndroid Build Coastguard Worker #endif // #if OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE
167*cfb92d14SAndroid Build Coastguard Worker
Process(Arg aArgs[])168*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("mgmt")>(Arg aArgs[])
169*cfb92d14SAndroid Build Coastguard Worker {
170*cfb92d14SAndroid Build Coastguard Worker otError error = OT_ERROR_INVALID_COMMAND;
171*cfb92d14SAndroid Build Coastguard Worker
172*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0].IsEmpty())
173*cfb92d14SAndroid Build Coastguard Worker {
174*cfb92d14SAndroid Build Coastguard Worker ExitNow(error = OT_ERROR_INVALID_COMMAND);
175*cfb92d14SAndroid Build Coastguard Worker }
176*cfb92d14SAndroid Build Coastguard Worker
177*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_CONFIG_BACKBONE_ROUTER_DUA_NDPROXYING_ENABLE && OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE
178*cfb92d14SAndroid Build Coastguard Worker /**
179*cfb92d14SAndroid Build Coastguard Worker * @cli bbr mgmt dua
180*cfb92d14SAndroid Build Coastguard Worker * @code
181*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt dua 1 2f7c235e5025a2fd
182*cfb92d14SAndroid Build Coastguard Worker * Done
183*cfb92d14SAndroid Build Coastguard Worker * @endcode
184*cfb92d14SAndroid Build Coastguard Worker * @code
185*cfb92d14SAndroid Build Coastguard Worker * bbr mgmt dua 160
186*cfb92d14SAndroid Build Coastguard Worker * Done
187*cfb92d14SAndroid Build Coastguard Worker * @endcode
188*cfb92d14SAndroid Build Coastguard Worker * @cparam bbr mgmt dua @ca{status|coap-code} [@ca{meshLocalIid}]
189*cfb92d14SAndroid Build Coastguard Worker * For `status` or `coap-code`, use:
190*cfb92d14SAndroid Build Coastguard Worker * * 0: ST_DUA_SUCCESS
191*cfb92d14SAndroid Build Coastguard Worker * * 1: ST_DUA_REREGISTER
192*cfb92d14SAndroid Build Coastguard Worker * * 2: ST_DUA_INVALID
193*cfb92d14SAndroid Build Coastguard Worker * * 3: ST_DUA_DUPLICATE
194*cfb92d14SAndroid Build Coastguard Worker * * 4: ST_DUA_NO_RESOURCES
195*cfb92d14SAndroid Build Coastguard Worker * * 5: ST_DUA_BBR_NOT_PRIMARY
196*cfb92d14SAndroid Build Coastguard Worker * * 6: ST_DUA_GENERAL_FAILURE
197*cfb92d14SAndroid Build Coastguard Worker * * 160: COAP code 5.00
198*cfb92d14SAndroid Build Coastguard Worker * @par
199*cfb92d14SAndroid Build Coastguard Worker * With the `meshLocalIid` included, this command configures the response status
200*cfb92d14SAndroid Build Coastguard Worker * for the next DUA registration. Without `meshLocalIid`, respond to the next
201*cfb92d14SAndroid Build Coastguard Worker * DUA.req with the specified `status` or `coap-code`.
202*cfb92d14SAndroid Build Coastguard Worker * @par
203*cfb92d14SAndroid Build Coastguard Worker * Available when `OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE` is enabled.
204*cfb92d14SAndroid Build Coastguard Worker * @sa otBackboneRouterConfigNextDuaRegistrationResponse
205*cfb92d14SAndroid Build Coastguard Worker */
206*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0] == "dua")
207*cfb92d14SAndroid Build Coastguard Worker {
208*cfb92d14SAndroid Build Coastguard Worker uint8_t status;
209*cfb92d14SAndroid Build Coastguard Worker otIp6InterfaceIdentifier *mlIid = nullptr;
210*cfb92d14SAndroid Build Coastguard Worker otIp6InterfaceIdentifier iid;
211*cfb92d14SAndroid Build Coastguard Worker
212*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = aArgs[1].ParseAsUint8(status));
213*cfb92d14SAndroid Build Coastguard Worker
214*cfb92d14SAndroid Build Coastguard Worker if (!aArgs[2].IsEmpty())
215*cfb92d14SAndroid Build Coastguard Worker {
216*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = aArgs[2].ParseAsHexString(iid.mFields.m8));
217*cfb92d14SAndroid Build Coastguard Worker mlIid = &iid;
218*cfb92d14SAndroid Build Coastguard Worker VerifyOrExit(aArgs[3].IsEmpty(), error = OT_ERROR_INVALID_ARGS);
219*cfb92d14SAndroid Build Coastguard Worker }
220*cfb92d14SAndroid Build Coastguard Worker
221*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterConfigNextDuaRegistrationResponse(GetInstancePtr(), mlIid, status);
222*cfb92d14SAndroid Build Coastguard Worker ExitNow();
223*cfb92d14SAndroid Build Coastguard Worker }
224*cfb92d14SAndroid Build Coastguard Worker #endif // OPENTHREAD_CONFIG_BACKBONE_ROUTER_DUA_NDPROXYING_ENABLE && OPENTHREAD_CONFIG_REFERENCE_DEVICE_ENABLE
225*cfb92d14SAndroid Build Coastguard Worker
226*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_CONFIG_BACKBONE_ROUTER_MULTICAST_ROUTING_ENABLE
227*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0] == "mlr")
228*cfb92d14SAndroid Build Coastguard Worker {
229*cfb92d14SAndroid Build Coastguard Worker error = Process<Cmd("mlr")>(aArgs + 1);
230*cfb92d14SAndroid Build Coastguard Worker ExitNow();
231*cfb92d14SAndroid Build Coastguard Worker }
232*cfb92d14SAndroid Build Coastguard Worker #endif
233*cfb92d14SAndroid Build Coastguard Worker
234*cfb92d14SAndroid Build Coastguard Worker exit:
235*cfb92d14SAndroid Build Coastguard Worker return error;
236*cfb92d14SAndroid Build Coastguard Worker }
237*cfb92d14SAndroid Build Coastguard Worker
238*cfb92d14SAndroid Build Coastguard Worker /**
239*cfb92d14SAndroid Build Coastguard Worker * @cli bbr enable
240*cfb92d14SAndroid Build Coastguard Worker * @code
241*cfb92d14SAndroid Build Coastguard Worker * bbr enable
242*cfb92d14SAndroid Build Coastguard Worker * Done
243*cfb92d14SAndroid Build Coastguard Worker * @endcode
244*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
245*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterSetEnabled
246*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])247*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("enable")>(Arg aArgs[])
248*cfb92d14SAndroid Build Coastguard Worker {
249*cfb92d14SAndroid Build Coastguard Worker OT_UNUSED_VARIABLE(aArgs);
250*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterSetEnabled(GetInstancePtr(), true);
251*cfb92d14SAndroid Build Coastguard Worker
252*cfb92d14SAndroid Build Coastguard Worker return OT_ERROR_NONE;
253*cfb92d14SAndroid Build Coastguard Worker }
254*cfb92d14SAndroid Build Coastguard Worker
255*cfb92d14SAndroid Build Coastguard Worker /**
256*cfb92d14SAndroid Build Coastguard Worker * @cli bbr disable
257*cfb92d14SAndroid Build Coastguard Worker * @code
258*cfb92d14SAndroid Build Coastguard Worker * bbr disable
259*cfb92d14SAndroid Build Coastguard Worker * Done
260*cfb92d14SAndroid Build Coastguard Worker * @endcode
261*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
262*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterSetEnabled
263*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])264*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("disable")>(Arg aArgs[])
265*cfb92d14SAndroid Build Coastguard Worker {
266*cfb92d14SAndroid Build Coastguard Worker OT_UNUSED_VARIABLE(aArgs);
267*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterSetEnabled(GetInstancePtr(), false);
268*cfb92d14SAndroid Build Coastguard Worker
269*cfb92d14SAndroid Build Coastguard Worker return OT_ERROR_NONE;
270*cfb92d14SAndroid Build Coastguard Worker }
271*cfb92d14SAndroid Build Coastguard Worker
272*cfb92d14SAndroid Build Coastguard Worker /**
273*cfb92d14SAndroid Build Coastguard Worker * @cli bbr jitter (get,set)
274*cfb92d14SAndroid Build Coastguard Worker * @code
275*cfb92d14SAndroid Build Coastguard Worker * bbr jitter
276*cfb92d14SAndroid Build Coastguard Worker * 20
277*cfb92d14SAndroid Build Coastguard Worker * Done
278*cfb92d14SAndroid Build Coastguard Worker * @endcode
279*cfb92d14SAndroid Build Coastguard Worker * @code
280*cfb92d14SAndroid Build Coastguard Worker * bbr jitter 10
281*cfb92d14SAndroid Build Coastguard Worker * Done
282*cfb92d14SAndroid Build Coastguard Worker * @endcode
283*cfb92d14SAndroid Build Coastguard Worker * @cparam bbr jitter [@ca{jitter}]
284*cfb92d14SAndroid Build Coastguard Worker * @par
285*cfb92d14SAndroid Build Coastguard Worker * Gets or sets jitter (in seconds) for Backbone Router registration.
286*cfb92d14SAndroid Build Coastguard Worker * @par
287*cfb92d14SAndroid Build Coastguard Worker * Available when `OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE` is enabled.
288*cfb92d14SAndroid Build Coastguard Worker * @sa otBackboneRouterGetRegistrationJitter
289*cfb92d14SAndroid Build Coastguard Worker * @sa otBackboneRouterSetRegistrationJitter
290*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])291*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("jitter")>(Arg aArgs[])
292*cfb92d14SAndroid Build Coastguard Worker {
293*cfb92d14SAndroid Build Coastguard Worker return ProcessGetSet(aArgs, otBackboneRouterGetRegistrationJitter, otBackboneRouterSetRegistrationJitter);
294*cfb92d14SAndroid Build Coastguard Worker }
295*cfb92d14SAndroid Build Coastguard Worker
296*cfb92d14SAndroid Build Coastguard Worker /**
297*cfb92d14SAndroid Build Coastguard Worker * @cli bbr register
298*cfb92d14SAndroid Build Coastguard Worker * @code
299*cfb92d14SAndroid Build Coastguard Worker * bbr register
300*cfb92d14SAndroid Build Coastguard Worker * Done
301*cfb92d14SAndroid Build Coastguard Worker * @endcode
302*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
303*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterRegister
304*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])305*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("register")>(Arg aArgs[])
306*cfb92d14SAndroid Build Coastguard Worker {
307*cfb92d14SAndroid Build Coastguard Worker OT_UNUSED_VARIABLE(aArgs);
308*cfb92d14SAndroid Build Coastguard Worker
309*cfb92d14SAndroid Build Coastguard Worker return otBackboneRouterRegister(GetInstancePtr());
310*cfb92d14SAndroid Build Coastguard Worker }
311*cfb92d14SAndroid Build Coastguard Worker
312*cfb92d14SAndroid Build Coastguard Worker /**
313*cfb92d14SAndroid Build Coastguard Worker * @cli bbr state
314*cfb92d14SAndroid Build Coastguard Worker * @code
315*cfb92d14SAndroid Build Coastguard Worker * bbr state
316*cfb92d14SAndroid Build Coastguard Worker * Disabled
317*cfb92d14SAndroid Build Coastguard Worker * Done
318*cfb92d14SAndroid Build Coastguard Worker * @endcode
319*cfb92d14SAndroid Build Coastguard Worker * @code
320*cfb92d14SAndroid Build Coastguard Worker * bbr state
321*cfb92d14SAndroid Build Coastguard Worker * Primary
322*cfb92d14SAndroid Build Coastguard Worker * Done
323*cfb92d14SAndroid Build Coastguard Worker * @endcode
324*cfb92d14SAndroid Build Coastguard Worker * @code
325*cfb92d14SAndroid Build Coastguard Worker * bbr state
326*cfb92d14SAndroid Build Coastguard Worker * Secondary
327*cfb92d14SAndroid Build Coastguard Worker * Done
328*cfb92d14SAndroid Build Coastguard Worker * @endcode
329*cfb92d14SAndroid Build Coastguard Worker * @par
330*cfb92d14SAndroid Build Coastguard Worker * Available when `OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE` is enabled.
331*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
332*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterGetState
333*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])334*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("state")>(Arg aArgs[])
335*cfb92d14SAndroid Build Coastguard Worker
336*cfb92d14SAndroid Build Coastguard Worker {
337*cfb92d14SAndroid Build Coastguard Worker static const char *const kStateStrings[] = {
338*cfb92d14SAndroid Build Coastguard Worker "Disabled", // (0) OT_BACKBONE_ROUTER_STATE_DISABLED
339*cfb92d14SAndroid Build Coastguard Worker "Secondary", // (1) OT_BACKBONE_ROUTER_STATE_SECONDARY
340*cfb92d14SAndroid Build Coastguard Worker "Primary", // (2) OT_BACKBONE_ROUTER_STATE_PRIMARY
341*cfb92d14SAndroid Build Coastguard Worker };
342*cfb92d14SAndroid Build Coastguard Worker
343*cfb92d14SAndroid Build Coastguard Worker static_assert(0 == OT_BACKBONE_ROUTER_STATE_DISABLED, "OT_BACKBONE_ROUTER_STATE_DISABLED value is incorrect");
344*cfb92d14SAndroid Build Coastguard Worker static_assert(1 == OT_BACKBONE_ROUTER_STATE_SECONDARY, "OT_BACKBONE_ROUTER_STATE_SECONDARY value is incorrect");
345*cfb92d14SAndroid Build Coastguard Worker static_assert(2 == OT_BACKBONE_ROUTER_STATE_PRIMARY, "OT_BACKBONE_ROUTER_STATE_PRIMARY value is incorrect");
346*cfb92d14SAndroid Build Coastguard Worker
347*cfb92d14SAndroid Build Coastguard Worker OT_UNUSED_VARIABLE(aArgs);
348*cfb92d14SAndroid Build Coastguard Worker
349*cfb92d14SAndroid Build Coastguard Worker OutputLine("%s", Stringify(otBackboneRouterGetState(GetInstancePtr()), kStateStrings));
350*cfb92d14SAndroid Build Coastguard Worker
351*cfb92d14SAndroid Build Coastguard Worker return OT_ERROR_NONE;
352*cfb92d14SAndroid Build Coastguard Worker }
353*cfb92d14SAndroid Build Coastguard Worker
354*cfb92d14SAndroid Build Coastguard Worker /**
355*cfb92d14SAndroid Build Coastguard Worker * @cli bbr config
356*cfb92d14SAndroid Build Coastguard Worker * @code
357*cfb92d14SAndroid Build Coastguard Worker * bbr config
358*cfb92d14SAndroid Build Coastguard Worker * seqno: 10
359*cfb92d14SAndroid Build Coastguard Worker * delay: 120 secs
360*cfb92d14SAndroid Build Coastguard Worker * timeout: 300 secs
361*cfb92d14SAndroid Build Coastguard Worker * Done
362*cfb92d14SAndroid Build Coastguard Worker * @endcode
363*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
364*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterGetConfig
365*cfb92d14SAndroid Build Coastguard Worker */
Process(Arg aArgs[])366*cfb92d14SAndroid Build Coastguard Worker template <> otError Bbr::Process<Cmd("config")>(Arg aArgs[])
367*cfb92d14SAndroid Build Coastguard Worker {
368*cfb92d14SAndroid Build Coastguard Worker otError error = OT_ERROR_NONE;
369*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterConfig config;
370*cfb92d14SAndroid Build Coastguard Worker
371*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterGetConfig(GetInstancePtr(), &config);
372*cfb92d14SAndroid Build Coastguard Worker
373*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0].IsEmpty())
374*cfb92d14SAndroid Build Coastguard Worker {
375*cfb92d14SAndroid Build Coastguard Worker OutputConfig(config);
376*cfb92d14SAndroid Build Coastguard Worker }
377*cfb92d14SAndroid Build Coastguard Worker else
378*cfb92d14SAndroid Build Coastguard Worker {
379*cfb92d14SAndroid Build Coastguard Worker // Set local Backbone Router configuration.
380*cfb92d14SAndroid Build Coastguard Worker /**
381*cfb92d14SAndroid Build Coastguard Worker * @cli bbr config (set)
382*cfb92d14SAndroid Build Coastguard Worker * @code
383*cfb92d14SAndroid Build Coastguard Worker * bbr config seqno 20 delay 30
384*cfb92d14SAndroid Build Coastguard Worker * Done
385*cfb92d14SAndroid Build Coastguard Worker * @endcode
386*cfb92d14SAndroid Build Coastguard Worker * @cparam bbr config [seqno @ca{seqno}] [delay @ca{delay}] [timeout @ca{timeout}]
387*cfb92d14SAndroid Build Coastguard Worker * @par
388*cfb92d14SAndroid Build Coastguard Worker * `bbr register` should be issued explicitly to register Backbone Router service to Leader
389*cfb92d14SAndroid Build Coastguard Worker * for Secondary Backbone Router.
390*cfb92d14SAndroid Build Coastguard Worker * @par api_copy
391*cfb92d14SAndroid Build Coastguard Worker * #otBackboneRouterSetConfig
392*cfb92d14SAndroid Build Coastguard Worker */
393*cfb92d14SAndroid Build Coastguard Worker for (Arg *arg = &aArgs[0]; !arg->IsEmpty(); arg++)
394*cfb92d14SAndroid Build Coastguard Worker {
395*cfb92d14SAndroid Build Coastguard Worker if (*arg == "seqno")
396*cfb92d14SAndroid Build Coastguard Worker {
397*cfb92d14SAndroid Build Coastguard Worker arg++;
398*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = arg->ParseAsUint8(config.mSequenceNumber));
399*cfb92d14SAndroid Build Coastguard Worker }
400*cfb92d14SAndroid Build Coastguard Worker else if (*arg == "delay")
401*cfb92d14SAndroid Build Coastguard Worker {
402*cfb92d14SAndroid Build Coastguard Worker arg++;
403*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = arg->ParseAsUint16(config.mReregistrationDelay));
404*cfb92d14SAndroid Build Coastguard Worker }
405*cfb92d14SAndroid Build Coastguard Worker else if (*arg == "timeout")
406*cfb92d14SAndroid Build Coastguard Worker {
407*cfb92d14SAndroid Build Coastguard Worker arg++;
408*cfb92d14SAndroid Build Coastguard Worker SuccessOrExit(error = arg->ParseAsUint32(config.mMlrTimeout));
409*cfb92d14SAndroid Build Coastguard Worker }
410*cfb92d14SAndroid Build Coastguard Worker else
411*cfb92d14SAndroid Build Coastguard Worker {
412*cfb92d14SAndroid Build Coastguard Worker ExitNow(error = OT_ERROR_INVALID_ARGS);
413*cfb92d14SAndroid Build Coastguard Worker }
414*cfb92d14SAndroid Build Coastguard Worker }
415*cfb92d14SAndroid Build Coastguard Worker
416*cfb92d14SAndroid Build Coastguard Worker error = otBackboneRouterSetConfig(GetInstancePtr(), &config);
417*cfb92d14SAndroid Build Coastguard Worker }
418*cfb92d14SAndroid Build Coastguard Worker
419*cfb92d14SAndroid Build Coastguard Worker exit:
420*cfb92d14SAndroid Build Coastguard Worker return error;
421*cfb92d14SAndroid Build Coastguard Worker }
422*cfb92d14SAndroid Build Coastguard Worker
423*cfb92d14SAndroid Build Coastguard Worker #endif // OPENTHREAD_FTD && OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE
424*cfb92d14SAndroid Build Coastguard Worker
Process(Arg aArgs[])425*cfb92d14SAndroid Build Coastguard Worker otError Bbr::Process(Arg aArgs[])
426*cfb92d14SAndroid Build Coastguard Worker {
427*cfb92d14SAndroid Build Coastguard Worker #define CmdEntry(aCommandString) {aCommandString, &Bbr::Process<Cmd(aCommandString)>}
428*cfb92d14SAndroid Build Coastguard Worker
429*cfb92d14SAndroid Build Coastguard Worker otError error = OT_ERROR_INVALID_COMMAND;
430*cfb92d14SAndroid Build Coastguard Worker
431*cfb92d14SAndroid Build Coastguard Worker /**
432*cfb92d14SAndroid Build Coastguard Worker * @cli bbr
433*cfb92d14SAndroid Build Coastguard Worker * @code
434*cfb92d14SAndroid Build Coastguard Worker * bbr
435*cfb92d14SAndroid Build Coastguard Worker * BBR Primary:
436*cfb92d14SAndroid Build Coastguard Worker * server16: 0xE400
437*cfb92d14SAndroid Build Coastguard Worker * seqno: 10
438*cfb92d14SAndroid Build Coastguard Worker * delay: 120 secs
439*cfb92d14SAndroid Build Coastguard Worker * timeout: 300 secs
440*cfb92d14SAndroid Build Coastguard Worker * Done
441*cfb92d14SAndroid Build Coastguard Worker * @endcode
442*cfb92d14SAndroid Build Coastguard Worker * @code
443*cfb92d14SAndroid Build Coastguard Worker * bbr
444*cfb92d14SAndroid Build Coastguard Worker * BBR Primary: None
445*cfb92d14SAndroid Build Coastguard Worker * Done
446*cfb92d14SAndroid Build Coastguard Worker * @endcode
447*cfb92d14SAndroid Build Coastguard Worker * @par
448*cfb92d14SAndroid Build Coastguard Worker * Returns the current Primary Backbone Router information for the Thread device.
449*cfb92d14SAndroid Build Coastguard Worker */
450*cfb92d14SAndroid Build Coastguard Worker if (aArgs[0].IsEmpty())
451*cfb92d14SAndroid Build Coastguard Worker {
452*cfb92d14SAndroid Build Coastguard Worker otBackboneRouterConfig config;
453*cfb92d14SAndroid Build Coastguard Worker
454*cfb92d14SAndroid Build Coastguard Worker OutputFormat("BBR Primary:");
455*cfb92d14SAndroid Build Coastguard Worker
456*cfb92d14SAndroid Build Coastguard Worker if (otBackboneRouterGetPrimary(GetInstancePtr(), &config) == OT_ERROR_NONE)
457*cfb92d14SAndroid Build Coastguard Worker {
458*cfb92d14SAndroid Build Coastguard Worker OutputNewLine();
459*cfb92d14SAndroid Build Coastguard Worker OutputLine("server16: 0x%04X", config.mServer16);
460*cfb92d14SAndroid Build Coastguard Worker OutputConfig(config);
461*cfb92d14SAndroid Build Coastguard Worker }
462*cfb92d14SAndroid Build Coastguard Worker else
463*cfb92d14SAndroid Build Coastguard Worker {
464*cfb92d14SAndroid Build Coastguard Worker OutputLine(" None");
465*cfb92d14SAndroid Build Coastguard Worker }
466*cfb92d14SAndroid Build Coastguard Worker
467*cfb92d14SAndroid Build Coastguard Worker error = OT_ERROR_NONE;
468*cfb92d14SAndroid Build Coastguard Worker ExitNow();
469*cfb92d14SAndroid Build Coastguard Worker }
470*cfb92d14SAndroid Build Coastguard Worker
471*cfb92d14SAndroid Build Coastguard Worker #if OPENTHREAD_FTD && OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE
472*cfb92d14SAndroid Build Coastguard Worker {
473*cfb92d14SAndroid Build Coastguard Worker static constexpr Command kCommands[] = {
474*cfb92d14SAndroid Build Coastguard Worker CmdEntry("config"), CmdEntry("disable"), CmdEntry("enable"), CmdEntry("jitter"),
475*cfb92d14SAndroid Build Coastguard Worker CmdEntry("mgmt"), CmdEntry("register"), CmdEntry("state"),
476*cfb92d14SAndroid Build Coastguard Worker };
477*cfb92d14SAndroid Build Coastguard Worker
478*cfb92d14SAndroid Build Coastguard Worker #undef CmdEntry
479*cfb92d14SAndroid Build Coastguard Worker
480*cfb92d14SAndroid Build Coastguard Worker static_assert(BinarySearch::IsSorted(kCommands), "kCommands is not sorted");
481*cfb92d14SAndroid Build Coastguard Worker
482*cfb92d14SAndroid Build Coastguard Worker const Command *command;
483*cfb92d14SAndroid Build Coastguard Worker
484*cfb92d14SAndroid Build Coastguard Worker command = BinarySearch::Find(aArgs[0].GetCString(), kCommands);
485*cfb92d14SAndroid Build Coastguard Worker VerifyOrExit(command != nullptr);
486*cfb92d14SAndroid Build Coastguard Worker
487*cfb92d14SAndroid Build Coastguard Worker error = (this->*command->mHandler)(aArgs + 1);
488*cfb92d14SAndroid Build Coastguard Worker }
489*cfb92d14SAndroid Build Coastguard Worker #endif // #if OPENTHREAD_FTD && OPENTHREAD_CONFIG_BACKBONE_ROUTER_ENABLE
490*cfb92d14SAndroid Build Coastguard Worker
491*cfb92d14SAndroid Build Coastguard Worker exit:
492*cfb92d14SAndroid Build Coastguard Worker return error;
493*cfb92d14SAndroid Build Coastguard Worker }
494*cfb92d14SAndroid Build Coastguard Worker
495*cfb92d14SAndroid Build Coastguard Worker } // namespace Cli
496*cfb92d14SAndroid Build Coastguard Worker } // namespace ot
497*cfb92d14SAndroid Build Coastguard Worker
498*cfb92d14SAndroid Build Coastguard Worker #endif // #if (OPENTHREAD_CONFIG_THREAD_VERSION >= OT_THREAD_VERSION_1_2)
499