| 
                Last change
                  on this file since 2623 was
                  1648,
                  checked in by ezyang, 15 years ago
           | 
        
        
          | 
            Add cluedump slide sources to Subversion.
           | 
        
        | 
            File size:
            1.2 KB
           | 
      
      
        
  | Rev | Line |   | 
|---|
| [1648] | 1 | \subsection{Kerberos} | 
|---|
 | 2 |  | 
|---|
 | 3 | \begin{frame} | 
|---|
 | 4 |   \frametitle{Group locker support} | 
|---|
 | 5 |  | 
|---|
 | 6 |   \begin{itemize} | 
|---|
 | 7 |   \item ``Users'' on scripts are actually lockers. | 
|---|
 | 8 |   \item User IDs are actually locker volume IDs. | 
|---|
 | 9 |     \pause | 
|---|
 | 10 |   \item Kerberos is modified to let users SSH in as any locker they | 
|---|
 | 11 |     administrate. | 
|---|
 | 12 |     \begin{itemize} | 
|---|
 | 13 |     \item Replaced the \texttt{.k5login} mechanism: | 
|---|
 | 14 |       \texttt{krb5\_kuserok()} in | 
|---|
 | 15 |       \texttt{krb5/src/lib/krb5/os/kuserok.c} | 
|---|
 | 16 |     \item Calls a Perl script \texttt{/usr/local/sbin/admof} to do the | 
|---|
 | 17 |       actual check. | 
|---|
 | 18 |     \end{itemize} | 
|---|
 | 19 |   \end{itemize} | 
|---|
 | 20 | \end{frame} | 
|---|
 | 21 |  | 
|---|
 | 22 | \begin{frame}[fragile] | 
|---|
 | 23 | \begin{footnotesize} | 
|---|
 | 24 | \begin{semiverbatim} | 
|---|
 | 25 |  krb5_boolean KRB5_CALLCONV | 
|---|
 | 26 |  krb5_kuserok(krb5_context context, krb5_principal principal, | 
|---|
 | 27 |               const char *luser) | 
|---|
 | 28 |  \{ | 
|---|
 | 29 |      \ldots | 
|---|
 | 30 | +    if ((pid = fork()) == -1) \{ | 
|---|
 | 31 | +       free(princname); | 
|---|
 | 32 | +       return(FALSE); | 
|---|
 | 33 | +    \} | 
|---|
 | 34 | +    if (pid == 0) \{ | 
|---|
 | 35 | +#define ADMOF_PATH "/usr/local/sbin/ssh-admof" | 
|---|
 | 36 | +        exec(ADMOF_PATH, ADMOF_PATH, (char *) luser, princname, NULL); | 
|---|
 | 37 | +        exit(1); | 
|---|
 | 38 | +    \} | 
|---|
 | 39 | +    if (waitpid(pid, &status, 0) > 0 && WIFEXITED(status) && | 
|---|
 | 40 | +        WEXITSTATUS(status) == 33) \{ | 
|---|
 | 41 | +        isok = TRUE; | 
|---|
 | 42 | +    \} | 
|---|
 | 43 |      \ldots | 
|---|
 | 44 |  \} | 
|---|
 | 45 | \end{semiverbatim} | 
|---|
 | 46 | \end{footnotesize} | 
|---|
 | 47 | \end{frame} | 
|---|
       
      
      Note: See 
TracBrowser
        for help on using the repository browser.