FreeRDP
Loading...
Searching...
No Matches
rdpSettings

This is the FreeRDP settings module. More...

Data Structures

struct  TARGET_NET_ADDRESS
 
struct  ARC_CS_PRIVATE_PACKET
 
struct  ARC_SC_PRIVATE_PACKET
 
struct  ADDIN_ARGV
 
struct  rdp_ext_set
 
struct  BITMAP_CACHE_CELL_INFO
 
struct  BITMAP_CACHE_V2_CELL_INFO
 
struct  GLYPH_CACHE_DEFINITION
 
struct  MONITOR_DEF
 
struct  MONITOR_ATTRIBUTES
 
struct  rdpMonitor
 
struct  RDPDR_DEVICE
 
struct  RDPDR_DRIVE
 
struct  RDPDR_PRINTER
 
struct  RDPDR_SMARTCARD
 
struct  RDPDR_SERIAL
 
struct  RDPDR_PARALLEL
 
struct  rdpSettings
 

Macros

#define FREERDP_SETTINGS_SERVER_MODE   0x00000001
 
#define FREERDP_SETTINGS_REMOTE_MODE   0x00000002
 
#define SURFCMDS_SET_SURFACE_BITS   0x00000002 /** @since version 3.7.0 */
 
#define SURFCMDS_FRAME_MARKER   0x00000010 /** @since version 3.7.0 */
 
#define SURFCMDS_STREAM_SURFACE_BITS   0x00000040 /** @since version 3.7.0 */
 
#define RAIL_LEVEL_SUPPORTED   0x00000001
 
#define RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED   0x00000002
 
#define RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED   0x00000004
 
#define RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED   0x00000008
 
#define RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED   0x00000010
 
#define RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED   0x00000020
 
#define RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED   0x00000040
 
#define RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED   0x00000080
 
#define PERF_FLAG_NONE   0x00000000
 
#define PERF_DISABLE_WALLPAPER   0x00000001
 
#define PERF_DISABLE_FULLWINDOWDRAG   0x00000002
 
#define PERF_DISABLE_MENUANIMATIONS   0x00000004
 
#define PERF_DISABLE_THEMING   0x00000008
 
#define PERF_DISABLE_CURSOR_SHADOW   0x00000020
 
#define PERF_DISABLE_CURSORSETTINGS   0x00000040
 
#define PERF_ENABLE_FONT_SMOOTHING   0x00000080
 
#define PERF_ENABLE_DESKTOP_COMPOSITION   0x00000100
 
#define CONNECTION_TYPE_INVALID
 
#define CONNECTION_TYPE_MODEM   0x01
 
#define CONNECTION_TYPE_BROADBAND_LOW   0x02
 
#define CONNECTION_TYPE_SATELLITE   0x03
 
#define CONNECTION_TYPE_BROADBAND_HIGH   0x04
 
#define CONNECTION_TYPE_WAN   0x05
 
#define CONNECTION_TYPE_LAN   0x06
 
#define CONNECTION_TYPE_AUTODETECT   0x07
 
#define CS_CORE   0xC001
 
#define CS_SECURITY   0xC002
 
#define CS_NET   0xC003
 
#define CS_CLUSTER   0xC004
 
#define CS_MONITOR   0xC005
 
#define CS_MCS_MSGCHANNEL   0xC006
 
#define CS_MONITOR_EX   0xC008
 
#define CS_UNUSED1   0xC00C
 
#define CS_MULTITRANSPORT   0xC00A
 
#define SC_CORE   0x0C01
 
#define SC_SECURITY   0x0C02
 
#define SC_NET   0x0C03
 
#define SC_MCS_MSGCHANNEL   0x0C04
 
#define SC_MULTITRANSPORT   0x0C08
 
#define RNS_UD_COLOR_4BPP   0xCA00
 
#define RNS_UD_COLOR_8BPP   0xCA01
 
#define RNS_UD_COLOR_16BPP_555   0xCA02
 
#define RNS_UD_COLOR_16BPP_565   0xCA03
 
#define RNS_UD_COLOR_24BPP   0xCA04
 
#define RNS_UD_SAS_DEL   0xAA03
 
#define RNS_UD_24BPP_SUPPORT   0x0001
 
#define RNS_UD_16BPP_SUPPORT   0x0002
 
#define RNS_UD_15BPP_SUPPORT   0x0004
 
#define RNS_UD_32BPP_SUPPORT   0x0008
 
#define AUDIO_MODE_REDIRECT   0 /* Bring to this computer */
 
#define AUDIO_MODE_PLAY_ON_SERVER   1 /* Leave at remote computer */
 
#define AUDIO_MODE_NONE   2 /* Do not play */
 
#define RNS_UD_CS_SUPPORT_ERRINFO_PDU   0x0001
 
#define RNS_UD_CS_WANT_32BPP_SESSION   0x0002
 
#define RNS_UD_CS_SUPPORT_STATUSINFO_PDU   0x0004
 
#define RNS_UD_CS_STRONG_ASYMMETRIC_KEYS   0x0008
 
#define RNS_UD_CS_RELATIVE_MOUSE_INPUT   0x0010
 
#define RNS_UD_CS_VALID_CONNECTION_TYPE   0x0020
 
#define RNS_UD_CS_SUPPORT_MONITOR_LAYOUT_PDU   0x0040
 
#define RNS_UD_CS_SUPPORT_NETCHAR_AUTODETECT   0x0080
 
#define RNS_UD_CS_SUPPORT_DYNVC_GFX_PROTOCOL   0x0100
 
#define RNS_UD_CS_SUPPORT_DYNAMIC_TIME_ZONE   0x0200
 
#define RNS_UD_CS_SUPPORT_HEARTBEAT_PDU   0x0400
 
#define RNS_UD_CS_SUPPORT_SKIP_CHANNELJOIN   0x0800
 
#define RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V1   0x00000001
 
#define RNS_UD_SC_DYNAMIC_DST_SUPPORTED   0x00000002
 
#define RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V2   0x00000004
 
#define RNS_UD_SC_SKIP_CHANNELJOIN_SUPPORTED   0x00000008
 
#define REDIRECTION_SUPPORTED   0x00000001
 
#define REDIRECTED_SESSIONID_FIELD_VALID   0x00000002
 
#define REDIRECTED_SMARTCARD   0x00000040
 
#define ServerSessionRedirectionVersionMask   0x0000003c
 
#define REDIRECTION_VERSION1   0x00
 
#define REDIRECTION_VERSION2   0x01
 
#define REDIRECTION_VERSION3   0x02
 
#define REDIRECTION_VERSION4   0x03
 
#define REDIRECTION_VERSION5   0x04
 
#define REDIRECTION_VERSION6   0x05
 
#define MONITOR_PRIMARY   0x00000001
 
#define ENCRYPTION_METHOD_NONE   0x00000000
 
#define ENCRYPTION_METHOD_40BIT   0x00000001
 
#define ENCRYPTION_METHOD_128BIT   0x00000002
 
#define ENCRYPTION_METHOD_56BIT   0x00000008
 
#define ENCRYPTION_METHOD_FIPS   0x00000010
 
#define ENCRYPTION_LEVEL_NONE   0x00000000
 
#define ENCRYPTION_LEVEL_LOW   0x00000001
 
#define ENCRYPTION_LEVEL_CLIENT_COMPATIBLE   0x00000002
 
#define ENCRYPTION_LEVEL_HIGH   0x00000003
 
#define ENCRYPTION_LEVEL_FIPS   0x00000004
 
#define TRANSPORT_TYPE_UDP_FECR   0x00000001
 
#define TRANSPORT_TYPE_UDP_FECL   0x00000004
 
#define TRANSPORT_TYPE_UDP_PREFERRED   0x00000100
 
#define SOFTSYNC_TCP_TO_UDP   0x00000200
 
#define CHANNEL_OPTION_INITIALIZED   0x80000000
 
#define CHANNEL_OPTION_ENCRYPT_RDP   0x40000000
 
#define CHANNEL_OPTION_ENCRYPT_SC   0x20000000
 
#define CHANNEL_OPTION_ENCRYPT_CS   0x10000000
 
#define CHANNEL_OPTION_PRI_HIGH   0x08000000
 
#define CHANNEL_OPTION_PRI_MED   0x04000000
 
#define CHANNEL_OPTION_PRI_LOW   0x02000000
 
#define CHANNEL_OPTION_COMPRESS_RDP   0x00800000
 
#define CHANNEL_OPTION_COMPRESS   0x00400000
 
#define CHANNEL_OPTION_SHOW_PROTOCOL   0x00200000
 
#define CHANNEL_REMOTE_CONTROL_PERSISTENT   0x00100000
 
#define VCCAPS_NO_COMPR   0x00000000
 
#define VCCAPS_COMPR_SC   0x00000001
 
#define VCCAPS_COMPR_CS_8K   0x00000002
 
#define LARGE_POINTER_FLAG_96x96   0x00000001
 
#define LARGE_POINTER_FLAG_384x384   0x00000002
 
#define AUTO_RECONNECT_VERSION_1   0x00000001
 
#define MSTSC_COOKIE_MAX_LENGTH   9
 
#define DEFAULT_COOKIE_MAX_LENGTH   0xFF
 
#define TS_CAPS_PROTOCOLVERSION   0x200 /** @since version 3.6.0 */
 
#define GLYPH_SUPPORT_NONE   0x0000
 
#define GLYPH_SUPPORT_PARTIAL   0x0001
 
#define GLYPH_SUPPORT_FULL   0x0002
 
#define GLYPH_SUPPORT_ENCODE   0x0003
 
#define TSC_PROXY_MODE_NONE_DIRECT   0x0
 
#define TSC_PROXY_MODE_DIRECT   0x1
 
#define TSC_PROXY_MODE_DETECT   0x2
 
#define TSC_PROXY_MODE_DEFAULT   0x3
 
#define TSC_PROXY_MODE_NONE_DETECT   0x4
 
#define TSC_PROXY_CREDS_MODE_USERPASS   0x0
 
#define TSC_PROXY_CREDS_MODE_SMARTCARD   0x1
 
#define TSC_PROXY_CREDS_MODE_ANY   0x2
 
#define KEYBOARD_HOOK_LOCAL   0
 
#define KEYBOARD_HOOK_REMOTE   1
 
#define KEYBOARD_HOOK_FULLSCREEN_ONLY   2
 
#define LOGON_MSG_SESSION_BUSY_OPTIONS   0xFFFFFFF8
 
#define LOGON_MSG_DISCONNECT_REFUSED   0xFFFFFFF9
 
#define LOGON_MSG_NO_PERMISSION   0xFFFFFFFA
 
#define LOGON_MSG_BUMP_OPTIONS   0xFFFFFFFB
 
#define LOGON_MSG_RECONNECT_OPTIONS   0xFFFFFFFC
 
#define LOGON_MSG_SESSION_TERMINATE   0xFFFFFFFD
 
#define LOGON_MSG_SESSION_CONTINUE   0xFFFFFFFE
 
#define ERROR_CODE_ACCESS_DENIED   0xFFFFFFFF
 
#define LOGON_FAILED_BAD_PASSWORD   0x00000000
 
#define LOGON_FAILED_UPDATE_PASSWORD   0x00000001
 
#define LOGON_FAILED_OTHER   0x00000002
 
#define LOGON_WARNING   0x00000003
 
#define STATUS_FINDING_DESTINATION   0x00000401
 
#define STATUS_LOADING_DESTINATION   0x00000402
 
#define STATUS_BRINGING_SESSION_ONLINE   0x00000403
 
#define STATUS_REDIRECTING_TO_DESTINATION   0x00000404
 
#define STATUS_VM_LOADING   0x00000501
 
#define STATUS_VM_WAKING   0x00000502
 
#define STATUS_VM_BOOTING   0x00000503
 
#define PACKET_COMPR_TYPE_8K   0x00
 
#define PACKET_COMPR_TYPE_64K   0x01
 
#define PACKET_COMPR_TYPE_RDP6   0x02
 
#define PACKET_COMPR_TYPE_RDP61   0x03
 
#define PACKET_COMPR_TYPE_RDP8   0x04
 
#define CLIPRDR_FLAG_LOCAL_TO_REMOTE   0x01
 
#define CLIPRDR_FLAG_LOCAL_TO_REMOTE_FILES   0x02
 
#define CLIPRDR_FLAG_REMOTE_TO_LOCAL   0x10
 
#define CLIPRDR_FLAG_REMOTE_TO_LOCAL_FILES   0x20
 
#define CLIPRDR_FLAG_DEFAULT_MASK
 
#define FREERDP_MONITOR_OVERRIDE_ORIENTATION   (1 << 0) /** @since version 3.15.0 */
 
#define FREERDP_MONITOR_OVERRIDE_DESKTOP_SCALE   (1 << 1) /** @since version 3.15.0 */
 
#define FREERDP_MONITOR_OVERRIDE_DEVICE_SCALE   (1 << 2) /** @since version 3.15.0 */
 
#define PROXY_TYPE_NONE   0
 
#define PROXY_TYPE_HTTP   1
 
#define PROXY_TYPE_SOCKS   2
 
#define PROXY_TYPE_IGNORE   0xFFFF
 
#define THREADING_FLAGS_DISABLE_THREADS   0x00000001
 
#define FREERDP_SETTINGS_SERVER_MODE   0x00000001
 
#define SETTINGS_DEPRECATED(x)   WINPR_DEPRECATED(x)
 

Enumerations

enum  RDP_VERSION {
  RDP_VERSION_4 = 0x00080001 , RDP_VERSION_5_PLUS = 0x00080004 , RDP_VERSION_10_0 = 0x00080005 , RDP_VERSION_10_1 = 0x00080006 ,
  RDP_VERSION_10_2 = 0x00080007 , RDP_VERSION_10_3 = 0x00080008 , RDP_VERSION_10_4 = 0x00080009 , RDP_VERSION_10_5 = 0x0008000a ,
  RDP_VERSION_10_6 = 0x0008000b , RDP_VERSION_10_7 = 0x0008000C , RDP_VERSION_10_8 = 0x0008000D , RDP_VERSION_10_9 = 0x0008000E ,
  RDP_VERSION_10_10 = 0x0008000F , RDP_VERSION_10_11 = 0x00080010 , RDP_VERSION_10_12 = 0x00080011
}
 
enum  FreeRDP_OrderSupportFlagConstants {
  NEG_DSTBLT_INDEX = 0x00 , NEG_PATBLT_INDEX = 0x01 , NEG_SCRBLT_INDEX = 0x02 , NEG_MEMBLT_INDEX = 0x03 ,
  NEG_MEM3BLT_INDEX = 0x04 , NEG_ATEXTOUT_INDEX = 0x05 , NEG_AEXTTEXTOUT_INDEX = 0x06 , NEG_DRAWNINEGRID_INDEX = 0x07 ,
  NEG_LINETO_INDEX = 0x08 , NEG_MULTI_DRAWNINEGRID_INDEX = 0x09 , NEG_OPAQUE_RECT_INDEX = 0x0A , NEG_SAVEBITMAP_INDEX = 0x0B ,
  NEG_WTEXTOUT_INDEX = 0x0C , NEG_MEMBLT_V2_INDEX = 0x0D , NEG_MEM3BLT_V2_INDEX = 0x0E , NEG_MULTIDSTBLT_INDEX = 0x0F ,
  NEG_MULTIPATBLT_INDEX = 0x10 , NEG_MULTISCRBLT_INDEX = 0x11 , NEG_MULTIOPAQUERECT_INDEX = 0x12 , NEG_FAST_INDEX_INDEX = 0x13 ,
  NEG_POLYGON_SC_INDEX = 0x14 , NEG_POLYGON_CB_INDEX = 0x15 , NEG_POLYLINE_INDEX = 0x16 , NEG_UNUSED23_INDEX = 0x17 ,
  NEG_FAST_GLYPH_INDEX = 0x18 , NEG_ELLIPSE_SC_INDEX = 0x19 , NEG_ELLIPSE_CB_INDEX = 0x1A , NEG_GLYPH_INDEX_INDEX = 0x1B ,
  NEG_GLYPH_WEXTTEXTOUT_INDEX = 0x1C , NEG_GLYPH_WLONGTEXTOUT_INDEX = 0x1D , NEG_GLYPH_WLONGEXTTEXTOUT_INDEX = 0x1E , NEG_UNUSED31_INDEX = 0x1F
}
 
enum  FreeRDP_DesktopRotationFlags { ORIENTATION_LANDSCAPE = 0 , ORIENTATION_PORTRAIT = 90 , ORIENTATION_LANDSCAPE_FLIPPED = 180 , ORIENTATION_PORTRAIT_FLIPPED = 270 }
 
enum  FreeRDP_RDPDR_DTYP {
  RDPDR_DTYP_SERIAL = 0x00000001 , RDPDR_DTYP_PARALLEL = 0x00000002 , RDPDR_DTYP_PRINT = 0x00000004 , RDPDR_DTYP_FILESYSTEM = 0x00000008 ,
  RDPDR_DTYP_SMARTCARD = 0x00000020
}
 
enum  rdp_settings_type {
  RDP_SETTINGS_TYPE_BOOL , RDP_SETTINGS_TYPE_UINT16 , RDP_SETTINGS_TYPE_INT16 , RDP_SETTINGS_TYPE_UINT32 ,
  RDP_SETTINGS_TYPE_INT32 , RDP_SETTINGS_TYPE_UINT64 , RDP_SETTINGS_TYPE_INT64 , RDP_SETTINGS_TYPE_STRING ,
  RDP_SETTINGS_TYPE_POINTER
}
 

Functions

FREERDP_API void freerdp_settings_free (rdpSettings *settings)
 Free a settings struct with all data in it.
 
WINPR_ATTR_NODISCARD FREERDP_API rdpSettings * freerdp_settings_new (DWORD flags)
 creates a new setting struct
 
WINPR_ATTR_NODISCARD FREERDP_API rdpSettings * freerdp_settings_clone (const rdpSettings *settings)
 Creates a deep copy of settings.
 
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_copy_item (rdpSettings *dst, const rdpSettings *src, SSIZE_T id)
 copies one setting identified by id from src to dst
 
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 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.
 
FREERDP_API void freerdp_addin_argv_free (ADDIN_ARGV *args)
 
WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGVfreerdp_addin_argv_new (size_t argc, const char *const argv[])
 
WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGVfreerdp_addin_argv_clone (const ADDIN_ARGV *args)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_add_argument (ADDIN_ARGV *args, const char *argument)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_add_argument_ex (ADDIN_ARGV *args, const char *argument, size_t len)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_del_argument (ADDIN_ARGV *args, const char *argument)
 
WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_set_argument (ADDIN_ARGV *args, const char *argument)
 
WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_replace_argument (ADDIN_ARGV *args, const char *previous, const char *argument)
 
WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_set_argument_value (ADDIN_ARGV *args, const char *option, const char *value)
 
WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_replace_argument_value (ADDIN_ARGV *args, const char *previous, const char *option, const char *value)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_device_collection_add (rdpSettings *settings, RDPDR_DEVICE *device)
 
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 RDPDR_DEVICEfreerdp_device_collection_find (rdpSettings *settings, const char *name)
 
WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICEfreerdp_device_collection_find_type (rdpSettings *settings, UINT32 type)
 
FREERDP_API void freerdp_device_free (RDPDR_DEVICE *device)
 
WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICEfreerdp_device_new (UINT32 Type, size_t count, const char *const args[])
 
WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICEfreerdp_device_clone (const RDPDR_DEVICE *device)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_device_equal (const RDPDR_DEVICE *what, const RDPDR_DEVICE *other)
 
FREERDP_API void freerdp_device_collection_free (rdpSettings *settings)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_static_channel_collection_add (rdpSettings *settings, ADDIN_ARGV *channel)
 
FREERDP_API BOOL freerdp_static_channel_collection_del (rdpSettings *settings, const char *name)
 
WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGVfreerdp_static_channel_collection_find (rdpSettings *settings, const char *name)
 
FREERDP_API void freerdp_static_channel_collection_free (rdpSettings *settings)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_dynamic_channel_collection_add (rdpSettings *settings, ADDIN_ARGV *channel)
 
FREERDP_API BOOL freerdp_dynamic_channel_collection_del (rdpSettings *settings, const char *name)
 
WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGVfreerdp_dynamic_channel_collection_find (const rdpSettings *settings, const char *name)
 
FREERDP_API void freerdp_dynamic_channel_collection_free (rdpSettings *settings)
 
FREERDP_API void freerdp_capability_buffer_free (rdpSettings *settings)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_capability_buffer_copy (rdpSettings *settings, const rdpSettings *src)
 
FREERDP_API void freerdp_server_license_issuers_free (rdpSettings *settings)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_server_license_issuers_copy (rdpSettings *settings, char **issuers, UINT32 count)
 
FREERDP_API void freerdp_target_net_addresses_free (rdpSettings *settings)
 
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_target_net_addresses_copy (rdpSettings *settings, char **addresses, UINT32 count)
 
FREERDP_API void freerdp_performance_flags_make (rdpSettings *settings)
 
FREERDP_API void freerdp_performance_flags_split (rdpSettings *settings)
 
FREERDP_API BOOL freerdp_set_gateway_usage_method (rdpSettings *settings, UINT32 GatewayUsageMethod)
 
FREERDP_API void freerdp_update_gateway_usage_method (rdpSettings *settings, UINT32 GatewayEnabled, UINT32 GatewayBypassLocal)
 
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_get_bool (const rdpSettings *settings, FreeRDP_Settings_Keys_Bool id)
 Returns a boolean settings value.
 
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 INT16 freerdp_settings_get_int16 (const rdpSettings *settings, FreeRDP_Settings_Keys_Int16 id)
 Returns a INT16 settings value.
 
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 UINT16 freerdp_settings_get_uint16 (const rdpSettings *settings, FreeRDP_Settings_Keys_UInt16 id)
 Returns a UINT16 settings value.
 
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 INT32 freerdp_settings_get_int32 (const rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id)
 Returns a INT32 settings value.
 
FREERDP_API BOOL freerdp_settings_set_int32 (rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id, INT32 val)
 Sets a INT32 settings value.
 
WINPR_ATTR_NODISCARD FREERDP_API UINT32 freerdp_settings_get_uint32 (const rdpSettings *settings, FreeRDP_Settings_Keys_UInt32 id)
 Returns a UINT32 settings value.
 
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 INT64 freerdp_settings_get_int64 (const rdpSettings *settings, FreeRDP_Settings_Keys_Int64 id)
 Returns a INT64 settings value.
 
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 UINT64 freerdp_settings_get_uint64 (const rdpSettings *settings, FreeRDP_Settings_Keys_UInt64 id)
 Returns a UINT64 settings value.
 
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 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 char * freerdp_settings_get_string_writable (rdpSettings *settings, FreeRDP_Settings_Keys_String id)
 Returns a string settings value.
 
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.
 
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 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 not empty,
 
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.
 
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 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 void * freerdp_settings_get_pointer (const rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id)
 Returns a immutable pointer settings value.
 
WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_writable (rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id)
 Returns a mutable pointer settings value.
 
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 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 const void * freerdp_settings_get_pointer_array (const rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, size_t offset)
 
WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_array_writable (const rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, size_t offset)
 
FREERDP_API BOOL freerdp_settings_set_pointer_array (rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, size_t offset, const void *data)
 

to value \b value

Set a setting Both, key and value are provided as strings and parsed internally.

The value will be checked internally:

  • Integer types must be within boundaries
  • BOOL must be any of {'true', 'false', 'on', 'off', '0', '1'} (case insensitive)
  • Strings are passed on as is
  • Pointers are also passed as is
