Add package: sdhcp
This commit is contained in:
44
core/sdhcp.d/Makefile
Normal file
44
core/sdhcp.d/Makefile
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
|
||||||
|
package=sdhcp
|
||||||
|
version=8455fd2d090bd9b227340c30c92c6aa13302c91a
|
||||||
|
pkgver=${version}_0
|
||||||
|
description=Suckless dhcp client
|
||||||
|
homepage=http://git.2f30.org/sdhcp
|
||||||
|
license=MIT/X Consortium License
|
||||||
|
|
||||||
|
alternatives=
|
||||||
|
shlib-provides=
|
||||||
|
shlib-requires=libc.so
|
||||||
|
|
||||||
|
include ../../Makefile
|
||||||
|
|
||||||
|
SOURCES = \
|
||||||
|
${package}
|
||||||
|
|
||||||
|
FILES = \
|
||||||
|
files/Makefile \
|
||||||
|
files/setip.c
|
||||||
|
|
||||||
|
${package}:
|
||||||
|
export url=git://git.2f30.org pkg=$@ commit=${version} && ${GITCLONE}
|
||||||
|
${SHA256D} "c9c990f5469d5e0b819fe5c59e05b36d7d21e8594f33b0cf71486c9926e2eb5d"
|
||||||
|
|
||||||
|
prepare: ${SOURCES}
|
||||||
|
mv ${package} build
|
||||||
|
mv -f files/Makefile build/
|
||||||
|
mv files/setip.c build/
|
||||||
|
|
||||||
|
root:
|
||||||
|
sed "s/VERSION/$(VERSION)/g" sdhcp.1 > _
|
||||||
|
mv _ sdhcp.1
|
||||||
|
|
||||||
|
sed '/setenv("DNS", buf, 1);/asetenv("IFNAME", ifname, 1);' sdhcp.c > _
|
||||||
|
mv _ sdhcp.c
|
||||||
|
|
||||||
|
${MAKE}
|
||||||
|
install -Dm 755 sdhcp "${root}/usr/bin/sdhcp"
|
||||||
|
install -Dm 644 sdhcp.1 "${root}/usr/share/man/man1/sdhcp.1"
|
||||||
|
|
||||||
|
${MAKE} setip
|
||||||
|
install -Dm 755 setip "${root}/usr/libexec/sdhcp/setip"
|
||||||
|
|
||||||
60
core/sdhcp.d/files/Makefile
Normal file
60
core/sdhcp.d/files/Makefile
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
include config.mk
|
||||||
|
|
||||||
|
.POSIX:
|
||||||
|
.SUFFIXES: .c .o
|
||||||
|
|
||||||
|
HDR = util.h arg.h
|
||||||
|
LIB = \
|
||||||
|
util/strlcpy.o \
|
||||||
|
util/eprintf.o
|
||||||
|
|
||||||
|
BIN = sdhcp
|
||||||
|
|
||||||
|
OBJ = $(BIN).o $(LIB)
|
||||||
|
MAN = $(BIN).1
|
||||||
|
|
||||||
|
all: options $(BIN)
|
||||||
|
|
||||||
|
options:
|
||||||
|
@echo sdhcp build options:
|
||||||
|
@echo "CFLAGS = ${CFLAGS}"
|
||||||
|
@echo "LDFLAGS = ${LDFLAGS}"
|
||||||
|
@echo "CC = ${CC}"
|
||||||
|
|
||||||
|
$(BIN): $(BIN).o
|
||||||
|
|
||||||
|
$(OBJ): $(HDR) config.mk
|
||||||
|
|
||||||
|
.o: util.a
|
||||||
|
@echo LD $@
|
||||||
|
@$(LD) -o $@ $< util.a $(LDFLAGS)
|
||||||
|
|
||||||
|
.c.o:
|
||||||
|
@echo CC $<
|
||||||
|
@$(CC) -c -o $@ $< $(CFLAGS)
|
||||||
|
|
||||||
|
util.a: $(LIB)
|
||||||
|
@echo AR $@
|
||||||
|
@$(AR) -r -c $@ $(LIB)
|
||||||
|
|
||||||
|
install: all
|
||||||
|
@echo installing executables to $(DESTDIR)$(PREFIX)/sbin
|
||||||
|
@mkdir -p $(DESTDIR)$(PREFIX)/sbin
|
||||||
|
@cp -f $(BIN) $(DESTDIR)$(PREFIX)/sbin
|
||||||
|
@cd $(DESTDIR)$(PREFIX)/sbin && chmod 755 $(BIN)
|
||||||
|
@echo installing manual pages to $(DESTDIR)$(MANPREFIX)/man1
|
||||||
|
@mkdir -p $(DESTDIR)$(MANPREFIX)/man1
|
||||||
|
@for m in $(MAN); do sed "s/VERSION/$(VERSION)/g" < "$$m" > $(DESTDIR)$(MANPREFIX)/man1/"$$m"; done
|
||||||
|
@cd $(DESTDIR)$(MANPREFIX)/man1 && chmod 644 $(MAN)
|
||||||
|
|
||||||
|
uninstall:
|
||||||
|
@echo removing executables from $(DESTDIR)$(PREFIX)/sbin
|
||||||
|
@cd $(DESTDIR)$(PREFIX)/sbin && rm -f $(BIN)
|
||||||
|
@echo removing manual pages from $(DESTDIR)$(MANPREFIX)/man1
|
||||||
|
@cd $(DESTDIR)$(MANPREFIX)/man1 && rm -f $(MAN)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@echo cleaning
|
||||||
|
@rm -f $(BIN) $(OBJ) util.a
|
||||||
|
|
||||||
|
.PHONY: all options clean install uninstall
|
||||||
62
core/sdhcp.d/files/setip.c
Normal file
62
core/sdhcp.d/files/setip.c
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <net/if.h>
|
||||||
|
#include <net/route.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
|
||||||
|
int main( void )
|
||||||
|
{
|
||||||
|
struct sockaddr_in * addr;
|
||||||
|
char *ifname = getenv( "IFNAME" ),
|
||||||
|
*client = getenv( "CLIENT" ),
|
||||||
|
*getway = getenv( "ROUTER" ),
|
||||||
|
*mask = getenv( "MASK" );
|
||||||
|
|
||||||
|
int fd = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP);
|
||||||
|
|
||||||
|
// IP
|
||||||
|
{
|
||||||
|
struct ifreq iface;
|
||||||
|
iface.ifr_addr.sa_family = AF_INET;
|
||||||
|
strcpy( iface.ifr_name, ifname );
|
||||||
|
|
||||||
|
addr = &iface.ifr_addr;
|
||||||
|
|
||||||
|
addr->sin_family = AF_INET;
|
||||||
|
addr->sin_addr.s_addr = inet_addr(client);
|
||||||
|
ioctl(fd, SIOCSIFADDR, &iface);
|
||||||
|
|
||||||
|
addr->sin_family = AF_INET;
|
||||||
|
addr->sin_addr.s_addr = inet_addr(mask);
|
||||||
|
ioctl(fd, SIOCSIFNETMASK, &iface);
|
||||||
|
|
||||||
|
iface.ifr_flags |= ( IFF_UP | IFF_RUNNING );
|
||||||
|
ioctl(fd, SIOCSIFFLAGS, &iface);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ROUTE
|
||||||
|
{
|
||||||
|
struct rtentry route;
|
||||||
|
|
||||||
|
addr = &route.rt_dst;
|
||||||
|
addr->sin_family = AF_INET;
|
||||||
|
addr->sin_addr.s_addr = INADDR_ANY;
|
||||||
|
|
||||||
|
addr = &route.rt_gateway;
|
||||||
|
addr->sin_family = AF_INET;
|
||||||
|
addr->sin_addr.s_addr = inet_addr(getway);
|
||||||
|
|
||||||
|
addr = &route.rt_genmask;
|
||||||
|
addr->sin_family = AF_INET;
|
||||||
|
addr->sin_addr.s_addr = INADDR_ANY;
|
||||||
|
|
||||||
|
route.rt_flags = RTF_UP | RTF_GATEWAY ;
|
||||||
|
ioctl(fd, SIOCADDRT, &route);
|
||||||
|
}
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user