jpaetzel d3ab0cf954 Fix a logic bug in pc-sysinstall creating partitions.
Improve exit when an error occurs.
Fix parsing to grab values which contain extra '=' signs.
Fix a bug setting the timezone properly.
Fix a usage bug when setting up with gmirror.
Allow a uzip file from local media to be used.
Allow specifying flags for "newfs" when using UFS as the file system.
Run custom commands after doing final cleanup / fstab generation
and such. Also fix using relative path for config file.

Approved by:	re (bz)
2011-09-19 05:12:53 +00:00
..

pc-sysinstall README

This file documents many of the variables used in pc-sysinstall
config scripts
#################################################################

# hostname=

Using hostname= will set the specified hostname on the
installed system

When hostname= is not present, pc-sysinstall will auto-generate
a hostname such as freebsd-XXXX or pcbsd-XXXX

# installMode=(fresh/upgrade/extract)

Set the type of install we are doing.

Fresh installs will format and mount the target disks before
extracting the install images to the system. Using this mode
it is also possible to do a system restore, by specifying a
full system backup as the install source.

Upgrades will mount the target disk, and extract the system
archive to the disk, overwriting files on the disk. 
The conf/exclude-from-upgrade file can be used to specify
additional files to exclude from overwriting during the
install process.

Extract will skip any disk setup, and perform an installation
to the directory specified by "installLocation=". This location
should be a directory with your pre-mounted file-systems ready
for file extraction. When using the "extract" option, /etc/fstab
on the installed system will *not* be automatically configured. 

# installLocation=

Used only when installMode is set to extract. 

This is set to the location you want to extract your system to,
and should already be mounted properly. 

# installInteractive=(yes or no)

Set if the installer is running in interactive mode, and
is able to prompt for input from the user, defaults to no


########################################################################
# NETWORK SETTINGS
########################################################################

# netDev=(AUTO-DHCP or <nic>)

netDev specifies what type of networking to enable for the installer
Can be set to AUTO-DHCP or to a network interface, such as et0

When set to AUTO-DHCP, pc-sysinstall will probe for all network devices
and attempt to set DHCP mode on each, until a working network connection
is established

If netDev= is set to a network interface such as et0, the following options
will need to be set in order to enable the interface

# netIP=(IP address such as 192.168.0.100)

 Set netIP to an address that you wish to have the interface specified in
 netDev set to
 Only used when netDev is not set to AUTO-DHCP

# netMask=(Netmask such as 255.255.255.0)

Set netMask to the address you with to have the interface specified in
netDev set to
Only used when netDev is not set to AUTO-DHCP

 
# netNameServer=(DNS Server such as 192.168.0.1)

Set netNameServer to the DNS address you want to use during the install
Only used when netDev is not set to AUTO-DHCP


# netDefaultRouter=(192.168.0.1)

Set netDefaultRouter to the gateway you wish to have the installer use
Only used when netDev is not set to AUTO-DHCP



# netSaveDev=(AUTO-DHCP or network interface)

netSaveDev specifies what networking to enable on the installed system

When set to AUTO-DHCP, pc-sysinstall will probe all network interfaces, and
set them all to DHCP in the systems /etc/rc.conf file. Wireless devices will also
have the corresponding wlan[0-9] device created. 

When set to a network interface, pc-sysinstall will set the target device with
the settings specified by the variables below.

# netSaveIP=192.168.0.49
# netSaveMask=255.255.255.0
# netSaveNameServer=208.67.222.222
# netSaveDefaultRouter=192.168.0.1




########################################################################
# DISK SLICE SETTINGS
########################################################################

The following section specifies the target disk(s) to be used in the
install or upgrade. 

# disk0=(disk device, such as ad0)

The diskX= variable should be set to the target device for this drive, such
as ad0, da0
The first should begin with disk0=, and additional drives to disk1=, disk2
if additional disks are to be setup. 

When doing an upgrade, the disk0= line should be set to the root device or 
root zpool of the target system to update. I.E:
 # disk0=tank0
 # disk0=ada0s1a


# partition=(all, free, s1, s1, s3, s4, image)

After setting disk[0-9], the partition= variable is used to specify which target
partition we will be working with for this device.

Setting this to "all" will setup the disk with a single FreeBSD slice as "s1"

Setting this to "free" will allow pc-sysinstall to search for the first available
primary slice with free space, and create the slice. 

Setting this to "s1, s2, s3 or s4" will use the specified MBR slice.

Setting this to "image" will use an image to configure the disk.

(This tag is unused for upgrades)

# partscheme=(MBR/GPT)

When performing a "full" disk (partition=all), the partscheme= variable is used
to determine the partition scheme type gpart will be using on the disk. Valid
choices are MBR or GPT. 

# mirror=(disk device such as ad1)

Setting the mirror= variable will setup the target device as a gmirror
of the diskX= device. The mirror device must be the same size or larger
than the drive being mirrored. 
 

# mirrorbal=(load, prefer, round-robin, split)

Allows the setting of the mirror balance method to be used, if not
specified this defaults to "round-robin"

# bootManager=(none, bsd)

Setting this option will instruct pc-sysinstall to install the BSD boot Manager,
or leave it empty

# image=(/path/to/image/file) (/mountpoint)

Setting this option will instruct pc-sysinstall to write the image file
specified by the path to the disk.

# commitDiskPart

This command must be placed at the end of the diskX= section, before starting
the listing of any additional diskX= directives. 


########################################################################
# DISK PARTITION / MOUNT SETTINGS
########################################################################

The following settings specify the partitioning / mount points to setup
on the target partition

# disk0-part=UFS+S 500 / (-n -o time)
# disk0-part=SWAP 2000 none
# disk0-part=UFS.eli 500 /usr
# encpass=mypass
# disk0-part=UFS+J 500 /tmp
# disk0-part=ZFS 0 /data,/storage (mirror: ad1)
# commitDiskLabel

