FreeRDP
TestCommonAssistance.c
1 #include <winpr/crt.h>
2 #include <winpr/print.h>
3 #include <winpr/ssl.h>
4 #include <winpr/wlog.h>
5 #include <winpr/platform.h>
6 
7 #include <freerdp/assistance.h>
8 
9 static const char TEST_MSRC_INCIDENT_PASSWORD_TYPE1[] = "Password1";
10 static const BYTE TEST_MSRC_INCIDENT_PASSWORD_TYPE1_ENC[32] = {
11  0x3c, 0x9c, 0xae, 0xb, 0xce, 0x7a, 0xb1, 0x5c, 0x8a, 0xac, 0x1, 0xd6, 0x76, 0x4, 0x5e, 0xdf,
12  0x3f, 0xfa, 0xf0, 0x92, 0xe2, 0xde, 0x36, 0x8a, 0x20, 0x17, 0xe6, 0x8a, 0xd, 0xed, 0x7c, 0x90
13 };
14 
15 static const char TEST_MSRC_INCIDENT_FILE_TYPE1[] =
16  "<?xml version=\"1.0\" encoding=\"Unicode\" ?>"
17  "<UPLOADINFO TYPE=\"Escalated\">"
18  "<UPLOADDATA "
19  "USERNAME=\"Administrator\" "
20  "RCTICKET=\"65538,1,10.0.3.105:3389;winxpsp3.contoso3.com:3389,*,"
21  "rb+v0oPmEISmi8N2zK/vuhgul/ABqlDt6wW0VxMyxK8=,*,*,IuaRySSbPDNna4+2mKcsKxsbJFI=\""
22  "RCTICKETENCRYPTED=\"1\" "
23  "DtStart=\"1314905741\" "
24  "DtLength=\"180\" "
25  "PassStub=\"RT=0PvIndan52*\" "
26  "L=\"0\" />"
27  "</UPLOADINFO>";
28 
29 WINPR_PRAGMA_DIAG_PUSH
30 WINPR_PRAGMA_DIAG_IGNORED_UNUSED_CONST_VAR
31 static const BYTE TEST_MSRC_INCIDENT_EXPERT_BLOB_TYPE1[32] =
32  "\x3C\x9C\xAE\x0B\xCE\x7A\xB1\x5C\x8A\xAC\x01\xD6\x76\x04\x5E\xDF"
33  "\x3F\xFA\xF0\x92\xE2\xDE\x36\x8A\x20\x17\xE6\x8A\x0D\xED\x7C\x90";
34 WINPR_PRAGMA_DIAG_POP
35 
36 static const char TEST_MSRC_INCIDENT_PASSWORD_TYPE2[] = "48BJQ853X3B4";
37 static const BYTE TEST_MSRC_INCIDENT_PASSWORD_TYPE2_ENC[32] = {
38  0x77, 0x7d, 0xfa, 0xae, 0x90, 0x28, 0x12, 0x4d, 0xd0, 0x2e, 0xde, 0x80, 0x14, 0x22, 0x1b, 0x4a,
39  0xd1, 0xf4, 0xec, 0x13, 0x85, 0x39, 0xd7, 0x33, 0xac, 0x76, 0x78, 0x95, 0xb2, 0xd8, 0x57, 0xd9
40 };
41 
42 static const char TEST_MSRC_INCIDENT_FILE_TYPE2[] =
43  "<?xml version=\"1.0\"?>"
44  "<UPLOADINFO TYPE=\"Escalated\">"
45  "<UPLOADDATA USERNAME=\"awake\" "
46  "LHTICKET=\""
47  "20FCC407AA53E95F8505AB56D485D26835064B03AF86CDA326248FD304626AD4"
48  "DBDBDFFE0C473228EFFF7A1E6CEB445BBEC429294BB6616BBB600854438DDFB5"
49  "82FC377CF65A2060EB3221647643C9B29BF5EC320856180B34D1BE9827A528C7"
50  "E8F0DCD53C8D38F974160FEE317458FAC9DBDBA7B972D21DF3BC5B1AF0E01878"
51  "65F07A3B915618C03E6EAF843FC1185770A1208C29C836DBCA5A040CB276D3C4"
52  "1DDE2FA8CA9627E5E74FA750A92C0E01AD6C3D1000A5B1479DEB899BF5BCD402"
53  "CE3BB3BF104CE0286C3F985AA711943C88C5EEEEE86F35B63F68883A90ADBCFD"
54  "CBBAE3EAB993EFD9148E1A21D092CE9498695943946236D65D20B4A38D724C61"
55  "72319E38E19C04E98EBC03F56A4A190E971F8EAEBFE6B415A3A2D8F35F7BF785"
56  "26B9BFAAB48D11BDD6C905EFE503D2265678E1EAD2F2F124E570667F04103180"
57  "2F63587276C14E6A5AB436CE234F722CE7C9B5D244508F14C012E84A49FE6992"
58  "3F30320ABB3641F1EFA66205F3EA709E7E1C3E6874BB9642486FB96D2730CDF4"
59  "514AA738167F00FC13B2978AED1D6678413FDF62008B03DD729E36173BE02742"
60  "B69CAD44938512D0F56335394759338AF6ADBCF39CE829116D97435085D05BB5"
61  "9320A134698050DCDBE01305A6B4712FD6BD48958BD2DC497498FF35CAECC9A8"
62  "2C97FD1A5B5EC4BAF5FFB75A1471B765C465B35A7C950019066BB219B391C6E9"
63  "8AE8FD2038E774F36F226D9FB9A38BCC313785612165D1EF69D19E2B9CF6E0F7"
64  "FE1ECCF00AB81F9E8B626363CA82FAC719A3B7D243325C9D6042B2488EC95B80"
65  "A31273FF9B72FBBB86F946E6D3DF8816BE4533F0B547C8BC028309EA9784C1E6\" "
66  "RCTICKET=\"65538,1,192.168.1.200:49230;169.254.6.170:49231,*,"
67  "+ULZ6ifjoCa6cGPMLQiGHRPwkg6VyJqGwxMnO6GcelwUh9a6/FBq3It5ADSndmLL,"
68  "*,*,BNRjdu97DyczQSRuMRrDWoue+HA=\" "
69  "PassStub=\"WB^6HsrIaFmEpi\" "
70  "RCTICKETENCRYPTED=\"1\" "
71  "DtStart=\"1403972263\" "
72  "DtLength=\"14400\" "
73  "L=\"0\"/>"
74  "</UPLOADINFO>";
75 
88 static const char connectionstr2[] =
89  "<E>\n"
90  "<A KH=\"YiKwWUY8Ioq5NB3wAQHSbs5kwrM=\"\n"
91  "KH2=\"sha256:wKSAkAV3sBfa9WpuRFJcP9q1twJc6wOBuoJ9tsyXwpk=\"\n"
92  "ID=\"8rYm30RBW8/4dAWoUsWbFCF5jno/7jr5tNpHQc2goLbw4uuBBJvLsU02YYLlBMg5\"/>\n"
93  "<C>\n"
94  "<T ID=\"1\" SID=\"1440550163\">\n"
95  "<L P=\"49749\" N=\"2001:4898:1a:5:79e2:3356:9b22:3470\"/>\n"
96  "<L P=\"49751\" N=\"172.31.250.64\"/>\n"
97  "</T>\n"
98  "</C>\n"
99  "</E>";
100 
101 static const char* fail_tests[] = {
102  "<UPLOADINFOTYPE=\"Escalated\"><UPLOADDATARCTICKET=\"65538,1, ,*,,*,*,\"/></UPLOADINFO>",
103  "<UPLOADINFO>(E><UPLOADDATA "
104  "FOTYPE=\"Escalated\"æÁATAPassStub=\"␕:&A&amp;␅RCTICKET=\"65538,1,ü,*,n,*,*,\"am␡/>␂</"
105  "UPLOADINFO>"
106 };
107 
108 static const char connectionstr3[] =
109  "<?xml version=\"1.0\"?>\n"
110  "<UPLOADINFO TYPE=\"Escalated\"><UPLOADDATA USERNAME=\"fx\" "
111  "LHTICKET="
112  "\"F9BBA098D84E1B20E37CD0983D9336B1FF4929925FCE5F3A1A9B9A596A524F2E169AD26D84255C7E8C0B88304A4C"
113  "40E0544624AD346A6828D6F2091C36C1315BD11255FE631F3A457F862FFD9948C496BC4B705B0AD2F26D0CDF7128E4"
114  "8625C8C501326B33888D42C591434F7ED4BBA0CEE02C8554921E49BCF130E1961F38FD0F0B7333001E639F89471940"
115  "93136CA5030EC4A92D05341488B79C40E11B28E1753F38682816EDF756CF5204943FD3F60DDD16416D220CA162B6FB"
116  "D43CC00C4F9D3F9FCF68ADAF191470B75EA4E8B37D03D2B9D3D844F54597D75FFF0A6216811518A3D06B26CA95F733"
117  "CCE8A46A4B1FF8F514971A1C06A8DC9D1DD0863087707045D3FCB74BB0444AF8B822FD6605DA68D8D628A7D8556212"
118  "D10F5BC4B1B7905E863F51346114FFED6A46D67314F3B933DF17F8A2E5EC6DAD2904349AC710E017652171A98C8621"
119  "4AF3801B1441E641CDA159BE76D8F2415129773283B5A4E0E7483580E6955B54B0E1432129612CFECD6770201F4206"
120  "1732E748B7F8A0C015EA8B36610962AC208C26373A483E830C7E01330492C9CBAB308A5E19272CC06F0F8008068816"
121  "78F8FB32667D876F6060C50D1A1251DDB9B339E2F846F48C0C7751BBDFF2138152B7A048AFECB31F6DE340E81EB8A4"
122  "EC7F8208B81E11E13033659B885686FEDF6881355679DCD96661201E5BC59D6C6EEFA1608B9E73E75F42D51A26E236"
123  "3690714D58A846B48E0AA2C753CA6347BAEA59CDCA5144527F3A69B560980BCC5DB77AC0FD1A68D19F802744D723D8"
124  "6595A48D1F72DAD0E3E61BA4D37E24EAAB9F49F21753CD481D6744036CA49DA0E432B961F48810FE90EB49DB0FB450"
125  "5FB316DCCAAC51E647B333EBA1C219A68F0A08BD65C9E4ED231D40EA15C2CEB80CB161495A0CADECAF2A00B5916AA9"
126  "91B78C7B17F26DA880DE25DFC09D9D823E174A8401CBC846D2A8B29B6B26EE92261C71C37E3C816540F77CB6DE916B"
127  "FCC7ED100949503251687B860E4A5F5B51CDADD11FF5CA408FA38E4A2AD6FA09D10E9B85523236D55132CD42936150"
128  "51913820DAE06877AC2954651049A157730A1AB67BD9A258CCB3A71909A8686F6F742FBC55312B041342C5475F808A"
129  "B04B629B99A1C69200740CDA5FE1602518B3117FB9835060BEF22EBAF20676662C9E0C3ED39C01E2F9A0822A2ADA07"
130  "D4718A93516AA04E4527C699A00FA8AFCAC7337F8D42949B3CB9F35A19BF5AC9BBF412C9E4AE82C593897BFF81240C"
131  "002486DF0F14845BB12A15966E95A9B6090C6512AF8B717F720F0CE452AA602106B65B98374CBCF9F6B5300FB077E5"
132  "554B489F6913E3857E352C94929A69C86EB13A67B872BB69980B9B3A1E05D6B9483C26A0D6D83CCD4C1AB6C21BA625"
133  "A5232C25BC1B7EB8B954B52D91B1BDF4277B2DCE039F4DBE2F18AE22533C2B877AB27B157ACE5DF21BC83E72104A31"
134  "C253704FDB2536308280D7172313F5D19D088E4C7F4F79C4786D6C65DEAB7FC16DE107AF8C61626502FA940497987F"
135  "60759878E40EDFAC98DED90BEA26E3020AA36A7307F2C9A9D5B19FAA34DF3633F643425F16A3615C996691EC705617"
136  "97CEB08463CBD0150F6B4C01BF1337E3B8B5E5355F62AD1AF949FCB3671327EA5AABC90081117E6CE11C6C42CF6E0E"
137  "DCB4C63EA9433D89F1030F65EDC82D45289C6367BF1E004D338CED13B7643C8708C42FF3671377A79DBFE3E4A39E19"
138  "F4759B84AA9CB03D64C2DBF5D2908DE64F5534AC07C11723F3A7602E307625F86B410BC7B54D85145B9F362E181860"
139  "AEF3574682CE4F3C57742870ED0B228CAC0E9183BD07BFF0435989263CA7EBF21B8CF25DBC2C7915FEB1000848A52F"
140  "94E7B34A416A826BFB1792E64F1CEA7FA3222131C53FA6DE38A786C99C355FE9C9D55B91D11B19087F1574CFF28C4D"
141  "AA9DE974A0939F0C13E9C408167ABAB90BD6BB25FA37B1588AAA3687AC86818543FEFD6E46D821D7F68BE1B0793585"
142  "4E7A81F6C9A0965159DAFF7B0E79C89A18DA3C52D6259EA711ED6B85CCC207AA35F62CB5D48299DAD003004702716E"
143  "65A96390033F8006FC7E7B1A09B9D1C6C17EC20811DE09EC19EB36844E45FCA18CF657A81E5922AB1B805721A5457E"
144  "01EB86334877FEDA378EDE6190491015158194ED1DEE3A99770DB8B9A87BC9FAE29A0AC17C4963DF07109B05AABA73"
145  "1A6AACDB8A02795CBDA935D51D0A7ABB35D8D1B6E598751E45BD507EC2778E285BEBAB2B50462FED1975B5A87F9751"
146  "25A6F272560E756CC941CF6D22FE72F7563CB2687E56F2FA2FC07FE01F3C8E6FCF7D4ECD60C1A53B98CA57AFB5BA18"
147  "97D4F530FCDEBDEB015D9CB1DE0BED20B7C3221283E292C252C742C23401B2E5A85EBD63E6916C3051FEAA1DC57975"
148  "410487AD7EE6CA0A346FE44F901E8BA81A7B398E94707E094081AE6391696EC42DD3F4B9189AB2A5311811481A48FB"
149  "0FAEFC1E9858547D15AA2F6FF01191F8EEC3564C59172605DA16C94F466156BE7A3E98E8C53BE50B671DEC5A3BD8A9"
150  "8C2A1B3FF47D27007AB17A4A1E155E094E3EA30FF531FBF6320F23BA57B3CAF8C470E176C93FACEE829C58B2399975"
151  "EBC4688B2F55132D102E83E45976C6607A57B90F43A33BCB68C03671E632B0E7C17B18406161AB46A8A0992DA7046A"
152  "08135E04142B68312BE3D0F7F5BBAE914E8DC5AAD04D992DA18FAB5B01EA34A0E27B253E92BEFE607578B1C79D4DAC"
153  "07DA6F92986F12AE036C227E4495662C46762E66EA3EC71C5C04BADD9DEDCAD725C16710825394179CFD17EDE482BA"
154  "11C421D0B4C806A2ED963831FAB4DE14FEAA904A3C5173AB9B86FCFF81E0F60DB45182A2471BC16DA992553EAE99DD"
155  "716E85DB11AC0F32BC960D6E8F6BE2250D59EDCAA69C19AF04E21362331225F94BD600EE76E1719417480AB6DC62DF"
156  "958DCCE951EBC64B4600DF3A826B9E702C536C0DF9E2952EDA7FAE6076C6F25CF41C0F7751768EC3C3293D727F8541"
157  "E997DA23E2D952D782B0472B3BFBC638CBDFDA43F367E3F6A7AAC9C8B07D51459432AEBB11564A669BF2EC1658B361"
158  "BE29B47F905352D13705E1E7F06B68A5F247B9FFA3B917CC54F7367386502A42F32CEE474F5E4D35CB5A44C3BA2192"
159  "A3F61DC334CE6D91E36D1C891E65A30C1E2B8F66A01B5DA8DDFB5CD051D61BD39B2E0516C6715F9AA7FE262BBD9BA4"
160  "CE8B785B42CA9582AD5EE24F8C11D2DA0DC6383506DE46C5187C03A930E5E507812A505884121C8A93C2569B269AE7"
161  "A26FDCF0BF7FA996250FFF790C3E97565B27C8DECFE5A15E2ED1A853FBF5D12207B8D3564CDD99549E508E92CB53DB"
162  "F6356F6EBF03E6A6672BFDE285A3DF84105F7C7E39577838C06B50D2ABB4F1C0377D45BE016ED022804F6BD9151BCD"
163  "883CE5FE8358798EE4EA3C24C67815D535CBCFA36094D7418EC104F90609C7AC008D07FDF89A6B3A0B5EC505E17DEC"
164  "57DA6256F4B2CC7DFF4E643FE89E4934440E2A360F035FA9C91F0F657A88AC9E7210A9ABAAAEA26D6B717EEAF231FB"
165  "79A0838B4BB85C11C9675F2BC746230F79A88137F911809C472750A5F6BB9415298C638FC3E24FA1763ACB513A4200"
166  "CB0BF550BC7DE0D2DC5D45AF18FF6073D96D2E4368A637B78257D087C9A471CC88E3368E810BFC29002D86C898F75D"
167  "3F6AE13648841038FDD1D3E8C4D2D5A4E1044614CAF544758A68F4947E3A3E736255CF01FE7A40A6FF136E7458F13D"
168  "759086A544FA14B47155511F784A2144E2B139EC5B5F3B0CAB52E511AAF84E00ABB4115644D42B0A7F91DA53F5C54D"
169  "744C583F5E838D402512A9644772E256CACCAA90ED300AE1616FDAA8309E5FB3FD92EB09F32216446CA2E737E8C136"
170  "C3E773FB986060A78D87CDF7CD92B187188CA7293998F0BC33C13A2FD8C7B0A76C2DAA662F0A71965E25930294D351"
171  "947DDE4800A237871F6BBFA77B7440339BFAE36035A84DA6AD87AA57FD52F7CDA342EB3D7B3E46F64592DFF327194C"
172  "D80C83272B5159BD97A9254089C90E1AFC7C30265BA814ED485550E4E4157FEDB14D9FB6D05AEE5983C81E799DF134"
173  "00766571BDBC8AC719AA2228C9DD592C102DE18A3F1C4B3501C6B29424B83B71D1740B1775967CFC984BC2D22C15\""
174  " PassStub=\"e4=3CiFuM6h2qH\" RCTICKETENCRYPTED=\"1\" DtStart=\"1704288424\" DtLength=\"360\" "
175  "L=\"0\"/>"
176  "</UPLOADINFO>";
177 static const char connectionpwd3[] = "4X638PTVZTKZ";
178 static const BYTE connectionpwd3_enc[32] = { 0x15, 0x20, 0x04, 0x96, 0xaf, 0x33, 0xc6, 0xe0,
179  0x1b, 0xbf, 0x4a, 0x15, 0xc9, 0xc1, 0xb8, 0x71,
180  0x44, 0x3f, 0x2e, 0x93, 0xa8, 0x82, 0x35, 0x2b,
181  0x24, 0x08, 0x06, 0x55, 0x16, 0x4e, 0x9d, 0x3b };
182 
183 static BOOL run_test_parse(wLog* log, const char* input, size_t len, const char* password,
184  BOOL expect)
185 {
186  rdpAssistanceFile* file = freerdp_assistance_file_new();
187  if (!file)
188  return FALSE;
189 
190  const int status = freerdp_assistance_parse_file_buffer(file, input, len, password);
191  const BOOL success = status >= 0;
192 
193  freerdp_assistance_print_file(file, log, WLOG_INFO);
194  freerdp_assistance_file_free(file);
195  return success == expect;
196 }
197 
198 static BOOL test_file_to_settings(wLog* log, rdpAssistanceFile* file)
199 {
200  rdpSettings* settings = freerdp_settings_new(0);
201  if (!settings)
202  return FALSE;
203  const BOOL rc = freerdp_assistance_populate_settings_from_assistance_file(file, settings);
204  freerdp_settings_free(settings);
205  return rc;
206 }
207 
208 static BOOL test_file_from_buffer(wLog* log, const char* data, size_t size, const char* pwd,
209  const BYTE* enc, size_t encsize)
210 {
211  BOOL rc = FALSE;
212  int status = 0;
213  char* pass = NULL;
214  char* expertBlob = NULL;
215  const char* EncryptedPassStub = NULL;
216  size_t EncryptedPassStubLength = 0;
217  rdpAssistanceFile* file = freerdp_assistance_file_new();
218 
219  if (!file)
220  return FALSE;
221 
222  status = freerdp_assistance_parse_file_buffer(file, data, size, pwd);
223  WLog_Print(log, WLOG_INFO, "freerdp_assistance_parse_file_buffer: %d", status);
224 
225  if (status < 0)
226  goto fail;
227 
228  freerdp_assistance_print_file(file, WLog_Get("foo"), WLOG_INFO);
229 
230  if (!freerdp_assistance_get_encrypted_pass_stub(file, &EncryptedPassStub,
231  &EncryptedPassStubLength))
232  goto fail;
233 
234  if (EncryptedPassStubLength > 0)
235  {
236  pass = freerdp_assistance_bin_to_hex_string(EncryptedPassStub, EncryptedPassStubLength);
237 
238  if (!pass)
239  goto fail;
240 
241  WLog_Print(log, WLOG_INFO, "freerdp_assistance_decrypt: %d %s [%" PRIdz "]", status, pass,
242  EncryptedPassStubLength);
243  expertBlob = freerdp_assistance_construct_expert_blob("Edgar Olougouna", pass);
244 
245  WLog_Print(log, WLOG_INFO, "expertBlob='%s'", expertBlob);
246  }
247  if (encsize != EncryptedPassStubLength)
248  goto fail;
249  if (encsize > 0)
250  {
251  if (memcmp(EncryptedPassStub, enc, encsize) != 0)
252  goto fail;
253  }
254 
255  rc = test_file_to_settings(log, file);
256 fail:
257  freerdp_assistance_file_free(file);
258  free(pass);
259  free(expertBlob);
260  return rc;
261 }
262 
263 static BOOL test_msrsc_incident_file_type1(wLog* log)
264 {
265  return test_file_from_buffer(
266  log, TEST_MSRC_INCIDENT_FILE_TYPE1, sizeof(TEST_MSRC_INCIDENT_FILE_TYPE1),
267  TEST_MSRC_INCIDENT_PASSWORD_TYPE1, TEST_MSRC_INCIDENT_PASSWORD_TYPE1_ENC,
268  sizeof(TEST_MSRC_INCIDENT_PASSWORD_TYPE1_ENC));
269 }
270 
271 static BOOL test_msrsc_incident_file_type2(wLog* log)
272 {
273  if (!test_file_from_buffer(log, connectionstr2, sizeof(connectionstr2),
274  TEST_MSRC_INCIDENT_PASSWORD_TYPE2, NULL, 0))
275  return FALSE;
276  if (!test_file_from_buffer(log, connectionstr3, sizeof(connectionstr3), connectionpwd3,
277  connectionpwd3_enc, sizeof(connectionpwd3_enc)))
278  return FALSE;
279  if (!test_file_from_buffer(
280  log, TEST_MSRC_INCIDENT_FILE_TYPE2, sizeof(TEST_MSRC_INCIDENT_FILE_TYPE2),
281  TEST_MSRC_INCIDENT_PASSWORD_TYPE2, TEST_MSRC_INCIDENT_PASSWORD_TYPE2_ENC,
282  sizeof(TEST_MSRC_INCIDENT_PASSWORD_TYPE2_ENC)))
283  return FALSE;
284  return TRUE;
285 }
286 
287 int TestCommonAssistance(int argc, char* argv[])
288 {
289  wLog* log = NULL;
290  WINPR_UNUSED(argc);
291  WINPR_UNUSED(argv);
292  log = WLog_Get(__func__);
293  winpr_InitializeSSL(WINPR_SSL_INIT_DEFAULT);
294 
295  for (size_t x = 0; x < ARRAYSIZE(fail_tests); x++)
296  {
297  const char* test = fail_tests[x];
298  const size_t len = strlen(test);
299 
300  if (!run_test_parse(log, test, len + 1, NULL, FALSE))
301  return -1;
302  }
303 
304  if (!test_msrsc_incident_file_type1(log))
305  {
306  WLog_Print(log, WLOG_ERROR, "test_msrsc_incident_file_type1 failed");
307  return -1;
308  }
309 
310  if (!test_msrsc_incident_file_type2(log))
311  {
312  WLog_Print(log, WLOG_ERROR, "test_msrsc_incident_file_type2 failed");
313  return -1;
314  }
315 
316  return 0;
317 }
FREERDP_API rdpSettings * freerdp_settings_new(DWORD flags)
creates a new setting struct
FREERDP_API void freerdp_settings_free(rdpSettings *settings)
Free a settings struct with all data in it.