com.canoo.dp.impl.server.mbean.DolphinContextMBeanRegistry Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dolphin-platform-remoting-server Show documentation
Show all versions of dolphin-platform-remoting-server Show documentation
The Dolphin Platform is a framework that implements the presentation model pattern and provides amodern way to create enterprise applications. The Platform provides several client implementations that all canbe used in combination with a general sever API.
The newest version!
/*
* Copyright 2015-2018 Canoo Engineering AG.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.canoo.dp.impl.server.mbean;
import com.canoo.dp.impl.platform.core.Assert;
import com.canoo.dp.impl.server.gc.GarbageCollector;
import com.canoo.dp.impl.server.mbean.beans.*;
import com.canoo.platform.core.functional.Subscription;
import com.canoo.platform.server.client.ClientSession;
import org.apiguardian.api.API;
import static org.apiguardian.api.API.Status.INTERNAL;
/**
* Helper method to register MBeans for Dolphin Platform
*/
@API(since = "0.x", status = INTERNAL)
public class DolphinContextMBeanRegistry {
private final String dolphinContextId;
/**
* Constructor
* @param dolphinContextId the dolphin context id
*/
public DolphinContextMBeanRegistry(String dolphinContextId) {
this.dolphinContextId = Assert.requireNonNull(dolphinContextId, "dolphinContextId");
}
/**
* Register a new dolphin session as a MBean
* @param session the session
* @return the subscription for deregistration
*/
public Subscription registerDolphinContext(ClientSession session, GarbageCollector garbageCollector) {
Assert.requireNonNull(session, "session");
Assert.requireNonNull(garbageCollector, "garbageCollector");
DolphinSessionInfoMBean mBean = new DolphinSessionInfo(session, garbageCollector);
return MBeanRegistry.getInstance().register(mBean, new MBeanDescription("com.canoo.dolphin", "DolphinSession", "session"));
}
/**
* Register a new Dolphin Platform controller as a MBean
* @param controllerClass the controller class
* @param controllerId the controller id
* @param modelProvider the model provider
* @return the subscription for deregistration
*/
public Subscription registerController(Class> controllerClass, String controllerId, ModelProvider modelProvider) {
Assert.requireNonNull(controllerClass, "controllerClass");
Assert.requireNonBlank(controllerId, "controllerId");
Assert.requireNonNull(modelProvider, "modelProvider");
DolphinControllerInfoMBean mBean = new DolphinControllerInfo(dolphinContextId, controllerClass, controllerId, modelProvider);
return MBeanRegistry.getInstance().register(mBean, new MBeanDescription("com.canoo.dolphin", controllerClass.getSimpleName(), "controller"));
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy