aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2005-07-13 03:59:53 +0000
committerrsc <devnull@localhost>2005-07-13 03:59:53 +0000
commitf0bf146d21ada82754fca0b033009c636d0aa084 (patch)
treec56aae98bbf98dea804e4d553b3d7ad934718293 /src
parent0b1c1f414ddda722072bb7c84783db0279d3f7f9 (diff)
downloadplan9port-f0bf146d21ada82754fca0b033009c636d0aa084.tar.gz
plan9port-f0bf146d21ada82754fca0b033009c636d0aa084.tar.bz2
plan9port-f0bf146d21ada82754fca0b033009c636d0aa084.zip
add listen1
Diffstat (limited to 'src')
-rw-r--r--src/cmd/listen1.c106
1 files changed, 106 insertions, 0 deletions
diff --git a/src/cmd/listen1.c b/src/cmd/listen1.c
new file mode 100644
index 00000000..0f9762ff
--- /dev/null
+++ b/src/cmd/listen1.c
@@ -0,0 +1,106 @@
+#include <u.h>
+#include <libc.h>
+#include <auth.h>
+
+int verbose;
+int trusted;
+
+void
+usage(void)
+{
+ fprint(2, "usage: listen1 [-v] address cmd args...\n");
+ exits("usage");
+}
+
+char*
+remoteaddr(char *dir)
+{
+ static char buf[128];
+ char *p;
+ int n, fd;
+
+ snprint(buf, sizeof buf, "%s/remote", dir);
+ fd = open(buf, OREAD);
+ if(fd < 0)
+ return "";
+ n = read(fd, buf, sizeof(buf));
+ close(fd);
+ if(n > 0){
+ buf[n] = 0;
+ p = strchr(buf, '!');
+ if(p)
+ *p = 0;
+ return buf;
+ }
+ return "";
+}
+
+void
+main(int argc, char **argv)
+{
+ char dir[40], ndir[40];
+ int ctl, nctl, fd;
+
+ ARGBEGIN{
+ default:
+ usage();
+ case 't':
+ trusted = 1;
+ break;
+ case 'v':
+ verbose = 1;
+ break;
+ }ARGEND
+
+ if(argc < 2)
+ usage();
+
+ if(!verbose){
+ close(1);
+ fd = open("/dev/null", OWRITE);
+ if(fd != 1){
+ dup(fd, 1);
+ close(fd);
+ }
+ }
+
+ print("listen started\n");
+ ctl = announce(argv[0], dir);
+ if(ctl < 0)
+ sysfatal("announce %s: %r", argv[0]);
+
+ for(;;){
+ nctl = listen(dir, ndir);
+ if(nctl < 0)
+ sysfatal("listen %s: %r", argv[0]);
+
+ switch(rfork(RFFDG|RFPROC|RFNOWAIT|RFNOTEG)){
+ case -1:
+ close(nctl);
+ continue;
+ case 0:
+ fd = accept(nctl, ndir);
+ if(fd < 0){
+ fprint(2, "accept %s: can't open %s/data: %r", argv[0], ndir);
+ _exits(0);
+ }
+ print("incoming call for %s from %s in %s\n", argv[0], remoteaddr(ndir), ndir);
+ close(ctl);
+ close(nctl);
+ //putenv("net", ndir);
+ //sprint(data, "%s/data", ndir);
+ //bind(data, "/dev/cons", MREPL);
+ dup(fd, 0);
+ dup(fd, 1);
+ dup(fd, 2);
+ close(fd);
+ exec(argv[1], argv+1);
+ fprint(2, "exec: %r");
+ exits(nil);
+ default:
+ close(nctl);
+ break;
+ }
+ }
+ exits(nil);
+}