1.\" Copyright (C) 1996 2.\" David L. Nugent. All rights reserved. 3.\" 4.\" Redistribution and use in source and binary forms, with or without 5.\" modification, are permitted provided that the following conditions 6.\" are met: 7.\" 1. Redistributions of source code must retain the above copyright 8.\" notice, this list of conditions and the following disclaimer. 9.\" 2. Redistributions in binary form must reproduce the above copyright 10.\" notice, this list of conditions and the following disclaimer in the 11.\" documentation and/or other materials provided with the distribution. 12.\" 13.\" THIS SOFTWARE IS PROVIDED BY DAVID L. NUGENT AND CONTRIBUTORS ``AS IS'' AND 14.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16.\" ARE DISCLAIMED. IN NO EVENT SHALL DAVID L. NUGENT OR CONTRIBUTORS BE LIABLE 17.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23.\" SUCH DAMAGE. 24.\" 25.\" $FreeBSD$ 26.\" 27.Dd March 30, 2007 28.Dt PW.CONF 5 29.Os 30.Sh NAME 31.Nm pw.conf 32.Nd format of the pw.conf configuration file 33.Sh DESCRIPTION 34The file 35.In /etc/pw.conf 36contains configuration data for the 37.Xr pw 8 38utility. 39The 40.Xr pw 8 41utility is used for maintenance of the system password and group 42files, allowing users and groups to be added, deleted and changed. 43This file may be modified via the 44.Xr pw 8 45command using the 46.Ar useradd 47command and the 48.Fl D 49option, or by editing it directly with a text editor. 50.Pp 51Each line in 52.Pa /etc/pw.conf 53is treated either a comment or as configuration data; 54blank lines and lines commencing with a 55.Ql \&# 56character are considered comments, and any remaining lines are 57examined for a leading keyword, followed by corresponding data. 58.Pp 59Keywords recognized by 60.Xr pw 8 61are: 62.Bl -tag -width password_days -offset indent -compact 63.It defaultpasswd 64affect passwords generated for new users 65.It reuseuids 66reuse gaps in uid sequences 67.It reusegids 68reuse gaps in gid sequences 69.It nispasswd 70path to the 71.Tn NIS 72passwd database 73.It skeleton 74where to obtain default home contents 75.It newmail 76mail to send to new users 77.It logfile 78log user/group modifications to this file 79.It home 80root directory for home directories 81.It homemode 82permissions for home directory 83.It shellpath 84paths in which to locate shell programs 85.It shells 86list of valid shells (without path) 87.It defaultshell 88default shell (without path) 89.It defaultgroup 90default group 91.It extragroups 92add new users to this groups 93.It defaultclass 94place new users in this login class 95.It minuid 96.It maxuid 97range of valid default user ids 98.It mingid 99.It maxgid 100range of valid default group ids 101.It expire_days 102days after which account expires 103.It password_days 104days after which password expires 105.El 106.Pp 107Valid values for 108.Ar defaultpasswd 109are: 110.Bl -tag -width password_days -offset indent -compact 111.It no 112disable login on newly created accounts 113.It yes 114force the password to be the account name 115.It none 116force a blank password 117.It random 118generate a random password 119.El 120.Pp 121The second and third options are insecure and should be avoided if 122possible on a publicly accessible system. 123The first option requires that the superuser run 124.Xr passwd 1 125to set a password before the account may be used. 126This may also be useful for creating administrative accounts. 127The final option causes 128.Xr pw 8 129to respond by printing a randomly generated password on stdout. 130This is the preferred and most secure option. 131The 132.Xr pw 8 133utility also provides a method of setting a specific password for the new 134user via a filehandle (command lines are not secure). 135.Pp 136Both 137.Ar reuseuids 138and 139.Ar reusegids 140determine the method by which new user and group id numbers are 141generated. 142A 143.Ql \&yes 144in this field will cause 145.Xr pw 8 146to search for the first unused user or group id within the allowed 147range, whereas a 148.Ql \&no 149will ensure that no other existing user or group id within the range 150is numerically lower than the new one generated, and therefore avoids 151reusing gaps in the user or group id sequence that are caused by 152previous user or group deletions. 153Note that if the default group is not specified using the 154.Ar defaultgroup 155keyword, 156.Xr pw 8 157will create a new group for the user and attempt to keep the new 158user's uid and gid the same. 159If the new user's uid is currently in use as a group id, then the next 160available group id is chosen instead. 161.Pp 162On 163.Tn NIS 164servers which maintain a separate passwd database to 165.Pa /etc/master.passwd , 166this option allows the additional file to be concurrently updated 167as user records are added, modified or removed. 168If blank or set to 'no', no additional database is updated. 169An absolute pathname must be used. 170.Pp 171The 172.Ar skeleton 173keyword nominates a directory from which the contents of a user's 174new home directory is constructed. 175This is 176.Pa /usr/share/skel 177by default. 178The 179.Xr pw 8 Ns 's 180.Fl m 181option causes the user's home directory to be created and populated 182using the files contained in the 183.Ar skeleton 184directory. 185.Pp 186To send an initial email to new users, the 187.Ar newmail 188keyword may be used to specify a path name to a file containing 189the message body of the message to be sent. 190To avoid sending mail when accounts are created, leave this entry 191blank or specify 192.Ql \&no . 193.Pp 194The 195.Ar logfile 196option allows logging of password file modifications into the 197nominated log file. 198To avoid creating or adding to such a logfile, then leave this 199field blank or specify 200.Ql \&no . 201.Pp 202The 203.Ar home 204keyword is mandatory. 205This specifies the location of the directory in which all new user 206home directories are created. 207.Pp 208The 209.Ar homemode 210keyword is optional. 211It specifies the creation mask of the user's home directory and is modified by 212.Xr umask 2 . 213.Pp 214The 215.Ar shellpath 216keyword specifies a list of directories - separated by colons 217.Ql \&: 218- which contain the programs used by the login shells. 219.Pp 220The 221.Ar shells 222keyword specifies a list of programs available for use as login 223shells. 224This list is a comma-separated list of shell names which should 225not contain a path. 226These shells must exist in one of the directories nominated by 227.Ar shellpath . 228.Pp 229The 230.Ar defaultshell 231keyword nominates which shell program to use for new users when 232none is specified on the 233.Xr pw 8 234command line. 235.Pp 236The 237.Ar defaultgroup 238keyword defines the primary group (the group id number in the 239password file) used for new accounts. 240If left blank, or the word 241.Ql \&no 242is used, then each new user will have a corresponding group of 243their own created automatically. 244This is the recommended procedure for new users as it best secures each 245user's files against interference by other users of the system 246irrespective of the 247.Em umask 248normally used by the user. 249.Pp 250The 251.Ar extragroups 252keyword provides an automatic means of placing new users into groups within 253the 254.Pa /etc/groups 255file. 256This is useful where all users share some resources, and is preferable 257to placing users into the same primary group. 258The effect of this keyword can be overridden using the 259.Fl G 260option on the 261.Xr pw 8 262command line. 263.Pp 264The 265.Ar defaultclass 266field determines the login class (See 267.Xr login.conf 5 ) 268that new users will be allocated unless overwritten by 269.Xr pw 8 . 270.Pp 271The 272.Ar minuid , 273.Ar maxuid , 274.Ar mingid , 275.Ar maxgid 276keywords determine the allowed ranges of automatically allocated user 277and group id numbers. 278The default values for both user and group ids are 1000 and 32000 as 279minimum and maximum respectively. 280The user and group id's actually used when creating an account with 281.Xr pw 8 282may be overridden using the 283.Fl u 284and 285.Fl g 286command line options. 287.Pp 288The 289.Ar expire_days 290and 291.Ar password_days 292are used to automatically calculate the number of days from the date 293on which an account is created when the account will expire or the 294user will be forced to change the account's password. 295A value of 296.Ql \&0 297in either field will disable the corresponding (account or password) 298expiration date. 299.Sh LIMITS 300The maximum line length of 301.Pa /etc/pw.conf 302is 1024 characters. 303Longer lines will be skipped and treated 304as comments. 305.Sh FILES 306.Bl -tag -width /etc/master.passwd -compact 307.It Pa /etc/pw.conf 308.It Pa /etc/passwd 309.It Pa /etc/master.passwd 310.It Pa /etc/group 311.El 312.Sh SEE ALSO 313.Xr passwd 1 , 314.Xr umask 2 , 315.Xr group 5 , 316.Xr login.conf 5 , 317.Xr passwd 5 , 318.Xr pw 8 319