readers.conf - Access control and configuration for nnrpd
There are two types of entries in readers.conf: parameter/value pairs and configuration groups. Blank lines and anything after a number sign ("#") are ignored, unless the character "#" is escaped with "\". The maximum number of characters on each line is 8,191.
Parameter/value pairs consist of a keyword immediately followed by a colon, at least one whitespace character, and a value. The case of the parameter is significant (parameter should generally be in all lowercase), and a parameter may contain any characters except colon, "#", and whitespace. An example:
hosts: *.example.comValues that contain whitespace should be quoted with double quotes, as in:
hosts: "*.example.com, *.example.net"If the parameter does not contain whitespace, such as:
hosts: *.example.com,*.example.netit's not necessary to quote it, although you may wish to anyway for clarity.
There is no way to continue a line on the next line, and therefore no way to have a single paramenter with a value longer than about 8,180 characters.
Many parameters take a boolean value. For all such parameters, the value may be specified as "true", "yes", or "on" to turn it on and may be any of "false", "no", or "off" to turn it off. The case of these values is not significant.
There are two basic types of configuration groups, auth and access. The auth group provides mechanisms to establish the identity of the user, who they are. The access group determines, given the user's identity, what they're permitted to do. Writing a readers.conf file for your setup is a two-step process, first assigning an identity to each incoming connection using auth groups, and then giving each identity appropriate privileges with access group.
A user identity, as established by an auth group, looks like an e-mail address; in other words, it's in the form ``<username>@<domain>'' (or sometimes just ``<username>'' if no domain is specified.
An auth group definition looks like:
auth <name> { hosts: <host-wildmat> auth: <auth-program> res: <res-program> default: <defuser> default-domain: <defdomain> # ...possibly other settings }The <name> is used as a label for the group and is only for documentation purposes.
A given auth group applies only to hosts whose name or IP address matches the wildmat expression given with the hosts: parameter (comma-separated wildmat expressions allowed, but "@" is not supported). Rather than wildmat expressions, you may also use CIDR notation to match any IP address in a netblock; for example, ``10.10.10.0/24'' will match any IP address between 10.10.10.0 and 10.10.10.255 inclusive.
For any connection from a host that matches that wildmat expression or netblock, <res-program> (the program given with the res: parameter, if present) is run to determine the identity of the user just from the connection information. If it fails, or if the res: parameter isn't present, the user is assigned an identity of ``<defuser>@<defdomain>''; in other words, the values of the default: and default-domain: parameters are used. If <res-program> only returns a username, <defdomain> is used as the domain.
If the user later authenticates via the AUTHINFO USER/PASS commands, the provided username and password is passed to <auth-program>, the value of the auth: parameter (if present). If this succeeds and returns a different identity than the one assigned at the time of the connection, it is matched against the available access groups again and the actions the user is authorized to do may change.
When matching auth groups, the last auth group in the file that matches a given connection or username/password combination is used.
An access group definition usually looks like:
access <name> { users: <identity-wildmat> newsgroups: <group-wildmat> # ...possibly other settings }Again, <name> is just for documentation purposes. This says that all users whose identity matches <identity-wildmat> can read and post to all newsgroups matching <group-wildmat> (as before, comma-separated wildmat expressions are allowed, but "@" is not supported). Alternately, you can use the form:
access <name> { users: <identity-wildmat> read: <read-wildmat> post: <post-wildmat> }and matching users will be able to read any group that matches <read-wildmat> and post to any group that matches <post-wildmat>. You can also set several other things in the access group as well as override various inn.conf(5) parameters for just that group of users.
Just like with auth groups, when matching access groups the last matching one in the file is used to determine the user's permissions.
There is one additional special case to be aware of. When forming particularly complex authentication and authorization rules, it is sometimes useful for the identities provided by a given auth group to only apply to particular access groups; in other words, rather than checking the identity against the users: parameter of every access group, it's checked against the users: parameter of only some specific access groups. This is done with the key: parameter. For example:
auth example { key: special hosts: *.example.com default: <SPECIAL> }
access example { key: special users: <SPECIAL> newsgroups: * }In this case, the two key: parameters bind this auth group with this access group. For any incoming connection matching ``*.example.com'' (assuming there isn't any later auth group that also matches such hosts), no access group that doesn't have ``key: special'' will even be checked. Similarly, the above access group will only be checked if the user was authenticated with an auth group containing ``key: special''. This mechanism normally isn't useful.
Also note in the above that there's no default-domain: parameter, which means that no domain is appended to the default username and the identity for such connections is just ``<SPECIAL>''. Note that some additional add-ons to INN may prefer that authenticated identities always return a full e-mail address (including a domain), so you may want to set up your system that way.
Below is the full list of allowable parameters for auth groups and access groups, and after that are some examples that may make this somewhat clearer.
Note that if you have a large number of patterns that can't be merged into broader patterns (such as a large number of individual systems scattered around the net that should have access), the hosts: parameter may exceed the maximum line length of 8,192 characters. In that case, you'll need to break that auth group into multiple auth groups, each with a portion of the hosts listed in its hosts: parameter, and each assigning the same user identity.
All hosts match if this parameter does not exist.
One auth group can have multiple res: parameters, and they will be tried
in the order they're listed in and the results of the first successful one
will be used.
Note that if this parameter is given, allownewnews in inn.conf(5) is ignored for connections matching this access group and the ability of the client to use NEWNEWS is entirely determined by the presence of "N" in the access string. If you want to support NEWNEWS, make sure to include "N" in the access string when you use this parameter.
Note that if this parameter is given and "R" isn't present in the access string, the client cannot read regardless of newsgroups: or read: parameters. Similarly, if this parameter is given and "P" isn't present, the client cannot post. This use of access: is deprecated and confusing; it's strongly recommended that if the access: parameter is used, "R" and "P" always be included in the access string and newsgroups:, read:, and post: be used to control access. (To grant read access but no posting access, one can have just a read: parameter and no post: parameter.)
In addition, all of the following parameters are valid in access groups and override the global setting in inn.conf(5). See inn.conf(5) for the descriptions of these parameters: addnntppostingdate, addnntppostinghost, backoff_auth, backoff_db, backoff_k, backoff_postfast, backoff_postslow, backoff_trigger, checkincludedtext, clienttimeout, complaints, domain, fromhost, localmaxartsize, moderatormailer, nnrpdauthsender, nnrpdcheckart, nnrpdoverstats, nnrpdposthost, nnrpdpostport, organization, pathhost, readertrack, spoolfirst, and strippostcc.
auth example.com { hosts: "*.example.com, example.com" default: <LOCAL> }
access full { newsgroups: * }Note that the access realm has no users: key and therefore applies to any user identity. The only available auth realm only matches hosts in the example.com domain, though, so any connections from other hosts will be rejected immediately.
If you have some systems that should only have read-only access to the server, you can modify the example above slightly by adding an additional auth and access group:
auth lab { hosts: "*.lab.example.com" default: <LAB> }
access lab { users: <LAB> read: * }If those are put in the file after the above example, they'll take precedence (because they're later in the file) for any user coming from a machine in the lab.example.com domain, and those users will only have read access, not posting access.
Here's a similar example for a news server that accepts connections from anywhere but requires the user to specify a username and password. The username and password is first checked against an external database of usernames and passwords, and then against the system shadow password file:
auth all { auth: "ckpasswd -d /usr/local/news/db/newsusers" auth: "ckpasswd -s" }
access full { users: * newsgroups: * }When the user first connects, there are no res: keys and no default, so they don't receive any valid identity and the connection won't match any access groups (even ones with "users: *"). Such users receive nothing but authentication required responses from nnrpd until they authenticate.
If they then later authenticate, the username and password are checked first by running ckpasswd with the -d option for an external dbm file of encrypted passwords, and then with the -s option to check the shadow password database (note that ckpasswd may have to be setgid to a shadow group to use this option). If both of those fail, the user will continue to have no identity; otherwise, they will acquire some other identity string (whatever username they specified, since the password was valid) and the access group will match, giving them full access.
Finally, here's a very complicated example. This is for an organization that has an internal hierarchy example.* only available to local shell users, who are on machines where identd can be trusted. Dialup users have to use a username and password, which is then checked against RADIUS. Remote users have to use a username and password that's checked against a database on the news server. Finally, the admin staff (users ``joe'' and ``jane'') can post anywhere, including the example.admin.* groups that are read-only for everyone else, and are exempted from the Perl filter. For an additional twist, posts from dialup users have their Sender header replaced by their authenticated identity.
auth default { auth: "ckpasswd -f /usr/local/news/db/newsusers" default: <FAIL> default-domain: example.com }
auth shell { hosts: *.shell.example.com res: ident auth: "ckpasswd -s" default: <FAIL> default-domain: shell.example.com }
auth dialup { hosts: *.dialup.example.com auth: radius default: <FAIL> default-domain: dialup.example.com }
access shell { users: *@shell.example.com read: * post: "*, !example.admin.*" }
access dialup { users: *@dialup.example.com newsgroups: *,!example.* nnrpdauthsender: true }
access other { users: "*@example.com, !<FAIL>@example.com" newsgroups: *,!example.* }
access fail { users: "<FAIL>@*" newsgroups: !* }
access admin { users: "joe@*,jane@*" newsgroups: * perlfilter: false }Note the use of different domains to separate dialup from shell users easily. Another way to do that would be with key: parameters, but this provides slightly more intuitive identity strings. Note also that the fail access group catches not only failing connections from external users but also failed authentication of shell and dialup users and dialup users before they've authenticated. The identity string given for, say, dialup users before RADIUS authentication has been attempted matches both the dialup access group and the fail access group, since it's <FAIL>@dialup.example.com, but the fail group is last so it takes precedence.
The shell auth group has an auth: parameter so that users joe and jane can, if they choose, use username and password authentication to gain their special privileges even if they're logged on as a different user on the shell machines (or if ident isn't working). When they first connect, they'd have the default access for that user, but they could then send AUTHINFO USER and AUTHINFO PASS (or AUTHINFO SIMPLE) and get their extended access.
Also note that if the users joe and jane are using their own accounts, they get their special privileges regardless of how they connect, whether the dialups, the shell machines, or even externally with a username and password.
$Id: readers.conf.5,v 1.5.2.8 2001/03/03 07:57:56 rra Exp $
Закладки на сайте Проследить за страницей |
Created 1996-2025 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |