The basic idea is to put the implementation of the different services offered to access the databases in separate modules. This has some advantages:
To fulfill the first goal above, the ABI of the modules will be described below. For getting the implementation of a new service right it is important to understand how the functions in the modules get called. They are in no way designed to be used by the programmer directly. Instead the programmer should only use the documented and standardized functions to access the databases.
The databases available in the NSS are
Groups of users, see Group Database.
Group passphrase hashes and related information.
Host names and numbers, see Host Names.
Supplementary group access list.
Network wide list of host and users, see Netgroup Database.
Network names and numbers, see Networks Database.
User identities, see User Database.
Network protocols, see Protocols Database.
Public keys for Secure RPC.
Remote procedure call names and numbers.
Network services, see Services Database.
User passphrase hashes and related information.
More databases may be added later.