From 71672d46ee7bb3151a46c86ecbec81b7d86cad7f Mon Sep 17 00:00:00 2001 From: Darin Kelkhoff Date: Thu, 20 Jul 2023 20:11:46 -0500 Subject: [PATCH] Initial checkin --- .../actions/StatementTimeoutCanceller.java | 73 +++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 qqq-backend-module-rdbms/src/main/java/com/kingsrook/qqq/backend/module/rdbms/actions/StatementTimeoutCanceller.java diff --git a/qqq-backend-module-rdbms/src/main/java/com/kingsrook/qqq/backend/module/rdbms/actions/StatementTimeoutCanceller.java b/qqq-backend-module-rdbms/src/main/java/com/kingsrook/qqq/backend/module/rdbms/actions/StatementTimeoutCanceller.java new file mode 100644 index 00000000..f43e7b92 --- /dev/null +++ b/qqq-backend-module-rdbms/src/main/java/com/kingsrook/qqq/backend/module/rdbms/actions/StatementTimeoutCanceller.java @@ -0,0 +1,73 @@ +/* + * QQQ - Low-code Application Framework for Engineers. + * Copyright (C) 2021-2023. Kingsrook, LLC + * 651 N Broad St Ste 205 # 6917 | Middletown DE 19709 | United States + * contact@kingsrook.com + * https://github.com/Kingsrook/ + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * 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 Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + */ + +package com.kingsrook.qqq.backend.module.rdbms.actions; + + +import java.sql.Statement; +import com.kingsrook.qqq.backend.core.exceptions.QRuntimeException; +import com.kingsrook.qqq.backend.core.logging.QLogger; +import static com.kingsrook.qqq.backend.core.logging.LogUtils.logPair; + + +/******************************************************************************* + ** Helper to cancel statements that timeout. + *******************************************************************************/ +public class StatementTimeoutCanceller implements Runnable +{ + private static final QLogger LOG = QLogger.getLogger(StatementTimeoutCanceller.class); + + private final Statement statement; + private final String sql; + + + + /******************************************************************************* + ** Constructor + ** + *******************************************************************************/ + public StatementTimeoutCanceller(Statement statement, CharSequence sql) + { + this.statement = statement; + this.sql = sql.toString(); + } + + + + /******************************************************************************* + ** + *******************************************************************************/ + @Override + public void run() + { + try + { + statement.cancel(); + LOG.info("Cancelled timed out statement", logPair("sql", sql)); + } + catch(Exception e) + { + LOG.warn("Error trying to cancel statement after timeout", e, logPair("sql", sql)); + } + + throw (new QRuntimeException("Statement timed out and was cancelled.")); + } +}