/[rdesktop]/sourceforge.net/trunk/rdesktop/rdesktop.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /sourceforge.net/trunk/rdesktop/rdesktop.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 213 by matthewc, Sun Oct 6 13:30:30 2002 UTC revision 262 by astrand, Mon Nov 18 15:37:20 2002 UTC
# Line 29  Line 29 
29  #include <sys/times.h>          /* times */  #include <sys/times.h>          /* times */
30  #include "rdesktop.h"  #include "rdesktop.h"
31    
32    #ifdef EGD_SOCKET
33    #include <sys/socket.h>         /* socket connect */
34    #include <sys/un.h>             /* sockaddr_un */
35    #endif
36    
37    #ifdef WITH_OPENSSL
38    #include <openssl/md5.h>
39    #else
40    #include "crypto/md5.h"
41    #endif
42    
43  char title[32] = "";  char title[32] = "";
44  char username[16];  char username[16];
45  char hostname[16];  char hostname[16];
# Line 40  int tcp_port_rdp = TCP_PORT_RDP; Line 51  int tcp_port_rdp = TCP_PORT_RDP;
51  BOOL bitmap_compression = True;  BOOL bitmap_compression = True;
52  BOOL sendmotion = True;  BOOL sendmotion = True;
53  BOOL orders = True;  BOOL orders = True;
 BOOL licence = True;  
54  BOOL encryption = True;  BOOL encryption = True;
55  BOOL desktop_save = True;  BOOL desktop_save = True;
56  BOOL fullscreen = False;  BOOL fullscreen = False;
57  BOOL grab_keyboard = True;  BOOL grab_keyboard = True;
58    BOOL hide_decorations = False;
59    
60  /* Display usage information */  /* Display usage information */
61  static void  static void
# Line 54  usage(char *program) Line 65  usage(char *program)
65          fprintf(stderr, "Version " VERSION ". Copyright (C) 1999-2002 Matt Chapman.\n");          fprintf(stderr, "Version " VERSION ". Copyright (C) 1999-2002 Matt Chapman.\n");
66          fprintf(stderr, "See http://www.rdesktop.org/ for more information.\n\n");          fprintf(stderr, "See http://www.rdesktop.org/ for more information.\n\n");
67    
68          fprintf(stderr, "Usage: %s [options] server\n", program);          fprintf(stderr, "Usage: %s [options] server[:port]\n", program);
69          fprintf(stderr, "   -u: user name\n");          fprintf(stderr, "   -u: user name\n");
70          fprintf(stderr, "   -d: domain\n");          fprintf(stderr, "   -d: domain\n");
71          fprintf(stderr, "   -s: shell\n");          fprintf(stderr, "   -s: shell\n");
72          fprintf(stderr, "   -c: working directory\n");          fprintf(stderr, "   -c: working directory\n");
73          fprintf(stderr, "   -p: password (- to prompt)\n");          fprintf(stderr, "   -p: password (- to prompt)\n");
74          fprintf(stderr, "   -n: client hostname\n");          fprintf(stderr, "   -n: client hostname\n");
75          fprintf(stderr, "   -k: keyboard layout on terminal server (us,sv,gr etc.)\n");          fprintf(stderr, "   -k: keyboard layout on terminal server (us,sv,gr,etc.)\n");
76          fprintf(stderr, "   -g: desktop geometry (WxH)\n");          fprintf(stderr, "   -g: desktop geometry (WxH)\n");
77          fprintf(stderr, "   -f: full-screen mode\n");          fprintf(stderr, "   -f: full-screen mode\n");
78          fprintf(stderr, "   -b: force bitmap updates\n");          fprintf(stderr, "   -b: force bitmap updates\n");
79          fprintf(stderr, "   -e: disable encryption (French TS)\n");          fprintf(stderr, "   -e: disable encryption (French TS)\n");
80          fprintf(stderr, "   -m: do not send motion events\n");          fprintf(stderr, "   -m: do not send motion events\n");
         fprintf(stderr, "   -l: do not request licence\n");  
         fprintf(stderr, "   -t: rdp tcp port\n");  
