1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- pppd: Implement option to strip domain part from MS CHAP response
- This patch implements a new boolean option "chapms-strip-domain" which
- strips the leading domain part of the username in a received MS Chap
- response.
- When the option is set, all leading chars up to and including the last
- backslash in the username are stripped. The option defaults to false.
- The patch originated from the Debian project.
- Signed-off-by: Jo-Philipp Wich <jow@openwrt.org>
- --- a/pppd/chap-new.c
- +++ b/pppd/chap-new.c
- @@ -58,6 +58,7 @@ int (*chap_verify_hook)(char *name, char
- int chap_timeout_time = 3;
- int chap_max_transmits = 10;
- int chap_rechallenge_time = 0;
- +int chapms_strip_domain = 0;
-
- /*
- * Command-line options.
- @@ -69,6 +70,8 @@ static option_t chap_option_list[] = {
- "Set max #xmits for challenge", OPT_PRIO },
- { "chap-interval", o_int, &chap_rechallenge_time,
- "Set interval for rechallenge", OPT_PRIO },
- + { "chapms-strip-domain", o_bool, &chapms_strip_domain,
- + "Strip the domain prefix before the Username", 1 },
- { NULL }
- };
-
- @@ -336,6 +339,14 @@ chap_handle_response(struct chap_server_
- /* Null terminate and clean remote name. */
- slprintf(rname, sizeof(rname), "%.*v", len, name);
- name = rname;
- +
- + /* strip the MS domain name */
- + if (chapms_strip_domain && strrchr(rname, '\\')) {
- + char tmp[MAXNAMELEN+1];
- +
- + strcpy(tmp, strrchr(rname, '\\') + 1);
- + strcpy(rname, tmp);
- + }
- }
-
- if (chap_verify_hook)
|