/* * Copyright � 2016 TIBCO Software,Inc.All rights reserved. * http://community.jaspersoft.com/project/jaspermobile-android * * Unless you have purchased a commercial license agreement from TIBCO Jaspersoft, * the following license terms apply: * * This program is part of TIBCO Jaspersoft Mobile for Android. * * TIBCO Jaspersoft Mobile is free software:you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation,either version 3of the License,or * (at your option)any later version. * * TIBCO Jaspersoft Mobile 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with TIBCO Jaspersoft Mobile for Android.If not,see * <http://www.gnu.org/licenses/lgpl>. */ package com.jaspersoft.android.jaspermobile.data.cache.profile; import com.jaspersoft.android.jaspermobile.domain.JasperServer; import com.jaspersoft.android.jaspermobile.domain.Profile; /** * Abstraction around server cache. * Following interface implemented by {@link AccountJasperServerCache} * * @author Tom Koptel * @since 2.3 */ public interface JasperServerCache { /** * Saves server in cache by associating it with {@link Profile} * * @param profile the target profile we use to associate with server * @param jasperServer metadata for server we are going to put in cache */ void put(Profile profile, JasperServer jasperServer); /** * Retrieves server metadata from cache on the basis of associated {@link Profile} * @param profile the target profile we use to associate with server * @return {@link JasperServer} abstraction that encompass additional server metadata */ JasperServer get(Profile profile); /** * Checks weather server meta data was stored on the basis of associated {@link Profile} * * @param profile the target profile we use to associate with server * @return True if cache retains server, False if not */ boolean hasServer(Profile profile); }