[BACK]Return to auth-options.c CVS log [TXT][DIR] Up to [local] / src / usr.bin / ssh

Diff for /src/usr.bin/ssh/auth-options.c between version 1.21 and 1.22

version 1.21, 2002/01/29 14:32:03 version 1.22, 2002/03/18 17:50:31
Line 20 
Line 20 
 #include "channels.h"  #include "channels.h"
 #include "auth-options.h"  #include "auth-options.h"
 #include "servconf.h"  #include "servconf.h"
   #include "bufaux.h"
 #include "misc.h"  #include "misc.h"
   #include "monitor_wrap.h"
   
   /* Debugging messages */
   Buffer auth_debug;
   int auth_debug_init;
   
 /* Flags set authorized_keys flags */  /* Flags set authorized_keys flags */
 int no_port_forwarding_flag = 0;  int no_port_forwarding_flag = 0;
 int no_agent_forwarding_flag = 0;  int no_agent_forwarding_flag = 0;
Line 37 
Line 43 
 extern ServerOptions options;  extern ServerOptions options;
   
 void  void
   auth_send_debug(Buffer *m)
   {
           char *msg;
   
           while (buffer_len(m)) {
                   msg = buffer_get_string(m, NULL);
                   packet_send_debug("%s", msg);
                   xfree(msg);
           }
   }
   
   void
 auth_clear_options(void)  auth_clear_options(void)
 {  {
           if (auth_debug_init)
                   buffer_clear(&auth_debug);
           else {
                   buffer_init(&auth_debug);
                   auth_debug_init = 1;
           }
   
         no_agent_forwarding_flag = 0;          no_agent_forwarding_flag = 0;
         no_port_forwarding_flag = 0;          no_port_forwarding_flag = 0;
         no_pty_flag = 0;          no_pty_flag = 0;
Line 63 
Line 88 
 int  int
 auth_parse_options(struct passwd *pw, char *opts, char *file, u_long linenum)  auth_parse_options(struct passwd *pw, char *opts, char *file, u_long linenum)
 {  {
           char tmp[1024];
         const char *cp;          const char *cp;
         int i;          int i;
   
Line 75 
Line 101 
         while (*opts && *opts != ' ' && *opts != '\t') {          while (*opts && *opts != ' ' && *opts != '\t') {
                 cp = "no-port-forwarding";                  cp = "no-port-forwarding";
                 if (strncasecmp(opts, cp, strlen(cp)) == 0) {                  if (strncasecmp(opts, cp, strlen(cp)) == 0) {
                         packet_send_debug("Port forwarding disabled.");                          snprintf(tmp, sizeof(tmp), "Port forwarding disabled.");
                           buffer_put_cstring(&auth_debug, tmp);
                         no_port_forwarding_flag = 1;                          no_port_forwarding_flag = 1;
                         opts += strlen(cp);                          opts += strlen(cp);
                         goto next_option;                          goto next_option;
                 }                  }
                 cp = "no-agent-forwarding";                  cp = "no-agent-forwarding";
                 if (strncasecmp(opts, cp, strlen(cp)) == 0) {                  if (strncasecmp(opts, cp, strlen(cp)) == 0) {
                         packet_send_debug("Agent forwarding disabled.");                          snprintf(tmp, sizeof(tmp), "Agent forwarding disabled.");
                           buffer_put_cstring(&auth_debug, tmp);
                         no_agent_forwarding_flag = 1;                          no_agent_forwarding_flag = 1;
                         opts += strlen(cp);                          opts += strlen(cp);
                         goto next_option;                          goto next_option;
                 }                  }
                 cp = "no-X11-forwarding";                  cp = "no-X11-forwarding";
                 if (strncasecmp(opts, cp, strlen(cp)) == 0) {                  if (strncasecmp(opts, cp, strlen(cp)) == 0) {
                         packet_send_debug("X11 forwarding disabled.");                          snprintf(tmp, sizeof(tmp), "X11 forwarding disabled.");
                           buffer_put_cstring(&auth_debug, tmp);
                         no_x11_forwarding_flag = 1;                          no_x11_forwarding_flag = 1;
                         opts += strlen(cp);                          opts += strlen(cp);
                         goto next_option;                          goto next_option;
                 }                  }
                 cp = "no-pty";                  cp = "no-pty";
                 if (strncasecmp(opts, cp, strlen(cp)) == 0) {                  if (strncasecmp(opts, cp, strlen(cp)) == 0) {
                         packet_send_debug("Pty allocation disabled.");                          snprintf(tmp, sizeof(tmp), "Pty allocation disabled.");
                           buffer_put_cstring(&auth_debug, tmp);
                         no_pty_flag = 1;                          no_pty_flag = 1;
                         opts += strlen(cp);                          opts += strlen(cp);
                         goto next_option;                          goto next_option;
Line 119 
Line 149 
                         if (!*opts) {                          if (!*opts) {
                                 debug("%.100s, line %lu: missing end quote",                                  debug("%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                 packet_send_debug("%.100s, line %lu: missing end quote",                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(forced_command);                                  xfree(forced_command);
                                 forced_command = NULL;                                  forced_command = NULL;
                                 goto bad_option;                                  goto bad_option;
                         }                          }
                         forced_command[i] = 0;                          forced_command[i] = 0;
                         packet_send_debug("Forced command: %.900s", forced_command);                          snprintf(tmp, sizeof(tmp), "Forced command: %.900s", forced_command);
                           buffer_put_cstring(&auth_debug, tmp);
                         opts++;                          opts++;
                         goto next_option;                          goto next_option;
                 }                  }
Line 151 
Line 183 
                         if (!*opts) {                          if (!*opts) {
                                 debug("%.100s, line %lu: missing end quote",                                  debug("%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                 packet_send_debug("%.100s, line %lu: missing end quote",                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(s);                                  xfree(s);
                                 goto bad_option;                                  goto bad_option;
                         }                          }
                         s[i] = 0;                          s[i] = 0;
                         packet_send_debug("Adding to environment: %.900s", s);                          snprintf(tmp, sizeof(tmp), "Adding to environment: %.900s", s);
                           buffer_put_cstring(&auth_debug, tmp);
                         debug("Adding to environment: %.900s", s);                          debug("Adding to environment: %.900s", s);
                         opts++;                          opts++;
                         new_envstring = xmalloc(sizeof(struct envstring));                          new_envstring = xmalloc(sizeof(struct envstring));
Line 188 
Line 222 
                         if (!*opts) {                          if (!*opts) {
                                 debug("%.100s, line %lu: missing end quote",                                  debug("%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                 packet_send_debug("%.100s, line %lu: missing end quote",                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(patterns);                                  xfree(patterns);
                                 goto bad_option;                                  goto bad_option;
                         }                          }
Line 202 
Line 237 
                                     "correct key but not from a permitted "                                      "correct key but not from a permitted "
                                     "host (host=%.200s, ip=%.200s).",                                      "host (host=%.200s, ip=%.200s).",
                                     pw->pw_name, remote_host, remote_ip);                                      pw->pw_name, remote_host, remote_ip);
                                 packet_send_debug("Your host '%.200s' is not "                                  snprintf(tmp, sizeof(tmp),
                                       "Your host '%.200s' is not "
                                     "permitted to use this key for login.",                                      "permitted to use this key for login.",
                                     remote_host);                                      remote_host);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 /* deny access */                                  /* deny access */
                                 return 0;                                  return 0;
                         }                          }
Line 233 
Line 270 
                         if (!*opts) {                          if (!*opts) {
                                 debug("%.100s, line %lu: missing end quote",                                  debug("%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                 packet_send_debug("%.100s, line %lu: missing end quote",                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: missing end quote",
                                     file, linenum);                                      file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(patterns);                                  xfree(patterns);
                                 goto bad_option;                                  goto bad_option;
                         }                          }
Line 244 
Line 282 
                             sscanf(patterns, "%255[^/]/%5[0-9]", host, sport) != 2) {                              sscanf(patterns, "%255[^/]/%5[0-9]", host, sport) != 2) {
                                 debug("%.100s, line %lu: Bad permitopen specification "                                  debug("%.100s, line %lu: Bad permitopen specification "
                                     "<%.100s>", file, linenum, patterns);                                      "<%.100s>", file, linenum, patterns);
                                 packet_send_debug("%.100s, line %lu: "                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: "
                                     "Bad permitopen specification", file, linenum);                                      "Bad permitopen specification", file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(patterns);                                  xfree(patterns);
                                 goto bad_option;                                  goto bad_option;
                         }                          }
                         if ((port = a2port(sport)) == 0) {                          if ((port = a2port(sport)) == 0) {
                                 debug("%.100s, line %lu: Bad permitopen port <%.100s>",                                  debug("%.100s, line %lu: Bad permitopen port <%.100s>",
                                     file, linenum, sport);                                      file, linenum, sport);
                                 packet_send_debug("%.100s, line %lu: "                                  snprintf(tmp, sizeof(tmp), "%.100s, line %lu: "
                                     "Bad permitopen port", file, linenum);                                      "Bad permitopen port", file, linenum);
                                   buffer_put_cstring(&auth_debug, tmp);
                                 xfree(patterns);                                  xfree(patterns);
                                 goto bad_option;                                  goto bad_option;
                         }                          }
Line 276 
Line 316 
                 opts++;                  opts++;
                 /* Process the next option. */                  /* Process the next option. */
         }          }
   
           if (!use_privsep)
                   auth_send_debug(&auth_debug);
   
         /* grant access */          /* grant access */
         return 1;          return 1;
   
 bad_option:  bad_option:
         log("Bad options in %.100s file, line %lu: %.50s",          log("Bad options in %.100s file, line %lu: %.50s",
             file, linenum, opts);              file, linenum, opts);
         packet_send_debug("Bad options in %.100s file, line %lu: %.50s",          snprintf(tmp, sizeof(tmp),
               "Bad options in %.100s file, line %lu: %.50s",
             file, linenum, opts);              file, linenum, opts);
           buffer_put_cstring(&auth_debug, tmp);
   
           if (!use_privsep)
                   auth_send_debug(&auth_debug);
   
         /* deny access */          /* deny access */
         return 0;          return 0;
 }  }

Legend:
Removed from v.1.21  
changed lines
  Added in v.1.22