This document pertains to the NeXTSTEP operating system, which is no longer a supported product of Apple Computer. This information is provided only as a convenience to our customers who have not yet upgraded their systems, and may not apply to OPENSTEP, WebObjects, or any other product of Apple Enterprise Software. Some questions in this Q&A document may not apply to version 3.3 or to any given specific version of NeXTSTEP.
Q: UserManager is unable to add a new user. For example, when I try to select a domain for a new user, a panel displays the following message:
NetInfo Failure, Unable to open connection to NetInfo Domain <chosen domain>, error was 'No such directory'. The user can't be added to the chosen domain as the correct domain can't be selected.
What's going on?
A: UserManager implicitly relies on the existence of NetInfo directories users, groups, and aliases. They are created by HostManager for the network domain or are there by default for the local domain. However, if a custom multi-level NetInfo hierarchy is built, the directories might not necessarily be there. If any of those three directories is missing, UserManager is not able to open the domain and thus can't add the new user.
A workaround is the following:
1) Launch NetInfoManager.
2) Open the appropriate domain.
3) Create a new subdirectory of the root domain, using the New Subdirectory command from the Domain submenu.
4) Double-click the newly created Subdirectory labeled NewValue.
5) Change the value of the name property to that of the missing directory. Repeat for any other missing directories.
You should now be able to open the appropriate domain to create a new user in UserManager.
Q: How do you execute ~/.login, ~/.cshrc, ~/.profile, or ~/.logout without invoking Terminal, Shell, or a similar sort of shell-based terminal emulator? Is there a hook in Workspace Manager that allows you do something when you log in or log out?
A: All the shell run control files (the ones mentioned above) are shell-specific. .cshrc, .login, and .logout pertain to the C-Shell; .profile pertains to the Bourne Shell. Only those programs examine and execute these files. (By implication, then, if your login shell is neither csh nor sh, these files are not executed even when you launch Terminal or Shell.)
There is a "LoginHook" and a "LogoutHook" in loginwindow. The LoginHook is run just before loginwindow launches the specified workspace (by default, the NeXT Workspace Manager; but this can be overridden in the user's defaults database), and after account verification. Note that the LoginHook is NOT run under the Workspace Manager, but rather is run BEFORE the Workspace Manager. LogoutHook is run after the Workspace Manager terminates.
To set up these hooks, type:
myhost% su
myhost# dwrite loginwindow LoginHook someProgram
myhost# dwrite loginwindow LogoutHook someOtherProgram
myhost# exit
where the final argument to dwrite is the name of whatever program you want to run.This creates the default on a machine-by-machine basis, since the information is stored in the directory /.NeXT. (Of course, if you have netboot clients, it need only be done on the servers of all the clients, since the root directory is shared.)
Note that neither hook is run if an automatic "me" login is performed. The real philosophy behind the hooks is to provide additional accounting or authentication, rather than setting up the Workspace Manager's environment. If something is required within the Workspace Manager's environment, the only real option is to have a program of your specification autolaunched from your dock.
Q: I tried to change my password using the passwd command or Preferences.app, but it didn't seem to take effect. Why not?
Q: How do I remove my password?
A: Use the Preferences application to change your password. If you are on a network composed of NEXTSTEP and non-NEXTSTEP OS's you might also need to update the NIS (formerly known as Yellow Pages) database by running the yppasswd command. If your account information is stored in NIS, run the following command in a Terminal or Shell:
machine>yppasswd your-login-name
as in: yppasswd jsmith.
If your account is stored in NetInfo--which is the default in NEXTSTEP--do the following to remove your password:
* Launch NetInfoManager.
* Open the domain where your account is stored; this is probably the root (/) domain if you
are on a Network. If you are on a standalone machine, the right (local) domain will come
up by default.
* Click the users directory , then double-click your account name. This opens the
property editor.
* Click the passwd property, then remove its value and save the changes
Removing a password that is stored in NIS is slightly more difficult. On the yp-master server do the following as root:
* Edit the /etc/passwd file and remove the passwd field from your account.
* Then run the following commands in a Shell or Terminal:
ypmaster#cd /etc/yp
ypmaster#make passwd
Q: How can I change my password from a non-NEXTSTEP system, given that the NIS (formerly known as Yellow Pages or "YP") database is mastered by NetInfo?
A: Replace the standard yppasswd command on the non-NEXTSTEP system with a shell script that rsh's the NetInfo master server and passes the arguments on as arguments to passwd. Something like:
#
# replace the yppasswd command on your non-NeXT machine with this shell
# script. This shell script checks if it received a username as an
# argument, if not it will default to the user that executes the command.
# The script turns echo off, logs into the configuration server and runs
# the passwd command that updates the NetInfo database. It then restores
# the echo status to it's initial value.
#
#!/bin/csh
set Server = "ni_server"
set Account = ${1}
if (${Account} == "") then
set Account = `whoami`
endif
(stty > /dev/tty) |& grep '.-echo' >& /dev/null
if ( ${status} != 0 ) then
set NoEcho=0
else
set NoEcho=1
endif
stty -echo
rsh ${Server} /bin/passwd $Account
if ( ${NoEcho} == 0 ) then
stty echo
endif
Then, every 5 minutes (or 15, or 30...), have cron test for changes in the password file by nidumping and comparing. If they are different, automatically perform a ypmake for the password file. Alternately, have the rsh touch a file on the master server that causes cron to dump and push the database.
Replace ni_server in the above shell script with the name of your configuration server. The shell script assumes that the hosts are equivalent, see the man page for hosts.equiv(5) for more information. Be sure to make this shell script read-only and set its ownership to root.
Q: How do I create a user account with localized defaults?
A: If you specify a language other than English when you create new user accounts using the UserManager application in OPENSTEP 4.0 for Mach, some OPENSTEP defaults in the new account will not correctly match the 3.3-style defaults given to the account. The Language, Measurement Units, and Paper Size values displayed in Preferences are not the ones that will be used by OPENSTEP apps (which will use English/US defaults for these values).
If you are creating many user accounts, you can use program hooks in UserManager to modify user accounts to have the correct OPENSTEP defaults as you create the accounts.
Copy the following text into a file with execute permissions turned on.
Then select Defaults in the User menu of the Usermanager application to bring up the User Defaults panel. Select "After creating a user's home" in the Program hooks pop-down menu in the User Defaults panel and set the Program hooks path to point to the file where you saved the above text.
For more information on using Program Hooks, see the "Program Hooks" section in Chapter 5 ("Managing User Accounts and User Groups") of the online NEXTSTEP Network and System Administration manual (in /NextLibrary/Bookshelves if you have the Documentation package installed).
If you are just working with a few accounts it may be easier to synchronize the OPENSTEP and 3.3-style defaults for the individual accounts. To do this, you should select a different value in Preferences for each of the Language, Measurement Units, and Paper Size defaults and then re-select the values that you want.