/* * Copyright (C) 2003-2013 eXo Platform SAS. * * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see<http://www.gnu.org/licenses/>. */ package org.exoplatform.forum.service.cache.model.key; import org.exoplatform.forum.common.cache.model.ScopeCacheKey; import org.exoplatform.forum.service.impl.model.TopicFilter; public class TopicListKey extends ScopeCacheKey { private static final long serialVersionUID = 1L; private TopicFilter filter; private int offset; private int limit; public TopicListKey(TopicFilter filter, int offset, int limit) { this.filter = filter; this.offset = offset; this.limit = limit; } /** * Gets ForumId from Filter * @return */ public String getForumId() { return this.filter.forumId(); } @Override public boolean equals(Object o) { if (this == o) return true; if (!(o instanceof TopicListKey)) return false; if (!super.equals(o)) return false; TopicListKey that = (TopicListKey) o; if (limit != that.limit) return false; if (offset != that.offset) return false; if (filter == null || filter.equals(that.filter) == false) { return false; } return true; } private int getHashCode(int current, Object key) { return 31 * current + (key != null ? key.hashCode() : 0); } @Override public int hashCode() { int result = super.hashCode(); result = getHashCode(result, filter.categoryId()); result = getHashCode(result, filter.forumId()); result = getHashCode(result, filter.isApproved()); result = getHashCode(result, filter.isAdmin()); result = getHashCode(result, filter.orderBy()); result = 31 * result + offset; result = 31 * result + limit; return result; } }