/*
* $#
* FOS API
*
* Copyright (C) 2013 Feedzai SA
*
* This software is licensed under the Apache License, Version 2.0 (the "Apache License") or the GNU
* Lesser General Public License version 3 (the "GPL License"). You may choose either license to govern
* your use of this software only upon the condition that you accept all of the terms of either the Apache
* License or the LGPL License.
*
* You may obtain a copy of the Apache License and the LGPL License at:
*
* http://www.apache.org/licenses/LICENSE-2.0.txt
* http://www.gnu.org/licenses/lgpl-3.0.txt
*
* Unless required by applicable law or agreed to in writing, software distributed under the Apache License
* or the LGPL License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the Apache License and the LGPL License for the specific language governing
* permissions and limitations under the Apache License and the LGPL License.
* #$
*/
package com.feedzai.fos.server.remote.api;
import com.feedzai.fos.api.FOSException;
import com.feedzai.fos.api.KryoScorer;
import com.feedzai.fos.api.Manager;
import com.feedzai.fos.api.Model;
import com.feedzai.fos.api.ModelConfig;
import com.feedzai.fos.api.ModelDescriptor;
import com.feedzai.fos.api.Scorer;
import com.feedzai.fos.common.validation.NotBlank;
import com.google.common.base.Optional;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.util.List;
import java.util.Map;
import java.util.UUID;
/**
* FOS Remote manager local adapter.
*
* @author Miguel Duarte (miguel.duarte@feedzai.com)
* @since 0.3.0
* @since 0.3.0
*/
public class FOSManagerAdapter implements Manager {
private final KryoScorer kryoScorer;
IRemoteManager manager;
public FOSManagerAdapter(IRemoteManager manager, KryoScorer kryoScorer) {
this.manager = manager;
this.kryoScorer = kryoScorer;
}
@Override
public UUID addModel(ModelConfig modelConfig, Model binary) throws FOSException {
try {
return manager.addModel(modelConfig, binary);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public UUID addModel(ModelConfig modelConfig, @NotBlank ModelDescriptor descriptor) throws FOSException {
try {
return manager.addModel(modelConfig, descriptor);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void removeModel(UUID uuid) throws FOSException {
try {
manager.removeModel(uuid);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void reconfigureModel(UUID uuid, ModelConfig modelConfig) throws FOSException {
try {
manager.reconfigureModel(uuid, modelConfig);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void reconfigureModel(UUID uuid, ModelConfig modelConfig, Model bytes) throws FOSException {
try {
manager.reconfigureModel(uuid, modelConfig, bytes);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void reconfigureModel(UUID uuid, ModelConfig modelConfig, @NotBlank ModelDescriptor descriptor) throws FOSException {
try {
manager.reconfigureModel(uuid, modelConfig, descriptor);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public Map<UUID, ? extends ModelConfig> listModels() throws FOSException {
try {
return manager.listModels();
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public Scorer getScorer() throws FOSException {
try {
if (kryoScorer != null) {
return kryoScorer;
} else {
return new FOSScorerAdapter(manager.getScorer());
}
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public UUID trainAndAdd(ModelConfig modelConfig, List<Object[]> objects) throws FOSException {
try {
return manager.trainAndAdd(modelConfig, objects);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public UUID trainAndAddFile(ModelConfig modelConfig, String s) throws FOSException {
try {
return manager.trainAndAddFile(modelConfig, s);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public Model train(ModelConfig modelConfig, List<Object[]> objects) throws FOSException {
try {
return manager.train(modelConfig, objects);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public double[] featureImportance(UUID uuid, Optional<List<Object[]>> instances, long seed) throws FOSException {
try {
return manager.featureImportance(uuid, instances, seed);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public Model trainFile(ModelConfig modelConfig, String s) throws FOSException {
try {
return manager.trainFile(modelConfig, s);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void close() throws FOSException {
try {
manager.close();
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void save(UUID uuid, String savepath) throws FOSException {
try {
manager.save(uuid, savepath);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
@Override
public void saveAsPMML(UUID uuid, String savePath, boolean compress) throws FOSException {
try {
manager.saveAsPMML(uuid, savePath, compress);
} catch (RemoteException e) {
throw new FOSException(e);
}
}
public static FOSManagerAdapter create(String registryHostname, int registryPort) throws RemoteException, NotBoundException {
IRemoteManager iRemoteManager = getiRemoteManager(registryHostname, registryPort);
return new FOSManagerAdapter(iRemoteManager, null);
}
public static FOSManagerAdapter createKryo(String registryHostname, int registryPort, int kryoPort) throws RemoteException, NotBoundException {
IRemoteManager iRemoteManager = getiRemoteManager(registryHostname, registryPort);
return new FOSManagerAdapter(iRemoteManager, new KryoScorer(registryHostname, kryoPort));
}
private static IRemoteManager getiRemoteManager(String registryHostname, int registryPort) throws RemoteException, NotBoundException {
Registry fosRegistry = LocateRegistry.getRegistry(registryHostname,
registryPort);
String managerClass = IRemoteManager.class.getSimpleName();
return (IRemoteManager) fosRegistry.lookup(managerClass);
}
}