Compare commits

..

No commits in common. "4d99835a6a57a1d5acf3b60d38a18a8a0a6f5728" and "78dfb481fa0e7ab3f5d61789bc0fa5bd6200ce0e" have entirely different histories.

54 changed files with 904 additions and 802 deletions

View File

@ -24,7 +24,7 @@ import javax.imageio.ImageIO;
import org.glassfish.jersey.media.multipart.FormDataContentDisposition; import org.glassfish.jersey.media.multipart.FormDataContentDisposition;
import org.glassfish.jersey.media.multipart.FormDataParam; import org.glassfish.jersey.media.multipart.FormDataParam;
import org.kar.archidata.annotation.security.PermitTokenInURI; import org.kar.archidata.annotation.security.PermitTokenInURI;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.QueryCondition; import org.kar.archidata.dataAccess.QueryCondition;
import org.kar.archidata.dataAccess.options.Condition; import org.kar.archidata.dataAccess.options.Condition;
import org.kar.archidata.exception.FailException; import org.kar.archidata.exception.FailException;
@ -64,7 +64,7 @@ public class DataResource {
private final static int CHUNK_SIZE_IN = 50 * 1024 * 1024; // 1MB chunks private final static int CHUNK_SIZE_IN = 50 * 1024 * 1024; // 1MB chunks
/** Upload some datas */ /** Upload some datas */
private static long tmpFolderId = 1; private static long tmpFolderId = 1;
protected final DBAccess da = DBAccess.createInterface(); protected final DataAccess da = DataAccess.createInterface();
private static void createFolder(final String path) throws IOException { private static void createFolder(final String path) throws IOException {
if (!Files.exists(java.nio.file.Path.of(path))) { if (!Files.exists(java.nio.file.Path.of(path))) {

View File

@ -1,330 +0,0 @@
package org.kar.archidata.dataAccess;
import java.io.Closeable;
import java.io.IOException;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.options.Condition;
import org.kar.archidata.dataAccess.options.FilterValue;
import org.kar.archidata.dataAccess.options.Limit;
import org.kar.archidata.dataAccess.options.QueryOption;
import org.kar.archidata.dataAccess.options.TransmitKey;
import org.kar.archidata.db.DBConfig;
import org.kar.archidata.db.DBInterfaceFactory;
import org.kar.archidata.db.DbInterface;
import org.kar.archidata.db.DbInterfaceMorphia;
import org.kar.archidata.db.DbInterfaceSQL;
import org.kar.archidata.exception.DataAccessException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import jakarta.ws.rs.InternalServerErrorException;
/* TODO list:
- Manage to group of SQL action to permit to commit only at the end.
*/
/** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite
* back-end. */
public abstract class DBAccess implements Closeable {
final static Logger LOGGER = LoggerFactory.getLogger(DBAccess.class);
public static final DBAccess createInterface() {
try {
return DBAccess.createInterface(GlobalConfiguration.getDbconfig());
} catch (InternalServerErrorException | IOException e) {
LOGGER.error("Fail to initialize connection of the DB");
e.printStackTrace();
}
return null;
}
public static final DBAccess createInterface(final DBConfig config)
throws InternalServerErrorException, IOException {
final DBInterfaceFactory entry = DBInterfaceFactory.create(config);
return DBAccess.createInterface(entry.getDbInterface());
}
public static final DBAccess createInterface(final DbInterface io) throws InternalServerErrorException {
if (io instanceof final DbInterfaceMorphia ioMorphia) {
return new DBAccessMorphia(ioMorphia);
} else if (io instanceof final DbInterfaceSQL ioSQL) {
return new DBAccessSQL(ioSQL);
}
throw new InternalServerErrorException("unknow DB interface ... ");
}
public boolean isDBExist(final String name, final QueryOption... option) throws InternalServerErrorException {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public boolean createDB(final String name) {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public void deleteDB(final String name) {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public boolean isTableExist(final String name, final QueryOption... option) throws InternalServerErrorException {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public <ID_TYPE> QueryCondition getTableIdCondition(final Class<?> clazz, final ID_TYPE idKey)
throws DataAccessException {
// Find the ID field type ....
final Field idField = AnnotationTools.getIdField(clazz);
if (idField == null) {
throw new DataAccessException(
"The class have no annotation @Id ==> can not determine the default type searching");
}
// check the compatibility of the id and the declared ID
final Class<?> typeClass = idField.getType();
if (idKey == null) {
throw new DataAccessException("Try to identify the ID type and object was null.");
}
if (idKey.getClass() != typeClass) {
if (idKey.getClass() == Condition.class) {
throw new DataAccessException(
"Try to identify the ID type on a condition 'close' internal API error use xxxWhere(...) instead.");
}
throw new DataAccessException("Request update with the wrong type ...");
}
return new QueryCondition(AnnotationTools.getFieldName(idField), "=", idKey);
}
// TODO: manage insert batch...
public <T> List<T> insertMultiple(final List<T> data, final QueryOption... options) throws Exception {
final List<T> out = new ArrayList<>();
for (final T elem : data) {
final T tmp = insert(elem, options);
out.add(tmp);
}
return out;
}
abstract public <T> T insert(final T data, final QueryOption... option) throws Exception;
// seems a good idea, but very dangerous if we not filter input data... if set an id it can be complicated...
public <T> T insertWithJson(final Class<T> clazz, final String jsonData) throws Exception {
final ObjectMapper mapper = new ObjectMapper();
// parse the object to be sure the data are valid:
final T data = mapper.readValue(jsonData, clazz);
return insert(data);
}
/** Update an object with the inserted json data
*
* @param <T> Type of the object to insert
* @param <ID_TYPE> Master key on the object manage with @Id
* @param clazz Class reference of the insertion model
* @param id Key to insert data
* @param jsonData Json data (partial) values to update
* @return the number of object updated
* @throws Exception */
public <T, ID_TYPE> long updateWithJson(
final Class<T> clazz,
final ID_TYPE id,
final String jsonData,
final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
options.add(new TransmitKey(id));
return updateWhereWithJson(clazz, jsonData, options.getAllArray());
}
public <T> long updateWhereWithJson(final Class<T> clazz, final String jsonData, final QueryOption... option)
throws Exception {
final QueryOptions options = new QueryOptions(option);
if (options.get(Condition.class).size() == 0) {
throw new DataAccessException("request a updateWhereWithJson without any condition");
}
final ObjectMapper mapper = new ObjectMapper();
// parse the object to be sure the data are valid:
final T data = mapper.readValue(jsonData, clazz);
// Read the tree to filter injection of data:
final JsonNode root = mapper.readTree(jsonData);
final List<String> keys = new ArrayList<>();
final var iterator = root.fieldNames();
iterator.forEachRemaining(e -> keys.add(e));
options.add(new FilterValue(keys));
return updateWhere(data, options.getAllArray());
}
public <T, ID_TYPE> long update(final T data, final ID_TYPE id) throws Exception {
return update(data, id, AnnotationTools.getFieldsNames(data.getClass()));
}
/** @param <T>
* @param data
* @param id
* @param filterValue
* @return the affected rows.
* @throws Exception */
public <T, ID_TYPE> long update(
final T data,
final ID_TYPE id,
final List<String> updateColomn,
final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(data.getClass(), id)));
options.add(new FilterValue(updateColomn));
options.add(new TransmitKey(id));
return updateWhere(data, options);
}
public <T> long updateWhere(final T data, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
return updateWhere(data, options);
}
public abstract <T> long updateWhere(final T data, QueryOptions options) throws Exception;
public <T> T getWhere(final Class<T> clazz, final QueryOptions options) throws Exception {
options.add(new Limit(1));
final List<T> values = getsWhere(clazz, options);
if (values.size() == 0) {
return null;
}
return values.get(0);
}
public <T> T getWhere(final Class<T> clazz, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
return getWhere(clazz, options);
}
public <T> List<T> getsWhere(final Class<T> clazz, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
return getsWhere(clazz, options);
}
public Condition conditionFusionOrEmpty(final QueryOptions options, final boolean throwIfEmpty)
throws DataAccessException {
if (options == null) {
return new Condition();
}
final List<Condition> conditions = options.get(Condition.class);
if (conditions.size() == 0) {
if (throwIfEmpty) {
throw new DataAccessException("request a gets without any condition");
} else {
return new Condition();
}
}
Condition condition = null;
if (conditions.size() == 1) {
condition = conditions.get(0);
} else {
final QueryAnd andCondition = new QueryAnd();
for (final Condition cond : conditions) {
andCondition.add(cond.condition);
}
condition = new Condition(andCondition);
}
return condition;
}
abstract public <T> List<T> getsWhere(final Class<T> clazz, final QueryOptions options)
throws DataAccessException, IOException;
public <ID_TYPE> long count(final Class<?> clazz, final ID_TYPE id, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return countWhere(clazz, options);
}
public long countWhere(final Class<?> clazz, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
return countWhere(clazz, options);
}
public abstract long countWhere(final Class<?> clazz, final QueryOptions options) throws Exception;
public <T, ID_TYPE> T get(final Class<T> clazz, final ID_TYPE id, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return getWhere(clazz, options.getAllArray());
}
public <T> List<T> gets(final Class<T> clazz) throws Exception {
return getsWhere(clazz);
}
public <T> List<T> gets(final Class<T> clazz, final QueryOption... option) throws Exception {
return getsWhere(clazz, option);
}
/** Delete items with the specific Id (cf @Id) and some options. If the Entity is manage as a softDeleted model, then it is flag as removed (if not already done before).
* @param <ID_TYPE> Type of the reference @Id
* @param clazz Data model that might remove element
* @param id Unique Id of the model
* @param options (Optional) Options of the request
* @return Number of element that is removed. */
public <ID_TYPE> long delete(final Class<?> clazz, final ID_TYPE id, final QueryOption... options)
throws Exception {
final String hasDeletedFieldName = AnnotationTools.getDeletedFieldName(clazz);
if (hasDeletedFieldName != null) {
return deleteSoft(clazz, id, options);
} else {
return deleteHard(clazz, id, options);
}
}
/** Delete items with the specific condition and some options. If the Entity is manage as a softDeleted model, then it is flag as removed (if not already done before).
* @param clazz Data model that might remove element.
* @param condition Condition to remove elements.
* @param options (Optional) Options of the request.
* @return Number of element that is removed. */
public long deleteWhere(final Class<?> clazz, final QueryOption... option) throws Exception {
final String hasDeletedFieldName = AnnotationTools.getDeletedFieldName(clazz);
if (hasDeletedFieldName != null) {
return deleteSoftWhere(clazz, option);
} else {
return deleteHardWhere(clazz, option);
}
}
public <ID_TYPE> long deleteHard(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return deleteHardWhere(clazz, options.getAllArray());
}
public abstract long deleteHardWhere(final Class<?> clazz, final QueryOption... option) throws Exception;
public <ID_TYPE> long deleteSoft(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return deleteSoftWhere(clazz, options.getAllArray());
}
public abstract long deleteSoftWhere(final Class<?> clazz, final QueryOption... option) throws Exception;
public <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id) throws DataAccessException {
return unsetDeleteWhere(clazz, new Condition(getTableIdCondition(clazz, id)));
}
public <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws DataAccessException {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return unsetDeleteWhere(clazz, options.getAllArray());
}
public abstract long unsetDeleteWhere(final Class<?> clazz, final QueryOption... option) throws DataAccessException;
public abstract void drop(final Class<?> clazz, final QueryOption... option) throws Exception;
public abstract void cleanAll(final Class<?> clazz, final QueryOption... option) throws Exception;
}

View File

@ -1,15 +1,36 @@
package org.kar.archidata.dataAccess; package org.kar.archidata.dataAccess;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.Field;
import java.sql.PreparedStatement;
import java.sql.Timestamp;
import java.time.LocalDate;
import java.time.LocalTime;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import java.util.List;
import java.util.UUID;
import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.options.Condition; import org.kar.archidata.dataAccess.options.Condition;
import org.kar.archidata.dataAccess.options.FilterValue;
import org.kar.archidata.dataAccess.options.Limit;
import org.kar.archidata.dataAccess.options.QueryOption; import org.kar.archidata.dataAccess.options.QueryOption;
import org.kar.archidata.dataAccess.options.TransmitKey;
import org.kar.archidata.db.DBConfig;
import org.kar.archidata.db.DBEntry;
import org.kar.archidata.db.DbInterface;
import org.kar.archidata.db.DbInterfaceMorphia;
import org.kar.archidata.db.DbInterfaceSQL;
import org.kar.archidata.exception.DataAccessException; import org.kar.archidata.exception.DataAccessException;
import org.kar.archidata.tools.UuidUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import edu.umd.cs.findbugs.annotations.SuppressFBWarnings; import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import jakarta.ws.rs.InternalServerErrorException; import jakarta.ws.rs.InternalServerErrorException;
/* TODO list: /* TODO list:
@ -18,59 +39,91 @@ import jakarta.ws.rs.InternalServerErrorException;
/** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite /** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite
* back-end. */ * back-end. */
public class DataAccess { public abstract class DataAccess {
static final Logger LOGGER = LoggerFactory.getLogger(DataAccess.class); final static Logger LOGGER = LoggerFactory.getLogger(DataAccess.class);
public DataAccess() {
public static final DataAccess createInterface() {
try {
return DataAccess.createInterface(GlobalConfiguration.getDbconfig());
} catch (InternalServerErrorException | IOException e) {
LOGGER.error("Fail to initialize connection of the DB");
e.printStackTrace();
}
return null;
} }
public static boolean isDBExist(final String name, final QueryOption... options) public static final DataAccess createInterface(final DBConfig config)
throws InternalServerErrorException, IOException { throws InternalServerErrorException, IOException {
try (DBAccess db = DBAccess.createInterface()) { final DBEntry entry = DBEntry.createInterface(config);
return db.isDBExist(name, options); return DataAccess.createInterface(entry.getDbInterface());
}
} }
public static boolean createDB(final String name) throws IOException { public static final DataAccess createInterface(final DbInterface io) throws InternalServerErrorException {
try (DBAccess db = DBAccess.createInterface()) { if (io instanceof final DbInterfaceMorphia ioMorphia) {
return db.createDB(name); return new DataAccessMorphia(ioMorphia);
} else if (io instanceof final DbInterfaceSQL ioSQL) {
return new DataAccessSQL(ioSQL);
} }
throw new InternalServerErrorException("unknow DB interface ... ");
} }
public static boolean isTableExist(final String name, final QueryOption... options) public boolean isDBExist(final String name, final QueryOption... option) throws InternalServerErrorException {
throws InternalServerErrorException, IOException { throw new InternalServerErrorException("Can Not manage the DB-access");
try (DBAccess db = DBAccess.createInterface()) {
return db.isTableExist(name, options);
} }
public boolean createDB(final String name) {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public void deleteDB(final String name) {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public boolean isTableExist(final String name, final QueryOption... option) throws InternalServerErrorException {
throw new InternalServerErrorException("Can Not manage the DB-access");
}
public <ID_TYPE> QueryCondition getTableIdCondition(final Class<?> clazz, final ID_TYPE idKey)
throws DataAccessException {
// Find the ID field type ....
final Field idField = AnnotationTools.getIdField(clazz);
if (idField == null) {
throw new DataAccessException(
"The class have no annotation @Id ==> can not determine the default type searching");
}
// check the compatibility of the id and the declared ID
final Class<?> typeClass = idField.getType();
if (idKey == null) {
throw new DataAccessException("Try to identify the ID type and object was null.");
}
if (idKey.getClass() != typeClass) {
if (idKey.getClass() == Condition.class) {
throw new DataAccessException(
"Try to identify the ID type on a condition 'close' internal API error use xxxWhere(...) instead.");
}
throw new DataAccessException("Request update with the wrong type ...");
}
return new QueryCondition(AnnotationTools.getFieldName(idField), "=", idKey);
} }
// TODO: manage insert batch... // TODO: manage insert batch...
public static <T> List<T> insertMultiple(final List<T> data, final QueryOption... options) throws Exception { public <T> List<T> insertMultiple(final List<T> data, final QueryOption... options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final List<T> out = new ArrayList<>();
return db.insertMultiple(data, options); for (final T elem : data) {
final T tmp = insert(elem, options);
out.add(tmp);
} }
return out;
} }
@SuppressFBWarnings("SQL_PREPARED_STATEMENT_GENERATED_FROM_NONCONSTANT_STRING") abstract public <T> T insert(final T data, final QueryOption... option) throws Exception;
public static <T> T insert(final T data, final QueryOption... options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
return db.insert(data, options);
}
}
// seems a good idea, but very dangerous if we not filter input data... if set an id it can be complicated... // seems a good idea, but very dangerous if we not filter input data... if set an id it can be complicated...
public static <T> T insertWithJson(final Class<T> clazz, final String jsonData) throws Exception { public <T> T insertWithJson(final Class<T> clazz, final String jsonData) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final ObjectMapper mapper = new ObjectMapper();
return db.insertWithJson(clazz, jsonData); // parse the object to be sure the data are valid:
} final T data = mapper.readValue(jsonData, clazz);
} return insert(data);
public static <ID_TYPE> QueryCondition getTableIdCondition(final Class<?> clazz, final ID_TYPE idKey)
throws DataAccessException, IOException {
try (DBAccess db = DBAccess.createInterface()) {
return db.getTableIdCondition(clazz, idKey);
}
} }
/** Update an object with the inserted json data /** Update an object with the inserted json data
@ -82,29 +135,37 @@ public class DataAccess {
* @param jsonData Json data (partial) values to update * @param jsonData Json data (partial) values to update
* @return the number of object updated * @return the number of object updated
* @throws Exception */ * @throws Exception */
public static <T, ID_TYPE> long updateWithJson( public <T, ID_TYPE> long updateWithJson(
final Class<T> clazz, final Class<T> clazz,
final ID_TYPE id, final ID_TYPE id,
final String jsonData, final String jsonData,
final QueryOption... options) throws Exception { final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.updateWithJson(clazz, id, jsonData, options); options.add(new Condition(getTableIdCondition(clazz, id)));
} options.add(new TransmitKey(id));
return updateWhereWithJson(clazz, jsonData, options.getAllArray());
} }
public static <T> long updateWhereWithJson( public <T> long updateWhereWithJson(final Class<T> clazz, final String jsonData, final QueryOption... option)
final Class<T> clazz, throws Exception {
final String jsonData, final QueryOptions options = new QueryOptions(option);
final QueryOption... options) throws Exception { if (options.get(Condition.class).size() == 0) {
try (DBAccess db = DBAccess.createInterface()) { throw new DataAccessException("request a updateWhereWithJson without any condition");
return db.updateWhereWithJson(clazz, jsonData, options);
} }
final ObjectMapper mapper = new ObjectMapper();
// parse the object to be sure the data are valid:
final T data = mapper.readValue(jsonData, clazz);
// Read the tree to filter injection of data:
final JsonNode root = mapper.readTree(jsonData);
final List<String> keys = new ArrayList<>();
final var iterator = root.fieldNames();
iterator.forEachRemaining(e -> keys.add(e));
options.add(new FilterValue(keys));
return updateWhere(data, options.getAllArray());
} }
public static <T, ID_TYPE> long update(final T data, final ID_TYPE id) throws Exception { public <T, ID_TYPE> long update(final T data, final ID_TYPE id) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { return update(data, id, AnnotationTools.getFieldsNames(data.getClass()));
return db.update(data, id);
}
} }
/** @param <T> /** @param <T>
@ -113,97 +174,146 @@ public class DataAccess {
* @param filterValue * @param filterValue
* @return the affected rows. * @return the affected rows.
* @throws Exception */ * @throws Exception */
public static <T, ID_TYPE> long update( public <T, ID_TYPE> long update(
final T data, final T data,
final ID_TYPE id, final ID_TYPE id,
final List<String> updateColomn, final List<String> updateColomn,
final QueryOption... options) throws Exception { final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.update(data, id, updateColomn, options); options.add(new Condition(getTableIdCondition(data.getClass(), id)));
options.add(new FilterValue(updateColomn));
options.add(new TransmitKey(id));
return updateWhere(data, options);
}
public <T> long updateWhere(final T data, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
return updateWhere(data, options);
}
public abstract <T> long updateWhere(final T data, QueryOptions options) throws Exception;
public void addElement(final PreparedStatement ps, final Object value, final CountInOut iii) throws Exception {
if (value instanceof final UUID tmp) {
final byte[] dataByte = UuidUtils.asBytes(tmp);
ps.setBytes(iii.value, dataByte);
} else if (value instanceof final Long tmp) {
LOGGER.debug("Inject Long => {}", tmp);
ps.setLong(iii.value, tmp);
} else if (value instanceof final Integer tmp) {
LOGGER.debug("Inject Integer => {}", tmp);
ps.setInt(iii.value, tmp);
} else if (value instanceof final String tmp) {
LOGGER.debug("Inject String => {}", tmp);
ps.setString(iii.value, tmp);
} else if (value instanceof final Short tmp) {
LOGGER.debug("Inject Short => {}", tmp);
ps.setShort(iii.value, tmp);
} else if (value instanceof final Byte tmp) {
LOGGER.debug("Inject Byte => {}", tmp);
ps.setByte(iii.value, tmp);
} else if (value instanceof final Float tmp) {
LOGGER.debug("Inject Float => {}", tmp);
ps.setFloat(iii.value, tmp);
} else if (value instanceof final Double tmp) {
LOGGER.debug("Inject Double => {}", tmp);
ps.setDouble(iii.value, tmp);
} else if (value instanceof final Boolean tmp) {
LOGGER.debug("Inject Boolean => {}", tmp);
ps.setBoolean(iii.value, tmp);
} else if (value instanceof final Timestamp tmp) {
LOGGER.debug("Inject Timestamp => {}", tmp);
ps.setTimestamp(iii.value, tmp);
} else if (value instanceof final Date tmp) {
LOGGER.debug("Inject Date => {}", tmp);
ps.setTimestamp(iii.value, java.sql.Timestamp.from((tmp).toInstant()));
} else if (value instanceof final LocalDate tmp) {
LOGGER.debug("Inject LocalDate => {}", tmp);
ps.setDate(iii.value, java.sql.Date.valueOf(tmp));
} else if (value instanceof final LocalTime tmp) {
LOGGER.debug("Inject LocalTime => {}", tmp);
ps.setTime(iii.value, java.sql.Time.valueOf(tmp));
} else if (value.getClass().isEnum()) {
LOGGER.debug("Inject ENUM => {}", value.toString());
ps.setString(iii.value, value.toString());
} else {
throw new DataAccessException("Not manage type ==> need to add it ...");
} }
} }
public static <T> long updateWhere(final T data, final QueryOption... options) throws Exception { public <T> T getWhere(final Class<T> clazz, final QueryOptions options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { options.add(new Limit(1));
return db.updateWhere(data, options); final List<T> values = getsWhere(clazz, options);
if (values.size() == 0) {
return null;
} }
return values.get(0);
} }
public static <T> long updateWhere(final T data, final QueryOptions options) throws Exception { public <T> T getWhere(final Class<T> clazz, final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.updateWhere(data, options); return getWhere(clazz, options);
}
} }
public static <T> T getWhere(final Class<T> clazz, final QueryOptions options) throws Exception { public <T> List<T> getsWhere(final Class<T> clazz, final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.getWhere(clazz, options); return getsWhere(clazz, options);
}
} }
public static <T> T getWhere(final Class<T> clazz, final QueryOption... options) throws Exception { public Condition conditionFusionOrEmpty(final QueryOptions options, final boolean throwIfEmpty)
try (DBAccess db = DBAccess.createInterface()) { throws DataAccessException {
return db.getWhere(clazz, options); if (options == null) {
return new Condition();
} }
final List<Condition> conditions = options.get(Condition.class);
if (conditions.size() == 0) {
if (throwIfEmpty) {
throw new DataAccessException("request a gets without any condition");
} else {
return new Condition();
}
}
Condition condition = null;
if (conditions.size() == 1) {
condition = conditions.get(0);
} else {
final QueryAnd andCondition = new QueryAnd();
for (final Condition cond : conditions) {
andCondition.add(cond.condition);
}
condition = new Condition(andCondition);
}
return condition;
} }
public static <T> List<T> getsWhere(final Class<T> clazz, final QueryOption... options) throws Exception { abstract public <T> List<T> getsWhere(final Class<T> clazz, final QueryOptions options)
try (DBAccess db = DBAccess.createInterface()) { throws DataAccessException, IOException;
return db.getsWhere(clazz, options);
} public <ID_TYPE> long count(final Class<?> clazz, final ID_TYPE id, final QueryOption... option) throws Exception {
final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id)));
return countWhere(clazz, options);
} }
public static Condition conditionFusionOrEmpty(final QueryOptions options, final boolean throwIfEmpty) public long countWhere(final Class<?> clazz, final QueryOption... option) throws Exception {
throws DataAccessException, IOException { final QueryOptions options = new QueryOptions(option);
try (DBAccess db = DBAccess.createInterface()) { return countWhere(clazz, options);
return db.conditionFusionOrEmpty(options, throwIfEmpty);
}
} }
@SuppressWarnings("unchecked") public abstract long countWhere(final Class<?> clazz, final QueryOptions options) throws Exception;
public static <T> List<T> getsWhere(final Class<T> clazz, final QueryOptions options)
throws DataAccessException, IOException { public <T, ID_TYPE> T get(final Class<T> clazz, final ID_TYPE id, final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.getsWhere(clazz, options); options.add(new Condition(getTableIdCondition(clazz, id)));
} return getWhere(clazz, options.getAllArray());
} }
public static <ID_TYPE> long count(final Class<?> clazz, final ID_TYPE id, final QueryOption... options) public <T> List<T> gets(final Class<T> clazz) throws Exception {
throws Exception { return getsWhere(clazz);
try (DBAccess db = DBAccess.createInterface()) {
return db.count(clazz, id, options);
}
} }
public static long countWhere(final Class<?> clazz, final QueryOption... options) throws Exception { public <T> List<T> gets(final Class<T> clazz, final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { return getsWhere(clazz, option);
return db.countWhere(clazz, options);
}
}
public static long countWhere(final Class<?> clazz, final QueryOptions options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
return db.countWhere(clazz, options);
}
}
public static <T, ID_TYPE> T get(final Class<T> clazz, final ID_TYPE id, final QueryOption... options)
throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
return db.get(clazz, id, options);
}
}
public static <T> List<T> gets(final Class<T> clazz) throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
return db.gets(clazz);
}
}
public static <T> List<T> gets(final Class<T> clazz, final QueryOption... options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
return db.gets(clazz, options);
}
} }
/** Delete items with the specific Id (cf @Id) and some options. If the Entity is manage as a softDeleted model, then it is flag as removed (if not already done before). /** Delete items with the specific Id (cf @Id) and some options. If the Entity is manage as a softDeleted model, then it is flag as removed (if not already done before).
@ -212,10 +322,13 @@ public class DataAccess {
* @param id Unique Id of the model * @param id Unique Id of the model
* @param options (Optional) Options of the request * @param options (Optional) Options of the request
* @return Number of element that is removed. */ * @return Number of element that is removed. */
public static <ID_TYPE> long delete(final Class<?> clazz, final ID_TYPE id, final QueryOption... options) public <ID_TYPE> long delete(final Class<?> clazz, final ID_TYPE id, final QueryOption... options)
throws Exception { throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final String hasDeletedFieldName = AnnotationTools.getDeletedFieldName(clazz);
return db.delete(clazz, id, options); if (hasDeletedFieldName != null) {
return deleteSoft(clazz, id, options);
} else {
return deleteHard(clazz, id, options);
} }
} }
@ -224,69 +337,48 @@ public class DataAccess {
* @param condition Condition to remove elements. * @param condition Condition to remove elements.
* @param options (Optional) Options of the request. * @param options (Optional) Options of the request.
* @return Number of element that is removed. */ * @return Number of element that is removed. */
public static long deleteWhere(final Class<?> clazz, final QueryOption... options) throws Exception { public long deleteWhere(final Class<?> clazz, final QueryOption... option) throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final String hasDeletedFieldName = AnnotationTools.getDeletedFieldName(clazz);
return db.deleteWhere(clazz, options); if (hasDeletedFieldName != null) {
return deleteSoftWhere(clazz, option);
} else {
return deleteHardWhere(clazz, option);
} }
} }
public static <ID_TYPE> long deleteHard(final Class<?> clazz, final ID_TYPE id, final QueryOption... options) public <ID_TYPE> long deleteHard(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws Exception { throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.deleteHard(clazz, id, options); options.add(new Condition(getTableIdCondition(clazz, id)));
} return deleteHardWhere(clazz, options.getAllArray());
} }
public static long deleteHardWhere(final Class<?> clazz, final QueryOption... options) throws Exception { public abstract long deleteHardWhere(final Class<?> clazz, final QueryOption... option) throws Exception;
try (DBAccess db = DBAccess.createInterface()) {
return db.deleteHardWhere(clazz, options);
}
}
public static <ID_TYPE> long deleteSoft(final Class<?> clazz, final ID_TYPE id, final QueryOption... options) private <ID_TYPE> long deleteSoft(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws Exception { throws Exception {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.deleteSoft(clazz, id, options); options.add(new Condition(getTableIdCondition(clazz, id)));
} return deleteSoftWhere(clazz, options.getAllArray());
} }
public static long deleteSoftWhere(final Class<?> clazz, final QueryOption... options) throws Exception { public abstract long deleteSoftWhere(final Class<?> clazz, final QueryOption... option) throws Exception;
try (DBAccess db = DBAccess.createInterface()) {
return db.deleteSoftWhere(clazz, options); public <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id) throws DataAccessException {
} return unsetDeleteWhere(clazz, new Condition(getTableIdCondition(clazz, id)));
} }
public static <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id) public <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws DataAccessException, IOException { throws DataAccessException {
try (DBAccess db = DBAccess.createInterface()) { final QueryOptions options = new QueryOptions(option);
return db.unsetDelete(clazz, id); options.add(new Condition(getTableIdCondition(clazz, id)));
} return unsetDeleteWhere(clazz, options.getAllArray());
} }
public static <ID_TYPE> long unsetDelete(final Class<?> clazz, final ID_TYPE id, final QueryOption... options) public abstract long unsetDeleteWhere(final Class<?> clazz, final QueryOption... option) throws DataAccessException;
throws DataAccessException, IOException {
try (DBAccess db = DBAccess.createInterface()) {
return db.unsetDelete(clazz, id, options);
}
}
public static long unsetDeleteWhere(final Class<?> clazz, final QueryOption... options) public abstract void drop(final Class<?> clazz, final QueryOption... option) throws Exception;
throws DataAccessException, IOException {
try (DBAccess db = DBAccess.createInterface()) {
return db.unsetDeleteWhere(clazz, options);
}
}
public static void drop(final Class<?> clazz, final QueryOption... options) throws Exception { public abstract void cleanAll(final Class<?> clazz, final QueryOption... option) throws Exception;
try (DBAccess db = DBAccess.createInterface()) {
db.drop(clazz, options);
}
}
public static void cleanAll(final Class<?> clazz, final QueryOption... options) throws Exception {
try (DBAccess db = DBAccess.createInterface()) {
db.cleanAll(clazz, options);
}
}
} }