Parameters
settingsThe settings instance to set the value, must not be nullptr
nameThe name of the settings key (like 'FreeRDP_Domain', same as output of freerdp_settings_get_name_for_key ) Must not be nullptr
valueThe value of the setting. Must not be nullptr
Note
If the function fails check wLog output for details
Since
version 3.0.0
Returns
TRUE in case of success, FALSE otherwise.
FREERDP_API BOOL freerdp_settings_set_value_for_name (rdpSettings *settings, const char *name, const char *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 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 SSIZE_T freerdp_settings_get_type_for_key (SSIZE_T key)
 Get a key type for the key index.
 
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 const char * freerdp_settings_get_type_name_for_type (SSIZE_T type)
 Returns the type name for a type.
 
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 UINT32 freerdp_settings_get_codecs_flags (const rdpSettings *settings)
 helper function to get a mask of supported codec flags.
 
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 const char * freerdp_settings_get_server_name (const rdpSettings *settings)
 A helper function to return the correct server name.
 
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 const char * freerdp_rdp_version_string (UINT32 version)
 Returns a stringified representation of the RDP protocol version.
 
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_encryption_level_string (UINT32 EncryptionLevel)
 
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_encryption_methods_string (UINT32 EncryptionMethods, char *buffer, size_t size)
 
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 char * freerdp_settings_get_config_path (void)
 return the configuration directory for the library
 
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 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 rdpSettings * freerdp_settings_deserialize (const char *jstr, size_t length)
 A function that converts a JSON string to a rdpSettings struct.
 

Detailed Description

This is the FreeRDP settings module.

FreeRDP: A Remote Desktop Protocol Implementation RDP Settings

Copyright 2009-2011 Jay Sorg Copyright 2010-2012 Marc-Andre Moreau marca.nosp@m.ndre.nosp@m..more.nosp@m.au@g.nosp@m.mail..nosp@m.com Copyright 2016 Armin Novak armin.nosp@m..nov.nosp@m.ak@gm.nosp@m.ail..nosp@m.com Copyright 2023 Armin Novak anova.nosp@m.k@th.nosp@m.incas.nosp@m.t.co.nosp@m.m Copyright 2023 Thincast Technologies GmbH

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Settings are used to store configuration data for an RDP connection. There are 3 different settings for each client and server:

  1. The initial connection supplied by the user
  2. The settings sent from client or server during capability exchange
  3. The settings merged from the capability exchange and the initial configuration.

The lifetime of the settings is as follows:

  1. Initial configuration is saved and will be valid for the whole application lifecycle
  2. The client or server settings from the other end are valid from capability exchange until the connection is ended (disconnect/redirect/...)
  3. The merged settings are created from the initial configuration and server settings and have the same lifetime, until the connection ends

So, when accessing the settings always ensure to know which one you are operating on! (this is especially important for the proxy where you have a RDP client and RDP server in the same application context)

FreeRDP: A Remote Desktop Protocol Implementation RDP Settings

Copyright 2009-2011 Jay Sorg Copyright 2010-2012 Marc-Andre Moreau marca.nosp@m.ndre.nosp@m..more.nosp@m.au@g.nosp@m.mail..nosp@m.com Copyright 2016 Armin Novak armin.nosp@m..nov.nosp@m.ak@gm.nosp@m.ail..nosp@m.com Copyright 2023 Armin Novak anova.nosp@m.k@th.nosp@m.incas.nosp@m.t.co.nosp@m.m Copyright 2023 Thincast Technologies GmbH

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

FreeRDP: A Remote Desktop Protocol Implementation Internal settings header for functions not exported

Copyright 2018 Armin Novak armin.nosp@m..nov.nosp@m.ak@th.nosp@m.inca.nosp@m.st.co.nosp@m.m Copyright 2018 Thincast Technologies GmbH

Licensed under the Apache License, Version 2.0 (the "License") you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.


Data Structure Documentation

◆ TARGET_NET_ADDRESS

struct TARGET_NET_ADDRESS

Definition at line 293 of file settings_types.h.

Data Fields
LPWSTR Address
UINT32 Length

◆ ARC_CS_PRIVATE_PACKET

struct ARC_CS_PRIVATE_PACKET

Definition at line 355 of file settings_types.h.

Data Fields
UINT32 cbLen
UINT32 logonId
BYTE securityVerifier[16]
UINT32 version

◆ ARC_SC_PRIVATE_PACKET

struct ARC_SC_PRIVATE_PACKET

Definition at line 364 of file settings_types.h.

Data Fields
BYTE arcRandomBits[16]
UINT32 cbLen
UINT32 logonId
UINT32 version

◆ ADDIN_ARGV

struct ADDIN_ARGV

Definition at line 374 of file settings_types.h.

Data Fields
int argc
char ** argv

◆ rdp_ext_set

struct rdp_ext_set

Definition at line 382 of file settings_types.h.

Data Fields
void * data
char name[256]

◆ BITMAP_CACHE_CELL_INFO

struct BITMAP_CACHE_CELL_INFO

Definition at line 390 of file settings_types.h.

Data Fields
UINT16 maxSize
UINT16 numEntries

◆ BITMAP_CACHE_V2_CELL_INFO

struct BITMAP_CACHE_V2_CELL_INFO

Definition at line 396 of file settings_types.h.

Data Fields
UINT32 numEntries
BOOL persistent

◆ GLYPH_CACHE_DEFINITION

struct GLYPH_CACHE_DEFINITION

Definition at line 404 of file settings_types.h.

Data Fields
UINT16 cacheEntries
UINT16 cacheMaximumCellSize

◆ MONITOR_DEF

struct MONITOR_DEF

Definition at line 412 of file settings_types.h.

Data Fields
INT32 bottom
UINT32 flags
INT32 left
INT32 right
INT32 top

◆ MONITOR_ATTRIBUTES

struct MONITOR_ATTRIBUTES

Definition at line 421 of file settings_types.h.

Data Fields
UINT32 desktopScaleFactor
UINT32 deviceScaleFactor
UINT32 orientation
UINT32 physicalHeight
UINT32 physicalWidth

◆ rdpMonitor

struct rdpMonitor

Definition at line 430 of file settings_types.h.

Collaboration diagram for rdpMonitor:
Data Fields
MONITOR_ATTRIBUTES attributes
INT32 height
UINT32 is_primary
UINT32 orig_screen
INT32 width
INT32 x
INT32 y

◆ RDPDR_DEVICE

struct RDPDR_DEVICE

Definition at line 451 of file settings_types.h.

Data Fields
UINT32 Id
char * Name
UINT32 Type

◆ RDPDR_DRIVE

struct RDPDR_DRIVE

Definition at line 458 of file settings_types.h.

Collaboration diagram for RDPDR_DRIVE:
Data Fields
BOOL automount
RDPDR_DEVICE device
char * Path

◆ RDPDR_PRINTER

struct RDPDR_PRINTER

Definition at line 465 of file settings_types.h.

Collaboration diagram for RDPDR_PRINTER:
Data Fields
RDPDR_DEVICE device
char * DriverName
BOOL IsDefault

◆ RDPDR_SMARTCARD

struct RDPDR_SMARTCARD

Definition at line 472 of file settings_types.h.

Collaboration diagram for RDPDR_SMARTCARD:
Data Fields
RDPDR_DEVICE device

◆ RDPDR_SERIAL

struct RDPDR_SERIAL

Definition at line 477 of file settings_types.h.

Collaboration diagram for RDPDR_SERIAL:
Data Fields
RDPDR_DEVICE device
char * Driver
char * Path
char * Permissive

◆ RDPDR_PARALLEL

struct RDPDR_PARALLEL

Definition at line 485 of file settings_types.h.

Collaboration diagram for RDPDR_PARALLEL:
Data Fields
RDPDR_DEVICE device
char * Path

Macro Definition Documentation

◆ AUDIO_MODE_NONE

#define AUDIO_MODE_NONE   2 /* Do not play */

Definition at line 144 of file settings_types.h.

◆ AUDIO_MODE_PLAY_ON_SERVER

#define AUDIO_MODE_PLAY_ON_SERVER   1 /* Leave at remote computer */

Definition at line 143 of file settings_types.h.

◆ AUDIO_MODE_REDIRECT

#define AUDIO_MODE_REDIRECT   0 /* Bring to this computer */

Definition at line 142 of file settings_types.h.

◆ AUTO_RECONNECT_VERSION_1

#define AUTO_RECONNECT_VERSION_1   0x00000001

Definition at line 224 of file settings_types.h.

◆ CHANNEL_OPTION_COMPRESS

#define CHANNEL_OPTION_COMPRESS   0x00400000

Definition at line 210 of file settings_types.h.

◆ CHANNEL_OPTION_COMPRESS_RDP

#define CHANNEL_OPTION_COMPRESS_RDP   0x00800000

Definition at line 209 of file settings_types.h.

◆ CHANNEL_OPTION_ENCRYPT_CS

#define CHANNEL_OPTION_ENCRYPT_CS   0x10000000

Definition at line 205 of file settings_types.h.

◆ CHANNEL_OPTION_ENCRYPT_RDP

#define CHANNEL_OPTION_ENCRYPT_RDP   0x40000000

Definition at line 203 of file settings_types.h.

◆ CHANNEL_OPTION_ENCRYPT_SC

#define CHANNEL_OPTION_ENCRYPT_SC   0x20000000

Definition at line 204 of file settings_types.h.

◆ CHANNEL_OPTION_INITIALIZED

#define CHANNEL_OPTION_INITIALIZED   0x80000000

Definition at line 202 of file settings_types.h.

◆ CHANNEL_OPTION_PRI_HIGH

#define CHANNEL_OPTION_PRI_HIGH   0x08000000

Definition at line 206 of file settings_types.h.

◆ CHANNEL_OPTION_PRI_LOW

#define CHANNEL_OPTION_PRI_LOW   0x02000000

Definition at line 208 of file settings_types.h.

◆ CHANNEL_OPTION_PRI_MED

#define CHANNEL_OPTION_PRI_MED   0x04000000

Definition at line 207 of file settings_types.h.

◆ CHANNEL_OPTION_SHOW_PROTOCOL

#define CHANNEL_OPTION_SHOW_PROTOCOL   0x00200000

Definition at line 211 of file settings_types.h.

◆ CHANNEL_REMOTE_CONTROL_PERSISTENT

#define CHANNEL_REMOTE_CONTROL_PERSISTENT   0x00100000

Definition at line 212 of file settings_types.h.

◆ CLIPRDR_FLAG_DEFAULT_MASK

#define CLIPRDR_FLAG_DEFAULT_MASK
Value:
(CLIPRDR_FLAG_LOCAL_TO_REMOTE | CLIPRDR_FLAG_LOCAL_TO_REMOTE_FILES | \
CLIPRDR_FLAG_REMOTE_TO_LOCAL | CLIPRDR_FLAG_REMOTE_TO_LOCAL_FILES)

Definition at line 345 of file settings_types.h.

359 {
360 UINT32 cbLen;
361 UINT32 version;
362 UINT32 logonId;
363 BYTE securityVerifier[16];
365
366 /* ARC_SC_PRIVATE_PACKET */
367 typedef struct
368 {
369 UINT32 cbLen;
370 UINT32 version;
371 UINT32 logonId;
372 BYTE arcRandomBits[16];
374
375 /* Channels */
376
377 typedef struct
378 {
379 int argc;
380 char** argv;
381 } ADDIN_ARGV;
382
383 /* Extensions */
384
385 struct rdp_ext_set
386 {
387 char name[256]; /* plugin name or path */
388 void* data; /* plugin data */
389 };
390
391 /* Bitmap Cache */
392
393 typedef struct
394 {
395 UINT16 numEntries;
396 UINT16 maxSize;
398
399 typedef struct
400 {
401 UINT32 numEntries;
402 BOOL persistent;
404
405 /* Glyph Cache */
406
407 typedef struct
408 {
409 UINT16 cacheEntries;
410 UINT16 cacheMaximumCellSize;
412
413 /* Monitors */
414
415 typedef struct
416 {
417 INT32 left;
418 INT32 top;
419 INT32 right;
420 INT32 bottom;
421 UINT32 flags;
422 } MONITOR_DEF;
423
424 typedef struct
425 {
426 UINT32 physicalWidth;
427 UINT32 physicalHeight;
428 UINT32 orientation;
429 UINT32 desktopScaleFactor;
430 UINT32 deviceScaleFactor;
432
433 typedef struct
434 {
435 INT32 x;
436 INT32 y;
437 INT32 width;
438 INT32 height;
439 UINT32 is_primary;
440 UINT32 orig_screen;
441 MONITOR_ATTRIBUTES attributes;
442 } rdpMonitor;
443
444 /* Device Redirection */
445 typedef enum
446 {
447 RDPDR_DTYP_SERIAL = 0x00000001,
448 RDPDR_DTYP_PARALLEL = 0x00000002,
449 RDPDR_DTYP_PRINT = 0x00000004,
450 RDPDR_DTYP_FILESYSTEM = 0x00000008,
451 RDPDR_DTYP_SMARTCARD = 0x00000020
452 } FreeRDP_RDPDR_DTYP;
453
454 typedef struct
455 {
456 UINT32 Id;
457 UINT32 Type;
458 char* Name;
459 } RDPDR_DEVICE;
460
461 typedef struct
462 {
463 RDPDR_DEVICE device;
464 char* Path;
465 BOOL automount;
466 } RDPDR_DRIVE;
467
468 typedef struct
469 {
470 RDPDR_DEVICE device;
471 char* DriverName;
472 BOOL IsDefault;
474
475 typedef struct
476 {
477 RDPDR_DEVICE device;
479
480 typedef struct
481 {
482 RDPDR_DEVICE device;
483 char* Path;
484 char* Driver;
485 char* Permissive;
486 } RDPDR_SERIAL;
487
488 typedef struct
489 {
490 RDPDR_DEVICE device;
491 char* Path;
493
494#define PROXY_TYPE_NONE 0
495#define PROXY_TYPE_HTTP 1
496#define PROXY_TYPE_SOCKS 2
497#define PROXY_TYPE_IGNORE 0xFFFF
498
499/* ThreadingFlags */
500#define THREADING_FLAGS_DISABLE_THREADS 0x00000001
501
502 enum rdp_settings_type
503 {
504 RDP_SETTINGS_TYPE_BOOL,
505 RDP_SETTINGS_TYPE_UINT16,
506 RDP_SETTINGS_TYPE_INT16,
507 RDP_SETTINGS_TYPE_UINT32,
508 RDP_SETTINGS_TYPE_INT32,
509 RDP_SETTINGS_TYPE_UINT64,
510 RDP_SETTINGS_TYPE_INT64,
511 RDP_SETTINGS_TYPE_STRING,
512 RDP_SETTINGS_TYPE_POINTER
513 };
514
518#define FREERDP_SETTINGS_SERVER_MODE 0x00000001
519
520#ifdef __cplusplus
521}
522#endif
523
526#endif /* FREERDP_SETTINGS_TYPES_H */

◆ CLIPRDR_FLAG_LOCAL_TO_REMOTE

#define CLIPRDR_FLAG_LOCAL_TO_REMOTE   0x01

Definition at line 340 of file settings_types.h.

◆ CLIPRDR_FLAG_LOCAL_TO_REMOTE_FILES

#define CLIPRDR_FLAG_LOCAL_TO_REMOTE_FILES   0x02

Definition at line 341 of file settings_types.h.

◆ CLIPRDR_FLAG_REMOTE_TO_LOCAL

#define CLIPRDR_FLAG_REMOTE_TO_LOCAL   0x10

Definition at line 342 of file settings_types.h.

◆ CLIPRDR_FLAG_REMOTE_TO_LOCAL_FILES

#define CLIPRDR_FLAG_REMOTE_TO_LOCAL_FILES   0x20

Definition at line 343 of file settings_types.h.

◆ CONNECTION_TYPE_AUTODETECT

#define CONNECTION_TYPE_AUTODETECT   0x07

Definition at line 82 of file settings_types.h.

◆ CONNECTION_TYPE_BROADBAND_HIGH

#define CONNECTION_TYPE_BROADBAND_HIGH   0x04

Definition at line 79 of file settings_types.h.

◆ CONNECTION_TYPE_BROADBAND_LOW

#define CONNECTION_TYPE_BROADBAND_LOW   0x02

Definition at line 77 of file settings_types.h.

◆ CONNECTION_TYPE_INVALID

#define CONNECTION_TYPE_INVALID
Value:
0x00

Definition at line 74 of file settings_types.h.

◆ CONNECTION_TYPE_LAN

#define CONNECTION_TYPE_LAN   0x06

Definition at line 81 of file settings_types.h.

◆ CONNECTION_TYPE_MODEM

#define CONNECTION_TYPE_MODEM   0x01

Definition at line 76 of file settings_types.h.

◆ CONNECTION_TYPE_SATELLITE

#define CONNECTION_TYPE_SATELLITE   0x03

Definition at line 78 of file settings_types.h.

◆ CONNECTION_TYPE_WAN

#define CONNECTION_TYPE_WAN   0x05

Definition at line 80 of file settings_types.h.

◆ CS_CLUSTER

#define CS_CLUSTER   0xC004

Definition at line 88 of file settings_types.h.

◆ CS_CORE

#define CS_CORE   0xC001

Definition at line 85 of file settings_types.h.

◆ CS_MCS_MSGCHANNEL

#define CS_MCS_MSGCHANNEL   0xC006

Definition at line 90 of file settings_types.h.

◆ CS_MONITOR

#define CS_MONITOR   0xC005

Definition at line 89 of file settings_types.h.

◆ CS_MONITOR_EX

#define CS_MONITOR_EX   0xC008

Definition at line 91 of file settings_types.h.

◆ CS_MULTITRANSPORT

#define CS_MULTITRANSPORT   0xC00A

Definition at line 93 of file settings_types.h.

◆ CS_NET

#define CS_NET   0xC003

Definition at line 87 of file settings_types.h.

◆ CS_SECURITY

#define CS_SECURITY   0xC002

Definition at line 86 of file settings_types.h.

◆ CS_UNUSED1

#define CS_UNUSED1   0xC00C

Definition at line 92 of file settings_types.h.

◆ DEFAULT_COOKIE_MAX_LENGTH

#define DEFAULT_COOKIE_MAX_LENGTH   0xFF

Definition at line 228 of file settings_types.h.

◆ ENCRYPTION_LEVEL_CLIENT_COMPATIBLE

#define ENCRYPTION_LEVEL_CLIENT_COMPATIBLE   0x00000002

Definition at line 191 of file settings_types.h.

◆ ENCRYPTION_LEVEL_FIPS

#define ENCRYPTION_LEVEL_FIPS   0x00000004

Definition at line 193 of file settings_types.h.

◆ ENCRYPTION_LEVEL_HIGH

#define ENCRYPTION_LEVEL_HIGH   0x00000003

Definition at line 192 of file settings_types.h.

◆ ENCRYPTION_LEVEL_LOW

#define ENCRYPTION_LEVEL_LOW   0x00000001

Definition at line 190 of file settings_types.h.

◆ ENCRYPTION_LEVEL_NONE

#define ENCRYPTION_LEVEL_NONE   0x00000000

Definition at line 189 of file settings_types.h.

◆ ENCRYPTION_METHOD_128BIT

#define ENCRYPTION_METHOD_128BIT   0x00000002

Definition at line 184 of file settings_types.h.

◆ ENCRYPTION_METHOD_40BIT

#define ENCRYPTION_METHOD_40BIT   0x00000001

Definition at line 183 of file settings_types.h.

◆ ENCRYPTION_METHOD_56BIT

#define ENCRYPTION_METHOD_56BIT   0x00000008

Definition at line 185 of file settings_types.h.

◆ ENCRYPTION_METHOD_FIPS

#define ENCRYPTION_METHOD_FIPS   0x00000010

Definition at line 186 of file settings_types.h.

◆ ENCRYPTION_METHOD_NONE

#define ENCRYPTION_METHOD_NONE   0x00000000

Definition at line 182 of file settings_types.h.

◆ ERROR_CODE_ACCESS_DENIED

#define ERROR_CODE_ACCESS_DENIED   0xFFFFFFFF

Definition at line 307 of file settings_types.h.

◆ FREERDP_MONITOR_OVERRIDE_DESKTOP_SCALE

#define FREERDP_MONITOR_OVERRIDE_DESKTOP_SCALE   (1 << 1) /** @since version 3.15.0 */

Definition at line 351 of file settings_types.h.

◆ FREERDP_MONITOR_OVERRIDE_DEVICE_SCALE

#define FREERDP_MONITOR_OVERRIDE_DEVICE_SCALE   (1 << 2) /** @since version 3.15.0 */

Definition at line 352 of file settings_types.h.

◆ FREERDP_MONITOR_OVERRIDE_ORIENTATION

#define FREERDP_MONITOR_OVERRIDE_ORIENTATION   (1 << 0) /** @since version 3.15.0 */

Definition at line 350 of file settings_types.h.

◆ FREERDP_SETTINGS_REMOTE_MODE

#define FREERDP_SETTINGS_REMOTE_MODE   0x00000002

Definition at line 81 of file include/freerdp/settings.h.

◆ FREERDP_SETTINGS_SERVER_MODE [1/2]

#define FREERDP_SETTINGS_SERVER_MODE   0x00000001

rdpSettings creation flags

Definition at line 80 of file include/freerdp/settings.h.

◆ FREERDP_SETTINGS_SERVER_MODE [2/2]

#define FREERDP_SETTINGS_SERVER_MODE   0x00000001

rdpSettings creation flags

Definition at line 515 of file settings_types.h.

◆ GLYPH_SUPPORT_ENCODE

#define GLYPH_SUPPORT_ENCODE   0x0003

Definition at line 274 of file settings_types.h.

◆ GLYPH_SUPPORT_FULL

#define GLYPH_SUPPORT_FULL   0x0002

Definition at line 273 of file settings_types.h.

◆ GLYPH_SUPPORT_NONE

#define GLYPH_SUPPORT_NONE   0x0000

Definition at line 271 of file settings_types.h.

◆ GLYPH_SUPPORT_PARTIAL

#define GLYPH_SUPPORT_PARTIAL   0x0001

Definition at line 272 of file settings_types.h.

◆ KEYBOARD_HOOK_FULLSCREEN_ONLY

#define KEYBOARD_HOOK_FULLSCREEN_ONLY   2

Definition at line 291 of file settings_types.h.

◆ KEYBOARD_HOOK_LOCAL

#define KEYBOARD_HOOK_LOCAL   0

Definition at line 289 of file settings_types.h.

◆ KEYBOARD_HOOK_REMOTE

#define KEYBOARD_HOOK_REMOTE   1

Definition at line 290 of file settings_types.h.

◆ LARGE_POINTER_FLAG_384x384

#define LARGE_POINTER_FLAG_384x384   0x00000002

Definition at line 221 of file settings_types.h.

◆ LARGE_POINTER_FLAG_96x96

#define LARGE_POINTER_FLAG_96x96   0x00000001

Definition at line 220 of file settings_types.h.

◆ LOGON_FAILED_BAD_PASSWORD

#define LOGON_FAILED_BAD_PASSWORD   0x00000000

Definition at line 309 of file settings_types.h.

◆ LOGON_FAILED_OTHER

#define LOGON_FAILED_OTHER   0x00000002

Definition at line 311 of file settings_types.h.

◆ LOGON_FAILED_UPDATE_PASSWORD

#define LOGON_FAILED_UPDATE_PASSWORD   0x00000001

Definition at line 310 of file settings_types.h.

◆ LOGON_MSG_BUMP_OPTIONS

#define LOGON_MSG_BUMP_OPTIONS   0xFFFFFFFB

Definition at line 303 of file settings_types.h.

◆ LOGON_MSG_DISCONNECT_REFUSED

#define LOGON_MSG_DISCONNECT_REFUSED   0xFFFFFFF9

Definition at line 301 of file settings_types.h.

◆ LOGON_MSG_NO_PERMISSION

#define LOGON_MSG_NO_PERMISSION   0xFFFFFFFA

Definition at line 302 of file settings_types.h.

◆ LOGON_MSG_RECONNECT_OPTIONS

#define LOGON_MSG_RECONNECT_OPTIONS   0xFFFFFFFC

Definition at line 304 of file settings_types.h.

◆ LOGON_MSG_SESSION_BUSY_OPTIONS

#define LOGON_MSG_SESSION_BUSY_OPTIONS   0xFFFFFFF8

Definition at line 300 of file settings_types.h.

◆ LOGON_MSG_SESSION_CONTINUE

#define LOGON_MSG_SESSION_CONTINUE   0xFFFFFFFE

Definition at line 306 of file settings_types.h.

◆ LOGON_MSG_SESSION_TERMINATE

#define LOGON_MSG_SESSION_TERMINATE   0xFFFFFFFD

Definition at line 305 of file settings_types.h.

◆ LOGON_WARNING

#define LOGON_WARNING   0x00000003

Definition at line 312 of file settings_types.h.

◆ MONITOR_PRIMARY

#define MONITOR_PRIMARY   0x00000001

Definition at line 179 of file settings_types.h.

◆ MSTSC_COOKIE_MAX_LENGTH

#define MSTSC_COOKIE_MAX_LENGTH   9

Definition at line 227 of file settings_types.h.

◆ PACKET_COMPR_TYPE_64K

#define PACKET_COMPR_TYPE_64K   0x01

Definition at line 325 of file settings_types.h.

◆ PACKET_COMPR_TYPE_8K

#define PACKET_COMPR_TYPE_8K   0x00

Definition at line 324 of file settings_types.h.

◆ PACKET_COMPR_TYPE_RDP6

#define PACKET_COMPR_TYPE_RDP6   0x02

Definition at line 326 of file settings_types.h.

◆ PACKET_COMPR_TYPE_RDP61

#define PACKET_COMPR_TYPE_RDP61   0x03

Definition at line 327 of file settings_types.h.

◆ PACKET_COMPR_TYPE_RDP8

#define PACKET_COMPR_TYPE_RDP8   0x04

Definition at line 328 of file settings_types.h.

◆ PERF_DISABLE_CURSOR_SHADOW

#define PERF_DISABLE_CURSOR_SHADOW   0x00000020

Definition at line 68 of file settings_types.h.

◆ PERF_DISABLE_CURSORSETTINGS

#define PERF_DISABLE_CURSORSETTINGS   0x00000040

Definition at line 69 of file settings_types.h.

◆ PERF_DISABLE_FULLWINDOWDRAG

#define PERF_DISABLE_FULLWINDOWDRAG   0x00000002

Definition at line 65 of file settings_types.h.

◆ PERF_DISABLE_MENUANIMATIONS

#define PERF_DISABLE_MENUANIMATIONS   0x00000004

Definition at line 66 of file settings_types.h.

◆ PERF_DISABLE_THEMING

#define PERF_DISABLE_THEMING   0x00000008

Definition at line 67 of file settings_types.h.

◆ PERF_DISABLE_WALLPAPER

#define PERF_DISABLE_WALLPAPER   0x00000001

Definition at line 64 of file settings_types.h.

◆ PERF_ENABLE_DESKTOP_COMPOSITION

#define PERF_ENABLE_DESKTOP_COMPOSITION   0x00000100

Definition at line 71 of file settings_types.h.

◆ PERF_ENABLE_FONT_SMOOTHING

#define PERF_ENABLE_FONT_SMOOTHING   0x00000080

Definition at line 70 of file settings_types.h.

◆ PERF_FLAG_NONE

#define PERF_FLAG_NONE   0x00000000

Definition at line 63 of file settings_types.h.

◆ PROXY_TYPE_HTTP

#define PROXY_TYPE_HTTP   1

Definition at line 492 of file settings_types.h.

◆ PROXY_TYPE_IGNORE

#define PROXY_TYPE_IGNORE   0xFFFF

Definition at line 494 of file settings_types.h.

◆ PROXY_TYPE_NONE

#define PROXY_TYPE_NONE   0

Definition at line 491 of file settings_types.h.

◆ PROXY_TYPE_SOCKS

#define PROXY_TYPE_SOCKS   2

Definition at line 493 of file settings_types.h.

◆ RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED

#define RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED   0x00000002

Definition at line 54 of file settings_types.h.

◆ RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED

#define RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED   0x00000080

Definition at line 60 of file settings_types.h.

◆ RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED

#define RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED   0x00000020

Definition at line 58 of file settings_types.h.

◆ RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED

#define RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED   0x00000008

Definition at line 56 of file settings_types.h.

◆ RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED

#define RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED   0x00000010

Definition at line 57 of file settings_types.h.

◆ RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED

#define RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED   0x00000004

Definition at line 55 of file settings_types.h.

◆ RAIL_LEVEL_SUPPORTED

#define RAIL_LEVEL_SUPPORTED   0x00000001

Definition at line 53 of file settings_types.h.

◆ RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED

#define RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED   0x00000040

Definition at line 59 of file settings_types.h.

◆ REDIRECTED_SESSIONID_FIELD_VALID

#define REDIRECTED_SESSIONID_FIELD_VALID   0x00000002

Definition at line 168 of file settings_types.h.

◆ REDIRECTED_SMARTCARD

#define REDIRECTED_SMARTCARD   0x00000040

Definition at line 169 of file settings_types.h.

◆ REDIRECTION_SUPPORTED

#define REDIRECTION_SUPPORTED   0x00000001

Definition at line 167 of file settings_types.h.

◆ REDIRECTION_VERSION1

#define REDIRECTION_VERSION1   0x00

Definition at line 172 of file settings_types.h.

◆ REDIRECTION_VERSION2

#define REDIRECTION_VERSION2   0x01

Definition at line 173 of file settings_types.h.

◆ REDIRECTION_VERSION3

#define REDIRECTION_VERSION3   0x02

Definition at line 174 of file settings_types.h.

◆ REDIRECTION_VERSION4

#define REDIRECTION_VERSION4   0x03

Definition at line 175 of file settings_types.h.

◆ REDIRECTION_VERSION5

#define REDIRECTION_VERSION5   0x04

Definition at line 176 of file settings_types.h.

◆ REDIRECTION_VERSION6

#define REDIRECTION_VERSION6   0x05

Definition at line 177 of file settings_types.h.

◆ RNS_UD_15BPP_SUPPORT

#define RNS_UD_15BPP_SUPPORT   0x0004

Definition at line 138 of file settings_types.h.

◆ RNS_UD_16BPP_SUPPORT

#define RNS_UD_16BPP_SUPPORT   0x0002

Definition at line 137 of file settings_types.h.

◆ RNS_UD_24BPP_SUPPORT

#define RNS_UD_24BPP_SUPPORT   0x0001

Definition at line 136 of file settings_types.h.

◆ RNS_UD_32BPP_SUPPORT

#define RNS_UD_32BPP_SUPPORT   0x0008

Definition at line 139 of file settings_types.h.

◆ RNS_UD_COLOR_16BPP_555

#define RNS_UD_COLOR_16BPP_555   0xCA02

Definition at line 128 of file settings_types.h.

◆ RNS_UD_COLOR_16BPP_565

#define RNS_UD_COLOR_16BPP_565   0xCA03

Definition at line 129 of file settings_types.h.

◆ RNS_UD_COLOR_24BPP

#define RNS_UD_COLOR_24BPP   0xCA04

Definition at line 130 of file settings_types.h.

◆ RNS_UD_COLOR_4BPP

#define RNS_UD_COLOR_4BPP   0xCA00

Definition at line 126 of file settings_types.h.

◆ RNS_UD_COLOR_8BPP

#define RNS_UD_COLOR_8BPP   0xCA01

Definition at line 127 of file settings_types.h.

◆ RNS_UD_CS_RELATIVE_MOUSE_INPUT

#define RNS_UD_CS_RELATIVE_MOUSE_INPUT   0x0010

Definition at line 151 of file settings_types.h.

◆ RNS_UD_CS_STRONG_ASYMMETRIC_KEYS

#define RNS_UD_CS_STRONG_ASYMMETRIC_KEYS   0x0008

Definition at line 150 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_DYNAMIC_TIME_ZONE

#define RNS_UD_CS_SUPPORT_DYNAMIC_TIME_ZONE   0x0200

Definition at line 156 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_DYNVC_GFX_PROTOCOL

#define RNS_UD_CS_SUPPORT_DYNVC_GFX_PROTOCOL   0x0100

Definition at line 155 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_ERRINFO_PDU

#define RNS_UD_CS_SUPPORT_ERRINFO_PDU   0x0001

Definition at line 147 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_HEARTBEAT_PDU

#define RNS_UD_CS_SUPPORT_HEARTBEAT_PDU   0x0400

Definition at line 157 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_MONITOR_LAYOUT_PDU

#define RNS_UD_CS_SUPPORT_MONITOR_LAYOUT_PDU   0x0040

Definition at line 153 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_NETCHAR_AUTODETECT

#define RNS_UD_CS_SUPPORT_NETCHAR_AUTODETECT   0x0080

Definition at line 154 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_SKIP_CHANNELJOIN

#define RNS_UD_CS_SUPPORT_SKIP_CHANNELJOIN   0x0800

Definition at line 158 of file settings_types.h.

◆ RNS_UD_CS_SUPPORT_STATUSINFO_PDU

#define RNS_UD_CS_SUPPORT_STATUSINFO_PDU   0x0004

Definition at line 149 of file settings_types.h.

◆ RNS_UD_CS_VALID_CONNECTION_TYPE

#define RNS_UD_CS_VALID_CONNECTION_TYPE   0x0020

Definition at line 152 of file settings_types.h.

◆ RNS_UD_CS_WANT_32BPP_SESSION

#define RNS_UD_CS_WANT_32BPP_SESSION   0x0002

Definition at line 148 of file settings_types.h.

◆ RNS_UD_SAS_DEL

#define RNS_UD_SAS_DEL   0xAA03

Definition at line 133 of file settings_types.h.

◆ RNS_UD_SC_DYNAMIC_DST_SUPPORTED

#define RNS_UD_SC_DYNAMIC_DST_SUPPORTED   0x00000002

Definition at line 162 of file settings_types.h.

◆ RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V1

#define RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V1   0x00000001

Definition at line 161 of file settings_types.h.

◆ RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V2

#define RNS_UD_SC_EDGE_ACTIONS_SUPPORTED_V2   0x00000004

Definition at line 163 of file settings_types.h.

◆ RNS_UD_SC_SKIP_CHANNELJOIN_SUPPORTED

#define RNS_UD_SC_SKIP_CHANNELJOIN_SUPPORTED   0x00000008

Definition at line 164 of file settings_types.h.

◆ SC_CORE

#define SC_CORE   0x0C01

Definition at line 96 of file settings_types.h.

◆ SC_MCS_MSGCHANNEL

#define SC_MCS_MSGCHANNEL   0x0C04

Definition at line 99 of file settings_types.h.

◆ SC_MULTITRANSPORT

#define SC_MULTITRANSPORT   0x0C08

Definition at line 100 of file settings_types.h.

◆ SC_NET

#define SC_NET   0x0C03

Definition at line 98 of file settings_types.h.

◆ SC_SECURITY

#define SC_SECURITY   0x0C02

Definition at line 97 of file settings_types.h.

◆ ServerSessionRedirectionVersionMask

#define ServerSessionRedirectionVersionMask   0x0000003c

Definition at line 171 of file settings_types.h.

◆ SETTINGS_DEPRECATED

#define SETTINGS_DEPRECATED (   x)    WINPR_DEPRECATED(x)

Definition at line 45 of file settings_types_private.h.

◆ SOFTSYNC_TCP_TO_UDP

#define SOFTSYNC_TCP_TO_UDP   0x00000200

Definition at line 199 of file settings_types.h.

◆ STATUS_BRINGING_SESSION_ONLINE

#define STATUS_BRINGING_SESSION_ONLINE   0x00000403

Definition at line 317 of file settings_types.h.

◆ STATUS_FINDING_DESTINATION

#define STATUS_FINDING_DESTINATION   0x00000401

Definition at line 315 of file settings_types.h.

◆ STATUS_LOADING_DESTINATION

#define STATUS_LOADING_DESTINATION   0x00000402

Definition at line 316 of file settings_types.h.

◆ STATUS_REDIRECTING_TO_DESTINATION

#define STATUS_REDIRECTING_TO_DESTINATION   0x00000404

Definition at line 318 of file settings_types.h.

◆ STATUS_VM_BOOTING

#define STATUS_VM_BOOTING   0x00000503

Definition at line 321 of file settings_types.h.

◆ STATUS_VM_LOADING

#define STATUS_VM_LOADING   0x00000501

Definition at line 319 of file settings_types.h.

◆ STATUS_VM_WAKING

#define STATUS_VM_WAKING   0x00000502

Definition at line 320 of file settings_types.h.

◆ SURFCMDS_FRAME_MARKER

#define SURFCMDS_FRAME_MARKER   0x00000010 /** @since version 3.7.0 */

Definition at line 49 of file settings_types.h.

◆ SURFCMDS_SET_SURFACE_BITS

#define SURFCMDS_SET_SURFACE_BITS   0x00000002 /** @since version 3.7.0 */

Definition at line 48 of file settings_types.h.

◆ SURFCMDS_STREAM_SURFACE_BITS

#define SURFCMDS_STREAM_SURFACE_BITS   0x00000040 /** @since version 3.7.0 */

Definition at line 50 of file settings_types.h.

◆ THREADING_FLAGS_DISABLE_THREADS

#define THREADING_FLAGS_DISABLE_THREADS   0x00000001

Definition at line 497 of file settings_types.h.

◆ TRANSPORT_TYPE_UDP_FECL

#define TRANSPORT_TYPE_UDP_FECL   0x00000004

Definition at line 197 of file settings_types.h.

◆ TRANSPORT_TYPE_UDP_FECR

#define TRANSPORT_TYPE_UDP_FECR   0x00000001

Definition at line 196 of file settings_types.h.

◆ TRANSPORT_TYPE_UDP_PREFERRED

#define TRANSPORT_TYPE_UDP_PREFERRED   0x00000100

Definition at line 198 of file settings_types.h.

◆ TS_CAPS_PROTOCOLVERSION

#define TS_CAPS_PROTOCOLVERSION   0x200 /** @since version 3.6.0 */

Definition at line 231 of file settings_types.h.

◆ TSC_PROXY_CREDS_MODE_ANY

#define TSC_PROXY_CREDS_MODE_ANY   0x2

Definition at line 286 of file settings_types.h.

◆ TSC_PROXY_CREDS_MODE_SMARTCARD

#define TSC_PROXY_CREDS_MODE_SMARTCARD   0x1

Definition at line 285 of file settings_types.h.

◆ TSC_PROXY_CREDS_MODE_USERPASS

#define TSC_PROXY_CREDS_MODE_USERPASS   0x0

Definition at line 284 of file settings_types.h.

◆ TSC_PROXY_MODE_DEFAULT

#define TSC_PROXY_MODE_DEFAULT   0x3

Definition at line 280 of file settings_types.h.

◆ TSC_PROXY_MODE_DETECT

#define TSC_PROXY_MODE_DETECT   0x2

Definition at line 279 of file settings_types.h.

◆ TSC_PROXY_MODE_DIRECT

#define TSC_PROXY_MODE_DIRECT   0x1

Definition at line 278 of file settings_types.h.

◆ TSC_PROXY_MODE_NONE_DETECT

#define TSC_PROXY_MODE_NONE_DETECT   0x4

Definition at line 281 of file settings_types.h.

◆ TSC_PROXY_MODE_NONE_DIRECT

#define TSC_PROXY_MODE_NONE_DIRECT   0x0

Definition at line 277 of file settings_types.h.

◆ VCCAPS_COMPR_CS_8K

#define VCCAPS_COMPR_CS_8K   0x00000002

Definition at line 217 of file settings_types.h.

◆ VCCAPS_COMPR_SC

#define VCCAPS_COMPR_SC   0x00000001

Definition at line 216 of file settings_types.h.

◆ VCCAPS_NO_COMPR

#define VCCAPS_NO_COMPR   0x00000000

Definition at line 215 of file settings_types.h.

Enumeration Type Documentation

◆ FreeRDP_DesktopRotationFlags

enum FreeRDP_DesktopRotationFlags

Definition at line 331 of file settings_types.h.

335 {
336 ORIENTATION_LANDSCAPE = 0,
337 ORIENTATION_PORTRAIT = 90,

◆ FreeRDP_OrderSupportFlagConstants

enum FreeRDP_OrderSupportFlagConstants

Definition at line 234 of file settings_types.h.

238 {
239 NEG_DSTBLT_INDEX = 0x00,
240 NEG_PATBLT_INDEX = 0x01,
241 NEG_SCRBLT_INDEX = 0x02,
242 NEG_MEMBLT_INDEX = 0x03,
243 NEG_MEM3BLT_INDEX = 0x04,
244 NEG_ATEXTOUT_INDEX = 0x05,
245 NEG_AEXTTEXTOUT_INDEX = 0x06, /* Must be ignored */
246 NEG_DRAWNINEGRID_INDEX = 0x07, /* Must be ignored */
247 NEG_LINETO_INDEX = 0x08,
248 NEG_MULTI_DRAWNINEGRID_INDEX = 0x09,
249 NEG_OPAQUE_RECT_INDEX = 0x0A, /* Must be ignored */
250 NEG_SAVEBITMAP_INDEX = 0x0B,
251 NEG_WTEXTOUT_INDEX = 0x0C, /* Must be ignored */
252 NEG_MEMBLT_V2_INDEX = 0x0D, /* Must be ignored */
253 NEG_MEM3BLT_V2_INDEX = 0x0E, /* Must be ignored */
254 NEG_MULTIDSTBLT_INDEX = 0x0F,
255 NEG_MULTIPATBLT_INDEX = 0x10,
256 NEG_MULTISCRBLT_INDEX = 0x11,
257 NEG_MULTIOPAQUERECT_INDEX = 0x12,
258 NEG_FAST_INDEX_INDEX = 0x13,
259 NEG_POLYGON_SC_INDEX = 0x14,
260 NEG_POLYGON_CB_INDEX = 0x15,
261 NEG_POLYLINE_INDEX = 0x16,
262 NEG_UNUSED23_INDEX = 0x17, /* Must be ignored */
263 NEG_FAST_GLYPH_INDEX = 0x18,
264 NEG_ELLIPSE_SC_INDEX = 0x19,
265 NEG_ELLIPSE_CB_INDEX = 0x1A,
266 NEG_GLYPH_INDEX_INDEX = 0x1B,
267 NEG_GLYPH_WEXTTEXTOUT_INDEX = 0x1C, /* Must be ignored */
268 NEG_GLYPH_WLONGTEXTOUT_INDEX = 0x1D, /* Must be ignored */

◆ FreeRDP_RDPDR_DTYP

enum FreeRDP_RDPDR_DTYP

Definition at line 442 of file settings_types.h.

446 {
447 RDPDR_DTYP_SERIAL = 0x00000001,
448 RDPDR_DTYP_PARALLEL = 0x00000002,
449 RDPDR_DTYP_PRINT = 0x00000004,

◆ rdp_settings_type

enum rdp_settings_type

Definition at line 499 of file settings_types.h.

503 {
504 RDP_SETTINGS_TYPE_BOOL,
505 RDP_SETTINGS_TYPE_UINT16,
506 RDP_SETTINGS_TYPE_INT16,
507 RDP_SETTINGS_TYPE_UINT32,
508 RDP_SETTINGS_TYPE_INT32,
509 RDP_SETTINGS_TYPE_UINT64,
510 RDP_SETTINGS_TYPE_INT64,

◆ RDP_VERSION

enum RDP_VERSION

Definition at line 106 of file settings_types.h.

110 {
111 RDP_VERSION_4 = 0x00080001,
112 RDP_VERSION_5_PLUS = 0x00080004,
113 RDP_VERSION_10_0 = 0x00080005,
114 RDP_VERSION_10_1 = 0x00080006,
115 RDP_VERSION_10_2 = 0x00080007,
116 RDP_VERSION_10_3 = 0x00080008,
117 RDP_VERSION_10_4 = 0x00080009,
118 RDP_VERSION_10_5 = 0x0008000a,
119 RDP_VERSION_10_6 = 0x0008000b,
120 RDP_VERSION_10_7 = 0x0008000C,
121 RDP_VERSION_10_8 = 0x0008000D,
122 RDP_VERSION_10_9 = 0x0008000E,
123 RDP_VERSION_10_10 = 0x0008000F,

Function Documentation

◆ freerdp_addin_argv_add_argument()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_add_argument ( ADDIN_ARGV args,
const char *  argument 
)

Definition at line 69 of file common/settings.c.

70{
71 return freerdp_addin_argv_add_argument_ex(args, argument, 0);
72}

◆ freerdp_addin_argv_add_argument_ex()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_add_argument_ex ( ADDIN_ARGV args,
const char *  argument,
size_t  len 
)

Definition at line 45 of file common/settings.c.

46{
47 if (!args || !argument)
48 return FALSE;
49
50 if (len == 0)
51 len = strlen(argument);
52
53 char** new_argv = (char**)realloc(
54 (void*)args->argv, sizeof(char*) * (WINPR_ASSERTING_INT_CAST(uint32_t, args->argc) + 1));
55
56 if (!new_argv)
57 return FALSE;
58
59 args->argv = new_argv;
60
61 char* str = calloc(len + 1, sizeof(char));
62 if (!str)
63 return FALSE;
64 memcpy(str, argument, len);
65 args->argv[args->argc++] = str;
66 return TRUE;
67}

◆ freerdp_addin_argv_clone()

WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGV * freerdp_addin_argv_clone ( const ADDIN_ARGV args)

Definition at line 799 of file common/settings.c.

800{
801 union
802 {
803 char** c;
804 const char** cc;
805 } cnv;
806 if (!args)
807 return nullptr;
808 cnv.c = args->argv;
809 return freerdp_addin_argv_new(WINPR_ASSERTING_INT_CAST(uint32_t, args->argc), cnv.cc);
810}

◆ freerdp_addin_argv_del_argument()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_addin_argv_del_argument ( ADDIN_ARGV args,
const char *  argument 
)

Definition at line 74 of file common/settings.c.

75{
76 if (!args || !argument)
77 return FALSE;
78 for (int x = 0; x < args->argc; x++)
79 {
80 char* arg = args->argv[x];
81 if (strcmp(argument, arg) == 0)
82 {
83 free(arg);
84 memmove_s((void*)&args->argv[x],
85 (WINPR_ASSERTING_INT_CAST(uint32_t, args->argc - x)) * sizeof(char*),
86 (void*)&args->argv[x + 1],
87 (WINPR_ASSERTING_INT_CAST(uint32_t, args->argc - x - 1)) * sizeof(char*));
88 args->argv[args->argc - 1] = nullptr;
89 args->argc--;
90 return TRUE;
91 }
92 }
93 return FALSE;
94}

◆ freerdp_addin_argv_free()

FREERDP_API void freerdp_addin_argv_free ( ADDIN_ARGV args)

Definition at line 749 of file common/settings.c.

750{
751 if (!args)
752 return;
753
754 if (args->argv)
755 {
756 for (int index = 0; index < args->argc; index++)
757 free(args->argv[index]);
758 free((void*)args->argv);
759 }
760
761 free(args);
762}

◆ freerdp_addin_argv_new()

WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGV * freerdp_addin_argv_new ( size_t  argc,
const char *const  argv[] 
)

Definition at line 764 of file common/settings.c.

765{
766 if (argc > INT32_MAX)
767 return nullptr;
768
769 ADDIN_ARGV* args = calloc(1, sizeof(ADDIN_ARGV));
770 if (!args)
771 return nullptr;
772 if (argc == 0)
773 return args;
774
775 args->argc = (int)argc;
776 args->argv = (char**)calloc(argc, sizeof(char*));
777 if (!args->argv)
778 goto fail;
779
780 if (argv)
781 {
782 for (size_t x = 0; x < argc; x++)
783 {
784 args->argv[x] = _strdup(argv[x]);
785 if (!args->argv[x])
786 goto fail;
787 }
788 }
789 return args;
790
791fail:
792 WINPR_PRAGMA_DIAG_PUSH
793 WINPR_PRAGMA_DIAG_IGNORED_MISMATCHED_DEALLOC
794 freerdp_addin_argv_free(args);
795 WINPR_PRAGMA_DIAG_POP
796 return nullptr;
797}

◆ freerdp_addin_replace_argument()

WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_replace_argument ( ADDIN_ARGV args,
const char *  previous,
const char *  argument 
)

Definition at line 114 of file common/settings.c.

115{
116 if (!args || !previous || !argument)
117 return -2;
118
119 for (int i = 0; i < args->argc; i++)
120 {
121 if (strcmp(args->argv[i], previous) == 0)
122 {
123 free(args->argv[i]);
124
125 if (!(args->argv[i] = _strdup(argument)))
126 return -1;
127
128 return 1;
129 }
130 }
131
132 if (!freerdp_addin_argv_add_argument(args, argument))
133 return -1;
134 return 0;
135}

◆ freerdp_addin_replace_argument_value()

WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_replace_argument_value ( ADDIN_ARGV args,
const char *  previous,
const char *  option,
const char *  value 
)

Definition at line 176 of file common/settings.c.

178{
179 BOOL rc = 0;
180 char* str = nullptr;
181 size_t length = 0;
182 if (!args || !previous || !option || !value)
183 return -2;
184 length = strlen(option) + strlen(value) + 1;
185 str = (char*)calloc(length + 1, sizeof(char));
186
187 if (!str)
188 return -1;
189
190 (void)sprintf_s(str, length + 1, "%s:%s", option, value);
191
192 for (int i = 0; i < args->argc; i++)
193 {
194 if (strcmp(args->argv[i], previous) == 0)
195 {
196 free(args->argv[i]);
197 args->argv[i] = str;
198 return 1;
199 }
200 }
201
202 rc = freerdp_addin_argv_add_argument(args, str);
203 free(str);
204 if (!rc)
205 return -1;
206 return 0;
207}

◆ freerdp_addin_set_argument()

WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_set_argument ( ADDIN_ARGV args,
const char *  argument 
)

Definition at line 96 of file common/settings.c.

97{
98 if (!args || !argument)
99 return -2;
100
101 for (int i = 0; i < args->argc; i++)
102 {
103 if (strcmp(args->argv[i], argument) == 0)
104 {
105 return 1;
106 }
107 }
108
109 if (!freerdp_addin_argv_add_argument(args, argument))
110 return -1;
111 return 0;
112}

◆ freerdp_addin_set_argument_value()

WINPR_ATTR_NODISCARD FREERDP_API int freerdp_addin_set_argument_value ( ADDIN_ARGV args,
const char *  option,
const char *  value 
)

Definition at line 137 of file common/settings.c.

138{
139 BOOL rc = 0;
140 char* p = nullptr;
141 char* str = nullptr;
142 size_t length = 0;
143 if (!args || !option || !value)
144 return -2;
145 length = strlen(option) + strlen(value) + 1;
146 str = (char*)calloc(length + 1, sizeof(char));
147
148 if (!str)
149 return -1;
150
151 (void)sprintf_s(str, length + 1, "%s:%s", option, value);
152
153 for (int i = 0; i < args->argc; i++)
154 {
155 p = strchr(args->argv[i], ':');
156
157 if (p)
158 {
159 if (strncmp(args->argv[i], option,
160 WINPR_ASSERTING_INT_CAST(size_t, p - args->argv[i])) == 0)
161 {
162 free(args->argv[i]);
163 args->argv[i] = str;
164 return 1;
165 }
166 }
167 }
168
169 rc = freerdp_addin_argv_add_argument(args, str);
170 free(str);
171 if (!rc)
172 return -1;
173 return 0;
174}

◆ freerdp_capability_buffer_copy()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_capability_buffer_copy ( rdpSettings *  settings,
const rdpSettings *  src 
)

Definition at line 943 of file common/settings.c.

944{
945 WINPR_ASSERT(settings);
946 WINPR_ASSERT(src);
947
948 if (src->ReceivedCapabilitiesSize == 0)
949 return TRUE;
950
951 if (!freerdp_capability_buffer_resize(settings, src->ReceivedCapabilitiesSize, TRUE))
952 return FALSE;
953
954 for (UINT32 x = 0; x < src->ReceivedCapabilitiesSize; x++)
955 {
956 WINPR_ASSERT(settings->ReceivedCapabilities);
957 settings->ReceivedCapabilities[x] = src->ReceivedCapabilities[x];
958
959 WINPR_ASSERT(settings->ReceivedCapabilityDataSizes);
960 settings->ReceivedCapabilityDataSizes[x] = src->ReceivedCapabilityDataSizes[x];
961
962 WINPR_ASSERT(settings->ReceivedCapabilityData);
963 if (src->ReceivedCapabilityDataSizes[x] > 0)
964 {
965 void* tmp = realloc(settings->ReceivedCapabilityData[x],
966 settings->ReceivedCapabilityDataSizes[x]);
967 if (!tmp)
968 return FALSE;
969 memcpy(tmp, src->ReceivedCapabilityData[x], src->ReceivedCapabilityDataSizes[x]);
970 settings->ReceivedCapabilityData[x] = tmp;
971 }
972 else
973 {
974 free(settings->ReceivedCapabilityData[x]);
975 settings->ReceivedCapabilityData[x] = nullptr;
976 }
977 }
978 return TRUE;
979}

◆ freerdp_capability_buffer_free()

FREERDP_API void freerdp_capability_buffer_free ( rdpSettings *  settings)

Definition at line 848 of file common/settings.c.

849{
850 WINPR_ASSERT(settings);
851
852 freerdp_capability_data_free(settings, 0, TRUE);
853
854 free(settings->ReceivedCapabilityDataSizes);
855 settings->ReceivedCapabilityDataSizes = nullptr;
856
857 free(settings->ReceivedCapabilities);
858 settings->ReceivedCapabilities = nullptr;
859
860 settings->ReceivedCapabilitiesSize = 0;
861}

◆ freerdp_device_clone()

WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICE * freerdp_device_clone ( const RDPDR_DEVICE device)

Definition at line 462 of file common/settings.c.

463{
464 union
465 {
466 const RDPDR_DEVICE* dev;
467 const RDPDR_DRIVE* drive;
468 const RDPDR_SERIAL* serial;
469 const RDPDR_PRINTER* printer;
470 const RDPDR_PARALLEL* parallel;
471 const RDPDR_SMARTCARD* smartcard;
472 } src;
473
474 union
475 {
476 RDPDR_DEVICE* dev;
477 RDPDR_DRIVE* drive;
478 RDPDR_SERIAL* serial;
479 RDPDR_PRINTER* printer;
480 RDPDR_PARALLEL* parallel;
481 RDPDR_SMARTCARD* smartcard;
482 } copy;
483 size_t count = 0;
484 const char* args[4] = WINPR_C_ARRAY_INIT;
485
486 copy.dev = nullptr;
487 src.dev = device;
488
489 if (!device)
490 return nullptr;
491
492 if (device->Name)
493 {
494 args[count++] = device->Name;
495 }
496
497 switch (device->Type)
498 {
499 case RDPDR_DTYP_FILESYSTEM:
500 if (src.drive->Path)
501 {
502 args[count++] = src.drive->Path;
503 args[count++] = src.drive->automount ? nullptr : src.drive->Path;
504 }
505 break;
506
507 case RDPDR_DTYP_PRINT:
508 if (src.printer->DriverName)
509 args[count++] = src.printer->DriverName;
510 break;
511
512 case RDPDR_DTYP_SMARTCARD:
513 break;
514
515 case RDPDR_DTYP_SERIAL:
516 if (src.serial->Path)
517 args[count++] = src.serial->Path;
518
519 if (src.serial->Driver)
520 args[count++] = src.serial->Driver;
521
522 if (src.serial->Permissive)
523 args[count++] = src.serial->Permissive;
524 break;
525
526 case RDPDR_DTYP_PARALLEL:
527 if (src.parallel->Path)
528 args[count++] = src.parallel->Path;
529 break;
530 default:
531 WLog_ERR(TAG, "unknown device type %" PRIu32 "", device->Type);
532 break;
533 }
534
535 copy.dev = freerdp_device_new(device->Type, count, args);
536 if (!copy.dev)
537 return nullptr;
538
539 copy.dev->Id = device->Id;
540
541 return copy.dev;
542}

◆ freerdp_device_collection_add()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_device_collection_add ( rdpSettings *  settings,
RDPDR_DEVICE device 
)

Definition at line 209 of file common/settings.c.

210{
211 UINT32 count = 0;
212 UINT32 old = 0;
213 WINPR_ASSERT(settings);
214 WINPR_ASSERT(device);
215
216 count = freerdp_settings_get_uint32(settings, FreeRDP_DeviceCount) + 1;
217 old = freerdp_settings_get_uint32(settings, FreeRDP_DeviceArraySize);
218 if (old < count)
219 {
220 const size_t new_size = (old + 32);
221 RDPDR_DEVICE** new_array =
222 (RDPDR_DEVICE**)realloc((void*)settings->DeviceArray, new_size * sizeof(RDPDR_DEVICE*));
223
224 if (!new_array)
225 return FALSE;
226
227 settings->DeviceArray = new_array;
228 for (size_t x = old; x < new_size; x++)
229 settings->DeviceArray[x] = nullptr;
230
231 if (!freerdp_settings_set_uint32(settings, FreeRDP_DeviceArraySize,
232 WINPR_ASSERTING_INT_CAST(uint32_t, new_size)))
233 return FALSE;
234 }
235
236 settings->DeviceArray[settings->DeviceCount++] = device;
237 return TRUE;
238}
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 UINT32 freerdp_settings_get_uint32(const rdpSettings *settings, FreeRDP_Settings_Keys_UInt32 id)
Returns a UINT32 settings value.

◆ freerdp_device_collection_del()

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.

Parameters
settingsthe settings to remove the device from
devicethe device to remove
Since
version 3.4.0
Returns
TRUE if the device was removed, FALSE if device was not found or is nullptr

Definition at line 240 of file common/settings.c.

241{
242 WINPR_ASSERT(settings);
243
244 if (!device)
245 return FALSE;
246
247 const UINT32 count = settings->DeviceCount;
248 for (size_t x = 0; x < count; x++)
249 {
250 const RDPDR_DEVICE* cur = settings->DeviceArray[x];
251 if (cur == device)
252 {
253 for (size_t y = x + 1; y < count; y++)
254 {
255 RDPDR_DEVICE* next = settings->DeviceArray[y];
256 settings->DeviceArray[y - 1] = next;
257 }
258 settings->DeviceArray[count - 1] = nullptr;
259 settings->DeviceCount--;
260 return TRUE;
261 }
262 }
263
264 return FALSE;
265}

◆ freerdp_device_collection_find()

WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICE * freerdp_device_collection_find ( rdpSettings *  settings,
const char *  name 
)

Definition at line 267 of file common/settings.c.

268{
269 RDPDR_DEVICE* device = nullptr;
270
271 WINPR_ASSERT(settings);
272 WINPR_ASSERT(name);
273 for (UINT32 index = 0; index < settings->DeviceCount; index++)
274 {
275 device = settings->DeviceArray[index];
276
277 if (!device->Name)
278 continue;
279
280 if (strcmp(device->Name, name) == 0)
281 return device;
282 }
283
284 return nullptr;
285}

◆ freerdp_device_collection_find_type()

WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICE * freerdp_device_collection_find_type ( rdpSettings *  settings,
UINT32  type 
)

Definition at line 287 of file common/settings.c.

288{
289 RDPDR_DEVICE* device = nullptr;
290 WINPR_ASSERT(settings);
291
292 for (UINT32 index = 0; index < settings->DeviceCount; index++)
293 {
294 device = settings->DeviceArray[index];
295
296 if (device->Type == type)
297 return device;
298 }
299
300 return nullptr;
301}

◆ freerdp_device_collection_free()

FREERDP_API void freerdp_device_collection_free ( rdpSettings *  settings)

Definition at line 544 of file common/settings.c.

545{
546 WINPR_ASSERT(settings);
547
548 if (settings->DeviceArray)
549 {
550 for (UINT32 index = 0; index < settings->DeviceArraySize; index++)
551 freerdp_settings_set_pointer_array(settings, FreeRDP_DeviceArray, index, nullptr);
552 }
553
554 free((void*)settings->DeviceArray);
555
556 freerdp_settings_set_pointer(settings, FreeRDP_DeviceArray, nullptr);
557 freerdp_settings_set_uint32(settings, FreeRDP_DeviceArraySize, 0);
558 freerdp_settings_set_uint32(settings, FreeRDP_DeviceCount, 0);
559}
FREERDP_API BOOL freerdp_settings_set_pointer(rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id, const void *val)
Set a pointer to value val.

◆ freerdp_device_equal()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_device_equal ( const RDPDR_DEVICE what,
const RDPDR_DEVICE other 
)

Definition at line 2053 of file common/settings.c.

2054{
2055 if (!what && !other)
2056 return TRUE;
2057 if (!what || !other)
2058 return FALSE;
2059
2060 if (what->Id != other->Id)
2061 return FALSE;
2062 if (what->Type != other->Type)
2063 return FALSE;
2064 if (what->Name && other->Name)
2065 {
2066 if (strcmp(what->Name, other->Name) != 0)
2067 return FALSE;
2068 }
2069 else
2070 {
2071 if (what->Name != other->Name)
2072 return FALSE;
2073 }
2074
2075 switch (what->Type)
2076 {
2077 case RDPDR_DTYP_PRINT:
2078 {
2079 const RDPDR_PRINTER* a = (const RDPDR_PRINTER*)what;
2080 const RDPDR_PRINTER* b = (const RDPDR_PRINTER*)other;
2081 if (a->DriverName && b->DriverName)
2082 return strcmp(a->DriverName, b->DriverName) == 0;
2083 return a->DriverName == b->DriverName;
2084 }
2085
2086 case RDPDR_DTYP_SERIAL:
2087 {
2088 const RDPDR_SERIAL* a = (const RDPDR_SERIAL*)what;
2089 const RDPDR_SERIAL* b = (const RDPDR_SERIAL*)other;
2090
2091 if (a->Path && b->Path)
2092 {
2093 if (strcmp(a->Path, b->Path) != 0)
2094 return FALSE;
2095 }
2096 else if (a->Path != b->Path)
2097 return FALSE;
2098
2099 if (a->Driver && b->Driver)
2100 {
2101 if (strcmp(a->Driver, b->Driver) != 0)
2102 return FALSE;
2103 }
2104 else if (a->Driver != b->Driver)
2105 return FALSE;
2106 if (a->Permissive && b->Permissive)
2107 return strcmp(a->Permissive, b->Permissive) == 0;
2108 return a->Permissive == b->Permissive;
2109 }
2110
2111 case RDPDR_DTYP_PARALLEL:
2112 {
2113 const RDPDR_PARALLEL* a = (const RDPDR_PARALLEL*)what;
2114 const RDPDR_PARALLEL* b = (const RDPDR_PARALLEL*)other;
2115 if (a->Path && b->Path)
2116 return strcmp(a->Path, b->Path) == 0;
2117 return a->Path == b->Path;
2118 }
2119
2120 case RDPDR_DTYP_SMARTCARD:
2121 break;
2122 case RDPDR_DTYP_FILESYSTEM:
2123 {
2124 const RDPDR_DRIVE* a = (const RDPDR_DRIVE*)what;
2125 const RDPDR_DRIVE* b = (const RDPDR_DRIVE*)other;
2126 if (a->automount != b->automount)
2127 return FALSE;
2128 if (a->Path && b->Path)
2129 return strcmp(a->Path, b->Path) == 0;
2130 return a->Path == b->Path;
2131 }
2132
2133 default:
2134 return FALSE;
2135 }
2136
2137 return TRUE;
2138}

◆ freerdp_device_free()

FREERDP_API void freerdp_device_free ( RDPDR_DEVICE device)

Definition at line 420 of file common/settings.c.

421{
422 if (!device)
423 return;
424
425 union
426 {
427 RDPDR_DEVICE* dev;
428 RDPDR_DRIVE* drive;
429 RDPDR_SERIAL* serial;
430 RDPDR_PRINTER* printer;
431 RDPDR_PARALLEL* parallel;
432 RDPDR_SMARTCARD* smartcard;
433 } cnv;
434
435 cnv.dev = device;
436
437 switch (device->Type)
438 {
439 case RDPDR_DTYP_PRINT:
440 free(cnv.printer->DriverName);
441 break;
442 case RDPDR_DTYP_SERIAL:
443 free(cnv.serial->Path);
444 free(cnv.serial->Driver);
445 free(cnv.serial->Permissive);
446 break;
447 case RDPDR_DTYP_PARALLEL:
448 free(cnv.parallel->Path);
449 break;
450 case RDPDR_DTYP_SMARTCARD:
451 break;
452 case RDPDR_DTYP_FILESYSTEM:
453 free(cnv.drive->Path);
454 break;
455 default:
456 break;
457 }
458 free(cnv.dev->Name);
459 free(cnv.dev);
460}

◆ freerdp_device_new()

WINPR_ATTR_NODISCARD FREERDP_API RDPDR_DEVICE * freerdp_device_new ( UINT32  Type,
size_t  count,
const char *const  args[] 
)

Definition at line 303 of file common/settings.c.

304{
305 size_t size = 0;
306 union
307 {
308 RDPDR_DEVICE* base;
309 RDPDR_DRIVE* drive;
310 RDPDR_SERIAL* serial;
311 RDPDR_PRINTER* printer;
312 RDPDR_PARALLEL* parallel;
313 RDPDR_SMARTCARD* smartcard;
314 } device;
315
316 device.base = nullptr;
317 WINPR_ASSERT(args || (count == 0));
318
319 switch (Type)
320 {
321 case RDPDR_DTYP_PRINT:
322 size = sizeof(RDPDR_PRINTER);
323 break;
324 case RDPDR_DTYP_SERIAL:
325 size = sizeof(RDPDR_SERIAL);
326 break;
327 case RDPDR_DTYP_PARALLEL:
328 size = sizeof(RDPDR_PARALLEL);
329 break;
330 case RDPDR_DTYP_SMARTCARD:
331 size = sizeof(RDPDR_SMARTCARD);
332 break;
333 case RDPDR_DTYP_FILESYSTEM:
334 size = sizeof(RDPDR_DRIVE);
335 break;
336 default:
337 goto fail;
338 }
339
340 device.base = calloc(1, size);
341 if (!device.base)
342 goto fail;
343 device.base->Id = 0;
344 device.base->Type = Type;
345
346 if (count > 0)
347 {
348 device.base->Name = _strdup(args[0]);
349 if (!device.base->Name)
350 goto fail;
351
352 switch (Type)
353 {
354 case RDPDR_DTYP_PRINT:
355 if (count > 1)
356 {
357 device.printer->DriverName = _strdup(args[1]);
358 if (!device.printer->DriverName)
359 goto fail;
360 }
361
362 if (count > 2)
363 {
364 device.printer->IsDefault = _stricmp(args[2], "default") == 0;
365 }
366 break;
367 case RDPDR_DTYP_SERIAL:
368 if (count > 1)
369 {
370 device.serial->Path = _strdup(args[1]);
371 if (!device.serial->Path)
372 goto fail;
373 }
374
375 if (count > 2)
376 {
377 device.serial->Driver = _strdup(args[2]);
378 if (!device.serial->Driver)
379 goto fail;
380 }
381
382 if (count > 3)
383 {
384 device.serial->Permissive = _strdup(args[3]);
385 if (!device.serial->Permissive)
386 goto fail;
387 }
388 break;
389 case RDPDR_DTYP_PARALLEL:
390 if (count > 1)
391 {
392 device.parallel->Path = _strdup(args[1]);
393 if (!device.serial->Path)
394 goto fail;
395 }
396 break;
397 case RDPDR_DTYP_SMARTCARD:
398 break;
399 case RDPDR_DTYP_FILESYSTEM:
400 if (count > 1)
401 {
402 device.drive->Path = _strdup(args[1]);
403 if (!device.drive->Path)
404 goto fail;
405 }
406 if (count > 2)
407 device.drive->automount = (args[2] == nullptr);
408 break;
409 default:
410 goto fail;
411 }
412 }
413 return device.base;
414
415fail:
416 freerdp_device_free(device.base);
417 return nullptr;
418}

◆ freerdp_dynamic_channel_collection_add()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_dynamic_channel_collection_add ( rdpSettings *  settings,
ADDIN_ARGV channel 
)

Definition at line 697 of file common/settings.c.

698{
699 UINT32 count = 0;
700 UINT32 oldSize = 0;
701
702 WINPR_ASSERT(settings);
703 WINPR_ASSERT(channel);
704
705 count = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelCount) + 1;
706 oldSize = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelArraySize);
707 if (oldSize < count)
708 {
709
710 const size_t size = oldSize + 32;
711 ADDIN_ARGV** new_array =
712 (ADDIN_ARGV**)realloc((void*)settings->DynamicChannelArray, sizeof(ADDIN_ARGV*) * size);
713
714 if (!new_array)
715 return FALSE;
716
717 settings->DynamicChannelArray = new_array;
718 {
719 for (size_t x = oldSize; x < size; x++)
720 settings->DynamicChannelArray[x] = nullptr;
721 }
722 if (!freerdp_settings_set_uint32(settings, FreeRDP_DynamicChannelArraySize,
723 WINPR_ASSERTING_INT_CAST(uint32_t, size)))
724 return FALSE;
725 }
726
727 count = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelCount);
728 settings->DynamicChannelArray[count++] = channel;
729 return freerdp_settings_set_uint32(settings, FreeRDP_DynamicChannelCount, count);
730}

◆ freerdp_dynamic_channel_collection_del()

FREERDP_API BOOL freerdp_dynamic_channel_collection_del ( rdpSettings *  settings,
const char *  name 
)

Definition at line 667 of file common/settings.c.

668{
669 const UINT32 count = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelCount);
670 if (!settings || !settings->DynamicChannelArray)
671 return FALSE;
672
673 for (UINT32 x = 0; x < count; x++)
674 {
675 ADDIN_ARGV* cur = settings->DynamicChannelArray[x];
676 if (cur && (cur->argc > 0))
677 {
678 if (strcmp(name, cur->argv[0]) == 0)
679 {
680 memmove_s((void*)&settings->DynamicChannelArray[x],
681 (count - x) * sizeof(ADDIN_ARGV*),
682 (void*)&settings->DynamicChannelArray[x + 1],
683 (count - x - 1) * sizeof(ADDIN_ARGV*));
684 for (size_t y = count - 1; y < settings->DynamicChannelArraySize; y++)
685 settings->DynamicChannelArray[y] = nullptr;
686
687 freerdp_addin_argv_free(cur);
688 return freerdp_settings_set_uint32(settings, FreeRDP_DynamicChannelCount,
689 count - 1);
690 }
691 }
692 }
693
694 return FALSE;
695}

◆ freerdp_dynamic_channel_collection_find()

WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGV * freerdp_dynamic_channel_collection_find ( const rdpSettings *  settings,
const char *  name 
)

Definition at line 732 of file common/settings.c.

733{
734 WINPR_ASSERT(settings);
735 WINPR_ASSERT(name);
736
737 for (UINT32 index = 0;
738 index < freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelCount); index++)
739 {
740 ADDIN_ARGV* channel = settings->DynamicChannelArray[index];
741
742 if (strcmp(channel->argv[0], name) == 0)
743 return channel;
744 }
745
746 return nullptr;
747}

◆ freerdp_dynamic_channel_collection_free()

FREERDP_API void freerdp_dynamic_channel_collection_free ( rdpSettings *  settings)

Definition at line 812 of file common/settings.c.

813{
814 WINPR_ASSERT(settings);
815
816 if (settings->DynamicChannelArray)
817 {
818 for (UINT32 i = 0;
819 i < freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelArraySize); i++)
820 freerdp_addin_argv_free(settings->DynamicChannelArray[i]);
821 }
822
823 free((void*)settings->DynamicChannelArray);
824 freerdp_settings_set_uint32(settings, FreeRDP_DynamicChannelArraySize, 0);
825 settings->DynamicChannelArray = nullptr;
826 freerdp_settings_set_uint32(settings, FreeRDP_DynamicChannelCount, 0);
827}

◆ freerdp_encryption_level_string()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_encryption_level_string ( UINT32  EncryptionLevel)

Definition at line 2311 of file common/settings.c.

2312{
2313 switch (EncryptionLevel)
2314 {
2315 case ENCRYPTION_LEVEL_NONE:
2316 return "ENCRYPTION_LEVEL_NONE";
2317 case ENCRYPTION_LEVEL_LOW:
2318 return "ENCRYPTION_LEVEL_LOW";
2319 case ENCRYPTION_LEVEL_CLIENT_COMPATIBLE:
2320 return "ENCRYPTION_LEVEL_CLIENT_COMPATIBLE";
2321 case ENCRYPTION_LEVEL_HIGH:
2322 return "ENCRYPTION_LEVEL_HIGH";
2323 case ENCRYPTION_LEVEL_FIPS:
2324 return "ENCRYPTION_LEVEL_FIPS";
2325 default:
2326 return "ENCRYPTION_LEVEL_UNKNOWN";
2327 }
2328}

◆ freerdp_encryption_methods_string()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_encryption_methods_string ( UINT32  EncryptionMethods,
char *  buffer,
size_t  size 
)

Definition at line 2330 of file common/settings.c.

2331{
2332 if (EncryptionMethods == ENCRYPTION_METHOD_NONE)
2333 {
2334 winpr_str_append("ENCRYPTION_METHOD_NONE", buffer, size, "|");
2335 return buffer;
2336 }
2337
2338 if (EncryptionMethods & ENCRYPTION_METHOD_40BIT)
2339 {
2340 winpr_str_append("ENCRYPTION_METHOD_40BIT", buffer, size, "|");
2341 }
2342 if (EncryptionMethods & ENCRYPTION_METHOD_128BIT)
2343 {
2344 winpr_str_append("ENCRYPTION_METHOD_128BIT", buffer, size, "|");
2345 }
2346 if (EncryptionMethods & ENCRYPTION_METHOD_56BIT)
2347 {
2348 winpr_str_append("ENCRYPTION_METHOD_56BIT", buffer, size, "|");
2349 }
2350 if (EncryptionMethods & ENCRYPTION_METHOD_FIPS)
2351 {
2352 winpr_str_append("ENCRYPTION_METHOD_FIPS", buffer, size, "|");
2353 }
2354
2355 return buffer;
2356}

◆ freerdp_performance_flags_make()

FREERDP_API void freerdp_performance_flags_make ( rdpSettings *  settings)

Definition at line 1064 of file common/settings.c.

1065{
1066 UINT32 PerformanceFlags = PERF_FLAG_NONE;
1067
1068 if (freerdp_settings_get_bool(settings, FreeRDP_AllowFontSmoothing))
1069 PerformanceFlags |= PERF_ENABLE_FONT_SMOOTHING;
1070
1071 if (freerdp_settings_get_bool(settings, FreeRDP_AllowDesktopComposition))
1072 PerformanceFlags |= PERF_ENABLE_DESKTOP_COMPOSITION;
1073
1074 if (freerdp_settings_get_bool(settings, FreeRDP_DisableWallpaper))
1075 PerformanceFlags |= PERF_DISABLE_WALLPAPER;
1076
1077 if (freerdp_settings_get_bool(settings, FreeRDP_DisableFullWindowDrag))
1078 PerformanceFlags |= PERF_DISABLE_FULLWINDOWDRAG;
1079
1080 if (freerdp_settings_get_bool(settings, FreeRDP_DisableMenuAnims))
1081 PerformanceFlags |= PERF_DISABLE_MENUANIMATIONS;
1082
1083 if (freerdp_settings_get_bool(settings, FreeRDP_DisableThemes))
1084 PerformanceFlags |= PERF_DISABLE_THEMING;
1085 freerdp_settings_set_uint32(settings, FreeRDP_PerformanceFlags, PerformanceFlags);
1086}
WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_get_bool(const rdpSettings *settings, FreeRDP_Settings_Keys_Bool id)
Returns a boolean settings value.

◆ freerdp_performance_flags_split()

FREERDP_API void freerdp_performance_flags_split ( rdpSettings *  settings)

Definition at line 1088 of file common/settings.c.

1089{
1090 freerdp_settings_set_bool(settings, FreeRDP_AllowFontSmoothing,
1091 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1092 PERF_ENABLE_FONT_SMOOTHING) != 0);
1093 freerdp_settings_set_bool(settings, FreeRDP_AllowDesktopComposition,
1094 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1095 PERF_ENABLE_DESKTOP_COMPOSITION) != 0);
1096 freerdp_settings_set_bool(settings, FreeRDP_DisableWallpaper,
1097 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1098 PERF_DISABLE_WALLPAPER) != 0);
1099 freerdp_settings_set_bool(settings, FreeRDP_DisableFullWindowDrag,
1100 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1101 PERF_DISABLE_FULLWINDOWDRAG) != 0);
1102 freerdp_settings_set_bool(settings, FreeRDP_DisableMenuAnims,
1103 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1104 PERF_DISABLE_MENUANIMATIONS) != 0);
1105 freerdp_settings_set_bool(settings, FreeRDP_DisableThemes,
1106 (freerdp_settings_get_uint32(settings, FreeRDP_PerformanceFlags) &
1107 PERF_DISABLE_THEMING) != 0);
1108}
FREERDP_API BOOL freerdp_settings_set_bool(rdpSettings *settings, FreeRDP_Settings_Keys_Bool id, BOOL val)
Sets a BOOL settings value.

◆ freerdp_rail_support_flags_to_string()

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.

Parameters
flagsThe flags to stringify
bufferA pointer to the string buffer to write to
lengthThe size of the string buffer
Returns
A pointer to buffer for success, nullptr otherwise

Definition at line 2140 of file common/settings.c.

2141{
2142 const UINT32 mask =
2143 RAIL_LEVEL_SUPPORTED | RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED |
2144 RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED | RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED |
2145 RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED | RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED |
2146 RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED | RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED;
2147
2148 if (flags & RAIL_LEVEL_SUPPORTED)
2149 winpr_str_append("RAIL_LEVEL_SUPPORTED", buffer, length, "|");
2150 if (flags & RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED)
2151 winpr_str_append("RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED", buffer, length, "|");
2152 if (flags & RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED)
2153 winpr_str_append("RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED", buffer, length, "|");
2154 if (flags & RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED)
2155 winpr_str_append("RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED", buffer, length, "|");
2156 if (flags & RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED)
2157 winpr_str_append("RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED", buffer, length, "|");
2158 if (flags & RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED)
2159 winpr_str_append("RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED", buffer, length, "|");
2160 if (flags & RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED)
2161 winpr_str_append("RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED", buffer, length, "|");
2162 if (flags & RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED)
2163 winpr_str_append("RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED", buffer, length, "|");
2164 if (flags & RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED)
2165 winpr_str_append("RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED", buffer, length, "|");
2166 if ((flags & ~mask) != 0)
2167 {
2168 char tbuffer[64] = WINPR_C_ARRAY_INIT;
2169 (void)_snprintf(tbuffer, sizeof(tbuffer), "RAIL_FLAG_UNKNOWN 0x%08" PRIx32, flags & mask);
2170 winpr_str_append(tbuffer, buffer, length, "|");
2171 }
2172 return buffer;
2173}

◆ freerdp_rdp_version_string()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_rdp_version_string ( UINT32  version)

Returns a stringified representation of the RDP protocol version.

Parameters
versionThe RDP protocol version number.
Returns
A string representation of the protocol version as "RDP_VERSION_10_11" or "RDP_VERSION_UNKNOWN" for invalid/unknown versions

Definition at line 2202 of file common/settings.c.

2203{
2204 switch (version)
2205 {
2206 case RDP_VERSION_4:
2207 return "RDP_VERSION_4";
2208 case RDP_VERSION_5_PLUS:
2209 return "RDP_VERSION_5_PLUS";
2210 case RDP_VERSION_10_0:
2211 return "RDP_VERSION_10_0";
2212 case RDP_VERSION_10_1:
2213 return "RDP_VERSION_10_1";
2214 case RDP_VERSION_10_2:
2215 return "RDP_VERSION_10_2";
2216 case RDP_VERSION_10_3:
2217 return "RDP_VERSION_10_3";
2218 case RDP_VERSION_10_4:
2219 return "RDP_VERSION_10_4";
2220 case RDP_VERSION_10_5:
2221 return "RDP_VERSION_10_5";
2222 case RDP_VERSION_10_6:
2223 return "RDP_VERSION_10_6";
2224 case RDP_VERSION_10_7:
2225 return "RDP_VERSION_10_7";
2226 case RDP_VERSION_10_8:
2227 return "RDP_VERSION_10_8";
2228 case RDP_VERSION_10_9:
2229 return "RDP_VERSION_10_9";
2230 case RDP_VERSION_10_10:
2231 return "RDP_VERSION_10_10";
2232 case RDP_VERSION_10_11:
2233 return "RDP_VERSION_10_11";
2234 case RDP_VERSION_10_12:
2235 return "RDP_VERSION_10_12";
2236 default:
2237 return "RDP_VERSION_UNKNOWN";
2238 }
2239}

◆ freerdp_rdpdr_dtyp_string()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_rdpdr_dtyp_string ( UINT32  type)

Returns a string representation of RDPDR_DTYP_*.

Parameters
typeThe integer of the RDPDR_DTYP_* to stringify
Returns
A string representation of the RDPDR_DTYP_* or "RDPDR_DTYP_UNKNOWN"

Definition at line 2292 of file common/settings.c.

2293{
2294 switch (type)
2295 {
2296 case RDPDR_DTYP_FILESYSTEM:
2297 return "RDPDR_DTYP_FILESYSTEM";
2298 case RDPDR_DTYP_PARALLEL:
2299 return "RDPDR_DTYP_PARALLEL";
2300 case RDPDR_DTYP_PRINT:
2301 return "RDPDR_DTYP_PRINT";
2302 case RDPDR_DTYP_SERIAL:
2303 return "RDPDR_DTYP_SERIAL";
2304 case RDPDR_DTYP_SMARTCARD:
2305 return "RDPDR_DTYP_SMARTCARD";
2306 default:
2307 return "RDPDR_DTYP_UNKNOWN";
2308 }
2309}

◆ freerdp_server_license_issuers_copy()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_server_license_issuers_copy ( rdpSettings *  settings,
char **  issuers,
UINT32  count 
)

Definition at line 1044 of file common/settings.c.

1045{
1046 WINPR_ASSERT(settings);
1047 WINPR_ASSERT(issuers || (count == 0));
1048
1049 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_ServerLicenseProductIssuers, nullptr,
1050 count))
1051 return FALSE;
1052
1053 for (UINT32 x = 0; x < count; x++)
1054 {
1055 char* issuer = _strdup(issuers[x]);
1056 if (!issuer)
1057 return FALSE;
1058 settings->ServerLicenseProductIssuers[x] = issuer;
1059 }
1060
1061 return TRUE;
1062}
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.

◆ freerdp_server_license_issuers_free()

FREERDP_API void freerdp_server_license_issuers_free ( rdpSettings *  settings)

Definition at line 1030 of file common/settings.c.

1031{
1032 WINPR_ASSERT(settings);
1033
1034 if (settings->ServerLicenseProductIssuers)
1035 {
1036 for (UINT32 x = 0; x < settings->ServerLicenseProductIssuersCount; x++)
1037 free(settings->ServerLicenseProductIssuers[x]);
1038 }
1039 free((void*)settings->ServerLicenseProductIssuers);
1040 settings->ServerLicenseProductIssuers = nullptr;
1041 settings->ServerLicenseProductIssuersCount = 0;
1042}

◆ freerdp_set_gateway_usage_method()

FREERDP_API BOOL freerdp_set_gateway_usage_method ( rdpSettings *  settings,
UINT32  GatewayUsageMethod 
)

This corresponds to "Automatically detect RD Gateway server settings", which means the client attempts to use gateway group policy settings http://technet.microsoft.com/en-us/library/cc770601.aspx

Definition at line 1110 of file common/settings.c.

1111{
1112 if (!freerdp_settings_set_uint32(settings, FreeRDP_GatewayUsageMethod, GatewayUsageMethod))
1113 return FALSE;
1114
1115 if (GatewayUsageMethod == TSC_PROXY_MODE_NONE_DIRECT)
1116 {
1117 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayEnabled, FALSE) ||
1118 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, FALSE))
1119 return FALSE;
1120 }
1121 else if (GatewayUsageMethod == TSC_PROXY_MODE_DIRECT)
1122 {
1123 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayEnabled, TRUE) ||
1124 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, FALSE))
1125 return FALSE;
1126 }
1127 else if (GatewayUsageMethod == TSC_PROXY_MODE_DETECT)
1128 {
1129 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayEnabled, TRUE) ||
1130 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, TRUE))
1131 return FALSE;
1132 }
1133 else if (GatewayUsageMethod == TSC_PROXY_MODE_DEFAULT)
1134 {
1140 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayEnabled, FALSE) ||
1141 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, FALSE))
1142 return FALSE;
1143 }
1144 else if (GatewayUsageMethod == TSC_PROXY_MODE_NONE_DETECT)
1145 {
1146 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayEnabled, FALSE) ||
1147 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, FALSE))
1148 return FALSE;
1149 }
1150
1151 return TRUE;
1152}

References freerdp_settings_set_bool(), and freerdp_settings_set_uint32().

Here is the call graph for this function:

◆ freerdp_settings_append_string()

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 not empty,

<old value><separator><param>

is created

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
separatorThe separator string to use. May be nullptr (no separator)
paramThe value to append
Returns
TRUE for success, FALSE for failure

Definition at line 2383 of file common/settings.c.

2385{
2386 const char* old = freerdp_settings_get_string(settings, id);
2387
2388 size_t len = 0;
2389 char* str = nullptr;
2390
2391 if (!old)
2392 winpr_asprintf(&str, &len, "%s", param);
2393 else if (!separator)
2394 winpr_asprintf(&str, &len, "%s%s", old, param);
2395 else
2396 winpr_asprintf(&str, &len, "%s%s%s", old, separator, param);
2397
2398 const BOOL rc = freerdp_settings_set_string_len(settings, id, str, len);
2399 free(str);
2400 return rc;
2401}
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.
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.

References freerdp_settings_get_string(), and freerdp_settings_set_string_len().

Here is the call graph for this function:

◆ freerdp_settings_are_valid()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_are_valid ( const rdpSettings *  settings)

Returns TRUE if settings are in a valid state, FALSE otherwise.

This function is meant to replace tideous return checks for freerdp_settings_set_* with a single check after these calls.

