summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/ppp/systems.c26
1 files changed, 19 insertions, 7 deletions
diff --git a/usr.sbin/ppp/systems.c b/usr.sbin/ppp/systems.c
index 51e58fc..0e26711 100644
--- a/usr.sbin/ppp/systems.c
+++ b/usr.sbin/ppp/systems.c
@@ -17,7 +17,7 @@
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*
- * $Id: systems.c,v 1.40 1998/10/31 17:38:47 brian Exp $
+ * $Id: systems.c,v 1.41 1999/02/02 09:35:30 brian Exp $
*
* TODO:
*/
@@ -249,6 +249,8 @@ xgets(char *buf, int buflen, FILE *fp)
#define SYSTEM_VALIDATE 2
#define SYSTEM_EXEC 3
+/* Returns -2 for ``file not found'' and -1 for ``label not found'' */
+
static int
ReadSystem(struct bundle *bundle, const char *name, const char *file,
struct prompt *prompt, struct datalink *cx, int how)
@@ -272,7 +274,7 @@ ReadSystem(struct bundle *bundle, const char *name, const char *file,
fp = ID0fopen(filename, "r");
if (fp == NULL) {
log_Printf(LogDEBUG, "ReadSystem: Can't open %s.\n", filename);
- return (-1);
+ return -2;
}
log_Printf(LogDEBUG, "ReadSystem: Checking %s (%s).\n", name, filename);
@@ -359,7 +361,7 @@ system_IsValid(const char *name, struct prompt *prompt, int mode)
* Note: The ReadSystem() calls only result in calls to the Allow*
* functions. arg->bundle will be set to NULL for these commands !
*/
- int def, how;
+ int def, how, rs;
def = !strcmp(name, "default");
how = ID0realuid() == 0 ? SYSTEM_EXISTS : SYSTEM_VALIDATE;
@@ -367,11 +369,21 @@ system_IsValid(const char *name, struct prompt *prompt, int mode)
modeok = 1;
modereq = mode;
- if (ReadSystem(NULL, "default", CONFFILE, prompt, NULL, how) != 0 && def)
- return "Configuration label not found";
+ rs = ReadSystem(NULL, "default", CONFFILE, prompt, NULL, how);
+
+ if (!def) {
+ if (rs == -1)
+ rs = 0; /* we don't care that ``default'' doesn't exist */
+
+ if (rs == 0)
+ rs = ReadSystem(NULL, name, CONFFILE, prompt, NULL, how);
- if (!def && ReadSystem(NULL, name, CONFFILE, prompt, NULL, how) != 0)
- return "Configuration label not found";
+ if (rs == -1)
+ return "Configuration label not found";
+
+ if (rs == -2)
+ return _PATH_PPP "/" CONFFILE ": File not found";
+ }
if (how == SYSTEM_EXISTS)
userok = modeok = 1;
OpenPOWER on IntegriCloud