diff options
-rw-r--r-- | net/Makefile | 1 | ||||
-rw-r--r-- | net/ris/Makefile | 51 | ||||
-rw-r--r-- | net/ris/distinfo | 2 | ||||
-rw-r--r-- | net/ris/files/binlsrv.sh.in | 41 | ||||
-rw-r--r-- | net/ris/files/patch-binlsrv.py | 39 | ||||
-rw-r--r-- | net/ris/files/patch-infparser.py | 37 | ||||
-rw-r--r-- | net/ris/pkg-descr | 4 |
7 files changed, 175 insertions, 0 deletions
diff --git a/net/Makefile b/net/Makefile index 5a591d7ef6dd..b8a11d21b7db 100644 --- a/net/Makefile +++ b/net/Makefile @@ -712,6 +712,7 @@ SUBDIR += rinetd SUBDIR += ripe-whois SUBDIR += ripetools + SUBDIR += ris SUBDIR += rmsg SUBDIR += roadrunner SUBDIR += rp-pppoe diff --git a/net/ris/Makefile b/net/ris/Makefile new file mode 100644 index 000000000000..eedb3b0c5a7e --- /dev/null +++ b/net/ris/Makefile @@ -0,0 +1,51 @@ +# New ports collection makefile for: ris +# Date created: 3 September 2005 +# Whom: Alex Deiter <tiamat@komi.mts.ru> +# +# $FreeBSD$ +# + +PORTNAME= ris +PORTVERSION= 0.1 +CATEGORIES= net +MASTER_SITES= http://oss.netfarm.it/guides/ \ + http://freebsd.komi.mtsnet.ru/ports/distfiles/ +DISTNAME= ris-linux + +MAINTAINER= tiamat@komi.mts.ru +COMMENT= OpenSource alternative to Microsoft Windows RIS + +RUN_DEPENDS= ${LOCALBASE}/libexec/in.tftpd:${PORTSDIR}/ftp/tftp-hpa + +USE_RC_SUBR= binlsrv.sh +USE_REINPLACE= yes +USE_PYTHON= yes +NO_BUILD= yes + +VARDIR= ${DESTDIR}/var +PID_FILE?= ${VARDIR}/run/binlsrv.pid +DEVLIST_CACHE?= ${VARDIR}/db/devlist.cache + +PLIST_FILES= sbin/binlsrv.py sbin/decode.py \ + sbin/fixloader.py sbin/infparser.py \ + sbin/fixup-repository.sh + +SUB_LIST= PYTHON_CMD=${PYTHON_CMD} \ + PID_FILE=${PID_FILE} \ + DEVLIST_CACHE=${DEVLIST_CACHE} + +post-patch: +.for SCRIPT in ${PLIST_FILES} + @${REINPLACE_CMD} -e \ + 's|@PYTHON_CMD@|${PYTHON_CMD}|; \ + s|@PID_FILE@|${PID_FILE}|; \ + s|@DEVLIST_CACHE@|${DEVLIST_CACHE}|' \ + ${WRKSRC}/${SCRIPT:S/sbin\///} +.endfor + +do-install: +.for SCRIPT in ${PLIST_FILES} + ${INSTALL_SCRIPT} ${WRKSRC}/${SCRIPT:S/sbin\///} ${PREFIX}/sbin +.endfor + +.include <bsd.port.mk> diff --git a/net/ris/distinfo b/net/ris/distinfo new file mode 100644 index 000000000000..2a0cb9c1176c --- /dev/null +++ b/net/ris/distinfo @@ -0,0 +1,2 @@ +MD5 (ris-linux.tar.gz) = 23b8e9c73d3a37e2e9b90bb8433e7ace +SIZE (ris-linux.tar.gz) = 10805 diff --git a/net/ris/files/binlsrv.sh.in b/net/ris/files/binlsrv.sh.in new file mode 100644 index 000000000000..bba45b8750c0 --- /dev/null +++ b/net/ris/files/binlsrv.sh.in @@ -0,0 +1,41 @@ +#!/bin/sh + +# PROVIDE: binlsrv +# REQUIRE: DAEMON +# BEFORE: LOGIN +# KEYWORD: FreeBSD shutdown + +# Define these variables in one of these files: +# /etc/rc.conf +# /etc/rc.conf.local +# /etc/rc.conf.d/binlsrv +# +# binlsrv_enable="YES" +# binlsrv_infdir="/path/to/dir_with_inf_files" + +. /etc/rc.subr + +name="binlsrv" +rcvar=`set_rcvar` +command="%%PYTHON_CMD%%" +command_args="%%PREFIX%%/sbin/${name}.py -d" +required_dirs="${binlsrv_infdir}" +pidfile="%%PID_FILE%%" +start_precmd="binlsrv_start_precmd" +stop_postcmd="binlsrv_stop_postcmd" + +binlsrv_start_precmd() +{ + %%PREFIX%%/sbin/infparser.py ${binlsrv_infdir} +} + +binlsrv_stop_postcmd() +{ + rm -f ${pidfile} +} + +load_rc_config "$name" +: ${binlsrv_enable="NO"} +: ${binlsrv_infdir=""} + +run_rc_command "$1" diff --git a/net/ris/files/patch-binlsrv.py b/net/ris/files/patch-binlsrv.py new file mode 100644 index 000000000000..1809045ff6a8 --- /dev/null +++ b/net/ris/files/patch-binlsrv.py @@ -0,0 +1,39 @@ +--- binlsrv.py.orig Fri Sep 2 14:15:31 2005 ++++ binlsrv.py Fri Sep 2 14:21:11 2005 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#! @PYTHON_CMD@ + # -*- Mode: Python; tab-width: 4 -*- + # + # Boot Information Negotiation Layer - OpenSource Implementation +@@ -671,7 +671,12 @@ + + import sys + +- if (fork()): sys_exit() ++ pid=fork() ++ if (pid): ++ pidfile=open('@PID_FILE@', 'w') ++ pidfile.write('%d\n' % pid) ++ pidfile.close() ++ sys_exit() + + close(sys.stdin.fileno()) + sys.stdin = open('/dev/null') +@@ -683,7 +688,7 @@ + sys.stderr = Log(open(LOGFILE, 'a+')) + + try: +- devlist = load(open('devlist.cache')) ++ devlist = load(open('@DEVLIST_CACHE@')) + except: + print 'Could not load devlist.cache, build it with infparser.py' + sys_exit(-1) +@@ -694,7 +699,6 @@ + s = socket(AF_INET, SOCK_DGRAM) + s.bind(('', 4011)) + +- print 'Binlserver started... pid %d' % getpid() + while 1: + addr, t, data = get_packet(s) + if t == FILEREQ: diff --git a/net/ris/files/patch-infparser.py b/net/ris/files/patch-infparser.py new file mode 100644 index 000000000000..b1fe739dcaea --- /dev/null +++ b/net/ris/files/patch-infparser.py @@ -0,0 +1,37 @@ +--- infparser.py.orig Fri Sep 2 14:15:32 2005 ++++ infparser.py Fri Sep 2 14:18:12 2005 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#! @PYTHON_CMD@ + # -*- Mode: Python; tab-width: 4 -*- + # + # Inf Driver parser +@@ -143,7 +143,7 @@ + if name.endswith('.services'): + prefix = name.split('.services', 1)[0] + check = prefix.split('.') +- if check[-1].startswith('nt'): ++ if check[-1].startswith('nt') and not check[-1].endswith('64'): + check = check[:-1] + check = check + ['services'] + name = '.'.join(check) +@@ -154,7 +154,7 @@ + while check[-1].isdigit() and len(check)>1: + check = check[:-1] + +- if check[-1].startswith('nt'): ++ if check[-1].startswith('nt') and not check[-1].endswith('64'): + check = check[:-1] + + name = '.'.join(check) +@@ -283,8 +283,8 @@ + if inffile.split('/').pop() not in exclude: + devlist.update(scan_inf(inffile)) + +- print 'Compiled %d drivers' % len(devlist) ++ print 'Starting inf parser: compiled %d drivers.' % len(devlist) + +- fd = open('devlist.cache','w') ++ fd = open('@DEVLIST_CACHE@','w') + dump(devlist, fd) + fd.close() diff --git a/net/ris/pkg-descr b/net/ris/pkg-descr new file mode 100644 index 000000000000..83d637ced212 --- /dev/null +++ b/net/ris/pkg-descr @@ -0,0 +1,4 @@ +OpenSource alternative to Microsoft Windows RIS (Remote Installation Services). +You can also use this stuff to install Microsoft Windows from the network. + +WWW: http://oss.netfarm.it/guides/ |