.RDP Password Attribute
Allow password to be stored in .RDP file and parsed and settings updated, this will allow for dynamic .RDP files to be created with complete login credentials, using this method the username, server and password will no longer be visible within process lists. Also fixed issue of username and domain being read from .RDP files and set to null by command line processor.
This commit is contained in:
parent
842a8c57ec
commit
f0a52d431d
@ -2513,20 +2513,22 @@ int freerdp_client_settings_parse_command_line_arguments(rdpSettings* settings,
|
|||||||
}
|
}
|
||||||
while ((arg = CommandLineFindNextArgumentA(arg)) != NULL);
|
while ((arg = CommandLineFindNextArgumentA(arg)) != NULL);
|
||||||
|
|
||||||
|
if (!settings->Username && user)
|
||||||
|
{
|
||||||
free(settings->Username);
|
free(settings->Username);
|
||||||
|
|
||||||
if (!settings->Domain && user)
|
if (!settings->Domain && user)
|
||||||
{
|
{
|
||||||
BOOL ret;
|
BOOL ret;
|
||||||
free(settings->Domain);
|
free(settings->Domain);
|
||||||
|
|
||||||
ret = freerdp_parse_username(user, &settings->Username, &settings->Domain);
|
ret = freerdp_parse_username(user, &settings->Username, &settings->Domain);
|
||||||
free(user);
|
free(user);
|
||||||
|
|
||||||
if (!ret)
|
if (!ret)
|
||||||
return COMMAND_LINE_ERROR;
|
return COMMAND_LINE_ERROR;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
settings->Username = user;
|
settings->Username = user;
|
||||||
|
}
|
||||||
|
|
||||||
free(settings->GatewayUsername);
|
free(settings->GatewayUsername);
|
||||||
|
|
||||||
|
@ -284,6 +284,8 @@ static int freerdp_client_rdp_file_set_string(rdpFile* file, const char* name, c
|
|||||||
tmp = &file->Username;
|
tmp = &file->Username;
|
||||||
else if (_stricmp(name, "domain") == 0)
|
else if (_stricmp(name, "domain") == 0)
|
||||||
tmp = &file->Domain;
|
tmp = &file->Domain;
|
||||||
|
else if (_stricmp(name, "password") == 0)
|
||||||
|
tmp = &file->Password;
|
||||||
else if (_stricmp(name, "full address") == 0)
|
else if (_stricmp(name, "full address") == 0)
|
||||||
tmp = &file->FullAddress;
|
tmp = &file->FullAddress;
|
||||||
else if (_stricmp(name, "alternate full address") == 0)
|
else if (_stricmp(name, "alternate full address") == 0)
|
||||||
@ -725,6 +727,7 @@ BOOL freerdp_client_populate_rdp_file_from_settings(rdpFile* file, const rdpSett
|
|||||||
{
|
{
|
||||||
SETTING_MODIFIED_SET_STRING(file->Domain, settings, Domain);
|
SETTING_MODIFIED_SET_STRING(file->Domain, settings, Domain);
|
||||||
SETTING_MODIFIED_SET_STRING(file->Username, settings, Username);
|
SETTING_MODIFIED_SET_STRING(file->Username, settings, Username);
|
||||||
|
SETTING_MODIFIED_SET_STRING(file->Password, settings, Password);
|
||||||
SETTING_MODIFIED_SET(file->ServerPort, settings, ServerPort);
|
SETTING_MODIFIED_SET(file->ServerPort, settings, ServerPort);
|
||||||
SETTING_MODIFIED_SET_STRING(file->FullAddress, settings, ServerHostname);
|
SETTING_MODIFIED_SET_STRING(file->FullAddress, settings, ServerHostname);
|
||||||
SETTING_MODIFIED_SET(file->DesktopWidth, settings, DesktopWidth);
|
SETTING_MODIFIED_SET(file->DesktopWidth, settings, DesktopWidth);
|
||||||
@ -895,6 +898,12 @@ BOOL freerdp_client_populate_settings_from_rdp_file(rdpFile* file, rdpSettings*
|
|||||||
free(domain);
|
free(domain);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (~((size_t)file->Password))
|
||||||
|
{
|
||||||
|
if (freerdp_set_param_string(settings, FreeRDP_Password, file->Password) != 0)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
if (~((size_t) file->FullAddress))
|
if (~((size_t) file->FullAddress))
|
||||||
{
|
{
|
||||||
int port = -1;
|
int port = -1;
|
||||||
@ -1423,6 +1432,7 @@ void freerdp_client_rdp_file_free(rdpFile* file)
|
|||||||
|
|
||||||
freerdp_client_file_string_check_free(file->Username);
|
freerdp_client_file_string_check_free(file->Username);
|
||||||
freerdp_client_file_string_check_free(file->Domain);
|
freerdp_client_file_string_check_free(file->Domain);
|
||||||
|
freerdp_client_file_string_check_free(file->Password);
|
||||||
freerdp_client_file_string_check_free(file->FullAddress);
|
freerdp_client_file_string_check_free(file->FullAddress);
|
||||||
freerdp_client_file_string_check_free(file->AlternateFullAddress);
|
freerdp_client_file_string_check_free(file->AlternateFullAddress);
|
||||||
freerdp_client_file_string_check_free(file->UsbDevicesToRedirect);
|
freerdp_client_file_string_check_free(file->UsbDevicesToRedirect);
|
||||||
|
@ -89,6 +89,7 @@ struct rdp_file
|
|||||||
|
|
||||||
LPSTR Username; /* username */
|
LPSTR Username; /* username */
|
||||||
LPSTR Domain; /* domain */
|
LPSTR Domain; /* domain */
|
||||||
|
LPSTR Password; /*password*/
|
||||||
PBYTE Password51; /* password 51 */
|
PBYTE Password51; /* password 51 */
|
||||||
|
|
||||||
LPSTR FullAddress; /* full address */
|
LPSTR FullAddress; /* full address */
|
||||||
|
Loading…
Reference in New Issue
Block a user