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

edu.psu.cse.siis.ic3.db.IntentTable Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2015 The Pennsylvania State University and the University of Wisconsin
 * Systems and Internet Infrastructure Security Laboratory
 *
 * Author: Damien Octeau
 *
 * 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 edu.psu.cse.siis.ic3.db;

import java.sql.SQLException;

public class IntentTable extends Table {
  private static final String INSERT = "INSERT INTO Intents (exit_id, implicit, alias) "
      + "VALUES (?, ?, ?)";

  // private static final String FIND = "SELECT Intents.id, COUNT(Intents.id) AS cnt "
  // + "FROM Intents " + "LEFT JOIN IActions ON Intents.id = IActions.intent_id "
  // + "LEFT JOIN ICategories ON Intents.id = ICategories.intent_id "
  // + "LEFT JOIN IMimeTypes ON Intents.id = IMimeTypes.intent_id "
  // + "LEFT JOIN IExtras ON Intents.id = IExtras.intent_id " + "WHERE exit_id = ? AND alias = ?";

  public int forceInsert(int exitId, boolean implicit, boolean alias) throws SQLException {
    // int id = find(connection, componentId, actions, categories, mimeTypes);
    // if (id != NOT_FOUND) {
    // return id;
    // }
    if (insertStatement == null || insertStatement.isClosed()) {
      insertStatement = getConnection().prepareStatement(INSERT);
    }
    insertStatement.setInt(1, exitId);
    insertStatement.setBoolean(2, implicit);
    insertStatement.setBoolean(3, alias);
    if (insertStatement.executeUpdate() == 0) {
      return NOT_FOUND;
    }
    return findAutoIncrement();
  }

  // public int find(int exitId, List actions, List categories, String mimeType,
  // Set extras, boolean alias) throws SQLException {
  // StringBuilder queryBuilder = new StringBuilder(FIND);
  //
  // if (actions != null && actions.size() > 0) {
  // queryBuilder.append(" AND (1 = 0");
  // for (int i = 0; i < actions.size(); ++i) {
  // queryBuilder.append(" OR action = ?");
  // }
  // queryBuilder.append(")");
  // } else {
  // queryBuilder.append(" AND action IS ?");
  // }
  // int finalCount = 1;
  // if (categories != null && categories.size() > 0) {
  // queryBuilder.append(" AND (1 = 0");
  // for (int i = 0; i < categories.size(); ++i) {
  // queryBuilder.append(" OR category = ?");
  // }
  // queryBuilder.append(")");
  // finalCount *= categories.size();
  // } else {
  // queryBuilder.append(" AND category IS ?");
  // }
  // String[] typeParts = null;
  // if (mimeType != null) {
  // if (mimeType.equals(Constants.ANY_STRING)) {
  // queryBuilder.append(" AND type = ? AND subtype = ?");
  // typeParts = new String[] { "*", "*" };
  // } else {
  // typeParts = mimeType.split("/");
  // if (typeParts.length == 2) {
  // queryBuilder.append(" AND type = ? AND subtype = ?");
  // } else {
  // System.err.println("Warning: invalid type: " + mimeType);
  // queryBuilder.append(" AND type IS ? AND subtype IS ?");
  // typeParts = null;
  // }
  // }
  // } else {
  // queryBuilder.append(" AND type IS ? AND subtype IS ?");
  // }
  // if (extras != null && extras.size() > 0) {
  // queryBuilder.append(" AND (1 = 0");
  // for (int i = 0; i < extras.size(); ++i) {
  // queryBuilder.append(" OR extra = ?");
  // }
  // queryBuilder.append(")");
  // finalCount *= extras.size();
  // } else {
  // queryBuilder.append(" AND extra IS ?");
  // }
  //
  // findStatement = getConnection().prepareStatement(queryBuilder.toString());
  //
  // findStatement.setInt(1, exitId);
  //
  // findStatement.setBoolean(2, alias);
  //
  // int parameterIndex = 3;
  //
  // if (actions != null && actions.size() > 0) {
  // for (Integer action : actions) {
  // findStatement.setInt(parameterIndex++, action);
  // }
  // } else {
  // findStatement.setNull(parameterIndex++, Types.INTEGER);
  // }
  // if (categories != null && categories.size() > 0) {
  // for (Integer category : categories) {
  // findStatement.setInt(parameterIndex++, category);
  // }
  // } else {
  // findStatement.setNull(parameterIndex++, Types.INTEGER);
  // }
  // if (typeParts != null && typeParts.length == 2) {
  // findStatement.setString(parameterIndex++, typeParts[0]);
  // findStatement.setString(parameterIndex++, typeParts[1]);
  // } else {
  // findStatement.setNull(parameterIndex++, Types.VARCHAR);
  // findStatement.setNull(parameterIndex++, Types.VARCHAR);
  // }
  // if (extras != null && extras.size() > 0) {
  // for (String extra : extras) {
  // findStatement.setString(parameterIndex++, extra);
  // }
  // } else {
  // findStatement.setNull(parameterIndex, Types.VARCHAR);
  // }
  //
  // // System.out.println(findStatement);
  // ResultSet resultSet = findStatement.executeQuery();
  // int result;
  // if (resultSet.next() && resultSet.getInt("cnt") == finalCount) {
  // result = resultSet.getInt("Intents.id");
  // } else {
  // result = NOT_FOUND;
  // }
  // resultSet.close();
  // findStatement.close();
  //
  // return result;
  // }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy