org.anvilpowered.anvil.api.datastore.CacheService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of anvil-api Show documentation
Show all versions of anvil-api Show documentation
A cross-platform database API / ORM / entity framework with useful services for minecraft plugins
The newest version!
/*
* Anvil - AnvilPowered
* Copyright (C) 2020
*
* This program 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 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package org.anvilpowered.anvil.api.datastore;
import org.anvilpowered.anvil.api.model.ObjectWithId;
import java.util.List;
import java.util.Optional;
import java.util.Set;
import java.util.function.Predicate;
@Deprecated // will probably break in 0.4
public interface CacheService<
TKey,
T extends ObjectWithId,
TDataStore>
extends Repository {
/**
* Starts cache invalidation task
*
* @param intervalSeconds How often the cache invalidation task should run
*/
void startCacheInvalidationTask(Integer intervalSeconds);
/**
* Stop cache invalidation task
*/
void stopCacheInvalidationTask();
/**
* @return Cache invalidation task
*/
Runnable getCacheInvalidationTask();
/**
* @return A set containing all parties in the cache
*/
Set getAllAsSet();
/**
* Deletes a {@link T} from the cache
*
* @param predicate of {@link T} to remove from cache
* @return An optional containing the {@link T} if it was successfully removed
*/
Optional deleteOne(Predicate super T> predicate);
/**
* Deletes a {@link T} from the cache
*
* @param t {@link T} to remove from cache
* @return An optional containing the {@link T} if it was successfully removed
*/
Optional delete(T t);
/**
* Deletes a {@link T} from the cache
*
* @param predicate of {@link T} to remove from cache
* @return A list of successfully deleted elements
*/
List delete(Predicate super T> predicate);
List getAll(Predicate super T> predicate);
Optional getOne(Predicate super T> predicate);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy