diff options
author | Laurent Bercot <ska-skaware@skarnet.org> | 2018-02-05 14:33:50 +0000 |
---|---|---|
committer | Laurent Bercot <ska-skaware@skarnet.org> | 2018-02-05 14:33:50 +0000 |
commit | 637d71df931a2627493618b5f73eab88d18132b8 (patch) | |
tree | 4064d626ee78c175f597da108091b392ef445460 | |
parent | 35bcdd437b531072dd587f50cf9e56084974746b (diff) | |
download | pamela-637d71df931a2627493618b5f73eab88d18132b8.tar.xz |
Document what modules won't work
-rw-r--r-- | doc/building.html | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/doc/building.html b/doc/building.html index 649dc43..fdd0cd8 100644 --- a/doc/building.html +++ b/doc/building.html @@ -99,5 +99,32 @@ The <a href="pamelad.html">pamelad</a> binary will then drop its privileges and run under this uid/gid. </li> </ul> +<h2> My application is not working with pam_foobar.so! </h2> + +<p> + A pamela-type architecture can only work if modules do not try +to do anything fancy outside of the official PAM communication +channels. In particular, if it <strong>sets global state</strong>, +it will not work. PAM modules that +</p> + +<ul> + <li> modify their process' environment </li> + <li> change their process' uid and gid </li> + <li> change their process' namespace </li> + <li> change the working directory </li> + <li> or any similar action impacting global data of the process </li> +</ul> + +<p> + will not, and <em>cannot</em>, be supported by pamela. The only +solution is to rewrite these modules so they communicate the +change they wish to make via the official PAM API, and have the +application perform the change itself. PAM provides a way to +do this: the <em>conversation function</em>, which exchanges data +between PAM and the application. pamela fully supports custom +conversation functions. +</p> + </body> </html> |