Parameters
settingsthe settings instance to check
Returns
TRUE if valid, FALSE otherwise

Definition at line 2403 of file common/settings.c.

2404{
2405 return settings != nullptr;
2406}

◆ freerdp_settings_clone()

WINPR_ATTR_NODISCARD FREERDP_API rdpSettings * freerdp_settings_clone ( const rdpSettings *  settings)

Creates a deep copy of settings.

Parameters
settingsA pointer to a settings struct to copy. May be nullptr (returns nullptr)
Returns
A newly allocated copy of settings or nullptr

Definition at line 1614 of file core/settings.c.

1615{
1616 rdpSettings* dst = (rdpSettings*)calloc(1, sizeof(rdpSettings));
1617
1618 if (!freerdp_settings_copy(dst, settings))
1619 goto out_fail;
1620
1621 return dst;
1622out_fail:
1623 WINPR_PRAGMA_DIAG_PUSH
1624 WINPR_PRAGMA_DIAG_IGNORED_MISMATCHED_DEALLOC
1626 WINPR_PRAGMA_DIAG_POP
1627 return nullptr;
1628}
BOOL freerdp_settings_copy(rdpSettings *dst, const rdpSettings *src)
Deep copies settings from src to dst.
void freerdp_settings_free(rdpSettings *settings)
Free a settings struct with all data in it.

References freerdp_settings_copy(), and freerdp_settings_free().

Here is the call graph for this function:

◆ freerdp_settings_copy()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_copy ( rdpSettings *  dst,
const rdpSettings *  src 
)

Deep copies settings from src to dst.

The function frees up all allocated data in dst before copying the data from src

Parameters
dstA pointer for the settings to copy data to. May be nullptr (fails copy)
srcA pointer to the settings to copy. May be nullptr (fails copy)
Returns
TRUE for success, FALSE for failure.

Definition at line 1588 of file core/settings.c.

1589{
1590 BOOL rc = 0;
1591
1592 if (!dst || !src)
1593 return FALSE;
1594
1595 /* This is required to free all non string buffers */
1596 freerdp_settings_free_internal(dst);
1597
1598 /* This copies everything except allocated non string buffers. reset all allocated buffers to
1599 * nullptr to fix issues during cleanup */
1600 rc = freerdp_settings_clone_keys(dst, src);
1601 if (!rc)
1602 goto out_fail;
1603 freerdp_settings_free_internal_ensure_reset(dst);
1604
1605 /* Begin copying */
1606 if (!freerdp_settings_int_buffer_copy(dst, src))
1607 goto out_fail;
1608 return TRUE;
1609out_fail:
1610 freerdp_settings_free_internal(dst);
1611 return FALSE;
1612}

Referenced by freerdp_settings_clone().

Here is the caller graph for this function:

◆ freerdp_settings_copy_item()

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

The function frees up all allocated data in dst before copying the data from src

Parameters
dstA pointer for the settings to copy data to. May be nullptr (fails copy)
srcA pointer to the settings to copy. May be nullptr (fails copy)
idThe settings identifier to copy
Returns
TRUE for success, FALSE for failure.

Definition at line 432 of file settings_str.c.

433{
434 WINPR_ASSERT(dst);
435 WINPR_ASSERT(src);
436
437 const SSIZE_T key = freerdp_settings_get_type_for_key(id);
438 switch (key)
439 {
440 case FREERDP_SETTINGS_TYPE_BOOL:
441 {
442 const BOOL val = freerdp_settings_get_bool(src, (FreeRDP_Settings_Keys_Bool)id);
443 return freerdp_settings_set_bool(dst, (FreeRDP_Settings_Keys_Bool)id, val);
444 }
445 case FREERDP_SETTINGS_TYPE_INT16:
446 {
447 const INT16 val = freerdp_settings_get_int16(src, (FreeRDP_Settings_Keys_Int16)id);
448 return freerdp_settings_set_int16(dst, (FreeRDP_Settings_Keys_Int16)id, val);
449 }
450 case FREERDP_SETTINGS_TYPE_INT32:
451 {
452 const INT32 val = freerdp_settings_get_int32(src, (FreeRDP_Settings_Keys_Int32)id);
453 return freerdp_settings_set_int32(dst, (FreeRDP_Settings_Keys_Int32)id, val);
454 }
455 case FREERDP_SETTINGS_TYPE_INT64:
456 {
457 const INT64 val = freerdp_settings_get_int64(src, (FreeRDP_Settings_Keys_Int64)id);
458 return freerdp_settings_set_int64(dst, (FreeRDP_Settings_Keys_Int64)id, val);
459 }
460 case FREERDP_SETTINGS_TYPE_UINT16:
461 {
462 const UINT16 val = freerdp_settings_get_uint16(src, (FreeRDP_Settings_Keys_UInt16)id);
463 return freerdp_settings_set_uint16(dst, (FreeRDP_Settings_Keys_UInt16)id, val);
464 }
465 case FREERDP_SETTINGS_TYPE_UINT32:
466 {
467 const UINT32 val = freerdp_settings_get_uint32(src, (FreeRDP_Settings_Keys_UInt32)id);
468 return freerdp_settings_set_uint32(dst, (FreeRDP_Settings_Keys_UInt32)id, val);
469 }
470 case FREERDP_SETTINGS_TYPE_UINT64:
471 {
472 const UINT64 val = freerdp_settings_get_uint64(src, (FreeRDP_Settings_Keys_UInt64)id);
473 return freerdp_settings_set_uint64(dst, (FreeRDP_Settings_Keys_UInt64)id, val);
474 }
475 case FREERDP_SETTINGS_TYPE_STRING:
476 {
477 const char* val = freerdp_settings_get_string(src, (FreeRDP_Settings_Keys_String)id);
478 return freerdp_settings_set_string(dst, (FreeRDP_Settings_Keys_String)id, val);
479 }
480 case FREERDP_SETTINGS_TYPE_POINTER:
481 {
482 const void* val = freerdp_settings_get_pointer(src, (FreeRDP_Settings_Keys_Pointer)id);
483 return freerdp_settings_set_pointer(dst, (FreeRDP_Settings_Keys_Pointer)id, val);
484 }
485 default:
486 return FALSE;
487 }
488}
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 INT32 freerdp_settings_get_int32(const rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id)
Returns a INT32 settings value.
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 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.
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 INT16 freerdp_settings_get_int16(const rdpSettings *settings, FreeRDP_Settings_Keys_Int16 id)
Returns a INT16 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 BOOL freerdp_settings_set_int32(rdpSettings *settings, FreeRDP_Settings_Keys_Int32 id, INT32 val)
Sets a INT32 settings value.
FREERDP_API BOOL freerdp_settings_set_int64(rdpSettings *settings, FreeRDP_Settings_Keys_Int64 id, INT64 val)
Sets a INT64 settings value.
FREERDP_API BOOL freerdp_settings_set_uint16(rdpSettings *settings, FreeRDP_Settings_Keys_UInt16 id, UINT16 val)
Sets a UINT16 settings value.
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.
SSIZE_T freerdp_settings_get_type_for_key(SSIZE_T key)
Get a key type for the key index.

References freerdp_settings_get_bool(), freerdp_settings_get_int16(), freerdp_settings_get_int32(), freerdp_settings_get_int64(), freerdp_settings_get_pointer(), freerdp_settings_get_string(), freerdp_settings_get_type_for_key(), freerdp_settings_get_uint16(), freerdp_settings_get_uint32(), freerdp_settings_get_uint64(), freerdp_settings_set_bool(), freerdp_settings_set_int16(), freerdp_settings_set_int32(), freerdp_settings_set_int64(), freerdp_settings_set_pointer(), freerdp_settings_set_string(), freerdp_settings_set_uint16(), freerdp_settings_set_uint32(), and freerdp_settings_set_uint64().

Here is the call graph for this function:

◆ freerdp_settings_deserialize()

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.

Parameters
jstrThe JSON string
lengthThe strlen of the JSON string
Returns
An allocated rdpSettings struct or nullptr in case of an error
Since
version 3.16.0

Definition at line 4290 of file common/settings.c.

4291{
4292 WINPR_JSON* json = WINPR_JSON_ParseWithLength(jstr, length);
4293 if (!json)
4294 return nullptr;
4295
4296 WINPR_JSON* jbool = WINPR_JSON_GetObjectItemCaseSensitive(
4297 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_BOOL));
4298 WINPR_JSON* juint16 = WINPR_JSON_GetObjectItemCaseSensitive(
4299 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT16));
4300 WINPR_JSON* jint16 = WINPR_JSON_GetObjectItemCaseSensitive(
4301 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT16));
4302 WINPR_JSON* juint32 = WINPR_JSON_GetObjectItemCaseSensitive(
4303 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT32));
4304 WINPR_JSON* jint32 = WINPR_JSON_GetObjectItemCaseSensitive(
4305 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT32));
4306 WINPR_JSON* juint64 = WINPR_JSON_GetObjectItemCaseSensitive(
4307 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT64));
4308 WINPR_JSON* jint64 = WINPR_JSON_GetObjectItemCaseSensitive(
4309 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT64));
4310 WINPR_JSON* jstring = WINPR_JSON_GetObjectItemCaseSensitive(
4311 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_STRING));
4312 WINPR_JSON* jpointer = WINPR_JSON_GetObjectItemCaseSensitive(
4313 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_POINTER));
4314
4315 rdpSettings* settings = freerdp_settings_new(0);
4316 if (!settings)
4317 goto fail;
4318 if (!jbool || !juint16 || !jint16 || !juint32 || !jint32 || !juint64 || !jint64 || !jstring ||
4319 !jpointer)
4320 goto fail;
4321
4322 for (int x = 0; x < FreeRDP_Settings_StableAPI_MAX; x++)
4323 {
4324 union
4325 {
4326
4327 int s;
4328 FreeRDP_Settings_Keys_Bool b;
4329 FreeRDP_Settings_Keys_Int16 i16;
4330 FreeRDP_Settings_Keys_UInt16 u16;
4331 FreeRDP_Settings_Keys_Int32 i32;
4332 FreeRDP_Settings_Keys_UInt32 u32;
4333 FreeRDP_Settings_Keys_Int64 i64;
4334 FreeRDP_Settings_Keys_UInt64 u64;
4335 FreeRDP_Settings_Keys_String str;
4336 FreeRDP_Settings_Keys_Pointer ptr;
4337 } iter;
4338 iter.s = x;
4339
4340 SSIZE_T type = freerdp_settings_get_type_for_key(iter.s);
4341 switch (type)
4342 {
4343 case RDP_SETTINGS_TYPE_POINTER:
4344 if (!deserialize_pointer(jpointer, settings, iter.ptr))
4345 goto fail;
4346 break;
4347 default:
4348 break;
4349 }
4350 }
4351
4352 for (int x = 0; x < FreeRDP_Settings_StableAPI_MAX; x++)
4353 {
4354 union
4355 {
4356
4357 int s;
4358 FreeRDP_Settings_Keys_Bool b;
4359 FreeRDP_Settings_Keys_Int16 i16;
4360 FreeRDP_Settings_Keys_UInt16 u16;
4361 FreeRDP_Settings_Keys_Int32 i32;
4362 FreeRDP_Settings_Keys_UInt32 u32;
4363 FreeRDP_Settings_Keys_Int64 i64;
4364 FreeRDP_Settings_Keys_UInt64 u64;
4365 FreeRDP_Settings_Keys_String str;
4366 FreeRDP_Settings_Keys_Pointer ptr;
4367 } iter;
4368 iter.s = x;
4369
4370 const char* name = freerdp_settings_get_name_for_key(iter.s);
4371 SSIZE_T type = freerdp_settings_get_type_for_key(iter.s);
4372 switch (type)
4373 {
4374 case RDP_SETTINGS_TYPE_BOOL:
4375 {
4376 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(jbool, name);
4377 if (!item)
4378 goto fail;
4379 if (!WINPR_JSON_IsBool(item))
4380 goto fail;
4381 const BOOL val = WINPR_JSON_IsTrue(item);
4382 if (!freerdp_settings_set_bool(settings, iter.b, val))
4383 goto fail;
4384 }
4385 break;
4386 case RDP_SETTINGS_TYPE_UINT16:
4387 {
4388 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(juint16, name);
4389 const uint16_t val = (uint16_t)uint_from_json_item(item, UINT16_MAX);
4390 if (errno != 0)
4391 goto fail;
4392 if (!freerdp_settings_set_uint16(settings, iter.u16, val))
4393 goto fail;
4394 }
4395 break;
4396 case RDP_SETTINGS_TYPE_INT16:
4397 {
4398 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(jint16, name);
4399 const int16_t val = (int16_t)int_from_json_item(item, INT16_MIN, INT16_MAX);
4400 if (errno != 0)
4401 goto fail;
4402 if (!freerdp_settings_set_int16(settings, iter.i16, val))
4403 goto fail;
4404 }
4405 break;
4406 case RDP_SETTINGS_TYPE_UINT32:
4407 {
4408 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(juint32, name);
4409 const uint32_t val = (uint32_t)uint_from_json_item(item, UINT32_MAX);
4410 if (errno != 0)
4411 goto fail;
4412 if (!freerdp_settings_set_uint32(settings, iter.u32, val))
4413 goto fail;
4414 }
4415 break;
4416 case RDP_SETTINGS_TYPE_INT32:
4417 {
4418 const int64_t val = int_from_json(jint32, name, INT32_MIN, INT32_MAX);
4419 if (errno != 0)
4420 goto fail;
4421 if (!freerdp_settings_set_int32(settings, iter.i32, (int32_t)val))
4422 goto fail;
4423 }
4424 break;
4425 case RDP_SETTINGS_TYPE_UINT64:
4426 {
4427 const uint64_t val = uint_from_json(juint64, name, UINT64_MAX);
4428 if (errno != 0)
4429 goto fail;
4430 if (!freerdp_settings_set_uint64(settings, iter.u64, val))
4431 goto fail;
4432 }
4433 break;
4434 case RDP_SETTINGS_TYPE_INT64:
4435 {
4436 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(jint64, name);
4437 const int64_t val = int_from_json_item(item, INT64_MIN, INT64_MAX);
4438 if (errno != 0)
4439 goto fail;
4440 if (!freerdp_settings_set_int64(settings, iter.i64, val))
4441 goto fail;
4442 }
4443 break;
4444 case RDP_SETTINGS_TYPE_STRING:
4445 {
4446 const char* val = nullptr;
4447 WINPR_JSON* item = WINPR_JSON_GetObjectItemCaseSensitive(jstring, name);
4448 if (item && !WINPR_JSON_IsNull(item))
4449 {
4450 if (!WINPR_JSON_IsString(item))
4451 goto fail;
4452 val = WINPR_JSON_GetStringValue(item);
4453 if (!val)
4454 goto fail;
4455 }
4456 if (!freerdp_settings_set_string(settings, iter.str, val))
4457 goto fail;
4458 }
4459 break;
4460 case RDP_SETTINGS_TYPE_POINTER:
4461 default:
4462 break;
4463 }
4464 }
4465
4466 WINPR_JSON_Delete(json);
4467 return settings;
4468
4469fail:
4470 freerdp_settings_free(settings);
4471 WINPR_JSON_Delete(json);
4472 return nullptr;
4473}
WINPR_API BOOL WINPR_JSON_IsNull(const WINPR_JSON *item)
Check if JSON item is Null.
Definition c-json.c:172
WINPR_API BOOL WINPR_JSON_IsString(const WINPR_JSON *item)
Check if JSON item is of type String.
Definition c-json.c:182
WINPR_API BOOL WINPR_JSON_IsBool(const WINPR_JSON *item)
Check if JSON item is of type BOOL.
Definition c-json.c:167
WINPR_API WINPR_JSON * WINPR_JSON_GetObjectItemCaseSensitive(const WINPR_JSON *object, const char *string)
Same as WINPR_JSON_GetObjectItem but with case sensitive matching.
Definition c-json.c:127
WINPR_ATTR_NODISCARD WINPR_API WINPR_JSON * WINPR_JSON_ParseWithLength(const char *value, size_t buffer_length)
Parse a JSON string.
Definition c-json.c:98
WINPR_API const char * WINPR_JSON_GetStringValue(WINPR_JSON *item)
Return the String value of a JSON item.
Definition c-json.c:142
WINPR_API void WINPR_JSON_Delete(WINPR_JSON *item)
Delete a WinPR JSON wrapper object.
Definition c-json.c:103
WINPR_API BOOL WINPR_JSON_IsTrue(const WINPR_JSON *item)
Check if JSON item is BOOL value True.
Definition c-json.c:162
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 rdpSettings * freerdp_settings_new(DWORD flags)
creates a new setting struct
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_name_for_key(SSIZE_T key)
Returns the type name for a key.

References freerdp_settings_free(), freerdp_settings_get_name_for_key(), freerdp_settings_get_type_for_key(), freerdp_settings_get_type_name_for_type(), freerdp_settings_new(), freerdp_settings_set_bool(), freerdp_settings_set_int16(), freerdp_settings_set_int32(), freerdp_settings_set_int64(), freerdp_settings_set_string(), freerdp_settings_set_uint16(), freerdp_settings_set_uint32(), freerdp_settings_set_uint64(), WINPR_JSON_Delete(), WINPR_JSON_GetObjectItemCaseSensitive(), WINPR_JSON_GetStringValue(), WINPR_JSON_IsBool(), WINPR_JSON_IsNull(), WINPR_JSON_IsString(), WINPR_JSON_IsTrue(), and WINPR_JSON_ParseWithLength().

