/* * * Copyright (C) 2007-2015 Licensed to the Comunes Association (CA) under * one or more contributor license agreements (see COPYRIGHT for details). * The CA licenses this file to you under the GNU Affero General Public * License version 3, (the "License"); you may not use this file except in * compliance with the License. This file is part of kune. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * */ package cc.kune.core.client.cookies; import java.util.Date; import cc.kune.common.client.log.Log; import cc.kune.common.client.utils.WindowUtils; import cc.kune.common.shared.utils.TextUtils; import cc.kune.core.shared.SessionConstants; import com.google.gwt.user.client.Cookies; /** * The Class CookiesManagerImpl. * * @author vjrj@ourproject.org (Vicente J. Ruiz Jurado) */ public class CookiesManagerImpl implements CookiesManager { /** The Constant ANON. */ private static final String ANON = "annon"; /** * Instantiates a new cookies manager impl. */ public CookiesManagerImpl() { } /* * (non-Javadoc) * * @see cc.kune.core.client.cookies.CookiesManager#getAnonCookie() */ @Override public String getAnonCookie() { return Cookies.getCookie(ANON); } /* * (non-Javadoc) * * @see cc.kune.core.client.cookies.CookiesManager#getAuthCookie() */ @Override public String getAuthCookie() { return Cookies.getCookie(SessionConstants.USERHASH); } /* * (non-Javadoc) * * @see cc.kune.core.client.cookies.CookiesManager#removeAnonCookie() */ @Override public void removeAnonCookie() { Cookies.removeCookie(ANON); Cookies.setCookie(ANON, null, new Date(0), CookieUtils.getDomain(), "/", false); } /* * (non-Javadoc) * * @see cc.kune.core.client.cookies.CookiesManager#removeAuthCookie() */ @Override public void removeAuthCookie() { // FIXME: Remove cookie doesn't works in all browsers, know // issue: // http://groups.google.com/group/Google-Web-Toolkit/browse_thread/thread/ded86778ee56690/515dc513c7d085eb?lnk=st&q=remove+cookie#515dc513c7d085eb // http://code.google.com/p/google-web-toolkit/issues/detail?id=1735&q=removeCookie Cookies.removeCookie(SessionConstants.USERHASH); Cookies.removeCookie(SessionConstants.JSESSIONID); // Workaround: Cookies.setCookie(SessionConstants.USERHASH, null, new Date(0), CookieUtils.getDomain(), "/", WindowUtils.isHttps()); Cookies.setCookie(SessionConstants.JSESSIONID, null, new Date(0), CookieUtils.getDomain(), "/", WindowUtils.isHttps()); } /* * (non-Javadoc) * * @see * cc.kune.core.client.cookies.CookiesManager#setAnonCookie(java.lang.Boolean) */ @Override public void setAnonCookie(final Boolean userRegister) { final Date expires = new Date(System.currentTimeMillis() + (userRegister ? SessionConstants.ANON_SESSION_DURATION_AFTER_REG : SessionConstants.ANON_SESSION_DURATION)); Cookies.setCookie(ANON, userRegister.toString(), expires, CookieUtils.getDomain(), "/", false); } /* * (non-Javadoc) * * @see * cc.kune.core.client.cookies.CookiesManager#setAuthCookie(java.lang.String) */ @Override public void setAuthCookie(final String userHash) { // http://code.google.com/p/google-web-toolkit-incubator/wiki/LoginSecurityFAQ final Date expires = new Date(System.currentTimeMillis() + SessionConstants.SESSION_DURATION); Cookies.setCookie(SessionConstants.USERHASH, userHash, expires, CookieUtils.getDomain(), "/", WindowUtils.isHttps()); Cookies.setCookie(SessionConstants.JSESSIONID, userHash, expires, CookieUtils.getDomain(), "/", WindowUtils.isHttps()); Log.info("Received hash: " + userHash, null); } }