View File

@ -3,6 +3,9 @@ package org.kar.archidata.dataAccess;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.Constructor; import java.lang.reflect.Constructor;
import java.lang.reflect.Field; import java.lang.reflect.Field;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.time.Instant; import java.time.Instant;
import java.time.LocalDate; import java.time.LocalDate;
@ -31,6 +34,7 @@ import org.kar.archidata.dataAccess.options.OrderBy;
import org.kar.archidata.dataAccess.options.QueryOption; import org.kar.archidata.dataAccess.options.QueryOption;
import org.kar.archidata.db.DbInterfaceMorphia; import org.kar.archidata.db.DbInterfaceMorphia;
import org.kar.archidata.exception.DataAccessException; import org.kar.archidata.exception.DataAccessException;
import org.kar.archidata.tools.DateTools;
import org.kar.archidata.tools.UuidUtils; import org.kar.archidata.tools.UuidUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -55,8 +59,8 @@ import jakarta.ws.rs.InternalServerErrorException;
/** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite /** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite
* back-end. */ * back-end. */
public class DBAccessMorphia extends DBAccess { public class DataAccessMorphia extends DataAccess {
static final Logger LOGGER = LoggerFactory.getLogger(DBAccessMorphia.class); static final Logger LOGGER = LoggerFactory.getLogger(DataAccessMorphia.class);
// by default we manage some add-on that permit to manage non-native model (like json serialization, List of external key as String list...) // by default we manage some add-on that permit to manage non-native model (like json serialization, List of external key as String list...)
static final List<DataAccessAddOn> addOn = new ArrayList<>(); static final List<DataAccessAddOn> addOn = new ArrayList<>();
@ -71,12 +75,12 @@ public class DBAccessMorphia extends DBAccess {
* @param addOn instantiate object on the Add-on * @param addOn instantiate object on the Add-on
*/ */
public static void addAddOn(final DataAccessAddOn addOn) { public static void addAddOn(final DataAccessAddOn addOn) {
DBAccessMorphia.addOn.add(addOn); DataAccessMorphia.addOn.add(addOn);
} }
private final DbInterfaceMorphia db; private final DbInterfaceMorphia db;
public DBAccessMorphia(final DbInterfaceMorphia db) { public DataAccessMorphia(final DbInterfaceMorphia db) {
this.db = db; this.db = db;
} }
@ -107,6 +111,44 @@ public class DBAccessMorphia extends DBAccess {
return true; return true;
} }
/** Extract a list of Long with "-" separated element from a SQL input data.
* @param rs Result Set of the BDD
* @param iii Id in the result set
* @return The list of Long value
* @throws SQLException if an error is generated in the SQL request. */
public List<Long> getListOfIds(final ResultSet rs, final int iii, final String separator) throws SQLException {
final String trackString = rs.getString(iii);
if (rs.wasNull()) {
return null;
}
final List<Long> out = new ArrayList<>();
final String[] elements = trackString.split(separator);
for (final String elem : elements) {
final Long tmp = Long.parseLong(elem);
out.add(tmp);
}
return out;
}
/** Extract a list of UUID with "-" separated element from a SQL input data.
* @param rs Result Set of the BDD
* @param iii Id in the result set
* @return The list of Long value
* @throws SQLException if an error is generated in the SQL request. */
public List<UUID> getListOfUUIDs(final ResultSet rs, final int iii, final String separator) throws SQLException {
final String trackString = rs.getString(iii);
if (rs.wasNull()) {
return null;
}
final List<UUID> out = new ArrayList<>();
final String[] elements = trackString.split(separator);
for (final String elem : elements) {
final UUID tmp = UUID.fromString(elem);
out.add(tmp);
}
return out;
}
public byte[][] splitIntoGroupsOf16Bytes(final byte[] input) { public byte[][] splitIntoGroupsOf16Bytes(final byte[] input) {
final int inputLength = input.length; final int inputLength = input.length;
final int numOfGroups = (inputLength + 15) / 16; // Calculate the number of groups needed final int numOfGroups = (inputLength + 15) / 16; // Calculate the number of groups needed
@ -121,6 +163,28 @@ public class DBAccessMorphia extends DBAccess {
return groups; return groups;
} }
public List<UUID> getListOfRawUUIDs(final ResultSet rs, final int iii) throws SQLException, DataAccessException {
final byte[] trackString = rs.getBytes(iii);
if (rs.wasNull()) {
return null;
}
final byte[][] elements = splitIntoGroupsOf16Bytes(trackString);
final List<UUID> out = new ArrayList<>();
for (final byte[] elem : elements) {
final UUID tmp = UuidUtils.asUuid(elem);
out.add(tmp);
}
return out;
}
public UUID getListOfRawUUID(final ResultSet rs, final int iii) throws SQLException, DataAccessException {
final byte[] elem = rs.getBytes(iii);
if (rs.wasNull()) {
return null;
}
return UuidUtils.asUuid(elem);
}
protected <T> void setValuedb( protected <T> void setValuedb(
final Class<?> type, final Class<?> type,
final T data, final T data,
@ -350,6 +414,220 @@ public class DBAccessMorphia extends DBAccess {
//throw new ArchiveException("wrong type of field [" + fieldName + "]: " + doc.toJson()); //throw new ArchiveException("wrong type of field [" + fieldName + "]: " + doc.toJson());
} }
// TODO: this function will replace the previous one !!!
protected RetreiveFromDB createSetValueFromDbCallback(final int count, final Field field) throws Exception {
final Class<?> type = field.getType();
if (type == UUID.class) {
return (final ResultSet rs, final Object obj) -> {
final byte[] tmp = rs.getBytes(count);
// final UUID tmp = rs.getObject(count, UUID.class);
if (rs.wasNull()) {
field.set(obj, null);
} else {
// field.set(obj, tmp);
final UUID uuid = UuidUtils.asUuid(tmp);
field.set(obj, uuid);
}
};
}
if (type == Long.class) {
return (final ResultSet rs, final Object obj) -> {
final Long tmp = rs.getLong(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == long.class) {
return (final ResultSet rs, final Object obj) -> {
final Long tmp = rs.getLong(count);
if (rs.wasNull()) {
// field.set(data, null);
} else {
field.setLong(obj, tmp);
}
};
}
if (type == Integer.class) {
return (final ResultSet rs, final Object obj) -> {
final Integer tmp = rs.getInt(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == int.class) {
return (final ResultSet rs, final Object obj) -> {
final Integer tmp = rs.getInt(count);
if (rs.wasNull()) {
// field.set(obj, null);
} else {
field.setInt(obj, tmp);
}
};
}
if (type == Float.class) {
return (final ResultSet rs, final Object obj) -> {
final Float tmp = rs.getFloat(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == float.class) {
return (final ResultSet rs, final Object obj) -> {
final Float tmp = rs.getFloat(count);
if (rs.wasNull()) {
// field.set(obj, null);
} else {
field.setFloat(obj, tmp);
}
};
}
if (type == Double.class) {
return (final ResultSet rs, final Object obj) -> {
final Double tmp = rs.getDouble(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == double.class) {
return (final ResultSet rs, final Object obj) -> {
final Double tmp = rs.getDouble(count);
if (rs.wasNull()) {
// field.set(obj, null);
} else {
field.setDouble(obj, tmp);
}
};
}
if (type == Boolean.class) {
return (final ResultSet rs, final Object obj) -> {
final Boolean tmp = rs.getBoolean(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == boolean.class) {
return (final ResultSet rs, final Object obj) -> {
final Boolean tmp = rs.getBoolean(count);
if (rs.wasNull()) {
// field.set(obj, null);
} else {
field.setBoolean(obj, tmp);
}
};
}
if (type == Timestamp.class) {
return (final ResultSet rs, final Object obj) -> {
final Timestamp tmp = rs.getTimestamp(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type == Date.class) {
return (final ResultSet rs, final Object obj) -> {
try {
final Timestamp tmp = rs.getTimestamp(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, Date.from(tmp.toInstant()));
}
} catch (final SQLException ex) {
final String tmp = rs.getString(count);
LOGGER.error("Fail to parse the SQL time !!! {}", tmp);
if (rs.wasNull()) {
field.set(obj, null);
} else {
final Date date = DateTools.parseDate(tmp);
LOGGER.error("Fail to parse the SQL time !!! {}", date);
field.set(obj, date);
}
}
};
}
if (type == Instant.class) {
return (final ResultSet rs, final Object obj) -> {
final String tmp = rs.getString(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, Instant.parse(tmp));
}
};
}
if (type == LocalDate.class) {
return (final ResultSet rs, final Object obj) -> {
final java.sql.Date tmp = rs.getDate(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp.toLocalDate());
}
};
}
if (type == LocalTime.class) {
return (final ResultSet rs, final Object obj) -> {
final java.sql.Time tmp = rs.getTime(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp.toLocalTime());
}
};
}
if (type == String.class) {
return (final ResultSet rs, final Object obj) -> {
final String tmp = rs.getString(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
field.set(obj, tmp);
}
};
}
if (type.isEnum()) {
return (final ResultSet rs, final Object obj) -> {
final String tmp = rs.getString(count);
if (rs.wasNull()) {
field.set(obj, null);
} else {
boolean find = false;
final Object[] arr = type.getEnumConstants();
for (final Object elem : arr) {
if (elem.toString().equals(tmp)) {
field.set(obj, elem);
find = true;
break;
}
}
if (!find) {
throw new DataAccessException("Enum value does not exist in the Model: '" + tmp + "'");
}
}
};
}
throw new DataAccessException("Unknown Field Type");
}
protected Object convertDefaultField(String data, final Field field) throws Exception { protected Object convertDefaultField(String data, final Field field) throws Exception {
if (data.startsWith("'") && data.endsWith("'")) { if (data.startsWith("'") && data.endsWith("'")) {
data = data.substring(1, data.length() - 1); data = data.substring(1, data.length() - 1);
@ -634,7 +912,7 @@ public class DBAccessMorphia extends DBAccess {
LOGGER.info("updateWhere with value: {}", actions.toJson()); LOGGER.info("updateWhere with value: {}", actions.toJson());
final UpdateResult ret = collection.updateMany(filters, actions); final UpdateResult ret = collection.updateMany(filters, actions);
return ret.getModifiedCount(); return ret.getModifiedCount();
} catch (final Exception ex) { } catch (final SQLException ex) {
ex.printStackTrace(); ex.printStackTrace();
} }
for (final LazyGetter action : asyncActions) { for (final LazyGetter action : asyncActions) {
@ -643,6 +921,55 @@ public class DBAccessMorphia extends DBAccess {
return 0; return 0;
} }
@Override
public void addElement(final PreparedStatement ps, final Object value, final CountInOut iii) throws Exception {
if (value instanceof final UUID tmp) {
final byte[] dataByte = UuidUtils.asBytes(tmp);
ps.setBytes(iii.value, dataByte);
} else if (value instanceof final Long tmp) {
LOGGER.debug("Inject Long => {}", tmp);
ps.setLong(iii.value, tmp);
} else if (value instanceof final Integer tmp) {
LOGGER.debug("Inject Integer => {}", tmp);
ps.setInt(iii.value, tmp);
} else if (value instanceof final String tmp) {
LOGGER.debug("Inject String => {}", tmp);
ps.setString(iii.value, tmp);
} else if (value instanceof final Short tmp) {
LOGGER.debug("Inject Short => {}", tmp);
ps.setShort(iii.value, tmp);
} else if (value instanceof final Byte tmp) {
LOGGER.debug("Inject Byte => {}", tmp);
ps.setByte(iii.value, tmp);
} else if (value instanceof final Float tmp) {
LOGGER.debug("Inject Float => {}", tmp);
ps.setFloat(iii.value, tmp);
} else if (value instanceof final Double tmp) {
LOGGER.debug("Inject Double => {}", tmp);
ps.setDouble(iii.value, tmp);
} else if (value instanceof final Boolean tmp) {
LOGGER.debug("Inject Boolean => {}", tmp);
ps.setBoolean(iii.value, tmp);
} else if (value instanceof final Timestamp tmp) {
LOGGER.debug("Inject Timestamp => {}", tmp);
ps.setTimestamp(iii.value, tmp);
} else if (value instanceof final Date tmp) {
LOGGER.debug("Inject Date => {}", tmp);
ps.setTimestamp(iii.value, java.sql.Timestamp.from((tmp).toInstant()));
} else if (value instanceof final LocalDate tmp) {
LOGGER.debug("Inject LocalDate => {}", tmp);
ps.setDate(iii.value, java.sql.Date.valueOf(tmp));
} else if (value instanceof final LocalTime tmp) {
LOGGER.debug("Inject LocalTime => {}", tmp);
ps.setTime(iii.value, java.sql.Time.valueOf(tmp));
} else if (value.getClass().isEnum()) {
LOGGER.debug("Inject ENUM => {}", value.toString());
ps.setString(iii.value, value.toString());
} else {
throw new DataAccessException("Not manage type ==> need to add it ...");
}
}
public List<String> generateSelectField(final Class<?> clazz, final QueryOptions options) throws Exception { public List<String> generateSelectField(final Class<?> clazz, final QueryOptions options) throws Exception {
// TODO: list of user select fields. // TODO: list of user select fields.
final boolean readAllfields = QueryOptions.readAllColomn(options); final boolean readAllfields = QueryOptions.readAllColomn(options);
@ -756,6 +1083,9 @@ public class DBAccessMorphia extends DBAccess {
elem.doRequest(); elem.doRequest();
} }
} }
} catch (final SQLException ex) {
ex.printStackTrace();
throw new DataAccessException("Catch a SQL Exception: " + ex.getMessage());
} catch (final Exception ex) { } catch (final Exception ex) {
ex.printStackTrace(); ex.printStackTrace();
throw new DataAccessException("Catch an Exception: " + ex.getMessage()); throw new DataAccessException("Catch an Exception: " + ex.getMessage());
@ -868,8 +1198,7 @@ public class DBAccessMorphia extends DBAccess {
return retFind.getDeletedCount(); return retFind.getDeletedCount();
} }
@Override private <ID_TYPE> long deleteSoft(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
public <ID_TYPE> long deleteSoft(final Class<?> clazz, final ID_TYPE id, final QueryOption... option)
throws Exception { throws Exception {
final QueryOptions options = new QueryOptions(option); final QueryOptions options = new QueryOptions(option);
options.add(new Condition(getTableIdCondition(clazz, id))); options.add(new Condition(getTableIdCondition(clazz, id)));
@ -935,10 +1264,4 @@ public class DBAccessMorphia extends DBAccess {
final MongoCollection<Document> collection = this.db.getDatastore().getDatabase().getCollection(collectionName); final MongoCollection<Document> collection = this.db.getDatastore().getDatabase().getCollection(collectionName);
collection.deleteMany(new Document()); collection.deleteMany(new Document());
} }
@Override
public void close() throws IOException {
// TODO Auto-generated method stub
}
} }

View File

@ -55,8 +55,8 @@ import jakarta.ws.rs.InternalServerErrorException;
/** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite /** Data access is an abstraction class that permit to access on the DB with a function wrapping that permit to minimize the SQL writing of SQL code. This interface support the SQL and SQLite
* back-end. */ * back-end. */
public class DBAccessSQL extends DBAccess { public class DataAccessSQL extends DataAccess {
final static Logger LOGGER = LoggerFactory.getLogger(DBAccessSQL.class); final static Logger LOGGER = LoggerFactory.getLogger(DataAccessSQL.class);
// by default we manage some add-on that permit to manage non-native model (like json serialization, List of external key as String list...) // by default we manage some add-on that permit to manage non-native model (like json serialization, List of external key as String list...)
final static List<DataAccessAddOn> addOn = new ArrayList<>(); final static List<DataAccessAddOn> addOn = new ArrayList<>();
@ -70,12 +70,12 @@ public class DBAccessSQL extends DBAccess {
/** Add a new add-on on the current management. /** Add a new add-on on the current management.
* @param addOn instantiate object on the Add-on */ * @param addOn instantiate object on the Add-on */
public static void addAddOn(final DataAccessAddOn addOn) { public static void addAddOn(final DataAccessAddOn addOn) {
DBAccessSQL.addOn.add(addOn); DataAccessSQL.addOn.add(addOn);
} }
private final DbInterfaceSQL db; private final DbInterfaceSQL db;
public DBAccessSQL(final DbInterfaceSQL db) { public DataAccessSQL(final DbInterfaceSQL db) {
this.db = db; this.db = db;
} }
@ -1121,6 +1121,7 @@ public class DBAccessSQL extends DBAccess {
return 0L; return 0L;
} }
@Override
public void addElement(final PreparedStatement ps, final Object value, final CountInOut iii) throws Exception { public void addElement(final PreparedStatement ps, final Object value, final CountInOut iii) throws Exception {
if (value instanceof final UUID tmp) { if (value instanceof final UUID tmp) {
final byte[] dataByte = UuidUtils.asBytes(tmp); final byte[] dataByte = UuidUtils.asBytes(tmp);
@ -1616,10 +1617,4 @@ public class DBAccessSQL extends DBAccess {
} }
return outs; return outs;
} }
@Override
public void close() throws IOException {
// TODO Auto-generated method stub
}
} }

View File

@ -244,7 +244,7 @@ public class DataExport {
} }
public static TableQuery queryTable( public static TableQuery queryTable(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final List<TableQueryTypes> headers, final List<TableQueryTypes> headers,
final String query, final String query,
final List<Object> parameters, final List<Object> parameters,
@ -254,7 +254,7 @@ public class DataExport {
} }
public static TableQuery queryTable( public static TableQuery queryTable(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final List<TableQueryTypes> headers, final List<TableQueryTypes> headers,
final String queryBase, final String queryBase,
final List<Object> parameters, final List<Object> parameters,

View File

@ -387,8 +387,8 @@ public class DataFactory {
} }
alreadyAdded.add(dataName); alreadyAdded.add(dataName);
LOGGER.trace(" + '{}'", elem.getName()); LOGGER.trace(" + '{}'", elem.getName());
if (DBAccessSQL.isAddOnField(elem)) { if (DataAccessSQL.isAddOnField(elem)) {
final DataAccessAddOn addOn = DBAccessSQL.findAddOnforField(elem); final DataAccessAddOn addOn = DataAccessSQL.findAddOnforField(elem);
LOGGER.trace("Create type for: {} ==> {} (ADD-ON)", AnnotationTools.getFieldName(elem), LOGGER.trace("Create type for: {} ==> {} (ADD-ON)", AnnotationTools.getFieldName(elem),
elem.getType()); elem.getType());
if (addOn != null) { if (addOn != null) {

View File

@ -45,7 +45,7 @@ public class QueryAnd implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
for (final QueryItem elem : this.childs) { for (final QueryItem elem : this.childs) {
elem.injectQuery(ioDb, ps, iii); elem.injectQuery(ioDb, ps, iii);

View File

@ -10,7 +10,7 @@ import org.slf4j.LoggerFactory;
import com.mongodb.client.model.Filters; import com.mongodb.client.model.Filters;
public class QueryCondition implements QueryItem { public class QueryCondition implements QueryItem {
static final Logger LOGGER = LoggerFactory.getLogger(DBAccess.class); static final Logger LOGGER = LoggerFactory.getLogger(DataAccess.class);
private final String key; private final String key;
private final String comparator; private final String comparator;
private final Object value; private final Object value;
@ -40,7 +40,7 @@ public class QueryCondition implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
ioDb.addElement(ps, this.value, iii); ioDb.addElement(ps, this.value, iii);
iii.inc(); iii.inc();

View File

@ -48,7 +48,7 @@ public class QueryInList<T> implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
for (final Object elem : this.value) { for (final Object elem : this.value) {
ioDb.addElement(ps, elem, iii); ioDb.addElement(ps, elem, iii);

View File

@ -10,7 +10,7 @@ public interface QueryItem {
void generateQuery(StringBuilder query, String tableName); void generateQuery(StringBuilder query, String tableName);
// For SQL mode query injection // For SQL mode query injection
void injectQuery(DBAccessSQL ioDb, PreparedStatement ps, CountInOut iii) throws Exception; void injectQuery(DataAccessSQL ioDb, PreparedStatement ps, CountInOut iii) throws Exception;
// For No-SQL mode filter creation // For No-SQL mode filter creation
void generateFilter(List<Bson> filters); void generateFilter(List<Bson> filters);

View File

@ -25,7 +25,7 @@ public class QueryNotNull implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception {} throws Exception {}
@Override @Override

View File

@ -25,7 +25,7 @@ public class QueryNull implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception {} throws Exception {}
@Override @Override

View File

@ -39,7 +39,7 @@ public class QueryOr implements QueryItem {
} }
@Override @Override
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
for (final QueryItem elem : this.childs) { for (final QueryItem elem : this.childs) {
elem.injectQuery(ioDb, ps, iii); elem.injectQuery(ioDb, ps, iii);

View File

@ -11,8 +11,8 @@ import org.bson.Document;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.annotation.DataJson; import org.kar.archidata.annotation.DataJson;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -55,7 +55,7 @@ public class AddOnDataJson implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
final Document docSet, final Document docSet,
@ -105,7 +105,7 @@ public class AddOnDataJson implements DataAccessAddOn {
@Override @Override
public void fillFromDoc( public void fillFromDoc(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Document doc, final Document doc,
final Field field, final Field field,
final Object data, final Object data,
@ -181,7 +181,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
@ -212,12 +212,12 @@ public class AddOnDataJson implements DataAccessAddOn {
* @throws Exception If an error occurs during data retrieval or update. * @throws Exception If an error occurs during data retrieval or update.
*/ */
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
// TODO: Get primary key name // TODO: Get primary key name
final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName)); final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName));
@ -231,7 +231,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));// TODO: ,new OverrideFieldName("covers", column)); ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));// TODO: ,new OverrideFieldName("covers", column));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -250,12 +250,12 @@ public class AddOnDataJson implements DataAccessAddOn {
* @throws Exception If an error occurs during data retrieval or update. * @throws Exception If an error occurs during data retrieval or update.
*/ */
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid, final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -269,7 +269,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -277,12 +277,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid, final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -296,7 +296,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -304,12 +304,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid, final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -325,7 +325,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -333,12 +333,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid, final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -354,7 +354,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -362,12 +362,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversLongLong data = ioDb.get(TableCoversLongLong.class, id, new OverrideTableName(tableName)); final TableCoversLongLong data = ioDb.get(TableCoversLongLong.class, id, new OverrideTableName(tableName));
if (data.covers == null) { if (data.covers == null) {
@ -382,7 +382,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -390,12 +390,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName)); final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName));
if (data.covers == null) { if (data.covers == null) {
@ -409,7 +409,7 @@ public class AddOnDataJson implements DataAccessAddOn {
newList.add(elem); newList.add(elem);
} }
data.covers = newList; data.covers = newList;
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
final String collectionName = AnnotationTools.getCollectionName(clazz); final String collectionName = AnnotationTools.getCollectionName(clazz);
final Field primaryfield = AnnotationTools.getPrimaryKeyField(clazz); final Field primaryfield = AnnotationTools.getPrimaryKeyField(clazz);
final String primaryFieldName = AnnotationTools.getFieldName(primaryfield); final String primaryFieldName = AnnotationTools.getFieldName(primaryfield);

View File

@ -9,8 +9,8 @@ import java.util.UUID;
import org.bson.Document; import org.bson.Document;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryAnd; import org.kar.archidata.dataAccess.QueryAnd;
@ -54,7 +54,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
final Document docSet, final Document docSet,
@ -206,7 +206,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void fillFromDoc( public void fillFromDoc(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Document doc, final Document doc,
final Field field, final Field field,
final Object data, final Object data,
@ -292,7 +292,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void asyncUpdate( public void asyncUpdate(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final String tableName, final String tableName,
final Object localKey, final Object localKey,
final Field field, final Field field,
@ -349,7 +349,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void asyncInsert( public void asyncInsert(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final String tableName, final String tableName,
final Object localKey, final Object localKey,
final Field field, final Field field,
@ -474,7 +474,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
@Override @Override
public void drop(final DBAccessMorphia ioDb, final String tableName, final Field field) throws Exception { public void drop(final DataAccessMorphia ioDb, final String tableName, final Field field) throws Exception {
final String columnName = AnnotationTools.getFieldName(field); final String columnName = AnnotationTools.getFieldName(field);
final String linkTableName = generateLinkTableName(tableName, columnName); final String linkTableName = generateLinkTableName(tableName, columnName);
final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()) final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType())
@ -487,7 +487,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
@Override @Override
public void cleanAll(final DBAccessMorphia ioDb, final String tableName, final Field field) throws Exception { public void cleanAll(final DataAccessMorphia ioDb, final String tableName, final Field field) throws Exception {
final String columnName = AnnotationTools.getFieldName(field); final String columnName = AnnotationTools.getFieldName(field);
final String linkTableName = generateLinkTableName(tableName, columnName); final String linkTableName = generateLinkTableName(tableName, columnName);
final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()) final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType())
@ -500,19 +500,19 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final long localKey, final long localKey,
final String column, final String column,
final long remoteKey) throws Exception { final long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final String linkTableName = generateLinkTableName(tableName, column); final String linkTableName = generateLinkTableName(tableName, column);
/* final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()).getActualTypeArguments()[0]; if (objectClass != Long.class && objectClass != UUID.class) { throw new /* final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()).getActualTypeArguments()[0]; if (objectClass != Long.class && objectClass != UUID.class) { throw new
* DataAccessException("Can not ManyToMany with other than List<Long> or List<UUID> Model: List<" + objectClass.getCanonicalName() + ">"); } */ * DataAccessException("Can not ManyToMany with other than List<Long> or List<UUID> Model: List<" + objectClass.getCanonicalName() + ">"); } */
final LinkTableLongLong insertElement = new LinkTableLongLong(localKey, remoteKey); final LinkTableLongLong insertElement = new LinkTableLongLong(localKey, remoteKey);
daSQL.insert(insertElement, new OverrideTableName(linkTableName)); daSQL.insert(insertElement, new OverrideTableName(linkTableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -521,18 +521,18 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
public static long removeLink( public static long removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final long localKey, final long localKey,
final String column, final String column,
final long remoteKey) throws Exception { final long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessMorphia daSQL) { if (ioDb instanceof final DataAccessMorphia daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final String linkTableName = generateLinkTableName(tableName, column); final String linkTableName = generateLinkTableName(tableName, column);
return daSQL.deleteWhere(LinkTableLongLong.class, new OverrideTableName(linkTableName), return daSQL.deleteWhere(LinkTableLongLong.class, new OverrideTableName(linkTableName),
new Condition(new QueryAnd(new QueryCondition("object1Id", "=", localKey), new Condition(new QueryAnd(new QueryCondition("object1Id", "=", localKey),
new QueryCondition("object2Id", "=", remoteKey)))); new QueryCondition("object2Id", "=", remoteKey))));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
return 0L; return 0L;
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");

View File

@ -7,7 +7,7 @@ import java.util.UUID;
import org.bson.Document; import org.bson.Document;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -43,7 +43,7 @@ public class AddOnManyToOne implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
final Document docSet, final Document docSet,
@ -143,7 +143,7 @@ public class AddOnManyToOne implements DataAccessAddOn {
@Override @Override
public void fillFromDoc( public void fillFromDoc(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Document doc, final Document doc,
final Field field, final Field field,
final Object data, final Object data,

View File

@ -12,7 +12,7 @@ import java.util.stream.Collectors;
import org.bson.Document; import org.bson.Document;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryCondition; import org.kar.archidata.dataAccess.QueryCondition;
@ -83,7 +83,7 @@ public class AddOnOneToMany implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
final Document docSet, final Document docSet,
@ -222,7 +222,7 @@ public class AddOnOneToMany implements DataAccessAddOn {
@Override @Override
public void fillFromDoc( public void fillFromDoc(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Document doc, final Document doc,
final Field field, final Field field,
final Object data, final Object data,

View File

@ -6,7 +6,7 @@ import java.util.List;
import org.bson.Document; import org.bson.Document;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -34,7 +34,7 @@ public interface DataAccessAddOn {
* @return the new index of injection in case of multiple value management * @return the new index of injection in case of multiple value management
* @throws SQLException */ * @throws SQLException */
void insertData( void insertData(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
final Document docSet, final Document docSet,
@ -66,7 +66,7 @@ public interface DataAccessAddOn {
// Return the number of colomn read // Return the number of colomn read
void fillFromDoc( void fillFromDoc(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
Document doc, Document doc,
Field field, Field field,
Object data, Object data,
@ -108,7 +108,7 @@ public interface DataAccessAddOn {
* @param data Data that might be inserted. * @param data Data that might be inserted.
* @param actions Asynchronous action to do after main request. */ * @param actions Asynchronous action to do after main request. */
default void asyncInsert( default void asyncInsert(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final String tableName, final String tableName,
final Object localId, final Object localId,
final Field field, final Field field,
@ -131,7 +131,7 @@ public interface DataAccessAddOn {
* @param data Data that might be inserted. * @param data Data that might be inserted.
* @param actions Asynchronous action to do after main request. */ * @param actions Asynchronous action to do after main request. */
default void asyncUpdate( default void asyncUpdate(
final DBAccessMorphia ioDb, final DataAccessMorphia ioDb,
final String tableName, final String tableName,
final Object localId, final Object localId,
final Field field, final Field field,
@ -140,11 +140,11 @@ public interface DataAccessAddOn {
} }
default void drop(final DBAccessMorphia ioDb, final String tableName, final Field field) throws Exception { default void drop(final DataAccessMorphia ioDb, final String tableName, final Field field) throws Exception {
} }
default void cleanAll(final DBAccessMorphia ioDb, final String tableName, final Field field) throws Exception { default void cleanAll(final DataAccessMorphia ioDb, final String tableName, final Field field) throws Exception {
} }

View File

@ -14,9 +14,9 @@ import org.bson.Document;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.annotation.DataJson; import org.kar.archidata.annotation.DataJson;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -60,7 +60,7 @@ public class AddOnDataJson implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final PreparedStatement ps, final PreparedStatement ps,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
@ -111,7 +111,7 @@ public class AddOnDataJson implements DataAccessAddOn {
@Override @Override
public void fillFromQuery( public void fillFromQuery(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final ResultSet rs, final ResultSet rs,
final Field field, final Field field,
final Object data, final Object data,
@ -183,7 +183,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
@ -214,12 +214,12 @@ public class AddOnDataJson implements DataAccessAddOn {
* @throws Exception If an error occurs during data retrieval or update. * @throws Exception If an error occurs during data retrieval or update.
*/ */
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
// TODO: Get primary key name // TODO: Get primary key name
final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName)); final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName));
@ -233,7 +233,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));// TODO: ,new OverrideFieldName("covers", column)); ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));// TODO: ,new OverrideFieldName("covers", column));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -252,12 +252,12 @@ public class AddOnDataJson implements DataAccessAddOn {
* @throws Exception If an error occurs during data retrieval or update. * @throws Exception If an error occurs during data retrieval or update.
*/ */
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid, final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -271,7 +271,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -279,12 +279,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid, final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -298,7 +298,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers.add(remoteKey); data.covers.add(remoteKey);
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -306,12 +306,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid, final TableCoversUUIDLong data = ioDb.get(TableCoversUUIDLong.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -327,7 +327,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -335,12 +335,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final UUID uuid, final UUID uuid,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid, final TableCoversUUIDUUID data = ioDb.get(TableCoversUUIDUUID.class, uuid,
new OverrideTableName(tableName)); new OverrideTableName(tableName));
@ -356,7 +356,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.uuid, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -364,12 +364,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final Long remoteKey) throws Exception { final Long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversLongLong data = ioDb.get(TableCoversLongLong.class, id, new OverrideTableName(tableName)); final TableCoversLongLong data = ioDb.get(TableCoversLongLong.class, id, new OverrideTableName(tableName));
if (data.covers == null) { if (data.covers == null) {
@ -384,7 +384,7 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
data.covers = newList; data.covers = newList;
ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName)); ioDb.update(data, data.id, List.of("covers"), new OverrideTableName(tableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -392,12 +392,12 @@ public class AddOnDataJson implements DataAccessAddOn {
} }
public static void removeLink( public static void removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final Long id, final Long id,
final String column, final String column,
final UUID remoteKey) throws Exception { final UUID remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName)); final TableCoversLongUUID data = ioDb.get(TableCoversLongUUID.class, id, new OverrideTableName(tableName));
if (data.covers == null) { if (data.covers == null) {
@ -411,7 +411,7 @@ public class AddOnDataJson implements DataAccessAddOn {
newList.add(elem); newList.add(elem);
} }
data.covers = newList; data.covers = newList;
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
final String collectionName = AnnotationTools.getCollectionName(clazz); final String collectionName = AnnotationTools.getCollectionName(clazz);
final Field primaryfield = AnnotationTools.getPrimaryKeyField(clazz); final Field primaryfield = AnnotationTools.getPrimaryKeyField(clazz);
final String primaryFieldName = AnnotationTools.getFieldName(primaryfield); final String primaryFieldName = AnnotationTools.getFieldName(primaryfield);

View File

@ -11,9 +11,9 @@ import java.util.UUID;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessMorphia; import org.kar.archidata.dataAccess.DataAccessMorphia;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryAnd; import org.kar.archidata.dataAccess.QueryAnd;
@ -58,7 +58,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final PreparedStatement ps, final PreparedStatement ps,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
@ -214,7 +214,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void fillFromQuery( public void fillFromQuery(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final ResultSet rs, final ResultSet rs,
final Field field, final Field field,
final Object data, final Object data,
@ -297,7 +297,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void asyncUpdate( public void asyncUpdate(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final String tableName, final String tableName,
final Object localKey, final Object localKey,
final Field field, final Field field,
@ -354,7 +354,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
@Override @Override
public void asyncInsert( public void asyncInsert(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final String tableName, final String tableName,
final Object localKey, final Object localKey,
final Field field, final Field field,
@ -479,7 +479,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
@Override @Override
public void drop(final DBAccessSQL ioDb, final String tableName, final Field field) throws Exception { public void drop(final DataAccessSQL ioDb, final String tableName, final Field field) throws Exception {
final String columnName = AnnotationTools.getFieldName(field); final String columnName = AnnotationTools.getFieldName(field);
final String linkTableName = generateLinkTableName(tableName, columnName); final String linkTableName = generateLinkTableName(tableName, columnName);
final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()) final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType())
@ -492,7 +492,7 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
@Override @Override
public void cleanAll(final DBAccessSQL ioDb, final String tableName, final Field field) throws Exception { public void cleanAll(final DataAccessSQL ioDb, final String tableName, final Field field) throws Exception {
final String columnName = AnnotationTools.getFieldName(field); final String columnName = AnnotationTools.getFieldName(field);
final String linkTableName = generateLinkTableName(tableName, columnName); final String linkTableName = generateLinkTableName(tableName, columnName);
final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()) final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType())
@ -505,19 +505,19 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
public static void addLink( public static void addLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final long localKey, final long localKey,
final String column, final String column,
final long remoteKey) throws Exception { final long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final String linkTableName = generateLinkTableName(tableName, column); final String linkTableName = generateLinkTableName(tableName, column);
/* final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()).getActualTypeArguments()[0]; if (objectClass != Long.class && objectClass != UUID.class) { throw new /* final Class<?> objectClass = (Class<?>) ((ParameterizedType) field.getGenericType()).getActualTypeArguments()[0]; if (objectClass != Long.class && objectClass != UUID.class) { throw new
* DataAccessException("Can not ManyToMany with other than List<Long> or List<UUID> Model: List<" + objectClass.getCanonicalName() + ">"); } */ * DataAccessException("Can not ManyToMany with other than List<Long> or List<UUID> Model: List<" + objectClass.getCanonicalName() + ">"); } */
final LinkTableLongLong insertElement = new LinkTableLongLong(localKey, remoteKey); final LinkTableLongLong insertElement = new LinkTableLongLong(localKey, remoteKey);
daSQL.insert(insertElement, new OverrideTableName(linkTableName)); daSQL.insert(insertElement, new OverrideTableName(linkTableName));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");
@ -526,18 +526,18 @@ public class AddOnManyToMany implements DataAccessAddOn {
} }
public static long removeLink( public static long removeLink(
final DBAccess ioDb, final DataAccess ioDb,
final Class<?> clazz, final Class<?> clazz,
final long localKey, final long localKey,
final String column, final String column,
final long remoteKey) throws Exception { final long remoteKey) throws Exception {
if (ioDb instanceof final DBAccessSQL daSQL) { if (ioDb instanceof final DataAccessSQL daSQL) {
final String tableName = AnnotationTools.getTableName(clazz); final String tableName = AnnotationTools.getTableName(clazz);
final String linkTableName = generateLinkTableName(tableName, column); final String linkTableName = generateLinkTableName(tableName, column);
return daSQL.deleteWhere(LinkTableLongLong.class, new OverrideTableName(linkTableName), return daSQL.deleteWhere(LinkTableLongLong.class, new OverrideTableName(linkTableName),
new Condition(new QueryAnd(new QueryCondition("object1Id", "=", localKey), new Condition(new QueryAnd(new QueryCondition("object1Id", "=", localKey),
new QueryCondition("object2Id", "=", remoteKey)))); new QueryCondition("object2Id", "=", remoteKey))));
} else if (ioDb instanceof final DBAccessMorphia dam) { } else if (ioDb instanceof final DataAccessMorphia dam) {
return 0L; return 0L;
} else { } else {
throw new DataAccessException("DataAccess Not managed"); throw new DataAccessException("DataAccess Not managed");

View File

@ -9,7 +9,7 @@ import java.util.UUID;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -48,7 +48,7 @@ public class AddOnManyToOne implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final PreparedStatement ps, final PreparedStatement ps,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
@ -152,7 +152,7 @@ public class AddOnManyToOne implements DataAccessAddOn {
if (field.getType() == decorators.targetEntity()) { if (field.getType() == decorators.targetEntity()) {
if (decorators.fetch() == FetchType.EAGER) { if (decorators.fetch() == FetchType.EAGER) {
// TODO: rework this to have a lazy mode ... // TODO: rework this to have a lazy mode ...
DBAccessSQL.generateSelectField(querySelect, query, field.getType(), options, count); DataAccessSQL.generateSelectField(querySelect, query, field.getType(), options, count);
final Class<?> subType = field.getType(); final Class<?> subType = field.getType();
final String subTableName = AnnotationTools.getTableName(subType); final String subTableName = AnnotationTools.getTableName(subType);
final Field idField = AnnotationTools.getFieldOfId(subType); final Field idField = AnnotationTools.getFieldOfId(subType);
@ -181,7 +181,7 @@ public class AddOnManyToOne implements DataAccessAddOn {
@Override @Override
public void fillFromQuery( public void fillFromQuery(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final ResultSet rs, final ResultSet rs,
final Field field, final Field field,
final Object data, final Object data,

View File

@ -12,7 +12,7 @@ import java.util.stream.Collectors;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryCondition; import org.kar.archidata.dataAccess.QueryCondition;
@ -83,7 +83,7 @@ public class AddOnOneToMany implements DataAccessAddOn {
@Override @Override
public void insertData( public void insertData(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final PreparedStatement ps, final PreparedStatement ps,
final Field field, final Field field,
final Object rootObject, final Object rootObject,
@ -222,7 +222,7 @@ public class AddOnOneToMany implements DataAccessAddOn {
@Override @Override
public void fillFromQuery( public void fillFromQuery(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final ResultSet rs, final ResultSet rs,
final Field field, final Field field,
final Object data, final Object data,

View File

@ -7,7 +7,7 @@ import java.sql.SQLException;
import java.util.List; import java.util.List;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.LazyGetter; import org.kar.archidata.dataAccess.LazyGetter;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -34,7 +34,7 @@ public interface DataAccessAddOn {
* @param iii The index of injection * @param iii The index of injection
* @return the new index of injection in case of multiple value management * @return the new index of injection in case of multiple value management
* @throws SQLException */ * @throws SQLException */
void insertData(final DBAccessSQL ioDb, PreparedStatement ps, final Field field, Object data, CountInOut iii) void insertData(final DataAccessSQL ioDb, PreparedStatement ps, final Field field, Object data, CountInOut iii)
throws Exception, SQLException, IllegalArgumentException, IllegalAccessException; throws Exception, SQLException, IllegalArgumentException, IllegalAccessException;
/** Element can insert in the single request /** Element can insert in the single request
@ -63,7 +63,7 @@ public interface DataAccessAddOn {
// Return the number of colomn read // Return the number of colomn read
void fillFromQuery( void fillFromQuery(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
ResultSet rs, ResultSet rs,
Field field, Field field,
Object data, Object data,
@ -106,7 +106,7 @@ public interface DataAccessAddOn {
* @param data Data that might be inserted. * @param data Data that might be inserted.
* @param actions Asynchronous action to do after main request. */ * @param actions Asynchronous action to do after main request. */
default void asyncInsert( default void asyncInsert(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final String tableName, final String tableName,
final Object localId, final Object localId,
final Field field, final Field field,
@ -129,7 +129,7 @@ public interface DataAccessAddOn {
* @param data Data that might be inserted. * @param data Data that might be inserted.
* @param actions Asynchronous action to do after main request. */ * @param actions Asynchronous action to do after main request. */
default void asyncUpdate( default void asyncUpdate(
final DBAccessSQL ioDb, final DataAccessSQL ioDb,
final String tableName, final String tableName,
final Object localId, final Object localId,
final Field field, final Field field,
@ -138,11 +138,11 @@ public interface DataAccessAddOn {
} }
default void drop(final DBAccessSQL ioDb, final String tableName, final Field field) throws Exception { default void drop(final DataAccessSQL ioDb, final String tableName, final Field field) throws Exception {
} }
default void cleanAll(final DBAccessSQL ioDb, final String tableName, final Field field) throws Exception { default void cleanAll(final DataAccessSQL ioDb, final String tableName, final Field field) throws Exception {
} }

View File

@ -3,7 +3,7 @@ package org.kar.archidata.dataAccess.options;
import java.util.List; import java.util.List;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
/** By default some element are not read like createAt and UpdatedAt. This option permit to read it. */ /** By default some element are not read like createAt and UpdatedAt. This option permit to read it. */
@ -14,13 +14,13 @@ public interface CheckFunctionInterface {
* @param filterValue List of fields that might be check. If null, then all column must be checked. * @param filterValue List of fields that might be check. If null, then all column must be checked.
* @throws Exception Exception is generate if the data are incorrect. */ * @throws Exception Exception is generate if the data are incorrect. */
void check( void check(
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
Object data, Object data,
List<String> filterValue, List<String> filterValue,
final QueryOptions options) throws Exception; final QueryOptions options) throws Exception;
default void checkAll(final DBAccess ioDb, final String baseName, final Object data, final QueryOptions options) default void checkAll(final DataAccess ioDb, final String baseName, final Object data, final QueryOptions options)
throws Exception { throws Exception {
check(ioDb, baseName, data, AnnotationTools.getAllFieldsNames(data.getClass()), options); check(ioDb, baseName, data, AnnotationTools.getAllFieldsNames(data.getClass()), options);
} }

View File

@ -2,14 +2,14 @@ package org.kar.archidata.dataAccess.options;
import java.util.List; import java.util.List;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
/** By default some element are not read like createAt and UpdatedAt. This option permit to read it. */ /** By default some element are not read like createAt and UpdatedAt. This option permit to read it. */
public class CheckFunctionVoid implements CheckFunctionInterface { public class CheckFunctionVoid implements CheckFunctionInterface {
@Override @Override
public void check( public void check(
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final Object data, final Object data,
final List<String> filterValue, final List<String> filterValue,

View File

@ -14,7 +14,7 @@ import java.util.regex.Pattern;
import org.kar.archidata.annotation.AnnotationTools; import org.kar.archidata.annotation.AnnotationTools;
import org.kar.archidata.annotation.DataJson; import org.kar.archidata.annotation.DataJson;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.QueryCondition; import org.kar.archidata.dataAccess.QueryCondition;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
import org.kar.archidata.exception.DataAccessException; import org.kar.archidata.exception.DataAccessException;
@ -38,7 +38,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
* @param data The object that might be injected. * @param data The object that might be injected.
* @param filterValue List of fields that might be check. If null, then all column must be checked. * @param filterValue List of fields that might be check. If null, then all column must be checked.
* @throws Exception Exception is generate if the data are incorrect. */ * @throws Exception Exception is generate if the data are incorrect. */
void check(DBAccess ioDb, final String baseName, final K data, final QueryOptions options) throws Exception; void check(DataAccess ioDb, final String baseName, final K data, final QueryOptions options) throws Exception;
} }
protected Map<String, List<CheckInterface<T>>> checking = null; protected Map<String, List<CheckInterface<T>>> checking = null;
@ -69,7 +69,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (AnnotationTools.isPrimaryKey(field)) { if (AnnotationTools.isPrimaryKey(field)) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -80,7 +80,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (AnnotationTools.getConstraintsNotNull(field)) { if (AnnotationTools.getConstraintsNotNull(field)) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -92,7 +92,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (AnnotationTools.isCreatedAtField(field) || AnnotationTools.isUpdateAtField(field)) { if (AnnotationTools.isCreatedAtField(field) || AnnotationTools.isUpdateAtField(field)) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -106,7 +106,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (maxValue != null) { if (maxValue != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -125,7 +125,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (minValue != null) { if (minValue != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -144,7 +144,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) { if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -170,7 +170,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final int maxValue = maxValueRoot.intValue(); final int maxValue = maxValueRoot.intValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -190,7 +190,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final int minValue = minValueRoot.intValue(); final int minValue = minValueRoot.intValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -209,7 +209,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) { if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -229,7 +229,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) { if (annotationManyToOne != null && annotationManyToOne.targetEntity() != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -252,7 +252,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final float maxValue = maxValueRoot.floatValue(); final float maxValue = maxValueRoot.floatValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -272,7 +272,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final float minValue = minValueRoot.floatValue(); final float minValue = minValueRoot.floatValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -293,7 +293,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final double maxValue = maxValueRoot.doubleValue(); final double maxValue = maxValueRoot.doubleValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -313,7 +313,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final double minValue = minValueRoot.doubleValue(); final double minValue = minValueRoot.doubleValue();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -339,7 +339,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (maxSizeString > 0) { if (maxSizeString > 0) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -358,7 +358,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
if (limitSize != null) { if (limitSize != null) {
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -382,7 +382,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
final Pattern pattern = Pattern.compile(patternString); final Pattern pattern = Pattern.compile(patternString);
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -406,7 +406,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
.newInstance(); .newInstance();
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -421,7 +421,7 @@ public class CheckJPA<T> implements CheckFunctionInterface {
// Create the request ... // Create the request ...
add(fieldName, add(fieldName,
( (
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final T data, final T data,
final QueryOptions options) -> { final QueryOptions options) -> {
@ -448,18 +448,18 @@ public class CheckJPA<T> implements CheckFunctionInterface {
} }
} }
public void check(final DBAccess ioDb, final String baseName, final Object data) throws Exception { public void check(final DataAccess ioDb, final String baseName, final Object data) throws Exception {
check(ioDb, baseName, data, null, null); check(ioDb, baseName, data, null, null);
} }
public void check(final DBAccess ioDb, final String baseName, final Object data, final List<String> filterValue) public void check(final DataAccess ioDb, final String baseName, final Object data, final List<String> filterValue)
throws Exception { throws Exception {
check(ioDb, baseName, data, filterValue, null); check(ioDb, baseName, data, filterValue, null);
} }
@Override @Override
public void check( public void check(
final DBAccess ioDb, final DataAccess ioDb,
final String baseName, final String baseName,
final Object data, final Object data,
final List<String> filterValue, final List<String> filterValue,

View File

@ -6,7 +6,7 @@ import java.util.List;
import org.bson.conversions.Bson; import org.bson.conversions.Bson;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.QueryItem; import org.kar.archidata.dataAccess.QueryItem;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
@ -30,7 +30,7 @@ public class Condition extends QueryOption {
} }
} }
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
if (this.condition != null) { if (this.condition != null) {
this.condition.injectQuery(ioDb, ps, iii); this.condition.injectQuery(ioDb, ps, iii);

View File

@ -3,7 +3,7 @@ package org.kar.archidata.dataAccess.options;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import org.kar.archidata.dataAccess.CountInOut; import org.kar.archidata.dataAccess.CountInOut;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
public class Limit extends QueryOption { public class Limit extends QueryOption {
protected final long limit; protected final long limit;
@ -16,7 +16,7 @@ public class Limit extends QueryOption {
query.append(" LIMIT ? \n"); query.append(" LIMIT ? \n");
} }
public void injectQuery(final DBAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii) public void injectQuery(final DataAccessSQL ioDb, final PreparedStatement ps, final CountInOut iii)
throws Exception { throws Exception {
ioDb.addElement(ps, this.limit, iii); ioDb.addElement(ps, this.limit, iii);
iii.inc(); iii.inc();

View File

@ -1,12 +1,12 @@
package org.kar.archidata.db; package org.kar.archidata.db;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.exception.DataAccessException; import org.kar.archidata.exception.DataAccessException;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
public class DBConfig { public class DBConfig {
static final Logger LOGGER = LoggerFactory.getLogger(DBAccess.class); static final Logger LOGGER = LoggerFactory.getLogger(DataAccess.class);
private final String type; private final String type;
private final String hostname; private final String hostname;
private final int port; private final int port;

View File

@ -8,22 +8,31 @@ import java.util.List;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
public class DBInterfaceFactory implements Closeable { public class DBEntry implements Closeable {
final static Logger LOGGER = LoggerFactory.getLogger(DBInterfaceFactory.class); final static Logger LOGGER = LoggerFactory.getLogger(DBEntry.class);
private final DBConfig config; private final DBConfig config;
private DbInterface ioDb; private DbInterface ioDb;
private Class<?> classes[] = {}; private Class<?> classes[] = {};
private static List<DBInterfaceFactory> stored = new ArrayList<>(); private static List<DBEntry> stored = new ArrayList<>();
private DBInterfaceFactory(final DBConfig config, final Class<?>... classes) throws IOException { private DBEntry(final DBConfig config, final boolean root, final Class<?>... classes) throws IOException {
this.config = config; this.config = config;
this.classes = classes; this.classes = classes;
if (root) {
connectRoot();
} else {
connect(); connect();
} }
}
public static DBInterfaceFactory create(final DBConfig config, final Class<?>... classes) throws IOException { public static DBEntry createInterface(final DBConfig config, final Class<?>... classes) throws IOException {
return createInterface(config, false, classes);
}
public static DBEntry createInterface(final DBConfig config, final boolean root, final Class<?>... classes)
throws IOException {
if (config.getKeepConnected()) { if (config.getKeepConnected()) {
for (final DBInterfaceFactory elem : stored) { for (final DBEntry elem : stored) {
if (elem == null) { if (elem == null) {
continue; continue;
} }
@ -31,11 +40,24 @@ public class DBInterfaceFactory implements Closeable {
return elem; return elem;
} }
} }
final DBInterfaceFactory tmp = new DBInterfaceFactory(config); final DBEntry tmp = new DBEntry(config, root);
stored.add(tmp); stored.add(tmp);
return tmp; return tmp;
} else { } else {
return new DBInterfaceFactory(config, classes); return new DBEntry(config, root, classes);
}
}
public void connectRoot() throws IOException {
// TODO: maybe better check for root connection ...
if ("mysql".equals(this.config.getType())) {
this.ioDb = new DbInterfaceSQL(this.config);
} else if ("sqlite".equals(this.config.getType())) {
this.ioDb = new DbInterfaceSQL(this.config);
} else if ("mongo".equals(this.config.getType())) {
this.ioDb = new DbInterfaceMorphia(this.config, this.classes);
} else {
throw new IOException("DB type: '" + this.config.getType() + "'is not managed");
} }
} }
@ -68,7 +90,7 @@ public class DBInterfaceFactory implements Closeable {
} }
public static void closeAllForceMode() throws IOException { public static void closeAllForceMode() throws IOException {
for (final DBInterfaceFactory entry : stored) { for (final DBEntry entry : stored) {
entry.closeForce(); entry.closeForce();
} }
stored = new ArrayList<>(); stored = new ArrayList<>();

View File

@ -1,7 +1,7 @@
package org.kar.archidata.migration; package org.kar.archidata.migration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
public interface AsyncCall { public interface AsyncCall {
void doRequest(DBAccess da) throws Exception; void doRequest(DataAccess da) throws Exception;
} }

View File

@ -5,8 +5,8 @@ import java.sql.SQLException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
import org.kar.archidata.db.DBConfig; import org.kar.archidata.db.DBConfig;
@ -24,17 +24,17 @@ public class MigrationEngine {
// initialization of the migration if the DB is not present... // initialization of the migration if the DB is not present...
private MigrationInterface init; private MigrationInterface init;
protected final DBAccess da; protected final DataAccess da;
/** Migration engine constructor (empty). */ /** Migration engine constructor (empty). */
public MigrationEngine(final DBAccess da) { public MigrationEngine(final DataAccess da) {
this(da, new ArrayList<>(), null); this(da, new ArrayList<>(), null);
} }
/** Migration engine constructor (specific mode). /** Migration engine constructor (specific mode).
* @param datas All the migration ordered. * @param datas All the migration ordered.
* @param init Initialization migration model. */ * @param init Initialization migration model. */
public MigrationEngine(final DBAccess da, final List<MigrationInterface> datas, final MigrationInterface init) { public MigrationEngine(final DataAccess da, final List<MigrationInterface> datas, final MigrationInterface init) {
this.datas = datas; this.datas = datas;
this.init = init; this.init = init;
this.da = da; this.da = da;
@ -159,7 +159,7 @@ public class MigrationEngine {
LOGGER.info("DB '{}' exist.", config.getDbName()); LOGGER.info("DB '{}' exist.", config.getDbName());
// STEP 2: Check migration table exist: // STEP 2: Check migration table exist:
LOGGER.info("Verify existance of migration table '{}'", "KAR_migration"); LOGGER.info("Verify existance of migration table '{}'", "KAR_migration");
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
exist = this.da.isTableExist("KAR_migration"); exist = this.da.isTableExist("KAR_migration");
if (!exist) { if (!exist) {
LOGGER.info("'{}' Does not exist create a new one...", "KAR_migration"); LOGGER.info("'{}' Does not exist create a new one...", "KAR_migration");

View File

@ -1,6 +1,6 @@
package org.kar.archidata.migration; package org.kar.archidata.migration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.migration.model.Migration; import org.kar.archidata.migration.model.Migration;
public interface MigrationInterface { public interface MigrationInterface {
@ -13,13 +13,13 @@ public interface MigrationInterface {
* @param log Stored data in the BDD for the migration progression. * @param log Stored data in the BDD for the migration progression.
* @param migration Migration post data on each step... * @param migration Migration post data on each step...
* @return true if migration is finished. */ * @return true if migration is finished. */
boolean applyMigration(DBAccess entry, StringBuilder log, Migration model) throws Exception; boolean applyMigration(DataAccess entry, StringBuilder log, Migration model) throws Exception;
/** Remove a migration the system to the previous version. /** Remove a migration the system to the previous version.
* @param entry DB interface for the migration. * @param entry DB interface for the migration.
* @param log Stored data in the BDD for the migration progression. * @param log Stored data in the BDD for the migration progression.
* @return true if migration is finished. */ * @return true if migration is finished. */
boolean revertMigration(DBAccess entry, StringBuilder log) throws Exception; boolean revertMigration(DataAccess entry, StringBuilder log) throws Exception;
/** Get the number of step in the migration process. /** Get the number of step in the migration process.
* @return count of SQL access. */ * @return count of SQL access. */

View File

@ -5,8 +5,8 @@ import java.sql.SQLException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.migration.model.Migration; import org.kar.archidata.migration.model.Migration;
import org.kar.archidata.tools.ConfigBaseVariable; import org.kar.archidata.tools.ConfigBaseVariable;
@ -70,7 +70,7 @@ public class MigrationSqlStep implements MigrationInterface {
} }
@Override @Override
public boolean applyMigration(final DBAccess da, final StringBuilder log, final Migration model) public boolean applyMigration(final DataAccess da, final StringBuilder log, final Migration model)
throws Exception { throws Exception {
if (!this.isGenerated) { if (!this.isGenerated) {
this.isGenerated = true; this.isGenerated = true;
@ -106,7 +106,7 @@ public class MigrationSqlStep implements MigrationInterface {
} }
try { try {
if (action.action() != null) { if (action.action() != null) {
if (da instanceof final DBAccessSQL ioDBSQL) { if (da instanceof final DataAccessSQL ioDBSQL) {
ioDBSQL.executeQuery(action.action()); ioDBSQL.executeQuery(action.action());
} }
} else { } else {
@ -145,7 +145,7 @@ public class MigrationSqlStep implements MigrationInterface {
} }
@Override @Override
public boolean revertMigration(final DBAccess da, final StringBuilder log) throws Exception { public boolean revertMigration(final DataAccess da, final StringBuilder log) throws Exception {
generateRevertStep(); generateRevertStep();
return false; return false;
} }

View File

@ -18,7 +18,7 @@ import java.util.UUID;
import org.apache.tika.Tika; import org.apache.tika.Tika;
import org.glassfish.jersey.media.multipart.FormDataContentDisposition; import org.glassfish.jersey.media.multipart.FormDataContentDisposition;
import org.kar.archidata.api.DataResource; import org.kar.archidata.api.DataResource;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.QueryAnd; import org.kar.archidata.dataAccess.QueryAnd;
import org.kar.archidata.dataAccess.QueryCondition; import org.kar.archidata.dataAccess.QueryCondition;
import org.kar.archidata.dataAccess.addOnSQL.AddOnDataJson; import org.kar.archidata.dataAccess.addOnSQL.AddOnDataJson;
@ -77,7 +77,7 @@ public class DataTools {
return filePath; return filePath;
} }
public static Data getWithSha512(final DBAccess ioDb, final String sha512) { public static Data getWithSha512(final DataAccess ioDb, final String sha512) {
try { try {
return ioDb.getWhere(Data.class, new Condition(new QueryCondition("sha512", "=", sha512)), return ioDb.getWhere(Data.class, new Condition(new QueryCondition("sha512", "=", sha512)),
new ReadAllColumn()); new ReadAllColumn());
@ -88,7 +88,7 @@ public class DataTools {
return null; return null;
} }
public static Data getWithId(final DBAccess ioDb, final long id) { public static Data getWithId(final DataAccess ioDb, final long id) {
try { try {
return ioDb.getWhere(Data.class, new Condition(new QueryAnd( return ioDb.getWhere(Data.class, new Condition(new QueryAnd(
List.of(new QueryCondition("deleted", "=", false), new QueryCondition("id", "=", id))))); List.of(new QueryCondition("deleted", "=", false), new QueryCondition("id", "=", id)))));
@ -100,7 +100,7 @@ public class DataTools {
} }
public static Data createNewData( public static Data createNewData(
final DBAccess ioDb, final DataAccess ioDb,
final long tmpUID, final long tmpUID,
final String originalFileName, final String originalFileName,
final String sha512, final String sha512,
@ -132,7 +132,7 @@ public class DataTools {
} }
public static Data createNewData( public static Data createNewData(
final DBAccess ioDb, final DataAccess ioDb,
final long tmpUID, final long tmpUID,
final String originalFileName, final String originalFileName,
final String sha512) throws IOException, SQLException { final String sha512) throws IOException, SQLException {
@ -151,7 +151,7 @@ public class DataTools {
return createNewData(ioDb, tmpUID, originalFileName, sha512, mimeType); return createNewData(ioDb, tmpUID, originalFileName, sha512, mimeType);
} }
public static void undelete(final DBAccess ioDb, final UUID id) { public static void undelete(final DataAccess ioDb, final UUID id) {
try { try {
ioDb.unsetDelete(Data.class, id); ioDb.unsetDelete(Data.class, id);
} catch (final Exception e) { } catch (final Exception e) {
@ -276,7 +276,7 @@ public class DataTools {
} }
public static <CLASS_TYPE, ID_TYPE> void uploadCoverFromUri( public static <CLASS_TYPE, ID_TYPE> void uploadCoverFromUri(
final DBAccess ioDb, final DataAccess ioDb,
final Class<CLASS_TYPE> clazz, final Class<CLASS_TYPE> clazz,
final ID_TYPE id, final ID_TYPE id,
final String url) throws Exception { final String url) throws Exception {
@ -355,7 +355,7 @@ public class DataTools {
} }
public static <CLASS_TYPE, ID_TYPE> void uploadCover( public static <CLASS_TYPE, ID_TYPE> void uploadCover(
final DBAccess ioDb, final DataAccess ioDb,
final Class<CLASS_TYPE> clazz, final Class<CLASS_TYPE> clazz,
final ID_TYPE id, final ID_TYPE id,
final InputStream fileInputStream, final InputStream fileInputStream,

View File

@ -4,8 +4,8 @@ import java.io.IOException;
import java.util.List; import java.util.List;
import org.kar.archidata.GlobalConfiguration; import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.db.DBInterfaceFactory; import org.kar.archidata.db.DBEntry;
import org.kar.archidata.tools.ConfigBaseVariable; import org.kar.archidata.tools.ConfigBaseVariable;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -35,7 +35,7 @@ import test.kar.archidata.dataAccess.model.TypesTable;
public class ConfigureDb { public class ConfigureDb {
final static private Logger LOGGER = LoggerFactory.getLogger(ConfigureDb.class); final static private Logger LOGGER = LoggerFactory.getLogger(ConfigureDb.class);
final static private String modeTestForced = null;//"MONGO"; final static private String modeTestForced = "MONGO";
public static void configure() throws IOException { public static void configure() throws IOException {
String modeTest = System.getenv("TEST_E2E_MODE"); String modeTest = System.getenv("TEST_E2E_MODE");
@ -97,7 +97,7 @@ public class ConfigureDb {
ConfigBaseVariable.dbUser = "root"; ConfigBaseVariable.dbUser = "root";
} }
// Connect the dataBase... // Connect the dataBase...
final DBInterfaceFactory entry = DBInterfaceFactory.create(GlobalConfiguration.getDbconfig(), final DBEntry entry = DBEntry.createInterface(GlobalConfiguration.getDbconfig(),
listObject.toArray(new Class<?>[0])); listObject.toArray(new Class<?>[0]));
entry.connect(); entry.connect();
@ -106,7 +106,7 @@ public class ConfigureDb {
public static void removeDB() { public static void removeDB() {
final DBAccess da = DBAccess.createInterface(); final DataAccess da = DataAccess.createInterface();
String modeTest = System.getenv("TEST_E2E_MODE"); String modeTest = System.getenv("TEST_E2E_MODE");
if (modeTest == null || modeTest.isEmpty() || "false".equalsIgnoreCase(modeTest)) { if (modeTest == null || modeTest.isEmpty() || "false".equalsIgnoreCase(modeTest)) {
@ -132,7 +132,7 @@ public class ConfigureDb {
public static void clear() throws IOException { public static void clear() throws IOException {
LOGGER.info("Remove the test db"); LOGGER.info("Remove the test db");
removeDB(); removeDB();
DBInterfaceFactory.closeAllForceMode(); DBEntry.closeAllForceMode();
ConfigBaseVariable.clearAllValue(); ConfigBaseVariable.clearAllValue();
} }

View File

@ -17,7 +17,7 @@ import org.kar.archidata.UpdateJwtPublicKey;
import org.kar.archidata.api.DataResource; import org.kar.archidata.api.DataResource;
import org.kar.archidata.api.ProxyResource; import org.kar.archidata.api.ProxyResource;
import org.kar.archidata.catcher.GenericCatcher; import org.kar.archidata.catcher.GenericCatcher;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.filter.CORSFilter; import org.kar.archidata.filter.CORSFilter;
import org.kar.archidata.filter.OptionFilter; import org.kar.archidata.filter.OptionFilter;
import org.kar.archidata.migration.MigrationEngine; import org.kar.archidata.migration.MigrationEngine;
@ -33,10 +33,10 @@ public class WebLauncher {
protected UpdateJwtPublicKey keyUpdater = null; protected UpdateJwtPublicKey keyUpdater = null;
protected HttpServer server = null; protected HttpServer server = null;
private final DBAccess da; private final DataAccess da;
public WebLauncher() { public WebLauncher() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
private static URI getBaseURI() { private static URI getBaseURI() {

View File

@ -5,7 +5,7 @@ import java.util.List;
import org.kar.archidata.annotation.ARCHIVE; import org.kar.archidata.annotation.ARCHIVE;
import org.kar.archidata.annotation.AsyncType; import org.kar.archidata.annotation.AsyncType;
import org.kar.archidata.annotation.RESTORE; import org.kar.archidata.annotation.RESTORE;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -27,7 +27,7 @@ import test.kar.archidata.dataAccess.model.SimpleTable;
public class TestResourceSample { public class TestResourceSample {
private static final Logger LOGGER = LoggerFactory.getLogger(TestResource.class); private static final Logger LOGGER = LoggerFactory.getLogger(TestResource.class);
private final DBAccess da = DBAccess.createInterface(); private final DataAccess da = DataAccess.createInterface();
@GET @GET
@PermitAll @PermitAll

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -27,7 +27,7 @@ import test.kar.archidata.dataAccess.model.SimpleTable;
public class TestJson { public class TestJson {
final static private Logger LOGGER = LoggerFactory.getLogger(TestJson.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestJson.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -40,14 +40,14 @@ public class TestJson {
} }
public TestJson() { public TestJson() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@Test @Test
public void testTableFactory() throws Exception { public void testTableFactory() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(SerializeAsJson.class); final List<String> sqlCommand = DataFactory.createTable(SerializeAsJson.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -12,8 +12,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -27,7 +27,7 @@ import test.kar.archidata.dataAccess.model.SerializeListAsJson;
public class TestListJson { public class TestListJson {
final static private Logger LOGGER = LoggerFactory.getLogger(TestListJson.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestListJson.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -40,14 +40,14 @@ public class TestListJson {
} }
public TestListJson() { public TestListJson() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@Test @Test
public void testTableInsertAndRetrieve() throws Exception { public void testTableInsertAndRetrieve() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(SerializeListAsJson.class); final List<String> sqlCommand = DataFactory.createTable(SerializeListAsJson.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.addOnSQL.AddOnManyToMany; import org.kar.archidata.dataAccess.addOnSQL.AddOnManyToMany;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -29,7 +29,7 @@ import test.kar.archidata.dataAccess.model.TypeManyToManyRootExpand;
public class TestManyToMany { public class TestManyToMany {
final static private Logger LOGGER = LoggerFactory.getLogger(TestManyToMany.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestManyToMany.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -42,7 +42,7 @@ public class TestManyToMany {
} }
public TestManyToMany() { public TestManyToMany() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@ -51,7 +51,7 @@ public class TestManyToMany {
final List<String> sqlCommand2 = DataFactory.createTable(TypeManyToManyRoot.class); final List<String> sqlCommand2 = DataFactory.createTable(TypeManyToManyRoot.class);
final List<String> sqlCommand = DataFactory.createTable(TypeManyToManyRemote.class); final List<String> sqlCommand = DataFactory.createTable(TypeManyToManyRemote.class);
sqlCommand.addAll(sqlCommand2); sqlCommand.addAll(sqlCommand2);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -31,7 +31,7 @@ import test.kar.archidata.dataAccess.model.TypeManyToOneUUIDRootExpand;
public class TestManyToOne { public class TestManyToOne {
final static private Logger LOGGER = LoggerFactory.getLogger(TestManyToOne.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestManyToOne.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -44,7 +44,7 @@ public class TestManyToOne {
} }
public TestManyToOne() { public TestManyToOne() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@ -54,7 +54,7 @@ public class TestManyToOne {
sqlCommand.addAll(DataFactory.createTable(TypeManyToOneRoot.class)); sqlCommand.addAll(DataFactory.createTable(TypeManyToOneRoot.class));
sqlCommand.addAll(DataFactory.createTable(TypeManyToOneUUIDRoot.class)); sqlCommand.addAll(DataFactory.createTable(TypeManyToOneUUIDRoot.class));
sqlCommand.addAll(DataFactory.createTable(TypeManyToOneUUIDRemote.class)); sqlCommand.addAll(DataFactory.createTable(TypeManyToOneUUIDRemote.class));
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -31,7 +31,7 @@ import test.kar.archidata.dataAccess.model.TypeOneToManyUUIDRootExpand;
public class TestOneToMany { public class TestOneToMany {
final static private Logger LOGGER = LoggerFactory.getLogger(TestOneToMany.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestOneToMany.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -44,7 +44,7 @@ public class TestOneToMany {
} }
public TestOneToMany() { public TestOneToMany() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@ -54,7 +54,7 @@ public class TestOneToMany {
sqlCommand.addAll(DataFactory.createTable(TypeOneToManyRoot.class)); sqlCommand.addAll(DataFactory.createTable(TypeOneToManyRoot.class));
sqlCommand.addAll(DataFactory.createTable(TypeOneToManyUUIDRemote.class)); sqlCommand.addAll(DataFactory.createTable(TypeOneToManyUUIDRemote.class));
sqlCommand.addAll(DataFactory.createTable(TypeOneToManyUUIDRoot.class)); sqlCommand.addAll(DataFactory.createTable(TypeOneToManyUUIDRoot.class));
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -26,7 +26,7 @@ import test.kar.archidata.dataAccess.model.TypesTable;
public class TestRawQuery { public class TestRawQuery {
final static private Logger LOGGER = LoggerFactory.getLogger(TestTypes.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestTypes.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -39,8 +39,8 @@ public class TestRawQuery {
} }
public TestRawQuery() { public TestRawQuery() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
LOGGER.error("lkjddlkj"); LOGGER.error("lkjddlkj");
} }
} }
@ -49,7 +49,7 @@ public class TestRawQuery {
@Test @Test
public void testCreateTable() throws Exception { public void testCreateTable() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(TypesTable.class); final List<String> sqlCommand = DataFactory.createTable(TypesTable.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);
@ -60,7 +60,7 @@ public class TestRawQuery {
@Order(2) @Order(2)
@Test @Test
public void testGet() throws Exception { public void testGet() throws Exception {
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
final TypesTable test = new TypesTable(); final TypesTable test = new TypesTable();
test.intData = 95; test.intData = 95;

View File

@ -14,8 +14,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -34,7 +34,7 @@ public class TestSimpleTable {
private static Long idOfTheObject = null; private static Long idOfTheObject = null;
private static Timestamp startAction = null; private static Timestamp startAction = null;
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -50,7 +50,7 @@ public class TestSimpleTable {
} }
public TestSimpleTable() { public TestSimpleTable() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@ -58,7 +58,7 @@ public class TestSimpleTable {
public void testTableInsertAndRetrieve() throws Exception { public void testTableInsertAndRetrieve() throws Exception {
TestSimpleTable.startAction = Timestamp.from(Instant.now()); TestSimpleTable.startAction = Timestamp.from(Instant.now());
final List<String> sqlCommand = DataFactory.createTable(SimpleTable.class); final List<String> sqlCommand = DataFactory.createTable(SimpleTable.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -14,8 +14,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.kar.archidata.dataAccess.QueryOptions; import org.kar.archidata.dataAccess.QueryOptions;
import org.kar.archidata.tools.ConfigBaseVariable; import org.kar.archidata.tools.ConfigBaseVariable;
@ -35,7 +35,7 @@ public class TestSimpleTableSoftDelete {
private static Long idOfTheObject = null; private static Long idOfTheObject = null;
private static Timestamp startAction = null; private static Timestamp startAction = null;
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -52,7 +52,7 @@ public class TestSimpleTableSoftDelete {
} }
public TestSimpleTableSoftDelete() { public TestSimpleTableSoftDelete() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@ -60,7 +60,7 @@ public class TestSimpleTableSoftDelete {
public void testTableInsertAndRetrieve() throws Exception { public void testTableInsertAndRetrieve() throws Exception {
TestSimpleTableSoftDelete.startAction = Timestamp.from(Instant.now()); TestSimpleTableSoftDelete.startAction = Timestamp.from(Instant.now());
final List<String> sqlCommand = DataFactory.createTable(SimpleTableSoftDelete.class); final List<String> sqlCommand = DataFactory.createTable(SimpleTableSoftDelete.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -27,7 +27,7 @@ import test.kar.archidata.dataAccess.model.TypesEnum1;
public class TestTypeEnum1 { public class TestTypeEnum1 {
final static private Logger LOGGER = LoggerFactory.getLogger(TestTypeEnum1.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestTypeEnum1.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -40,14 +40,14 @@ public class TestTypeEnum1 {
} }
public TestTypeEnum1() { public TestTypeEnum1() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@Test @Test
public void testCreateTable() throws Exception { public void testCreateTable() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(TypesEnum1.class); final List<String> sqlCommand = DataFactory.createTable(TypesEnum1.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -11,8 +11,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -27,7 +27,7 @@ import test.kar.archidata.dataAccess.model.TypesEnum2;
public class TestTypeEnum2 { public class TestTypeEnum2 {
final static private Logger LOGGER = LoggerFactory.getLogger(TestTypeEnum2.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestTypeEnum2.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -40,14 +40,14 @@ public class TestTypeEnum2 {
} }
public TestTypeEnum2() { public TestTypeEnum2() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@Test @Test
public void testCreateTable() throws Exception { public void testCreateTable() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(TypesEnum2.class); final List<String> sqlCommand = DataFactory.createTable(TypesEnum2.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -16,8 +16,8 @@ import org.junit.jupiter.api.Order;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.dataAccess.DBAccessSQL; import org.kar.archidata.dataAccess.DataAccessSQL;
import org.kar.archidata.dataAccess.DataFactory; import org.kar.archidata.dataAccess.DataFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -31,7 +31,7 @@ import test.kar.archidata.dataAccess.model.TypesTable;
public class TestTypes { public class TestTypes {
final static private Logger LOGGER = LoggerFactory.getLogger(TestTypes.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestTypes.class);
private DBAccess da = null; private DataAccess da = null;
@BeforeAll @BeforeAll
public static void configureWebServer() throws Exception { public static void configureWebServer() throws Exception {
@ -44,14 +44,14 @@ public class TestTypes {
} }
public TestTypes() { public TestTypes() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@Order(1) @Order(1)
@Test @Test
public void testCreateTable() throws Exception { public void testCreateTable() throws Exception {
final List<String> sqlCommand = DataFactory.createTable(TypesTable.class); final List<String> sqlCommand = DataFactory.createTable(TypesTable.class);
if (this.da instanceof final DBAccessSQL daSQL) { if (this.da instanceof final DataAccessSQL daSQL) {
for (final String elem : sqlCommand) { for (final String elem : sqlCommand) {
LOGGER.debug("request: '{}'", elem); LOGGER.debug("request: '{}'", elem);
daSQL.executeSimpleQuery(elem); daSQL.executeSimpleQuery(elem);

View File

@ -2,7 +2,7 @@ package test.kar.archidata.migration;
import java.io.IOException; import java.io.IOException;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.migration.MigrationSqlStep; import org.kar.archidata.migration.MigrationSqlStep;
class MigrationFail extends MigrationSqlStep { class MigrationFail extends MigrationSqlStep {
@ -19,7 +19,7 @@ class MigrationFail extends MigrationSqlStep {
@Override @Override
public void generateStep() throws Exception { public void generateStep() throws Exception {
addAction((final DBAccess da) -> { addAction((final DataAccess da) -> {
throw new IOException("FAIL migration"); throw new IOException("FAIL migration");
}); });
display(); display();

View File

@ -11,7 +11,7 @@ import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.GlobalConfiguration; import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.migration.MigrationEngine; import org.kar.archidata.migration.MigrationEngine;
import org.kar.archidata.migration.MigrationException; import org.kar.archidata.migration.MigrationException;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -26,10 +26,10 @@ import test.kar.archidata.migration.model.TypesMigrationInitialisationFirst;
public class TestMigrationFail { public class TestMigrationFail {
final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFirstInit.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFirstInit.class);
private DBAccess da = null; private DataAccess da = null;
public TestMigrationFail() { public TestMigrationFail() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@BeforeAll @BeforeAll

View File

@ -11,7 +11,7 @@ import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.GlobalConfiguration; import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.migration.MigrationEngine; import org.kar.archidata.migration.MigrationEngine;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -26,10 +26,10 @@ import test.kar.archidata.migration.model.TypesMigrationInitialisationFirst;
public class TestMigrationFirstInit { public class TestMigrationFirstInit {
final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFail.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFail.class);
private DBAccess da = null; private DataAccess da = null;
public TestMigrationFirstInit() { public TestMigrationFirstInit() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@BeforeAll @BeforeAll

View File

@ -12,7 +12,7 @@ import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestMethodOrder; import org.junit.jupiter.api.TestMethodOrder;
import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.api.extension.ExtendWith;
import org.kar.archidata.GlobalConfiguration; import org.kar.archidata.GlobalConfiguration;
import org.kar.archidata.dataAccess.DBAccess; import org.kar.archidata.dataAccess.DataAccess;
import org.kar.archidata.migration.MigrationEngine; import org.kar.archidata.migration.MigrationEngine;
import org.kar.archidata.migration.model.Migration; import org.kar.archidata.migration.model.Migration;
import org.slf4j.Logger; import org.slf4j.Logger;
@ -27,10 +27,10 @@ import test.kar.archidata.migration.model.TypesMigrationInitialisationCurrent;
public class TestMigrationFirstInitWithMigration { public class TestMigrationFirstInitWithMigration {
final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFirstInitWithMigration.class); final static private Logger LOGGER = LoggerFactory.getLogger(TestMigrationFirstInitWithMigration.class);
private DBAccess da = null; private DataAccess da = null;
public TestMigrationFirstInitWithMigration() { public TestMigrationFirstInitWithMigration() {
this.da = DBAccess.createInterface(); this.da = DataAccess.createInterface();
} }
@BeforeAll @BeforeAll