.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:
bigpjo 2017-02-10 20:38:52 +00:00
parent 842a8c57ec
commit f0a52d431d
3 changed files with 24 additions and 11 deletions

View File

@ -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);

View File

@ -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);

View File

@ -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 */