Here is the call graph for this function:

◆ freerdp_settings_dump()

FREERDP_API void freerdp_settings_dump ( wLog *  log,
DWORD  level,
const rdpSettings *  settings 
)

Dumps the contents of a settings struct to a WLog logger.

Parameters
logThe logger to write to, must not be nullptr
levelThe WLog level to use for the log entries
settingsA pointer to the settings to dump. May be nullptr.

Definition at line 249 of file settings_str.c.

250{
251 WINPR_ASSERT(log);
252 WINPR_ASSERT(settings);
253
254 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
255 {
256 const struct settings_str_entry* cur = &settings_map[x];
257 switch (cur->type)
258 {
259 case FREERDP_SETTINGS_TYPE_BOOL: /* bool */
260 {
261 BOOL sval =
262 freerdp_settings_get_bool(settings, (FreeRDP_Settings_Keys_Bool)cur->id);
263 WLog_Print(log, level, "%s [BOOL]: %s", cur->str, sval ? "TRUE" : "FALSE");
264 }
265 break;
266 case FREERDP_SETTINGS_TYPE_UINT16: /* UINT16 */
267 {
268 UINT16 sval =
269 freerdp_settings_get_uint16(settings, (FreeRDP_Settings_Keys_UInt16)cur->id);
270 WLog_Print(log, level, "%s [UINT16]: %" PRIu16, cur->str, sval);
271 }
272 break;
273 case FREERDP_SETTINGS_TYPE_INT16: /* INT16 */
274 {
275 INT16 sval =
276 freerdp_settings_get_int16(settings, (FreeRDP_Settings_Keys_Int16)cur->id);
277 WLog_Print(log, level, "%s [INT16]: %" PRId16, cur->str, sval);
278 }
279 break;
280 case FREERDP_SETTINGS_TYPE_UINT32: /* UINT32 */
281 {
282 UINT32 sval =
283 freerdp_settings_get_uint32(settings, (FreeRDP_Settings_Keys_UInt32)cur->id);
284 WLog_Print(log, level, "%s [UINT32]: %" PRIu32, cur->str, sval);
285 }
286 break;
287 case FREERDP_SETTINGS_TYPE_INT32: /* INT32 */
288 {
289 INT32 sval =
290 freerdp_settings_get_int32(settings, (FreeRDP_Settings_Keys_Int32)cur->id);
291 WLog_Print(log, level, "%s [INT32]: %" PRId32, cur->str, sval);
292 }
293 break;
294 case FREERDP_SETTINGS_TYPE_UINT64: /* UINT64 */
295 {
296 UINT64 sval =
297 freerdp_settings_get_uint64(settings, (FreeRDP_Settings_Keys_UInt64)cur->id);
298 WLog_Print(log, level, "%s [UINT64]: %" PRIu64, cur->str, sval);
299 }
300 break;
301 case FREERDP_SETTINGS_TYPE_INT64: /* INT64 */
302 {
303 INT64 sval =
304 freerdp_settings_get_int64(settings, (FreeRDP_Settings_Keys_Int64)cur->id);
305 WLog_Print(log, level, "%s [INT64]: %" PRId64, cur->str, sval);
306 }
307 break;
308 case FREERDP_SETTINGS_TYPE_STRING: /* strings */
309 {
310 const char* sval =
311 freerdp_settings_get_string(settings, (FreeRDP_Settings_Keys_String)cur->id);
312 WLog_Print(log, level, "%s [STRING]: '%s'", cur->str, sval);
313 }
314 break;
315 case FREERDP_SETTINGS_TYPE_POINTER: /* pointer */
316 {
317 const void* sval =
318 freerdp_settings_get_pointer(settings, (FreeRDP_Settings_Keys_Pointer)cur->id);
319 WLog_Print(log, level, "%s [POINTER]: '%p'", cur->str, sval);
320 }
321 break;
322 default:
323 break;
324 }
325 }
326}

References freerdp_settings_get_bool(), freerdp_settings_get_int16(), freerdp_settings_get_int32(), freerdp_settings_get_int64(), freerdp_settings_get_pointer(), freerdp_settings_get_string(), freerdp_settings_get_uint16(), freerdp_settings_get_uint32(), and freerdp_settings_get_uint64().

Here is the call graph for this function:

◆ freerdp_settings_free()

FREERDP_API void freerdp_settings_free ( rdpSettings *  settings)

Free a settings struct with all data in it.

Parameters
settingsA pointer to the settings to free, May be nullptr

Definition at line 1372 of file core/settings.c.

1373{
1374 if (!settings)
1375 return;
1376
1377 freerdp_settings_free_internal(settings);
1378 free(settings);
1379}

Referenced by freerdp_settings_clone(), freerdp_settings_deserialize(), and freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_get_bool()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_settings_get_bool ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Bool  id 
)

Returns a boolean settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the boolean key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_new(), freerdp_settings_print_diff(), freerdp_settings_serialize(), AppDelegate::rdpConnectError:, and SdlContext::SdlContext().

Here is the caller graph for this function:

◆ freerdp_settings_get_codecs_flags()

WINPR_ATTR_NODISCARD FREERDP_API UINT32 freerdp_settings_get_codecs_flags ( const rdpSettings *  settings)

helper function to get a mask of supported codec flags.

This function checks various settings to create a mask of supported codecs FreeRDP_CodecFlags defines the codecs

Parameters
settingsthe settings to check
Returns
a mask of supported codecs

Definition at line 1994 of file common/settings.c.

1995{
1996 UINT32 flags = FREERDP_CODEC_ALL;
1997 if (settings->RemoteFxCodec == FALSE)
1998 {
1999 flags &= (uint32_t)~FREERDP_CODEC_REMOTEFX;
2000 }
2001 if (settings->NSCodec == FALSE)
2002 {
2003 flags &= (uint32_t)~FREERDP_CODEC_NSCODEC;
2004 }
2005 /*TODO: check other codecs flags */
2006 return flags;
2007}

◆ freerdp_settings_get_config_path()

WINPR_ATTR_NODISCARD FREERDP_API char * freerdp_settings_get_config_path ( void  )

return the configuration directory for the library

Returns
The current configuration path or nullptr
Since
version 3.6.0
Note
Since 3.17.1 this is a wrapper for freerdp_GetConfigFilePath(FALSE, "")

Definition at line 808 of file core/settings.c.

809{
810 return freerdp_GetConfigFilePath(FALSE, "");
811}

Referenced by freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_get_int16()

WINPR_ATTR_NODISCARD FREERDP_API INT16 freerdp_settings_get_int16 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Int16  id 
)

Returns a INT16 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the INT16 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_int32()

WINPR_ATTR_NODISCARD FREERDP_API INT32 freerdp_settings_get_int32 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Int32  id 
)

Returns a INT32 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the INT32 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_int64()

WINPR_ATTR_NODISCARD FREERDP_API INT64 freerdp_settings_get_int64 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Int64  id 
)

Returns a INT64 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the INT64 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_key_for_name()

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.

Parameters
valueA key name string like FreeRDP_ServerMode
Returns
The key index or -1 in case of an error (e.g. name does not exist)

Definition at line 351 of file settings_str.c.

352{
353 WINPR_ASSERT(value);
354
355 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
356 {
357 const struct settings_str_entry* cur = &settings_map[x];
358 if (strcmp(value, cur->str) == 0)
359 return cur->id;
360 }
361 return -1;
362}

◆ freerdp_settings_get_name_for_key()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_name_for_key ( SSIZE_T  key)

Returns the type name for a key.

Parameters
keythe key number to stringify
Returns
the name of the key or nullptr

Definition at line 421 of file settings_str.c.

422{
423 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
424 {
425 const struct settings_str_entry* cur = &settings_map[x];
426 if (cur->id == key)
427 return cur->str;
428 }
429 return nullptr;
430}

Referenced by freerdp_settings_deserialize(), freerdp_settings_get_pointer_writable(), freerdp_settings_get_string_writable(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_pointer()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the immutable pointer value

Definition at line 1414 of file common/settings.c.

1416{
1417 union
1418 {
1419 const rdpSettings* pc;
1420 rdpSettings* p;
1421 } cnv;
1422 cnv.pc = settings;
1423 return freerdp_settings_get_pointer_writable(cnv.p, id);
1424}
WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_writable(rdpSettings *settings, FreeRDP_Settings_Keys_Pointer id)
Returns a mutable pointer settings value.

References freerdp_settings_get_pointer_writable().

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), and freerdp_settings_print_diff().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ freerdp_settings_get_pointer_array()

WINPR_ATTR_NODISCARD FREERDP_API const void * freerdp_settings_get_pointer_array ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Pointer  id,
size_t  offset 
)

Definition at line 1988 of file common/settings.c.

1990{
1991 return freerdp_settings_get_pointer_array_writable(settings, id, offset);
1992}

◆ freerdp_settings_get_pointer_array_writable()

WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_array_writable ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_Pointer  id,
size_t  offset 
)

Definition at line 1639 of file common/settings.c.

1641{
1642 size_t max = 0;
1643 if (!settings)
1644 return nullptr;
1645 switch (id)
1646 {
1647 case FreeRDP_ClientAutoReconnectCookie:
1648 max = 1;
1649 if ((offset >= max) || !settings->ClientAutoReconnectCookie)
1650 goto fail;
1651 return &settings->ClientAutoReconnectCookie[offset];
1652 case FreeRDP_ServerAutoReconnectCookie:
1653 max = 1;
1654 if ((offset >= max) || !settings->ServerAutoReconnectCookie)
1655 goto fail;
1656 return &settings->ServerAutoReconnectCookie[offset];
1657 case FreeRDP_ServerCertificate:
1658 max = freerdp_settings_get_uint32(settings, FreeRDP_ServerCertificateLength);
1659 if (offset >= max)
1660 goto fail;
1661 return &settings->ServerCertificate[offset];
1662 case FreeRDP_ServerRandom:
1663 max = freerdp_settings_get_uint32(settings, FreeRDP_ServerRandomLength);
1664 if (offset >= max)
1665 goto fail;
1666 return &settings->ServerRandom[offset];
1667 case FreeRDP_ClientRandom:
1668 max = freerdp_settings_get_uint32(settings, FreeRDP_ClientRandomLength);
1669 if (offset >= max)
1670 goto fail;
1671 return &settings->ClientRandom[offset];
1672 case FreeRDP_LoadBalanceInfo:
1673 max = freerdp_settings_get_uint32(settings, FreeRDP_LoadBalanceInfoLength);
1674 if (offset >= max)
1675 goto fail;
1676 return &settings->LoadBalanceInfo[offset];
1677
1678 case FreeRDP_RedirectionTsvUrl:
1679 max = freerdp_settings_get_uint32(settings, FreeRDP_RedirectionTsvUrlLength);
1680 if (offset >= max)
1681 goto fail;
1682 return &settings->RedirectionTsvUrl[offset];
1683
1684 case FreeRDP_RedirectionPassword:
1685 max = freerdp_settings_get_uint32(settings, FreeRDP_RedirectionPasswordLength);
1686 if (offset >= max)
1687 goto fail;
1688 return &settings->RedirectionPassword[offset];
1689
1690 case FreeRDP_OrderSupport:
1691 max = 32;
1692 if (offset >= max)
1693 goto fail;
1694 return &settings->OrderSupport[offset];
1695 case FreeRDP_MonitorIds:
1696 max = freerdp_settings_get_uint32(settings, FreeRDP_NumMonitorIds);
1697 if (offset >= max)
1698 goto fail;
1699 return &settings->MonitorIds[offset];
1700 case FreeRDP_MonitorDefArray:
1701 max = freerdp_settings_get_uint32(settings, FreeRDP_MonitorDefArraySize);
1702 if (offset >= max)
1703 goto fail;
1704 return &settings->MonitorDefArray[offset];
1705 case FreeRDP_ChannelDefArray:
1706 max = freerdp_settings_get_uint32(settings, FreeRDP_ChannelDefArraySize);
1707 if (offset >= max)
1708 goto fail;
1709 return &settings->ChannelDefArray[offset];
1710 case FreeRDP_DeviceArray:
1711 max = freerdp_settings_get_uint32(settings, FreeRDP_DeviceArraySize);
1712 if (offset >= max)
1713 goto fail;
1714 return settings->DeviceArray[offset];
1715 case FreeRDP_StaticChannelArray:
1716 max = freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelArraySize);
1717 if (offset >= max)
1718 goto fail;
1719 return settings->StaticChannelArray[offset];
1720 case FreeRDP_DynamicChannelArray:
1721 max = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelArraySize);
1722 if (offset >= max)
1723 goto fail;
1724 return settings->DynamicChannelArray[offset];
1725 case FreeRDP_FragCache:
1726 max = 1;
1727 if (offset >= max)
1728 goto fail;
1729 return &settings->FragCache[offset];
1730 case FreeRDP_GlyphCache:
1731 max = 10;
1732 if (offset >= max)
1733 goto fail;
1734 return &settings->GlyphCache[offset];
1735 case FreeRDP_BitmapCacheV2CellInfo:
1736 max = freerdp_settings_get_uint32(settings, FreeRDP_BitmapCacheV2NumCells);
1737 if (offset >= max)
1738 goto fail;
1739 return &settings->BitmapCacheV2CellInfo[offset];
1740 case FreeRDP_ReceivedCapabilities:
1741 max = freerdp_settings_get_uint32(settings, FreeRDP_ReceivedCapabilitiesSize);
1742 if (offset >= max)
1743 goto fail;
1744 return &settings->ReceivedCapabilities[offset];
1745 case FreeRDP_TargetNetAddresses:
1746 max = freerdp_settings_get_uint32(settings, FreeRDP_TargetNetAddressCount);
1747 if (offset >= max)
1748 goto fail;
1749 WINPR_ASSERT(settings->TargetNetAddresses);
1750 return settings->TargetNetAddresses[offset];
1751 case FreeRDP_TargetNetPorts:
1752 max = freerdp_settings_get_uint32(settings, FreeRDP_TargetNetAddressCount);
1753 if (offset >= max)
1754 goto fail;
1755 WINPR_ASSERT(settings->TargetNetPorts);
1756 return &settings->TargetNetPorts[offset];
1757 case FreeRDP_ClientTimeZone:
1758 max = 1;
1759 if (offset >= max)
1760 goto fail;
1761 return settings->ClientTimeZone;
1762 case FreeRDP_RdpServerCertificate:
1763 max = 1;
1764 if (offset >= max)
1765 goto fail;
1766 return settings->RdpServerCertificate;
1767 case FreeRDP_RdpServerRsaKey:
1768 max = 1;
1769 if (offset >= max)
1770 goto fail;
1771 return settings->RdpServerRsaKey;
1772 case FreeRDP_ServerLicenseProductIssuers:
1773 max = freerdp_settings_get_uint32(settings, FreeRDP_ServerLicenseProductIssuersCount);
1774 if (offset >= max)
1775 goto fail;
1776 return settings->ServerLicenseProductIssuers[offset];
1777 case FreeRDP_ReceivedCapabilityData:
1778 max = freerdp_settings_get_uint32(settings, FreeRDP_ReceivedCapabilitiesSize);
1779 if (offset >= max)
1780 goto fail;
1781 WINPR_ASSERT(settings->ReceivedCapabilityData);
1782 return settings->ReceivedCapabilityData[offset];
1783
1784 case FreeRDP_ReceivedCapabilityDataSizes:
1785 max = freerdp_settings_get_uint32(settings, FreeRDP_ReceivedCapabilitiesSize);
1786 if (offset >= max)
1787 goto fail;
1788 WINPR_ASSERT(settings->ReceivedCapabilityDataSizes);
1789 return &settings->ReceivedCapabilityDataSizes[offset];
1790 default:
1791 WLog_WARN(TAG, "Invalid id %s [%d]", freerdp_settings_get_name_for_key(id), id);
1792 return nullptr;
1793 }
1794
1795fail:
1796 WLog_WARN(TAG, "Invalid offset for %s [%d]: size=%" PRIuz ", offset=%" PRIuz,
1797 freerdp_settings_get_name_for_key(id), id, max, offset);
1798 return nullptr;
1799}

◆ freerdp_settings_get_pointer_writable()

WINPR_ATTR_NODISCARD FREERDP_API void * freerdp_settings_get_pointer_writable ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Pointer  id 
)

Returns a mutable pointer settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the mutable pointer value

Definition at line 4088 of file settings_getters.c.

4089{
4090 WINPR_ASSERT(settings);
4091
4092 switch (id)
4093 {
4094 case FreeRDP_BitmapCacheV2CellInfo:
4095 return (void*)settings->BitmapCacheV2CellInfo;
4096
4097 case FreeRDP_ChannelDefArray:
4098 return (void*)settings->ChannelDefArray;
4099
4100 case FreeRDP_ClientAutoReconnectCookie:
4101 return (void*)settings->ClientAutoReconnectCookie;
4102
4103 case FreeRDP_ClientRandom:
4104 return (void*)settings->ClientRandom;
4105
4106 case FreeRDP_ClientTimeZone:
4107 return (void*)settings->ClientTimeZone;
4108
4109 case FreeRDP_DeviceArray:
4110 return (void*)settings->DeviceArray;
4111
4112 case FreeRDP_DynamicChannelArray:
4113 return (void*)settings->DynamicChannelArray;
4114
4115 case FreeRDP_FragCache:
4116 return (void*)settings->FragCache;
4117
4118 case FreeRDP_GlyphCache:
4119 return (void*)settings->GlyphCache;
4120
4121 case FreeRDP_LoadBalanceInfo:
4122 return (void*)settings->LoadBalanceInfo;
4123
4124 case FreeRDP_MonitorDefArray:
4125 return (void*)settings->MonitorDefArray;
4126
4127 case FreeRDP_MonitorIds:
4128 return (void*)settings->MonitorIds;
4129
4130 case FreeRDP_OrderSupport:
4131 return (void*)settings->OrderSupport;
4132
4133 case FreeRDP_Password51:
4134 return (void*)settings->Password51;
4135
4136 case FreeRDP_RdpServerCertificate:
4137 return (void*)settings->RdpServerCertificate;
4138
4139 case FreeRDP_RdpServerRsaKey:
4140 return (void*)settings->RdpServerRsaKey;
4141
4142 case FreeRDP_ReceivedCapabilities:
4143 return (void*)settings->ReceivedCapabilities;
4144
4145 case FreeRDP_ReceivedCapabilityData:
4146 return (void*)settings->ReceivedCapabilityData;
4147
4148 case FreeRDP_ReceivedCapabilityDataSizes:
4149 return (void*)settings->ReceivedCapabilityDataSizes;
4150
4151 case FreeRDP_RedirectionGuid:
4152 return (void*)settings->RedirectionGuid;
4153
4154 case FreeRDP_RedirectionPassword:
4155 return (void*)settings->RedirectionPassword;
4156
4157 case FreeRDP_RedirectionTargetCertificate:
4158 return (void*)settings->RedirectionTargetCertificate;
4159
4160 case FreeRDP_RedirectionTsvUrl:
4161 return (void*)settings->RedirectionTsvUrl;
4162
4163 case FreeRDP_ServerAutoReconnectCookie:
4164 return (void*)settings->ServerAutoReconnectCookie;
4165
4166 case FreeRDP_ServerCertificate:
4167 return (void*)settings->ServerCertificate;
4168
4169 case FreeRDP_ServerLicenseProductIssuers:
4170 return (void*)settings->ServerLicenseProductIssuers;
4171
4172 case FreeRDP_ServerRandom:
4173 return (void*)settings->ServerRandom;
4174
4175 case FreeRDP_StaticChannelArray:
4176 return (void*)settings->StaticChannelArray;
4177
4178 case FreeRDP_TargetNetAddresses:
4179 return (void*)settings->TargetNetAddresses;
4180
4181 case FreeRDP_TargetNetPorts:
4182 return (void*)settings->TargetNetPorts;
4183
4184 case FreeRDP_instance:
4185 return settings->instance;
4186
4187 default:
4188 WLog_ERR(TAG, "Invalid key index %d [%s|%s]", id, freerdp_settings_get_name_for_key(id),
4190 WINPR_ASSERT(FALSE);
4191 return nullptr;
4192 }
4193}
WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_type_name_for_key(SSIZE_T key)
Returns the type name for a key.

References freerdp_settings_get_name_for_key(), and freerdp_settings_get_type_name_for_key().

Referenced by freerdp_settings_get_pointer(), freerdp_settings_new(), and freerdp_settings_set_monitor_def_array_sorted().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ freerdp_settings_get_server_name()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_server_name ( const rdpSettings *  settings)

A helper function to return the correct server name.

The server name might be in key FreeRDP_ServerHostname or if used in FreeRDP_UserSpecifiedServerName. This function returns the correct name to use.

Parameters
settingsThe settings to query, must not be nullptr.
Returns
A string pointer or nullptr in case of failure.

Definition at line 2009 of file common/settings.c.

2010{
2011 WINPR_ASSERT(settings);
2012 const char* hostname = settings->ServerHostname;
2013
2014 if (settings->UserSpecifiedServerName)
2015 hostname = settings->UserSpecifiedServerName;
2016
2017 return hostname;
2018}

◆ freerdp_settings_get_string()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the immutable string pointer

Referenced by freerdp_settings_append_string(), freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_get_string_as_utf16(), freerdp_settings_new(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_string_as_utf16()

WINPR_ATTR_NODISCARD 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.

Parameters
settingsA pointer to the settings struct to use
idThe settings identifier
Returns
An allocated, '\0' terminated WCHAR string or nullptr

Definition at line 2281 of file common/settings.c.

2283{
2284 const char* str = freerdp_settings_get_string(settings, id);
2285 if (pCharLen)
2286 *pCharLen = 0;
2287 if (!str)
2288 return nullptr;
2289 return ConvertUtf8ToWCharAlloc(str, pCharLen);
2290}

References freerdp_settings_get_string().

Here is the call graph for this function:

◆ freerdp_settings_get_string_writable()

WINPR_ATTR_NODISCARD FREERDP_API char * freerdp_settings_get_string_writable ( rdpSettings *  settings,
FreeRDP_Settings_Keys_String  id 
)

Returns a string settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the string pointer

Definition at line 3048 of file settings_getters.c.

3049{
3050 WINPR_ASSERT(settings);
3051
3052 switch (id)
3053 {
3054 case FreeRDP_AadServerHostname:
3055 return settings->AadServerHostname;
3056
3057 case FreeRDP_AcceptedCert:
3058 return settings->AcceptedCert;
3059
3060 case FreeRDP_ActionScript:
3061 return settings->ActionScript;
3062
3063 case FreeRDP_AllowedTlsCiphers:
3064 return settings->AllowedTlsCiphers;
3065
3066 case FreeRDP_AlternateShell:
3067 return settings->AlternateShell;
3068
3069 case FreeRDP_AssistanceFile:
3070 return settings->AssistanceFile;
3071
3072 case FreeRDP_AuthenticationPackageList:
3073 return settings->AuthenticationPackageList;
3074
3075 case FreeRDP_AuthenticationServiceClass:
3076 return settings->AuthenticationServiceClass;
3077
3078 case FreeRDP_BitmapCachePersistFile:
3079 return settings->BitmapCachePersistFile;
3080
3081 case FreeRDP_CardName:
3082 return settings->CardName;
3083
3084 case FreeRDP_CertificateAcceptedFingerprints:
3085 return settings->CertificateAcceptedFingerprints;
3086
3087 case FreeRDP_CertificateName:
3088 return settings->CertificateName;
3089
3090 case FreeRDP_ClientAddress:
3091 return settings->ClientAddress;
3092
3093 case FreeRDP_ClientDir:
3094 return settings->ClientDir;
3095
3096 case FreeRDP_ClientHostname:
3097 return settings->ClientHostname;
3098
3099 case FreeRDP_ClientProductId:
3100 return settings->ClientProductId;
3101
3102 case FreeRDP_ClipboardUseSelection:
3103 return settings->ClipboardUseSelection;
3104
3105 case FreeRDP_ComputerName:
3106 return settings->ComputerName;
3107
3108 case FreeRDP_ConfigPath:
3109 return settings->ConfigPath;
3110
3111 case FreeRDP_ConnectionFile:
3112 return settings->ConnectionFile;
3113
3114 case FreeRDP_ContainerName:
3115 return settings->ContainerName;
3116
3117 case FreeRDP_CspName:
3118 return settings->CspName;
3119
3120 case FreeRDP_CurrentPath:
3121 return settings->CurrentPath;
3122
3123 case FreeRDP_Domain:
3124 return settings->Domain;
3125
3126 case FreeRDP_DrivesToRedirect:
3127 return settings->DrivesToRedirect;
3128
3129 case FreeRDP_DumpRemoteFxFile:
3130 return settings->DumpRemoteFxFile;
3131
3132 case FreeRDP_DynamicDSTTimeZoneKeyName:
3133 return settings->DynamicDSTTimeZoneKeyName;
3134
3135 case FreeRDP_GatewayAcceptedCert:
3136 return settings->GatewayAcceptedCert;
3137
3138 case FreeRDP_GatewayAccessToken:
3139 return settings->GatewayAccessToken;
3140
3141 case FreeRDP_GatewayAvdAadtenantid:
3142 return settings->GatewayAvdAadtenantid;
3143
3144 case FreeRDP_GatewayAvdAccessAadFormat:
3145 return settings->GatewayAvdAccessAadFormat;
3146
3147 case FreeRDP_GatewayAvdAccessTokenFormat:
3148 return settings->GatewayAvdAccessTokenFormat;
3149
3150 case FreeRDP_GatewayAvdActivityhint:
3151 return settings->GatewayAvdActivityhint;
3152
3153 case FreeRDP_GatewayAvdArmpath:
3154 return settings->GatewayAvdArmpath;
3155
3156 case FreeRDP_GatewayAvdClientID:
3157 return settings->GatewayAvdClientID;
3158
3159 case FreeRDP_GatewayAvdDiagnosticserviceurl:
3160 return settings->GatewayAvdDiagnosticserviceurl;
3161
3162 case FreeRDP_GatewayAvdGeo:
3163 return settings->GatewayAvdGeo;
3164
3165 case FreeRDP_GatewayAvdHubdiscoverygeourl:
3166 return settings->GatewayAvdHubdiscoverygeourl;
3167
3168 case FreeRDP_GatewayAvdScope:
3169 return settings->GatewayAvdScope;
3170
3171 case FreeRDP_GatewayAvdWvdEndpointPool:
3172 return settings->GatewayAvdWvdEndpointPool;
3173
3174 case FreeRDP_GatewayAzureActiveDirectory:
3175 return settings->GatewayAzureActiveDirectory;
3176
3177 case FreeRDP_GatewayDomain:
3178 return settings->GatewayDomain;
3179
3180 case FreeRDP_GatewayHostname:
3181 return settings->GatewayHostname;
3182
3183 case FreeRDP_GatewayHttpExtAuthBearer:
3184 return settings->GatewayHttpExtAuthBearer;
3185
3186 case FreeRDP_GatewayHttpMsUserAgent:
3187 return settings->GatewayHttpMsUserAgent;
3188
3189 case FreeRDP_GatewayHttpReferer:
3190 return settings->GatewayHttpReferer;
3191
3192 case FreeRDP_GatewayHttpUserAgent:
3193 return settings->GatewayHttpUserAgent;
3194
3195 case FreeRDP_GatewayPassword:
3196 return settings->GatewayPassword;
3197
3198 case FreeRDP_GatewayUrl:
3199 return settings->GatewayUrl;
3200
3201 case FreeRDP_GatewayUsername:
3202 return settings->GatewayUsername;
3203
3204 case FreeRDP_HomePath:
3205 return settings->HomePath;
3206
3207 case FreeRDP_ImeFileName:
3208 return settings->ImeFileName;
3209
3210 case FreeRDP_KerberosArmor:
3211 return settings->KerberosArmor;
3212
3213 case FreeRDP_KerberosCache:
3214 return settings->KerberosCache;
3215
3216 case FreeRDP_KerberosKdcUrl:
3217 return settings->KerberosKdcUrl;
3218
3219 case FreeRDP_KerberosKeytab:
3220 return settings->KerberosKeytab;
3221
3222 case FreeRDP_KerberosLifeTime:
3223 return settings->KerberosLifeTime;
3224
3225 case FreeRDP_KerberosRealm:
3226 return settings->KerberosRealm;
3227
3228 case FreeRDP_KerberosRenewableLifeTime:
3229 return settings->KerberosRenewableLifeTime;
3230
3231 case FreeRDP_KerberosStartTime:
3232 return settings->KerberosStartTime;
3233
3234 case FreeRDP_KeyboardPipeName:
3235 return settings->KeyboardPipeName;
3236
3237 case FreeRDP_KeyboardRemappingList:
3238 return settings->KeyboardRemappingList;
3239
3240 case FreeRDP_NtlmSamFile:
3241 return settings->NtlmSamFile;
3242
3243 case FreeRDP_Password:
3244 return settings->Password;
3245
3246 case FreeRDP_PasswordHash:
3247 return settings->PasswordHash;
3248
3249 case FreeRDP_Pkcs11Module:
3250 return settings->Pkcs11Module;
3251
3252 case FreeRDP_PkinitAnchors:
3253 return settings->PkinitAnchors;
3254
3255 case FreeRDP_PlayRemoteFxFile:
3256 return settings->PlayRemoteFxFile;
3257
3258 case FreeRDP_PreconnectionBlob:
3259 return settings->PreconnectionBlob;
3260
3261 case FreeRDP_ProxyHostname:
3262 return settings->ProxyHostname;
3263
3264 case FreeRDP_ProxyPassword:
3265 return settings->ProxyPassword;
3266
3267 case FreeRDP_ProxyUsername:
3268 return settings->ProxyUsername;
3269
3270 case FreeRDP_RDP2TCPArgs:
3271 return settings->RDP2TCPArgs;
3272
3273 case FreeRDP_ReaderName:
3274 return settings->ReaderName;
3275
3276 case FreeRDP_RedirectionAcceptedCert:
3277 return settings->RedirectionAcceptedCert;
3278
3279 case FreeRDP_RedirectionDomain:
3280 return settings->RedirectionDomain;
3281
3282 case FreeRDP_RedirectionTargetFQDN:
3283 return settings->RedirectionTargetFQDN;
3284
3285 case FreeRDP_RedirectionTargetNetBiosName:
3286 return settings->RedirectionTargetNetBiosName;
3287
3288 case FreeRDP_RedirectionUsername:
3289 return settings->RedirectionUsername;
3290
3291 case FreeRDP_RemoteApplicationCmdLine:
3292 return settings->RemoteApplicationCmdLine;
3293
3294 case FreeRDP_RemoteApplicationFile:
3295 return settings->RemoteApplicationFile;
3296
3297 case FreeRDP_RemoteApplicationGuid:
3298 return settings->RemoteApplicationGuid;
3299
3300 case FreeRDP_RemoteApplicationIcon:
3301 return settings->RemoteApplicationIcon;
3302
3303 case FreeRDP_RemoteApplicationName:
3304 return settings->RemoteApplicationName;
3305
3306 case FreeRDP_RemoteApplicationProgram:
3307 return settings->RemoteApplicationProgram;
3308
3309 case FreeRDP_RemoteApplicationWorkingDir:
3310 return settings->RemoteApplicationWorkingDir;
3311
3312 case FreeRDP_RemoteAssistancePassStub:
3313 return settings->RemoteAssistancePassStub;
3314
3315 case FreeRDP_RemoteAssistancePassword:
3316 return settings->RemoteAssistancePassword;
3317
3318 case FreeRDP_RemoteAssistanceRCTicket:
3319 return settings->RemoteAssistanceRCTicket;
3320
3321 case FreeRDP_RemoteAssistanceSessionId:
3322 return settings->RemoteAssistanceSessionId;
3323
3324 case FreeRDP_ServerHostname:
3325 return settings->ServerHostname;
3326
3327 case FreeRDP_ServerLicenseCompanyName:
3328 return settings->ServerLicenseCompanyName;
3329
3330 case FreeRDP_ServerLicenseProductName:
3331 return settings->ServerLicenseProductName;
3332
3333 case FreeRDP_ShellWorkingDirectory:
3334 return settings->ShellWorkingDirectory;
3335
3336 case FreeRDP_SmartcardCertificate:
3337 return settings->SmartcardCertificate;
3338
3339 case FreeRDP_SmartcardPrivateKey:
3340 return settings->SmartcardPrivateKey;
3341
3342 case FreeRDP_SspiModule:
3343 return settings->SspiModule;
3344
3345 case FreeRDP_TargetNetAddress:
3346 return settings->TargetNetAddress;
3347
3348 case FreeRDP_TerminalDescriptor:
3349 return settings->TerminalDescriptor;
3350
3351 case FreeRDP_TlsSecretsFile:
3352 return settings->TlsSecretsFile;
3353
3354 case FreeRDP_TransportDumpFile:
3355 return settings->TransportDumpFile;
3356
3357 case FreeRDP_UserSpecifiedServerName:
3358 return settings->UserSpecifiedServerName;
3359
3360 case FreeRDP_Username:
3361 return settings->Username;
3362
3363 case FreeRDP_WinSCardModule:
3364 return settings->WinSCardModule;
3365
3366 case FreeRDP_WindowTitle:
3367 return settings->WindowTitle;
3368
3369 case FreeRDP_WmClass:
3370 return settings->WmClass;
3371
3372 default:
3373 WLog_ERR(TAG, "Invalid key index %d [%s|%s]", id, freerdp_settings_get_name_for_key(id),
3375 WINPR_ASSERT(FALSE);
3376 return nullptr;
3377 }
3378}

References freerdp_settings_get_name_for_key(), and freerdp_settings_get_type_name_for_key().

Here is the call graph for this function:

◆ freerdp_settings_get_type_for_key()

WINPR_ATTR_NODISCARD FREERDP_API SSIZE_T freerdp_settings_get_type_for_key ( SSIZE_T  key)

Get a key type for the key index.

Parameters
keyThe key index like FreeRDP_ServerMode
Returns
The key type (e.g. FREERDP_SETTINGS_TYPE_BOOL) or -1 in case of an error (e.g. name does not exist)

Definition at line 410 of file settings_str.c.

411{
412 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
413 {
414 const struct settings_str_entry* cur = &settings_map[x];
415 if (cur->id == key)
416 return cur->type;
417 }
418 return -1;
419}

Referenced by freerdp_settings_copy_item(), freerdp_settings_deserialize(), freerdp_settings_get_type_name_for_key(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_type_for_name()

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.

Parameters
valueA key name string like FreeRDP_ServerMode
Returns
The key type (e.g. FREERDP_SETTINGS_TYPE_BOOL) or -1 in case of an error (e.g. name does not exist)

Definition at line 364 of file settings_str.c.

365{
366 WINPR_ASSERT(value);
367
368 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
369 {
370 const struct settings_str_entry* cur = &settings_map[x];
371 if (strcmp(value, cur->str) == 0)
372 return cur->type;
373 }
374 return -1;
375}

◆ freerdp_settings_get_type_name_for_key()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_type_name_for_key ( SSIZE_T  key)

Returns the type name for a key.

Parameters
keythe key number to stringify
Returns
the type name of the key or FREERDP_SETTINGS_TYPE_UNKNOWN

Definition at line 377 of file settings_str.c.

378{
379 const SSIZE_T type = freerdp_settings_get_type_for_key(key);
381}

References freerdp_settings_get_type_for_key(), and freerdp_settings_get_type_name_for_type().

Referenced by freerdp_settings_get_pointer_writable(), and freerdp_settings_get_string_writable().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ freerdp_settings_get_type_name_for_type()

WINPR_ATTR_NODISCARD FREERDP_API const char * freerdp_settings_get_type_name_for_type ( SSIZE_T  type)

Returns the type name for a type.

Parameters
typethe type to stringify
Returns
the name of the key or FREERDP_SETTINGS_TYPE_UNKNOWN

Definition at line 383 of file settings_str.c.

384{
385 switch (type)
386 {
387 case FREERDP_SETTINGS_TYPE_BOOL:
388 return "FREERDP_SETTINGS_TYPE_BOOL";
389 case FREERDP_SETTINGS_TYPE_UINT16:
390 return "FREERDP_SETTINGS_TYPE_UINT16";
391 case FREERDP_SETTINGS_TYPE_INT16:
392 return "FREERDP_SETTINGS_TYPE_INT16";
393 case FREERDP_SETTINGS_TYPE_UINT32:
394 return "FREERDP_SETTINGS_TYPE_UINT32";
395 case FREERDP_SETTINGS_TYPE_INT32:
396 return "FREERDP_SETTINGS_TYPE_INT32";
397 case FREERDP_SETTINGS_TYPE_UINT64:
398 return "FREERDP_SETTINGS_TYPE_UINT64";
399 case FREERDP_SETTINGS_TYPE_INT64:
400 return "FREERDP_SETTINGS_TYPE_INT64";
401 case FREERDP_SETTINGS_TYPE_STRING:
402 return "FREERDP_SETTINGS_TYPE_STRING";
403 case FREERDP_SETTINGS_TYPE_POINTER:
404 return "FREERDP_SETTINGS_TYPE_POINTER";
405 default:
406 return "FREERDP_SETTINGS_TYPE_UNKNOWN";
407 }
408}

Referenced by freerdp_settings_deserialize(), freerdp_settings_get_type_name_for_key(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_uint16()

WINPR_ATTR_NODISCARD FREERDP_API UINT16 freerdp_settings_get_uint16 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt16  id 
)

Returns a UINT16 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the UINT16 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_get_uint32()

WINPR_ATTR_NODISCARD FREERDP_API UINT32 freerdp_settings_get_uint32 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt32  id 
)

Returns a UINT32 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the UINT32 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), freerdp_settings_serialize(), and AppDelegate::rdpConnectError:.

Here is the caller graph for this function:

◆ freerdp_settings_get_uint64()

WINPR_ATTR_NODISCARD FREERDP_API UINT64 freerdp_settings_get_uint64 ( const rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt64  id 
)

Returns a UINT64 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
Returns
the value of the UINT64 key

Referenced by freerdp_settings_copy_item(), freerdp_settings_dump(), freerdp_settings_print_diff(), and freerdp_settings_serialize().

Here is the caller graph for this function:

◆ freerdp_settings_new()

WINPR_ATTR_NODISCARD FREERDP_API rdpSettings * freerdp_settings_new ( DWORD  flags)

creates a new setting struct

Parameters
flagsFlags for creation, use FREERDP_SETTINGS_SERVER_MODE for server settings, 0 for client.
Returns
A newly allocated settings struct or nullptr

Definition at line 813 of file core/settings.c.

814{
815 const BOOL server = ((flags & FREERDP_SETTINGS_SERVER_MODE) != 0);
816 const BOOL remote = ((flags & FREERDP_SETTINGS_REMOTE_MODE) != 0);
817 rdpSettings* settings = (rdpSettings*)calloc(1, sizeof(rdpSettings));
818
819 if (!settings)
820 return nullptr;
821
822 {
823 const char* vendor = freerdp_getApplicationDetailsVendor();
824 const char* product = freerdp_getApplicationDetailsProduct();
825 const char* details = freerdp_getApplicationDetailsString();
826 char* issuer1 = nullptr;
827 char* issuer2 = nullptr;
828 char* issuer3 = nullptr;
829 size_t len = 0;
830 (void)winpr_asprintf(&issuer1, &len, "%s-licenser", freerdp_getApplicationDetailsString());
831 (void)winpr_asprintf(&issuer2, &len, "%s-licenser", freerdp_getApplicationDetailsVendor());
832 (void)winpr_asprintf(&issuer3, &len, "%s-licenser", freerdp_getApplicationDetailsProduct());
833
834 char* issuers[] = { WINPR_CAST_CONST_PTR_AWAY(vendor, char*),
835 WINPR_CAST_CONST_PTR_AWAY(product, char*),
836 WINPR_CAST_CONST_PTR_AWAY(details, char*),
837 issuer1,
838 issuer2,
839 issuer3 };
840
841 const BOOL res = freerdp_server_license_issuers_copy(settings, issuers, ARRAYSIZE(issuers));
842 free(issuer1);
843 free(issuer2);
844 free(issuer3);
845 if (!res)
846 goto out_fail;
847 }
848 if (!server && !remote)
849 {
850 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayHttpUserAgent,
851 FREERDP_USER_AGENT))
852 goto out_fail;
853 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayHttpMsUserAgent,
854 FREERDP_USER_AGENT))
855 goto out_fail;
856
857 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayHttpReferer, ""))
858 goto out_fail;
859 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAvdAccessTokenFormat,
860 "ms-appx-web%%3a%%2f%%2fMicrosoft.AAD.BrokerPlugin%%2f%s"))
861 goto out_fail;
862 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAvdAccessAadFormat,
863 "https%%3A%%2F%%2F%s%%2F%s%%2Foauth2%%2Fnativeclient"))
864 goto out_fail;
865 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAvdScope,
866 "https%3A%2F%2Fwww.wvd.microsoft.com%2F.default%20openid%"
867 "20profile%20offline_access"))
868
869 goto out_fail;
870 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAvdClientID,
871 "a85cf173-4192-42f8-81fa-777a763e6e2c"))
872 goto out_fail;
873 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAzureActiveDirectory,
874 "login.microsoftonline.com"))
875 goto out_fail;
876 if (!freerdp_settings_set_string(settings, FreeRDP_GatewayAvdAadtenantid, "common"))
877 goto out_fail;
878 if (!freerdp_settings_set_bool(settings, FreeRDP_GatewayAvdUseTenantid, FALSE))
879 goto out_fail;
880 if (!freerdp_settings_set_uint32(settings, FreeRDP_DesktopPhysicalWidth, 1000))
881 goto out_fail;
882 if (!freerdp_settings_set_uint32(settings, FreeRDP_DesktopPhysicalHeight, 1000))
883 goto out_fail;
884 if (!freerdp_settings_set_uint16(settings, FreeRDP_DesktopOrientation,
885 ORIENTATION_LANDSCAPE))
886 goto out_fail;
887 if (!freerdp_settings_set_uint32(settings, FreeRDP_DeviceScaleFactor, 100))
888 goto out_fail;
889 if (!freerdp_settings_set_uint32(settings, FreeRDP_DesktopScaleFactor, 100))
890 goto out_fail;
891 }
892 if (!freerdp_settings_set_uint32(settings, FreeRDP_SurfaceCommandsSupported,
893 SURFCMDS_SET_SURFACE_BITS | SURFCMDS_STREAM_SURFACE_BITS |
894 SURFCMDS_FRAME_MARKER))
895 goto out_fail;
896
897 if (!freerdp_settings_set_uint32(settings, FreeRDP_RemoteFxRlgrMode, RLGR3))
898 goto out_fail;
899
900 if (!freerdp_settings_set_uint16(settings, FreeRDP_CapsProtocolVersion,
901 TS_CAPS_PROTOCOLVERSION))
902 goto out_fail;
903
904 if (!freerdp_settings_set_uint32(settings, FreeRDP_ClipboardFeatureMask,
905 CLIPRDR_FLAG_DEFAULT_MASK))
906 goto out_fail;
907 if (!freerdp_settings_set_string(settings, FreeRDP_ServerLicenseCompanyName,
908 freerdp_getApplicationDetailsVendor()))
909 goto out_fail;
910
911 {
912 size_t len = 0;
913 char* val = nullptr;
914 (void)winpr_asprintf(&val, &len, "%s-licensing-server",
915 freerdp_getApplicationDetailsProduct());
916 if (!val)
917 goto out_fail;
918
919 const BOOL rc =
920 freerdp_settings_set_string(settings, FreeRDP_ServerLicenseProductName, val);
921 free(val);
922 if (!rc)
923 goto out_fail;
924 }
925
926 if (!freerdp_settings_set_uint32(settings, FreeRDP_ServerLicenseProductVersion, 1))
927 goto out_fail;
928
929 if (!freerdp_settings_set_uint16(settings, FreeRDP_SupportedColorDepths,
930 RNS_UD_32BPP_SUPPORT | RNS_UD_24BPP_SUPPORT |
931 RNS_UD_16BPP_SUPPORT | RNS_UD_15BPP_SUPPORT))
932 goto out_fail;
933
934 if (!freerdp_settings_set_bool(settings, FreeRDP_UnicodeInput, TRUE) ||
935 !freerdp_settings_set_bool(settings, FreeRDP_HasHorizontalWheel, TRUE) ||
936 !freerdp_settings_set_bool(settings, FreeRDP_HasExtendedMouseEvent, TRUE) ||
937 !freerdp_settings_set_bool(settings, FreeRDP_HasQoeEvent, TRUE) ||
938 !freerdp_settings_set_bool(settings, FreeRDP_HasRelativeMouseEvent, TRUE) ||
939 !freerdp_settings_set_bool(settings, FreeRDP_HiDefRemoteApp, TRUE) ||
941 settings, FreeRDP_RemoteApplicationSupportMask,
942 RAIL_LEVEL_SUPPORTED | RAIL_LEVEL_DOCKED_LANGBAR_SUPPORTED |
943 RAIL_LEVEL_SHELL_INTEGRATION_SUPPORTED | RAIL_LEVEL_LANGUAGE_IME_SYNC_SUPPORTED |
944 RAIL_LEVEL_SERVER_TO_CLIENT_IME_SYNC_SUPPORTED |
945 RAIL_LEVEL_HIDE_MINIMIZED_APPS_SUPPORTED | RAIL_LEVEL_WINDOW_CLOAKING_SUPPORTED |
946 RAIL_LEVEL_HANDSHAKE_EX_SUPPORTED) ||
947 !freerdp_settings_set_uint16(settings, FreeRDP_TextANSICodePage, CP_UTF8) ||
948 !freerdp_settings_set_uint16(settings, FreeRDP_OrderSupportFlags,
949 NEGOTIATE_ORDER_SUPPORT | ZERO_BOUNDS_DELTA_SUPPORT |
950 COLOR_INDEX_SUPPORT) ||
951 !freerdp_settings_set_bool(settings, FreeRDP_SupportHeartbeatPdu, TRUE) ||
952 !freerdp_settings_set_bool(settings, FreeRDP_ServerMode, server) ||
953 !freerdp_settings_set_bool(settings, FreeRDP_WaitForOutputBufferFlush, TRUE) ||
954 !freerdp_settings_set_uint32(settings, FreeRDP_ClusterInfoFlags, REDIRECTION_SUPPORTED) ||
955 !freerdp_settings_set_uint32(settings, FreeRDP_DesktopWidth, 1024) ||
956 !freerdp_settings_set_uint32(settings, FreeRDP_DesktopHeight, 768) ||
957 !freerdp_settings_set_bool(settings, FreeRDP_Workarea, FALSE) ||
958 !freerdp_settings_set_bool(settings, FreeRDP_Fullscreen, FALSE) ||
959 !freerdp_settings_set_bool(settings, FreeRDP_GrabKeyboard, TRUE) ||
960 !freerdp_settings_set_bool(settings, FreeRDP_Decorations, TRUE) ||
961 !freerdp_settings_set_uint32(settings, FreeRDP_RdpVersion, RDP_VERSION_10_12) ||
962 !freerdp_settings_set_uint32(settings, FreeRDP_ColorDepth, 32) ||
963 !freerdp_settings_set_bool(settings, FreeRDP_AadSecurity, FALSE) ||
964 !freerdp_settings_set_bool(settings, FreeRDP_ExtSecurity, FALSE) ||
965 !freerdp_settings_set_bool(settings, FreeRDP_NlaSecurity, TRUE) ||
966 !freerdp_settings_set_bool(settings, FreeRDP_TlsSecurity, TRUE) ||
967 !freerdp_settings_set_bool(settings, FreeRDP_RdpSecurity, TRUE) ||
968 !freerdp_settings_set_bool(settings, FreeRDP_RdstlsSecurity, FALSE) ||
969 !freerdp_settings_set_bool(settings, FreeRDP_NegotiateSecurityLayer, TRUE) ||
970 !freerdp_settings_set_bool(settings, FreeRDP_RestrictedAdminModeRequired, FALSE) ||
971 !freerdp_settings_set_bool(settings, FreeRDP_RestrictedAdminModeSupported, TRUE) ||
972 !freerdp_settings_set_bool(settings, FreeRDP_MstscCookieMode, FALSE) ||
973 !freerdp_settings_set_uint32(settings, FreeRDP_CookieMaxLength,
974 DEFAULT_COOKIE_MAX_LENGTH) ||
975 !freerdp_settings_set_uint32(settings, FreeRDP_ClientBuild,
976 18363) || /* Windows 10, Version 1909 */
977 !freerdp_settings_set_uint32(settings, FreeRDP_KeyboardType, WINPR_KBD_TYPE_IBM_ENHANCED) ||
978 !freerdp_settings_set_uint32(settings, FreeRDP_KeyboardSubType, 0) ||
979 !freerdp_settings_set_uint32(settings, FreeRDP_KeyboardFunctionKey, 12) ||
980 !freerdp_settings_set_uint32(settings, FreeRDP_KeyboardLayout, 0) ||
981 !freerdp_settings_set_uint32(settings, FreeRDP_KeyboardHook,
982 KEYBOARD_HOOK_FULLSCREEN_ONLY) ||
983 !freerdp_settings_set_bool(settings, FreeRDP_UseRdpSecurityLayer, FALSE) ||
984 !freerdp_settings_set_bool(settings, FreeRDP_SaltedChecksum, TRUE) ||
985 !freerdp_settings_set_uint32(settings, FreeRDP_ServerPort, 3389) ||
986 !freerdp_settings_set_uint32(settings, FreeRDP_GatewayPort, 443) ||
987 !freerdp_settings_set_bool(settings, FreeRDP_DesktopResize, TRUE) ||
988 !freerdp_settings_set_bool(settings, FreeRDP_ToggleFullscreen, TRUE) ||
989 !freerdp_settings_set_uint32(settings, FreeRDP_DesktopPosX, UINT32_MAX) ||
990 !freerdp_settings_set_uint32(settings, FreeRDP_DesktopPosY, UINT32_MAX) ||
991 !freerdp_settings_set_bool(settings, FreeRDP_SoftwareGdi, TRUE) ||
992 !freerdp_settings_set_bool(settings, FreeRDP_UnmapButtons, FALSE) ||
993 !freerdp_settings_set_uint32(settings, FreeRDP_PerformanceFlags, PERF_FLAG_NONE) ||
994 !freerdp_settings_set_bool(settings, FreeRDP_AllowFontSmoothing, TRUE) ||
995 !freerdp_settings_set_bool(settings, FreeRDP_AllowDesktopComposition, FALSE) ||
996 !freerdp_settings_set_bool(settings, FreeRDP_DisableWallpaper, FALSE) ||
997 !freerdp_settings_set_bool(settings, FreeRDP_DisableFullWindowDrag, TRUE) ||
998 !freerdp_settings_set_bool(settings, FreeRDP_DisableMenuAnims, TRUE) ||
999 !freerdp_settings_set_bool(settings, FreeRDP_DisableThemes, FALSE) ||
1000 !freerdp_settings_set_uint32(settings, FreeRDP_ConnectionType,
1001 CONNECTION_TYPE_AUTODETECT) ||
1002 !freerdp_settings_set_bool(settings, FreeRDP_NetworkAutoDetect, TRUE) ||
1003 !freerdp_settings_set_uint32(settings, FreeRDP_EncryptionMethods, ENCRYPTION_METHOD_NONE) ||
1004 !freerdp_settings_set_uint32(settings, FreeRDP_EncryptionLevel, ENCRYPTION_LEVEL_NONE) ||
1005 !freerdp_settings_set_bool(settings, FreeRDP_FIPSMode, FALSE) ||
1006 !freerdp_settings_set_bool(settings, FreeRDP_CompressionEnabled, TRUE) ||
1007 !freerdp_settings_set_bool(settings, FreeRDP_LogonNotify, TRUE) ||
1008 !freerdp_settings_set_uint32(settings, FreeRDP_BrushSupportLevel, BRUSH_COLOR_FULL) ||
1009 !freerdp_settings_set_uint32(settings, FreeRDP_CompressionLevel, PACKET_COMPR_TYPE_RDP61) ||
1010 !freerdp_settings_set_bool(settings, FreeRDP_Authentication, TRUE) ||
1011 !freerdp_settings_set_bool(settings, FreeRDP_AuthenticationOnly, FALSE) ||
1012 !freerdp_settings_set_bool(settings, FreeRDP_CredentialsFromStdin, FALSE) ||
1013 !freerdp_settings_set_bool(settings, FreeRDP_DisableCredentialsDelegation, FALSE) ||
1014 !freerdp_settings_set_uint32(settings, FreeRDP_AuthenticationLevel, 2) ||
1015 !freerdp_settings_set_uint32(settings, FreeRDP_ChannelCount, 0) ||
1016 !freerdp_settings_set_bool(settings, FreeRDP_CertificateCallbackPreferPEM, FALSE) ||
1017 !freerdp_settings_set_uint32(settings, FreeRDP_KeySpec, AT_KEYEXCHANGE))
1018 goto out_fail;
1019
1020 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_ChannelDefArray, nullptr,
1021 CHANNEL_MAX_COUNT))
1022 goto out_fail;
1023
1024 if (!freerdp_settings_set_bool(settings, FreeRDP_SupportMonitorLayoutPdu, FALSE))
1025 goto out_fail;
1026
1027 if (!freerdp_settings_set_uint32(settings, FreeRDP_MonitorCount, 0))
1028 goto out_fail;
1029
1030 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_MonitorDefArray, nullptr, 32))
1031 goto out_fail;
1032
1033 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftX, 0))
1034 goto out_fail;
1035
1036 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftY, 0))
1037 goto out_fail;
1038
1039 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_MonitorIds, nullptr, 0))
1040 goto out_fail;
1041
1042 if (!freerdp_settings_set_uint32(settings, FreeRDP_MultitransportFlags,
1043 TRANSPORT_TYPE_UDP_FECR))
1044 goto out_fail;
1045 if (!freerdp_settings_set_bool(settings, FreeRDP_SupportMultitransport, TRUE))
1046 goto out_fail;
1047
1048 if (!settings_init_computer_name(settings))
1049 goto out_fail;
1050
1051 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_RdpServerCertificate, nullptr, 1))
1052 goto out_fail;
1053
1054 if (!freerdp_capability_buffer_resize(settings, 32, FALSE))
1055 goto out_fail;
1056
1057 {
1058 char tmp[32] = WINPR_C_ARRAY_INIT;
1059 if (!freerdp_settings_set_string_len(settings, FreeRDP_ClientProductId, tmp, sizeof(tmp)))
1060 goto out_fail;
1061 }
1062
1063 /* [MS-RDPBCGR] 2.2.7.1.5 Pointer Capability Set (TS_POINTER_CAPABILITYSET)
1064 *
1065 * if we are in server mode send a reasonable large cache size,
1066 * if we are in client mode just set the value to the maximum we want to
1067 * support and during capability exchange that size will be limited to the
1068 * sizes the server supports
1069 *
1070 * We have chosen 128 cursors in cache which is at worst 128 * 576kB (384x384 pixel cursor with
1071 * 32bit color depth)
1072 * */
1073 if (freerdp_settings_get_bool(settings, FreeRDP_ServerMode))
1074 {
1075 if (!freerdp_settings_set_uint32(settings, FreeRDP_PointerCacheSize, 25) ||
1076 !freerdp_settings_set_uint32(settings, FreeRDP_ColorPointerCacheSize, 25))
1077 goto out_fail;
1078 }
1079 else
1080 {
1081 if (!freerdp_settings_set_uint32(settings, FreeRDP_PointerCacheSize, 128) ||
1082 !freerdp_settings_set_uint32(settings, FreeRDP_ColorPointerCacheSize, 128))
1083 goto out_fail;
1084 }
1085
1086 if (!freerdp_settings_set_uint32(settings, FreeRDP_LargePointerFlag,
1087 (LARGE_POINTER_FLAG_96x96 | LARGE_POINTER_FLAG_384x384)) ||
1088 !freerdp_settings_set_bool(settings, FreeRDP_SoundBeepsEnabled, TRUE) ||
1089 !freerdp_settings_set_bool(settings, FreeRDP_DrawGdiPlusEnabled, FALSE) ||
1090 !freerdp_settings_set_bool(settings, FreeRDP_DrawAllowSkipAlpha, TRUE) ||
1091 !freerdp_settings_set_bool(settings, FreeRDP_DrawAllowColorSubsampling, FALSE) ||
1092 !freerdp_settings_set_bool(settings, FreeRDP_DrawAllowDynamicColorFidelity, TRUE) ||
1093 !freerdp_settings_set_bool(settings, FreeRDP_FrameMarkerCommandEnabled, TRUE) ||
1094 !freerdp_settings_set_bool(settings, FreeRDP_SurfaceFrameMarkerEnabled, TRUE) ||
1095 !freerdp_settings_set_bool(settings, FreeRDP_AllowCacheWaitingList, TRUE) ||
1096 !freerdp_settings_set_uint32(settings, FreeRDP_BitmapCacheV2NumCells, 5))
1097 goto out_fail;
1098 settings->BitmapCacheV2CellInfo =
1100
1101 if (!settings->BitmapCacheV2CellInfo)
1102 goto out_fail;
1103
1104 {
1105 BITMAP_CACHE_V2_CELL_INFO cache = WINPR_C_ARRAY_INIT;
1106 cache.numEntries = 600;
1107 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_BitmapCacheV2CellInfo, 0,
1108 &cache) ||
1109 !freerdp_settings_set_pointer_array(settings, FreeRDP_BitmapCacheV2CellInfo, 1, &cache))
1110 goto out_fail;
1111 cache.numEntries = 2048;
1112 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_BitmapCacheV2CellInfo, 2,
1113 &cache) ||
1114 !freerdp_settings_set_pointer_array(settings, FreeRDP_BitmapCacheV2CellInfo, 4, &cache))
1115 goto out_fail;
1116 cache.numEntries = 4096;
1117 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_BitmapCacheV2CellInfo, 3, &cache))
1118 goto out_fail;
1119 }
1120 if (!freerdp_settings_set_bool(settings, FreeRDP_NoBitmapCompressionHeader, TRUE) ||
1121 !freerdp_settings_set_bool(settings, FreeRDP_RefreshRect, TRUE) ||
1122 !freerdp_settings_set_bool(settings, FreeRDP_SuppressOutput, TRUE) ||
1123 !freerdp_settings_set_uint32(settings, FreeRDP_GlyphSupportLevel, GLYPH_SUPPORT_NONE))
1124 goto out_fail;
1125 settings->GlyphCache = calloc(10, sizeof(GLYPH_CACHE_DEFINITION));
1126
1127 if (!settings->GlyphCache)
1128 goto out_fail;
1129
1130 settings->FragCache = calloc(1, sizeof(GLYPH_CACHE_DEFINITION));
1131
1132 if (!settings->FragCache)
1133 goto out_fail;
1134
1135 for (size_t x = 0; x < 10; x++)
1136 {
1137 GLYPH_CACHE_DEFINITION cache = WINPR_C_ARRAY_INIT;
1138 cache.cacheEntries = 254;
1139 switch (x)
1140 {
1141 case 0:
1142 case 1:
1143 cache.cacheMaximumCellSize = 4;
1144 break;
1145 case 2:
1146 case 3:
1147 cache.cacheMaximumCellSize = 8;
1148 break;
1149 case 4:
1150 cache.cacheMaximumCellSize = 16;
1151 break;
1152 case 5:
1153 cache.cacheMaximumCellSize = 32;
1154 break;
1155 case 6:
1156 cache.cacheMaximumCellSize = 64;
1157 break;
1158 case 7:
1159 cache.cacheMaximumCellSize = 128;
1160 break;
1161 case 8:
1162 cache.cacheMaximumCellSize = 256;
1163 break;
1164 case 9:
1165 cache.cacheMaximumCellSize = 256;
1166 break;
1167 default:
1168 goto out_fail;
1169 }
1170
1171 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_GlyphCache, x, &cache))
1172 goto out_fail;
1173 }
1174 {
1175 GLYPH_CACHE_DEFINITION cache = WINPR_C_ARRAY_INIT;
1176 cache.cacheEntries = 256;
1177 cache.cacheMaximumCellSize = 256;
1178 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_FragCache, 0, &cache))
1179 goto out_fail;
1180 }
1181 if (!freerdp_settings_set_uint32(settings, FreeRDP_OffscreenSupportLevel, 0) ||
1182 !freerdp_settings_set_uint32(settings, FreeRDP_OffscreenCacheSize, 7680) ||
1183 !freerdp_settings_set_uint32(settings, FreeRDP_OffscreenCacheEntries, 2000) ||
1184 !freerdp_settings_set_uint32(settings, FreeRDP_DrawNineGridCacheSize, 2560) ||
1185 !freerdp_settings_set_uint32(settings, FreeRDP_DrawNineGridCacheEntries, 256) ||
1186 !freerdp_settings_set_string(settings, FreeRDP_ClientDir, client_dll) ||
1187 !freerdp_settings_get_string(settings, FreeRDP_ClientDir) ||
1188 !freerdp_settings_set_uint32(settings, FreeRDP_RemoteWndSupportLevel,
1189 WINDOW_LEVEL_SUPPORTED | WINDOW_LEVEL_SUPPORTED_EX) ||
1190 !freerdp_settings_set_uint32(settings, FreeRDP_RemoteAppNumIconCaches, 3) ||
1191 !freerdp_settings_set_uint32(settings, FreeRDP_RemoteAppNumIconCacheEntries, 12) ||
1192 !freerdp_settings_set_uint32(settings, FreeRDP_VCChunkSize,
1193 (server && !remote) ? CHANNEL_CHUNK_MAX_LENGTH
1194 : CHANNEL_CHUNK_LENGTH) ||
1195 /* [MS-RDPBCGR] 2.2.7.2.7 Large Pointer Capability Set (TS_LARGE_POINTER_CAPABILITYSET)
1196 requires at least this size */
1197 !freerdp_settings_set_uint32(settings, FreeRDP_MultifragMaxRequestSize,
1198 server ? 0 : 608299) ||
1199 !freerdp_settings_set_bool(settings, FreeRDP_GatewayUseSameCredentials, FALSE) ||
1200 !freerdp_settings_set_bool(settings, FreeRDP_GatewayBypassLocal, FALSE) ||
1201 !freerdp_settings_set_bool(settings, FreeRDP_GatewayRpcTransport, TRUE) ||
1202 !freerdp_settings_set_bool(settings, FreeRDP_GatewayHttpTransport, TRUE) ||
1203 !freerdp_settings_set_bool(settings, FreeRDP_GatewayUdpTransport, TRUE) ||
1204 !freerdp_settings_set_bool(settings, FreeRDP_GatewayHttpUseWebsockets, TRUE) ||
1205 !freerdp_settings_set_bool(settings, FreeRDP_GatewayHttpExtAuthSspiNtlm, FALSE) ||
1206 !freerdp_settings_set_bool(settings, FreeRDP_GatewayArmTransport, FALSE) ||
1207 !freerdp_settings_set_bool(settings, FreeRDP_FastPathInput, TRUE) ||
1208 !freerdp_settings_set_bool(settings, FreeRDP_FastPathOutput, TRUE) ||
1209 !freerdp_settings_set_bool(settings, FreeRDP_LongCredentialsSupported, TRUE) ||
1210 !freerdp_settings_set_uint32(settings, FreeRDP_FrameAcknowledge, 2) ||
1211 !freerdp_settings_set_bool(settings, FreeRDP_MouseMotion, TRUE) ||
1212 !freerdp_settings_set_uint32(settings, FreeRDP_NSCodecColorLossLevel, 3) ||
1213 !freerdp_settings_set_bool(settings, FreeRDP_NSCodecAllowSubsampling, TRUE) ||
1214 !freerdp_settings_set_bool(settings, FreeRDP_NSCodecAllowDynamicColorFidelity, TRUE) ||
1215 !freerdp_settings_set_bool(settings, FreeRDP_AutoReconnectionEnabled, FALSE) ||
1216 !freerdp_settings_set_uint32(settings, FreeRDP_AutoReconnectMaxRetries, 20) ||
1217 !freerdp_settings_set_bool(settings, FreeRDP_GfxThinClient, FALSE) ||
1218 !freerdp_settings_set_bool(settings, FreeRDP_GfxSmallCache, TRUE) ||
1219 !freerdp_settings_set_bool(settings, FreeRDP_GfxProgressive, FALSE) ||
1220 !freerdp_settings_set_bool(settings, FreeRDP_GfxProgressiveV2, FALSE) ||
1221 !freerdp_settings_set_bool(settings, FreeRDP_GfxPlanar, TRUE) ||
1222 !freerdp_settings_set_bool(settings, FreeRDP_GfxH264, FALSE) ||
1223 !freerdp_settings_set_bool(settings, FreeRDP_GfxAVC444, FALSE) ||
1224 !freerdp_settings_set_bool(settings, FreeRDP_GfxSendQoeAck, FALSE) ||
1225 !freerdp_settings_set_bool(settings, FreeRDP_SupportDisplayControl, TRUE))
1226 goto out_fail;
1227 {
1228 ARC_CS_PRIVATE_PACKET cookie = WINPR_C_ARRAY_INIT;
1229 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_ClientAutoReconnectCookie, &cookie,
1230 1))
1231 goto out_fail;
1232 }
1233 {
1234 ARC_SC_PRIVATE_PACKET cookie = WINPR_C_ARRAY_INIT;
1235 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_ServerAutoReconnectCookie, &cookie,
1236 1))
1237 goto out_fail;
1238 }
1239
1240 settings->ClientTimeZone = (LPTIME_ZONE_INFORMATION)calloc(1, sizeof(TIME_ZONE_INFORMATION));
1241
1242 if (!settings->ClientTimeZone)
1243 goto out_fail;
1244
1245 if (!settings->ServerMode)
1246 {
1247 DYNAMIC_TIME_ZONE_INFORMATION dynamic = WINPR_C_ARRAY_INIT;
1249 freerdp_settings_get_pointer_writable(settings, FreeRDP_ClientTimeZone);
1250 WINPR_ASSERT(tz);
1251
1252 GetTimeZoneInformation(tz);
1253 GetDynamicTimeZoneInformation(&dynamic);
1254
1255 if (!freerdp_settings_set_string_from_utf16N(settings, FreeRDP_DynamicDSTTimeZoneKeyName,
1256 dynamic.TimeZoneKeyName,
1257 ARRAYSIZE(dynamic.TimeZoneKeyName)))
1258 goto out_fail;
1259
1260 if (!freerdp_settings_set_bool(settings, FreeRDP_DynamicDaylightTimeDisabled,
1261 dynamic.DynamicDaylightTimeDisabled))
1262 goto out_fail;
1263 }
1264
1265 if (!freerdp_settings_set_bool(settings, FreeRDP_TcpKeepAlive, TRUE) ||
1266 !freerdp_settings_set_uint32(settings, FreeRDP_TcpKeepAliveRetries, 3) ||
1267 !freerdp_settings_set_uint32(settings, FreeRDP_TcpKeepAliveDelay, 5) ||
1268 !freerdp_settings_set_uint32(settings, FreeRDP_TcpKeepAliveInterval, 2) ||
1269 !freerdp_settings_set_uint32(settings, FreeRDP_TcpAckTimeout, 9000) ||
1270 !freerdp_settings_set_uint32(settings, FreeRDP_TcpConnectTimeout, 15000))
1271 goto out_fail;
1272
1273 if (!freerdp_settings_get_bool(settings, FreeRDP_ServerMode))
1274 {
1275 BOOL rc = FALSE;
1276 char* path = nullptr;
1277 if (!freerdp_settings_set_bool(settings, FreeRDP_RedirectClipboard, TRUE))
1278 goto out_fail;
1279 /* these values are used only by the client part */
1280 path = GetKnownPath(KNOWN_PATH_HOME);
1281 rc = freerdp_settings_set_string(settings, FreeRDP_HomePath, path);
1282 free(path);
1283
1284 if (!rc || !freerdp_settings_get_string(settings, FreeRDP_HomePath))
1285 goto out_fail;
1286
1287 char* config = freerdp_settings_get_config_path();
1288 rc = freerdp_settings_set_string(settings, FreeRDP_ConfigPath, config);
1289 if (rc)
1290 {
1291 char* action = GetCombinedPath(config, "action.sh");
1292 rc = freerdp_settings_set_string(settings, FreeRDP_ActionScript, action);
1293 free(action);
1294 }
1295
1296 free(config);
1297 if (!rc)
1298 goto out_fail;
1299 }
1300
1301 settings_load_hkey_local_machine(settings);
1302
1303 if (!freerdp_settings_set_bool(settings, FreeRDP_SmartcardLogon, FALSE))
1304 goto out_fail;
1305 if (!freerdp_settings_set_uint32(settings, FreeRDP_TlsSecLevel, 1))
1306 goto out_fail;
1307 settings->OrderSupport = calloc(1, 32);
1308
1309 if (!freerdp_settings_set_uint16(settings, FreeRDP_TLSMinVersion, TLS1_VERSION))
1310 goto out_fail;
1311 if (!freerdp_settings_set_uint16(settings, FreeRDP_TLSMaxVersion, 0))
1312 goto out_fail;
1313
1314 if (!settings->OrderSupport)
1315 goto out_fail;
1316
1317 if (!freerdp_settings_set_default_order_support(settings))
1318 goto out_fail;
1319
1320 {
1321 const BOOL enable = freerdp_settings_get_bool(settings, FreeRDP_ServerMode);
1322 {
1323 const FreeRDP_Settings_Keys_Bool keys[] = { FreeRDP_SupportGraphicsPipeline,
1324 FreeRDP_SupportStatusInfoPdu,
1325 FreeRDP_SupportErrorInfoPdu,
1326 FreeRDP_SupportAsymetricKeys };
1327
1328 for (size_t x = 0; x < ARRAYSIZE(keys); x++)
1329 {
1330 if (!freerdp_settings_set_bool(settings, keys[x], enable))
1331 goto out_fail;
1332 }
1333 }
1334 }
1335
1336 if (!freerdp_settings_set_bool(settings, FreeRDP_SupportDynamicTimeZone, TRUE))
1337 goto out_fail;
1338 if (!freerdp_settings_set_bool(settings, FreeRDP_SupportSkipChannelJoin, TRUE))
1339 goto out_fail;
1340
1341 return settings;
1342out_fail:
1343 WINPR_PRAGMA_DIAG_PUSH
1344 WINPR_PRAGMA_DIAG_IGNORED_MISMATCHED_DEALLOC
1345 freerdp_settings_free(settings);
1346 WINPR_PRAGMA_DIAG_POP
1347 return nullptr;
1348}
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.
char * freerdp_settings_get_config_path(void)
return the configuration directory for the library
#define FREERDP_SETTINGS_SERVER_MODE