81          fprintf(stderr, "   -K: keep window manager key bindings\n");          fprintf(stderr, "   -K: keep window manager key bindings\n");
82          fprintf(stderr, "   -w: window title\n");          fprintf(stderr, "   -T: window title\n");
83            fprintf(stderr, "   -D: hide window manager decorations\n");
84  }  }
85    
86  static BOOL  static BOOL
# Line 113  read_password(char *password, int size) Line 123  read_password(char *password, int size)
123  int  int
124  main(int argc, char *argv[])  main(int argc, char *argv[])
125  {  {
126            char server[64];
127          char fullhostname[64];          char fullhostname[64];
128          char domain[16];          char domain[16];
129          char password[16];          char password[16];
130          char shell[32];          char shell[128];
131          char directory[32];          char directory[32];
132          BOOL prompt_password;          BOOL prompt_password;
133          struct passwd *pw;          struct passwd *pw;
         char *server, *p;  
134          uint32 flags;          uint32 flags;
135            char *p;
136          int c;          int c;
137    
138          flags = RDP_LOGON_NORMAL;          flags = RDP_LOGON_NORMAL;
139          prompt_password = False;          prompt_password = False;
140          domain[0] = password[0] = shell[0] = directory[0] = 0;          domain[0] = password[0] = shell[0] = directory[0] = 0;
141          strcpy(keymapname, "us");          strcpy(keymapname, "en-us");
142    
143          while ((c = getopt(argc, argv, "u:d:s:c:p:n:k:g:t:fbemlKw:h?")) != -1)          while ((c = getopt(argc, argv, "u:d:s:c:p:n:k:g:fbemKT:Dh?")) != -1)
144          {          {
145                  switch (c)                  switch (c)
146                  {                  {
# Line 201  main(int argc, char *argv[]) Line 212  main(int argc, char *argv[])
212                                  sendmotion = False;                                  sendmotion = False;
213                                  break;                                  break;
214    
                         case 'l':  
                                 licence = False;  
                                 break;  
   
                         case 't':  
                                 tcp_port_rdp = strtol(optarg, NULL, 10);  
                                 break;  
   
215                          case 'K':                          case 'K':
216                                  grab_keyboard = False;                                  grab_keyboard = False;
217                                  break;                                  break;
218    
219                          case 'w':                          case 'T':
220                                  strncpy(title, optarg, sizeof(title));                                  STRNCPY(title, optarg, sizeof(title));
221                                    break;
222    
223                            case 'D':
224                                    hide_decorations = True;
225                                  break;                                  break;
226    
227                          case 'h':                          case 'h':
# Line 231  main(int argc, char *argv[]) Line 238  main(int argc, char *argv[])
238                  return 1;                  return 1;
239          }          }
240    
241          server = argv[optind];          STRNCPY(server, argv[optind], sizeof(server));
242            p = strchr(server, ':');
243            if (p != NULL)
244            {
245                    tcp_port_rdp = strtol(p + 1, NULL, 10);
246                    *p = 0;
247            }
248    
249          if (username[0] == 0)          if (username[0] == 0)
250          {          {
# Line 290  main(int argc, char *argv[]) Line 303  main(int argc, char *argv[])
303          return 0;          return 0;
304  }  }
305    
306    #ifdef EGD_SOCKET
307    /* Read 32 random bytes from PRNGD or EGD socket (based on OpenSSL RAND_egd) */
308    static BOOL
309    generate_random_egd(uint8 * buf)
310    {
311            struct sockaddr_un addr;
312            BOOL ret = False;
313            int fd;
314    
315            fd = socket(AF_UNIX, SOCK_STREAM, 0);
316            if (fd == -1)
317                    return False;
318    
319            addr.sun_family = AF_UNIX;
320            memcpy(addr.sun_path, EGD_SOCKET, sizeof(EGD_SOCKET));
321            if (connect(fd, (struct sockaddr *) &addr, sizeof(addr)) == -1)
322                    goto err;
323    
324            /* PRNGD and EGD use a simple communications protocol */
325            buf[0] = 1;             /* Non-blocking (similar to /dev/urandom) */
326            buf[1] = 32;            /* Number of requested random bytes */
327            if (write(fd, buf, 2) != 2)
328                    goto err;
329    
330            if ((read(fd, buf, 1) != 1) || (buf[0] == 0))   /* Available? */
331                    goto err;
332    
333            if (read(fd, buf, 32) != 32)
334                    goto err;
335    
336            ret = True;
337    
338          err:
339            close(fd);
340            return ret;
341    }
342    #endif
343    
344  /* Generate a 32-byte random for the secure transport code. */  /* Generate a 32-byte random for the secure transport code. */
345  void  void
346  generate_random(uint8 * random)  generate_random(uint8 * random)
347  {  {
348          struct stat st;          struct stat st;
349          struct tms tmsbuf;          struct tms tmsbuf;
350          uint32 *r = (uint32 *) random;          MD5_CTX md5;
351          int fd;          uint32 *r;
352            int fd, n;
353    
354          /* If we have a kernel random device, use it. */          /* If we have a kernel random device, try that first */
355          if (((fd = open("/dev/urandom", O_RDONLY)) != -1)          if (((fd = open("/dev/urandom", O_RDONLY)) != -1)
356              || ((fd = open("/dev/random", O_RDONLY)) != -1))              || ((fd = open("/dev/random", O_RDONLY)) != -1))
357          {          {
358                  read(fd, random, 32);                  n = read(fd, random, 32);
359                  close(fd);                  close(fd);
360                  return;                  if (n == 32)
361                            return;
362          }          }
363    
364    #ifdef EGD_SOCKET
365            /* As a second preference use an EGD */
366            if (generate_random_egd(random))
367                    return;
368    #endif
369    
370          /* Otherwise use whatever entropy we can gather - ideas welcome. */          /* Otherwise use whatever entropy we can gather - ideas welcome. */
371            r = (uint32 *) random;
372          r[0] = (getpid()) | (getppid() << 16);          r[0] = (getpid()) | (getppid() << 16);
373          r[1] = (getuid()) | (getgid() << 16);          r[1] = (getuid()) | (getgid() << 16);
374          r[2] = times(&tmsbuf);  /* system uptime (clocks) */          r[2] = times(&tmsbuf);  /* system uptime (clocks) */
# Line 317  generate_random(uint8 * random) Line 377  generate_random(uint8 * random)
377          r[5] = st.st_atime;          r[5] = st.st_atime;
378          r[6] = st.st_mtime;          r[6] = st.st_mtime;
379          r[7] = st.st_ctime;          r[7] = st.st_ctime;
380    
381            /* Hash both halves with MD5 to obscure possible patterns */
382            MD5_Init(&md5);
383            MD5_Update(&md5, random, 16);
384            MD5_Final(random, &md5);
385            MD5_Update(&md5, random + 16, 16);
386            MD5_Final(random + 16, &md5);
387  }  }
388    
389  /* malloc; exit if out of memory */  /* malloc; exit if out of memory */

Legend:
Removed from v.213  
changed lines
  Added in v.262

  ViewVC Help
Powered by ViewVC 1.1.26