diff --git a/CHANGELOG.md b/CHANGELOG.md index e2e0b81..fd0db5c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,11 @@ to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## [Unreleased] +## [7.2.0] - 2024-10-03 + +- Compatible with plugin interface version 6.3 +- Adds support for OAuthStorage + ## [7.1.3] - 2024-09-04 - Adds index on `last_active_time` for `user_last_active` table to improve the performance of MAU computation. diff --git a/build.gradle b/build.gradle index 4d9af05..9248813 100644 --- a/build.gradle +++ b/build.gradle @@ -2,7 +2,7 @@ plugins { id 'java-library' } -version = "7.1.3" +version = "7.2.0" repositories { mavenCentral() diff --git a/pluginInterfaceSupported.json b/pluginInterfaceSupported.json index 0dedee8..25f8238 100644 --- a/pluginInterfaceSupported.json +++ b/pluginInterfaceSupported.json @@ -1,6 +1,6 @@ { "_comment": "contains a list of plugin interfaces branch names that this core supports", "versions": [ - "6.2" + "6.3" ] } \ No newline at end of file diff --git a/src/main/java/io/supertokens/storage/mysql/Start.java b/src/main/java/io/supertokens/storage/mysql/Start.java index 4b9fe42..bf3e505 100644 --- a/src/main/java/io/supertokens/storage/mysql/Start.java +++ b/src/main/java/io/supertokens/storage/mysql/Start.java @@ -58,7 +58,10 @@ import io.supertokens.pluginInterface.multitenancy.exceptions.TenantOrAppNotFoundException; import io.supertokens.pluginInterface.multitenancy.sqlStorage.MultitenancySQLStorage; import io.supertokens.pluginInterface.oauth.OAuthLogoutChallenge; +import io.supertokens.pluginInterface.oauth.OAuthRevokeTargetType; import io.supertokens.pluginInterface.oauth.OAuthStorage; +import io.supertokens.pluginInterface.oauth.exception.DuplicateOAuthLogoutChallengeException; +import io.supertokens.pluginInterface.oauth.exception.OAuthClientNotFoundException; import io.supertokens.pluginInterface.passwordless.PasswordlessCode; import io.supertokens.pluginInterface.passwordless.PasswordlessDevice; import io.supertokens.pluginInterface.passwordless.exception.*; @@ -3037,159 +3040,192 @@ public int countUsersThatHaveMoreThanOneLoginMethodOrTOTPEnabledAndActiveSince(A } @Override - public boolean doesClientIdExistForApp(AppIdentifier appIdentifier, String clientId) + public boolean doesOAuthClientIdExist(AppIdentifier appIdentifier, String clientId) throws StorageQueryException { try { - return OAuthQueries.isClientIdForAppId(this, clientId, appIdentifier); + return OAuthQueries.doesOAuthClientIdExist(this, clientId, appIdentifier); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public void addOrUpdateClientForApp(AppIdentifier appIdentifier, String clientId, boolean isClientCredentialsOnly) - throws StorageQueryException { + public void addOrUpdateOauthClient(AppIdentifier appIdentifier, String clientId, boolean isClientCredentialsOnly) + throws StorageQueryException, TenantOrAppNotFoundException { try { - OAuthQueries.insertClientIdForAppId(this, appIdentifier, clientId, isClientCredentialsOnly); + OAuthQueries.addOrUpdateOauthClient(this, appIdentifier, clientId, isClientCredentialsOnly); } catch (SQLException e) { + if (e instanceof SQLIntegrityConstraintViolationException) { + MySQLConfig config = Config.getConfig(this); + String serverMessage = e.getMessage(); + + if (isForeignKeyConstraintError(serverMessage, config.getAppsTable(), "app_id")) { + throw new TenantOrAppNotFoundException(appIdentifier); + } + } throw new StorageQueryException(e); } } @Override - public boolean removeAppClientAssociation(AppIdentifier appIdentifier, String clientId) - throws StorageQueryException { + public boolean deleteOAuthClient(AppIdentifier appIdentifier, String clientId) throws StorageQueryException { try { - return OAuthQueries.deleteClientIdForAppId(this, clientId, appIdentifier); + return OAuthQueries.deleteOAuthClient(this, clientId, appIdentifier); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public List listClientsForApp(AppIdentifier appIdentifier) throws StorageQueryException { + public List listOAuthClients(AppIdentifier appIdentifier) throws StorageQueryException { try { - return OAuthQueries.listClientsForApp(this, appIdentifier); + return OAuthQueries.listOAuthClients(this, appIdentifier); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public void revoke(AppIdentifier appIdentifier, String targetType, String targetValue, long exp) - throws StorageQueryException { + public void revokeOAuthTokensBasedOnTargetFields(AppIdentifier appIdentifier, OAuthRevokeTargetType targetType, String targetValue, long exp) + throws StorageQueryException, TenantOrAppNotFoundException { try { - OAuthQueries.revoke(this, appIdentifier, targetType, targetValue, exp); + OAuthQueries.revokeOAuthTokensBasedOnTargetFields(this, appIdentifier, targetType, targetValue, exp); } catch (SQLException e) { + if (e instanceof SQLIntegrityConstraintViolationException) { + MySQLConfig config = Config.getConfig(this); + String serverMessage = e.getMessage(); + + if (isForeignKeyConstraintError(serverMessage, config.getAppsTable(), "app_id")) { + throw new TenantOrAppNotFoundException(appIdentifier); + } + } throw new StorageQueryException(e); } + } @Override - public boolean isRevoked(AppIdentifier appIdentifier, String[] targetTypes, String[] targetValues, long issuedAt) + public boolean isOAuthTokenRevokedBasedOnTargetFields(AppIdentifier appIdentifier, OAuthRevokeTargetType[] targetTypes, String[] targetValues, long issuedAt) throws StorageQueryException { try { - return OAuthQueries.isRevoked(this, appIdentifier, targetTypes, targetValues, issuedAt); + return OAuthQueries.isOAuthTokenRevokedBasedOnTargetFields(this, appIdentifier, targetTypes, targetValues, issuedAt); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public void addM2MToken(AppIdentifier appIdentifier, String clientId, long iat, long exp) - throws StorageQueryException { + public void addOAuthM2MTokenForStats(AppIdentifier appIdentifier, String clientId, long iat, long exp) + throws StorageQueryException, OAuthClientNotFoundException { try { - OAuthQueries.addM2MToken(this, appIdentifier, clientId, iat, exp); + OAuthQueries.addOAuthM2MTokenForStats(this, appIdentifier, clientId, iat, exp); } catch (SQLException e) { + if (e instanceof SQLIntegrityConstraintViolationException) { + MySQLConfig config = Config.getConfig(this); + String serverMessage = e.getMessage(); + + if (isForeignKeyConstraintError(serverMessage, config.getOAuthClientsTable(), "client_id")) { + throw new OAuthClientNotFoundException(); + } + } throw new StorageQueryException(e); } } @Override - public void addLogoutChallenge(AppIdentifier appIdentifier, String challenge, String clientId, - String postLogoutRedirectionUri, String sessionHandle, String state, long timeCreated) throws StorageQueryException { + public void cleanUpExpiredAndRevokedOAuthTokensList() throws StorageQueryException { try { - OAuthQueries.addLogoutChallenge(this, appIdentifier, challenge, clientId, postLogoutRedirectionUri, sessionHandle, state, timeCreated); + OAuthQueries.cleanUpExpiredAndRevokedOAuthTokensList(this); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public OAuthLogoutChallenge getLogoutChallenge(AppIdentifier appIdentifier, String challenge) - throws StorageQueryException { + public void addOAuthLogoutChallenge(AppIdentifier appIdentifier, String challenge, String clientId, + String postLogoutRedirectionUri, String sessionHandle, String state, long timeCreated) + throws StorageQueryException, DuplicateOAuthLogoutChallengeException, OAuthClientNotFoundException { try { - return OAuthQueries.getLogoutChallenge(this, appIdentifier, challenge); + OAuthQueries.addOAuthLogoutChallenge(this, appIdentifier, challenge, clientId, postLogoutRedirectionUri, sessionHandle, state, timeCreated); } catch (SQLException e) { + if (e instanceof SQLIntegrityConstraintViolationException) { + MySQLConfig config = Config.getConfig(this); + String serverMessage = e.getMessage(); + if (isPrimaryKeyError(serverMessage, config.getOAuthLogoutChallengesTable())) { + throw new DuplicateOAuthLogoutChallengeException(); + } + else if (isForeignKeyConstraintError(serverMessage, config.getOAuthClientsTable(), "client_id")) { + throw new OAuthClientNotFoundException(); + } + } throw new StorageQueryException(e); } } @Override - public void deleteLogoutChallenge(AppIdentifier appIdentifier, String challenge) throws StorageQueryException { + public OAuthLogoutChallenge getOAuthLogoutChallenge(AppIdentifier appIdentifier, String challenge) throws StorageQueryException { try { - OAuthQueries.deleteLogoutChallenge(this, appIdentifier, challenge); + return OAuthQueries.getOAuthLogoutChallenge(this, appIdentifier, challenge); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public void deleteLogoutChallengesBefore(AppIdentifier appIdentifier, long time) throws StorageQueryException { + public void deleteOAuthLogoutChallenge(AppIdentifier appIdentifier, String challenge) throws StorageQueryException { try { - OAuthQueries.deleteLogoutChallengesBefore(this, appIdentifier, time); + OAuthQueries.deleteOAuthLogoutChallenge(this, appIdentifier, challenge); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public void cleanUpExpiredAndRevokedTokens(AppIdentifier appIdentifier) throws StorageQueryException { + public void deleteOAuthLogoutChallengesBefore(long time) throws StorageQueryException { try { - OAuthQueries.cleanUpExpiredAndRevokedTokens(this, appIdentifier); + OAuthQueries.deleteOAuthLogoutChallengesBefore(this, time); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public int countTotalNumberOfM2MTokensAlive(AppIdentifier appIdentifier) throws StorageQueryException { + public int countTotalNumberOfOAuthClients(AppIdentifier appIdentifier) throws StorageQueryException { try { - return OAuthQueries.countTotalNumberOfM2MTokensAlive(this, appIdentifier); + return OAuthQueries.countTotalNumberOfClients(this, appIdentifier, false); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public int countTotalNumberOfM2MTokensCreatedSince(AppIdentifier appIdentifier, long since) + public int countTotalNumberOfClientCredentialsOnlyOAuthClients(AppIdentifier appIdentifier) throws StorageQueryException { try { - return OAuthQueries.countTotalNumberOfM2MTokensCreatedSince(this, appIdentifier, since); + return OAuthQueries.countTotalNumberOfClients(this, appIdentifier, true); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public int countTotalNumberOfClientCredentialsOnlyClientsForApp(AppIdentifier appIdentifier) + public int countTotalNumberOfOAuthM2MTokensCreatedSince(AppIdentifier appIdentifier, long since) throws StorageQueryException { try { - return OAuthQueries.countTotalNumberOfClientsForApp(this, appIdentifier, true); + return OAuthQueries.countTotalNumberOfOAuthM2MTokensCreatedSince(this, appIdentifier, since); } catch (SQLException e) { throw new StorageQueryException(e); } } @Override - public int countTotalNumberOfClientsForApp(AppIdentifier appIdentifier) throws StorageQueryException { + public int countTotalNumberOfOAuthM2MTokensAlive(AppIdentifier appIdentifier) throws StorageQueryException { try { - return OAuthQueries.countTotalNumberOfClientsForApp(this, appIdentifier, false); + return OAuthQueries.countTotalNumberOfOAuthM2MTokensAlive(this, appIdentifier); } catch (SQLException e) { throw new StorageQueryException(e); - } } - + } public static boolean isEnabledForDeadlockTesting() { return enableForDeadlockTesting; diff --git a/src/main/java/io/supertokens/storage/mysql/queries/GeneralQueries.java b/src/main/java/io/supertokens/storage/mysql/queries/GeneralQueries.java index 015334a..e9f2059 100644 --- a/src/main/java/io/supertokens/storage/mysql/queries/GeneralQueries.java +++ b/src/main/java/io/supertokens/storage/mysql/queries/GeneralQueries.java @@ -428,6 +428,7 @@ public static void createTablesIfNotExists(Start start, Connection con) throws S // index update(con, OAuthQueries.getQueryToCreateOAuthRevokeTimestampIndex(start), NO_OP_SETTER); + update(con, OAuthQueries.getQueryToCreateOAuthRevokeExpIndex(start), NO_OP_SETTER); } if (!doesTableExists(start, con, Config.getConfig(start).getOAuthM2MTokensTable())) { diff --git a/src/main/java/io/supertokens/storage/mysql/queries/OAuthQueries.java b/src/main/java/io/supertokens/storage/mysql/queries/OAuthQueries.java index 98d16f8..bd72880 100644 --- a/src/main/java/io/supertokens/storage/mysql/queries/OAuthQueries.java +++ b/src/main/java/io/supertokens/storage/mysql/queries/OAuthQueries.java @@ -8,6 +8,7 @@ import io.supertokens.pluginInterface.exceptions.StorageQueryException; import io.supertokens.pluginInterface.multitenancy.AppIdentifier; import io.supertokens.pluginInterface.oauth.OAuthLogoutChallenge; +import io.supertokens.pluginInterface.oauth.OAuthRevokeTargetType; import io.supertokens.storage.mysql.Start; import io.supertokens.storage.mysql.config.Config; import io.supertokens.storage.mysql.utils.Utils; @@ -51,6 +52,12 @@ public static String getQueryToCreateOAuthRevokeTimestampIndex(Start start) { + oAuth2RevokeTable + "(timestamp DESC, app_id DESC);"; } + public static String getQueryToCreateOAuthRevokeExpIndex(Start start) { + String oAuth2RevokeTable = Config.getConfig(start).getOAuthRevokeTable(); + return "CREATE INDEX oauth_revoke_exp_index ON " + + oAuth2RevokeTable + "(exp DESC);"; + } + public static String getQueryToCreateOAuthM2MTokensTable(Start start) { String oAuth2M2MTokensTable = Config.getConfig(start).getOAuthM2MTokensTable(); // @formatter:off @@ -60,8 +67,8 @@ public static String getQueryToCreateOAuthM2MTokensTable(Start start) { + "iat BIGINT UNSIGNED NOT NULL," + "exp BIGINT UNSIGNED NOT NULL," + "PRIMARY KEY (app_id, client_id, iat)," - + "FOREIGN KEY(app_id)" - + " REFERENCES " + Config.getConfig(start).getAppsTable() + "(app_id) ON DELETE CASCADE" + + "FOREIGN KEY(app_id, client_id)" + + " REFERENCES " + Config.getConfig(start).getOAuthClientsTable() + "(app_id, client_id) ON DELETE CASCADE" + ");"; // @formatter:on } @@ -75,7 +82,7 @@ public static String getQueryToCreateOAuthM2MTokenIatIndex(Start start) { public static String getQueryToCreateOAuthM2MTokenExpIndex(Start start) { String oAuth2M2MTokensTable = Config.getConfig(start).getOAuthM2MTokensTable(); return "CREATE INDEX oauth_m2m_token_exp_index ON " - + oAuth2M2MTokensTable + "(exp DESC, app_id DESC);"; + + oAuth2M2MTokensTable + "(exp DESC);"; } public static String getQueryToCreateOAuthLogoutChallengesTable(Start start) { @@ -91,9 +98,7 @@ public static String getQueryToCreateOAuthLogoutChallengesTable(Start start) { + "time_created BIGINT UNSIGNED NOT NULL," + "PRIMARY KEY (app_id, challenge)," + "FOREIGN KEY(app_id, client_id)" - + " REFERENCES " + Config.getConfig(start).getOAuthClientsTable() + "(app_id, client_id) ON DELETE CASCADE," - + "FOREIGN KEY(app_id)" - + " REFERENCES " + Config.getConfig(start).getAppsTable() + "(app_id) ON DELETE CASCADE" + + " REFERENCES " + Config.getConfig(start).getOAuthClientsTable() + "(app_id, client_id) ON DELETE CASCADE" + ");"; // @formatter:on } @@ -104,7 +109,7 @@ public static String getQueryToCreateOAuthLogoutChallengesTimeCreatedIndex(Start + oAuth2LogoutChallengesTable + "(time_created ASC, app_id ASC);"; } - public static boolean isClientIdForAppId(Start start, String clientId, AppIdentifier appIdentifier) + public static boolean doesOAuthClientIdExist(Start start, String clientId, AppIdentifier appIdentifier) throws SQLException, StorageQueryException { String QUERY = "SELECT app_id FROM " + Config.getConfig(start).getOAuthClientsTable() + " WHERE client_id = ? AND app_id = ?"; @@ -115,7 +120,7 @@ public static boolean isClientIdForAppId(Start start, String clientId, AppIdenti }, ResultSet::next); } - public static List listClientsForApp(Start start, AppIdentifier appIdentifier) + public static List listOAuthClients(Start start, AppIdentifier appIdentifier) throws SQLException, StorageQueryException { String QUERY = "SELECT client_id FROM " + Config.getConfig(start).getOAuthClientsTable() + " WHERE app_id = ?"; @@ -130,7 +135,7 @@ public static List listClientsForApp(Start start, AppIdentifier appIdent }); } - public static void insertClientIdForAppId(Start start, AppIdentifier appIdentifier, String clientId, + public static void addOrUpdateOauthClient(Start start, AppIdentifier appIdentifier, String clientId, boolean isClientCredentialsOnly) throws SQLException, StorageQueryException { String INSERT = "INSERT INTO " + Config.getConfig(start).getOAuthClientsTable() @@ -144,7 +149,7 @@ public static void insertClientIdForAppId(Start start, AppIdentifier appIdentifi }); } - public static boolean deleteClientIdForAppId(Start start, String clientId, AppIdentifier appIdentifier) + public static boolean deleteOAuthClient(Start start, String clientId, AppIdentifier appIdentifier) throws SQLException, StorageQueryException { String DELETE = "DELETE FROM " + Config.getConfig(start).getOAuthClientsTable() + " WHERE app_id = ? AND client_id = ?"; @@ -155,7 +160,7 @@ public static boolean deleteClientIdForAppId(Start start, String clientId, AppId return numberOfRow > 0; } - public static void revoke(Start start, AppIdentifier appIdentifier, String targetType, String targetValue, long exp) + public static void revokeOAuthTokensBasedOnTargetFields(Start start, AppIdentifier appIdentifier, OAuthRevokeTargetType targetType, String targetValue, long exp) throws SQLException, StorageQueryException { String INSERT = "INSERT INTO " + Config.getConfig(start).getOAuthRevokeTable() + "(app_id, target_type, target_value, timestamp, exp) VALUES (?, ?, ?, ?, ?) " @@ -164,7 +169,7 @@ public static void revoke(Start start, AppIdentifier appIdentifier, String targe long currentTime = System.currentTimeMillis() / 1000; update(start, INSERT, pst -> { pst.setString(1, appIdentifier.getAppId()); - pst.setString(2, targetType); + pst.setString(2, targetType.getValue()); pst.setString(3, targetValue); pst.setLong(4, currentTime); pst.setLong(5, exp); @@ -173,7 +178,7 @@ public static void revoke(Start start, AppIdentifier appIdentifier, String targe }); } - public static boolean isRevoked(Start start, AppIdentifier appIdentifier, String[] targetTypes, String[] targetValues, long issuedAt) + public static boolean isOAuthTokenRevokedBasedOnTargetFields(Start start, AppIdentifier appIdentifier, OAuthRevokeTargetType[] targetTypes, String[] targetValues, long issuedAt) throws SQLException, StorageQueryException { String QUERY = "SELECT app_id FROM " + Config.getConfig(start).getOAuthRevokeTable() + " WHERE app_id = ? AND timestamp > ? AND ("; @@ -194,7 +199,7 @@ public static boolean isRevoked(Start start, AppIdentifier appIdentifier, String int index = 3; for (int i = 0; i < targetTypes.length; i++) { - pst.setString(index, targetTypes[i]); + pst.setString(index, targetTypes[i].getValue()); index++; pst.setString(index, targetValues[i]); index++; @@ -202,7 +207,7 @@ public static boolean isRevoked(Start start, AppIdentifier appIdentifier, String }, ResultSet::next); } - public static int countTotalNumberOfClientsForApp(Start start, AppIdentifier appIdentifier, + public static int countTotalNumberOfClients(Start start, AppIdentifier appIdentifier, boolean filterByClientCredentialsOnly) throws SQLException, StorageQueryException { if (filterByClientCredentialsOnly) { String QUERY = "SELECT COUNT(*) as c FROM " + Config.getConfig(start).getOAuthClientsTable() + @@ -230,7 +235,7 @@ public static int countTotalNumberOfClientsForApp(Start start, AppIdentifier app } } - public static int countTotalNumberOfM2MTokensAlive(Start start, AppIdentifier appIdentifier) + public static int countTotalNumberOfOAuthM2MTokensAlive(Start start, AppIdentifier appIdentifier) throws SQLException, StorageQueryException { String QUERY = "SELECT COUNT(*) as c FROM " + Config.getConfig(start).getOAuthM2MTokensTable() + " WHERE app_id = ? AND exp > ?"; @@ -245,7 +250,7 @@ public static int countTotalNumberOfM2MTokensAlive(Start start, AppIdentifier ap }); } - public static int countTotalNumberOfM2MTokensCreatedSince(Start start, AppIdentifier appIdentifier, long since) + public static int countTotalNumberOfOAuthM2MTokensCreatedSince(Start start, AppIdentifier appIdentifier, long since) throws SQLException, StorageQueryException { String QUERY = "SELECT COUNT(*) as c FROM " + Config.getConfig(start).getOAuthM2MTokensTable() + " WHERE app_id = ? AND iat >= ?"; @@ -260,10 +265,10 @@ public static int countTotalNumberOfM2MTokensCreatedSince(Start start, AppIdenti }); } - public static void addM2MToken(Start start, AppIdentifier appIdentifier, String clientId, long iat, long exp) + public static void addOAuthM2MTokenForStats(Start start, AppIdentifier appIdentifier, String clientId, long iat, long exp) throws SQLException, StorageQueryException { String QUERY = "INSERT INTO " + Config.getConfig(start).getOAuthM2MTokensTable() + - " (app_id, client_id, iat, exp) VALUES (?, ?, ?, ?)"; + " (app_id, client_id, iat, exp) VALUES (?, ?, ?, ?) ON DUPLICATE KEY UPDATE exp=exp"; update(start, QUERY, pst -> { pst.setString(1, appIdentifier.getAppId()); pst.setString(2, clientId); @@ -272,33 +277,31 @@ public static void addM2MToken(Start start, AppIdentifier appIdentifier, String }); } - public static void cleanUpExpiredAndRevokedTokens(Start start, AppIdentifier appIdentifier) throws SQLException, StorageQueryException { + public static void cleanUpExpiredAndRevokedOAuthTokensList(Start start) throws SQLException, StorageQueryException { { // delete expired M2M tokens String QUERY = "DELETE FROM " + Config.getConfig(start).getOAuthM2MTokensTable() + - " WHERE app_id = ? AND exp < ?"; + " WHERE exp < ?"; long timestamp = System.currentTimeMillis() / 1000 - 3600 * 24 * 31; // expired 31 days ago update(start, QUERY, pst -> { - pst.setString(1, appIdentifier.getAppId()); - pst.setLong(2, timestamp); + pst.setLong(1, timestamp); }); } { // delete expired revoked tokens String QUERY = "DELETE FROM " + Config.getConfig(start).getOAuthRevokeTable() + - " WHERE app_id = ? AND exp < ?"; + " WHERE exp < ?"; long timestamp = System.currentTimeMillis() / 1000 - 3600 * 24 * 31; // expired 31 days ago update(start, QUERY, pst -> { - pst.setString(1, appIdentifier.getAppId()); - pst.setLong(2, timestamp); + pst.setLong(1, timestamp); }); } } - public static void addLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge, String clientId, + public static void addOAuthLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge, String clientId, String postLogoutRedirectionUri, String sessionHandle, String state, long timeCreated) throws SQLException, StorageQueryException { String QUERY = "INSERT INTO " + Config.getConfig(start).getOAuthLogoutChallengesTable() + " (app_id, challenge, client_id, post_logout_redirect_uri, session_handle, state, time_created) VALUES (?, ?, ?, ?, ?, ?, ?)"; @@ -313,7 +316,7 @@ public static void addLogoutChallenge(Start start, AppIdentifier appIdentifier, }); } - public static OAuthLogoutChallenge getLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge) throws SQLException, StorageQueryException { + public static OAuthLogoutChallenge getOAuthLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge) throws SQLException, StorageQueryException { String QUERY = "SELECT challenge, client_id, post_logout_redirect_uri, session_handle, state, time_created FROM " + Config.getConfig(start).getOAuthLogoutChallengesTable() + " WHERE app_id = ? AND challenge = ?"; @@ -336,7 +339,7 @@ public static OAuthLogoutChallenge getLogoutChallenge(Start start, AppIdentifier }); } - public static void deleteLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge) throws SQLException, StorageQueryException { + public static void deleteOAuthLogoutChallenge(Start start, AppIdentifier appIdentifier, String challenge) throws SQLException, StorageQueryException { String QUERY = "DELETE FROM " + Config.getConfig(start).getOAuthLogoutChallengesTable() + " WHERE app_id = ? AND challenge = ?"; update(start, QUERY, pst -> { @@ -345,12 +348,11 @@ public static void deleteLogoutChallenge(Start start, AppIdentifier appIdentifie }); } - public static void deleteLogoutChallengesBefore(Start start, AppIdentifier appIdentifier, long time) throws SQLException, StorageQueryException { + public static void deleteOAuthLogoutChallengesBefore(Start start, long time) throws SQLException, StorageQueryException { String QUERY = "DELETE FROM " + Config.getConfig(start).getOAuthLogoutChallengesTable() + - " WHERE app_id = ? AND time_created < ?"; + " WHERE time_created < ?"; update(start, QUERY, pst -> { - pst.setString(1, appIdentifier.getAppId()); - pst.setLong(2, time); + pst.setLong(1, time); }); } }