View Javadoc

1   /*
2    * Copyright (c) 2006 The University of Reading
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions
7    * are met:
8    * 1. Redistributions of source code must retain the above copyright
9    *    notice, this list of conditions and the following disclaimer.
10   * 2. Redistributions in binary form must reproduce the above copyright
11   *    notice, this list of conditions and the following disclaimer in the
12   *    documentation and/or other materials provided with the distribution.
13   * 3. Neither the name of the University of Reading, nor the names of the
14   *    authors or contributors may be used to endorse or promote products
15   *    derived from this software without specific prior written permission.
16   *
17   * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18   * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20   * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21   * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22   * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23   * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24   * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25   * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26   * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27   */
28  
29  package uk.ac.rdg.resc.jstyx.server;
30  
31  /***
32   * Class representing the user at the other end of a Styx connection.
33   *
34   * @author Jon Blower
35   * $Revision: 604 $
36   * $Date: 2006-03-21 14:58:42 +0000 (Tue, 21 Mar 2006) $
37   * $Log$
38   * Revision 1.3  2006/03/21 14:58:42  jonblower
39   * Implemented clear-text password-based authentication and did some simple tests
40   *
41   * Revision 1.2  2006/03/21 09:06:15  jonblower
42   * Still implementing authentication
43   *
44   * Revision 1.1  2006/03/20 17:51:50  jonblower
45   * Adding authentication to base JStyx system
46   *
47   */
48  public class User
49  {
50      private StyxSecurityContext securityContext;
51      private String username;
52      private String password;
53      private String fullName;
54      
55      /***
56       * Creates a new instance of User
57       */
58      public User(StyxSecurityContext securityContext, String username,
59          String password, String fullName)
60      {
61          this.securityContext = securityContext;
62          this.username = username.trim();
63          this.password = password.trim();
64          this.fullName = fullName.trim();
65      }
66      
67      public String getUsername()
68      {
69          return this.username;
70      }
71      
72      public String getFullName()
73      {
74          return this.fullName;
75      }
76      
77      public boolean passwordMatches(String otherPassword)
78      {
79          return this.password.equals(otherPassword);
80      }
81      
82      /***
83       * @return true if this user is a member of the group with the given name.
84       * See StyxSecurityContext.isMember()
85       */
86      public boolean isMemberOf(String groupName)
87      {
88          return this.securityContext.isMember(this.username, groupName);
89      }
90      
91  }