[FEAT] update ObjectId for data

This commit is contained in:
Edouard DUPIN 2025-01-05 21:41:19 +01:00
parent ea8e2cc452
commit d3a7db4f21
8 changed files with 80 additions and 105 deletions

View File

@ -21,6 +21,7 @@ import java.util.UUID;
import javax.imageio.ImageIO; import javax.imageio.ImageIO;
import org.bson.types.ObjectId;
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;
@ -86,24 +87,25 @@ public class DataResource {
return filePath; return filePath;
} }
public static String getFileDataOld(final long tmpFolderId) { public static String getFileDataOld(final UUID uuid) {
final String filePath = ConfigBaseVariable.getMediaDataFolder() + File.separator + tmpFolderId + File.separator final String stringUUID = uuid.toString();
final String filePath = ConfigBaseVariable.getMediaDataFolder() + File.separator + stringUUID + File.separator
+ "data"; + "data";
try { try {
createFolder(ConfigBaseVariable.getMediaDataFolder() + File.separator + tmpFolderId + File.separator); createFolder(ConfigBaseVariable.getMediaDataFolder() + File.separator + stringUUID + File.separator);
} catch (final IOException e) { } catch (final IOException e) {
e.printStackTrace(); e.printStackTrace();
} }
return filePath; return filePath;
} }
public static String getFileData(final UUID uuid) { public static String getFileData(final ObjectId oid) {
final String stringUUID = uuid.toString(); final String stringOid = oid.toHexString();
final String part1 = stringUUID.substring(0, 2); final String part1 = stringOid.substring(0, 2);
final String part2 = stringUUID.substring(2, 4); final String part2 = stringOid.substring(2, 4);
final String part3 = stringUUID.substring(4); final String part3 = stringOid.substring(4);
final String finalPath = part1 + File.separator + part2; final String finalPath = part1 + File.separator + part2;
String filePath = ConfigBaseVariable.getMediaDataFolder() + "_uuid" + File.separator + finalPath String filePath = ConfigBaseVariable.getMediaDataFolder() + "_oid" + File.separator + finalPath
+ File.separator; + File.separator;
try { try {
createFolder(filePath); createFolder(filePath);
@ -114,8 +116,8 @@ public class DataResource {
return filePath; return filePath;
} }
public static String getFileMetaData(final UUID uuid) { public static String getFileMetaData(final ObjectId oid) {
return getFileData(uuid) + ".json"; return getFileData(oid) + ".json";
} }
public Data getWithSha512(final String sha512) { public Data getWithSha512(final String sha512) {
@ -166,7 +168,7 @@ public class DataResource {
e.printStackTrace(); e.printStackTrace();
return null; return null;
} }
final String mediaPath = getFileData(injectedData.uuid); final String mediaPath = getFileData(injectedData.oid);
LOGGER.info("src = {}", tmpPath); LOGGER.info("src = {}", tmpPath);
LOGGER.info("dst = {}", mediaPath); LOGGER.info("dst = {}", mediaPath);
Files.move(Paths.get(tmpPath), Paths.get(mediaPath), StandardCopyOption.ATOMIC_MOVE); Files.move(Paths.get(tmpPath), Paths.get(mediaPath), StandardCopyOption.ATOMIC_MOVE);
@ -174,9 +176,9 @@ public class DataResource {
return injectedData; return injectedData;
} }
public static void modeFileOldModelToNewModel(final long id, final UUID uuid) throws IOException { public static void modeFileOldModelToNewModel(final UUID uuid, final ObjectId oid) throws IOException {
String mediaCurentPath = getFileDataOld(id); String mediaCurentPath = getFileDataOld(uuid);
String mediaDestPath = getFileData(uuid); String mediaDestPath = getFileData(oid);
LOGGER.info("src = {}", mediaCurentPath); LOGGER.info("src = {}", mediaCurentPath);
LOGGER.info("dst = {}", mediaDestPath); LOGGER.info("dst = {}", mediaDestPath);
if (Files.exists(Paths.get(mediaCurentPath))) { if (Files.exists(Paths.get(mediaCurentPath))) {
@ -252,9 +254,9 @@ public class DataResource {
return sb.toString(); return sb.toString();
} }
public Data getSmall(final UUID id) { public Data getSmall(final ObjectId oid) {
try { try {
return DataAccess.get(Data.class, id); return DataAccess.get(Data.class, oid);
} catch (final Exception e) { } catch (final Exception e) {
// TODO Auto-generated catch block // TODO Auto-generated catch block
e.printStackTrace(); e.printStackTrace();
@ -288,7 +290,7 @@ public class DataResource {
} }
@GET @GET
@Path("{uuid}") @Path("{oid}")
@PermitTokenInURI @PermitTokenInURI
@RolesAllowed("USER") @RolesAllowed("USER")
@Produces(MediaType.APPLICATION_OCTET_STREAM) @Produces(MediaType.APPLICATION_OCTET_STREAM)
@ -297,17 +299,17 @@ public class DataResource {
@Context final SecurityContext sc, @Context final SecurityContext sc,
@QueryParam(HttpHeaders.AUTHORIZATION) final String token, @QueryParam(HttpHeaders.AUTHORIZATION) final String token,
@HeaderParam("Range") final String range, @HeaderParam("Range") final String range,
@PathParam("uuid") final UUID uuid) throws FailException { @PathParam("oid") final ObjectId oid) throws FailException {
final GenericContext gc = (GenericContext) sc.getUserPrincipal(); final GenericContext gc = (GenericContext) sc.getUserPrincipal();
// logger.info("==================================================="); // logger.info("===================================================");
LOGGER.info("== DATA retrieveDataId ? id={} user={}", uuid, (gc == null ? "null" : gc.userByToken)); LOGGER.info("== DATA retrieveDataId ? oid={} user={}", oid, (gc == null ? "null" : gc.userByToken));
// logger.info("==================================================="); // logger.info("===================================================");
final Data value = getSmall(uuid); final Data value = getSmall(oid);
if (value == null) { if (value == null) {
return Response.status(404).entity("media NOT FOUND: " + uuid).type("text/plain").build(); return Response.status(404).entity("media NOT FOUND: " + oid).type("text/plain").build();
} }
try { try {
return buildStream(getFileData(uuid), range, return buildStream(getFileData(oid), range,
value.mimeType == null ? "application/octet-stream" : value.mimeType); value.mimeType == null ? "application/octet-stream" : value.mimeType);
} catch (final Exception ex) { } catch (final Exception ex) {
throw new FailException(Response.Status.INTERNAL_SERVER_ERROR, "Fail to build output stream", ex); throw new FailException(Response.Status.INTERNAL_SERVER_ERROR, "Fail to build output stream", ex);
@ -315,7 +317,7 @@ public class DataResource {
} }
@GET @GET
@Path("thumbnail/{uuid}") @Path("thumbnail/{oid}")
@RolesAllowed("USER") @RolesAllowed("USER")
@PermitTokenInURI @PermitTokenInURI
@Produces(MediaType.APPLICATION_OCTET_STREAM) @Produces(MediaType.APPLICATION_OCTET_STREAM)
@ -325,19 +327,19 @@ public class DataResource {
@Context final SecurityContext sc, @Context final SecurityContext sc,
@QueryParam(HttpHeaders.AUTHORIZATION) final String token, @QueryParam(HttpHeaders.AUTHORIZATION) final String token,
@HeaderParam("Range") final String range, @HeaderParam("Range") final String range,
@PathParam("uuid") final UUID uuid) throws FailException { @PathParam("oid") final ObjectId oid) throws FailException {
final GenericContext gc = (GenericContext) sc.getUserPrincipal(); final GenericContext gc = (GenericContext) sc.getUserPrincipal();
LOGGER.info("==================================================="); LOGGER.info("===================================================");
LOGGER.info("== DATA retrieveDataThumbnailId ? {}", (gc == null ? "null" : gc.userByToken)); LOGGER.info("== DATA retrieveDataThumbnailId ? {}", (gc == null ? "null" : gc.userByToken));
LOGGER.info("==================================================="); LOGGER.info("===================================================");
final Data value = getSmall(uuid); final Data value = getSmall(oid);
if (value == null) { if (value == null) {
return Response.status(404).entity("media NOT FOUND: " + uuid).type("text/plain").build(); return Response.status(404).entity("media NOT FOUND: " + oid).type("text/plain").build();
} }
final String filePathName = getFileData(uuid); final String filePathName = getFileData(oid);
final File inputFile = new File(filePathName); final File inputFile = new File(filePathName);
if (!inputFile.exists()) { if (!inputFile.exists()) {
return Response.status(404).entity("{\"error\":\"media Does not exist: " + uuid + "\"}") return Response.status(404).entity("{\"error\":\"media Does not exist: " + oid + "\"}")
.type("application/json").build(); .type("application/json").build();
} }
if (value.mimeType.contentEquals("image/jpeg") || value.mimeType.contentEquals("image/png") if (value.mimeType.contentEquals("image/jpeg") || value.mimeType.contentEquals("image/png")
@ -402,7 +404,7 @@ public class DataResource {
} }
@GET @GET
@Path("{uuid}/{name}") @Path("{oid}/{name}")
@PermitTokenInURI @PermitTokenInURI
@RolesAllowed("USER") @RolesAllowed("USER")
@Produces(MediaType.APPLICATION_OCTET_STREAM) @Produces(MediaType.APPLICATION_OCTET_STREAM)
@ -411,17 +413,17 @@ public class DataResource {
@Context final SecurityContext sc, @Context final SecurityContext sc,
@QueryParam(HttpHeaders.AUTHORIZATION) final String token, @QueryParam(HttpHeaders.AUTHORIZATION) final String token,
@HeaderParam("Range") final String range, @HeaderParam("Range") final String range,
@PathParam("uuid") final UUID uuid, @PathParam("oid") final ObjectId oid,
@PathParam("name") final String name) throws Exception { @PathParam("name") final String name) throws Exception {
final GenericContext gc = (GenericContext) sc.getUserPrincipal(); final GenericContext gc = (GenericContext) sc.getUserPrincipal();
// logger.info("==================================================="); // logger.info("===================================================");
LOGGER.info("== DATA retrieveDataFull ? id={} user={}", uuid, (gc == null ? "null" : gc.userByToken)); LOGGER.info("== DATA retrieveDataFull ? id={} user={}", oid, (gc == null ? "null" : gc.userByToken));
// logger.info("==================================================="); // logger.info("===================================================");
final Data value = getSmall(uuid); final Data value = getSmall(oid);
if (value == null) { if (value == null) {
return Response.status(404).entity("media NOT FOUND: " + uuid).type("text/plain").build(); return Response.status(404).entity("media NOT FOUND: " + oid).type("text/plain").build();
} }
return buildStream(getFileData(uuid), range, return buildStream(getFileData(oid), range,
value.mimeType == null ? "application/octet-stream" : value.mimeType); value.mimeType == null ? "application/octet-stream" : value.mimeType);
} }

View File

@ -207,39 +207,6 @@ public class DBAccessSQL extends DBAccess {
return out; 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 List<ObjectId> getListOfOIDs(final ResultSet rs, final int iii, final String separator) throws SQLException {
final String trackString = rs.getString(iii);
if (rs.wasNull()) {
return null;
}
final List<ObjectId> out = new ArrayList<>();
final String[] elements = trackString.split(separator);
for (final String elem : elements) {
final ObjectId tmp = new ObjectId(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
@ -309,8 +276,8 @@ public class DBAccessSQL extends DBAccess {
if (tmp == null) { if (tmp == null) {
ps.setNull(iii.value, Types.BINARY); ps.setNull(iii.value, Types.BINARY);
} else { } else {
final String dataString = ((ObjectId) tmp).toHexString(); final byte[] dataByte = ((ObjectId) tmp).toByteArray();
ps.setString(iii.value, dataString); ps.setBytes(iii.value, dataByte);
} }
} else if (type == UUID.class) { } else if (type == UUID.class) {
final Object tmp = field.get(data); final Object tmp = field.get(data);
@ -432,7 +399,7 @@ public class DBAccessSQL extends DBAccess {
final ResultSet rs, final ResultSet rs,
final CountInOut countNotNull) throws Exception { final CountInOut countNotNull) throws Exception {
if (type == ObjectId.class) { if (type == ObjectId.class) {
final String tmp = rs.getString(count.value); final byte[] tmp = rs.getBytes(count.value);
if (rs.wasNull()) { if (rs.wasNull()) {
field.set(data, null); field.set(data, null);
} else { } else {
@ -623,7 +590,7 @@ public class DBAccessSQL extends DBAccess {
final Class<?> type = field.getType(); final Class<?> type = field.getType();
if (type == ObjectId.class) { if (type == ObjectId.class) {
return (final ResultSet rs, final Object obj) -> { return (final ResultSet rs, final Object obj) -> {
final String tmp = rs.getString(count); final byte[] tmp = rs.getBytes(count);
if (rs.wasNull()) { if (rs.wasNull()) {
field.set(obj, null); field.set(obj, null);
} else { } else {
@ -1055,12 +1022,12 @@ public class DBAccessSQL extends DBAccess {
if (primaryKeyField.getType() == UUID.class) { if (primaryKeyField.getType() == UUID.class) {
// uniqueSQLUUID = generatedKeys.getObject(1, UUID.class); // uniqueSQLUUID = generatedKeys.getObject(1, UUID.class);
/* final Object obj = generatedKeys.getObject(1); final BigInteger bigint = (BigInteger) generatedKeys.getObject(1); uniqueSQLUUID = UuidUtils.asUuid(bigint); final UUID /* final Object obj = generatedKeys.getObject(1); final BigInteger bigint = (BigInteger) generatedKeys.getObject(1); uniqueSQLUUID = UuidUtils.asUuid(bigint); final UUID
* generatedUUID = (UUID) generatedKeys.getObject(1); System.out.println("UUID généré: " + generatedUUID); */ * generatedUUID = (UUID) generatedKeys.getObject(1); LOGGER.trace("UUID généré: " + generatedUUID); */
//final Object obj = generatedKeys.getObject(1); //final Object obj = generatedKeys.getObject(1);
final byte[] tmpid = generatedKeys.getBytes(1); final byte[] tmpid = generatedKeys.getBytes(1);
uniqueSQLUUID = UuidUtils.asUuid(tmpid); uniqueSQLUUID = UuidUtils.asUuid(tmpid);
} else if (primaryKeyField.getType() == ObjectId.class) { } else if (primaryKeyField.getType() == ObjectId.class) {
final String tmpid = generatedKeys.getString(1); final byte[] tmpid = generatedKeys.getBytes(1);
uniqueSQLOID = new ObjectId(tmpid); uniqueSQLOID = new ObjectId(tmpid);
} else { } else {
uniqueSQLID = generatedKeys.getLong(1); uniqueSQLID = generatedKeys.getLong(1);
@ -1245,12 +1212,13 @@ public class DBAccessSQL extends DBAccess {
return; return;
} }
if (value instanceof final UUID tmp) { if (value instanceof final UUID tmp) {
LOGGER.debug("Inject uuid => {}", tmp);
final byte[] dataByte = UuidUtils.asBytes(tmp); final byte[] dataByte = UuidUtils.asBytes(tmp);
ps.setBytes(iii.value, dataByte); ps.setBytes(iii.value, dataByte);
} else if (value instanceof final ObjectId tmp) { } else if (value instanceof final ObjectId tmp) {
final String dataString = tmp.toHexString(); final byte[] dataByte = tmp.toByteArray();
LOGGER.debug("Inject oid => {}", dataString); LOGGER.debug("Inject oid => {}", tmp.toHexString());
ps.setString(iii.value, dataString); ps.setBytes(iii.value, dataByte);
} else if (value instanceof final Long tmp) { } else if (value instanceof final Long tmp) {
LOGGER.debug("Inject Long => {}", tmp); LOGGER.debug("Inject Long => {}", tmp);
ps.setLong(iii.value, tmp); ps.setLong(iii.value, tmp);

View File

@ -37,8 +37,7 @@ public class DataFactory {
return "binary(16)"; return "binary(16)";
} }
if (type == ObjectId.class) { if (type == ObjectId.class) {
return "varchar(24)"; return "binary(12)";
// return "binary(12)";
} }
if (type == Long.class || type == long.class) { if (type == Long.class || type == long.class) {
return "bigint"; return "bigint";
@ -95,8 +94,7 @@ public class DataFactory {
return "BINARY(16)"; return "BINARY(16)";
} }
if (type == ObjectId.class) { if (type == ObjectId.class) {
return "text"; return "BINARY(12)";
//return "BINARY(12)";
} }
if (type == Long.class || type == long.class) { if (type == Long.class || type == long.class) {
return "INTEGER"; return "INTEGER";

View File

@ -17,6 +17,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.UUID; import java.util.UUID;
import org.bson.types.ObjectId;
import org.glassfish.jersey.media.multipart.ContentDisposition; import org.glassfish.jersey.media.multipart.ContentDisposition;
import org.glassfish.jersey.media.multipart.FormDataContentDisposition; import org.glassfish.jersey.media.multipart.FormDataContentDisposition;
import org.kar.archidata.catcher.RestErrorResponse; import org.kar.archidata.catcher.RestErrorResponse;
@ -157,6 +158,12 @@ public class TsGenerateApi {
tsModels.add(new TsClassElement(models, "ZodUUID", "UUID", "isUUID", "zod.string().uuid()", tsModels.add(new TsClassElement(models, "ZodUUID", "UUID", "isUUID", "zod.string().uuid()",
DefinedPosition.BASIC)); DefinedPosition.BASIC));
} }
models = api.getCompatibleModels(List.of(ObjectId.class));
if (models != null) {
tsModels.add(new TsClassElement(models, "ZodObjectId", "ObjectId", "isObjectId",
"zod.string().length(24, \"Invalid ObjectId length\").regex(/^[a-fA-F0-9]{24}$/, \"Invalid ObjectId format\")",
DefinedPosition.BASIC));
}
models = api.getCompatibleModels(List.of(Long.class, long.class)); models = api.getCompatibleModels(List.of(Long.class, long.class));
if (models != null) { if (models != null) {
tsModels.add( tsModels.add(

View File

@ -11,7 +11,7 @@ import jakarta.persistence.Table;
@Table(name = "data") @Table(name = "data")
@DataIfNotExists @DataIfNotExists
@JsonInclude(JsonInclude.Include.NON_NULL) @JsonInclude(JsonInclude.Include.NON_NULL)
public class Data extends UUIDGenericDataSoftDelete { public class Data extends OIDGenericDataSoftDelete {
@Column(length = 128, nullable = false) @Column(length = 128, nullable = false)
@Schema(description = "Sha512 of the data") @Schema(description = "Sha512 of the data")
public String sha512; public String sha512;

View File

@ -9,9 +9,9 @@ import jakarta.validation.constraints.NotNull;
public class OIDGenericData extends GenericTiming { public class OIDGenericData extends GenericTiming {
@Id @Id
//@jakarta.persistence.Id @jakarta.persistence.Id
@Column(nullable = false, unique = true) @Column(nullable = false, unique = true, name = "_id")
@Schema(description = "Unique ObjectID of the object", required = false, readOnly = true, example = "65161616841351") @Schema(description = "Unique ObjectID of the object", required = false, readOnly = true, example = "65161616841351")
@NotNull @NotNull
public ObjectId _id = null; public ObjectId oid = null;
} }

View File

@ -13,9 +13,9 @@ import java.security.NoSuchAlgorithmException;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.UUID;
import org.apache.tika.Tika; import org.apache.tika.Tika;
import org.bson.types.ObjectId;
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.DBAccess;
@ -121,7 +121,7 @@ public class DataTools {
return null; return null;
} }
final String mediaPath = DataResource.getFileData(out.uuid); final String mediaPath = DataResource.getFileData(out.oid);
LOGGER.info("src = {}", tmpPath); LOGGER.info("src = {}", tmpPath);
LOGGER.info("dst = {}", mediaPath); LOGGER.info("dst = {}", mediaPath);
Files.move(Paths.get(tmpPath), Paths.get(mediaPath), StandardCopyOption.ATOMIC_MOVE); Files.move(Paths.get(tmpPath), Paths.get(mediaPath), StandardCopyOption.ATOMIC_MOVE);
@ -151,9 +151,9 @@ 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 DBAccess ioDb, final ObjectId oid) {
try { try {
ioDb.unsetDelete(Data.class, id); ioDb.unsetDelete(Data.class, oid);
} catch (final Exception e) { } catch (final Exception e) {
// TODO Auto-generated catch block // TODO Auto-generated catch block
e.printStackTrace(); e.printStackTrace();
@ -338,14 +338,14 @@ public class DataTools {
} }
} else if (data.deleted) { } else if (data.deleted) {
LOGGER.error("Data already exist but deleted"); LOGGER.error("Data already exist but deleted");
undelete(ioDb, data.uuid); undelete(ioDb, data.oid);
data.deleted = false; data.deleted = false;
} else { } else {
LOGGER.error("Data already exist ... all good"); LOGGER.error("Data already exist ... all good");
} }
// Fist step: retrieve all the Id of each parents:... // Fist step: retrieve all the Id of each parents:...
LOGGER.info("Find typeNode"); LOGGER.info("Find typeNode");
AddOnDataJson.addLink(ioDb, clazz, null, id, null, data.uuid); AddOnDataJson.addLink(ioDb, clazz, null, id, null, data.oid);
} }
public static <CLASS_TYPE, ID_TYPE> void uploadCover( public static <CLASS_TYPE, ID_TYPE> void uploadCover(
@ -384,13 +384,13 @@ public class DataTools {
} }
} else if (data.deleted) { } else if (data.deleted) {
LOGGER.error("Data already exist but deleted"); LOGGER.error("Data already exist but deleted");
undelete(ioDb, data.uuid); undelete(ioDb, data.oid);
data.deleted = false; data.deleted = false;
} else { } else {
LOGGER.error("Data already exist ... all good"); LOGGER.error("Data already exist ... all good");
} }
// Fist step: retrieve all the Id of each parents:... // Fist step: retrieve all the Id of each parents:...
LOGGER.info("Find typeNode"); LOGGER.info("Find typeNode");
AddOnDataJson.addLink(ioDb, clazz, null, id, null, data.uuid); AddOnDataJson.addLink(ioDb, clazz, null, id, null, data.oid);
} }
} }

View File

@ -166,7 +166,7 @@ public class TestListJson {
final SerializeListAsJsonObjectId insertedData = ConfigureDb.da.insert(test); final SerializeListAsJsonObjectId insertedData = ConfigureDb.da.insert(test);
Assertions.assertNotNull(insertedData); Assertions.assertNotNull(insertedData);
Assertions.assertNotNull(insertedData._id); Assertions.assertNotNull(insertedData.oid);
Assertions.assertNotNull(insertedData.data); Assertions.assertNotNull(insertedData.data);
Assertions.assertEquals(5, insertedData.data.size()); Assertions.assertEquals(5, insertedData.data.size());
Assertions.assertEquals(test.data.get(0), insertedData.data.get(0)); Assertions.assertEquals(test.data.get(0), insertedData.data.get(0));
@ -177,10 +177,10 @@ public class TestListJson {
// Try to retrieve all the data: // Try to retrieve all the data:
final SerializeListAsJsonObjectId retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class, final SerializeListAsJsonObjectId retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class,
insertedData._id); insertedData.oid);
Assertions.assertNotNull(retrieve); Assertions.assertNotNull(retrieve);
Assertions.assertNotNull(retrieve._id); Assertions.assertNotNull(retrieve.oid);
Assertions.assertNotNull(retrieve.data); Assertions.assertNotNull(retrieve.data);
Assertions.assertEquals(5, retrieve.data.size()); Assertions.assertEquals(5, retrieve.data.size());
Assertions.assertEquals(test.data.get(0), retrieve.data.get(0)); Assertions.assertEquals(test.data.get(0), retrieve.data.get(0));
@ -199,38 +199,38 @@ public class TestListJson {
final SerializeListAsJsonObjectId insertedData = ConfigureDb.da.insert(test); final SerializeListAsJsonObjectId insertedData = ConfigureDb.da.insert(test);
Assertions.assertNotNull(insertedData); Assertions.assertNotNull(insertedData);
Assertions.assertNotNull(insertedData._id); Assertions.assertNotNull(insertedData.oid);
Assertions.assertNotNull(insertedData.data); Assertions.assertNotNull(insertedData.data);
Assertions.assertEquals(0, insertedData.data.size()); Assertions.assertEquals(0, insertedData.data.size());
final ObjectId firstDataInserted1 = new ObjectId(); final ObjectId firstDataInserted1 = new ObjectId();
final ObjectId firstDataInserted2 = new ObjectId(); final ObjectId firstDataInserted2 = new ObjectId();
final ObjectId firstDataInserted3 = new ObjectId(); final ObjectId firstDataInserted3 = new ObjectId();
AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData._id, "data", AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData.oid, "data",
firstDataInserted1); firstDataInserted1);
AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData._id, "data", AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData.oid, "data",
firstDataInserted2); firstDataInserted2);
AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData._id, "data", AddOnDataJson.addLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData.oid, "data",
firstDataInserted3); firstDataInserted3);
// Try to retrieve all the data: // Try to retrieve all the data:
SerializeListAsJsonObjectId retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class, insertedData._id); SerializeListAsJsonObjectId retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class, insertedData.oid);
Assertions.assertNotNull(retrieve); Assertions.assertNotNull(retrieve);
Assertions.assertNotNull(retrieve._id); Assertions.assertNotNull(retrieve.oid);
Assertions.assertNotNull(retrieve.data); Assertions.assertNotNull(retrieve.data);
Assertions.assertEquals(3, retrieve.data.size()); Assertions.assertEquals(3, retrieve.data.size());
Assertions.assertEquals(firstDataInserted1, retrieve.data.get(0)); Assertions.assertEquals(firstDataInserted1, retrieve.data.get(0));
Assertions.assertEquals(firstDataInserted2, retrieve.data.get(1)); Assertions.assertEquals(firstDataInserted2, retrieve.data.get(1));
Assertions.assertEquals(firstDataInserted3, retrieve.data.get(2)); Assertions.assertEquals(firstDataInserted3, retrieve.data.get(2));
AddOnDataJson.removeLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData._id, "data", AddOnDataJson.removeLink(ConfigureDb.da, SerializeListAsJsonObjectId.class, "_id", insertedData.oid, "data",
firstDataInserted2); firstDataInserted2);
// Try to retrieve all the data: // Try to retrieve all the data:
retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class, insertedData._id); retrieve = ConfigureDb.da.get(SerializeListAsJsonObjectId.class, insertedData.oid);
Assertions.assertNotNull(retrieve); Assertions.assertNotNull(retrieve);
Assertions.assertNotNull(retrieve._id); Assertions.assertNotNull(retrieve.oid);
Assertions.assertNotNull(retrieve.data); Assertions.assertNotNull(retrieve.data);
Assertions.assertEquals(2, retrieve.data.size()); Assertions.assertEquals(2, retrieve.data.size());
Assertions.assertEquals(firstDataInserted1, retrieve.data.get(0)); Assertions.assertEquals(firstDataInserted1, retrieve.data.get(0));