org.tentackle.dbms.DefaultIdSourceConfigurator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tentackle-database Show documentation
Show all versions of tentackle-database Show documentation
Tentackle Low-Level DBMS Layer
The newest version!
/*
* Tentackle - https://tentackle.org
*
* This library 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.
*
* This library 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.tentackle.dbms;
import org.tentackle.common.Service;
import org.tentackle.session.PersistenceException;
import org.tentackle.sql.Backend;
import java.util.StringTokenizer;
/**
* Default {@link IdSourceConfigurator}.
*
* There are 2 configuration options:
*
* - table:<name>
* - sequence:<name>[:<sequence-multiplier>:<global-multiplier>]
*
*
* @author harald
*/
@Service(IdSourceConfigurator.class)
public class DefaultIdSourceConfigurator implements IdSourceConfigurator {
/** table-based id source. */
public static final String TABLE_BASED = "table";
/** sequence-based id source. */
public static final String SEQUENCE_BASED = "sequence";
/**
* Creates an IdSource configurator.
*/
public DefaultIdSourceConfigurator() {
// see -Xlint:missing-explicit-ctor since Java 16
}
@Override
public IdSource configure(Db db, String idConfig) {
if (idConfig == null) {
// default from backend
Backend backend = db.getBackend();
if (backend.isSequenceSupported()) {
idConfig = SEQUENCE_BASED + ":object_sequence_id";
}
else {
idConfig = TABLE_BASED + ":object_id";
}
}
// parse
String type = null;
String name = null;
Integer sequenceMultiplier = null;
Integer globalMultiplier = null;
StringTokenizer stok = new StringTokenizer(idConfig, ":");
while (stok.hasMoreTokens()) {
String token = stok.nextToken();
if (type == null) {
type = token;
}
else if (name == null) {
name = token;
}
else if (sequenceMultiplier == null) {
sequenceMultiplier = Integer.parseInt(token);
}
else if (globalMultiplier == null) {
globalMultiplier = Integer.parseInt(token);
}
else {
throw new PersistenceException("malformed idSource configuration: " + idConfig);
}
}
if (type == null) {
throw new PersistenceException("empty id configuration");
}
switch (type) {
case SEQUENCE_BASED:
if (sequenceMultiplier == null) { // implies globalMultiplier == null
return ObjectSequenceId.get(name);
}
else if (globalMultiplier != null) {
return ObjectSequenceId.get(name, sequenceMultiplier, globalMultiplier);
}
throw new PersistenceException("sequenceMultiplier and globalMultiplier must be defined both or not at all");
case TABLE_BASED:
return new ObjectId(name);
default:
throw new PersistenceException("unsupported idSource type: " + type);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy