divide by zero, inaccurate discount and totals, reflection of user input git-svn-id: http://webgoat.googlecode.com/svn/trunk/webgoat@273 4033779f-a91e-0410-96ef-6bf7bf53c507
274 lines
6.6 KiB
Java
274 lines
6.6 KiB
Java
package org.owasp.webgoat.session;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collection;
|
|
import java.util.HashMap;
|
|
import java.util.Iterator;
|
|
import java.util.Map;
|
|
|
|
import org.apache.catalina.Role;
|
|
import org.apache.catalina.User;
|
|
import org.apache.catalina.users.MemoryUserDatabase;
|
|
|
|
/*******************************************************************************
|
|
*
|
|
*
|
|
* This file is part of WebGoat, an Open Web Application Security Project
|
|
* utility. For details, please see http://www.owasp.org/
|
|
*
|
|
* Copyright (c) 2002 - 2007 Bruce Mayhew
|
|
*
|
|
* This program 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; either version 2 of the License, or (at your option) any later
|
|
* version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|
* Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* Getting Source ==============
|
|
*
|
|
* Source for this application is maintained at code.google.com, a repository
|
|
* for free software projects.
|
|
*
|
|
* For details, please see http://code.google.com/p/webgoat/
|
|
*
|
|
* @author Bruce Mayhew <a href="http://code.google.com/p/webgoat">WebGoat</a>
|
|
* @created October 29, 2003
|
|
*/
|
|
|
|
public class UserTracker
|
|
{
|
|
|
|
private static UserTracker instance;
|
|
|
|
// FIXME: persist this somehow!
|
|
|
|
private static HashMap<String, HashMap<String, LessonTracker>> storage = new HashMap<String, HashMap<String, LessonTracker>>();
|
|
|
|
private static MemoryUserDatabase usersDB = new MemoryUserDatabase();
|
|
|
|
|
|
/**
|
|
* Constructor for the UserTracker object
|
|
*/
|
|
private UserTracker()
|
|
{}
|
|
|
|
|
|
/**
|
|
* Gets the completed attribute of the UserTracker object
|
|
*
|
|
* @param userName Description of the Parameter
|
|
* @return The completed value
|
|
*/
|
|
public int getCompleted(String userName)
|
|
{
|
|
|
|
HashMap usermap = getUserMap(userName);
|
|
|
|
Iterator i = usermap.entrySet().iterator();
|
|
|
|
int count = 0;
|
|
|
|
while (i.hasNext())
|
|
{
|
|
|
|
Map.Entry entry = (Map.Entry) i.next();
|
|
|
|
int value = ((Integer) entry.getValue()).intValue();
|
|
|
|
if (value > 5)
|
|
{
|
|
count++;
|
|
}
|
|
|
|
}
|
|
|
|
return count;
|
|
}
|
|
|
|
|
|
/**
|
|
* Gets the users attribute of the UserTracker object
|
|
*
|
|
* @return The users value
|
|
*/
|
|
public Collection getUsers()
|
|
{
|
|
return storage.keySet();
|
|
}
|
|
|
|
|
|
public Collection<String> getAllUsers(String roleName)
|
|
{
|
|
synchronized (usersDB)
|
|
{
|
|
Collection<String> allUsers = new ArrayList<String>();
|
|
try
|
|
{
|
|
usersDB.open();
|
|
Iterator users = usersDB.getUsers();
|
|
while (users.hasNext())
|
|
{
|
|
User user = (User) users.next();
|
|
Iterator roles = user.getRoles();
|
|
while (roles.hasNext())
|
|
{
|
|
Role role = (Role) roles.next();
|
|
if (role.getRolename().trim().equals(roleName))
|
|
{
|
|
allUsers.add(user.getUsername());
|
|
}
|
|
}
|
|
}
|
|
usersDB.close();
|
|
}
|
|
catch (Exception e)
|
|
{}
|
|
return allUsers;
|
|
}
|
|
}
|
|
|
|
|
|
public void deleteUser(String user)
|
|
{
|
|
synchronized (usersDB)
|
|
{
|
|
try
|
|
{
|
|
usersDB.open();
|
|
Iterator users = usersDB.getUsers();
|
|
while (users.hasNext())
|
|
{
|
|
User tomcatUser = (User) users.next();
|
|
if (tomcatUser.getUsername().equals(user))
|
|
{
|
|
usersDB.removeUser(tomcatUser);
|
|
// FIXME: delete all the lesson tracking property files
|
|
break;
|
|
}
|
|
}
|
|
usersDB.close();
|
|
|
|
}
|
|
catch (Exception e)
|
|
{}
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Gets the lessonTracker attribute of the UserTracker object
|
|
*
|
|
* @param screen Description of the Parameter
|
|
* @param userName Description of the Parameter
|
|
* @return The lessonTracker value
|
|
*/
|
|
public LessonTracker getLessonTracker(WebSession s, Screen screen)
|
|
{
|
|
return getLessonTracker(s, s.getUserName(), screen);
|
|
}
|
|
|
|
|
|
public LessonTracker getLessonTracker(WebSession s, String user,
|
|
Screen screen)
|
|
{
|
|
HashMap<String, LessonTracker> usermap = getUserMap(user);
|
|
LessonTracker tracker = (LessonTracker) usermap.get(screen.getTitle());
|
|
if (tracker == null)
|
|
{
|
|
// Creates a new lesson tracker, if one does not exist on disk.
|
|
tracker = LessonTracker.load(s, user, screen);
|
|
usermap.put(screen.getTitle(), tracker);
|
|
}
|
|
//System.out.println( "User: [" + userName + "] UserTracker:getLessonTracker() LTH " + tracker.hashCode() + " for " + screen );
|
|
return tracker;
|
|
}
|
|
|
|
|
|
/**
|
|
* Gets the status attribute of the UserTracker object
|
|
*
|
|
* @param screen Description of the Parameter
|
|
* @param userName Description of the Parameter
|
|
* @return The status value
|
|
*/
|
|
public String getStatus(WebSession s, Screen screen)
|
|
{
|
|
return ("User [" + s.getUserName() + "] has accessed " + screen
|
|
+ " UserTracker:getStatus()LTH = " + getLessonTracker(s, screen)
|
|
.hashCode());
|
|
}
|
|
|
|
|
|
/**
|
|
* Gets the userMap attribute of the UserTracker object
|
|
*
|
|
* @param userName Description of the Parameter
|
|
* @return The userMap value
|
|
*/
|
|
private HashMap<String, LessonTracker> getUserMap(String userName)
|
|
{
|
|
|
|
HashMap<String, LessonTracker> usermap = storage.get(userName);
|
|
|
|
if (usermap == null)
|
|
{
|
|
|
|
usermap = new HashMap<String, LessonTracker>();
|
|
|
|
storage.put(userName, usermap);
|
|
|
|
}
|
|
|
|
return (usermap);
|
|
}
|
|
|
|
|
|
/**
|
|
* Description of the Method
|
|
*
|
|
* @return Description of the Return Value
|
|
*/
|
|
public static synchronized UserTracker instance()
|
|
{
|
|
|
|
if (instance == null)
|
|
{
|
|
|
|
instance = new UserTracker();
|
|
|
|
}
|
|
|
|
return instance;
|
|
}
|
|
|
|
|
|
/**
|
|
* Description of the Method
|
|
*
|
|
* @param screen Description of the Parameter
|
|
* @param s Description of the Parameter
|
|
*/
|
|
public void update(WebSession s, Screen screen)
|
|
{
|
|
|
|
LessonTracker tracker = getLessonTracker(s, screen);
|
|
|
|
//System.out.println( "User [" + s.getUserName() + "] TRACKER: updating " + screen + " LTH " + tracker.hashCode() );
|
|
tracker.store(s, screen);
|
|
|
|
HashMap<String, LessonTracker> usermap = getUserMap(s.getUserName());
|
|
usermap.put(screen.getTitle(), tracker);
|
|
|
|
}
|
|
|
|
}
|