aboutsummaryrefslogtreecommitdiffstats
path: root/japanese
diff options
context:
space:
mode:
authorhrs <hrs@FreeBSD.org>2011-07-02 22:54:06 +0800
committerhrs <hrs@FreeBSD.org>2011-07-02 22:54:06 +0800
commitc358d480aa9fe1dc36da9b21ce3ceb814360ac75 (patch)
tree1af881a6ef02dee0528280534e2b6935be8fe0bf /japanese
parent116fad2b6ff00315f3edd924c62bc42620cc33f9 (diff)
downloadfreebsd-ports-gnome-c358d480aa9fe1dc36da9b21ce3ceb814360ac75.tar.gz
freebsd-ports-gnome-c358d480aa9fe1dc36da9b21ce3ceb814360ac75.tar.zst
freebsd-ports-gnome-c358d480aa9fe1dc36da9b21ce3ceb814360ac75.zip
- Fix a crash when an invalid log file is specified.
- Add -u uid option to drop the root privilege. - Add skkserv user and group. - Display fatal error messages in mksock() even if debug=0.
Diffstat (limited to 'japanese')
-rw-r--r--japanese/skkserv/Makefile4
-rw-r--r--japanese/skkserv/files/patch-skkserv.c112
-rw-r--r--japanese/skkserv/files/patch-skkserv.h8
-rw-r--r--japanese/skkserv/files/skkserv.sh.in2
4 files changed, 112 insertions, 14 deletions
diff --git a/japanese/skkserv/Makefile b/japanese/skkserv/Makefile
index f215cc4e1a84..32e07c05ec13 100644
--- a/japanese/skkserv/Makefile
+++ b/japanese/skkserv/Makefile
@@ -7,7 +7,7 @@
PORTNAME= skkserv
PORTVERSION= 9.6
-PORTREVISION= 3
+PORTREVISION= 4
CATEGORIES= japanese
MASTER_SITES= ${MASTER_SITE_PORTS_JP}
DISTNAME= skk${PORTVERSION}
@@ -23,6 +23,8 @@ GNU_CONFIGURE= yes
MAKE_ARGS= SUBDIRS='skkserv'
CONFIGURE_ARGS+= --with-jisyo=${SKKJISYO} --libexecdir=${PREFIX}/sbin
PLIST_FILES= sbin/skkserv
+USERS= skkserv
+GROUPS= skkserv
SKKJISYO_SIZE?= L
SKKJISYO?= SKK-JISYO.${SKKJISYO_SIZE}
diff --git a/japanese/skkserv/files/patch-skkserv.c b/japanese/skkserv/files/patch-skkserv.c
index 92b3ad6e203a..665b8d8e3f3a 100644
--- a/japanese/skkserv/files/patch-skkserv.c
+++ b/japanese/skkserv/files/patch-skkserv.c
@@ -1,18 +1,65 @@
--- skkserv/skkserv.c.orig 1997-01-21 04:16:36.000000000 +0900
-+++ skkserv/skkserv.c 2011-07-02 22:05:16.000000000 +0900
-@@ -124,6 +124,8 @@
++++ skkserv/skkserv.c 2011-07-02 23:48:44.000000000 +0900
+@@ -102,6 +102,8 @@
+
+ #define err(m) \
+ {if (debug) fprintf(errout, "%s: %s\n", pgmnm, m); exit(1);}
++#define nderr(m) \
++ {fprintf(errout, "%s: %s\n", pgmnm, m); exit(1);}
+
+ /*
+ * Global Variables
+@@ -124,18 +126,25 @@
int clientsock[MAXCLNT]; /* socket for each client */
int nclients; /* max index for active clients */
+char listenaddr[NI_MAXHOST];
++uid_t uid;
++gid_t gid;
+
main(argc, argv)
char *argv[];
{
-@@ -166,6 +168,12 @@
+ int parg;
+ int setjisho = 0;
+ int ctlterm; /* fildes for control terminal */
++ struct passwd *pwent;
+ void reread();
+
+ pgmnm = argv[0];
+ debug = 0;
+ errout = stderr;
+ portnum = 0;
++ uid = getuid();
++ gid = getgid();
+
+ /* The following patch (a work-around due to "rsh" bug) was pointed */
+ /* out by kazushi@kubota.co.jp in the message "714" in SKK-ML */
+@@ -155,7 +164,7 @@
+ if (parg + 1 == argc) showusage();
+ if ((errout = fopen(argv[++parg], "w")) == NULL) {
+ fprintf(stderr, "%s: opening logfile \"%s\" failed\n",
+- pgmnm, *argv[parg]);
++ pgmnm, argv[parg]);
+ exit(1);
+ }
+ debug = 1; break;
+@@ -166,6 +175,24 @@
case 'P':
if (parg +1 == argc) showusage();
portnum = atoi(argv[++parg]); break;
++ case 'u':
++ case 'U':
++ if (parg + 1 == argc) showusage();
++ pwent = getpwnam(argv[++parg]);
++ if (pwent == NULL) {
++ fprintf(stderr,
++ "%s: invalid uid \"%s\"\n", pgmnm, argv[parg]);
++ exit(1);
++ }
++ uid = pwent->pw_uid;
++ gid = pwent->pw_gid;
++ break;
+ case 'a':
+ case 'A':
+ if (parg +1 == argc) showusage();
@@ -22,19 +69,39 @@
default: showusage();
}
} else if (setjisho == 0) {
-@@ -232,9 +240,9 @@
+@@ -183,6 +210,17 @@
+ exit(1);
+ }
+
++ if (setgid(gid) == -1) {
++ fprintf(stderr,
++ "%s: setgid() failed\n", pgmnm);
++ exit(1);
++ }
++ if (setuid(uid) == -1) {
++ fprintf(stderr,
++ "%s: setuid() failed\n", pgmnm);
++ exit(1);
++ }
++
+ set_hname();
+
+ /* make socket */
+@@ -232,9 +270,11 @@
showusage()
{
fprintf(stderr,
- "Usage: %s [-d] [-l logfile] [-p port] \n", pgmnm);
-+ "Usage: %s [-d] [-l logfile] [-p port] [-a listenaddr]\n", pgmnm);
++ "Usage: %s [-d] [-l logfile] [-p port] [-a listenaddr] [-u uid]\n",
++ pgmnm);
fprintf(stderr,
- " %s [-d] [-l logfile] [-p port] skk-jisho\n", pgmnm);
-+ " %s [-d] [-l logfile] [-p port] [-a listenaddr] skk-jisho\n", pgmnm);
++ " %s [-d] [-l logfile] [-p port] [-a listenaddr] [-u uid]"
++ " skk-jisho\n", pgmnm);
exit(1);
}
-@@ -249,7 +257,21 @@
+@@ -249,27 +289,41 @@
bzero((char*)&sin, sizeof(sin));
sin.sin_family = AF_INET;
@@ -47,7 +114,7 @@
+ struct in_addr **pptr;
+
+ if ((hp = gethostbyname(listenaddr)) == NULL) {
-+ err("could not resolve the specified listen address");
++ nderr("could not resolve the specified listen address");
+ }
+ pptr = (struct in_addr **)hp->h_addr_list;
+ memcpy(&sin.sin_addr.s_addr, pptr[0], sizeof(struct in_addr));
@@ -57,7 +124,32 @@
if (portnum == 0) {
#ifdef PORTNUM
portnum = PORTNUM;
-@@ -382,6 +404,10 @@
+ #else
+ if ((sp = getservbyname(SERVICE_NAME, "tcp")) == NULL)
+- err("service name is undefined in /etc/services file");
++ nderr("service name is undefined in /etc/services file");
+ portnum = ntohs(sp->s_port);
+ #endif
+ }
+ sin.sin_port = htons(portnum);
+
+ if ((initsock = socket(PF_INET, SOCK_STREAM, 0)) < 0)
+- err("socket error; socket cannot be created");
++ nderr("socket error; socket cannot be created");
+ if (setsockopt(initsock, SOL_SOCKET, SO_REUSEADDR,
+ &optbuf, sizeof(optbuf)) < 0)
+- err("socket error; cannot set socket option");
++ nderr("socket error; cannot set socket option");
+ if (bind(initsock, (struct sockaddr *)&sin, sizeof(sin))< 0)
+- err("bind error; the socket is already used");
++ nderr("bind error; the socket is already used");
+ if (listen(initsock, MAXQUE) < 0)
+- err("listen error; something wrong happened with the socket");
++ nderr("listen error; something wrong happened with the socket");
+ if (debug) {
+ fprintf(errout, "file descriptor for initsock is %d\n", initsock);
+ fflush(errout);
+@@ -382,6 +436,10 @@
code = KANA_END;
while ((c = fgetc(jisho)) != EOF) {
@@ -68,7 +160,7 @@
target = ((c & 0xff)<< 8) | (fgetc(jisho) & 0xff);
if (target == STRMARK) {
fgets(buf, BUFSIZE, jisho);
-@@ -476,7 +502,7 @@
+@@ -476,7 +534,7 @@
if (FD_ISSET(initsock, &readfds)) {
len = sizeof(from);
diff --git a/japanese/skkserv/files/patch-skkserv.h b/japanese/skkserv/files/patch-skkserv.h
index ae8375cca646..e6a6149ff668 100644
--- a/japanese/skkserv/files/patch-skkserv.h
+++ b/japanese/skkserv/files/patch-skkserv.h
@@ -1,5 +1,5 @@
--- skkserv/skkserv.h.orig 1997-01-21 04:16:36.000000000 +0900
-+++ skkserv/skkserv.h 2008-11-01 23:53:43.000000000 +0900
++++ skkserv/skkserv.h 2011-07-02 23:07:17.000000000 +0900
@@ -37,6 +37,8 @@
/* Necessary for SunOS 3.x and maybe other old systems */
@@ -9,7 +9,7 @@
#include <sys/types.h>
#ifdef HAVE_SYS_IOCTL_H
-@@ -44,6 +46,7 @@
+@@ -44,9 +46,11 @@
#endif
#include <sys/socket.h>
#include <netinet/in.h>
@@ -17,3 +17,7 @@
#include <netdb.h>
#include <signal.h>
#include <errno.h>
++#include <pwd.h>
+
+ #ifndef DEFAULT_JISYO
+ #define DEFAULT_JISYO "/usr/local/share/emacs/SKK-JISYO.L"
diff --git a/japanese/skkserv/files/skkserv.sh.in b/japanese/skkserv/files/skkserv.sh.in
index ab94342e58cc..cf7e2aba557b 100644
--- a/japanese/skkserv/files/skkserv.sh.in
+++ b/japanese/skkserv/files/skkserv.sh.in
@@ -12,7 +12,7 @@ name=skkserv
rcvar=`set_rcvar`
command=%%PREFIX%%/sbin/skkserv
-: ${skkserv_flags:="-a 127.0.0.1"}
+: ${skkserv_flags:="-a 127.0.0.1 -u skkserv"}
load_rc_config ${name}
run_rc_command $1