File: README.pam_script

package info (click to toggle)
libpam-script 1.1.9-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 224 kB
  • sloc: ansic: 374; perl: 348; sh: 179; makefile: 76
file content (72 lines) | stat: -rw-r--r-- 2,987 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
The pam_script tool
-------------------

Pam-script confusingly provides the pam_script tool for running generic
pam-script programs in ./pam-script.d/ or for performing some basic
administrative functions like creating or removing symbolic links to
a pam-script enabled script or program.  Read the other READMEs or man
pages for further info regarding the attributes of a pam-script program.
This README will focus on the pam_script tool and its role in the
pam-script universe.

The pam_script tool serves two purposes.  Primarily running scripts
in ./pam-script.d/, and secondly, managing the symbolic links in
./pam-script.d/ or elsewhere of the various PAM module-types.

The various PAM module-types are:
	auth		- authorization
	acct		- account
	passwd		- password changes
	ses_open	- session start
	ses_close	- session end

If the pam_script tool is set-up with the various symbolic links as
described in the README, then it will run the appropriate scripts
in the ./pam-script.d/ directory.  For example, say the PAM stack
invoked pam-script with a PAM module-type of acct, then pam-script
will run pam_script_acct, which is a symbolic link to pam_script.
The pam_script tool sees that it was called as pam_script_acct and
then runs all scripts in ./pam-script.d/ that end with _acct.
Then returns 0 if all ran successfully, else 1 if any one of them
failed with a non-zero return status.

In addition, pam_script will set the PAM_SCRIPT_STATUS environment
variable with the overall exit status so far, so the script can 
choose whether to perform its action or not.  If PAM_SCRIPT_STATUS
is already non-zero then there may be no point to run any further.
However, some scripts may need to be run whether the PAM_SCRIPT_STATUS
is non-zero or not.

Also, the command line arguments passed to pam-script (in the
pam-script.conf) are also passed on to all the scripts invoked from
within ./pam-script.d/.

Link Administration
-------------------

The pam_script tool can create all or some of the needed symbolic
links.  The goal is to allow a third party package to drop a script
or program in ./pam-script.d/, then create the set of symbolic links
within the same directory so it may become part of the PAM stack
via pam-script without the necessity of crafting a full PAM module.

The program dropped into ./pam-script.d/ should check how it is called
and act accordingly.  Check the provided example scripts, on how to
do this.

Report problems/bugs to R.K. Owen <rkowen@nersc.gov>

COPYRIGHT AND LICENCE

AUTHOR: R K Owen, Ph.D., <rkowen@nersc.gov>
of the National Energy Research Scientific Computing Center (NERSC),
a Division of the Lawrence Berkeley National Laboratory (LBL),
funded by the U.S. Department of Energy.

Copyright (C) 2008 The Regents of the University of California

This is free software; you can redistribute it
and/or modify it under the terms of the GNU General
Public License as published by the Free Software Foundation;
version 2.0 of the License.