use of de.janrufmonitor.framework.ICallList in project janrufmonitor by tbrandt77.
the class AbstractDatabaseCallManager method updateCall.
public synchronized void updateCall(ICall call) {
ICallList cl = this.getRuntime().getCallFactory().createCallList(1);
cl.add(call);
this.updateCalls(cl);
}
use of de.janrufmonitor.framework.ICallList in project janrufmonitor by tbrandt77.
the class AbstractDatabaseCallManager method removeCall.
public synchronized void removeCall(ICall call) {
ICallList cl = this.getRuntime().getCallFactory().createCallList(1);
cl.add(call);
this.removeCalls(cl);
}
use of de.janrufmonitor.framework.ICallList in project janrufmonitor by tbrandt77.
the class AbstractPersistentCallManager method getInitialCallList.
protected ICallList getInitialCallList(IFilter f) {
ICallList cl = this.getRuntime().getCallFactory().createCallList();
cl.add(this.m_callList);
return cl;
}
use of de.janrufmonitor.framework.ICallList in project janrufmonitor by tbrandt77.
the class ArchiveJournal method startArchiving.
private void startArchiving() {
if (m_archivingThread == null || !m_archivingThread.isAlive()) {
m_archivingThread = new Thread(new Runnable() {
public void run() {
String currentRepository = getRuntime().getConfigManagerFactory().getConfigManager().getProperty("ui.jface.application.journal.Journal", "repository");
if (currentRepository != null && currentRepository.length() > 0) {
ICallManager cmg = getRuntime().getCallManagerFactory().getCallManager(currentRepository);
if (!currentRepository.equalsIgnoreCase(ID) && cmg != null && cmg.isActive() && cmg.isSupported(IReadCallRepository.class) && cmg.isSupported(IWriteCallRepository.class)) {
long timeframe = Long.parseLong(m_configuration.getProperty(CFG_TIMEFRAME, "0"));
if (timeframe > 0) {
try {
Thread.sleep(10000);
} catch (InterruptedException e1) {
}
long time = System.currentTimeMillis() - (timeframe * 86400000L);
IFilter tf = new DateFilter(new Date(time), new Date(0));
ICallList cl = ((IReadCallRepository) cmg).getCalls(tf);
if (cl.size() > 0) {
try {
getDatabaseHandler().setCallList(cl);
((IWriteCallRepository) cmg).removeCalls(cl);
// added 2010/12/06: added due to high memory consumption
getDatabaseHandler().commit();
getDatabaseHandler().disconnect();
getRuntime().getConfigManagerFactory().getConfigManager().setProperty(NAMESPACE, "lastrun", Long.toString(System.currentTimeMillis()));
getRuntime().getConfigManagerFactory().getConfigManager().saveConfiguration();
String root = PathResolver.getInstance(getRuntime()).resolve(m_configuration.getProperty(CFG_DB, PathResolver.getInstance(getRuntime()).getDataDirectory() + "/journal.archive"));
if (root != null && root.length() > 64) {
root = root.substring(0, root.indexOf(File.separator, 4) + 1) + "..." + root.substring(root.lastIndexOf(File.separator));
}
PropagationFactory.getInstance().fire(new Message(Message.INFO, "ui.jface.configuration.pages.ArchiveJournal", "success", new String[] { Integer.toString(cl.size()), root }, new Exception()));
} catch (SQLException e) {
m_logger.log(Level.SEVERE, e.getMessage(), e);
PropagationFactory.getInstance().fire(new Message(Message.ERROR, "ui.jface.configuration.pages.ArchiveJournal", "failed", e));
}
}
} else {
m_logger.warning("No archiving timeframe is set. Archiving is stopped.");
PropagationFactory.getInstance().fire(new Message(Message.ERROR, "ui.jface.configuration.pages.ArchiveJournal", "failed", new Exception("No archiving timeframe is set. Archiving is stopped.")));
}
} else {
m_logger.warning("Journal <" + currentRepository + "> invalid or not enabled. Archiving is stopped.");
}
} else {
m_logger.warning("No journal configured to be archived.");
PropagationFactory.getInstance().fire(new Message(Message.ERROR, "ui.jface.configuration.pages.ArchiveJournal", "failed", new Exception("No journal configured to be archived.")));
}
}
});
m_archivingThread.setDaemon(true);
m_archivingThread.setName("JAM-JournalArchiving#" + System.currentTimeMillis() + "-Thread-(non-deamon)");
m_archivingThread.start();
}
}
use of de.janrufmonitor.framework.ICallList in project janrufmonitor by tbrandt77.
the class JournalController method updateElement.
public synchronized void updateElement(Object call, boolean isUpdateAll) {
if (call instanceof ICall) {
ICallManager cm = this._getRepository();
if (cm != null && cm.isActive() && cm.isSupported(IReadCallRepository.class) && cm.isSupported(IWriteCallRepository.class)) {
ICaller caller = ((ICall) call).getCaller();
if (!caller.getPhoneNumber().isClired() && isUpdateAll) {
ICallList cl = ((IReadCallRepository) cm).getCalls(new CallerFilter(caller));
ICall aCall = null;
for (int i = cl.size() - 1; i >= 0; i--) {
aCall = cl.get(i);
aCall.setCaller(caller);
}
((IWriteCallRepository) cm).updateCalls(cl);
} else {
// update a single CLIR call or isUpdateAll == false
if (cm.isSupported(IWriteCallRepository.class))
((IWriteCallRepository) cm).updateCall((ICall) call);
}
}
}
}
Aggregations