The above values instructs pc-sysinstall which partitions / mounts
to create on the target drive / slice, specified by "disk0".
(disk0 will resolve to the drive / slice specified in the previous section)

The notation is as follows:
<File System Type> <Size> <Mountpoint>

Available FileSystems: 
  UFS - Standard UFS2 FileSystem
UFS+S - UFS2 + Softupdates enabled
UFS+SUJ - UFS2 + Soft Updates + Journaling enabled
UFS+J - UFS2 + Journaling through gjournal
  ZFS - Z File System, pools / mounts created automatically
 SWAP - BSD Swap space partition, mountpoint should be set to "none"

Adding the ".eli" extension to any of the above file systems
will enable disk encryption via geli
(UFS.eli, UFS+S.eli, UFS+SUJ.eli, UFS+J.eli, ZFS.eli, SWAP.eli)

If you with to use a passphrase with this encrypted partition, on the next line
the flag "encpass=" should be entered:
encpass=mypass

All sizes are expressed in MegaBytes
Specifying a size 0 instructs pc-sysinstall to use the rest of the 
available slice size, and should only be used for the last partition / mount

When using "UFS" and its various types, it is possible to specify custom options
for newfs using (). For examplei:
disk0-part=UFS+SUJ 1000 / (-o time)
In this case "-o time" would be passed to newfs when creating the "/" filesystem.


When using "ZFS" specifically, it is possible to specify additional disks / partitions
to include in the zpool. By using the syntax: (mirror: ad1,ad2) or (raidz: ad1,ad2), it is possible
to include the disk "ad1" into the zpool for this partition, using the raidz / mirror methods.
If you with to just include the disk into the pool in "basic" mode, then use (ad1,ad2) with no flags

########################################################################
# INSTALL OPTIONS / SOURCES
########################################################################

The following settings specify the type, locations and sources
for this installation

# installMedium=(dvd, usb, ftp, rsync, image)

Set installMedium= to the source type we will be using for this install.

Available Types:
  dvd - Search for and mount the DVD which contains the install archive
  usb - Search for and mount the USB drive which contains the install archive
  ftp - The install archive will be fetched from a FTP / HTTP server before install
rsync - Pull the system data from a ssh + rsync server, specified with variables below
image - Install system from an image

# installType=(PCBSD, FreeBSD)

Set the type of system we are installing, PCBSD or FreeBSD

# installFile=fbsd-release.tbz

The installer archive, if not using the defaults specified in conf/pc-sysinstall.conf

# packageType=(tar, uzip, split)

The archive type we are extracting from when using dvd, usb or ftp

# ftpPath=ftp://ftp.pcbsd.org/pub/8.0/netinstall

Location of the installer archive when using a installMedium=ftp

# rsyncPath=life-preserver/back-2009-11-12T14_53_14

The location of the rsync data on the remote server when using installMedium=rsync

# rsyncUser=rsyncuser

The username to use for the ssh server running rsync

# rsyncHost=192.168.0.50

The rsync / ssh server we wish to connect to

# rsyncPort=22

The port to use when connecting to a ssh + rsync server

# installComponents=amarok,firefox,ports

The specified components to install, view available with "./pc-sysinstall list-components"


########################################################################
# UPGRADE OPTIONS
########################################################################

Options specific to performing an upgrade

# upgradeKeepDesktopProfile=(yes/no)

This option allows you to specify if you wish to keep your existing users desktop
profile data. The default is NO, and your existing profile will be moved to 
.kde4.preUpgrade automatically. 

########################################################################
# USER OPTIONS
########################################################################

Options for setting up usernames and passwords on the installed system

# rootPass=root

Set the root password of the installed system to the specified plaintext string

# rootEncPass=<encryptedstring>

Set the root password of the installed system to the specified encrypted string

The below variables are used to setup a user on the installed system
Be sure to call commitUser after after adding these values, and before
starting another user block

# userName=kris
# userComment=Kris Moore
# userPass=mypass
or
# userEncPass=<encryptedstring>
# userShell=/bin/csh
# userHome=/home/kris
# userGroups=wheel,operator
# commitUser

########################################################################
# RUN COMMANDS
########################################################################

The following variables can be set to run commands post-installation,
allowing the user to further tweak / modify the system

# runCommand=

Run the specified command within chroot of the installed system

# runScript=

runScript will copy the specified script into FSMNT, and run it in chroot of the system
Useful when you have a 3rd party script on the DVD / USB, and you want to copy it into
the installed system and run

# runExtCommand=

runExtCommand is used when you wish to run a command outside the chroot
The variable $FSMNT is set to the mount-point of your installed system


########################################################################
# PC-BSD SPECIFIC OPTIONS
########################################################################

Options for time-zones and NTP on the installed system

# timeZone=

timeZone can be set to the zone file in /usr/share/zoneinfo/ that is to be used
example: America/New_York

# enableNTP= (yes / no)

set enableNTP to yes or no to enable or disable the NTP service on the system


########################################################################
# PC-BSD SPECIFC OPTIONS
########################################################################

Options specific to installing PC-BSD, such as localization, and KDE settings

# localizeLang=en

localizeLang will set the system console and Desktop to the target language

# localizeKeyLayout=en

localizeKeyLayout updates the system's xorg config to set the keyboard layout

# localizeKeyModel=pc104

localizeKeyModel updates the system's xorg config to set the keyboard model

# localizeKeyVariant=intl

localizeKeyVariant is used to update the xorg config to set the keyboard variant

# autoLoginUser=kris

Setting autoLoginUser will enable the specified user to log into the desktop 
automatically without entering a password

$FreeBSD$