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

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

There is a newer version: 5.0.0.CR1
Show 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.db2client.impl.drda.DRDAQueryRequest;
import io.vertx.db2client.impl.drda.DRDAQueryResponse;
import io.vertx.db2client.impl.drda.Section;
import io.vertx.sqlclient.Row;
import io.vertx.sqlclient.impl.command.CommandResponse;
import io.vertx.sqlclient.impl.command.SimpleQueryCommand;

class SimpleQueryCommandCodec extends QueryCommandBaseCodec> {

  private Section querySection;

  SimpleQueryCommandCodec(SimpleQueryCommand cmd) {
    super(cmd);
  }

  @Override
  void encodeQuery(DRDAQueryRequest queryCommand) {
    querySection = encoder.socketConnection.connMetadata.sectionManager.getSection(cmd.sql());
    queryCommand.writePrepareDescribeOutput(cmd.sql(), encoder.socketConnection.connMetadata.databaseName, querySection);
    queryCommand.writeOpenQuery(querySection, encoder.socketConnection.connMetadata.databaseName, 0, ResultSet.TYPE_FORWARD_ONLY);
  }

  @Override
  void encodeUpdate(DRDAQueryRequest updateCommand) {
    querySection = encoder.socketConnection.connMetadata.sectionManager.getSection(cmd.sql());
    updateCommand.writeExecuteImmediate(cmd.sql(), querySection, encoder.socketConnection.connMetadata.databaseName);
    if (cmd.autoCommit()) {
      updateCommand.buildRDBCMM();
    }
  }

  void decodeUpdate(ByteBuf payload) {
    DRDAQueryResponse updateResponse = new DRDAQueryResponse(payload, encoder.socketConnection.connMetadata);
    querySection.release();

    int updatedCount = (int) updateResponse.readExecuteImmediate();
    T result = emptyResult(cmd.collector());
    cmd.resultHandler().handleResult(updatedCount, 0, null, result, null);

    if (cmd.autoCommit()) {
      updateResponse.readLocalCommit();
    }
    completionHandler.handle(CommandResponse.success(true));
  }

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

  void decodeQuery(ByteBuf payload) {
    querySection.release();

    DRDAQueryResponse resp = new DRDAQueryResponse(payload, encoder.socketConnection.connMetadata);
    resp.readPrepareDescribeOutput();
    resp.readBeginOpenQuery();
    columnDefinitions = resp.getOutputColumnMetaData();
    RowResultDecoder decoder = new RowResultDecoder<>(cmd.collector(), DB2RowDesc.create(columnDefinitions), resp.getCursor(), resp);

    while (decoder.next()) {
      decoder.handleRow(columnDefinitions.columns_, payload);
    }
    if (decoder.isQueryComplete()) {
      decoder.cursor.setAllRowsReceivedFromServer(true);
    } else {
      throw new UnsupportedOperationException("Need to fetch more data from DB");
    }

    handleQueryResult(decoder);
    completionHandler.handle(CommandResponse.success(true));
  }

  @Override
  public String toString() {
    return super.toString() + ", section=" + querySection;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy