src.main.java.org.kawanfw.sql.servlet.ServletMetadataQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aceql-http Show documentation
Show all versions of aceql-http Show documentation
AceQL HTTP is a framework of REST like http APIs that allow to access to remote SQL databases over http from any device that supports http.
AceQL HTTP is provided with three client SDK:
- The AceQL C# Client SDK allows to wrap the HTTP APIs using Microsoft SQL Server like calls in their code, just like they would for a local database.
- The AceQL Java Client JDBC Driver allows to wrap the HTTP APIs using JDBC calls in their code, just like they would for a local database.
- The AceQL Python Client SDK allows SQL calls to be encoded with standard unmodified DB-API 2.0 syntax
/*
* This file is part of AceQL HTTP.
* AceQL HTTP: SQL Over HTTP
* Copyright (C) 2020, KawanSoft SAS
* (http://www.kawansoft.com). All rights reserved.
*
* AceQL HTTP is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* AceQL HTTP is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA
*
* Any modifications to this file must keep this entire header
* intact.
*/
package org.kawanfw.sql.servlet;
import java.sql.SQLException;
import java.util.Objects;
public class ServletMetadataQuery {
public static final String METADATA_QUERY = "METADATA_QUERY";
private String requestUri = null;
public ServletMetadataQuery(String requestUri) {
this.requestUri =Objects.requireNonNull(requestUri, "requestUri cannot be null!");
}
public String getAction() {
if (requestUri.contains("/metadata_query/db_schema_download")) {
return HttpParameter.METADATA_QUERY_DB_SCHEMA_DOWNLOAD;
}
else if (requestUri.endsWith("/metadata_query/get_db_metadata")) {
return HttpParameter.METADATA_QUERY_GET_DB_METADATA;
}
else if (requestUri.endsWith("/metadata_query/get_table_names")) {
return HttpParameter.METADATA_QUERY_GET_TABLE_NAMES;
}
else if (requestUri.contains("/metadata_query/get_table")) {
return HttpParameter.METADATA_QUERY_GET_TABLE_DETAILS;
}
else {
throw new IllegalArgumentException("Unknown metadata_query action: " + requestUri);
}
}
public static boolean isMetadataQueryAction(String action) throws SQLException {
Objects.requireNonNull(action, "action cannot be null!");
return (action.equals(HttpParameter.METADATA_QUERY_DB_SCHEMA_DOWNLOAD)
|| action.equals(HttpParameter.METADATA_QUERY_GET_TABLE_DETAILS)
|| action.equals(HttpParameter.METADATA_QUERY_GET_DB_METADATA)
|| action.equals(HttpParameter.METADATA_QUERY_GET_TABLE_NAMES));
}
}