Improve secure logging
[lgpl/argeo-commons.git] / security / plugins / org.argeo.security.ui / src / main / java / org / argeo / security / ui / views / LogView.java
index f432ad34863a4a10d26559db21cfbc68d411f6a8..a612bc9f71552d5a813690ba4e0fe129d294350c 100644 (file)
@@ -3,14 +3,13 @@ package org.argeo.security.ui.views;
 import java.util.ArrayList;
 
 import org.argeo.ArgeoLogListener;
+import org.argeo.ArgeoLogger;
 import org.argeo.security.ui.SecurityUiPlugin;
 import org.eclipse.jface.viewers.LabelProvider;
 import org.eclipse.jface.viewers.TableViewer;
 import org.eclipse.swt.SWT;
 import org.eclipse.swt.widgets.Composite;
 import org.eclipse.ui.part.ViewPart;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceRegistration;
 
 /**
  * Display log lines with a virtual table. Register and unregisters a
@@ -22,8 +21,7 @@ public class LogView extends ViewPart {
        private TableViewer viewer;
 
        private LogContentProvider logContentProvider;
-
-       private ServiceRegistration serviceRegistration;
+       private ArgeoLogger argeoLogger;
 
        @Override
        public void createPartControl(Composite parent) {
@@ -31,11 +29,12 @@ public class LogView extends ViewPart {
                                | SWT.V_SCROLL | SWT.FULL_SELECTION | SWT.BORDER);
                viewer.setLabelProvider(new LabelProvider());
                logContentProvider = new LogContentProvider(viewer);
-               serviceRegistration = getBundleContext().registerService(
-                               ArgeoLogListener.class.getName(), logContentProvider, null);
                viewer.setContentProvider(logContentProvider);
-               //viewer.setUseHashlookup(true);
+               // viewer.setUseHashlookup(true);
                viewer.setInput(new ArrayList<String>());
+
+               if (argeoLogger != null)
+                       argeoLogger.register(logContentProvider, 1000);
        }
 
        @Override
@@ -45,11 +44,12 @@ public class LogView extends ViewPart {
 
        @Override
        public void dispose() {
-               if (serviceRegistration != null)
-                       serviceRegistration.unregister();
+               if (argeoLogger != null)
+                       argeoLogger.unregister(logContentProvider);
        }
 
-       private BundleContext getBundleContext() {
-               return SecurityUiPlugin.getDefault().getBundle().getBundleContext();
+       public void setArgeoLogger(ArgeoLogger argeoLogger) {
+               this.argeoLogger = argeoLogger;
        }
+
 }