[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: net/ja-samba swat authorization failed
ご指摘、ありがとうございます。
In message <808ydn5d9e.fsf@kurishna.tri.asanuma.co.jp>
on Wed, 14 Jul 2004 15:11:41 +0900,
moriko@hh.iij4u.or.jp wrote:
> net/ja-samba について、swat が HTTP の BASIC 認証に失敗します。
swat使ってないというのがバレバレです。:-(
> オリジナルのソースからコンパイルした swat では認証に成功するので
> 調べたところ、patch-ap によりパスワードをコピーするコードが実行
> されなくなってしまっているようです。
こんなところで、どうでしょう?
--- lib/system.c.orig 2003-07-17 20:23:53.000000000 +0900
+++ lib/system.c
@@ -776,6 +776,11 @@ static int num_lookups; /* Counter so we
static void copy_pwent(struct saved_pw *dst, struct passwd *pass)
{
+#ifdef BSD
+ char *bp, *gecos, *p;
+ pstring buf, buf2;
+#endif
+
memcpy((char *)&dst->pass, pass, sizeof(struct passwd));
unix_to_dos(dst->pw_name, pass->pw_name);
@@ -783,9 +788,39 @@ static void copy_pwent(struct saved_pw *
fstrcpy(dst->pw_passwd, pass->pw_passwd);
dst->pass.pw_passwd = dst->pw_passwd;
+#ifdef BSD
+ if (pass->pw_gecos) {
+ gecos = pass->pw_gecos;
+ if (*gecos == '*')
+ gecos++;
+ bp = buf;
+
+ /* copy gecos, interpolating & to be full name */
+ for (p = gecos; *p != '\0'; p++) {
+ if (bp >= &buf[PSTRING_LEN - 1]) {
+ /* buffer overflow */
+ gecos = pass->pw_name;
+ goto gecos_done;
+ }
+ if (*p == '&') {
+ /* interpolate full name */
+ snprintf(bp, PSTRING_LEN - (bp - buf), "%s",
+ pass->pw_name);
+ *bp = toupper(*bp);
+ bp += strlen(bp);
+ }
+ else
+ *bp++ = *p;
+ }
+ *bp = '\0';
+ gecos = buf;
- unix_to_dos(dst->pw_gecos, pass->pw_gecos);
+ gecos_done:
+ unix_to_dos(buf2, gecos);
+ fstrcpy(dst->pw_gecos, buf2);
+ }
dst->pass.pw_gecos = dst->pw_gecos;
+#endif
unix_to_dos(dst->pw_dir, pass->pw_dir);
dst->pass.pw_dir = dst->pw_dir;
--
神戸 隆博(かんべ たかひろ) at 仕事場