References freerdp_settings_free(), freerdp_settings_get_bool(), freerdp_settings_get_config_path(), freerdp_settings_get_pointer_writable(), freerdp_settings_get_string(), FREERDP_SETTINGS_SERVER_MODE, freerdp_settings_set_bool(), freerdp_settings_set_int32(), freerdp_settings_set_pointer_len(), freerdp_settings_set_string(), freerdp_settings_set_string_from_utf16N(), freerdp_settings_set_string_len(), freerdp_settings_set_uint16(), and freerdp_settings_set_uint32().

Referenced by freerdp_settings_deserialize().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ freerdp_settings_print_diff()

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.

Parameters
logThe logger to write to, must not be nullptr.
levelThe WLog level to use for the log entries.
settingsA pointer to the settings to dump. May be nullptr.
otherA pointer to the settings to dump. May be nullptr.
Returns
TRUE if not equal, FALSE otherwise

Definition at line 99 of file settings_str.c.

101{
102 BOOL rc = FALSE;
103
104 WINPR_ASSERT(log);
105 WINPR_ASSERT(settings);
106 WINPR_ASSERT(other);
107
108 for (size_t x = 0; x < ARRAYSIZE(settings_map); x++)
109 {
110 const struct settings_str_entry* cur = &settings_map[x];
111 switch (cur->type)
112 {
113 case FREERDP_SETTINGS_TYPE_BOOL: /* bool */
114 {
115 BOOL sval =
116 freerdp_settings_get_bool(settings, (FreeRDP_Settings_Keys_Bool)cur->id);
117 BOOL cval = freerdp_settings_get_bool(other, (FreeRDP_Settings_Keys_Bool)cur->id);
118 if (sval != cval)
119 {
120 rc = TRUE;
121 WLog_Print(log, level, "%s [BOOL]: %s -> %s", cur->str, sval ? "TRUE" : "FALSE",
122 cval ? "TRUE" : "FALSE");
123 }
124 }
125 break;
126 case FREERDP_SETTINGS_TYPE_UINT16: /* UINT16 */
127 {
128 UINT16 sval =
129 freerdp_settings_get_uint16(settings, (FreeRDP_Settings_Keys_UInt16)cur->id);
130 UINT16 cval =
131 freerdp_settings_get_uint16(other, (FreeRDP_Settings_Keys_UInt16)cur->id);
132 if (sval != cval)
133 {
134 rc = TRUE;
135 WLog_Print(log, level, "%s [UINT16]: %" PRIu16 " -> %" PRIu16, cur->str, sval,
136 cval);
137 }
138 }
139 break;
140 case FREERDP_SETTINGS_TYPE_INT16: /* INT16 */
141 {
142 INT16 sval =
143 freerdp_settings_get_int16(settings, (FreeRDP_Settings_Keys_Int16)cur->id);
144 INT16 cval =
145 freerdp_settings_get_int16(other, (FreeRDP_Settings_Keys_Int16)cur->id);
146 if (sval != cval)
147 {
148 rc = TRUE;
149 WLog_Print(log, level, "%s [INT16]: %" PRId16 " -> %" PRId16, cur->str, sval,
150 cval);
151 }
152 }
153 break;
154 case FREERDP_SETTINGS_TYPE_UINT32: /* UINT32 */
155 {
156 UINT32 sval =
157 freerdp_settings_get_uint32(settings, (FreeRDP_Settings_Keys_UInt32)cur->id);
158 UINT32 cval =
159 freerdp_settings_get_uint32(other, (FreeRDP_Settings_Keys_UInt32)cur->id);
160 if (sval != cval)
161 {
162 rc = TRUE;
163 WLog_Print(log, level, "%s [UINT32]: %" PRIu32 " -> %" PRIu32, cur->str, sval,
164 cval);
165 }
166 }
167 break;
168 case FREERDP_SETTINGS_TYPE_INT32: /* INT32 */
169 {
170 INT32 sval =
171 freerdp_settings_get_int32(settings, (FreeRDP_Settings_Keys_Int32)cur->id);
172 INT32 cval =
173 freerdp_settings_get_int32(other, (FreeRDP_Settings_Keys_Int32)cur->id);
174 if (sval != cval)
175 {
176 rc = TRUE;
177 WLog_Print(log, level, "%s [INT32]: %" PRId32 " -> %" PRId32, cur->str, sval,
178 cval);
179 }
180 }
181 break;
182 case FREERDP_SETTINGS_TYPE_UINT64: /* UINT64 */
183 {
184 UINT64 sval =
185 freerdp_settings_get_uint64(settings, (FreeRDP_Settings_Keys_UInt64)cur->id);
186 UINT64 cval =
187 freerdp_settings_get_uint64(other, (FreeRDP_Settings_Keys_UInt64)cur->id);
188 if (sval != cval)
189 {
190 rc = TRUE;
191 WLog_Print(log, level, "%s [UINT64]: %" PRIu64 " -> %" PRIu64, cur->str, sval,
192 cval);
193 }
194 }
195 break;
196 case FREERDP_SETTINGS_TYPE_INT64: /* INT64 */
197 {
198 INT64 sval =
199 freerdp_settings_get_int64(settings, (FreeRDP_Settings_Keys_Int64)cur->id);
200 INT64 cval =
201 freerdp_settings_get_int64(other, (FreeRDP_Settings_Keys_Int64)cur->id);
202 if (sval != cval)
203 {
204 rc = TRUE;
205 WLog_Print(log, level, "%s [INT64]: %" PRId64 " -> %" PRId64, cur->str, sval,
206 cval);
207 }
208 }
209 break;
210 case FREERDP_SETTINGS_TYPE_STRING: /* strings */
211 {
212 const char* sval =
213 freerdp_settings_get_string(settings, (FreeRDP_Settings_Keys_String)cur->id);
214 const char* cval =
215 freerdp_settings_get_string(other, (FreeRDP_Settings_Keys_String)cur->id);
216 if (sval != cval)
217 {
218 if (!sval || !cval || (strcmp(sval, cval) != 0))
219 {
220 rc = TRUE;
221 WLog_Print(log, level, "%s [STRING]: '%s' -> '%s'", cur->str, sval, cval);
222 }
223 }
224 }
225 break;
226 case FREERDP_SETTINGS_TYPE_POINTER: /* pointer */
227 {
228 const void* sval =
229 freerdp_settings_get_pointer(settings, (FreeRDP_Settings_Keys_Pointer)cur->id);
230 const void* cval =
231 freerdp_settings_get_pointer(other, (FreeRDP_Settings_Keys_Pointer)cur->id);
232 if (sval != cval)
233 {
234 if ((sval && !cval) || (!sval && cval))
235 {
236 rc = TRUE;
237 WLog_Print(log, level, "%s [POINTER]: '%p' -> '%p'", cur->str, sval, cval);
238 }
239 }
240 }
241 break;
242 default:
243 break;
244 }
245 }
246 return rc;
247}

References freerdp_settings_get_bool(), freerdp_settings_get_int16(), freerdp_settings_get_int32(), freerdp_settings_get_int64(), freerdp_settings_get_pointer(), freerdp_settings_get_string(), freerdp_settings_get_uint16(), freerdp_settings_get_uint32(), and freerdp_settings_get_uint64().

Here is the call graph for this function:

◆ freerdp_settings_serialize()

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.

Parameters
settingsThe settings instance to serialize
prettyFormat the resulting JSON human readable
plengthAn optional pointer that receives the length (strlen) of the returned string.
Returns
A JSON string representing the serialized form of the rdpSettings or nullptr in case of an error.
Since
version 3.16.0

Definition at line 3684 of file common/settings.c.

3685{
3686 char* str = nullptr;
3687
3688 if (plength)
3689 *plength = 0;
3690
3691 if (!settings)
3692 return nullptr;
3693
3694 WINPR_JSON* json = WINPR_JSON_CreateObject();
3695 if (!json)
3696 return nullptr;
3697
3698 WINPR_JSON* jbool = WINPR_JSON_AddObjectToObject(
3699 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_BOOL));
3700 WINPR_JSON* juint16 = WINPR_JSON_AddObjectToObject(
3701 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT16));
3702 WINPR_JSON* jint16 = WINPR_JSON_AddObjectToObject(
3703 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT16));
3704 WINPR_JSON* juint32 = WINPR_JSON_AddObjectToObject(
3705 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT32));
3706 WINPR_JSON* jint32 = WINPR_JSON_AddObjectToObject(
3707 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT32));
3708 WINPR_JSON* juint64 = WINPR_JSON_AddObjectToObject(
3709 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_UINT64));
3710 WINPR_JSON* jint64 = WINPR_JSON_AddObjectToObject(
3711 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_INT64));
3712 WINPR_JSON* jstring = WINPR_JSON_AddObjectToObject(
3713 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_STRING));
3714 WINPR_JSON* jpointer = WINPR_JSON_AddObjectToObject(
3715 json, freerdp_settings_get_type_name_for_type(RDP_SETTINGS_TYPE_POINTER));
3716 if (!jbool || !juint16 || !jint16 || !juint32 || !jint32 || !juint64 || !jint64 || !jstring ||
3717 !jpointer)
3718 goto fail;
3719
3720 for (int x = 0; x < FreeRDP_Settings_StableAPI_MAX; x++)
3721 {
3722 union
3723 {
3724
3725 int s;
3726 FreeRDP_Settings_Keys_Bool b;
3727 FreeRDP_Settings_Keys_Int16 i16;
3728 FreeRDP_Settings_Keys_UInt16 u16;
3729 FreeRDP_Settings_Keys_Int32 i32;
3730 FreeRDP_Settings_Keys_UInt32 u32;
3731 FreeRDP_Settings_Keys_Int64 i64;
3732 FreeRDP_Settings_Keys_UInt64 u64;
3733 FreeRDP_Settings_Keys_String str;
3734 FreeRDP_Settings_Keys_Pointer ptr;
3735 } iter;
3736 iter.s = x;
3737
3738 const char* name = freerdp_settings_get_name_for_key(iter.s);
3739 SSIZE_T type = freerdp_settings_get_type_for_key(iter.s);
3740 switch (type)
3741 {
3742 case RDP_SETTINGS_TYPE_BOOL:
3743 {
3744 const BOOL val = freerdp_settings_get_bool(settings, iter.b);
3745 if (!WINPR_JSON_AddBoolToObject(jbool, name, val))
3746 goto fail;
3747 }
3748 break;
3749 case RDP_SETTINGS_TYPE_UINT16:
3750 {
3751 const uint16_t val = freerdp_settings_get_uint16(settings, iter.u16);
3752 if (!WINPR_JSON_AddNumberToObject(juint16, name, (double)val))
3753 goto fail;
3754 }
3755 break;
3756 case RDP_SETTINGS_TYPE_INT16:
3757 {
3758 const int16_t val = freerdp_settings_get_int16(settings, iter.i16);
3759 if (!WINPR_JSON_AddNumberToObject(jint16, name, (double)val))
3760 goto fail;
3761 }
3762 break;
3763 case RDP_SETTINGS_TYPE_UINT32:
3764 {
3765 const uint32_t val = freerdp_settings_get_uint32(settings, iter.u32);
3766 if (!WINPR_JSON_AddNumberToObject(juint32, name, (double)val))
3767 goto fail;
3768 }
3769 break;
3770 case RDP_SETTINGS_TYPE_INT32:
3771 {
3772 const int32_t val = freerdp_settings_get_int32(settings, iter.i32);
3773 if (!WINPR_JSON_AddNumberToObject(jint32, name, (double)val))
3774 goto fail;
3775 }
3776 break;
3777 case RDP_SETTINGS_TYPE_UINT64:
3778 {
3779 const uint64_t val = freerdp_settings_get_uint64(settings, iter.u64);
3780 if (!WINPR_JSON_AddNumberToObject(juint64, name, (double)val))
3781 goto fail;
3782 }
3783 break;
3784 case RDP_SETTINGS_TYPE_INT64:
3785 {
3786 const int64_t val = freerdp_settings_get_int64(settings, iter.i64);
3787 if (!WINPR_JSON_AddNumberToObject(jint64, name, (double)val))
3788 goto fail;
3789 }
3790 break;
3791 case RDP_SETTINGS_TYPE_STRING:
3792 {
3793 const char* val = freerdp_settings_get_string(settings, iter.str);
3794 if (val)
3795 {
3796 if (!WINPR_JSON_AddStringToObject(jstring, name, val))
3797 goto fail;
3798 }
3799 else
3800 {
3801 (void)WINPR_JSON_AddNullToObject(jstring, name);
3802 }
3803 }
3804 break;
3805 case RDP_SETTINGS_TYPE_POINTER:
3806 if (!serialize_pointer(settings, jpointer, iter.ptr))
3807 goto fail;
3808 break;
3809 default:
3810 break;
3811 }
3812 }
3813
3814 if (pretty)
3815 str = WINPR_JSON_Print(json);
3816 else
3817 str = WINPR_JSON_PrintUnformatted(json);
3818
3819 if (!str)
3820 goto fail;
3821 if (plength)
3822 *plength = strlen(str);
3823
3824fail:
3825 WINPR_JSON_Delete(json);
3826 return str;
3827}
WINPR_ATTR_NODISCARD WINPR_API char * WINPR_JSON_PrintUnformatted(WINPR_JSON *item)
Serialize a JSON instance to string without formatting for human readable formatted output see WINPR_...
Definition c-json.c:301
WINPR_API WINPR_JSON * WINPR_JSON_AddNumberToObject(WINPR_JSON *object, const char *name, double number)
WINPR_JSON_AddNumberToObject.
Definition c-json.c:257
WINPR_API WINPR_JSON * WINPR_JSON_CreateObject(void)
WINPR_JSON_CreateObject.
Definition c-json.c:232
WINPR_ATTR_NODISCARD WINPR_API char * WINPR_JSON_Print(WINPR_JSON *item)
Serialize a JSON instance to string for minimal size without formatting see WINPR_JSON_PrintUnformatt...
Definition c-json.c:296
WINPR_API WINPR_JSON * WINPR_JSON_AddStringToObject(WINPR_JSON *object, const char *name, const char *string)
WINPR_JSON_AddStringToObject.
Definition c-json.c:269
WINPR_API WINPR_JSON * WINPR_JSON_AddBoolToObject(WINPR_JSON *object, const char *name, BOOL boolean)
WINPR_JSON_AddBoolToObject.
Definition c-json.c:252
WINPR_API WINPR_JSON * WINPR_JSON_AddNullToObject(WINPR_JSON *object, const char *name)
WINPR_JSON_AddNullToObject.
Definition c-json.c:237
WINPR_API WINPR_JSON * WINPR_JSON_AddObjectToObject(WINPR_JSON *object, const char *name)
WINPR_JSON_AddObjectToObject.
Definition c-json.c:274

References freerdp_settings_get_bool(), freerdp_settings_get_int16(), freerdp_settings_get_int32(), freerdp_settings_get_int64(), freerdp_settings_get_name_for_key(), freerdp_settings_get_string(), freerdp_settings_get_type_for_key(), freerdp_settings_get_type_name_for_type(), freerdp_settings_get_uint16(), freerdp_settings_get_uint32(), freerdp_settings_get_uint64(), WINPR_JSON_AddBoolToObject(), WINPR_JSON_AddNullToObject(), WINPR_JSON_AddNumberToObject(), WINPR_JSON_AddObjectToObject(), WINPR_JSON_AddStringToObject(), WINPR_JSON_CreateObject(), WINPR_JSON_Delete(), WINPR_JSON_Print(), and WINPR_JSON_PrintUnformatted().

Here is the call graph for this function:

◆ freerdp_settings_set_bool()

FREERDP_API BOOL freerdp_settings_set_bool ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Bool  id,
BOOL  val 
)

Sets a BOOL settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_set_gateway_usage_method(), freerdp_settings_copy_item(), freerdp_settings_deserialize(), and freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_set_int16()

FREERDP_API BOOL freerdp_settings_set_int16 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Int16  id,
INT16  val 
)

Sets a INT16 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), and freerdp_settings_deserialize().

Here is the caller graph for this function:

◆ freerdp_settings_set_int32()

FREERDP_API BOOL freerdp_settings_set_int32 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Int32  id,
INT32  val 
)

Sets a INT32 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), freerdp_settings_deserialize(), freerdp_settings_new(), and freerdp_settings_set_monitor_def_array_sorted().

Here is the caller graph for this function:

◆ freerdp_settings_set_int64()

FREERDP_API BOOL freerdp_settings_set_int64 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Int64  id,
INT64  val 
)

Sets a INT64 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), and freerdp_settings_deserialize().

Here is the caller graph for this function:

◆ freerdp_settings_set_monitor_def_array_sorted()

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:

  1. First monitor is at x/y 0/0 and is the primary monitor
  2. The primary monitor must be at 0/0, if not set FreeRDP_MonitorLocalShiftX/FreeRDP_MonitorLocalShiftY

The FreeRDP_MonitorLocalShiftX/FreeRDP_MonitorLocalShiftY is required to map the local monitors / mouse / touch coordinates to the remote ones.

Parameters
settingsThe settings to set the monitors for
monitorsThe unsorted monitors array
countThe number of monitors in the unsorted array
Returns
TRUE if the configuration is valid (or could be corrected to a valid one), FALSE otherwise.
Version
since 3.11.0

Definition at line 2432 of file common/settings.c.

2434{
2435 WINPR_ASSERT(monitors || (count == 0));
2436 if (count == 0)
2437 {
2438 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftX, 0))
2439 return FALSE;
2440 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftY, 0))
2441 return FALSE;
2442 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_MonitorDefArray, nullptr, 0))
2443 return FALSE;
2444 return freerdp_settings_set_uint32(settings, FreeRDP_MonitorCount, 0);
2445 }
2446
2447 // Find primary or alternatively the monitor at 0/0
2448 const rdpMonitor* primary = nullptr;
2449 for (size_t x = 0; x < count; x++)
2450 {
2451 const rdpMonitor* cur = &monitors[x];
2452 if (cur->is_primary)
2453 {
2454 primary = cur;
2455 break;
2456 }
2457 }
2458 if (!primary)
2459 {
2460 for (size_t x = 0; x < count; x++)
2461 {
2462 const rdpMonitor* cur = &monitors[x];
2463 if ((cur->x == 0) && (cur->y == 0))
2464 {
2465 primary = cur;
2466 break;
2467 }
2468 }
2469 }
2470
2471 if (!primary)
2472 {
2473 WLog_ERR(TAG, "Could not find primary monitor, aborting");
2474 return FALSE;
2475 }
2476
2477 if (!freerdp_settings_set_pointer_len(settings, FreeRDP_MonitorDefArray, nullptr, count))
2478 return FALSE;
2479 rdpMonitor* sorted = freerdp_settings_get_pointer_writable(settings, FreeRDP_MonitorDefArray);
2480 WINPR_ASSERT(sorted);
2481
2482 size_t sortpos = 0;
2483
2484 /* Set primary. Ensure left/top is at 0/0 and flags contains MONITOR_PRIMARY */
2485 sorted[sortpos] = *primary;
2486 sorted[sortpos].x = 0;
2487 sorted[sortpos].y = 0;
2488 sorted[sortpos].is_primary = TRUE;
2489 sortpos++;
2490
2491 /* Set monitor shift to original layout */
2492 const INT32 offsetX = primary->x;
2493 const INT32 offsetY = primary->y;
2494 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftX, offsetX))
2495 return FALSE;
2496 if (!freerdp_settings_set_int32(settings, FreeRDP_MonitorLocalShiftY, offsetY))
2497 return FALSE;
2498
2499 for (size_t x = 0; x < count; x++)
2500 {
2501 const rdpMonitor* cur = &monitors[x];
2502 if (cur == primary)
2503 continue;
2504
2505 rdpMonitor m = monitors[x];
2506 m.x -= offsetX;
2507 m.y -= offsetY;
2508 sorted[sortpos++] = m;
2509 }
2510
2511 // Sort remaining monitors by x/y ?
2512 qsort(sorted, count, sizeof(rdpMonitor), sort_monitor_fn);
2513
2514 return freerdp_settings_set_uint32(settings, FreeRDP_MonitorCount,
2515 WINPR_ASSERTING_INT_CAST(uint32_t, count));
2516}

References freerdp_settings_get_pointer_writable(), freerdp_settings_set_int32(), freerdp_settings_set_pointer_len(), and freerdp_settings_set_uint32().

Here is the call graph for this function:

◆ freerdp_settings_set_pointer()

FREERDP_API BOOL freerdp_settings_set_pointer ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Pointer  id,
const void *  val 
)

Set a pointer to value val.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to update
valThe data to set (direct update, no copy created, previous value overwritten)
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), and freerdp_settings_set_pointer_len().

Here is the caller graph for this function:

◆ freerdp_settings_set_pointer_array()

FREERDP_API BOOL freerdp_settings_set_pointer_array ( rdpSettings *  settings,
FreeRDP_Settings_Keys_Pointer  id,
size_t  offset,
const void *  data 
)

Definition at line 1801 of file common/settings.c.

