Annotation of 42BSD/lib/libc/net/rexec.c, revision 1.1.1.1

1.1       root        1: #ifndef lint
                      2: static char sccsid[] = "@(#)rexec.c    4.8 83/08/18";
                      3: #endif
                      4: 
                      5: #include <sys/types.h>
                      6: #include <sys/socket.h>
                      7: 
                      8: #include <netinet/in.h>
                      9: 
                     10: #include <stdio.h>
                     11: #include <netdb.h>
                     12: #include <errno.h>
                     13: 
                     14: extern errno;
                     15: char   *index(), *sprintf();
                     16: int    rexecoptions;
                     17: char   *getpass(), *getlogin();
                     18: 
                     19: rexec(ahost, rport, name, pass, cmd, fd2p)
                     20:        char **ahost;
                     21:        int rport;
                     22:        char *name, *pass, *cmd;
                     23:        int *fd2p;
                     24: {
                     25:        int s, timo = 1, s3;
                     26:        struct sockaddr_in sin, sin2, from;
                     27:        char c;
                     28:        short port;
                     29:        struct hostent *hp;
                     30: 
                     31:        hp = gethostbyname(*ahost);
                     32:        if (hp == 0) {
                     33:                fprintf(stderr, "%s: unknown host\n", *ahost);
                     34:                return (-1);
                     35:        }
                     36:        *ahost = hp->h_name;
                     37:        ruserpass(hp->h_name, &name, &pass);
                     38: retry:
                     39:        s = socket(AF_INET, SOCK_STREAM, 0);
                     40:        if (s < 0) {
                     41:                perror("rexec: socket");
                     42:                return (-1);
                     43:        }
                     44:        sin.sin_family = hp->h_addrtype;
                     45:        sin.sin_port = rport;
                     46:        bcopy(hp->h_addr, (caddr_t)&sin.sin_addr, hp->h_length);
                     47:        if (connect(s, &sin, sizeof(sin)) < 0) {
                     48:                if (errno == ECONNREFUSED && timo <= 16) {
                     49:                        (void) close(s);
                     50:                        sleep(timo);
                     51:                        timo *= 2;
                     52:                        goto retry;
                     53:                }
                     54:                perror(hp->h_name);
                     55:                return (-1);
                     56:        }
                     57:        if (fd2p == 0) {
                     58:                (void) write(s, "", 1);
                     59:                port = 0;
                     60:        } else {
                     61:                char num[8];
                     62:                int s2, sin2len;
                     63:                
                     64:                s2 = socket(AF_INET, SOCK_STREAM, 0);
                     65:                if (s2 < 0) {
                     66:                        (void) close(s);
                     67:                        return (-1);
                     68:                }
                     69:                listen(s2, 1);
                     70:                sin2len = sizeof (sin2);
                     71:                if (getsockname(s2, (char *)&sin2, &sin2len) < 0 ||
                     72:                  sin2len != sizeof (sin2)) {
                     73:                        perror("getsockname");
                     74:                        (void) close(s2);
                     75:                        goto bad;
                     76:                }
                     77:                port = ntohs((u_short)sin2.sin_port);
                     78:                (void) sprintf(num, "%d", port);
                     79:                (void) write(s, num, strlen(num)+1);
                     80:                { int len = sizeof (from);
                     81:                  s3 = accept(s2, &from, &len, 0);
                     82:                  close(s2);
                     83:                  if (s3 < 0) {
                     84:                        perror("accept");
                     85:                        port = 0;
                     86:                        goto bad;
                     87:                  }
                     88:                }
                     89:                *fd2p = s3;
                     90:        }
                     91:        (void) write(s, name, strlen(name) + 1);
                     92:        /* should public key encypt the password here */
                     93:        (void) write(s, pass, strlen(pass) + 1);
                     94:        (void) write(s, cmd, strlen(cmd) + 1);
                     95:        if (read(s, &c, 1) != 1) {
                     96:                perror(*ahost);
                     97:                goto bad;
                     98:        }
                     99:        if (c != 0) {
                    100:                while (read(s, &c, 1) == 1) {
                    101:                        (void) write(2, &c, 1);
                    102:                        if (c == '\n')
                    103:                                break;
                    104:                }
                    105:                goto bad;
                    106:        }
                    107:        return (s);
                    108: bad:
                    109:        if (port)
                    110:                (void) close(*fd2p);
                    111:        (void) close(s);
                    112:        return (-1);
                    113: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.