1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.kuali.rice.kew.rule.service.impl;
17
18 import org.kuali.rice.kew.rule.service.RuleDelegationCacheProcessor;
19 import org.kuali.rice.kew.util.PerformanceLogger;
20 import org.kuali.rice.ksb.api.KsbApiServiceLocator;
21
22 public class RuleDelegationCacheProcessorImpl implements RuleDelegationCacheProcessor {
23
24 private static final org.apache.log4j.Logger LOG = org.apache.log4j.Logger.getLogger(RuleDelegationCacheProcessorImpl.class);
25
26 public void clearRuleDelegationFromCache(String responsibilityId) {
27 PerformanceLogger logger = new PerformanceLogger();
28 if (responsibilityId != null) {
29 flushListFromCache(responsibilityId);
30 }
31 logger.log("Time to notify cache of rule delegation change for responsibility id=" + responsibilityId);
32 }
33
34 protected void flushListFromCache(String responsibilityId) {
35 if (LOG.isInfoEnabled())
36 LOG.info("Flushing delegation rules from Cache for responsibilityId='" + responsibilityId );
37 KsbApiServiceLocator.getCacheAdministrator().flushEntry(getRuleDlgnCacheKey(responsibilityId));
38 }
39
40 protected String getRuleDlgnCacheKey(String responsibilityId) {
41 return "RuleDlgnCache:" + responsibilityId;
42 }
43
44 }