1803{
1804 size_t maxOffset = 0;
1805 if (!settings)
1806 return FALSE;
1807 switch (id)
1808 {
1809 case FreeRDP_ClientAutoReconnectCookie:
1810 maxOffset = 1;
1811 if ((offset >= maxOffset) || !data || !settings->ClientAutoReconnectCookie)
1812 goto fail;
1813 settings->ClientAutoReconnectCookie[offset] = *(const ARC_CS_PRIVATE_PACKET*)data;
1814 return TRUE;
1815 case FreeRDP_ServerAutoReconnectCookie:
1816 maxOffset = 1;
1817 if ((offset >= maxOffset) || !data || !settings->ServerAutoReconnectCookie)
1818 goto fail;
1819 settings->ServerAutoReconnectCookie[offset] = *(const ARC_SC_PRIVATE_PACKET*)data;
1820 return TRUE;
1821 case FreeRDP_ServerCertificate:
1822 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ServerCertificateLength);
1823 if ((offset >= maxOffset) || !data)
1824 goto fail;
1825 settings->ServerCertificate[offset] = *(const BYTE*)data;
1826 return TRUE;
1827 case FreeRDP_DeviceArray:
1828 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_DeviceArraySize);
1829 if (offset >= maxOffset)
1830 goto fail;
1831 freerdp_device_free(settings->DeviceArray[offset]);
1832 settings->DeviceArray[offset] = freerdp_device_clone(data);
1833 return TRUE;
1834 case FreeRDP_TargetNetAddresses:
1835 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_TargetNetAddressCount);
1836 if ((offset >= maxOffset) || !data)
1837 goto fail;
1838 WINPR_ASSERT(settings->TargetNetAddresses);
1839 free(settings->TargetNetAddresses[offset]);
1840 settings->TargetNetAddresses[offset] = _strdup((const char*)data);
1841 return settings->TargetNetAddresses[offset] != nullptr;
1842 case FreeRDP_TargetNetPorts:
1843 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_TargetNetAddressCount);
1844 if ((offset >= maxOffset) || !data)
1845 goto fail;
1846 WINPR_ASSERT(settings->TargetNetPorts);
1847 settings->TargetNetPorts[offset] = *((const UINT32*)data);
1848 return TRUE;
1849 case FreeRDP_StaticChannelArray:
1850 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelArraySize);
1851 if ((offset >= maxOffset) || !data)
1852 goto fail;
1853 freerdp_addin_argv_free(settings->StaticChannelArray[offset]);
1854 settings->StaticChannelArray[offset] = freerdp_addin_argv_clone(data);
1855 return TRUE;
1856 case FreeRDP_DynamicChannelArray:
1857 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_DynamicChannelArraySize);
1858 if ((offset >= maxOffset) || !data)
1859 goto fail;
1860 freerdp_addin_argv_free(settings->DynamicChannelArray[offset]);
1861 settings->DynamicChannelArray[offset] = freerdp_addin_argv_clone(data);
1862 return TRUE;
1863 case FreeRDP_BitmapCacheV2CellInfo:
1864 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_BitmapCacheV2NumCells);
1865 if ((offset >= maxOffset) || !data)
1866 goto fail;
1867 {
1868 const BITMAP_CACHE_V2_CELL_INFO* cdata = (const BITMAP_CACHE_V2_CELL_INFO*)data;
1869 settings->BitmapCacheV2CellInfo[offset] = *cdata;
1870 }
1871 return TRUE;
1872 case FreeRDP_ServerRandom:
1873 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ServerRandomLength);
1874 if ((offset >= maxOffset) || !data)
1875 goto fail;
1876 settings->ServerRandom[offset] = *(const BYTE*)data;
1877 return TRUE;
1878 case FreeRDP_ClientRandom:
1879 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ClientRandomLength);
1880 if ((offset >= maxOffset) || !data)
1881 goto fail;
1882 settings->ClientRandom[offset] = *(const BYTE*)data;
1883 return TRUE;
1884 case FreeRDP_LoadBalanceInfo:
1885 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_LoadBalanceInfoLength);
1886 if ((offset >= maxOffset) || !data)
1887 goto fail;
1888 settings->LoadBalanceInfo[offset] = *(const BYTE*)data;
1889 return TRUE;
1890 case FreeRDP_RedirectionTsvUrl:
1891 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_RedirectionTsvUrlLength);
1892 if ((offset >= maxOffset) || !data)
1893 goto fail;
1894 settings->RedirectionTsvUrl[offset] = *(const BYTE*)data;
1895 return TRUE;
1896 case FreeRDP_RedirectionPassword:
1897 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_RedirectionPasswordLength);
1898 if ((offset >= maxOffset) || !data)
1899 goto fail;
1900 settings->RedirectionPassword[offset] = *(const BYTE*)data;
1901 return TRUE;
1902 case FreeRDP_OrderSupport:
1903 maxOffset = 32;
1904 if (!settings->OrderSupport)
1905 goto fail;
1906 if ((offset >= maxOffset) || !data)
1907 goto fail;
1908 settings->OrderSupport[offset] = *(const BOOL*)data ? 1 : 0;
1909 return TRUE;
1910 case FreeRDP_GlyphCache:
1911 maxOffset = 10;
1912 if (!settings->GlyphCache)
1913 goto fail;
1914 if ((offset >= maxOffset) || !data)
1915 goto fail;
1916 settings->GlyphCache[offset] = *(const GLYPH_CACHE_DEFINITION*)data;
1917 return TRUE;
1918 case FreeRDP_FragCache:
1919 maxOffset = 1;
1920 if (!settings->FragCache)
1921 goto fail;
1922 if ((offset >= maxOffset) || !data)
1923 goto fail;
1924 settings->FragCache[offset] = *(const GLYPH_CACHE_DEFINITION*)data;
1925 return TRUE;
1926 case FreeRDP_MonitorIds:
1927 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_NumMonitorIds);
1928 if ((offset >= maxOffset) || !data)
1929 goto fail;
1930 settings->MonitorIds[offset] = *(const UINT32*)data;
1931 return TRUE;
1932 case FreeRDP_ChannelDefArray:
1933 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ChannelDefArraySize);
1934 if ((offset >= maxOffset) || !data)
1935 goto fail;
1936 settings->ChannelDefArray[offset] = *(const CHANNEL_DEF*)data;
1937 return TRUE;
1938 case FreeRDP_MonitorDefArray:
1939 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_MonitorDefArraySize);
1940 if ((offset >= maxOffset) || !data)
1941 goto fail;
1942 settings->MonitorDefArray[offset] = *(const rdpMonitor*)data;
1943 return TRUE;
1944
1945 case FreeRDP_ClientTimeZone:
1946 maxOffset = 1;
1947 if ((offset >= maxOffset) || !data || !settings->ClientTimeZone)
1948 goto fail;
1949 settings->ClientTimeZone[offset] = *(const TIME_ZONE_INFORMATION*)data;
1950 return TRUE;
1951
1952 case FreeRDP_ServerLicenseProductIssuers:
1953 maxOffset =
1954 freerdp_settings_get_uint32(settings, FreeRDP_ServerLicenseProductIssuersCount);
1955 if ((offset >= maxOffset) || !settings->ServerLicenseProductIssuers)
1956 goto fail;
1957 free(settings->ServerLicenseProductIssuers[offset]);
1958 settings->ServerLicenseProductIssuers[offset] = nullptr;
1959 if (data)
1960 settings->ServerLicenseProductIssuers[offset] = _strdup((const char*)data);
1961 return TRUE;
1962
1963 case FreeRDP_ReceivedCapabilityData:
1964 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ReceivedCapabilitiesSize);
1965 if (offset >= maxOffset)
1966 goto fail;
1967 WINPR_ASSERT(settings->ReceivedCapabilityData);
1968 settings->ReceivedCapabilityData[offset] = WINPR_CAST_CONST_PTR_AWAY(data, BYTE*);
1969 return TRUE;
1970 case FreeRDP_ReceivedCapabilityDataSizes:
1971 maxOffset = freerdp_settings_get_uint32(settings, FreeRDP_ReceivedCapabilitiesSize);
1972 if (offset >= maxOffset)
1973 goto fail;
1974 WINPR_ASSERT(settings->ReceivedCapabilityDataSizes);
1975 settings->ReceivedCapabilityDataSizes[offset] = *(const uint32_t*)data;
1976 return TRUE;
1977 default:
1978 WLog_WARN(TAG, "Invalid id %s [%d]", freerdp_settings_get_name_for_key(id), id);
1979 return FALSE;
1980 }
1981
1982fail:
1983 WLog_WARN(TAG, "[%s] Invalid offset=%" PRIuz " [%" PRIuz "] or nullptr data=%p",
1984 freerdp_settings_get_name_for_key(id), offset, maxOffset, data);
1985 return FALSE;
1986}

◆ freerdp_settings_set_pointer_len()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to update
dataThe data to set (copy created, previous value freed)
Returns
TRUE for success, FALSE for failure

Definition at line 1426 of file common/settings.c.

1428{
1429 union
1430 {
1431 const void* cv;
1432 void* v;
1433 } cnv;
1434
1435 cnv.cv = data;
1436 if (!settings)
1437 return FALSE;
1438
1439 switch (id)
1440 {
1441 case FreeRDP_RdpServerCertificate:
1442 freerdp_certificate_free(settings->RdpServerCertificate);
1443
1444 if (len > 1)
1445 {
1446 WLog_ERR(TAG, "FreeRDP_RdpServerCertificate::len must be 0 or 1");
1447 return FALSE;
1448 }
1449 settings->RdpServerCertificate = cnv.v;
1450 if (!settings->RdpServerCertificate && (len > 0))
1451 {
1452 settings->RdpServerCertificate = freerdp_certificate_new();
1453 if (!settings->RdpServerCertificate)
1454 return FALSE;
1455 }
1456 return TRUE;
1457 case FreeRDP_RdpServerRsaKey:
1458 freerdp_key_free(settings->RdpServerRsaKey);
1459 if (len > 1)
1460 {
1461 WLog_ERR(TAG, "FreeRDP_RdpServerRsaKey::len must be 0 or 1");
1462 return FALSE;
1463 }
1464 settings->RdpServerRsaKey = (rdpPrivateKey*)cnv.v;
1465 if (!settings->RdpServerRsaKey && (len > 0))
1466 {
1467 settings->RdpServerRsaKey = freerdp_key_new();
1468 if (!settings->RdpServerRsaKey)
1469 return FALSE;
1470 }
1471 return TRUE;
1472 case FreeRDP_RedirectionPassword:
1473 return freerdp_settings_set_pointer_len_(
1474 settings, id, FreeRDP_RedirectionPasswordLength, data, len, sizeof(char));
1475 case FreeRDP_RedirectionTsvUrl:
1476 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_RedirectionTsvUrlLength,
1477 data, len, sizeof(char));
1478 case FreeRDP_RedirectionTargetCertificate:
1479 freerdp_certificate_free(settings->RedirectionTargetCertificate);
1480
1481 if (len > 1)
1482 {
1483 WLog_ERR(TAG, "FreeRDP_RedirectionTargetCertificate::len must be 0 or 1");
1484 return FALSE;
1485 }
1486 settings->RedirectionTargetCertificate = cnv.v;
1487 if (!settings->RedirectionTargetCertificate && (len > 0))
1488 {
1489 settings->RedirectionTargetCertificate = freerdp_certificate_new();
1490 if (!settings->RedirectionTargetCertificate)
1491 return FALSE;
1492 }
1493 return TRUE;
1494 case FreeRDP_RedirectionGuid:
1495 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_RedirectionGuidLength,
1496 data, len, sizeof(BYTE));
1497 case FreeRDP_LoadBalanceInfo:
1498 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_LoadBalanceInfoLength,
1499 data, len, sizeof(char));
1500 case FreeRDP_ServerRandom:
1501 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_ServerRandomLength, data,
1502 len, sizeof(char));
1503 case FreeRDP_ClientRandom:
1504 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_ClientRandomLength, data,
1505 len, sizeof(char));
1506 case FreeRDP_ServerCertificate:
1507 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_ServerCertificateLength,
1508 data, len, sizeof(char));
1509 case FreeRDP_TargetNetAddresses:
1510 if (!freerdp_target_net_addresses_resize(settings, len))
1511 return FALSE;
1512 if (data == nullptr)
1513 target_net_addresses_free(settings, 0);
1514 return TRUE;
1515 case FreeRDP_ServerLicenseProductIssuers:
1516 if (data == nullptr)
1517 freerdp_server_license_issuers_free(settings);
1518 return freerdp_settings_set_pointer_len_(
1519 settings, id, FreeRDP_ServerLicenseProductIssuersCount, data, len, sizeof(char*));
1520 case FreeRDP_TargetNetPorts:
1521 if (!freerdp_target_net_addresses_resize(settings, len))
1522 return FALSE;
1523 if (data == nullptr)
1524 {
1525 for (size_t x = 0; x < len; x++)
1526 settings->TargetNetPorts[x] = 0;
1527 }
1528 return TRUE;
1529 case FreeRDP_DeviceArray:
1530 if (data == nullptr)
1531 freerdp_device_collection_free(settings);
1532 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_DeviceArraySize, data,
1533 len, sizeof(RDPDR_DEVICE*));
1534 case FreeRDP_ChannelDefArray:
1535 if ((len > 0) && (len < CHANNEL_MAX_COUNT))
1536 WLog_WARN(TAG,
1537 "FreeRDP_ChannelDefArray::len expected to be >= %d, but have %" PRIuz,
1538 CHANNEL_MAX_COUNT, len);
1539 return freerdp_settings_set_pointer_len_(settings, FreeRDP_ChannelDefArray,
1540 FreeRDP_ChannelDefArraySize, data, len,
1541 sizeof(CHANNEL_DEF));
1542 case FreeRDP_MonitorDefArray:
1543 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_MonitorDefArraySize,
1544 data, len, sizeof(rdpMonitor));
1545 case FreeRDP_ClientAutoReconnectCookie:
1546 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1547 sizeof(ARC_CS_PRIVATE_PACKET));
1548 case FreeRDP_ServerAutoReconnectCookie:
1549 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1550 sizeof(ARC_SC_PRIVATE_PACKET));
1551 case FreeRDP_ClientTimeZone:
1552 if (len > 1)
1553 {
1554 WLog_ERR(TAG, "FreeRDP_ClientTimeZone::len must be 0 or 1");
1555 return FALSE;
1556 }
1557 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1558 sizeof(TIME_ZONE_INFORMATION));
1559 case FreeRDP_BitmapCacheV2CellInfo:
1560 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_BitmapCacheV2NumCells,
1561 data, len, sizeof(BITMAP_CACHE_V2_CELL_INFO));
1562 case FreeRDP_GlyphCache:
1563 if ((len != 0) && (len != 10))
1564 {
1565 WLog_ERR(TAG, "FreeRDP_GlyphCache::len must be 0 or 10");
1566 return FALSE;
1567 }
1568 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1569 sizeof(GLYPH_CACHE_DEFINITION));
1570 case FreeRDP_FragCache:
1571 if (len > 1)
1572 {
1573 WLog_ERR(TAG, "FreeRDP_FragCache::len must be 0 or 1");
1574 return FALSE;
1575 }
1576 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1577 sizeof(GLYPH_CACHE_DEFINITION));
1578 case FreeRDP_StaticChannelArray:
1579 if (data == nullptr)
1580 freerdp_static_channel_collection_free(settings);
1581 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_StaticChannelArraySize,
1582 data, len, sizeof(ADDIN_ARGV*));
1583 case FreeRDP_DynamicChannelArray:
1584 if (data == nullptr)
1585 freerdp_dynamic_channel_collection_free(settings);
1586 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_DynamicChannelArraySize,
1587 data, len, sizeof(ADDIN_ARGV*));
1588 case FreeRDP_ReceivedCapabilityData:
1589 if (!freerdp_capability_buffer_resize(settings, len, FALSE))
1590 return FALSE;
1591 if (data == nullptr)
1592 {
1593 freerdp_capability_data_free(settings, 0, FALSE);
1594 }
1595 return TRUE;
1596 case FreeRDP_ReceivedCapabilities:
1597 if (!freerdp_capability_buffer_resize(settings, len, FALSE))
1598 return FALSE;
1599 if (data == nullptr)
1600 {
1601 for (size_t x = 0; x < settings->ReceivedCapabilitiesSize; x++)
1602 {
1603 settings->ReceivedCapabilities[x] = 0;
1604 }
1605 }
1606 return TRUE;
1607 case FreeRDP_OrderSupport:
1608 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_UINT32_UNUSED, data, len,
1609 sizeof(char));
1610
1611 case FreeRDP_MonitorIds:
1612 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_NumMonitorIds, data, len,
1613 sizeof(UINT32));
1614
1615 case FreeRDP_ReceivedCapabilityDataSizes:
1616 if (!freerdp_capability_buffer_resize(settings, len, FALSE))
1617 return FALSE;
1618 if (data == nullptr)
1619 {
1620 for (size_t x = 0; x < settings->ReceivedCapabilitiesSize; x++)
1621 settings->ReceivedCapabilityDataSizes[x] = 0;
1622 }
1623 return TRUE;
1624
1625 case FreeRDP_Password51:
1626 return freerdp_settings_set_pointer_len_(settings, id, FreeRDP_Password51Length, data,
1627 len, sizeof(char));
1628 default:
1629 if ((data == nullptr) && (len == 0))
1630 {
1631 freerdp_settings_set_pointer(settings, id, nullptr);
1632 }
1633 else
1634 WLog_WARN(TAG, "Invalid id %d", id);
1635 return FALSE;
1636 }
1637}

References freerdp_settings_set_pointer().

Referenced by freerdp_settings_new(), and freerdp_settings_set_monitor_def_array_sorted().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ freerdp_settings_set_string()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set. If nullptr removes the old entry, otherwise a copy is created.
Returns
TRUE for success, FALSE for failure

Definition at line 3729 of file settings_getters.c.

3731{
3732 size_t len = 0;
3733 if (val)
3734 len = strlen(val);
3735 return freerdp_settings_set_string_copy_(settings, id, val, len, TRUE);
3736}

Referenced by freerdp_settings_copy_item(), freerdp_settings_deserialize(), and freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_set_string_from_utf16()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
paramThe value to set. If nullptr removes the old entry, otherwise a copy is created.
Returns
TRUE for success, FALSE for failure

Definition at line 2241 of file common/settings.c.

2243{
2244 WINPR_ASSERT(settings);
2245
2246 if (!param)
2247 return freerdp_settings_set_string_copy_(settings, id, nullptr, 0, TRUE);
2248
2249 size_t len = 0;
2250
2251 char* str = ConvertWCharToUtf8Alloc(param, &len);
2252 if (!str && (len != 0))
2253 return FALSE;
2254
2255 return freerdp_settings_set_string_(settings, id, str, len);
2256}

◆ freerdp_settings_set_string_from_utf16N()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
paramThe value to set. If nullptr removes the old entry, otherwise a copy is created.
lengthThe length of the WCHAR string in number of WCHAR characters
Returns
TRUE for success, FALSE for failure

Definition at line 2258 of file common/settings.c.

2260{
2261 size_t len = 0;
2262
2263 WINPR_ASSERT(settings);
2264
2265 if (!param)
2266 return freerdp_settings_set_string_copy_(settings, id, nullptr, length, TRUE);
2267
2268 char* str = ConvertWCharNToUtf8Alloc(param, length, &len);
2269 if (!str && (length != 0))
2270 {
2271 /* If the input string is an empty string, but length > 0
2272 * consider the conversion a success */
2273 const size_t wlen = _wcsnlen(param, length);
2274 if (wlen != 0)
2275 return FALSE;
2276 }
2277
2278 return freerdp_settings_set_string_(settings, id, str, len);
2279}

Referenced by freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_set_string_len()

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.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set. If nullptr allocates an empty string buffer of len size, otherwise a copy is created.
lenThe length of val, 0 to remove the old entry.
Returns
TRUE for success, FALSE for failure

Definition at line 3723 of file settings_getters.c.

3725{
3726 return freerdp_settings_set_string_copy_(settings, id, val, len, TRUE);
3727}

Referenced by freerdp_settings_append_string(), and freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_set_uint16()

FREERDP_API BOOL freerdp_settings_set_uint16 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt16  id,
UINT16  val 
)

Sets a UINT16 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), freerdp_settings_deserialize(), and freerdp_settings_new().

Here is the caller graph for this function:

◆ freerdp_settings_set_uint32()

FREERDP_API BOOL freerdp_settings_set_uint32 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt32  id,
UINT32  val 
)

Sets a UINT32 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_set_gateway_usage_method(), freerdp_settings_copy_item(), freerdp_settings_deserialize(), freerdp_settings_new(), and freerdp_settings_set_monitor_def_array_sorted().

Here is the caller graph for this function:

◆ freerdp_settings_set_uint64()

FREERDP_API BOOL freerdp_settings_set_uint64 ( rdpSettings *  settings,
FreeRDP_Settings_Keys_UInt64  id,
UINT64  val 
)

Sets a UINT64 settings value.

Parameters
settingsA pointer to the settings to query, must not be nullptr.
idThe key to query
valThe value to set.
Returns
TRUE for success, FALSE for failure

Referenced by freerdp_settings_copy_item(), and freerdp_settings_deserialize().

Here is the caller graph for this function:

◆ freerdp_settings_set_value_for_name()

FREERDP_API BOOL freerdp_settings_set_value_for_name ( rdpSettings *  settings,
const char *  name,
const char *  value 
)

Definition at line 1276 of file common/settings.c.

1277{
1278 ULONGLONG uval = 0;
1279 LONGLONG ival = 0;
1280 SSIZE_T type = 0;
1281
1282 if (!settings || !name)
1283 return FALSE;
1284
1285 const SSIZE_T i = freerdp_settings_get_key_for_name(name);
1286 if (i < 0)
1287 {
1288 WLog_ERR(TAG, "Invalid settings key [%s]", name);
1289 return FALSE;
1290 }
1291
1292 const SSIZE_T index = i;
1293
1295 switch (type)
1296 {
1297
1298 case RDP_SETTINGS_TYPE_BOOL:
1299 {
1300 const BOOL val = (_strnicmp(value, "TRUE", 5) == 0) || (_strnicmp(value, "ON", 5) == 0);
1301 const BOOL nval =
1302 (_strnicmp(value, "FALSE", 6) == 0) || (_strnicmp(value, "OFF", 6) == 0);
1303 if (!val && !nval)
1304 return parsing_fail(name, "BOOL", value);
1305
1306 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1307 return freerdp_settings_set_bool(settings, (FreeRDP_Settings_Keys_Bool)index, val);
1308 }
1309 case RDP_SETTINGS_TYPE_UINT16:
1310 if (!value_to_uint(value, &uval, 0, UINT16_MAX))
1311 return parsing_fail(name, "UINT16", value);
1312
1313 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1314 if (!freerdp_settings_set_uint16(settings, (FreeRDP_Settings_Keys_UInt16)index,
1315 (UINT16)uval))
1316 return parsing_fail(name, "UINT16", value);
1317 return TRUE;
1318
1319 case RDP_SETTINGS_TYPE_INT16:
1320 if (!value_to_int(value, &ival, INT16_MIN, INT16_MAX))
1321 return parsing_fail(name, "INT16", value);
1322
1323 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1324 if (!freerdp_settings_set_int16(settings, (FreeRDP_Settings_Keys_Int16)index,
1325 (INT16)ival))
1326 return parsing_fail(name, "INT16", value);
1327 return TRUE;
1328 case RDP_SETTINGS_TYPE_UINT32:
1329 if (!value_to_uint(value, &uval, 0, UINT32_MAX))
1330 return parsing_fail(name, "UINT32", value);
1331
1332 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1333 if (!freerdp_settings_set_uint32(settings, (FreeRDP_Settings_Keys_UInt32)index,
1334 (UINT32)uval))
1335 return parsing_fail(name, "UINT32", value);
1336 return TRUE;
1337 case RDP_SETTINGS_TYPE_INT32:
1338 if (!value_to_int(value, &ival, INT32_MIN, INT32_MAX))
1339 return parsing_fail(name, "INT32", value);
1340
1341 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1342 if (!freerdp_settings_set_int32(settings, (FreeRDP_Settings_Keys_Int32)index,
1343 (INT32)ival))
1344 return parsing_fail(name, "INT32", value);
1345 return TRUE;
1346 case RDP_SETTINGS_TYPE_UINT64:
1347 if (!value_to_uint(value, &uval, 0, UINT64_MAX))
1348 return parsing_fail(name, "UINT64", value);
1349
1350 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1351 if (!freerdp_settings_set_uint64(settings, (FreeRDP_Settings_Keys_UInt64)index, uval))
1352 return parsing_fail(name, "UINT64", value);
1353 return TRUE;
1354 case RDP_SETTINGS_TYPE_INT64:
1355 if (!value_to_int(value, &ival, INT64_MIN, INT64_MAX))
1356 return parsing_fail(name, "INT64", value);
1357
1358 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1359 if (!freerdp_settings_set_int64(settings, (FreeRDP_Settings_Keys_Int64)index, ival))
1360 return parsing_fail(name, "INT64", value);
1361 return TRUE;
1362
1363 case RDP_SETTINGS_TYPE_STRING:
1364 // NOLINTNEXTLINE(clang-analyzer-optin.core.EnumCastOutOfRange)
1365 return freerdp_settings_set_string(settings, (FreeRDP_Settings_Keys_String)index,
1366 value);
1367 case RDP_SETTINGS_TYPE_POINTER:
1368 return parsing_fail(name, "POINTER", value);
1369 default:
1370 return FALSE;
1371 }
1372 return FALSE;
1373}
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.

◆ freerdp_settings_update_from_caps()

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.

The capability message is stored in raw form in the settings, the data parsed and applied to the settings.

Parameters
settingsA pointer to the settings to use
capsFlagsA pointer to the capability flags, must have capsCount fields
capsDataA pointer array to the RAW capability data, must have capsCount fields
capsSizesA pointer to an array of RAW capability sizes, must have capsCount fields
capsCountThe number of capabilities contained in the RAW data
serverReceivedCapsIndicates if the parser should assume to be a server or client instance
Returns
TRUE for success, FALSE in case of an error

Definition at line 2175 of file common/settings.c.

2178{
2179 WINPR_ASSERT(settings);
2180 WINPR_ASSERT(capsFlags || (capsCount == 0));
2181 WINPR_ASSERT(capsData || (capsCount == 0));
2182 WINPR_ASSERT(capsSizes || (capsCount == 0));
2183 WINPR_ASSERT(capsCount <= UINT16_MAX);
2184
2185 wLog* log = WLog_Get(TAG);
2186
2187 for (UINT32 x = 0; x < capsCount; x++)
2188 {
2189 if (capsFlags[x])
2190 {
2191 wStream buffer = WINPR_C_ARRAY_INIT;
2192 wStream* sub = Stream_StaticConstInit(&buffer, capsData[x], capsSizes[x]);
2193
2194 if (!rdp_read_capability_set(log, sub, (UINT16)x, settings, serverReceivedCaps))
2195 return FALSE;
2196 }
2197 }
2198
2199 return TRUE;
2200}

◆ freerdp_static_channel_collection_add()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_static_channel_collection_add ( rdpSettings *  settings,
ADDIN_ARGV channel 
)

Definition at line 593 of file common/settings.c.

594{
595 UINT32 count = 0;
596
597 WINPR_ASSERT(settings);
598 WINPR_ASSERT(channel);
599
600 count = freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelCount) + 1;
601 if (freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelArraySize) < count)
602 {
603 const UINT32 oldSize =
604 freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelArraySize);
605 const size_t new_size = oldSize + 32ul;
606 ADDIN_ARGV** new_array = (ADDIN_ARGV**)realloc((void*)settings->StaticChannelArray,
607 new_size * sizeof(ADDIN_ARGV*));
608
609 if (!new_array)
610 return FALSE;
611
612 settings->StaticChannelArray = new_array;
613 {
614 for (size_t x = oldSize; x < new_size; x++)
615 settings->StaticChannelArray[x] = nullptr;
616 }
617 if (!freerdp_settings_set_uint32(settings, FreeRDP_StaticChannelArraySize,
618 WINPR_ASSERTING_INT_CAST(uint32_t, new_size)))
619 return FALSE;
620 }
621
622 count = freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelCount);
623
624 ADDIN_ARGV** cur = &settings->StaticChannelArray[count++];
625 freerdp_addin_argv_free(*cur);
626 *cur = channel;
627 return freerdp_settings_set_uint32(settings, FreeRDP_StaticChannelCount, count);
628}

◆ freerdp_static_channel_collection_del()

FREERDP_API BOOL freerdp_static_channel_collection_del ( rdpSettings *  settings,
const char *  name 
)

Definition at line 561 of file common/settings.c.

562{
563 const UINT32 count = freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelCount);
564 if (!settings || !settings->StaticChannelArray)
565 return FALSE;
566
567 for (UINT32 x = 0; x < count; x++)
568 {
569 ADDIN_ARGV* cur = settings->StaticChannelArray[x];
570 if (cur && (cur->argc > 0))
571 {
572 if (strcmp(name, cur->argv[0]) == 0)
573 {
574 memmove_s((void*)&settings->StaticChannelArray[x],
575 (count - x) * sizeof(ADDIN_ARGV*),
576 (void*)&settings->StaticChannelArray[x + 1],
577 (count - x - 1) * sizeof(ADDIN_ARGV*));
578 for (size_t y = count - 1; y < settings->StaticChannelArraySize; y++)
579 settings->StaticChannelArray[y] = nullptr;
580
581 freerdp_addin_argv_free(cur);
582 return freerdp_settings_set_uint32(settings, FreeRDP_StaticChannelCount, count - 1);
583 }
584 }
585 }
586 {
587 for (size_t x = count; x < settings->StaticChannelArraySize; x++)
588 settings->StaticChannelArray[x] = nullptr;
589 }
590 return FALSE;
591}

◆ freerdp_static_channel_collection_find()

WINPR_ATTR_NODISCARD FREERDP_API ADDIN_ARGV * freerdp_static_channel_collection_find ( rdpSettings *  settings,
const char *  name 
)

Definition at line 630 of file common/settings.c.

631{
632 ADDIN_ARGV* channel = nullptr;
633
634 WINPR_ASSERT(settings);
635 WINPR_ASSERT(name);
636
637 for (UINT32 index = 0;
638 index < freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelCount); index++)
639 {
640 channel = settings->StaticChannelArray[index];
641
642 if (strcmp(channel->argv[0], name) == 0)
643 return channel;
644 }
645
646 return nullptr;
647}

◆ freerdp_static_channel_collection_free()

FREERDP_API void freerdp_static_channel_collection_free ( rdpSettings *  settings)

Definition at line 649 of file common/settings.c.

650{
651 if (!settings)
652 return;
653
654 if (settings->StaticChannelArray)
655 {
656 for (UINT32 i = 0;
657 i < freerdp_settings_get_uint32(settings, FreeRDP_StaticChannelArraySize); i++)
658 freerdp_addin_argv_free(settings->StaticChannelArray[i]);
659 }
660
661 free((void*)settings->StaticChannelArray);
662 freerdp_settings_set_uint32(settings, FreeRDP_StaticChannelArraySize, 0);
663 settings->StaticChannelArray = nullptr;
664 freerdp_settings_set_uint32(settings, FreeRDP_StaticChannelCount, 0);
665}

◆ freerdp_supported_color_depths_string()

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

Parameters
maskA bitmask of supported color dephts RNS_UD_*
bufferA pointer to a buffer of size bytes
sizeThe size of the buffer in bytes
Returns
A string reprenentation of the bitmask.

Definition at line 2358 of file common/settings.c.

2359{
2360 const UINT32 invalid = mask & ~(RNS_UD_32BPP_SUPPORT | RNS_UD_24BPP_SUPPORT |
2361 RNS_UD_16BPP_SUPPORT | RNS_UD_15BPP_SUPPORT);
2362
2363 if (mask & RNS_UD_32BPP_SUPPORT)
2364 winpr_str_append("RNS_UD_32BPP_SUPPORT", buffer, size, "|");
2365 if (mask & RNS_UD_24BPP_SUPPORT)
2366 winpr_str_append("RNS_UD_24BPP_SUPPORT", buffer, size, "|");
2367 if (mask & RNS_UD_16BPP_SUPPORT)
2368 winpr_str_append("RNS_UD_16BPP_SUPPORT", buffer, size, "|");
2369 if (mask & RNS_UD_15BPP_SUPPORT)
2370 winpr_str_append("RNS_UD_15BPP_SUPPORT", buffer, size, "|");
2371
2372 if (invalid != 0)
2373 {
2374 char str[32] = WINPR_C_ARRAY_INIT;
2375 (void)_snprintf(str, sizeof(str), "RNS_UD_INVALID[0x%04" PRIx32 "]", invalid);
2376 winpr_str_append(str, buffer, size, "|");
2377 }
2378 char hex[32] = WINPR_C_ARRAY_INIT;
2379 (void)_snprintf(hex, sizeof(hex), "[0x%04" PRIx16 "]", mask);
2380 return buffer;
2381}

◆ freerdp_target_net_addresses_copy()

WINPR_ATTR_NODISCARD FREERDP_API BOOL freerdp_target_net_addresses_copy ( rdpSettings *  settings,
char **  addresses,
UINT32  count 
)

Definition at line 2032 of file common/settings.c.

2033{
2034 WINPR_ASSERT(settings);
2035 WINPR_ASSERT(addresses);
2036
2037 if (!freerdp_target_net_adresses_reset(settings, count))
2038 return FALSE;
2039
2040 for (UINT32 i = 0; i < settings->TargetNetAddressCount; i++)
2041 {
2042 const char* address = addresses[i];
2043 if (!freerdp_settings_set_pointer_array(settings, FreeRDP_TargetNetAddresses, i, address))
2044 {
2045 freerdp_target_net_addresses_free(settings);
2046 return FALSE;
2047 }
2048 }
2049
2050 return TRUE;
2051}

◆ freerdp_target_net_addresses_free()

FREERDP_API void freerdp_target_net_addresses_free ( rdpSettings *  settings)

Definition at line 995 of file common/settings.c.

996{
997 WINPR_ASSERT(settings);
998
999 target_net_addresses_free(settings, 0);
1000
1001 free((void*)settings->TargetNetAddresses);
1002 settings->TargetNetAddresses = nullptr;
1003
1004 free(settings->TargetNetPorts);
1005 settings->TargetNetPorts = nullptr;
1006
1007 settings->TargetNetAddressCount = 0;
1008}

◆ freerdp_update_gateway_usage_method()

FREERDP_API void freerdp_update_gateway_usage_method ( rdpSettings *  settings,
UINT32  GatewayEnabled,
UINT32  GatewayBypassLocal 
)

Definition at line 1154 of file common/settings.c.

1156{
1157 UINT32 GatewayUsageMethod = 0;
1158
1159 if (!GatewayEnabled && !GatewayBypassLocal)
1160 GatewayUsageMethod = TSC_PROXY_MODE_NONE_DIRECT;
1161 else if (GatewayEnabled && !GatewayBypassLocal)
1162 GatewayUsageMethod = TSC_PROXY_MODE_DIRECT;
1163 else if (GatewayEnabled && GatewayBypassLocal)
1164 GatewayUsageMethod = TSC_PROXY_MODE_DETECT;
1165
1166 freerdp_set_gateway_usage_method(settings, GatewayUsageMethod);
1167}
BOOL freerdp_set_gateway_usage_method(rdpSettings *settings, UINT32 GatewayUsageMethod)