aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/upas
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/upas')
-rw-r--r--src/cmd/upas/common/aux.c6
-rw-r--r--src/cmd/upas/common/config.c16
-rw-r--r--src/cmd/upas/common/libcommon.abin251056 -> 67236 bytes
-rw-r--r--src/cmd/upas/common/libsys.c104
-rw-r--r--src/cmd/upas/common/mkfile16
-rw-r--r--src/cmd/upas/common/process.c9
-rw-r--r--src/cmd/upas/common/sys.h6
-rw-r--r--src/cmd/upas/fs/pop3.c4
8 files changed, 41 insertions, 120 deletions
diff --git a/src/cmd/upas/common/aux.c b/src/cmd/upas/common/aux.c
index 7577acae..6e8001ca 100644
--- a/src/cmd/upas/common/aux.c
+++ b/src/cmd/upas/common/aux.c
@@ -30,8 +30,8 @@ append_match(Resub *subexp, String *sp, int se)
{
char *cp, *ep;
- cp = subexp[se].s.sp; /* jpc .sp -> .s.sp */
- ep = subexp[se].e.ep; /* jpc .ep -> .e.ep */
+ cp = subexp[se].s.sp;
+ ep = subexp[se].e.ep;
for (; cp < ep; cp++)
s_putc(sp, *cp);
s_terminate(sp);
@@ -53,7 +53,7 @@ shellchars(char *cp)
return 0;
}
-static char *specialchars = " ()<>{};=\\'\`^&|";
+static char *specialchars = " ()<>{};=\\'`^&|";
static char *escape = "%%";
int
diff --git a/src/cmd/upas/common/config.c b/src/cmd/upas/common/config.c
index 4bbaff83..21b34a12 100644
--- a/src/cmd/upas/common/config.c
+++ b/src/cmd/upas/common/config.c
@@ -9,3 +9,19 @@ char *SHELL = "#9/bin/rc";
char *POST = "#9/sys/lib/post/dispatch";
int MBOXMODE = 0662;
+
+void
+upasconfig(void)
+{
+ static int did;
+
+ if(did)
+ return;
+ did = 1;
+ MAILROOT = unsharp(MAILROOT);
+ UPASLOG = unsharp(UPASLOG);
+ UPASLIB = unsharp(UPASLIB);
+ UPASBIN = unsharp(UPASBIN);
+ SHELL = unsharp(SHELL);
+ POST = unsharp(POST);
+}
diff --git a/src/cmd/upas/common/libcommon.a b/src/cmd/upas/common/libcommon.a
index 7266859d..c767d7ce 100644
--- a/src/cmd/upas/common/libcommon.a
+++ b/src/cmd/upas/common/libcommon.a
Binary files differ
diff --git a/src/cmd/upas/common/libsys.c b/src/cmd/upas/common/libsys.c
index 67f36798..a9d4f0f8 100644
--- a/src/cmd/upas/common/libsys.c
+++ b/src/cmd/upas/common/libsys.c
@@ -33,24 +33,7 @@ getlog(void)
{
return getuser();
}
-#if 0 /* jpc */
-extern char *
-getlog(void)
-{
- static char user[64];
- int fd;
- int n;
- fd = open("/dev/user", 0);
- if(fd < 0)
- return nil;
- if((n=read(fd, user, sizeof(user)-1)) <= 0)
- return nil;
- close(fd);
- user[n] = 0;
- return user;
-}
-#endif /* jpc */
/*
* return the lock name (we use one lock per directory)
*/
@@ -704,64 +687,17 @@ pipesigoff(void)
atnotify(catchpipe, 0);
}
-void
-exit9(int i)
-{
- char buf[32];
-
- if(i == 0)
- exits(0);
- snprint(buf, sizeof(buf), "%d", i);
- exits(buf);
-}
-
-static int
-islikeatty(int fd)
-{
- Dir *d;
- int rv;
-
- d = dirfstat(fd);
- if(d == nil)
- return 0;
- rv = strcmp(d->name, "cons") == 0;
- free(d);
- return rv;
-}
-
-#if 0
-/* jpc */
-static int
-islikeatty(int fd)
-{
- char buf[64];
-
- if(fd2path(fd, buf, sizeof buf) != 0)
- return 0;
-
- /* might be /mnt/term/dev/cons */
- return strlen(buf) >= 9 && strcmp(buf+strlen(buf)-9, "/dev/cons") == 0;
-}
-#endif
-
extern int
holdon(void)
{
- int fd;
-
- if(!islikeatty(0))
- return -1;
-
- fd = open("/dev/consctl", OWRITE);
- write(fd, "holdon", 6);
-
- return fd;
+ /* XXX talk to 9term? */
+ return -1;
}
extern int
sysopentty(void)
{
- return open("/dev/cons", ORDWR);
+ return open("/dev/tty", ORDWR);
}
extern void
@@ -786,11 +722,13 @@ sysfiles(void)
extern String *
mboxpath(char *path, char *user, String *to, int dot)
{
+ upasconfig();
+
if (dot || *path=='/' || strncmp(path, "./", 2) == 0
|| strncmp(path, "../", 3) == 0) {
to = s_append(to, path);
} else {
- to = s_append(to, unsharp(MAILROOT));
+ to = s_append(to, MAILROOT);
to = s_append(to, "/box/");
to = s_append(to, user);
to = s_append(to, "/");
@@ -885,35 +823,7 @@ username(String *from)
char *
remoteaddr(int fd, char *dir)
{
- char buf[128], *p;
- int n;
-
- if(dir == 0){
- fprint(2,"remoteaddr: called fd2path: fixme\n"); /* jpc
- if(fd2path(fd, buf, sizeof(buf)) != 0)
- return ""; */
-
- /* parse something of the form /net/tcp/nnnn/data */
- p = strrchr(buf, '/');
- if(p == 0)
- return "";
- strncpy(p+1, "remote", sizeof(buf)-(p-buf)-2);
- } else
- snprint(buf, sizeof buf, "%s/remote", dir);
- buf[sizeof(buf)-1] = 0;
-
- fd = open(buf, OREAD);
- if(fd < 0)
- return "";
- n = read(fd, buf, sizeof(buf)-1);
- close(fd);
- if(n > 0){
- buf[n] = 0;
- p = strchr(buf, '!');
- if(p)
- *p = 0;
- return strdup(buf);
- }
+ /* XXX should call netconninfo */
return "";
}
diff --git a/src/cmd/upas/common/mkfile b/src/cmd/upas/common/mkfile
index 8cfaf267..5cd01233 100644
--- a/src/cmd/upas/common/mkfile
+++ b/src/cmd/upas/common/mkfile
@@ -2,19 +2,17 @@
LIB=libcommon.a
-OFILES=aux.$O\
- become.$O\
+OFILES=\
+ appendfiletombox.$O\
+ aux.$O\
+ config.$O\
+ libsys.$O\
mail.$O\
process.$O\
- libsys.$O\
- config.$O\
- appendfiletombox.$O\
-HFILES=common.h\
+HFILES=\
+ common.h\
sys.h\
<$PLAN9/src/mklib
-nuke:V:
- mk clean
- rm -f libcommon.a
diff --git a/src/cmd/upas/common/process.c b/src/cmd/upas/common/process.c
index 16b21aef..56725a88 100644
--- a/src/cmd/upas/common/process.c
+++ b/src/cmd/upas/common/process.c
@@ -93,10 +93,8 @@ noshell_proc_start(char **av, stream *inp, stream *outp, stream *errp, int newpg
dup(pp->std[i]->fd, i);
for (n = sysfiles(); i < n; i++)
close(i);
- if(who) {
- fprint(2,"process.c: trying to become(%s,%s)\n",av,who);
- // jpc become(av, who);
- }
+ if(who)
+ fprint(2, "warning: cannot run %s as %s\n", av[0], who);
exec(av[0], av);
perror("proc_start");
exits("proc_start");
@@ -116,7 +114,8 @@ proc_start(char *cmd, stream *inp, stream *outp, stream *errp, int newpg, char *
{
char *av[4];
- av[0] = unsharp(SHELL);
+ upasconfig();
+ av[0] = SHELL;
av[1] = "-c";
av[2] = cmd;
av[3] = 0;
diff --git a/src/cmd/upas/common/sys.h b/src/cmd/upas/common/sys.h
index 960aebb3..50691558 100644
--- a/src/cmd/upas/common/sys.h
+++ b/src/cmd/upas/common/sys.h
@@ -6,7 +6,7 @@
#include <libc.h>
#include <regexp.h>
#include <bio.h>
-#include "libString.h" /* jpc String.h -> libString.h */
+#include <libString.h>
/*
* for the lock routines in libsys.c
@@ -19,7 +19,7 @@ struct Mlock {
};
/*
- * from config.c
+ * from config.c - call upasconfig() before using
*/
extern char *MAILROOT; /* root of mail system */
extern char *UPASLOG; /* log directory */
@@ -29,6 +29,7 @@ extern char *UPASTMP; /* temporary directory */
extern char *SHELL; /* path name of shell */
extern char *POST; /* path name of post server addresses */
extern int MBOXMODE; /* default mailbox protection mode */
+extern void upasconfig(void);
/*
* files in libsys.c
@@ -58,7 +59,6 @@ extern int syskill(int);
extern int syskillpg(int);
extern int syscreate(char*, int, ulong);
extern Mlock *trylock(char *);
-extern void exit9(int);
extern void pipesig(int*);
extern void pipesigoff(void);
extern int holdon(void);
diff --git a/src/cmd/upas/fs/pop3.c b/src/cmd/upas/fs/pop3.c
index 4ea9adb3..ebffcdd3 100644
--- a/src/cmd/upas/fs/pop3.c
+++ b/src/cmd/upas/fs/pop3.c
@@ -231,10 +231,8 @@ pop3login(Pop *pop)
if(pop->needtls && !pop->encrypted)
return "could not negotiate TLS";
- up = auth_getuserpasswd(auth_getkey, "role=client proto=pass service=pop dom=%q%s",
+ up = auth_getuserpasswd(auth_getkey, "proto=pass role=client service=pop dom=%q%s",
pop->host, ubuf);
- /* up = auth_getuserpasswd(auth_getkey, "proto=pass service=pop dom=%q%s",
- pop->host, ubuf); jpc */
if(up == nil)
return "no usable keys found";