24#ifndef FREERDP_SETTINGS_H
25#define FREERDP_SETTINGS_H
27#include <winpr/timezone.h>
28#include <winpr/wlog.h>
30#include <freerdp/api.h>
31#include <freerdp/config.h>
32#include <freerdp/types.h>
33#include <freerdp/redirection.h>
35#if !defined(WITH_OPAQUE_SETTINGS)
36#include <freerdp/settings_types_private.h>
39#include <freerdp/settings_keys.h>
40#include <freerdp/settings_types.h>
42#include <freerdp/crypto/certificate.h>
43#include <freerdp/crypto/privatekey.h>
80#define FREERDP_SETTINGS_SERVER_MODE 0x00000001
81#define FREERDP_SETTINGS_REMOTE_MODE 0x00000002
153 const rdpSettings* settings,
154 const rdpSettings* other);
156 FREERDP_API
void freerdp_addin_argv_free(
ADDIN_ARGV* args);
158 WINPR_ATTR_MALLOC(freerdp_addin_argv_free, 1)
159 FREERDP_API
ADDIN_ARGV* freerdp_addin_argv_new(
size_t argc, const
char* const argv[]);
161 WINPR_ATTR_MALLOC(freerdp_addin_argv_free, 1)
165 FREERDP_API BOOL freerdp_addin_argv_add_argument(
ADDIN_ARGV* args, const
char* argument);
168 FREERDP_API BOOL freerdp_addin_argv_add_argument_ex(
ADDIN_ARGV* args, const
char* argument,
172 FREERDP_API BOOL freerdp_addin_argv_del_argument(
ADDIN_ARGV* args, const
char* argument);
175 FREERDP_API
int freerdp_addin_set_argument(
ADDIN_ARGV* args, const
char* argument);
178 FREERDP_API
int freerdp_addin_replace_argument(
ADDIN_ARGV* args, const
char* previous,
179 const
char* argument);
182 FREERDP_API
int freerdp_addin_set_argument_value(
ADDIN_ARGV* args, const
char* option,
186 FREERDP_API
int freerdp_addin_replace_argument_value(
ADDIN_ARGV* args, const
char* previous,
187 const
char* option, const
char* value);
190 FREERDP_API BOOL freerdp_device_collection_add(rdpSettings* settings,
RDPDR_DEVICE* device);
206 FREERDP_API
RDPDR_DEVICE* freerdp_device_collection_find(rdpSettings* settings,
209 FREERDP_API
RDPDR_DEVICE* freerdp_device_collection_find_type(rdpSettings* settings,
212 FREERDP_API
void freerdp_device_free(
RDPDR_DEVICE* device);
214 WINPR_ATTR_MALLOC(freerdp_device_free, 1)
215 FREERDP_API
RDPDR_DEVICE* freerdp_device_new(UINT32 Type,
size_t count,
216 const
char* const args[]);
218 WINPR_ATTR_MALLOC(freerdp_device_free, 1)
224 FREERDP_API
void freerdp_device_collection_free(rdpSettings* settings);
227 FREERDP_API BOOL freerdp_static_channel_collection_add(rdpSettings* settings,
230 FREERDP_API BOOL freerdp_static_channel_collection_del(rdpSettings* settings, const
char* name);
233 FREERDP_API
ADDIN_ARGV* freerdp_static_channel_collection_find(rdpSettings* settings,
235#if defined(WITH_FREERDP_DEPRECATED)
236 WINPR_DEPRECATED(WINPR_ATTR_MALLOC(freerdp_addin_argv_free, 1)
240 FREERDP_API
void freerdp_static_channel_collection_free(rdpSettings* settings);
243 FREERDP_API BOOL freerdp_dynamic_channel_collection_add(rdpSettings* settings,
246 FREERDP_API BOOL freerdp_dynamic_channel_collection_del(rdpSettings* settings,
250 FREERDP_API
ADDIN_ARGV* freerdp_dynamic_channel_collection_find(
const rdpSettings* settings,
253#if defined(WITH_FREERDP_DEPRECATED)
255 WINPR_ATTR_MALLOC(freerdp_addin_argv_free, 1)
259 FREERDP_API
void freerdp_dynamic_channel_collection_free(rdpSettings* settings);
260 FREERDP_API
void freerdp_capability_buffer_free(rdpSettings* settings);
263 FREERDP_API BOOL freerdp_capability_buffer_copy(rdpSettings* settings,
const rdpSettings* src);
265 FREERDP_API
void freerdp_server_license_issuers_free(rdpSettings* settings);
268 FREERDP_API BOOL freerdp_server_license_issuers_copy(rdpSettings* settings,
char** issuers,
271 FREERDP_API
void freerdp_target_net_addresses_free(rdpSettings* settings);
274 FREERDP_API BOOL freerdp_target_net_addresses_copy(rdpSettings* settings,
char** addresses,
277 FREERDP_API
void freerdp_performance_flags_make(rdpSettings* settings);
278 FREERDP_API
void freerdp_performance_flags_split(rdpSettings* settings);
282 UINT32 GatewayUsageMethod);
284 FREERDP_API UINT32 freerdp_get_gateway_usage_method(
const rdpSettings* settings);
286 FREERDP_API
void freerdp_update_gateway_usage_method(rdpSettings* settings,
287 UINT32 GatewayEnabled,
288 UINT32 GatewayBypassLocal);
294#if defined(WITH_FREERDP_DEPRECATED)
295 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_get_bool instead",
296 WINPR_ATTR_NODISCARD FREERDP_API BOOL
297 freerdp_get_param_bool(
const rdpSettings* settings,
int id));
298 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_set_bool instead",
299 FREERDP_API
int freerdp_set_param_bool(rdpSettings* settings,
int id,
302 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_get_int[16|32] instead",
303 WINPR_ATTR_NODISCARD FREERDP_API
int freerdp_get_param_int(
304 const rdpSettings* settings,
int id));
305 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_set_int[16|32] instead",
306 FREERDP_API
int freerdp_set_param_int(rdpSettings* settings,
int id,
309 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_get_uint32 instead",
310 WINPR_ATTR_NODISCARD FREERDP_API UINT32
311 freerdp_get_param_uint32(
const rdpSettings* settings,
int id));
312 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_set_uint32 instead",
313 FREERDP_API
int freerdp_set_param_uint32(rdpSettings* settings,
int id,
316 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_get_uint64 instead",
317 WINPR_ATTR_NODISCARD FREERDP_API UINT64
318 freerdp_get_param_uint64(
const rdpSettings* settings,
int id));
319 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_set_uint64 instead",
320 FREERDP_API
int freerdp_set_param_uint64(rdpSettings* settings,
int id,
323 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_get_string instead",
324 WINPR_ATTR_NODISCARD FREERDP_API
char* freerdp_get_param_string(
325 const rdpSettings* settings,
int id));
326 WINPR_DEPRECATED_VAR(
"Use freerdp_settings_set_string instead",
327 FREERDP_API
int freerdp_set_param_string(rdpSettings* settings,
int id,
352 FreeRDP_Settings_Keys_Bool
id);
375 FreeRDP_Settings_Keys_Int16
id);
387 FreeRDP_Settings_Keys_Int16
id, INT16 val);
398 FreeRDP_Settings_Keys_UInt16
id);
410 FreeRDP_Settings_Keys_UInt16
id, UINT16 val);
421 FreeRDP_Settings_Keys_Int32
id);
433 FreeRDP_Settings_Keys_Int32
id, INT32 val);
444 FreeRDP_Settings_Keys_UInt32
id);
456 FreeRDP_Settings_Keys_UInt32
id, UINT32 val);
467 FreeRDP_Settings_Keys_Int64
id);
479 FreeRDP_Settings_Keys_Int64
id, INT64 val);
490 FreeRDP_Settings_Keys_UInt64
id);
502 FreeRDP_Settings_Keys_UInt64
id, UINT64 val);
513 FreeRDP_Settings_Keys_String
id);
524 FreeRDP_Settings_Keys_String
id);
537 FreeRDP_Settings_Keys_String
id,
538 const char* val,
size_t len);
551 FreeRDP_Settings_Keys_String
id,
const char* val);
566 FreeRDP_Settings_Keys_String
id,
567 const char* separator,
const char* param);
580 FreeRDP_Settings_Keys_String
id,
595 FreeRDP_Settings_Keys_String
id,
596 const WCHAR* param,
size_t length);
604 WINPR_ATTR_MALLOC(free, 1)
606 FreeRDP_Settings_Keys_String
id,
618 FreeRDP_Settings_Keys_Pointer
id);
629 FreeRDP_Settings_Keys_Pointer
id);
641 FreeRDP_Settings_Keys_Pointer
id,
654 FreeRDP_Settings_Keys_Pointer
id,
655 const
void* data,
size_t len);
658 FREERDP_API const
void* freerdp_settings_get_pointer_array(const rdpSettings* settings,
659 FreeRDP_Settings_Keys_Pointer
id,
663 FREERDP_API
void* freerdp_settings_get_pointer_array_writable(const rdpSettings* settings,
664 FreeRDP_Settings_Keys_Pointer
id,
668 FREERDP_API BOOL freerdp_settings_set_pointer_array(rdpSettings* settings,
669 FreeRDP_Settings_Keys_Pointer
id,
670 size_t offset, const
void* data);
693 FREERDP_API BOOL freerdp_settings_set_value_for_name(rdpSettings* settings, const
char* name,
778 const BYTE** capsData,
779 const UINT32* capsSizes, UINT32 capsCount,
780 BOOL serverReceivedCaps);
826 FREERDP_API const
char* freerdp_encryption_level_string(UINT32 EncryptionLevel);
829 FREERDP_API const
char* freerdp_encryption_methods_string(UINT32 EncryptionMethods,
830 char* buffer,
size_t size);
848 WINPR_ATTR_MALLOC(free, 1)
883 WINPR_ATTR_MALLOC(free, 1)
FREERDP_API void freerdp_settings_dump(wLog *log, DWORD level, const rdpSettings *settings)
Dumps the contents of a settings struct to a WLog logger.
WINPR_ATTR_NODISCARD FREERDP_API const void * freerdp_settings_get_pointer(const rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id)
Returns a immutable pointer settings value.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_type_name_for_type(SSIZE_T type)
Returns the type name for a type.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_string_from_utf16N(rdpSettings *settings, FreeRDP_Settings_Keys_String id, const WCHAR *param, size_t length)
Sets a string settings value. The param is converted to UTF-8 and the copy stored.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_update_from_caps(rdpSettings *settings, const BYTE *capsFlags, const BYTE **capsData, const UINT32 *capsSizes, UINT32 capsCount, BOOL serverReceivedCaps)
Parse capability data and apply to settings.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_pointer(rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, const void *val)
Set a pointer to value val.
FREERDP_API rdpSettings * freerdp_settings_new(DWORD flags)
creates a new setting struct
WINPR_ATTR_NODISCARD FREERDP_API char * freerdp_settings_get_string_writable(rdpSettings *settings, FreeRDP_Settings_Keys_String id)
Returns a string settings value.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_server_name(const rdpSettings *settings)
A helper function to return the correct server name.
FREERDP_API rdpSettings * freerdp_settings_clone(const rdpSettings *settings)
Creates a deep copy of settings.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_int64(rdpSettings *settings, FreeRDP_Settings_Keys_Int64 id, INT64 val)
Sets a INT64 settings value.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_string(const rdpSettings *settings, FreeRDP_Settings_Keys_String id)
Returns a immutable string settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_bool(rdpSettings *settings, FreeRDP_Settings_Keys_Bool id, BOOL val)
Sets a BOOL settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_copy_item(rdpSettings *dst, const rdpSettings *src, SSIZE_T id)
copies one setting identified by id from src to dst
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_string_len(rdpSettings *settings, FreeRDP_Settings_Keys_String id, const char *val, size_t len)
Sets a string settings value. The val is copied.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_device_collection_del(rdpSettings *settings, const RDPDR_DEVICE *device)
Removed a device from the settings, returns ownership of the allocated device to caller.
WINPR_ATTR_NODISCARD FREERDP_API SSIZE_T freerdp_settings_get_type_for_name(const char *value)
Get a key type for the name string of that key.
WINPR_ATTR_NODISCARD FREERDP_API INT32 freerdp_settings_get_int32(const rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id)
Returns a INT32 settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_string_from_utf16(rdpSettings *settings, FreeRDP_Settings_Keys_String id, const WCHAR *param)
Sets a string settings value. The param is converted to UTF-8 and the copy stored.
WINPR_ATTR_NODISCARD FREERDP_API char * freerdp_settings_get_config_path(void)
return the configuration directory for the library
WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_writable(rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id)
Returns a mutable pointer settings value.
WINPR_ATTR_NODISCARD FREERDP_API rdpSettings * freerdp_settings_deserialize(const char *jstr, size_t length)
A function that converts a JSON string to a rdpSettings struct.
WINPR_ATTR_NODISCARD FREERDP_API UINT32 freerdp_settings_get_codecs_flags(const rdpSettings *settings)
helper function to get a mask of supported codec flags.
WINPR_ATTR_NODISCARD FREERDP_API UINT16 freerdp_settings_get_uint16(const rdpSettings *settings, FreeRDP_Settings_Keys_UInt16 id)
Returns a UINT16 settings value.
WINPR_ATTR_NODISCARD FREERDP_API UINT64 freerdp_settings_get_uint64(const rdpSettings *settings, FreeRDP_Settings_Keys_UInt64 id)
Returns a UINT64 settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_copy(rdpSettings *dst, const rdpSettings *src)
Deep copies settings from src to dst.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_uint32(rdpSettings *settings, FreeRDP_Settings_Keys_UInt32 id, UINT32 val)
Sets a UINT32 settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_pointer_len(rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, const void *data, size_t len)
Set a pointer to value data.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_uint64(rdpSettings *settings, FreeRDP_Settings_Keys_UInt64 id, UINT64 val)
Sets a UINT64 settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_int16(rdpSettings *settings, FreeRDP_Settings_Keys_Int16 id, INT16 val)
Sets a INT16 settings value.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_int32(rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id, INT32 val)
Sets a INT32 settings value.
FREERDP_API void freerdp_settings_free(rdpSettings *settings)
Free a settings struct with all data in it.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_type_name_for_key(SSIZE_T key)
Returns the type name for a key.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_append_string(rdpSettings *settings, FreeRDP_Settings_Keys_String id, const char *separator, const char *param)
appends a string to a settings value. The param is copied. If the initial value of the setting was no...
WINPR_ATTR_NODISCARD FREERDP_API INT16 freerdp_settings_get_int16(const rdpSettings *settings, FreeRDP_Settings_Keys_Int16 id)
Returns a INT16 settings value.
WINPR_ATTR_NODISCARD FREERDP_API SSIZE_T freerdp_settings_get_key_for_name(const char *value)
Get a key index for the name string of that key.
WINPR_ATTR_NODISCARD FREERDP_API UINT32 freerdp_settings_get_uint32(const rdpSettings *settings, FreeRDP_Settings_Keys_UInt32 id)
Returns a UINT32 settings value.
WINPR_ATTR_NODISCARD FREERDP_API INT64 freerdp_settings_get_int64(const rdpSettings *settings, FreeRDP_Settings_Keys_Int64 id)
Returns a INT64 settings value.
FREERDP_API WCHAR * freerdp_settings_get_string_as_utf16(const rdpSettings *settings, FreeRDP_Settings_Keys_String id, size_t *pCharLen)
Return an allocated UTF16 string.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_rdp_version_string(UINT32 version)
Returns a stringified representation of the RDP protocol version.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_are_valid(const rdpSettings *settings)
Returns TRUE if settings are in a valid state, FALSE otherwise.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_uint16(rdpSettings *settings, FreeRDP_Settings_Keys_UInt16 id, UINT16 val)
Sets a UINT16 settings value.
WINPR_ATTR_NODISCARD FREERDP_API char * freerdp_settings_serialize(const rdpSettings *settings, BOOL pretty, size_t *plength)
A function that converts a rdpSettings struct to a JSON serialized string.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_monitor_def_array_sorted(rdpSettings *settings, const rdpMonitor *monitors, size_t count)
Sort monitor array according to:
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_rail_support_flags_to_string(UINT32 flags, char *buffer, size_t length)
Returns a stringified representation of RAIL support flags.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_set_gateway_usage_method(rdpSettings *settings, UINT32 GatewayUsageMethod)
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_set_string(rdpSettings *settings, FreeRDP_Settings_Keys_String id, const char *val)
Sets a string settings value. The param is copied.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_rdpdr_dtyp_string(UINT32 type)
Returns a string representation of RDPDR_DTYP_*.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_supported_color_depths_string(UINT16 mask, char *buffer, size_t size)
returns a string representation of RNS_UD_XXBPP_SUPPORT values
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_get_bool(const rdpSettings *settings, FreeRDP_Settings_Keys_Bool id)
Returns a boolean settings value.
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_name_for_key(SSIZE_T key)
Returns the type name for a key.
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_print_diff(wLog *log, DWORD level, const rdpSettings *settings, const rdpSettings *other)
Dumps the difference between two settings structs to a WLog.
WINPR_ATTR_NODISCARD FREERDP_API SSIZE_T freerdp_settings_get_type_for_key(SSIZE_T key)
Get a key type for the key index.