| C++ Server-Side SDK
    LaunchDarkly SDK | 
LaunchDarkly Server-side C Bindings. More...
#include <launchdarkly/server_side/bindings/c/all_flags_state/all_flags_state.h>#include <launchdarkly/server_side/bindings/c/config/builder.h>#include <launchdarkly/bindings/c/context.h>#include <launchdarkly/bindings/c/data/evaluation_detail.h>#include <launchdarkly/bindings/c/data_source/error_info.h>#include <launchdarkly/bindings/c/export.h>#include <launchdarkly/bindings/c/listener_connection.h>#include <launchdarkly/bindings/c/memory_routines.h>#include <launchdarkly/bindings/c/shared_function_argument_macro_definitions.h>#include <launchdarkly/bindings/c/status.h>#include <launchdarkly/bindings/c/value.h>#include <stddef.h>#include <stdint.h>#include <time.h>
Go to the source code of this file.
| Classes | |
| struct | LDServerDataSourceStatusListener | 
| Enumerations | |
| enum | LDServerDataSourceStatus_State { LD_SERVERDATASOURCESTATUS_STATE_INITIALIZING = 0 , LD_SERVERDATASOURCESTATUS_STATE_VALID = 1 , LD_SERVERDATASOURCESTATUS_STATE_INTERRUPTED = 2 , LD_SERVERDATASOURCESTATUS_STATE_OFF = 3 } | 
| Functions | |
| LDServerSDK_New (LDServerConfig config) | |
| LDServerSDK_Version (void) | |
| LDServerSDK_Start (LDServerSDK sdk, unsigned int milliseconds, bool *out_succeeded) | |
| LDServerSDK_Initialized (LDServerSDK sdk) | |
| LDServerSDK_TrackEvent (LDServerSDK sdk, LDContext context, char const *event_name) | |
| LDServerSDK_TrackMetric (LDServerSDK sdk, LDContext context, char const *event_name, double metric_value, LDValue data) | |
| LDServerSDK_TrackData (LDServerSDK sdk, LDContext context, char const *event_name, LDValue data) | |
| LDServerSDK_Flush (LDServerSDK sdk, unsigned int reserved) | |
| LDServerSDK_Identify (LDServerSDK sdk, LDContext context) | |
| LDServerSDK_BoolVariation (LDServerSDK sdk, LDContext context, char const *flag_key, bool default_value) | |
| LDServerSDK_BoolVariationDetail (LDServerSDK sdk, LDContext context, char const *flag_key, bool default_value, LDEvalDetail *out_detail) | |
| LDServerSDK_StringVariation (LDServerSDK sdk, LDContext context, char const *flag_key, char const *default_value) | |
| LDServerSDK_StringVariationDetail (LDServerSDK sdk, LDContext context, char const *flag_key, char const *default_value, LDEvalDetail *out_detail) | |
| LDServerSDK_IntVariation (LDServerSDK sdk, LDContext context, char const *flag_key, int default_value) | |
| LDServerSDK_IntVariationDetail (LDServerSDK sdk, LDContext context, char const *flag_key, int default_value, LDEvalDetail *out_detail) | |
| LDServerSDK_DoubleVariation (LDServerSDK sdk, LDContext context, char const *flag_key, double default_value) | |
| LDServerSDK_DoubleVariationDetail (LDServerSDK sdk, LDContext context, char const *flag_key, double default_value, LDEvalDetail *out_detail) | |
| LDServerSDK_JsonVariation (LDServerSDK sdk, LDContext context, char const *flag_key, LDValue default_value) | |
| LDServerSDK_JsonVariationDetail (LDServerSDK sdk, LDContext context, char const *flag_key, LDValue default_value, LDEvalDetail *out_detail) | |
| LDServerSDK_AllFlagsState (LDServerSDK sdk, LDContext context, enum LDAllFlagsState_Options options) | |
| LDServerSDK_Free (LDServerSDK sdk) | |
| LDServerDataSourceStatus_GetState (LDServerDataSourceStatus status) | |
| LDServerDataSourceStatus_GetLastError (LDServerDataSourceStatus status) | |
| LDServerDataSourceStatus_StateSince (LDServerDataSourceStatus status) | |
| LDServerDataSourceStatusListener_Init (struct LDServerDataSourceStatusListener *listener) | |
| LDServerSDK_DataSourceStatus_OnStatusChange (LDServerSDK sdk, struct LDServerDataSourceStatusListener listener) | |
| LDServerSDK_DataSourceStatus_Status (LDServerSDK sdk) | |
| LDServerDataSourceStatus_Free (LDServerDataSourceStatus status) | |
LaunchDarkly Server-side C Bindings.
Enumeration of possible data source states.
| LDServerDataSourceStatus_Free | ( | LDServerDataSourceStatus | status | ) | 
Frees the data source status.
| status | The data source status to free. | 
| LDServerDataSourceStatus_GetLastError | ( | LDServerDataSourceStatus | status | ) | 
Information about the last error that the data source encountered, if any. If there has not been an error, then NULL will be returned.
If a non-NULL value is returned, then it should be freed using LDDataSourceStatus_ErrorInfo_Free.
This property should be updated whenever the data source encounters a problem, even if it does not cause the state to change. For instance, if a stream connection fails and the state changes to LD_SERVERDATASOURCESTATUS_STATE_INTERRUPTED, and then subsequent attempts to restart the connection also fail, the state will remain LD_SERVERDATASOURCESTATUS_STATE_INTERRUPTED but the error information will be updated each time– and the last error will still be reported in this property even if the state later becomes LD_SERVERDATASOURCESTATUS_STATE_VALID.
| LDServerDataSourceStatus_GetState | ( | LDServerDataSourceStatus | status | ) | 
Get an enumerated value representing the overall current state of the data source.
| LDServerDataSourceStatus_StateSince | ( | LDServerDataSourceStatus | status | ) | 
The date/time that the value of State most recently changed, in seconds since epoch.
The meaning of this depends on the current state:
| LDServerDataSourceStatusListener_Init | ( | struct LDServerDataSourceStatusListener * | listener | ) | 
Initializes a data source status change listener. Must be called before passing the listener to LDServerSDK_DataSourceStatus_OnStatusChange.
If the StatusChanged member of the listener struct is not set (NULL), then the function will not register a listener. In that case the return value will be NULL.
Create the struct, initialize the struct, set the StatusChanged handler and optionally UserData, and then pass the struct to LDServerSDK_DataSourceStatus_OnStatusChange. NULL will be returned if the StatusChanged member of the listener struct is NULL.
| listener | Listener to initialize. | 
| LDServerSDK_AllFlagsState | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| enum LDAllFlagsState_Options | options | ||
| ) | 
Evaluates all flags for a context, returning a data structure containing the results and additional flag metadata.
The method's behavior can be controlled by passing a combination of one or more options.
A common use-case for AllFlagsState is to generate data suitable for bootstrapping the client-side JavaScript SDK.
This method will not send analytics events back to LaunchDarkly.
| sdk | SDK. Must not be NULL. | 
| context | The context against which all flags will be evaluated. Ownership is NOT transferred. Must not be NULL. | 
| options | A combination of one or more options. Pass LD_ALLFLAGSSTATE_DEFAULT for default behavior. | 
| LDServerSDK_BoolVariation | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| bool | default_value | ||
| ) | 
Returns the boolean value of a feature flag for a given flag key and context.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| LDServerSDK_BoolVariationDetail | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| bool | default_value, | ||
| LDEvalDetail * | out_detail | ||
| ) | 
Returns the boolean value of a feature flag for a given flag key and context, and details that also describes the way the value was determined.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| detail | Out parameter to store the details. May pass LD_DISCARD_DETAILS or NULL to discard the details. The details object must be freed with LDEvalDetail_Free. | 
| LDServerSDK_DataSourceStatus_OnStatusChange | ( | LDServerSDK | sdk, | 
| struct LDServerDataSourceStatusListener | listener | ||
| ) | 
Listen for changes to the data source status.
| sdk | SDK. Must not be NULL. | 
| listener | The listener, whose StatusChanged callback will be invoked, when the data source status changes. Must not be NULL. | 
| LDServerSDK_DataSourceStatus_Status | ( | LDServerSDK | sdk | ) | 
The current status of the data source.
The caller must free the returned value using LDServerDataSourceStatus_Free.
| LDServerSDK_DoubleVariation | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| double | default_value | ||
| ) | 
Returns the double value of a feature flag for a given flag key and context.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| LDServerSDK_DoubleVariationDetail | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| double | default_value, | ||
| LDEvalDetail * | out_detail | ||
| ) | 
Returns the double value of a feature flag for a given flag key and context, and details that also describes the way the value was determined.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| detail | Out parameter to store the details. May pass LD_DISCARD_DETAILS or NULL to discard the details. The details object must be freed with LDEvalDetail_Free. | 
| LDServerSDK_Flush | ( | LDServerSDK | sdk, | 
| unsigned int | reserved | ||
| ) | 
Requests delivery of all pending analytic events (if any).
You MUST pass LD_NONBLOCKING as the second parameter.
| sdk | SDK. Must not be NULL. | 
| milliseconds | Must pass LD_NONBLOCKING. | 
| LDServerSDK_Free | ( | LDServerSDK | sdk | ) | 
Frees the SDK's resources, shutting down any connections. May block.
| sdk | SDK. | 
| LDServerSDK_Identify | ( | LDServerSDK | sdk, | 
| LDContext | context | ||
| ) | 
Generates an identify event for the given context.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| LDServerSDK_Initialized | ( | LDServerSDK | sdk | ) | 
Returns a boolean value indicating LaunchDarkly connection and flag state within the client.
When you first start the client, once Start has completed, Initialized should return true if and only if either 1. it connected to LaunchDarkly and successfully retrieved flags, or 2. it started in offline mode so there's no need to connect to LaunchDarkly.
If the client timed out trying to connect to LD, then Initialized returns false (even if we do have cached flags). If the client connected and got a 401 error, Initialized is will return false. This serves the purpose of letting the app know that there was a problem of some kind.
| sdk | SDK. Must not be NULL. | 
| LDServerSDK_IntVariation | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| int | default_value | ||
| ) | 
Returns the int value of a feature flag for a given flag key and context.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| LDServerSDK_IntVariationDetail | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| int | default_value, | ||
| LDEvalDetail * | out_detail | ||
| ) | 
Returns the int value of a feature flag for a given flag key and context, and details that also describes the way the value was determined.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| detail | Out parameter to store the details. May pass LD_DISCARD_DETAILS or NULL to discard the details. The details object must be freed with LDEvalDetail_Free. | 
| LDServerSDK_JsonVariation | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| LDValue | default_value | ||
| ) | 
Returns the JSON value of a feature flag for a given flag key and context.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. Ownership is NOT transferred. | 
| LDServerSDK_JsonVariationDetail | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| LDValue | default_value, | ||
| LDEvalDetail * | out_detail | ||
| ) | 
Returns the JSON value of a feature flag for a given flag key and context, and details that also describes the way the value was determined.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. Ownership is NOT transferred. | 
| detail | Out parameter to store the details. May pass LD_DISCARD_DETAILS or NULL to discard the details. The details object must be freed with LDEvalDetail_Free. | 
| LDServerSDK_New | ( | LDServerConfig | config | ) | 
Constructs a new server-side LaunchDarkly SDK from a configuration.
| config | The configuration. Ownership is transferred. Do not free or access the LDServerConfig in any way after this call, otherwise behavior is undefined. Must not be NULL. | 
| LDServerSDK_Start | ( | LDServerSDK | sdk, | 
| unsigned int | milliseconds, | ||
| bool * | out_succeeded | ||
| ) | 
Starts the SDK, initiating a connection to LaunchDarkly if not offline.
Only one Start call can be in progress at once; calling it concurrently invokes undefined behavior.
The method may be blocking or asynchronous depending on the arguments.
To block, pass a positive milliseconds value and an optional pointer to a boolean. The return value will be true if the SDK started within the specified timeframe, or false if the operation couldn't complete in time. The value of out_succeeded will be true if the SDK successfully initialized.
Example:
To start asynchronously, pass LD_NONBLOCKING. In this case, the return value will be false and you may pass NULL to out_succeeded.
| sdk | SDK. Must not be NULL. | 
| milliseconds | Milliseconds to wait for initialization or LD_NONBLOCKINGto return immediately. | 
| out_succeeded | Pointer to bool representing successful initialization. Only modified if a positive milliseconds value is passed; may be NULL. | 
| LDServerSDK_StringVariation | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| char const * | default_value | ||
| ) | 
Returns the string value of a feature flag for a given flag key and context. Ensure the string is freed with LDMemory_FreeString.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| LDServerSDK_StringVariationDetail | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | flag_key, | ||
| char const * | default_value, | ||
| LDEvalDetail * | out_detail | ||
| ) | 
Returns the string value of a feature flag for a given flag key and context, and details that also describes the way the value was determined. Ensure the string is freed with LDMemory_FreeString.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| flag_key | The unique key for the feature flag. Must not be NULL. | 
| default_value | The default value of the flag. | 
| detail | Out parameter to store the details. May pass LD_DISCARD_DETAILS or NULL to discard the details. The details object must be freed with LDEvalDetail_Free. | 
| LDServerSDK_TrackData | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | event_name, | ||
| LDValue | data | ||
| ) | 
Tracks that the given context performed an event with the given event name, with additional JSON data.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| event_name | The name of the event. Must not be NULL. | 
| data | A JSON value containing additional data associated with the event. Ownership is transferred. Must not be NULL. | 
| LDServerSDK_TrackEvent | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | event_name | ||
| ) | 
Tracks that the given context performed an event with the given event name.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| event_name | Name of the event. Must not be NULL. | 
| LDServerSDK_TrackMetric | ( | LDServerSDK | sdk, | 
| LDContext | context, | ||
| char const * | event_name, | ||
| double | metric_value, | ||
| LDValue | data | ||
| ) | 
Tracks that the given context performed an event with the given event name, and associates it with a numeric metric and value.
If the data parameter isn't needed, pass LDValue_NewNull() as the value: 
If the data parameter is needed (example using a string):
If the metric value isn't needed, see LDServerSDK_TrackData.
| sdk | SDK. Must not be NULL. | 
| context | The context. Ownership is NOT transferred. Must not be NULL. | 
| event_name | The name of the event. Must not be NULL. | 
| metric_value | This value is used by the LaunchDarkly experimentation feature in numeric custom metrics, and will also be returned as part of the custom event for Data Export. | 
| data | A JSON value containing additional data associated with the event. Ownership is transferred into the SDK. Must not be NULL. | 
| LDServerSDK_Version | ( | void | ) | 
Returns the version of the SDK.