X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=sbr%2Fmts.c;h=dd193bc4e53a30a59b6d7479fcb1a965a8c8c4c6;hb=ca1023716d4c2ab890696f3e41fa0d94267a940e;hp=6b8b3a2cd9fe85b2294bc8465a2b5e3b89fa32bf;hpb=d3540eaa4251b3a282115a72ed5d1bb39ce74b3f;p=mmh diff --git a/sbr/mts.c b/sbr/mts.c index 6b8b3a2..dd193bc 100644 --- a/sbr/mts.c +++ b/sbr/mts.c @@ -11,7 +11,6 @@ #include #include #include -#include #include #include @@ -132,16 +131,17 @@ getfullname(void) static void getuserinfo(void) { - register unsigned char *cp; - register char *np; - register struct passwd *pw; - - if ((pw = getpwuid(getuid())) == NULL - || pw->pw_name == NULL - || *pw->pw_name == '\0') { + unsigned char *cp; + char *np; + struct passwd *pw; + int needquotes = 0; + char tmp[BUFSIZ]; + char *tp; + + if (!(pw = getpwuid(getuid())) || !pw->pw_name || !*pw->pw_name) { strncpy(username, "unknown", sizeof(username)); - snprintf(fullname, sizeof(fullname), "The Unknown User-ID (%d)", - (int) getuid()); + snprintf(fullname, sizeof(fullname), + "The Unknown User-ID (%d)", (int)getuid()); return; } @@ -152,7 +152,7 @@ getuserinfo(void) ** we hit a ',', which some OSes use to separate other 'finger' ** information in the GECOS field, like phone number. */ - for (cp = fullname; *np != '\0' && *np != ',';) { + for (cp = tmp; *np != '\0' && *np != ',';) { #ifndef BSD42 *cp++ = *np++; #else /* BSD42 */ @@ -185,15 +185,36 @@ getuserinfo(void) ** idea of your real name. */ if ((cp = getenv("SIGNATURE")) && *cp) - strncpy(fullname, cp, sizeof(fullname)); - - if (strchr(fullname, '.')) { /* quote any .'s */ - char tmp[BUFSIZ]; - - /* should quote "'s too */ - snprintf(tmp, sizeof(tmp), "\"%s\"", fullname); - strncpy(fullname, tmp, sizeof(fullname)); + strncpy(tmp, cp, sizeof(tmp)); + + /* quote the fullname as needed */ + needquotes = 0; + for (tp=tmp; *tp; tp++) { + switch (*tp) { + case '(': case ')': case '<': case '>': case '[': case ']': + case ':': case ';': case '@': case '\\': case ',': case '.': + case '"': /* cf. RFC 5322 */ + break; /* ... the switch */ + default: + continue; /* ... the loop */ + } + /* we've found a special char */ + needquotes = 1; + break; + } + cp=fullname; + if (needquotes) { + *cp++ = '"'; } + for (tp=tmp; *tp; *cp++=*tp++) { + if (*tp == '"') { + *cp++ = '\\'; /* prepend backslash */ + } + } + if (needquotes) { + *cp++ = '"'; + } + *cp = '\0'; return; }