| NATS C Client with JetStream and Streaming support
    3.2.0
    The nats.io C Client, Supported by Synadia Communications Inc. | 
| Modules | |
| KeyValue store management | |
| KeyValue store entries | |
| KeyValue store watcher | |
| KeyValue store status | |
| Functions | |
| NATS_EXTERN natsStatus | kvStore_Get (kvEntry **new_entry, kvStore *kv, const char *key) | 
| Returns the latest entry for the key.  More... | |
| NATS_EXTERN natsStatus | kvStore_Put (uint64_t *rev, kvStore *kv, const char *key, const void *data, int len) | 
| Places the new value for the key into the store.  More... | |
| NATS_EXTERN natsStatus | kvStore_PutString (uint64_t *rev, kvStore *kv, const char *key, const char *data) | 
| Places the new value (as a string) for the key into the store.  More... | |
| NATS_EXTERN natsStatus | kvStore_Create (uint64_t *rev, kvStore *kv, const char *key, const void *data, int len) | 
| Places the value for the key into the store if and only if the key does not exist.  More... | |
| NATS_EXTERN natsStatus | kvStore_CreateString (uint64_t *rev, kvStore *kv, const char *key, const char *data) | 
| Places the value (as a string) for the key into the store if and only if the key does not exist.  More... | |
| NATS_EXTERN natsStatus | kvStore_Update (uint64_t *rev, kvStore *kv, const char *key, const void *data, int len, uint64_t last) | 
| Updates the value for the key into the store if and only if the latest revision matches.  More... | |
| NATS_EXTERN natsStatus | kvStore_UpdateString (uint64_t *rev, kvStore *kv, const char *key, const char *data, uint64_t last) | 
| Updates the value (as a string) for the key into the store if and only if the latest revision matches.  More... | |
| NATS_EXTERN natsStatus | kvStore_Delete (kvStore *kv, const char *key) | 
| Deletes a key by placing a delete marker and leaving all revisions.  More... | |
| NATS_EXTERN natsStatus | kvStore_Purge (kvStore *kv, const char *key) | 
| Deletes a key by placing a purge marker and removing all revisions.  More... | |
| NATS_EXTERN natsStatus | kvWatchOptions_Init (kvWatchOptions *opts) | 
| Initializes a KeyValue watcher options structure.  More... | |
| NATS_EXTERN natsStatus | kvStore_PurgeDeletes (kvStore *kv, kvWatchOptions *opts) | 
| Removes all current delete markers.  More... | |
| NATS_EXTERN natsStatus | kvStore_Watch (kvWatcher **new_watcher, kvStore *kv, const char *keys, kvWatchOptions *opts) | 
| Returns a watcher for any updates to keys that match the keysargument.  More... | |
| NATS_EXTERN natsStatus | kvStore_WatchAll (kvWatcher **new_watcher, kvStore *kv, kvWatchOptions *opts) | 
| Returns a watcher for any updates to any keys of the KeyValue store bucket.  More... | |
| NATS_EXTERN natsStatus | kvStore_Keys (kvKeysList *list, kvStore *kv, kvWatchOptions *opts) | 
| Returns all keys in the bucket.  More... | |
| NATS_EXTERN void | kvKeysList_Destroy (kvKeysList *list) | 
| Destroys this list of KeyValue store key strings.  More... | |
| NATS_EXTERN natsStatus | kvStore_History (kvEntryList *list, kvStore *kv, const char *key, kvWatchOptions *opts) | 
| Returns all historical entries for the key.  More... | |
| NATS_EXTERN void | kvEntryList_Destroy (kvEntryList *list) | 
| Destroys this list of KeyValue store entries.  More... | |
| NATS_EXTERN const char * | kvStore_Bucket (kvStore *kv) | 
| Returns the bucket name of this KeyValue store object.  More... | |
| NATS_EXTERN natsStatus | kvStore_Status (kvStatus **new_status, kvStore *kv) | 
| Returns the status and configuration of a bucket.  More... | |
A KeyValue store is a materialized view of JetStream.
| NATS_EXTERN natsStatus kvStore_Get | ( | kvEntry ** | new_entry, | 
| kvStore * | kv, | ||
| const char * | key | ||
| ) | 
Returns the latest entry for the key.
| new_entry | the location where to store the pointer to the entry associated with the key. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| NATS_EXTERN natsStatus kvStore_Put | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const void * | data, | ||
| int | len | ||
| ) | 
Places the new value for the key into the store.
| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the data in memory. | 
| len | the number of bytes to copy from the data's memory location. | 
| NATS_EXTERN natsStatus kvStore_PutString | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const char * | data | ||
| ) | 
Places the new value, as a string, for the key into the store.
(int) strlen(data).| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the string to store. | 
| NATS_EXTERN natsStatus kvStore_Create | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const void * | data, | ||
| int | len | ||
| ) | 
Places the value for the key into the store if and only if the key does not exist.
| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the data in memory. | 
| len | the number of bytes to copy from the data's memory location. | 
| NATS_EXTERN natsStatus kvStore_CreateString | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const char * | data | ||
| ) | 
Places the value (as a string) for the key into the store if and only if the key does not exist.
(int) strlen(data).| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the string. | 
| NATS_EXTERN natsStatus kvStore_Update | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const void * | data, | ||
| int | len, | ||
| uint64_t | last | ||
| ) | 
Updates the value for the key into the store if and only if the latest revision matches.
| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the data in memory. | 
| len | the number of bytes to copy from the data's memory location. | 
| last | the expected latest revision prior to the update. | 
| NATS_EXTERN natsStatus kvStore_UpdateString | ( | uint64_t * | rev, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| const char * | data, | ||
| uint64_t | last | ||
| ) | 
Updates the value (as a string) for the key into the store if and only if the latest revision matches.
(int) strlen(data).| rev | the location where to store the revision of this value, or NULLif the stream information is not needed. | 
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| data | the pointer to the string. | 
| last | the expected latest revision prior to the update. | 
| NATS_EXTERN natsStatus kvStore_Delete | ( | kvStore * | kv, | 
| const char * | key | ||
| ) | 
Deletes a key by placing a delete marker and leaving all revisions.
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| NATS_EXTERN natsStatus kvStore_Purge | ( | kvStore * | kv, | 
| const char * | key | ||
| ) | 
Deletes a key by placing a purge marker and removing all revisions.
| kv | the pointer to the kvStore object. | 
| key | the name of the key. | 
| NATS_EXTERN natsStatus kvWatchOptions_Init | ( | kvWatchOptions * | opts | ) | 
Use this before setting specific watcher options and passing it to kvStore_Watch.
| opts | the pointer to the kvWatchOptions to initialize. | 
| NATS_EXTERN natsStatus kvStore_PurgeDeletes | ( | kvStore * | kv, | 
| kvWatchOptions * | opts | ||
| ) | 
Removes all current delete markers.
This is a maintenance option if there is a larger buildup of delete markers.
| kv | the pointer to the kvStore object. | 
| opts | the pointer to the kvWatchOptions, possibly NULL. | 
| NATS_EXTERN natsStatus kvStore_Watch | ( | kvWatcher ** | new_watcher, | 
| kvStore * | kv, | ||
| const char * | keys, | ||
| kvWatchOptions * | opts | ||
| ) | 
Returns a watcher for any updates to keys that match the keys argument, which could include wildcard.
A NULL entry will be posted when the watcher has received all initial values.
Call kvWatcher_Next to get the next kvEntry.
| NATS_EXTERN natsStatus kvStore_WatchAll | ( | kvWatcher ** | new_watcher, | 
| kvStore * | kv, | ||
| kvWatchOptions * | opts | ||
| ) | 
Returns a watcher for any updates to any keys of the KeyValue store bucket.
A NULL entry will be posted when the watcher has received all initial values.
Call kvWatcher_Next to get the next kvEntry.
| NATS_EXTERN natsStatus kvStore_Keys | ( | kvKeysList * | list, | 
| kvStore * | kv, | ||
| kvWatchOptions * | opts | ||
| ) | 
Returns all keys in the bucket.
| list | list the pointer to a kvKeysList that will be initialized and filled with resulting key strings. | 
| kv | the pointer to the kvStore object. | 
| opts | the history options, possibly NULL. | 
| NATS_EXTERN void kvKeysList_Destroy | ( | kvKeysList * | list | ) | 
This function iterates through the list of all key strings and free them. It then frees the array that was allocated to hold pointers to those keys.
| list | the kvKeysList list of key strings to destroy. | 
| NATS_EXTERN natsStatus kvStore_History | ( | kvEntryList * | list, | 
| kvStore * | kv, | ||
| const char * | key, | ||
| kvWatchOptions * | opts | ||
| ) | 
Returns all historical entries for the key
Use the options to alter the behavior. For instance, if delete markers are not desired, option kvWatchOptions.IgnoreDeletes should be specified.
| list | the pointer to a kvEntryList that will be initialized and filled with resulting entries. | 
| kv | the pointer to the kvStore object. | 
| key | the key for which the history is requested. | 
| opts | the history options, possibly NULL. | 
| NATS_EXTERN void kvEntryList_Destroy | ( | kvEntryList * | list | ) | 
This function iterates through the list of all entries and call kvEntry_Destroy. It then frees the array that was allocated to hold pointers to those entries.
| list | the kvEntryList list of kvEntry objects to destroy. | 
| NATS_EXTERN const char * kvStore_Bucket | ( | kvStore * | kv | ) | 
Returns the bucket name of this KeyValue store object, or NULL if kv itself is NULL.
| kv | the pointer to the kvStore object. | 
| NATS_EXTERN natsStatus kvStore_Status | ( | kvStatus ** | new_status, | 
| kvStore * | kv | ||
| ) | 
Returns the status and configuration of a bucket.
| new_status | the location where to store the status of this KeyValue store. | 
| kv | the pointer to the kvStore object. |