Projet

Général

Profil

Télécharger (2,8 ko) Statistiques
| Branche: | Tag: | Révision:
/*
* This program is a part of the IoTa Project.
*
* Copyright © 2008-2012 Université de Caen Basse-Normandie, GREYC
* Copyright © 2008-2012 Orange Labs
*
* 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 3 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.
* <http://www.gnu.org/licenses/>
*
* See AUTHORS for a list of contributors.
*/
package fr.unicaen.iota.discovery.server.util;

import fr.unicaen.iota.discovery.server.hibernate.User;
import java.io.UnsupportedEncodingException;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public final class Session {

private Session() {
}
private static final Log log = LogFactory.getLog(Session.class);
private static final Map<String, User> sessions = new HashMap<String, User>();
private static MessageDigest MD5;

static {
try {
MD5 = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
log.fatal(null, e);
}
}

public static synchronized String openSession(User user) {
if (MD5 == null) {
log.error("MD5 not avalaible");
return null;
}
log.debug("opening session for user " + user.getUserID());
String sessionID;
long today = new Date().getTime();
try {
do {
String text = Long.toString(today) + user.getLogin() + (today * Math.random()); // TODO add login+pass
byte[] digest = MD5.digest(text.getBytes("UTF-8"));
sessionID = new BigInteger(1, digest).toString(16);
} while (sessions.containsKey(sessionID));
} catch (UnsupportedEncodingException e) {
log.error(null, e);
return null;
}
sessions.put(sessionID, user);
return sessionID;
}

public static synchronized boolean isValidSession(String sessionID) {
return sessions.containsKey(sessionID);
}

public static synchronized void closeSession(String sessionID) {
log.debug("closing session " + sessionID);
sessions.remove(sessionID);
}

public static synchronized User getUser(String sessionID) {
return sessions.get(sessionID);
}
}
(6-6/8)