DropSchemaGenerator.java
/*
* Copyright 2023-2024 Markitect
*
* 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 dev.markitect.liquibase.sqlgenerator;
import static com.google.common.base.Preconditions.checkNotNull;
import dev.markitect.liquibase.statement.DropSchemaStatement;
import liquibase.database.Database;
import liquibase.database.core.H2Database;
import liquibase.database.core.HsqlDatabase;
import liquibase.database.core.MSSQLDatabase;
import liquibase.database.core.PostgresDatabase;
import liquibase.exception.ValidationErrors;
import liquibase.sql.Sql;
import liquibase.sql.UnparsedSql;
import liquibase.sqlgenerator.SqlGeneratorChain;
import liquibase.sqlgenerator.core.AbstractSqlGenerator;
import liquibase.structure.core.Schema;
public class DropSchemaGenerator extends AbstractSqlGenerator<DropSchemaStatement> {
@Override
public boolean supports(DropSchemaStatement statement, Database database) {
checkNotNull(statement);
checkNotNull(database);
return database instanceof H2Database
|| database instanceof HsqlDatabase
|| database instanceof MSSQLDatabase
|| database instanceof PostgresDatabase;
}
@Override
@SuppressWarnings("DuplicatedCode")
public ValidationErrors validate(
DropSchemaStatement statement,
Database database,
SqlGeneratorChain<DropSchemaStatement> sqlGeneratorChain) {
checkNotNull(statement);
checkNotNull(database);
checkNotNull(sqlGeneratorChain);
var errors = new ValidationErrors();
errors.checkDisallowedField(
"catalogName", statement.getCatalogName(), database, database.getClass());
errors.checkRequiredField("schemaName", statement.getSchemaName());
return errors;
}
@Override
public Sql[] generateSql(
DropSchemaStatement statement,
Database database,
SqlGeneratorChain<DropSchemaStatement> sqlGeneratorChain) {
checkNotNull(statement);
checkNotNull(database);
checkNotNull(sqlGeneratorChain);
String sql =
"DROP SCHEMA " + database.escapeObjectName(statement.getSchemaName(), Schema.class);
return new Sql[] {
new UnparsedSql(sql, new Schema(statement.getCatalogName(), statement.getSchemaName()))
};
}
}