17323adacSDevin Teskeif [ ! "$_MEDIA_NFS_SUBR" ]; then _MEDIA_NFS_SUBR=1 27323adacSDevin Teske# 37323adacSDevin Teske# Copyright (c) 2012-2013 Devin Teske 4f8ea072aSDevin Teske# All rights reserved. 57323adacSDevin Teske# 67323adacSDevin Teske# Redistribution and use in source and binary forms, with or without 77323adacSDevin Teske# modification, are permitted provided that the following conditions 87323adacSDevin Teske# are met: 97323adacSDevin Teske# 1. Redistributions of source code must retain the above copyright 107323adacSDevin Teske# notice, this list of conditions and the following disclaimer. 117323adacSDevin Teske# 2. Redistributions in binary form must reproduce the above copyright 127323adacSDevin Teske# notice, this list of conditions and the following disclaimer in the 137323adacSDevin Teske# documentation and/or other materials provided with the distribution. 147323adacSDevin Teske# 157323adacSDevin Teske# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 168e37a7c8SDevin Teske# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 177323adacSDevin Teske# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 187323adacSDevin Teske# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 197323adacSDevin Teske# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 208e37a7c8SDevin Teske# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 217323adacSDevin Teske# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 227323adacSDevin Teske# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 237323adacSDevin Teske# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 247323adacSDevin Teske# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 257323adacSDevin Teske# SUCH DAMAGE. 267323adacSDevin Teske# 277323adacSDevin Teske# 287323adacSDevin Teske############################################################ INCLUDES 297323adacSDevin Teske 307323adacSDevin TeskeBSDCFG_SHARE="/usr/share/bsdconfig" 317323adacSDevin Teske. $BSDCFG_SHARE/common.subr || exit 1 327323adacSDevin Teskef_dprintf "%s: loading includes..." media/nfs.subr 337323adacSDevin Teskef_include $BSDCFG_SHARE/device.subr 347323adacSDevin Teskef_include $BSDCFG_SHARE/dialog.subr 357323adacSDevin Teskef_include $BSDCFG_SHARE/media/common.subr 367323adacSDevin Teskef_include $BSDCFG_SHARE/media/network.subr 371de60ff0SDevin Teskef_include $BSDCFG_SHARE/media/tcpip.subr 381de60ff0SDevin Teskef_include $BSDCFG_SHARE/struct.subr 391de60ff0SDevin Teskef_include $BSDCFG_SHARE/variable.subr 407323adacSDevin Teske 417323adacSDevin TeskeBSDCFG_LIBE="/usr/libexec/bsdconfig" 427323adacSDevin Teskef_include_lang $BSDCFG_LIBE/include/messages.subr 437323adacSDevin Teske 447323adacSDevin Teske############################################################ GLOBALS 457323adacSDevin Teske 467323adacSDevin TeskeNFS_MOUNTED= 477323adacSDevin Teske 487323adacSDevin Teske############################################################ FUNCTIONS 497323adacSDevin Teske 507323adacSDevin Teske# f_media_set_nfs 517323adacSDevin Teske# 527323adacSDevin Teske# Return success if we both found and set the media type to be an NFS server. 537323adacSDevin Teske# Variables from variable.subr that can be used to script user input: 547323adacSDevin Teske# 557323adacSDevin Teske# VAR_NFS_PATH 567323adacSDevin Teske# The NFS path specification (host:path) to use when mounting the 577323adacSDevin Teske# remote repository. 587323adacSDevin Teske# VAR_NAMESERVER [Optional] 597323adacSDevin Teske# Automatically populated from resolv.conf(5) but can be 607323adacSDevin Teske# overridden. If set, the host portion of VAR_NFS_PATH is 617323adacSDevin Teske# looked up using f_host_lookup() from `tcpip.subr'. 627323adacSDevin Teske# 637323adacSDevin Teske# Meanwhile, the following variables from variable.subr are set after 647323adacSDevin Teske# successful execution: 657323adacSDevin Teske# 667323adacSDevin Teske# VAR_NFS_HOST 677323adacSDevin Teske# The host portion of the NFS path specification, parsed from 687323adacSDevin Teske# VAR_NFS_PATH. 697323adacSDevin Teske# 707323adacSDevin Teskef_media_set_nfs() 717323adacSDevin Teske{ 727323adacSDevin Teske local nfs 737323adacSDevin Teske 747323adacSDevin Teske f_media_close 757323adacSDevin Teske 767323adacSDevin Teske f_variable_get_value $VAR_NFS_PATH \ 777323adacSDevin Teske "$msg_please_enter_the_full_nfs_file_specification" 787323adacSDevin Teske f_getvar $VAR_NFS_PATH nfs 797323adacSDevin Teske [ "$nfs" ] || return $FAILURE 807323adacSDevin Teske 817323adacSDevin Teske case "$nfs" in 827323adacSDevin Teske *:*) : valid NFS path ;; 837323adacSDevin Teske *) 847079fc4eSDevin Teske f_show_msg "$msg_invalid_nfs_path_specification" 857323adacSDevin Teske return $FAILURE 867323adacSDevin Teske esac 877323adacSDevin Teske 887323adacSDevin Teske f_struct_new DEVICE device_nfs 897323adacSDevin Teske device_nfs set name "$nfs" 907323adacSDevin Teske 917323adacSDevin Teske if ! f_struct device_network || 927323adacSDevin Teske ! f_dialog_yesno "$msg_youve_already_done_the_network_configuration" 937323adacSDevin Teske then 947323adacSDevin Teske f_struct device_network && 95*9ecd54f2SDevin Teske f_device_shutdown device_network 967323adacSDevin Teske f_device_select_tcp || return $FAILURE 97*9ecd54f2SDevin Teske local dev if 98*9ecd54f2SDevin Teske f_getvar $VAR_NETWORK_DEVICE if 99*9ecd54f2SDevin Teske f_device_find -1 "$if" $DEVICE_TYPE_NETWORK dev 100*9ecd54f2SDevin Teske f_struct_copy "$dev" device_network 1017323adacSDevin Teske fi 102*9ecd54f2SDevin Teske f_device_init device_network || 1037323adacSDevin Teske f_dprintf "%s: $msg_net_device_init_failed\n" f_media_set_nfs 1047323adacSDevin Teske 1057323adacSDevin Teske local hostname="${nfs%%:*}" 10680433743SDevin Teske if f_isset $VAR_NAMESERVER && ! { 10780433743SDevin Teske f_validate_ipaddr "$hostname" || f_validate_ipaddr6 "$hostname" 1087323adacSDevin Teske }; then 1097323adacSDevin Teske f_show_info "$msg_looking_up_host" "$hostname" 1107323adacSDevin Teske f_dprintf "%s Looking up hostname, %s, using host(1)" \ 1117323adacSDevin Teske "f_media_set_nfs" "$hostname" 1127323adacSDevin Teske if ! f_quietly f_host_lookup "$hostname"; then 1137323adacSDevin Teske f_show_msg "$msg_cannot_resolve_hostname" "$hostname" 1147323adacSDevin Teske f_struct device_network && 115*9ecd54f2SDevin Teske f_device_shutdown device_network 1167323adacSDevin Teske f_struct_free device_network 1177323adacSDevin Teske unset $VAR_NFS_PATH 1187323adacSDevin Teske return $FAILURE 1197323adacSDevin Teske fi 1207323adacSDevin Teske f_dprintf "Found DNS entry for %s successfully." "$hostname" 1217323adacSDevin Teske fi 1227323adacSDevin Teske 1237323adacSDevin Teske setvar $VAR_NFS_HOST "$hostname" 1247323adacSDevin Teske 1257323adacSDevin Teske device_nfs set type $DEVICE_TYPE_NFS 1267323adacSDevin Teske device_nfs set init f_media_init_nfs 1277323adacSDevin Teske device_nfs set get f_media_get_nfs 1287323adacSDevin Teske device_nfs set shutdown f_media_shutdown_nfs 1297323adacSDevin Teske device_nfs set private device_network # in name only (deref'd later) 1307323adacSDevin Teske 1317323adacSDevin Teske f_struct_copy device_nfs device_media 1327323adacSDevin Teske f_struct_free device_nfs 1337323adacSDevin Teske 1347323adacSDevin Teske return $SUCCESS 1357323adacSDevin Teske} 1367323adacSDevin Teske 1377323adacSDevin Teske# f_media_init_nfs $device 1387323adacSDevin Teske# 1397323adacSDevin Teske# Initializes the NFS media device. Returns success if able to mount the NFS 1407323adacSDevin Teske# device using mount_nfs(1). 1417323adacSDevin Teske# 1427323adacSDevin Teske# The variables (from variable.subr) used to initialize the NFS mount are as 1437323adacSDevin Teske# follows (all of which are configured manually/optionally from the options 1447323adacSDevin Teske# menu): 1457323adacSDevin Teske# 1467323adacSDevin Teske# VAR_NFS_TCP [Optional] 1477323adacSDevin Teske# If non-NULL, adds the "tcp" option via `-o' to mount_nfs(8). 1487323adacSDevin Teske# VAR_NFS_V3 [Optional] 1497323adacSDevin Teske# If non-NULL, adds the "nfsv3" option via `-o' to mount_nfs(8). 1507323adacSDevin Teske# VAR_NFS_SECURE [Optional] 1517323adacSDevin Teske# If non-NULL, adds the "-P" flag to mount_nfs(8). 1527323adacSDevin Teske# VAR_SLOW_ETHER [Optional] 1537323adacSDevin Teske# If non-NULL, adjusts the read/write size to avoid timeouts. 1547323adacSDevin Teske# 1557323adacSDevin Teskef_media_init_nfs() 1567323adacSDevin Teske{ 157d4ae33f0SDevin Teske local funcname=f_media_init_nfs 1587323adacSDevin Teske local dev="$1" name err 1597323adacSDevin Teske 160*9ecd54f2SDevin Teske $dev get name name || return $FAILURE 1617323adacSDevin Teske f_dprintf "Init routine called for NFS device. name=[%s]" \ 1627323adacSDevin Teske "$name" 1637323adacSDevin Teske 1647323adacSDevin Teske if [ "$NFS_MOUNTED" ]; then 1657323adacSDevin Teske f_dprintf "NFS device already mounted." 1667323adacSDevin Teske return $SUCCESS 1677323adacSDevin Teske fi 1687323adacSDevin Teske 169*9ecd54f2SDevin Teske if ! f_device_init device_network; then 1707323adacSDevin Teske f_dprintf "f_media_init_nfs: %s" "$msg_net_device_init_failed" 1717323adacSDevin Teske return $FAILURE 1727323adacSDevin Teske fi 1737323adacSDevin Teske 174d4ae33f0SDevin Teske if [ ! -e "$MOUNTPOINT" ]; then 175d4ae33f0SDevin Teske f_eval_catch $funcname mkdir 'mkdir -p "%s"' "$MOUNTPOINT" || 1767323adacSDevin Teske return $FAILURE 1777323adacSDevin Teske fi 1787323adacSDevin Teske 1797323adacSDevin Teske local cp tcp="" use3="" secure="" readsize=4096 writesize=4096 1807323adacSDevin Teske f_getvar $VAR_NFS_TCP cp 1817323adacSDevin Teske [ "$cp" = "YES" ] && tcp=1 1827323adacSDevin Teske f_getvar $VAR_NFS_V3 cp 1837323adacSDevin Teske [ "$cp" = "YES" ] && use3=1 1847323adacSDevin Teske f_getvar $VAR_NFS_SECURE cp 1857323adacSDevin Teske [ "$cp" = "YES" ] && secure=1 1867323adacSDevin Teske f_getvar $VAR_SLOW_ETHER cp 1877323adacSDevin Teske [ "$cp" = "YES" ] && readsize=1024 writesize=1024 1887323adacSDevin Teske 1897323adacSDevin Teske local options="rsize=$readsize,wsize=$writesize" 1907323adacSDevin Teske [ "$use3" ] && options="$options,nfsv3" 1917323adacSDevin Teske [ "$tcp" ] && options="$options,tcp" 1927323adacSDevin Teske 193d4ae33f0SDevin Teske if ! f_eval_catch -dk err $funcname mount_nfs \ 194d4ae33f0SDevin Teske 'mount_nfs %s -o "%s" "%s" "%s"' \ 195d4ae33f0SDevin Teske "${secure:+-P}" "$options" "$name" "$MOUNTPOINT" 1967323adacSDevin Teske then 1977323adacSDevin Teske err="${err#mount_nfs: }" 1987323adacSDevin Teske f_show_msg "$msg_error_mounting_device" \ 1997323adacSDevin Teske "$name" "$MOUNTPOINT" "$err" 2007323adacSDevin Teske f_struct device_network && 201*9ecd54f2SDevin Teske f_device_shutdown device_network 2027323adacSDevin Teske return $FAILURE 2037323adacSDevin Teske fi 2047323adacSDevin Teske NFS_MOUNTED=1 2057323adacSDevin Teske 2067323adacSDevin Teske f_dprintf "Mounted NFS device %s onto %s" "$name" "$MOUNTPOINT" 2077323adacSDevin Teske 2087323adacSDevin Teske return $SUCCESS 2097323adacSDevin Teske} 2107323adacSDevin Teske 211dde7be41SDevin Teske# f_media_get_nfs $device $file [$probe_type] 2127323adacSDevin Teske# 213424d0badSDevin Teske# Returns data from $file on a mounted NFS device. Similar to cat(1). If 214dde7be41SDevin Teske# $probe_type is present and non-NULL, returns success if $file exists. If 215dde7be41SDevin Teske# $probe_type is equal to $PROBE_SIZE, prints the size of $file in bytes to 216dde7be41SDevin Teske# standard-out. 2177323adacSDevin Teske# 2187323adacSDevin Teskef_media_get_nfs() 2197323adacSDevin Teske{ 220dde7be41SDevin Teske local dev="$1" file="$2" probe_type="$3" 221*9ecd54f2SDevin Teske local name 2227323adacSDevin Teske 223*9ecd54f2SDevin Teske $dev get name name 224dde7be41SDevin Teske f_dprintf "f_media_get_nfs: dev=[%s] file=[%s] probe_type=%s" \ 225*9ecd54f2SDevin Teske "$name" "$file" "$probe_type" 2267323adacSDevin Teske 227dde7be41SDevin Teske f_media_generic_get "$MOUNTPOINT" "$file" "$probe_type" 2287323adacSDevin Teske} 2297323adacSDevin Teske 2307323adacSDevin Teske# f_media_shutdown_nfs $device 2317323adacSDevin Teske# 2327323adacSDevin Teske# Shuts down the NFS device using umount(8). Return status should be ignored. 2337323adacSDevin Teske# 2347323adacSDevin Teskef_media_shutdown_nfs() 2357323adacSDevin Teske{ 236d4ae33f0SDevin Teske local funcname=f_media_shutdown_nfs 2377323adacSDevin Teske local dev="$1" err 2387323adacSDevin Teske 239f677a9e2SDevin Teske [ "$NFS_MOUNTED" ] || return $FAILURE 2407323adacSDevin Teske 2417323adacSDevin Teske f_dprintf "Unmounting NFS partition on %s" "$MOUNTPOINT" 242d4ae33f0SDevin Teske if ! f_eval_catch -dk err $funcname umount \ 243d4ae33f0SDevin Teske 'umount -f "%s"' "$MOUNTPOINT" 244d4ae33f0SDevin Teske then 2457323adacSDevin Teske err="${err#umount: }"; err="${err#*: }" 2467323adacSDevin Teske f_show_msg "$msg_could_not_unmount_the_nfs_partition" \ 2477323adacSDevin Teske "$MOUNTPOINT" "$err" 2487323adacSDevin Teske else 2497323adacSDevin Teske NFS_MOUNTED= 2507323adacSDevin Teske fi 2517323adacSDevin Teske} 2527323adacSDevin Teske 2537323adacSDevin Teske############################################################ MAIN 2547323adacSDevin Teske 2557323adacSDevin Teskef_dprintf "%s: Successfully loaded." media/nfs.subr 2567323adacSDevin Teske 2577323adacSDevin Teskefi # ! $_MEDIA_NFS_SUBR 258