All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hedera.hashgraph.sdk.ContractCallQuery Maven / Gradle / Ivy

There is a newer version: 2.45.0
Show newest version
/*-
 *
 * Hedera Java SDK
 *
 * Copyright (C) 2020 - 2024 Hedera Hashgraph, 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 com.hedera.hashgraph.sdk;

import com.google.protobuf.ByteString;
import com.hedera.hashgraph.sdk.proto.ContractCallLocalQuery;
import com.hedera.hashgraph.sdk.proto.QueryHeader;
import com.hedera.hashgraph.sdk.proto.Response;
import com.hedera.hashgraph.sdk.proto.ResponseHeader;
import com.hedera.hashgraph.sdk.proto.SmartContractServiceGrpc;
import io.grpc.MethodDescriptor;
import java.util.Arrays;
import java.util.Objects;
import java.util.concurrent.CompletableFuture;
import javax.annotation.Nullable;

/**
 * Call a function of the given smart contract instance, giving it functionParameters as its inputs.
 * It will consume the entire given amount of gas.
 * 

* This is performed locally on the particular node that the client is communicating with. * It cannot change the state of the contract instance (and so, cannot spend * anything from the instance's cryptocurrency account). *

* It will not have a consensus timestamp. It cannot generate a record or a receipt. * The response will contain the output returned by the function call. * This is useful for calling getter functions, which purely read the state and don't change it. * It is faster and cheaper than a normal call, because it is purely local to a single node. */ public final class ContractCallQuery extends Query { @Nullable private ContractId contractId = null; private long gas = 0; private byte[] functionParameters = {}; private long maxResultSize = 0; @Nullable private AccountId senderAccountId = null; /** * Constructor. */ public ContractCallQuery() { } /** * Extract the contract id. * * @return the contract id */ @Nullable public ContractId getContractId() { return contractId; } /** * Sets the contract instance to call, in the format used in transactions. * * @param contractId The ContractId to be set * @return {@code this} */ public ContractCallQuery setContractId(ContractId contractId) { Objects.requireNonNull(contractId); this.contractId = contractId; return this; } /** * Extract the gas. * * @return the gas */ public long getGas() { return gas; } /** * Sets the amount of gas to use for the call. *

* All of the gas offered will be charged for. * * @param gas The long to be set as gas * @return {@code this} */ public ContractCallQuery setGas(long gas) { this.gas = gas; return this; } @Override public CompletableFuture getCostAsync(Client client) { // network bug: ContractCallLocal cost estimate is too low return super.getCostAsync(client).thenApply(cost -> Hbar.fromTinybars((long) (cost.toTinybars() * 1.1))); } /** * Extract the function parameters. * * @return the byte string representation */ public ByteString getFunctionParameters() { return ByteString.copyFrom(functionParameters); } /** * Sets the function parameters as their raw bytes. *

* Use this instead of {@link #setFunction(String, ContractFunctionParameters)} if you have already * pre-encoded a solidity function call. * * @param functionParameters The function parameters to be set * @return {@code this} */ public ContractCallQuery setFunctionParameters(byte[] functionParameters) { this.functionParameters = Arrays.copyOf(functionParameters, functionParameters.length); return this; } /** * Sets the function name to call. *

* The function will be called with no parameters. Use {@link #setFunction(String, ContractFunctionParameters)} * to call a function with parameters. * * @param name The function name to be set * @return {@code this} */ public ContractCallQuery setFunction(String name) { return setFunction(name, new ContractFunctionParameters()); } /** * Sets the function to call, and the parameters to pass to the function. * * @param name The function name to be set * @param params The parameters to pass * @return {@code this} */ public ContractCallQuery setFunction(String name, ContractFunctionParameters params) { Objects.requireNonNull(params); setFunctionParameters(params.toBytes(name).toByteArray()); return this; } /** * Get the max number of bytes that the result might include * * @deprecated with no replacement * @return the max number of byes */ @Deprecated public long getMaxResultSize() { return maxResultSize; } /** * @deprecated with no replacement *
* Sets the max number of bytes that the result might include. * The run will fail if it had returned more than this number of bytes. * * @param size The long to be set as size * @return {@code this} */ @Deprecated public ContractCallQuery setMaxResultSize(long size) { maxResultSize = size; return this; } /** * Get the sender account ID * @return the account that is the "sender" */ @Nullable public AccountId getSenderAccountId() { return senderAccountId; } /** * Sets the account that is the "sender." If not present it is the accountId from the transactionId. * Typically a different value than specified in the transactionId requires a valid signature * over either the hedera transaction or foreign transaction data. * * @param senderAccountId the account that is the "sender" * @return {@code this} */ public ContractCallQuery setSenderAccountId(AccountId senderAccountId) { Objects.requireNonNull(senderAccountId); this.senderAccountId = senderAccountId; return this; } @Override void validateChecksums(Client client) throws BadEntityIdException { if (contractId != null) { contractId.validateChecksum(client); } } @Override void onMakeRequest(com.hedera.hashgraph.sdk.proto.Query.Builder queryBuilder, QueryHeader header) { var builder = ContractCallLocalQuery.newBuilder(); if (contractId != null) { builder.setContractID(contractId.toProtobuf()); } builder.setGas(gas); builder.setFunctionParameters(ByteString.copyFrom(functionParameters)); if (senderAccountId != null) { builder.setSenderId(senderAccountId.toProtobuf()); } queryBuilder.setContractCallLocal(builder.setHeader(header)); } @Override ResponseHeader mapResponseHeader(Response response) { return response.getContractCallLocal().getHeader(); } @Override QueryHeader mapRequestHeader(com.hedera.hashgraph.sdk.proto.Query request) { return request.getContractCallLocal().getHeader(); } @Override ContractFunctionResult mapResponse(Response response, AccountId nodeId, com.hedera.hashgraph.sdk.proto.Query request) { return new ContractFunctionResult(response.getContractCallLocal().getFunctionResult()); } @Override MethodDescriptor getMethodDescriptor() { return SmartContractServiceGrpc.getContractCallLocalMethodMethod(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy