DiagnosticDriver.java
/*
* GovWay - A customizable API Gateway
* https://govway.org
*
* Copyright (c) 2005-2025 Link.it srl (https://link.it).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3, as published by
* the Free Software Foundation.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openspcoop2.protocol.basic.diagnostica;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
import javax.sql.DataSource;
import org.openspcoop2.protocol.basic.BasicComponentFactory;
import org.openspcoop2.protocol.basic.Costanti;
import org.openspcoop2.protocol.sdk.IProtocolFactory;
import org.openspcoop2.protocol.sdk.ProtocolException;
import org.openspcoop2.protocol.sdk.diagnostica.DriverMsgDiagnosticiException;
import org.openspcoop2.protocol.sdk.diagnostica.DriverMsgDiagnosticiNotFoundException;
import org.openspcoop2.protocol.sdk.diagnostica.FiltroRicercaDiagnostici;
import org.openspcoop2.protocol.sdk.diagnostica.FiltroRicercaDiagnosticiConPaginazione;
import org.openspcoop2.protocol.sdk.diagnostica.IDiagnosticDriver;
import org.openspcoop2.protocol.sdk.diagnostica.MsgDiagnostico;
import org.openspcoop2.protocol.sdk.tracciamento.DriverTracciamentoException;
import org.openspcoop2.utils.LoggerWrapperFactory;
import org.openspcoop2.utils.StringWrapper;
import org.openspcoop2.utils.TipiDatabase;
import org.openspcoop2.utils.jdbc.JDBCUtilities;
import org.openspcoop2.utils.resources.GestoreJNDI;
import org.openspcoop2.utils.sql.ISQLQueryObject;
import org.slf4j.Logger;
/**
* Interfaccia di ricerca dei messaggi diagnostici
*
* @author Stefano Corallo (corallo@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class DiagnosticDriver extends BasicComponentFactory implements IDiagnosticDriver {
/**
* DataSource
*/
DataSource datasource = null;
/**
* SQLQueryObject
*/
String tipoDatabase = null;
Connection con = null;
boolean connectionOpenViaJDBCInCostructor = false;
public DiagnosticDriver(IProtocolFactory<?> factory) throws ProtocolException{
super(factory);
}
private static final String QUERY_PREFIX = "Query : ";
private static final String ROWS_SUFFIX = " rows";
public static final String IDDIAGNOSTICI = "@@@@@-----@@@@-----IDDIAGNOSTICI-DB----@@@@@-----@@@@";
/**
* Properties per campi aggiuntivi
*/
private List<String> propertiesMsgDiagnostici;
public void setPropertiesMsgDiagnostici(List<String> properties) {
this.propertiesMsgDiagnostici = properties;
}
public void init(String nomeDataSource, String tipoDatabase, Properties jndiProperties) throws DriverMsgDiagnosticiException {
init(nomeDataSource,tipoDatabase,jndiProperties,null);
}
public void init(String nomeDataSource, String tipoDatabase, Properties jndiProperties, Logger log) throws DriverMsgDiagnosticiException {
// Logger
try {
if(log==null)
this.log = LoggerWrapperFactory.getLogger(Costanti.LOGANALIZER_DRIVER_DB_LOGGER);
else
this.log = log;
} catch (Exception e) {
throw new DriverMsgDiagnosticiException("Errore durante l'inizializzazione del logger (datasource params): "+e.getMessage(),e);
}
// Datasource
try {
this.log.info("Inizializzo DriverLogAnalyzer...");
GestoreJNDI gestoreJNDI = new GestoreJNDI(jndiProperties);
this.datasource = (DataSource) gestoreJNDI.lookup(nomeDataSource);
if (this.datasource == null)
throw new DriverMsgDiagnosticiException ("datasource is null");
this.log.info("Inizializzo DriverLogAnalyzer terminata.");
} catch (Exception e) {
this.logError("Errore durante la ricerca del datasource (datasource params): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante la ricerca del datasource (datasource params): "+e.getMessage(),e);
}
// ISQLQueryObject
try {
this.log.info("Inizializzo ISQLQueryObject (datasource params)");
if (TipiDatabase.isAMember(tipoDatabase)) {
this.tipoDatabase = tipoDatabase;
} else {
throw new DriverMsgDiagnosticiException("Tipo database non gestito (datasource params)");
}
this.log.info("Inizializzo ISQLQueryObject terminata (datasource params)");
} catch (Exception e) {
this.logError("Errore durante la ricerca del SQLQueryObject (datasource params): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante la ricerca del SQLQueryObject (datasource params): "+e.getMessage(),e);
}
}
public void init(DataSource dataSourceObject, String tipoDatabase) throws DriverMsgDiagnosticiException {
init(dataSourceObject,tipoDatabase,null);
}
public void init(DataSource dataSourceObject, String tipoDatabase, Logger log) throws DriverMsgDiagnosticiException {
// Logger
try {
if(log==null)
this.log = LoggerWrapperFactory.getLogger(Costanti.LOGANALIZER_DRIVER_DB_LOGGER);
else
this.log = log;
} catch (Exception e) {
throw new DriverMsgDiagnosticiException("Errore durante l'inizializzazione del logger (datasource): "+e.getMessage(),e);
}
// Datasource
try {
this.datasource = dataSourceObject;
if (this.datasource == null)
throw new DriverMsgDiagnosticiException ("datasource is null");
} catch (Exception e) {
this.logError("Errore durante l'assegnamento del datasource (datasource): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante l'assegnamento del datasource (datasource): "+e.getMessage(),e);
}
// ISQLQueryObject
try {
this.log.info("Inizializzo ISQLQueryObject (datasource)");
if (TipiDatabase.isAMember(tipoDatabase)) {
this.tipoDatabase = tipoDatabase;
} else {
throw new DriverMsgDiagnosticiException("Tipo database non gestito (datasource)");
}
this.log.info("Inizializzo ISQLQueryObject terminata (datasource)");
} catch (Exception e) {
this.logError("Errore durante la ricerca del SQLQueryObject (datasource): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante la ricerca del SQLQueryObject (datasource): "+e.getMessage(),e);
}
}
public void init(Connection connection, String tipoDatabase, Logger log) throws DriverMsgDiagnosticiException {
// Logger
try {
this.log = log;
} catch (Exception e) {
throw new DriverMsgDiagnosticiException("Errore durante l'inizializzazione del logger (connection): "+e.getMessage(),e);
}
// connection
this.con = connection;
// ISQLQueryObject
try {
this.log.info("Inizializzo ISQLQueryObject (connection)");
if (TipiDatabase.isAMember(tipoDatabase)) {
this.tipoDatabase = tipoDatabase;
} else {
throw new DriverMsgDiagnosticiException("Tipo database non gestito (connection)");
}
this.log.info("Inizializzo ISQLQueryObject terminata (connection)");
} catch (Exception e) {
this.logError("Errore durante la ricerca del SQLQueryObject (connection): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante la ricerca del SQLQueryObject (connection): "+e.getMessage(),e);
}
}
public void init(String urlJDBC,String driverJDBC,
String username,String password, String tipoDatabase, Logger log) throws DriverMsgDiagnosticiException {
// Logger
try {
this.log = log;
} catch (Exception e) {
throw new DriverMsgDiagnosticiException("Errore durante l'inizializzazione del logger (connectionUrl params): "+e.getMessage(),e);
}
// connection
try {
Class.forName(driverJDBC);
if(username!=null){
this.con = DriverManager.getConnection(urlJDBC,username,password);
}else{
this.con = DriverManager.getConnection(urlJDBC);
}
this.connectionOpenViaJDBCInCostructor = true;
} catch (Exception e) {
this.logError("Errore durante l'inizializzazione della connessione (connectionUrl params): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante l'inizializzazione della connessione (connectionUrl params): "+e.getMessage(),e);
}
// ISQLQueryObject
try {
this.log.info("Inizializzo ISQLQueryObject (connectionUrl params)");
if (TipiDatabase.isAMember(tipoDatabase)) {
this.tipoDatabase = tipoDatabase;
} else {
throw new DriverMsgDiagnosticiException("Tipo database non gestito (connectionUrl params)");
}
this.log.info("Inizializzo ISQLQueryObject terminata (connectionUrl params)");
} catch (Exception e) {
this.logError("Errore durante la ricerca del SQLQueryObject (connectionUrl params): "+e.getMessage(),e);
throw new DriverMsgDiagnosticiException("Errore durante la ricerca del SQLQueryObject (connectionUrl params): "+e.getMessage(),e);
}
}
/* *********** ACCESSI TRAMITE RICERCHE (DIAGNOSTICI) ******* */
/**
* Si occupa di ritornare il numero di diagnostici che rispettano il filtro di ricerca
*
* @param filtro Filtro di ricerca
* @return numero di diagnostici che rispettano il filtro di ricerca
*
*/
@Override
public int countMessaggiDiagnostici(FiltroRicercaDiagnostici filtro) throws DriverMsgDiagnosticiException{
PreparedStatement stmt = null;
ResultSet rs=null;
Connection connectionDB = null;
boolean closeConnection = true;
ISQLQueryObject sqlObj = null;
int countDiagnostici = 0;
try{
if(this.con!=null){
connectionDB=this.con;
closeConnection=false;
}else{
connectionDB = this.datasource.getConnection();
}
checkConnection(connectionDB);
sqlObj = DiagnosticDriverUtilities.createSQLQueryObj_countMessaggiDiagnostici(filtro, this.tipoDatabase);
StringWrapper sqlDebug = new StringWrapper(sqlObj.createSQLQuery());
DiagnosticDriverUtilities.setValues_countMessaggiDiagnostici(filtro, sqlDebug, 1);
this.logDebug(QUERY_PREFIX+sqlDebug);
String sql = sqlObj.createSQLQuery();
stmt=connectionDB.prepareStatement(sql);
DiagnosticDriverUtilities.setValues_countMessaggiDiagnostici(filtro, stmt, 1);
rs=stmt.executeQuery();
if(rs.next()){
countDiagnostici = rs.getInt("countMsgDiagnostici");
}
this.logDebug("Query found "+countDiagnostici+ROWS_SUFFIX);
return countDiagnostici;
}catch (DriverMsgDiagnosticiException e) {
throw e;
}catch (Exception e) {
throw new DriverMsgDiagnosticiException(e);
}finally{
JDBCUtilities.closeResources(rs, stmt);
if(closeConnection){
try{
JDBCUtilities.closeConnection(BasicComponentFactory.getCheckLogger(), connectionDB, BasicComponentFactory.isCheckAutocommit(), BasicComponentFactory.isCheckIsClosed());
}catch (Exception e) {
// ignore
}
}
}
}
/**
* Si occupa di ritornare i diagnostici che rispettano il filtro di ricerca
*
* @param filtro Filtro di ricerca
* @return diagnostici che rispettano il filtro di ricerca
*
*/
@Override
public List<MsgDiagnostico> getMessaggiDiagnostici(FiltroRicercaDiagnosticiConPaginazione filtro)
throws DriverMsgDiagnosticiException, DriverMsgDiagnosticiNotFoundException{
PreparedStatement stmt = null;
ResultSet rs=null;
Connection connectionDB = null;
boolean closeConnection = true;
ISQLQueryObject sqlObj = null;
try{
ArrayList<MsgDiagnostico> listaMSGDiagnostici = new ArrayList<>();
if(this.con!=null){
connectionDB=this.con;
closeConnection=false;
}else{
connectionDB = this.datasource.getConnection();
}
checkConnection(connectionDB);
sqlObj = DiagnosticDriverUtilities.createSQLQueryObj_searchMessaggiDiagnostici(filtro, this.tipoDatabase);
StringWrapper sqlDebug = new StringWrapper(sqlObj.createSQLQuery());
DiagnosticDriverUtilities.setValues_searchMessaggiDiagnostici(filtro, sqlDebug, 1);
this.logDebug(QUERY_PREFIX+sqlDebug);
String sql = sqlObj.createSQLQuery();
stmt=connectionDB.prepareStatement(sql);
DiagnosticDriverUtilities.setValues_searchMessaggiDiagnostici(filtro, stmt, 1);
rs=stmt.executeQuery();
while(rs.next()){
long idMsgDiagnostico = rs.getLong("idMsgDiagnostico");
MsgDiagnostico msgDiag =
DiagnosticDriverUtilities.getMsgDiagnostico(connectionDB, this.tipoDatabase,
this.log, idMsgDiagnostico, this.propertiesMsgDiagnostici);
listaMSGDiagnostici.add(msgDiag);
}
rs.close();
stmt.close();
this.logDebug("Query found "+listaMSGDiagnostici.size()+ROWS_SUFFIX);
if(!listaMSGDiagnostici.isEmpty())
return listaMSGDiagnostici;
else
throw new DriverMsgDiagnosticiNotFoundException("Non sono stati trovati diagnostici che rispettano il filtro impostato");
}catch (DriverMsgDiagnosticiNotFoundException | DriverMsgDiagnosticiException e) {
throw e;
}catch (Exception e) {
throw new DriverMsgDiagnosticiException(e);
}finally{
JDBCUtilities.closeResources(rs, stmt);
if(closeConnection){
try{
JDBCUtilities.closeConnection(BasicComponentFactory.getCheckLogger(), connectionDB, BasicComponentFactory.isCheckAutocommit(), BasicComponentFactory.isCheckIsClosed());
}catch (Exception e) {
// ignore
}
}
}
}
/**
* Si occupa di eliminare i diagnostici che rispettano il filtro di ricerca
*
* @param filter Filtro di ricerca
* @return numero di diagnostici eliminati
* @throws DriverTracciamentoException
*/
@Override
public int deleteMessaggiDiagnostici(FiltroRicercaDiagnostici filter) throws DriverMsgDiagnosticiException{
PreparedStatement stmt = null;
int deleted = 0;
Connection connectionDB = null;
boolean closeConnection = true;
ISQLQueryObject sqlObj = null;
try{
if(this.con!=null){
connectionDB=this.con;
closeConnection=false;
}else{
connectionDB = this.datasource.getConnection();
}
checkConnection(connectionDB);
sqlObj = DiagnosticDriverUtilities.createSQLQueryObj_deleteMessaggiDiagnostici(filter, this.tipoDatabase);
StringWrapper sqlDebug = new StringWrapper(sqlObj.createSQLDelete());
DiagnosticDriverUtilities.setValues_deleteMessaggiDiagnostici(filter, sqlDebug, 1);
this.logDebug(QUERY_PREFIX+sqlDebug);
String sql = sqlObj.createSQLDelete();
stmt=connectionDB.prepareStatement(sql);
DiagnosticDriverUtilities.setValues_deleteMessaggiDiagnostici(filter, stmt, 1);
deleted = stmt.executeUpdate();
stmt.close();
this.logDebug("Deleted "+deleted+ROWS_SUFFIX);
return deleted;
}catch (DriverMsgDiagnosticiException e) {
throw e;
}catch (Exception e) {
throw new DriverMsgDiagnosticiException(e);
}finally{
JDBCUtilities.closeResources(stmt);
if(closeConnection){
try{
JDBCUtilities.closeConnection(BasicComponentFactory.getCheckLogger(), connectionDB, BasicComponentFactory.isCheckAutocommit(), BasicComponentFactory.isCheckIsClosed());
}catch (Exception e) {
// ignore
}
}
}
}
/* ******* RISORSE INTERNE ********** */
@Override
public void close() throws DriverMsgDiagnosticiException {
try{
if(this.connectionOpenViaJDBCInCostructor &&
this.con!=null && !this.con.isClosed()){
JDBCUtilities.closeConnection(BasicComponentFactory.getCheckLogger(), this.con, BasicComponentFactory.isCheckAutocommit(), BasicComponentFactory.isCheckIsClosed());
}
}catch(Exception e){
throw new DriverMsgDiagnosticiException(e.getMessage(),e);
}
}
/* ------------- UTILITY INTERNE -------------------------- */
private void checkConnection(Connection con) throws DriverMsgDiagnosticiException {
if(con==null &&
this.con==null) {
throw new DriverMsgDiagnosticiException("Connection non ottenuta dal datasource["+this.datasource+"]");
}
}
/**
* Viene chiamato in causa per ottenere una connessione al DB
*/
public java.sql.Connection getConnection() {
if (this.datasource == null) {
return null;
}
Connection connectionDB = null;
try {
connectionDB = this.datasource.getConnection();
} catch (Exception e) {
return null;
}
return connectionDB;
}
/**
* Viene chiamato in causa per rilasciare una connessione al DB, effettuando
* precedentemente un commit
*
* @param connectionDB
* Connessione da rilasciare.
*/
public void releaseConnection(java.sql.Connection connectionDB) {
try {
JDBCUtilities.closeConnection(BasicComponentFactory.getCheckLogger(), connectionDB, BasicComponentFactory.isCheckAutocommit(), BasicComponentFactory.isCheckIsClosed());
} catch (SQLException e) {
// ignore
}
}
/**
* Viene chiamato in causa per ottenere il tipoDatabase
*/
public String getTipoDatabase() {
return this.tipoDatabase;
}
}