Skip to content

Commit

Permalink
doc: Update MGMTd documentation
Browse files Browse the repository at this point in the history
This commit updates the existing MGMTd user and developer documentations
with details regarding the new support for retrieving operational
data via the MGMT Front-end interface.

Signed-off-by: Pushpasis Sarkar <[email protected]>
  • Loading branch information
pushpasis committed Sep 27, 2023
1 parent 30f2349 commit 136ec4c
Show file tree
Hide file tree
Showing 2 changed files with 131 additions and 12 deletions.
108 changes: 105 additions & 3 deletions doc/developer/mgmtd-dev.rst
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ has been converted to it, but in the future RESTCONF and NETCONF servers can
easily be added as *front-ends* to mgmtd to support those protocols as well.


Converting A Daemon to MGMTD
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Converting A Daemon to MGMTD Client
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

A daemon must first be transitioned to the new *northbound* interface if that
has not already been done (see `this northbound conversion documentation
Expand All @@ -57,11 +57,13 @@ Front-End Interface:
3. Add CLI handler file[s] to ``mgmtd/subdir.am`` (e.g., ``staticd/static_vty.c``)
4. [if needed] Exclude (#ifndef) non-configuration CLI handlers from CLI source
file (e.g., inside ``staticd/static_vty.c``)
5. Redirect MGMT Frontend Client debug CLI handlers to the daemon.

Back-End Interface:

5. Add XPATHs mappings to a couple arrays to direct ``mgmtd`` at your daemon in
6. Add XPATHs mappings to a couple arrays to direct ``mgmtd`` at your daemon in
``mgmtd/mgmt_be_adapter.c``
7. Redirect MGMT Backend Client debug CLI handlers to the daemon.


Add YANG and CLI into MGMTD
Expand Down Expand Up @@ -140,6 +142,29 @@ handlers. For example:
}
Redirect MGMT Frontend Debug CLI handlers to the Daemon
-------------------------------------------------------

In order to debug the MGMT frontend client library operations on the client
daemon MGMT provides 'debug mgmt frontend' CLI that needs to notify the
command on the new client daemon as well. To do that the daemon needs to be
added to 'VTYSH_MGMT_FE' list in the file 'vtysh/vtysh.h' as shown below.

.. code-block:: c
#define VTYSH_MGMT_FE VTYSH_MGMT | VTYSH_XXXX
And then the daemon needs to call mgmt_fe_client_lib_vty_init() from it's
daemon-specifc VTY initializing routine as show below.

.. code-block:: c
void daemon_vty_init(void)
{
...
mgmt_fe_client_lib_vty_init();
}
Add Back-End XPATH mappings
---------------------------
Expand Down Expand Up @@ -202,6 +227,83 @@ Below are the strings added for staticd support:
#endif
};
The abobe example adds 'staticd' as a configuration validator for certain xpaths
under the overall data subtree in 'running' and 'candidate' datastores.
However, sometimes daemons may also need to provide operational data and state
via the MGMT frontend interface. Below is an example how the zebra daemon
can add support for retrieveing oprational data for the data subtree it
represents under the entire data tree in the operational datastore. Please note
that zebra here only takes responsibility of providing real-time operational
values of the dpecified data portions,. It does not accept any responsibility
of validating any data under these data portions, by specifying only
'MGMT_SUBSCR_OPER_OWN' for the '.subsribed' value for the corresponding Xpath
map entry.

.. code-block:: c
static struct mgmt_be_client_xpath zebra_xpaths[] = {
{
.xpath = "/frr-zebra:zebra/*",
.subscribed = MGMT_SUBSCR_OPER_OWN,
},
{
.xpath = "/frr-vrf:lib/vrf[name='*']/frr-zebra:zebra/*",
.subscribed = MGMT_SUBSCR_OPER_OWN,
},
};
static struct mgmt_be_client_xpath_map
mgmt_client_xpaths[MGMTD_BE_CLIENT_ID_MAX] = {
...
[MGMTD_BE_CLIENT_ID_ZEBRA] = {zebra_xpaths,
array_size(zebra_xpaths)},
...
};
However a daemon can certainly support both accepting configurational
values for a data portion (via one of the config datastsores), as well as
providing the real-time operational value of the same data portion
(via the 'operational' datastore). In such case it should combine both
'MGMT_SUBSCR_VALIDATE_CFG' and 'MGMT_SUBSCR_OPER_OWN' values for the
'.subscribed' attribute in the corresponding Xpath map entry. Below is
a variation of the zebra Xpath mappings given above that combines both.

.. code-block:: c
static struct mgmt_be_client_xpath zebra_xpaths[] = {
{
.xpath = "/frr-zebra:zebra/*",
.subscribed = MGMT_SUBSCR_VALIDATE_CFG | MGMT_SUBSCR_OPER_OWN,
},
{
.xpath = "/frr-vrf:lib/vrf[name='*']/frr-zebra:zebra/*",
.subscribed = MGMT_SUBSCR_OPER_OWN,
},
};
Redirect MGMT Backend Debug CLI handlers to the Daemon
------------------------------------------------------

In order to debug the MGMT backend client library operations on the client
daemon MGMT provides 'debug mgmt backend' CLI that needs to notify the
command on the new client daemon as well. To do that the daemon needs to be
added to 'VTYSH_MGMT_BE' list in the file 'vtysh/vtysh.h' as shown below.

.. code-block:: c
#define VTYSH_MGMT_BE VTYSH_STATICD | VTYSH_ZEBRA
And then the daemon needs to call mgmt_be_client_lib_vty_init() from it's
daemon-specifc VTY initializing routine as show below.

.. code-block:: c
void daemon_vty_init(void)
{
...
mgmt_be_client_lib_vty_init();
}
MGMTD Internals
^^^^^^^^^^^^^^^
Expand Down
35 changes: 26 additions & 9 deletions doc/user/mgmtd.rst
Original file line number Diff line number Diff line change
Expand Up @@ -347,19 +347,23 @@ MGMT Show commands
.. clicmd:: show mgmt get-config [candidate|running] XPATH

This command uses the GET_CONFIG operation over the MGMT Frontend interface and
returns the xpaths and values of the nodes of the subtree pointed by the <xpath>.
returns the xpaths and values of the nodes of the subtree pointed by the <xpath>
from the specifed datastore. Currenlty only supported values for datastore are
'candidate' and 'running'.

.. clicmd:: show mgmt get-data [candidate|operation|running] XPATH
.. clicmd:: show mgmt get-data operational XPATH

This command uses the GET_DATA operation over the MGMT Frontend interface and
returns the xpaths and values of the nodes of the subtree pointed by the <xpath>.
Currenlty supported values for 'candidate' and 'running' only
('operational' shall be supported in future soon).
returns the xpaths and values of the nodes of the subtree pointed by the <xpath>
from a specified datastore. Currenlty only supported values for datastore is
'operational'. GET-DATA operation on 'running' and 'candidate' are not allowed
(use the 'show mgmt get-config [candidate|running]' instead).

.. clicmd:: show mgmt database-contents [candidate|operation|running] [xpath WORD] [file WORD] json|xml
.. clicmd:: show mgmt database-contents [candidate|running] [xpath WORD] [file WORD] json|xml

This command dumps the subtree pointed by the xpath in JSON or XML format. If filepath is
not present then the tree will be printed on the shell.
This command dumps the subtree pointed by the xpath from a specifed datastore
in JSON or XML format. If filepath is not present then the tree will be printed on the
shell. Currenlty only supported values for datastore are 'candidate' and 'running'.

.. clicmd:: show mgmt commit-history

Expand Down Expand Up @@ -395,7 +399,7 @@ The following debug commands enable debugging within the management daemon:
MGMT Client debug commands
==========================

The following debug commands enable debugging within the management front and
The following debug commands enable debugging within the management frontend and
backend clients:

.. clicmd:: [no] debug mgmt client backend
Expand All @@ -407,3 +411,16 @@ backend clients:

Enable[/Disable] debugging messages related to frontend operations inside the
frontend mgmtd clients.


MGMT Common debug commands
==========================

The following debug commands enable debugging of some common operations that
are running on the management daemon as well as all management frontend and
backend clients:

.. clicmd:: [no] debug mgmt utilities

Enable[/Disable] debugging messages related to common utility operations on the
mamagemnt daemon as well as all management frontend and backend clients.

0 comments on commit 136ec4c

Please sign in to comment.