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

io.vertx.db2client.impl.codec.ExtendedQueryCommandBaseCodec Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2019,2020 IBM Corporation
 *
 * 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.vertx.db2client.impl.codec;

import java.sql.ResultSet;
import java.util.stream.Collector;

import io.netty.buffer.ByteBuf;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.internal.buffer.BufferInternal;
import io.vertx.db2client.impl.codec.DB2PreparedStatement.QueryInstance;
import io.vertx.db2client.impl.drda.DRDAQueryRequest;
import io.vertx.db2client.impl.drda.DRDAQueryResponse;
import io.vertx.sqlclient.Row;
import io.vertx.sqlclient.Tuple;
import io.vertx.sqlclient.data.Numeric;
import io.vertx.sqlclient.internal.command.CommandResponse;
import io.vertx.sqlclient.internal.command.ExtendedQueryCommand;

abstract class ExtendedQueryCommandBaseCodec>
    extends QueryCommandBaseCodec {

  final DB2PreparedStatement statement;

  ExtendedQueryCommandBaseCodec(C cmd) {
    super(cmd);
    statement = (DB2PreparedStatement) cmd.preparedStatement();
    columnDefinitions = statement.rowDesc.columnDefinitions();
  }

  void encodePreparedQuery(DRDAQueryRequest queryRequest, QueryInstance queryInstance, Tuple params) {
    int requiredParams = statement.paramDesc.paramDefinitions().columns_;
    if (params.size() != requiredParams) {
      completionHandler.handle(CommandResponse.failure("Only " + params.size()
          + " prepared statement parameters were provided " + "but " + requiredParams + " parameters are required."));
      return;
    }

    Object[] inputs = sanitize(params);
    if (queryInstance.cursor == null) {
      queryRequest.writeOpenQuery(statement.section, encoder.socketConnection.connMetadata.databaseName, cmd.fetch(),
          ResultSet.TYPE_FORWARD_ONLY, statement.paramDesc.paramDefinitions(), inputs);
    } else {
      queryRequest.writeFetch(statement.section, encoder.socketConnection.connMetadata.databaseName, cmd.fetch(),
          queryInstance.queryInstanceId);
    }
  }

  void encodePreparedUpdate(DRDAQueryRequest queryRequest, Tuple params) {
    Object[] inputs = sanitize(params);
    boolean outputExpected = false;
    boolean chainAutoCommit = true;
    queryRequest.writeExecute(statement.section, encoder.socketConnection.connMetadata.databaseName,
        statement.paramDesc.paramDefinitions(), inputs, outputExpected, chainAutoCommit);
  }

  RowResultDecoder decodePreparedQuery(ByteBuf payload, DRDAQueryResponse resp, QueryInstance queryInstance) {
    RowResultDecoder decoder = null;
    if (queryInstance.cursor == null) {
      resp.setOutputColumnMetaData(columnDefinitions);
      resp.readBeginOpenQuery();
      decoder = new RowResultDecoder<>(cmd.collector(), DB2RowDesc.create(columnDefinitions), resp.getCursor(), resp);
      queryInstance.cursor = resp.getCursor();
      queryInstance.queryInstanceId = resp.getQueryInstanceId();
    } else {
      resp.readFetch(queryInstance.cursor);
      decoder = new RowResultDecoder<>(cmd.collector(), statement.rowDesc, queryInstance.cursor, resp);
    }
    while (decoder.next()) {
      decoder.handleRow(columnDefinitions.columns_, payload);
    }
    if (decoder.isQueryComplete()) {
      resp.readEndOpenQuery();
      statement.closeQuery(queryInstance);
    }
    return decoder;
  }

  void handleUpdateResult(DRDAQueryResponse updateResponse) {
    int updatedCount = (int) updateResponse.readExecute();
    R result = emptyResult(cmd.collector());
    cmd.resultHandler().handleResult(updatedCount, 0, null, result, null);
  }

  static  T emptyResult(Collector collector) {
    return collector.finisher().apply(collector.supplier().get());
  }

  private static Object[] sanitize(Tuple params) {
    Object[] inputs = new Object[params.size()];
    for (int i = 0; i < params.size(); i++) {
      Object val = params.getValue(i);
      if (val instanceof Numeric)
        val = ((Numeric) val).bigDecimalValue();
      if (val instanceof Buffer)
        val = ((BufferInternal) val).getByteBuf();
      inputs[i] = val;
    }
    return inputs;
  }

  @Override
  public String toString() {
    if (isQuery)
      return super.toString() + ", ps=" + statement + ", fetch=" + cmd.fetch();
    else
      return super.toString() + ", ps=" + statement;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy