diff options
author | piaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2009-06-09 23:34:27 +0800 |
---|---|---|
committer | piaip <piaip@63ad8ddf-47c3-0310-b6dd-a9e9d9715204> | 2009-06-09 23:34:27 +0800 |
commit | 9890096610e8e6961e0d330756d975a56c105bc6 (patch) | |
tree | 6f285768adbf48e359106399f1c05f21d691e845 /daemon | |
parent | 60a93d4b1cc71acd8b3a80e6426e54f2a1c75211 (diff) | |
download | pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar.gz pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar.bz2 pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar.lz pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar.xz pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.tar.zst pttbbs-9890096610e8e6961e0d330756d975a56c105bc6.zip |
* make tunnel file with BBS user permission
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@4529 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'daemon')
-rw-r--r-- | daemon/logind/logind.c | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/daemon/logind/logind.c b/daemon/logind/logind.c index 2930be5e..6706b413 100644 --- a/daemon/logind/logind.c +++ b/daemon/logind/logind.c @@ -1087,16 +1087,6 @@ main(int argc, char *argv[]) signal_set(&ev_sighup, SIGHUP, sighup_cb, &ev_sighup); signal_add(&ev_sighup, NULL); - // create tunnel - if ( (tfd = tobindex(tunnel_path, 1, _set_bind_opt, 1)) < 0) - { - fprintf(stderr, "cannot create tunnel: %s. abort.\r\n", tunnel_path); - return 2; - } - chmod(tunnel_path, 0666); - event_set(&ev_tunnel, tfd, EV_READ | EV_PERSIST, tunnel_cb, &ev_tunnel); - event_add(&ev_tunnel, NULL); - // bind ports if (port && bind_port(port) < 0) { @@ -1133,6 +1123,19 @@ main(int argc, char *argv[]) return 4; } + /* Give up root privileges: no way back from here */ + setgid(BBSGID); + setuid(BBSUID); + + // create tunnel + if ( (tfd = tobindex(tunnel_path, 1, _set_bind_opt, 1)) < 0) + { + fprintf(stderr, "cannot create tunnel: %s. abort.\r\n", tunnel_path); + return 2; + } + event_set(&ev_tunnel, tfd, EV_READ | EV_PERSIST, tunnel_cb, &ev_tunnel); + event_add(&ev_tunnel, NULL); + fprintf(stderr, "start event dispatch.\r\n"); event_dispatch(); |