io.hotmoka.node.local.internal.builders.InitialResponseBuilderImpl Maven / Gradle / Ivy
/*
Copyright 2021 Fausto Spoto
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.hotmoka.node.local.internal.builders;
import java.math.BigInteger;
import java.util.concurrent.Callable;
import io.hotmoka.node.api.TransactionRejectedException;
import io.hotmoka.node.api.requests.InitialTransactionRequest;
import io.hotmoka.node.api.responses.InitialTransactionResponse;
import io.hotmoka.node.api.transactions.TransactionReference;
import io.hotmoka.node.local.api.StoreException;
/**
* Implementation of the creator of the response for an initial transaction. Initial transactions do not consume gas.
*
* @param the type of the request of the transaction
* @param the type of the response of the transaction
*/
public abstract class InitialResponseBuilderImpl, Response extends InitialTransactionResponse> extends AbstractResponseBuilder {
/**
* Creates the builder of the response.
*
* @param reference the reference to the transaction that is building the response
* @param request the request of the transaction
* @param environment the execution environment where the response is built
* @throws TransactionRejectedException if the builder cannot be created
* @throws StoreException if the operation cannot be completed correctly
*/
protected InitialResponseBuilderImpl(TransactionReference reference, Request request, ExecutionEnvironment environment) throws TransactionRejectedException, StoreException {
super(reference, request, environment);
if (environment.getManifest().isPresent())
throw new TransactionRejectedException("Cannot run an initial transaction request in an already initialized node", consensus);
}
protected abstract class ResponseCreator extends AbstractResponseBuilder.ResponseCreator {
protected ResponseCreator() {
}
@Override
public final void chargeGasForCPU(BigInteger amount) {
// initial transactions consume no gas; this implementation is needed
// since code run in initial transactions (such as the creation of gametes) tries to charge for gas
}
@Override
public final void chargeGasForRAM(BigInteger amount) {
// initial transactions consume no gas; this implementation is needed
// since code run in initial transactions (such as the creation of gametes) tries to charge for gas
}
@Override
public final void event(Object event) {
// initial transactions do not generate events
}
@Override
public final T withGas(BigInteger amount, Callable what) throws Exception {
// initial transactions consume no gas; this implementation is needed
// if (in the future) code run in initial transactions tries to run tasks with a limited amount of gas
return what.call();
}
}
}