001/*
002 * (C) Copyright 2006-2011 Nuxeo SA (http://nuxeo.com/) and others.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 *
016 * Contributors:
017 *     Nuxeo - initial API and implementation
018 *
019 * $Id$
020 */
021package org.nuxeo.ecm.core.management.events;
022
023import org.nuxeo.ecm.core.event.EventServiceAdmin;
024import org.nuxeo.ecm.core.event.impl.EventListenerDescriptor;
025import org.nuxeo.ecm.core.event.impl.EventListenerList;
026import org.nuxeo.runtime.api.Framework;
027
028/**
029 * Monitoring MBean implementation.
030 *
031 * @author Thierry Delprat
032 * @deprecated since 11.4: superseded by dropwizard metrics
033 */
034@Deprecated(since = "11.4")
035public class EventMonitoring implements EventMonitoringMBean {
036
037    private static EventServiceAdmin getAdminService() {
038        return Framework.getService(EventServiceAdmin.class);
039    }
040
041    @Override
042    public boolean isAsyncHandlersTrackingEnabled() {
043        return EventStatsHolder.isCollectAsyncHandlersExecTime();
044    }
045
046    @Override
047    public void setAsyncHandlersTrackingEnabled(boolean collectAsyncHandlersExecTime) {
048        EventStatsHolder.setCollectAsyncHandlersExecTime(collectAsyncHandlersExecTime);
049    }
050
051    @Override
052    public boolean isSyncHandlersTrackingEnabled() {
053        return EventStatsHolder.isCollectSyncHandlersExecTime();
054    }
055
056    @Override
057    public void setSyncHandlersTrackingEnabled(boolean collectSyncHandlersExecTime) {
058        EventStatsHolder.setCollectSyncHandlersExecTime(collectSyncHandlersExecTime);
059    }
060
061    @Override
062    public int getActiveThreadsCount() {
063        return getAdminService().getActiveThreadsCount();
064    }
065
066    @Override
067    public int getEventsInQueueCount() {
068        return getAdminService().getEventsInQueueCount();
069    }
070
071    @Override
072    public String getAsyncHandlersExecTime() {
073        return EventStatsHolder.getAsyncHandlersExecTime();
074    }
075
076    @Override
077    public String getSyncHandlersExecTime() {
078        return EventStatsHolder.getSyncHandlersExecTime();
079    }
080
081    @Override
082    public boolean isBlockAsyncHandlers() {
083        return getAdminService().isBlockAsyncHandlers();
084    }
085
086    @Override
087    public void setBlockAsyncHandlers(boolean blockAsyncHandlers) {
088        getAdminService().setBlockAsyncHandlers(blockAsyncHandlers);
089    }
090
091    @Override
092    public boolean isBlockSyncPostCommitHandlers() {
093        return getAdminService().isBlockSyncPostCommitHandlers();
094    }
095
096    @Override
097    public void setBlockSyncPostCommitHandlers(boolean blockSyncPostCommitHandlers) {
098        getAdminService().setBlockSyncPostCommitHandlers(blockSyncPostCommitHandlers);
099    }
100
101    @Override
102    public void resetHandlersExecTime() {
103        EventStatsHolder.resetHandlersExecTime();
104    }
105
106    @Override
107    public String getListenersConfig() {
108
109        EventListenerList listenerList = getAdminService().getListenerList();
110        StringBuilder sb = new StringBuilder();
111        for (EventListenerDescriptor desc : listenerList.getAsyncPostCommitListenersDescriptors()) {
112            sb.append(desc.getName());
113            sb.append(" - Async PostCommit - ");
114            sb.append(desc.isEnabled());
115            sb.append("\n");
116        }
117        for (EventListenerDescriptor desc : listenerList.getSyncPostCommitListenersDescriptors()) {
118            sb.append(desc.getName());
119            sb.append(" - Sync PostCommit - ");
120            sb.append(desc.isEnabled());
121            sb.append("\n");
122        }
123        for (EventListenerDescriptor desc : listenerList.getInlineListenersDescriptors()) {
124            sb.append(desc.getName());
125            sb.append(" - Synchronous - ");
126            sb.append(desc.isEnabled());
127            sb.append("\n");
128        }
129        return sb.toString();
130    }
131
132    @Override
133    public void setListenerEnabledFlag(String listenerName, boolean enabled) {
134        getAdminService().setListenerEnabledFlag(listenerName, enabled);
135    }
136
137    @Override
138    public boolean isBulkModeEnabled() {
139        return getAdminService().isBulkModeEnabled();
140    }
141
142    @Override
143    public void setBulkModeEnabled(boolean bulkModeEnabled) {
144        getAdminService().setBulkModeEnabled(bulkModeEnabled);
145    }
146
147}