summaryrefslogtreecommitdiffstats
path: root/src/connections/ethernet
diff options
context:
space:
mode:
authorJames Rayner <james@archlinux.org>2008-12-18 06:33:31 +0100
committerJames Rayner <james@archlinux.org>2008-12-18 06:33:31 +0100
commit164df2fdcc8ac4286c7f8f04f1e7c9004ade6960 (patch)
tree50e56f8711d4c7e9db7981c3c6282a994213acca /src/connections/ethernet
parent300cd2c73b599c2a58463ce75e1aa2cb19ac2414 (diff)
downloadnetctl-164df2fdcc8ac4286c7f8f04f1e7c9004ade6960.tar.gz
netctl-164df2fdcc8ac4286c7f8f04f1e7c9004ade6960.tar.xz
fix libify
Diffstat (limited to 'src/connections/ethernet')
-rw-r--r--src/connections/ethernet122
1 files changed, 122 insertions, 0 deletions
diff --git a/src/connections/ethernet b/src/connections/ethernet
new file mode 100644
index 0000000..3605663
--- /dev/null
+++ b/src/connections/ethernet
@@ -0,0 +1,122 @@
+#! /bin/bash
+
+
+ethernet_up() {
+ if [[ ! -e /sys/class/net/$INTERFACE ]]; then
+ if ! echo "$INTERFACE"|grep ":"; then
+ err_append "Interface $INTERFACE does not exist"
+ fi
+ fi
+
+ if ip link show $INTERFACE|grep -q "NO-CARRIER"; then
+ err_append "No connection available"
+ return 1
+ fi
+
+ ifconfig $INTERFACE up
+
+ if checkyesno ${AUTH8021X:-no}; then
+ . ${SUBR_DIR}/8021x
+ [[ -z "$WPA_CONF" ]] && WPA_CONF="/etc/wpa_supplicant.conf"
+ [[ -z "$WPA_OPTS" ]] && WPA_OPTS="-Dwired"
+ start_wpa "$INTERFACE" "$WPA_CONF" "$WPA_OPTS"
+ if ! wpa_check "$INTERFACE"; then
+ ifconfig $INTERFACE down
+ return 1
+ fi
+ fi
+
+ case $IP in
+ dhcp)
+ # Check if DHCP_TIMEOUT was set if not set a default value
+ [[ -z "$DHCP_TIMEOUT" ]] && DHCP_TIMEOUT=10
+
+ if checkyesno $DHCLIENT; then
+ rm -r /var/run/dhclient-${INTERFACE}.pid >/dev/null 2>&1
+ if ! dhclient -q -e TIMEOUT=$DHCP_TIMEOUT -pf /var/run/dhclient-${INTERFACE}.pid $INTERFACE; then
+ err_append "DHCP IP lease attempt failed"
+ return 1
+ fi
+ else
+ # Clear remaining pid files.
+ rm -f /var/run/dhcpcd-${INTERFACE}.{pid,cache} >/dev/null 2>&1
+ # If using own dns, tell dhcpcd to NOT replace resolv.conf
+ [[ -n "$DNS1" ]] && DHCP_OPTIONS="-C resolv.conf $DHCP_OPTIONS"
+ # Start dhcpcd
+ if ! dhcpcd -qL -t $DHCP_TIMEOUT $DHCP_OPTIONS $INTERFACE; then
+ err_append "DHCP IP lease attempt failed"
+ return 1
+ fi
+ fi
+ # TODO: add support for $section:ifconfig for other stuff, like mtu or mac?
+ ;;
+ static)
+ if ! ifconfig $INTERFACE $IFOPTS up; then
+ err_append "Could not bring interface up"
+ return 1
+ fi
+
+ # bring up the default route (gateway)
+ if [[ -n "$GATEWAY" ]]; then
+ if ! route add default gw $GATEWAY; then
+ err_append "Adding gateway $GATEWAY failed"
+ return 1
+ fi
+ fi
+ ;;
+ *)
+ err_append "Profile error: IP must be either 'dhcp' or 'static'"
+ return 1
+ ;;
+ esac
+
+ # set the hostname
+ if [[ -n "$HOSTNAME" ]]; then
+ if ! hostname $HOSTNAME; then
+ err_append "Cannot set hostname"
+ return 1
+ fi
+ fi
+
+ # Generate a new resolv.conf
+ if [[ -n "$DNS1" ]] || [[ -n "$DNS" ]]; then
+
+ : >/etc/resolv.conf
+ [[ -n "$DOMAIN" ]] && echo "domain $DOMAIN" >>/etc/resolv.conf
+ [[ -n "$SEARCH" ]] && echo "search $SEARCH" >>/etc/resolv.conf
+ [[ -n "$DNS1" ]] && echo "nameserver $DNS1" >>/etc/resolv.conf
+ [[ -n "$DNS2" ]] && echo "nameserver $DNS2" >>/etc/resolv.conf
+
+ if [[ -n "$DNS" ]]; then
+ for dns in ${DNS[@]}; do
+ echo "nameserver $dns" >>/etc/resolv.conf
+ done
+ fi
+ fi
+ return 0
+}
+
+ethernet_down() {
+ case $IP in
+ dhcp)
+ if checkyesno $DHCLIENT; then
+ if [[ -f /var/run/dhclient-${INTERFACE}.pid ]]; then
+ kill `cat /var/run/dhclient-${INTERFACE}.pid`
+ fi
+ else
+ if [[ -f /var/run/dhcpcd-${INTERFACE}.pid ]]; then
+ dhcpcd -qx $INTERFACE
+ fi
+ fi
+ ;;
+ static)
+ [[ -n "$GATEWAY" ]] && route del default gw $GATEWAY
+ ;;
+ esac
+ ifconfig $INTERFACE 0.0.0.0
+
+ quirk "nodown" || ifconfig $INTERFACE down
+
+}
+
+# vim: set ts=4 et sw=4: