(root)/
Linux-PAM-1.5.3/
xtests/
tst-pam_authfail.c
       1  /*
       2   * Redistribution and use in source and binary forms, with or without
       3   * modification, are permitted provided that the following conditions
       4   * are met:
       5   * 1. Redistributions of source code must retain the above copyright
       6   *    notice, and the entire permission notice in its entirety,
       7   *    including the disclaimer of warranties.
       8   * 2. Redistributions in binary form must reproduce the above copyright
       9   *    notice, this list of conditions and the following disclaimer in the
      10   *    documentation and/or other materials provided with the distribution.
      11   * 3. The name of the author may not be used to endorse or promote
      12   *    products derived from this software without specific prior
      13   *    written permission.
      14   *
      15   * ALTERNATIVELY, this product may be distributed under the terms of
      16   * the GNU Public License, in which case the provisions of the GPL are
      17   * required INSTEAD OF the above restrictions.  (This clause is
      18   * necessary due to a potential bad interaction between the GPL and
      19   * the restrictions contained in a BSD-style copyright.)
      20   *
      21   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
      22   * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
      23   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
      24   * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
      25   * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
      26   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
      27   * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
      28   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
      29   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
      30   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
      31   * OF THE POSSIBILITY OF SUCH DAMAGE.
      32   */
      33  
      34  #ifdef HAVE_CONFIG_H
      35  #include <config.h>
      36  #endif
      37  
      38  #include <stdio.h>
      39  #include <string.h>
      40  #include <security/pam_appl.h>
      41  #include <security/pam_misc.h>
      42  
      43  static struct pam_conv conv = {
      44      misc_conv,
      45      NULL
      46  };
      47  
      48  
      49  /* Check that auth stack fails.  */
      50  
      51  int
      52  main(int argc, char *argv[])
      53  {
      54    pam_handle_t *pamh=NULL;
      55    const char *user="nobody";
      56    const char *stack="tst-pam_authfail";
      57    int retval;
      58    int debug = 0;
      59  
      60    if (argc > 2) {
      61      stack = argv[2];
      62    }
      63  
      64    if (argc > 1) {
      65      if (strcmp (argv[1], "-d") == 0)
      66        debug = 1;
      67      else
      68        stack = argv[1];
      69    }
      70  
      71  
      72    retval = pam_start(stack, user, &conv, &pamh);
      73    if (retval != PAM_SUCCESS)
      74      {
      75        if (debug)
      76  	fprintf (stderr, "test3: pam_start returned %d\n", retval);
      77        return 1;
      78      }
      79  
      80    retval = pam_authenticate(pamh, 0);
      81    if (retval == PAM_SUCCESS)
      82      {
      83        if (debug)
      84  	fprintf (stderr, "test3: pam_authenticate returned %d\n", retval);
      85        return 1;
      86      }
      87  
      88    retval = pam_end(pamh,retval);
      89    if (retval != PAM_SUCCESS)
      90      {
      91        if (debug)
      92  	fprintf (stderr, "test3: pam_end returned %d\n", retval);
      93        return 1;
      94      }
      95    return 0;
      96  }