Skip to content

Simplifies Play! Framework 1.2.x Cache Management

License

Notifications You must be signed in to change notification settings

ugurlu/play-cacheman

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cacheman

Cacheman is a Cache Manager for Play! Framework. It simplifies the management of cache keys within session or global scopes
and provides tools for describing the generation of the values for cache keys.

Getting started

To install Cacheman, you can use the modules repository:

play install cacheman-<required version>

If you are using Play! 1.2 or above, you can add it to your dependencies.

- play -> cacheman <required version>

Sample application

A sample application is included in the test-app folder.

Usage

Create enums for the session and global scope cache keys. A sample enum named SampleCacheKey is included in the module. Below is a sample enum for global scope cache keys. Two enums, SessionCacheKey and GlobalCacheKey is sufficient for a common application.

A CacheAdapter is used for defining the generation of the values for the cache keys. You can pass a function or a static method of the GenericModel to the CacheAdapter. Then you can use CacheManager.get(GlobalCacheKey.USER_COUNT) or CacheManager.get(GlobalCacheKey.USER, username) to get the value. If the value is present in the cache then CacheManager.get immediately returns the value. If the value is not present in the cache then the value is generated and stored in the cache, then the generated value is returned.

package cache;
import models.User;
import cachemanager.cache.CacheAdapter;
import cachemanager.cache.CacheKey;
import cachemanager.common.Function;
public enum GlobalCacheKey implements CacheKey 
{
    USER(new CacheAdapter(new Function<String, User>() 
        {
            @Override
            public User apply(String username) 
            {
                return User.findByUsername(username);
            }
        }, 
        "8h")),
    USER_COUNT(new CacheAdapter(User.class, "count", "5mn"));
    private CacheAdapter adapter;
    private GlobalCacheKey(CacheAdapter adapter) 
    {
        this.adapter = adapter;
    }
    @Override
    public CacheScope scope() 
    {
        return CacheScope.GLOBAL;
    }
    @Override
    public String key() 
    {
        return this.name();
    }
    @Override
    public CacheAdapter adapter() 
    {
        return adapter;
    }
}

About

Simplifies Play! Framework 1.2.x Cache Management

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 77.1%
  • HTML 22.9%