sysrepo 3.6.11
YANG-based system repository for all-around configuration management.
Loading...
Searching...
No Matches
sysrepo.h
Go to the documentation of this file.
1
16
17#ifndef _SYSREPO_H
18#define _SYSREPO_H
19
20#include <stdint.h>
21#include <stdlib.h>
22#include <sys/types.h>
23#include <time.h>
24#include <unistd.h>
25
26#include <libyang/libyang.h>
27
28#include "sysrepo_types.h"
29
30#ifdef __cplusplus
31extern "C" {
32#endif
33
35// Logging API
37
42
49const char *sr_strerror(int err_code);
50
62
69
86void sr_log_syslog(const char *app_name, sr_log_level_t log_level);
87
94
101void sr_log_set_cb(sr_log_cb log_callback);
102
104
106// Connection / Session Management
108
113
125
138
150const struct ly_ctx *sr_acquire_context(sr_conn_ctx_t *conn);
151
161const struct ly_ctx *sr_session_acquire_context(sr_session_ctx_t *session);
162
171
180
189
198int sr_get_plugins(sr_conn_ctx_t *conn, const char ***ds_plugins, const char ***ntf_plugins);
199
205uid_t sr_get_su_uid(void);
206
216int sr_session_start(sr_conn_ctx_t *conn, const sr_datastore_t datastore, sr_session_ctx_t **session);
217
231
242
255
266
274
290int sr_session_set_orig_name(sr_session_ctx_t *session, const char *orig_name);
291
299
311int sr_session_push_orig_data(sr_session_ctx_t *session, uint32_t size, const void *data);
312
319
329int sr_session_get_orig_data(sr_session_ctx_t *session, uint32_t idx, uint32_t *size, const void **data);
330
341int sr_session_get_error(sr_session_ctx_t *session, const sr_error_info_t **error_info);
342
351
370int sr_session_set_error(sr_session_ctx_t *session, const char *err_format_name, sr_error_t err_code,
371 const char *err_msg_format, ...);
372
376int sr_session_set_error_message(sr_session_ctx_t *session, const char *format, ...);
377
381int sr_session_set_error_format(sr_session_ctx_t *session, const char *error_format);
382
393int sr_session_push_error_data(sr_session_ctx_t *session, uint32_t size, const void *data);
394
407int sr_get_error_data(const sr_error_info_err_t *err, uint32_t idx, uint32_t *size, const void **data);
408
416
426int sr_session_set_user(sr_session_ctx_t *session, const char *user);
427
435
443
445
447// Schema Manipulation API
449
454
463const char *sr_get_repo_path(void);
464
470const char *sr_get_shm_path(void);
471
477const char *sr_get_shm_prefix(void);
478
490int sr_install_module(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs, const char **features);
491
501
526int sr_install_module2(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs, const char **features,
527 const sr_module_ds_t *module_ds, const char *owner, const char *group, mode_t perm, const char *data,
528 const char *data_path, LYD_FORMAT format);
529
543int sr_install_modules(sr_conn_ctx_t *conn, const char **schema_paths, const char *search_dirs,
544 const char ***features);
545
561int sr_install_modules2(sr_conn_ctx_t *conn, const sr_install_mod_t *modules, uint32_t module_count,
562 const char *search_dirs, const char *data, const char *data_path, LYD_FORMAT format);
563
574int sr_remove_module(sr_conn_ctx_t *conn, const char *module_name, int force);
575
586int sr_remove_modules(sr_conn_ctx_t *conn, const char **module_names, int force);
587
598int sr_update_module(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs);
599
610int sr_update_modules(sr_conn_ctx_t *conn, const char **schema_paths, const char *search_dirs);
611
620int sr_set_module_replay_support(sr_conn_ctx_t *conn, const char *module_name, int enable);
621
632int sr_get_module_replay_support(sr_conn_ctx_t *conn, const char *module_name, struct timespec *earliest_notif,
633 int *enabled);
634
646int sr_set_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, const char *owner,
647 const char *group, mode_t perm);
648
660int sr_get_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, char **owner, char **group,
661 mode_t *perm);
662
673int sr_check_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, int *read, int *write);
674
685int sr_enable_module_feature(sr_conn_ctx_t *conn, const char *module_name, const char *feature_name);
686
697int sr_disable_module_feature(sr_conn_ctx_t *conn, const char *module_name, const char *feature_name);
698
708int sr_get_module_info(sr_conn_ctx_t *conn, sr_data_t **sysrepo_data);
709
718int sr_is_module_internal(const struct lys_module *ly_mod);
719
721
723// Data Retrieval API (get / get-config functionality)
725
730
752int sr_get_item(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_val_t **value);
753
771int sr_get_items(sr_session_ctx_t *session, const char *xpath, uint32_t timeout_ms, const sr_get_options_t opts,
772 sr_val_t **values, size_t *value_cnt);
773
786int sr_session_acquire_data(sr_session_ctx_t *session, struct lyd_node *tree, sr_data_t **data);
787
798int sr_acquire_data(sr_conn_ctx_t *conn, struct lyd_node *tree, sr_data_t **data);
799
818int sr_get_subtree(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_data_t **subtree);
819
844int sr_get_data(sr_session_ctx_t *session, const char *xpath, uint32_t max_depth, uint32_t timeout_ms,
845 const sr_get_options_t opts, sr_data_t **data);
846
863int sr_get_node(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_data_t **node);
864
872
879
887void sr_free_values(sr_val_t *values, size_t count);
888
890
892// Data Manipulation API (edit-config functionality)
894
899
927int sr_set_item(sr_session_ctx_t *session, const char *path, const sr_val_t *value, const sr_edit_options_t opts);
928
944int sr_set_item_str(sr_session_ctx_t *session, const char *path, const char *value, const char *origin,
945 const sr_edit_options_t opts);
946
966int sr_delete_item(sr_session_ctx_t *session, const char *path, const sr_edit_options_t opts);
967
971int sr_oper_delete_item_str(sr_session_ctx_t *session, const char *path, const char *value, const sr_edit_options_t opts);
972
990int sr_discard_items(sr_session_ctx_t *session, const char *xpath);
991
1005int sr_delete_discard_items(sr_session_ctx_t *session, const char *xpath, const sr_edit_options_t opts);
1006
1033int sr_move_item(sr_session_ctx_t *session, const char *path, const sr_move_position_t position, const char *list_keys,
1034 const char *leaflist_value, const char *origin, const sr_edit_options_t opts);
1035
1050int sr_edit_batch(sr_session_ctx_t *session, const struct lyd_node *edit, const char *default_operation);
1051
1063int sr_validate(sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms);
1064
1081int sr_apply_changes(sr_session_ctx_t *session, uint32_t timeout_ms);
1082
1090
1099const struct lyd_node *sr_get_changes(sr_session_ctx_t *session);
1100
1108
1116int sr_discard_changes_xpath(sr_session_ctx_t *session, const char *xpath);
1117
1131int sr_replace_config(sr_session_ctx_t *session, const char *module_name, struct lyd_node *src_config,
1132 uint32_t timeout_ms);
1133
1151int sr_copy_config(sr_session_ctx_t *session, const char *module_name, sr_datastore_t src_datastore, uint32_t timeout_ms);
1152
1162int sr_discard_oper_changes(sr_conn_ctx_t *conn, sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms);
1163
1172int sr_get_oper_changes(sr_session_ctx_t *session, const char *module_name, sr_data_t **data);
1173
1187int sr_set_oper_changes_order(sr_session_ctx_t *session, const char *module_name, uint32_t order);
1188
1198int sr_get_oper_changes_order(sr_session_ctx_t *session, const char *module_name, uint32_t *order);
1199
1201
1203// Locking API
1205
1210
1227int sr_lock(sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms);
1228
1238int sr_unlock(sr_session_ctx_t *session, const char *module_name);
1239
1255int sr_get_lock(sr_conn_ctx_t *conn, sr_datastore_t datastore, const char *module_name, int *is_locked, uint32_t *id,
1256 struct timespec *timestamp);
1257
1259
1261// Subscription API
1263
1268
1279int sr_get_event_pipe(sr_subscription_ctx_t *subscription, int *event_pipe);
1280
1294 struct timespec *wake_up_in);
1295
1303
1312int sr_subscription_get_suspended(sr_subscription_ctx_t *subscription, uint32_t sub_id, int *suspended);
1313
1322int sr_subscription_suspend(sr_subscription_ctx_t *subscription, uint32_t sub_id);
1323
1332int sr_subscription_resume(sr_subscription_ctx_t *subscription, uint32_t sub_id);
1333
1347int sr_unsubscribe_sub(sr_subscription_ctx_t *subscription, uint32_t sub_id);
1348
1357
1365
1374
1384
1386
1388// Change Subscriptions API
1390
1395
1421int sr_module_change_set_order(sr_conn_ctx_t *conn, const char *module_name, sr_datastore_t ds, uint32_t priority);
1422
1434int sr_module_change_get_order(sr_conn_ctx_t *conn, const char *module_name, sr_datastore_t ds, uint32_t *priority);
1435
1455int sr_module_change_subscribe(sr_session_ctx_t *session, const char *module_name, const char *xpath,
1456 sr_module_change_cb callback, void *private_data, uint32_t priority, sr_subscr_options_t opts,
1457 sr_subscription_ctx_t **subscription);
1458
1470int sr_module_change_sub_get_info(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char **module_name,
1471 sr_datastore_t *ds, const char **xpath, uint32_t *filtered_out);
1472
1481int sr_module_change_sub_modify_xpath(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char *xpath);
1482
1498int sr_get_changes_iter(sr_session_ctx_t *session, const char *xpath, sr_change_iter_t **iter);
1499
1515int sr_dup_changes_iter(sr_session_ctx_t *session, const char *xpath, sr_change_iter_t **iter);
1516
1536 sr_val_t **old_value, sr_val_t **new_value);
1537
1561 const struct lyd_node **node, const char **prev_value, const char **prev_list, int *prev_dflt);
1562
1569
1577const struct lyd_node *sr_get_change_diff(sr_session_ctx_t *session);
1578
1580
1582// RPC (Remote Procedure Calls) and Action API
1584
1589
1605int sr_rpc_subscribe(sr_session_ctx_t *session, const char *xpath, sr_rpc_cb callback, void *private_data,
1606 uint32_t priority, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1607
1623int sr_rpc_subscribe_tree(sr_session_ctx_t *session, const char *xpath, sr_rpc_tree_cb callback,
1624 void *private_data, uint32_t priority, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1625
1645int sr_rpc_send(sr_session_ctx_t *session, const char *path, const sr_val_t *input, const size_t input_cnt,
1646 uint32_t timeout_ms, sr_val_t **output, size_t *output_cnt);
1647
1661int sr_rpc_send_tree(sr_session_ctx_t *session, struct lyd_node *input, uint32_t timeout_ms, sr_data_t **output);
1662
1664
1666// Notifications API
1668
1673
1691int sr_notif_subscribe(sr_session_ctx_t *session, const char *module_name, const char *xpath,
1692 const struct timespec *start_time, const struct timespec *stop_time, sr_event_notif_cb callback,
1693 void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1694
1712int sr_notif_subscribe_tree(sr_session_ctx_t *session, const char *module_name, const char *xpath,
1713 const struct timespec *start_time, const struct timespec *stop_time, sr_event_notif_tree_cb callback,
1714 void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1715
1736int sr_notif_send(sr_session_ctx_t *session, const char *path, const sr_val_t *values, const size_t values_cnt,
1737 uint32_t timeout_ms, int wait);
1738
1756int sr_notif_send_tree(sr_session_ctx_t *session, struct lyd_node *notif, uint32_t timeout_ms, int wait);
1757
1770int sr_notif_sub_get_info(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char **module_name,
1771 const char **xpath, struct timespec *start_time, struct timespec *stop_time, uint32_t *filtered_out);
1772
1782int sr_notif_sub_modify_xpath(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char *xpath);
1783
1793int sr_notif_sub_modify_stop_time(sr_subscription_ctx_t *subscription, uint32_t sub_id, const struct timespec *stop_time);
1794
1796
1798// Operational Data API
1800
1805
1834int sr_oper_get_subscribe(sr_session_ctx_t *session, const char *module_name, const char *path,
1835 sr_oper_get_items_cb callback, void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1836
1861int sr_oper_poll_subscribe(sr_session_ctx_t *session, const char *module_name, const char *path, uint32_t valid_ms,
1862 sr_subscr_options_t opts, sr_subscription_ctx_t **subscription);
1863
1865
1867// sysrepo-plugind Plugin API
1869
1874
1880#define SRP_INIT_CB "sr_plugin_init_cb"
1881
1887#define SRP_CLEANUP_CB "sr_plugin_cleanup_cb"
1888
1900void srplg_log_errinfo(sr_error_info_t **err_info, const char *plg_name, const char *err_format_name,
1901 sr_error_t err_code, const char *format, ...) _FORMAT_PRINTF(5, 6);
1902
1914int srplg_errinfo_push_error_data(sr_error_info_t *err_info, uint32_t size, const void *data);
1915
1922
1927#define SRPLG_LOG_ERR(plg_name, ...) srplg_log(plg_name, SR_LL_ERR, __VA_ARGS__)
1928
1935#define SRPLG_LOG_WRN(plg_name, ...) srplg_log(plg_name, SR_LL_WRN, __VA_ARGS__)
1936
1943#define SRPLG_LOG_INF(plg_name, ...) srplg_log(plg_name, SR_LL_INF, __VA_ARGS__)
1944
1951#define SRPLG_LOG_DBG(plg_name, ...) srplg_log(plg_name, SR_LL_DBG, __VA_ARGS__)
1952
1954
1964void srplg_log(const char *plg_name, sr_log_level_t ll, const char *format, ...) _FORMAT_PRINTF(3, 4);
1965
1966#ifdef __cplusplus
1967}
1968#endif
1969
1970#endif /* _SYSREPO_H */
int sr_module_change_set_order(sr_conn_ctx_t *conn, const char *module_name, sr_datastore_t ds, uint32_t priority)
Change the global priority of modules being notified about their changes. The default priority of eve...
int sr_module_change_sub_modify_xpath(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char *xpath)
Modify an existing change subscription by changing its XPath filter.
int sr_get_change_tree_next(sr_session_ctx_t *session, sr_change_iter_t *iter, sr_change_oper_t *operation, const struct lyd_node **node, const char **prev_value, const char **prev_list, int *prev_dflt)
Returns the next change from the provided iterator created by sr_get_changes_iter call....
sr_change_oper_t
Type of the operation made on an item, used by changeset retrieval in sr_get_change_next.
const struct lyd_node * sr_get_change_diff(sr_session_ctx_t *session)
Get the changes directly in the form of a diff in module-change callbacks. It cannot be used outside ...
int sr_get_changes_iter(sr_session_ctx_t *session, const char *xpath, sr_change_iter_t **iter)
Create an iterator for retrieving the changes (list of newly added / removed / modified nodes) in mod...
int sr_module_change_sub_get_info(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char **module_name, sr_datastore_t *ds, const char **xpath, uint32_t *filtered_out)
Get information about an existing change subscription.
int sr_get_change_next(sr_session_ctx_t *session, sr_change_iter_t *iter, sr_change_oper_t *operation, sr_val_t **old_value, sr_val_t **new_value)
Return the next change from the provided iterator created by sr_get_changes_iter call....
int sr_module_change_subscribe(sr_session_ctx_t *session, const char *module_name, const char *xpath, sr_module_change_cb callback, void *private_data, uint32_t priority, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Subscribe for changes made in the specified module.
struct sr_change_iter_s sr_change_iter_t
Iterator used for retrieval of a changeset using sr_get_changes_iter call.
int sr_module_change_get_order(sr_conn_ctx_t *conn, const char *module_name, sr_datastore_t ds, uint32_t *priority)
Get the current global priority of change subscriptions of a module.
int sr_dup_changes_iter(sr_session_ctx_t *session, const char *xpath, sr_change_iter_t **iter)
Create an iterator for retrieving the changes (list of newly added / removed / modified nodes) in mod...
int(* sr_module_change_cb)(sr_session_ctx_t *session, uint32_t sub_id, const char *module_name, const char *xpath, sr_event_t event, uint32_t operation_id, void *private_data)
Callback to be called on the event of changing datastore content of the specified module.
void sr_free_change_iter(sr_change_iter_t *iter)
Frees sr_change_iter_t iterator and all memory allocated within it.
int sr_session_set_orig_name(sr_session_ctx_t *session, const char *orig_name)
Set event originator name used for all events sent on this session. It can then be read from the impl...
int sr_session_set_error_message(sr_session_ctx_t *session, const char *format,...)
Deprecated, use sr_session_set_error().
int sr_session_switch_ds(sr_session_ctx_t *session, sr_datastore_t ds)
Change datastore which the session operates on. All subsequent calls will be issued on the chosen dat...
int sr_session_push_error_data(sr_session_ctx_t *session, uint32_t size, const void *data)
Push (add) another chunk of error data for a failed callback communicated back to the originator....
void sr_release_context(sr_conn_ctx_t *conn)
Release libyang context obtained from a session/connection.
void sr_session_release_context(sr_session_ctx_t *session)
Release libyang context obtained from a session/connection.
int sr_session_push_orig_data(sr_session_ctx_t *session, uint32_t size, const void *data)
Push (add) another chunk of event originator data used for all events sent on this session....
uid_t sr_get_su_uid(void)
Get the sysrepo SUPERUSER UID.
int sr_disconnect(sr_conn_ctx_t *conn)
Disconnect from the sysrepo datastore.
int sr_session_unsubscribe(sr_session_ctx_t *session)
Unsubscribe all subscriptions created by this session.
int sr_session_get_orig_data(sr_session_ctx_t *session, uint32_t idx, uint32_t *size, const void **data)
Get a specific chunk of event originator data in a callback.
const char * sr_session_get_orig_name(sr_session_ctx_t *session)
Get event originator name.
int sr_session_stop(sr_session_ctx_t *session)
Stop the session and releases resources tied to it.
int sr_connect(const sr_conn_options_t opts, sr_conn_ctx_t **conn)
Connects to the sysrepo datastore.
int sr_session_set_user(sr_session_ctx_t *session, const char *user)
Set the effective user of a session to a different one than the process owner.
int sr_session_start(sr_conn_ctx_t *conn, const sr_datastore_t datastore, sr_session_ctx_t **session)
Start a new session.
int sr_session_set_error(sr_session_ctx_t *session, const char *err_format_name, sr_error_t err_code, const char *err_msg_format,...)
Set an error for a failed callback communicated back to the originator. Does not print the message.
const struct ly_ctx * sr_session_acquire_context(sr_session_ctx_t *session)
Get the libyang context used by a connection. Can be used in an application for working with data and...
sr_datastore_t sr_session_get_ds(sr_session_ctx_t *session)
Learn the datastore a session operates on.
const struct ly_ctx * sr_acquire_context(sr_conn_ctx_t *conn)
Get the libyang context used by a connection. Can be used in an application for working with data and...
int sr_session_get_error(sr_session_ctx_t *session, const sr_error_info_t **error_info)
Retrieve information about the error that has occurred during the last operation executed within prov...
uint32_t sr_session_get_id(sr_session_ctx_t *session)
Return the assigned session ID of the sysrepo session.
int sr_get_error_data(const sr_error_info_err_t *err, uint32_t idx, uint32_t *size, const void **data)
Get a specific chunk of error data.
int sr_session_set_error_format(sr_session_ctx_t *session, const char *error_format)
Deprecated, use sr_session_set_error().
void sr_session_del_orig_data(sr_session_ctx_t *session)
Remove all pushed event originator data.
int sr_session_notif_buffer(sr_session_ctx_t *session)
Use notification buffering for the session.
struct sr_conn_ctx_s sr_conn_ctx_t
Sysrepo connection.
int sr_get_plugins(sr_conn_ctx_t *conn, const char ***ds_plugins, const char ***ntf_plugins)
Get loaded plugins of a connection.
int sr_session_dup_error(sr_session_ctx_t *src_session, sr_session_ctx_t *trg_session)
Copy the first error (if any) from a session to a callback session.
const char * sr_session_get_user(sr_session_ctx_t *session)
Get the effective user of a session.
sr_conn_ctx_t * sr_session_get_connection(sr_session_ctx_t *session)
Get the connection the session was created on.
uint32_t sr_get_content_id(sr_conn_ctx_t *conn)
Get content ID of the current YANG module set. It conforms to the requirements for ietf-yang-library ...
int sr_move_item(sr_session_ctx_t *session, const char *path, const sr_move_position_t position, const char *list_keys, const char *leaflist_value, const char *origin, const sr_edit_options_t opts)
Prepare to move/create the instance of an user-ordered list or leaf-list to the specified position....
int sr_validate(sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms)
Perform the validation a datastore and any changes made in the current session, but do not apply nor ...
int sr_copy_config(sr_session_ctx_t *session, const char *module_name, sr_datastore_t src_datastore, uint32_t timeout_ms)
Replaces a conventional datastore with the contents of another conventional datastore....
int sr_set_item_str(sr_session_ctx_t *session, const char *path, const char *value, const char *origin, const sr_edit_options_t opts)
Prepare to set (create) the value of a leaf, leaf-list, list, or presence container....
int sr_replace_config(sr_session_ctx_t *session, const char *module_name, struct lyd_node *src_config, uint32_t timeout_ms)
Replace a datastore with the contents of a data tree. If the module is specified, limit the operation...
int sr_discard_items(sr_session_ctx_t *session, const char *xpath)
Prepare to discard nodes matching the specified xpath in the operational datastore before applying th...
sr_move_position_t
Options for specifying move direction of sr_move_item call.
int sr_discard_oper_changes(sr_conn_ctx_t *conn, sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms)
Discard push operational changes of a module for a session.
int sr_set_oper_changes_order(sr_session_ctx_t *session, const char *module_name, uint32_t order)
Set explicit push operational changes order determining when they are applied relative to other sessi...
int sr_edit_batch(sr_session_ctx_t *session, const struct lyd_node *edit, const char *default_operation)
Provide a prepared edit data tree to be applied. These changes are applied only after calling sr_appl...
int sr_delete_item(sr_session_ctx_t *session, const char *path, const sr_edit_options_t opts)
Prepare to delete the nodes matching the specified xpath. These changes are applied only after callin...
const struct lyd_node * sr_get_changes(sr_session_ctx_t *session)
Retrieve stored changes (prepared, not yet applied).
int sr_get_oper_changes_order(sr_session_ctx_t *session, const char *module_name, uint32_t *order)
Get push operational changes order determining when they are applied relative to other sessions for t...
int sr_discard_changes_xpath(sr_session_ctx_t *session, const char *xpath)
Discard prepared changes made in the current session matching an XPath expression.
int sr_discard_changes(sr_session_ctx_t *session)
Discard prepared changes made in the current session.
int sr_set_item(sr_session_ctx_t *session, const char *path, const sr_val_t *value, const sr_edit_options_t opts)
Prepare to set (create) the value of a leaf, leaf-list, list, or presence container....
int sr_has_changes(sr_session_ctx_t *session)
Learn whether there are any prepared non-applied changes in the session.
uint32_t sr_edit_options_t
Options overriding default behavior of data manipulation calls, it is supposed to be bitwise OR-ed va...
int sr_oper_delete_item_str(sr_session_ctx_t *session, const char *path, const char *value, const sr_edit_options_t opts)
Deprecated, not supported.
int sr_apply_changes(sr_session_ctx_t *session, uint32_t timeout_ms)
Apply changes made in the current session. In case the changes could not be applied successfully for ...
int sr_get_oper_changes(sr_session_ctx_t *session, const char *module_name, sr_data_t **data)
Get stored push operational changes of a session.
int sr_delete_discard_items(sr_session_ctx_t *session, const char *xpath, const sr_edit_options_t opts)
Remove a 'discard-items' node from a push oper data of a session. Usable only for SR_DS_OPERATIONAL d...
void sr_free_val(sr_val_t *value)
Free sr_val_t structure and all memory allocated within it.
int sr_get_items(sr_session_ctx_t *session, const char *xpath, uint32_t timeout_ms, const sr_get_options_t opts, sr_val_t **values, size_t *value_cnt)
Retrieve an array of data elements selected by the provided XPath. Data are represented as sr_val_t s...
int sr_get_data(sr_session_ctx_t *session, const char *xpath, uint32_t max_depth, uint32_t timeout_ms, const sr_get_options_t opts, sr_data_t **data)
Retrieve a tree whose root nodes match the provided XPath. Data are represented as libyang subtrees.
void sr_free_values(sr_val_t *values, size_t count)
Free array of sr_val_t structures (and all memory allocated within of each array element).
int sr_get_item(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_val_t **value)
Retrieve a single data element selected by the provided path. Data are represented as sr_val_t struct...
int sr_session_acquire_data(sr_session_ctx_t *session, struct lyd_node *tree, sr_data_t **data)
Acquire libyang data tree together with its context lock in a SR data structure.
int sr_get_subtree(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_data_t **subtree)
Retrieve a single subtree whose root node is selected by the provided path. Data are represented as l...
void sr_release_data(sr_data_t *data)
Release SR data structure, whoch consists of freeing the data tree, releasing the context,...
int sr_acquire_data(sr_conn_ctx_t *conn, struct lyd_node *tree, sr_data_t **data)
Acquire libyang data tree together with its context lock in a SR data structure.
int sr_get_node(sr_session_ctx_t *session, const char *path, uint32_t timeout_ms, sr_data_t **node)
Retrieve a single value matching the provided XPath. Data are represented as a single libyang node.
Structure that safely wraps libyang data and prevents unexpected context changes.
int sr_lock(sr_session_ctx_t *session, const char *module_name, uint32_t timeout_ms)
Locks the data of the specified module or the whole datastore.
int sr_unlock(sr_session_ctx_t *session, const char *module_name)
Unlocks the data of the specified module or the whole datastore.
int sr_get_lock(sr_conn_ctx_t *conn, sr_datastore_t datastore, const char *module_name, int *is_locked, uint32_t *id, struct timespec *timestamp)
Check whether the data of the specified module or the whole datastore are locked.
void sr_log_syslog(const char *app_name, sr_log_level_t log_level)
Enables / disables / changes log level (verbosity) of logging to system log.
void sr_log_set_cb(sr_log_cb log_callback)
Sets callback that will be called when a log entry would be populated. Callback will be called for ev...
sr_error_t
Sysrepo error codes.
void sr_log_stderr(sr_log_level_t log_level)
Enables / disables / changes log level (verbosity) of logging to standard error output.
void(* sr_log_cb)(sr_log_level_t level, const char *message)
Sets callback that will be called when a log entry would be populated.
const char * sr_strerror(int err_code)
Returns the error message corresponding to the error code.
sr_log_level_t sr_log_get_stderr(void)
Learn current standard error output log level.
sr_log_level_t sr_log_get_syslog(void)
Learn current system log log level.
sr_log_level_t
Log levels used to determine if message of certain severity should be printed.
int sr_notif_send(sr_session_ctx_t *session, const char *path, const sr_val_t *values, const size_t values_cnt, uint32_t timeout_ms, int wait)
Send a notification. Data are represented as sr_val_t structures. In case there are particularly many...
int sr_notif_sub_get_info(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char **module_name, const char **xpath, struct timespec *start_time, struct timespec *stop_time, uint32_t *filtered_out)
Get information about an existing notification subscription.
void(* sr_event_notif_cb)(sr_session_ctx_t *session, uint32_t sub_id, const sr_ev_notif_type_t notif_type, const char *xpath, const sr_val_t *values, const size_t values_cnt, struct timespec *timestamp, void *private_data)
Callback to be called for the delivery of a notification. Data are represented as sr_val_t structures...
int sr_notif_sub_modify_xpath(sr_subscription_ctx_t *subscription, uint32_t sub_id, const char *xpath)
Modify an existing notification subscription by changing its XPath filter. Special SR_EV_NOTIF_MODIFI...
void(* sr_event_notif_tree_cb)(sr_session_ctx_t *session, uint32_t sub_id, const sr_ev_notif_type_t notif_type, const struct lyd_node *notif, struct timespec *timestamp, void *private_data)
Callback to be called for the delivery of a notification. Data are represented as libyang subtrees.
int sr_notif_subscribe_tree(sr_session_ctx_t *session, const char *module_name, const char *xpath, const struct timespec *start_time, const struct timespec *stop_time, sr_event_notif_tree_cb callback, void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Subscribes for the delivery of a notification(s). Data are represented as libyang subtrees.
int sr_notif_sub_modify_stop_time(sr_subscription_ctx_t *subscription, uint32_t sub_id, const struct timespec *stop_time)
Modify an existing notification subscription by changing its stop time. Special SR_EV_NOTIF_MODIFIED ...
int sr_notif_subscribe(sr_session_ctx_t *session, const char *module_name, const char *xpath, const struct timespec *start_time, const struct timespec *stop_time, sr_event_notif_cb callback, void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Subscribe for the delivery of a notification(s). Data are represented as sr_val_t structures.
int sr_notif_send_tree(sr_session_ctx_t *session, struct lyd_node *notif, uint32_t timeout_ms, int wait)
Send a notification. Data are represented as libyang subtrees. In case there are particularly many no...
int(* sr_oper_get_items_cb)(sr_session_ctx_t *session, uint32_t sub_id, const char *module_name, const char *path, const char *request_xpath, uint32_t operation_id, struct lyd_node **parent, void *private_data)
Callback to be called when operational data at the selected xpath are requested. Data are represented...
int sr_oper_poll_subscribe(sr_session_ctx_t *session, const char *module_name, const char *path, uint32_t valid_ms, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Start periodic retrieval and caching of operational data at the given path.
int sr_oper_get_subscribe(sr_session_ctx_t *session, const char *module_name, const char *path, sr_oper_get_items_cb callback, void *private_data, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Register for providing operational data at the given path.
int sr_rpc_send_tree(sr_session_ctx_t *session, struct lyd_node *input, uint32_t timeout_ms, sr_data_t **output)
Send an RPC/action and wait for the result. Data are represented as libyang subtrees.
int sr_rpc_subscribe(sr_session_ctx_t *session, const char *xpath, sr_rpc_cb callback, void *private_data, uint32_t priority, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Subscribe for the delivery of an RPC/action. Data are represented as sr_val_t structures.
int sr_rpc_send(sr_session_ctx_t *session, const char *path, const sr_val_t *input, const size_t input_cnt, uint32_t timeout_ms, sr_val_t **output, size_t *output_cnt)
Send an RPC/action and wait for the result. Data are represented as sr_val_t structures.
int(* sr_rpc_cb)(sr_session_ctx_t *session, uint32_t sub_id, const char *xpath, const sr_val_t *input, const size_t input_cnt, sr_event_t event, uint32_t operation_id, sr_val_t **output, size_t *output_cnt, void *private_data)
Callback to be called for the delivery of an RPC/action. Data are represented as sr_val_t structures.
int(* sr_rpc_tree_cb)(sr_session_ctx_t *session, uint32_t sub_id, const char *op_path, const struct lyd_node *input, sr_event_t event, uint32_t operation_id, struct lyd_node *output, void *private_data)
Callback to be called for the delivery of an RPC/action. Data are represented as libyang subtrees.
int sr_rpc_subscribe_tree(sr_session_ctx_t *session, const char *xpath, sr_rpc_tree_cb callback, void *private_data, uint32_t priority, sr_subscr_options_t opts, sr_subscription_ctx_t **subscription)
Subscribe for the delivery of an RPC/action. Data are represented as libyang subtrees.
int sr_check_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, int *read, int *write)
Check whether the current application has read/write access to a module.
int sr_install_module2(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs, const char **features, const sr_module_ds_t *module_ds, const char *owner, const char *group, mode_t perm, const char *data, const char *data_path, LYD_FORMAT format)
Install a new schema (module) into sysrepo with all the available options.
int sr_update_module(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs)
Update an installed schema (module) to a new revision.
int sr_enable_module_feature(sr_conn_ctx_t *conn, const char *module_name, const char *feature_name)
Enable a module feature.
const sr_module_ds_t * sr_get_module_ds_default(void)
Get the default datastore plugins.
int sr_install_modules2(sr_conn_ctx_t *conn, const sr_install_mod_t *modules, uint32_t module_count, const char *search_dirs, const char *data, const char *data_path, LYD_FORMAT format)
Install new schemas (modules) into sysrepo in a batch with all the available options.
int sr_get_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, char **owner, char **group, mode_t *perm)
Learn about module permissions.
int sr_disable_module_feature(sr_conn_ctx_t *conn, const char *module_name, const char *feature_name)
Disable a module feature.
int sr_get_module_replay_support(sr_conn_ctx_t *conn, const char *module_name, struct timespec *earliest_notif, int *enabled)
Learn replay support of a module.
int sr_remove_module(sr_conn_ctx_t *conn, const char *module_name, int force)
Remove an installed module from sysrepo.
int sr_is_module_internal(const struct lys_module *ly_mod)
Check whether a module is an internal libyang or sysrepo module. Evaluates to true for all the module...
const char * sr_get_shm_prefix(void)
Get the common SHM file prefix prepended to all SHM files.
const char * sr_get_repo_path(void)
Get the path (directory) for all persistent sysrepo files.
int sr_set_module_replay_support(sr_conn_ctx_t *conn, const char *module_name, int enable)
Change module replay support.
int sr_install_modules(sr_conn_ctx_t *conn, const char **schema_paths, const char *search_dirs, const char ***features)
Install new schemas (modules) into sysrepo in a batch.
int sr_get_module_info(sr_conn_ctx_t *conn, sr_data_t **sysrepo_data)
Get internal sysrepo data tree, which holds detailed information about installed modules....
int sr_remove_modules(sr_conn_ctx_t *conn, const char **module_names, int force)
Remove installed modules from sysrepo.
int sr_update_modules(sr_conn_ctx_t *conn, const char **schema_paths, const char *search_dirs)
Update installed schemas (modules) to new revisions in a batch.
int sr_set_module_ds_access(sr_conn_ctx_t *conn, const char *module_name, int mod_ds, const char *owner, const char *group, mode_t perm)
Change module permissions.
const char * sr_get_shm_path(void)
Get the path (directory) for all volatile sysrepo files, created as SHM files.
int sr_install_module(sr_conn_ctx_t *conn, const char *schema_path, const char *search_dirs, const char **features)
Install a new schema (module) into sysrepo.
void int srplg_errinfo_push_error_data(sr_error_info_t *err_info, uint32_t size, const void *data)
Push (add) another chunk of error data for a failed plugin callback. Its meaning is specific to the e...
void srplg_log_errinfo(sr_error_info_t **err_info, const char *plg_name, const char *err_format_name, sr_error_t err_code, const char *format,...) _FORMAT_PRINTF(5
Log a plugin error message and add the error into an error info structure.
void srplg_errinfo_free(sr_error_info_t **err_info)
Free a superfluous error info.
int sr_subscription_thread_notify(sr_subscription_ctx_t *subscription)
Notify (wake up) a subscription thread signalling there is a new event to process....
int sr_subscription_process_events(sr_subscription_ctx_t *subscription, sr_session_ctx_t *session, struct timespec *wake_up_in)
Process any pending new events on a subscription. Should not be called unless SR_SUBSCR_NO_THREAD fla...
int sr_subscription_suspend(sr_subscription_ctx_t *subscription, uint32_t sub_id)
Suspend a specific subscription. Special SR_EV_NOTIF_SUSPENDED notification is delivered for suspende...
int sr_unsubscribe_sub(sr_subscription_ctx_t *subscription, uint32_t sub_id)
Unsubscribe a specific or all the subscriptions in a subscription structure.
int sr_subscription_resume(sr_subscription_ctx_t *subscription, uint32_t sub_id)
Resume a previously suspended subscription. Special SR_EV_NOTIF_RESUMED notification is delivered for...
int sr_subscription_get_suspended(sr_subscription_ctx_t *subscription, uint32_t sub_id, int *suspended)
Learn the suspend state of a specific subscription.
int sr_unsubscribe(sr_subscription_ctx_t *subscription)
Unsubscribe all the subscriptions in a subscription structure and free it.
uint32_t sr_subscription_get_last_sub_id(const sr_subscription_ctx_t *subscription)
Get the subscription ID of the last created subscription.
uint32_t sr_subscr_options_t
Options overriding default behavior of subscriptions, it is supposed to be a bitwise OR-ed value of a...
int sr_subscription_thread_suspend(sr_subscription_ctx_t *subscription)
Suspend the default handler thread of a subscription structure. Meaning it will stop handling any eve...
struct sr_subscription_ctx_s sr_subscription_ctx_t
Sysrepo subscription context returned from sr_*_subscribe calls, it is supposed to be released by the...
int sr_get_event_pipe(sr_subscription_ctx_t *subscription, int *event_pipe)
Get the event pipe of a subscription. Do not call unless SR_SUBSCR_NO_THREAD flag was used when subsc...
int sr_subscription_thread_resume(sr_subscription_ctx_t *subscription)
Resume the default handler thread of a subscription structure that was suspended previously.
void srplg_log(const char *plg_name, sr_log_level_t ll, const char *format,...) _FORMAT_PRINTF(3
public sysrepo types header
struct sr_session_ctx_s sr_session_ctx_t
Sysrepo session on a connection.
uint32_t sr_conn_options_t
Options overriding default connection handling by sr_connect call, it is supposed to be bitwise OR-ed...
uint32_t sr_get_options_t
Options overriding default get handling by sr_get_data call, it is supposed to be a bitmask sr_get_op...
sr_datastore_t
Datastores that sysrepo supports. To change which datastore a session operates on,...
A single, detailed error message. Used in sr_error_info_t.
Detailed sysrepo session error information.
Information about a module to be installed.
Custom datastore implementation config for each datastore and notifications of a module.
Structure that contains value of an data element stored in the sysrepo datastore.