/*
* Copyright (c) 2001 Apple Computer, Inc. All rights reserved.
*
* @APPLE_LICENSE_HEADER_START@
*
* "Portions Copyright (c) 1999 Apple Computer, Inc. All Rights
* Original Code as defined in and that are subject to the Apple Public
* Source License Version 1.0 (the 'License'). You may not use this file
* except in compliance with the License. Please obtain a copy of the
* License at http://www.apple.com/publicsource and read it before using
* this file.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
* License for the specific language governing rights and limitations
* under the License."
*
* @APPLE_LICENSE_HEADER_END@
*/
/*
* Routines for interacting with the user to get credentials
*/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <libintl.h>
#include <ctype.h>
#include "private.h"
#include "ntlm.h"
#if 0 /* not yet */
#define MAXLINE 127
static void
smb_tty_prompt(char *prmpt,
{
char *cp;
int ch;
break;
continue;
break;
}
/* If input empty, accept default. */
return;
/* Use input as new value. */
}
#endif /* not yet */
/*
* Prompt for a new password after auth. failure.
* (and maybe new user+domain, but not yet)
*/
int
{
char *npw;
int err;
/*
* If we're getting a password, we must be doing
* some kind of NTLM, possibly after a failure to
* authenticate using Kerberos. Turn off krb5.
*/
/* Tried a keychain hash and failed. */
/* XXX: delete the KC entry? */
}
return (ENOTTY);
if (isatty(STDIN_FILENO)) {
/* Need command-line prompting. */
return (EINTR);
} else {
/*
* XXX: Ask the user for help, possibly via
* GNOME dbus or some such... (todo).
*/
"Cannot prompt for a password when input is redirected."), 0);
return (ENOTTY);
}
/*
* Recompute the password hashes.
*/
if (ctx->ct_password[0]) {
if (err != 0)
return (err);
if (err != 0)
return (err);
}
return (0);
}
/*ARGSUSED*/
int
{
/*
* Let user pick a share.
* Not supported.
*/
return (EINTR);
}