
io.datakernel.rpc.protocol.RpcRemoteException Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of datakernel-rpc Show documentation
Show all versions of datakernel-rpc Show documentation
High-performance and fault-tolerant remote procedure call module for building distributed applications.
Provides a high-performance asynchronous binary RPC streaming protocol.
The newest version!
/*
* Copyright (C) 2015-2018 SoftIndex LLC.
*
* 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 io.datakernel.rpc.protocol;
import io.datakernel.rpc.server.RpcServerConnection;
import io.datakernel.serializer.annotations.Deserialize;
import io.datakernel.serializer.annotations.Serialize;
import io.datakernel.serializer.annotations.SerializeNullable;
import org.jetbrains.annotations.Nullable;
public class RpcRemoteException extends RpcException implements RpcMandatoryData {
private static final long serialVersionUID = 769022174067373741L;
@Nullable
private final String causeMessage;
@Nullable
private final String causeClassName;
public RpcRemoteException(String message, Throwable cause) {
super(RpcServerConnection.class, message, cause);
this.causeClassName = cause.getClass().getName();
this.causeMessage = cause.getMessage();
}
public RpcRemoteException(Throwable cause) {
this(cause.toString(), cause);
}
@SuppressWarnings("unused")
public RpcRemoteException(String message) {
super(RpcServerConnection.class, message);
this.causeClassName = null;
this.causeMessage = null;
}
@SuppressWarnings("unused")
public RpcRemoteException(@Deserialize("message") String message,
@Nullable @Deserialize("causeClassName") String causeClassName,
@Nullable @Deserialize("causeMessage") String causeMessage) {
super(RpcServerConnection.class, message);
this.causeClassName = causeClassName;
this.causeMessage = causeMessage;
}
@Nullable
@Serialize(order = 1)
@SerializeNullable
public String getCauseMessage() {
return causeMessage;
}
@Nullable
@Serialize(order = 0)
@SerializeNullable
public String getCauseClassName() {
return causeClassName;
}
@Override
@Serialize(order = 2)
@SerializeNullable
public String getMessage() {
return super.getMessage();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy