io.proximax.xpx.service.TransactionSender Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xpx-java-sdk Show documentation
Show all versions of xpx-java-sdk Show documentation
Proximax P2P File Storage Java SDK (NIS1 Compatible)
/*
* Copyright 2018 ProximaX Limited
*
* 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.proximax.xpx.service;
import io.proximax.xpx.exceptions.ApiException;
import io.proximax.xpx.exceptions.InsufficientAmountException;
import org.nem.core.model.MultisigSignatureTransaction;
import org.nem.core.model.MultisigTransaction;
import org.nem.core.model.Transaction;
import org.nem.core.model.TransferTransaction;
import org.nem.core.model.ncc.NemAnnounceResult;
import org.nem.core.model.ncc.RequestAnnounce;
import org.nem.core.model.primitive.Amount;
import org.nem.core.serialization.BinarySerializer;
import org.nem.core.serialization.Deserializer;
import org.pmw.tinylog.Logger;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;
/**
* The Class TransactionSenderUtil.
*/
public class TransactionSender {
/** The Constant LOGGER. */
private final NemTransactionApi nemTransactionApi;
/** The proximax account api. */
private final NemAccountApi nemAccountApi;
/**
* Instantiates a new transaction sender.
*
* @param nemTransactionApi the proximax transaction api
* @param nemAccountApi the proximax account api
*/
public TransactionSender(NemTransactionApi nemTransactionApi, NemAccountApi nemAccountApi) {
this.nemTransactionApi = nemTransactionApi;
this.nemAccountApi = nemAccountApi;
}
/**
* Send transaction.
*
* @param transaction
* the transaction
* @throws ApiException
* the api exception
*/
public void sendTransaction(Transaction transaction) throws ApiException {
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
final CompletableFuture future = nemTransactionApi.announceTransaction(request);
try {
future.thenAcceptAsync(d -> {
final NemAnnounceResult result = new NemAnnounceResult(d);
switch (result.getCode()) {
case 1:
Logger.info(String.format("successfully send xem " + result.getMessage()));
break;
default:
Logger.info(String.format("could not send xem " + result.getMessage()));
}
}).exceptionally(e -> {
Logger.error("Error on uploading file data: " + e.getMessage());
return null;
}).get();
} catch (Exception e) {
Logger.error("Sending/Announcing Transfer Transaction: " + e.getMessage());
// e.printStackTrace();
}
}
/**
* Send transfer transaction.
*
* @param transaction the transaction
* @return the proximax announce result
* @throws ApiException the api exception
* @throws InterruptedException the interrupted exception
* @throws ExecutionException the execution exception
* @throws InsufficientAmountException the insufficient amount exception
*/
public NemAnnounceResult sendTransferTransaction(TransferTransaction transaction) throws ApiException, InterruptedException, ExecutionException, InsufficientAmountException {
checkAddressBalanceAgainstAmount(transaction.getSigner().getAddress().toString(), transaction.getAmount());
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
final CompletableFuture future = nemTransactionApi.announceTransaction(request);
try {
Deserializer transDes = future.get();
return new NemAnnounceResult(transDes);
} catch (Exception e) {
Logger.error("Sending/Announcing Transfer Transaction: " + e.getMessage());
}
return null;
}
/**
* Send transfer transaction.
*
* @param data
* the data
* @param signature
* the signature
* @return the proximax announce result
* @throws ApiException
* the api exception
*/
public NemAnnounceResult sendTransferTransaction(byte[] data, byte[] signature) throws ApiException {
final RequestAnnounce request = new RequestAnnounce(data, signature);
final CompletableFuture future = nemTransactionApi.announceTransaction(request);
try {
Deserializer transDes = future.get();
return new NemAnnounceResult(transDes);
} catch (Exception e) {
Logger.error("Error Occured: " + e.getMessage());
}
return null;
}
/**
* Send future transfer transaction.
*
* @param transaction the transaction
* @return the completable future
* @throws ApiException the api exception
* @throws InterruptedException the interrupted exception
* @throws ExecutionException the execution exception
* @throws InsufficientAmountException the insufficient amount exception
*/
public CompletableFuture sendFutureTransferTransaction(TransferTransaction transaction)
throws ApiException, InterruptedException, ExecutionException, InsufficientAmountException {
checkAddressBalanceAgainstAmount(transaction.getSigner().getAddress().toString(), transaction.getAmount());
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
return nemTransactionApi.announceTransaction(request);
}
/**
* Send multi sig transaction.
*
* @param transaction
* the transaction
* @return the proximax announce result
* @throws ApiException
* the api exception
*/
public NemAnnounceResult sendMultisigTransaction(MultisigTransaction transaction) throws ApiException {
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
final CompletableFuture future = nemTransactionApi.announceTransaction(request);
try {
Deserializer transDes = future.get();
return new NemAnnounceResult(transDes);
} catch (Exception e) {
Logger.error("Error Occured: " + e.getMessage());
}
return null;
}
/**
* Send future multi sig transaction.
*
* @param transaction
* the transaction
* @return the completable future
* @throws ApiException
* the api exception
*/
public CompletableFuture sendFutureMultiSigTransaction(MultisigTransaction transaction)
throws ApiException {
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
return nemTransactionApi.announceTransaction(request);
}
/**
* Send multisig signature transaction.
*
* @param transaction
* the transaction
* @return the proximax announce result
* @throws ApiException
* the api exception
*/
public NemAnnounceResult sendMultisigSignatureTransaction(MultisigSignatureTransaction transaction)
throws ApiException {
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
final CompletableFuture future = nemTransactionApi.announceTransaction(request);
try {
Deserializer transDes = future.get();
return new NemAnnounceResult(transDes);
} catch (Exception e) {
Logger.error("Error Occured: " + e.getMessage());
}
return null;
}
/**
* Send future multisig signature transaction.
*
* @param transaction
* the transaction
* @return the completable future
* @throws ApiException
* the api exception
*/
public CompletableFuture sendFutureMultisigSignatureTransaction(
MultisigSignatureTransaction transaction) throws ApiException {
final byte[] data = BinarySerializer.serializeToBytes(transaction.asNonVerifiable());
final RequestAnnounce request = new RequestAnnounce(data, transaction.getSignature().getBytes());
return nemTransactionApi.announceTransaction(request);
}
/**
* Check address balance against amount.
*
* @param address the address
* @param amount the amount
* @throws InterruptedException the interrupted exception
* @throws ExecutionException the execution exception
* @throws ApiException the api exception
* @throws InsufficientAmountException the insufficient amount exception
*/
private void checkAddressBalanceAgainstAmount(String address, Amount amount) throws InterruptedException, ExecutionException, ApiException, InsufficientAmountException {
long balance = nemAccountApi.getAccountByAddress(address).getEntity().getBalance().getNumNem();
long transactionAmount = amount.getNumNem();
if (balance < transactionAmount) {
throw new InsufficientAmountException("Insufficient amount for Address: " + address + ". Balance: " +amount.getNumNem() + ". Transaction Amount: " + transactionAmount);
}
}
}