[DEV] continue integration to support new model of data with uuid
This commit is contained in:
parent
5e8b244ebd
commit
154c825499
@ -1,7 +1,11 @@
|
|||||||
|
|
||||||
package org.kar.karideo;
|
package org.kar.karideo;
|
||||||
|
|
||||||
|
import java.io.FileWriter;
|
||||||
|
|
||||||
|
import org.kar.archidata.dataAccess.DataFactoryZod;
|
||||||
import org.kar.archidata.tools.ConfigBaseVariable;
|
import org.kar.archidata.tools.ConfigBaseVariable;
|
||||||
|
import org.kar.karideo.migration.Initialization;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
@ -10,7 +14,12 @@ public class WebLauncherLocal extends WebLauncher {
|
|||||||
|
|
||||||
private WebLauncherLocal() {}
|
private WebLauncherLocal() {}
|
||||||
|
|
||||||
public static void main(final String[] args) throws InterruptedException {
|
public static void main(final String[] args) throws Exception {
|
||||||
|
final String model = DataFactoryZod.createTables(Initialization.CLASSES_BASE);
|
||||||
|
LOGGER.info("Zod Model = {}", model);
|
||||||
|
final FileWriter writer = new FileWriter("../front/src/app/model/server-karideo-api.ts");
|
||||||
|
writer.write(model);
|
||||||
|
writer.close();
|
||||||
final WebLauncherLocal launcher = new WebLauncherLocal();
|
final WebLauncherLocal launcher = new WebLauncherLocal();
|
||||||
launcher.process();
|
launcher.process();
|
||||||
LOGGER.info("end-configure the server & wait finish process:");
|
LOGGER.info("end-configure the server & wait finish process:");
|
||||||
|
@ -2,7 +2,6 @@ package org.kar.karideo.api;
|
|||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
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;
|
||||||
@ -99,7 +98,7 @@ public class SeasonResource {
|
|||||||
return Response.ok(DataAccess.get(Season.class, id)).build();
|
return Response.ok(DataAccess.get(Season.class, id)).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Season getOrCreate(final String name, final UUID seriesId) {
|
public static Season getOrCreate(final String name, final Long seriesId) {
|
||||||
try {
|
try {
|
||||||
Season out = DataAccess.getWhere(Season.class, new Condition(new QueryAnd(new QueryCondition("name", "=", name), new QueryCondition("parentId", "=", seriesId))));
|
Season out = DataAccess.getWhere(Season.class, new Condition(new QueryAnd(new QueryCondition("name", "=", name), new QueryCondition("parentId", "=", seriesId))));
|
||||||
if (out == null) {
|
if (out == null) {
|
||||||
|
@ -2,7 +2,6 @@ package org.kar.karideo.api;
|
|||||||
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
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;
|
||||||
@ -99,7 +98,7 @@ public class SeriesResource {
|
|||||||
return Response.ok(DataAccess.get(Series.class, id)).build();
|
return Response.ok(DataAccess.get(Series.class, id)).build();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Series getOrCreate(final String name, final UUID typeId) {
|
public static Series getOrCreate(final String name, final Long typeId) {
|
||||||
try {
|
try {
|
||||||
Series out = DataAccess.getWhere(Series.class, new Condition(new QueryAnd(new QueryCondition("name", "=", name), new QueryCondition("parentId", "=", typeId))));
|
Series out = DataAccess.getWhere(Series.class, new Condition(new QueryAnd(new QueryCondition("name", "=", name), new QueryCondition("parentId", "=", typeId))));
|
||||||
if (out == null) {
|
if (out == null) {
|
||||||
|
@ -131,7 +131,7 @@ public class VideoResource {
|
|||||||
System.out.println("Data already exist ... all good");
|
System.out.println("Data already exist ... all good");
|
||||||
System.out.flush();
|
System.out.flush();
|
||||||
}
|
}
|
||||||
// Fist step: retive all the Id of each parents:...
|
// Fist step: retieve all the Id of each parents:...
|
||||||
System.out.println("Find typeNode");
|
System.out.println("Find typeNode");
|
||||||
// check if id of type exist:
|
// check if id of type exist:
|
||||||
final Type typeNode = TypeResource.getId(Long.parseLong(typeId));
|
final Type typeNode = TypeResource.getId(Long.parseLong(typeId));
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
package org.kar.karideo.migration;
|
package org.kar.karideo.migration;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.kar.archidata.migration.MigrationSqlStep;
|
import org.kar.archidata.migration.MigrationSqlStep;
|
||||||
import org.kar.archidata.model.Data;
|
import org.kar.archidata.model.Data;
|
||||||
import org.kar.archidata.model.User;
|
import org.kar.archidata.model.User;
|
||||||
@ -13,6 +15,7 @@ public class Initialization extends MigrationSqlStep {
|
|||||||
|
|
||||||
public static final int KARSO_INITIALISATION_ID = 1;
|
public static final int KARSO_INITIALISATION_ID = 1;
|
||||||
|
|
||||||
|
public static final List<Class<?>> CLASSES_BASE = List.of(Data.class, Media.class, Type.class, Series.class, Season.class, User.class, UserMediaAdvancement.class);
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return "Initialization";
|
return "Initialization";
|
||||||
|
@ -1,15 +1,18 @@
|
|||||||
package org.kar.karideo.migration;
|
package org.kar.karideo.migration;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
|
import org.kar.archidata.api.DataResource;
|
||||||
import org.kar.archidata.dataAccess.DataAccess;
|
import org.kar.archidata.dataAccess.DataAccess;
|
||||||
import org.kar.archidata.dataAccess.options.AccessDeletedItems;
|
import org.kar.archidata.dataAccess.options.AccessDeletedItems;
|
||||||
import org.kar.archidata.dataAccess.options.OverrideTableName;
|
import org.kar.archidata.dataAccess.options.OverrideTableName;
|
||||||
import org.kar.archidata.migration.MigrationSqlStep;
|
import org.kar.archidata.migration.MigrationSqlStep;
|
||||||
import org.kar.karideo.migration.model.UUIDConversion;
|
import org.kar.karideo.migration.model.UUIDConversion;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class Migration20240226 extends MigrationSqlStep {
|
public class Migration20240226 extends MigrationSqlStep {
|
||||||
|
private static final Logger LOGGER = LoggerFactory.getLogger(Migration20240226.class);
|
||||||
|
|
||||||
public static final int KARSO_INITIALISATION_ID = 1;
|
public static final int KARSO_INITIALISATION_ID = 1;
|
||||||
|
|
||||||
@ -24,21 +27,85 @@ public class Migration20240226 extends MigrationSqlStep {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void generateStep() throws Exception {
|
public void generateStep() throws Exception {
|
||||||
|
/*
|
||||||
// update migration update (last one)
|
|
||||||
addAction("""
|
addAction("""
|
||||||
ALTER TABLE `media` ADD `uuid` binary(16) AFTER `id`;
|
ALTER TABLE `data` ADD `uuid` binary(16) AFTER `id`;
|
||||||
""");
|
""");
|
||||||
addAction(() -> {
|
addAction(() -> {
|
||||||
final List<UUIDConversion> medias = DataAccess.gets(UUIDConversion.class, new AccessDeletedItems(), new OverrideTableName("media"));
|
final List<UUIDConversion> datas = DataAccess.gets(UUIDConversion.class, new AccessDeletedItems(), new OverrideTableName("data"));
|
||||||
for (final UUIDConversion elem: medias) {
|
for (final UUIDConversion elem: datas) {
|
||||||
elem.uuid = UUID.randomUUID();
|
elem.uuid = UUID.randomUUID();
|
||||||
|
//elem.uuid = new UUID(elem.id * (long)Math.pow(2, 32), 0);
|
||||||
}
|
}
|
||||||
for (final UUIDConversion elem: medias) {
|
for (final UUIDConversion elem: datas) {
|
||||||
DataAccess.update(elem, elem.id, List.of("uuid"), new OverrideTableName("media"));
|
DataAccess.update(elem, elem.id, List.of("uuid"), new OverrideTableName("data"));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
addAction("""
|
||||||
|
ALTER TABLE `data` CHANGE `uuid` `uuid` binary(16) DEFAULT (UUID_TO_BIN(UUID(), TRUE));
|
||||||
|
""");
|
||||||
|
final List<String> tableToTransform = List.of("media", "season", "series", "type", "user");
|
||||||
|
for (final String tableName : tableToTransform ) {
|
||||||
|
addAction("ALTER TABLE `" + tableName + "` ADD `covers` text NULL;");
|
||||||
|
addAction(() -> {
|
||||||
|
final List<UUIDConversion> datas = DataAccess.gets(UUIDConversion.class, new AccessDeletedItems(), new OverrideTableName("data"));
|
||||||
|
final List<CoverConversion> medias = DataAccess.gets(CoverConversion.class, new AccessDeletedItems(), new OverrideTableName(tableName));
|
||||||
|
final List<LinkTable> links = DataAccess.gets(LinkTable.class, new OverrideTableName(tableName + "_link_cover"));
|
||||||
|
LOGGER.info("Get somes data: {} {} {}", datas.size(), medias.size(), links.size());
|
||||||
|
for (final CoverConversion media: medias) {
|
||||||
|
final List<UUID> values = new ArrayList<>();
|
||||||
|
for (final LinkTable link: links) {
|
||||||
|
if (link.object1Id.equals(media.id)) {
|
||||||
|
for (final UUIDConversion data: datas) {
|
||||||
|
if (data.id.equals(link.object2Id)) {
|
||||||
|
values.add(data.uuid);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (values.size() != 0) {
|
||||||
|
media.covers = values;
|
||||||
|
LOGGER.info(" update: {} => {}", media.id, media.covers);
|
||||||
|
DataAccess.update(media, media.id, List.of("covers"), new OverrideTableName(tableName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
addAction("DROP TABLE `" + tableName + "_link_cover`;");
|
||||||
|
}
|
||||||
|
addAction("""
|
||||||
|
ALTER TABLE `media` ADD `dataUUID` binary(16) AFTER dataId;
|
||||||
|
""");
|
||||||
|
addAction(() -> {
|
||||||
|
final List<UUIDConversion> datas = DataAccess.gets(UUIDConversion.class, new AccessDeletedItems(), new OverrideTableName("data"));
|
||||||
|
final List<MediaConversion> medias = DataAccess.gets(MediaConversion.class, new AccessDeletedItems(), new OverrideTableName("media"));
|
||||||
|
for (final MediaConversion media: medias) {
|
||||||
|
for (final UUIDConversion data: datas) {
|
||||||
|
if (data.id.equals(media.dataId)) {
|
||||||
|
media.dataUUID = data.uuid;
|
||||||
|
DataAccess.update(media, media.id, List.of("dataUUID"), new OverrideTableName("media"));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
addAction("""
|
||||||
|
ALTER TABLE `media` CHANGE `dataUUID` `dataUUID` binary(16) NOT NULL;
|
||||||
|
""");
|
||||||
|
addAction("""
|
||||||
|
ALTER TABLE `media` DROP `dataId`;
|
||||||
|
""");
|
||||||
|
*/
|
||||||
|
// Move the files...
|
||||||
|
addAction(() -> {
|
||||||
|
final List<UUIDConversion> datas = DataAccess.gets(UUIDConversion.class, new AccessDeletedItems(), new OverrideTableName("data"));
|
||||||
|
for (final UUIDConversion data: datas) {
|
||||||
|
|
||||||
|
final String origin = DataResource.getFileData(data.id);
|
||||||
|
final String destination = DataResource.getFileData(data.uuid);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,15 @@
|
|||||||
|
package org.kar.karideo.migration.model;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import org.kar.archidata.annotation.DataJson;
|
||||||
|
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
|
||||||
|
public class CoverConversion {
|
||||||
|
@Id
|
||||||
|
public Long id = null;
|
||||||
|
@DataJson
|
||||||
|
public List<UUID> covers = null;
|
||||||
|
}
|
@ -0,0 +1,12 @@
|
|||||||
|
package org.kar.karideo.migration.model;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
|
||||||
|
public class MediaConversion {
|
||||||
|
@Id
|
||||||
|
public Long id = null;
|
||||||
|
public Long dataId = null;
|
||||||
|
public UUID dataUUID = null;
|
||||||
|
}
|
@ -5,7 +5,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
import org.kar.archidata.annotation.DataJson;
|
import org.kar.archidata.annotation.DataJson;
|
||||||
import org.kar.archidata.model.Data;
|
import org.kar.archidata.model.Data;
|
||||||
import org.kar.archidata.model.UUIDGenericDataSoftDelete;
|
import org.kar.archidata.model.GenericDataSoftDelete;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ import jakarta.persistence.Table;
|
|||||||
@JsonInclude(JsonInclude.Include.NON_NULL)
|
@JsonInclude(JsonInclude.Include.NON_NULL)
|
||||||
//@SQLDelete(sql = "UPDATE table_product SET deleted = true WHERE id=?")
|
//@SQLDelete(sql = "UPDATE table_product SET deleted = true WHERE id=?")
|
||||||
//@Where(clause = "deleted=false")
|
//@Where(clause = "deleted=false")
|
||||||
public class Media extends UUIDGenericDataSoftDelete {
|
public class Media extends GenericDataSoftDelete {
|
||||||
// Name of the media (this represent the title)
|
// Name of the media (this represent the title)
|
||||||
@Column(nullable = false, length = 0)
|
@Column(nullable = false, length = 0)
|
||||||
public String name;
|
public String name;
|
||||||
@ -33,14 +33,14 @@ public class Media extends UUIDGenericDataSoftDelete {
|
|||||||
public UUID dataId;
|
public UUID dataId;
|
||||||
// Type of the media")
|
// Type of the media")
|
||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Type.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Type.class)
|
||||||
public UUID typeId;
|
public Long typeId;
|
||||||
// Series reference of the media
|
// Series reference of the media
|
||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Series.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Series.class)
|
||||||
public UUID seriesId;
|
public Long seriesId;
|
||||||
// Saison reference of the media
|
// Saison reference of the media
|
||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Season.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Season.class)
|
||||||
public UUID seasonId;
|
public Long seasonId;
|
||||||
// Episide Id
|
// Episode Id
|
||||||
public Integer episode;
|
public Integer episode;
|
||||||
// ")
|
// ")
|
||||||
public Integer date;
|
public Integer date;
|
||||||
|
@ -5,7 +5,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
import org.kar.archidata.annotation.DataIfNotExists;
|
import org.kar.archidata.annotation.DataIfNotExists;
|
||||||
import org.kar.archidata.annotation.DataJson;
|
import org.kar.archidata.annotation.DataJson;
|
||||||
import org.kar.archidata.model.UUIDGenericDataSoftDelete;
|
import org.kar.archidata.model.GenericDataSoftDelete;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ import jakarta.persistence.Table;
|
|||||||
@Table(name = "season")
|
@Table(name = "season")
|
||||||
@DataIfNotExists
|
@DataIfNotExists
|
||||||
@JsonInclude(JsonInclude.Include.NON_NULL)
|
@JsonInclude(JsonInclude.Include.NON_NULL)
|
||||||
public class Season extends UUIDGenericDataSoftDelete {
|
public class Season extends GenericDataSoftDelete {
|
||||||
@Column(nullable = false, length = 0)
|
@Column(nullable = false, length = 0)
|
||||||
@Schema(description = "Name of the media (this represent the title)")
|
@Schema(description = "Name of the media (this represent the title)")
|
||||||
public String name;
|
public String name;
|
||||||
@ -28,8 +28,8 @@ public class Season extends UUIDGenericDataSoftDelete {
|
|||||||
@Column(nullable = false)
|
@Column(nullable = false)
|
||||||
@Schema(description = "series parent ID")
|
@Schema(description = "series parent ID")
|
||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Series.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Series.class)
|
||||||
public UUID parentId;
|
public Long parentId;
|
||||||
@Schema(description = "List of Id of the sopecific covers")
|
@Schema(description = "List of Id of the specific covers")
|
||||||
@DataJson()
|
@DataJson()
|
||||||
public List<UUID> covers = null;
|
public List<UUID> covers = null;
|
||||||
}
|
}
|
@ -5,7 +5,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
import org.kar.archidata.annotation.DataIfNotExists;
|
import org.kar.archidata.annotation.DataIfNotExists;
|
||||||
import org.kar.archidata.annotation.DataJson;
|
import org.kar.archidata.annotation.DataJson;
|
||||||
import org.kar.archidata.model.UUIDGenericDataSoftDelete;
|
import org.kar.archidata.model.GenericDataSoftDelete;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ import jakarta.persistence.Table;
|
|||||||
@Table(name = "series")
|
@Table(name = "series")
|
||||||
@DataIfNotExists
|
@DataIfNotExists
|
||||||
@JsonInclude(JsonInclude.Include.NON_NULL)
|
@JsonInclude(JsonInclude.Include.NON_NULL)
|
||||||
public class Series extends UUIDGenericDataSoftDelete {
|
public class Series extends GenericDataSoftDelete {
|
||||||
@Column(nullable = false, length = 0)
|
@Column(nullable = false, length = 0)
|
||||||
@Schema(description = "Name of the media (this represent the title)")
|
@Schema(description = "Name of the media (this represent the title)")
|
||||||
public String name;
|
public String name;
|
||||||
@ -28,8 +28,8 @@ public class Series extends UUIDGenericDataSoftDelete {
|
|||||||
@Column(nullable = false)
|
@Column(nullable = false)
|
||||||
@Schema(description = "series parent ID")
|
@Schema(description = "series parent ID")
|
||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Type.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Type.class)
|
||||||
public UUID parentId;
|
public Long parentId;
|
||||||
@Schema(description = "List of Id of the sopecific covers")
|
@Schema(description = "List of Id of the specific covers")
|
||||||
@DataJson()
|
@DataJson()
|
||||||
public List<UUID> covers = null;
|
public List<UUID> covers = null;
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
import org.kar.archidata.annotation.DataIfNotExists;
|
import org.kar.archidata.annotation.DataIfNotExists;
|
||||||
import org.kar.archidata.annotation.DataJson;
|
import org.kar.archidata.annotation.DataJson;
|
||||||
import org.kar.archidata.model.UUIDGenericDataSoftDelete;
|
import org.kar.archidata.model.GenericDataSoftDelete;
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonInclude;
|
import com.fasterxml.jackson.annotation.JsonInclude;
|
||||||
|
|
||||||
@ -16,14 +16,14 @@ import jakarta.persistence.Table;
|
|||||||
@Table(name = "type")
|
@Table(name = "type")
|
||||||
@DataIfNotExists
|
@DataIfNotExists
|
||||||
@JsonInclude(JsonInclude.Include.NON_NULL)
|
@JsonInclude(JsonInclude.Include.NON_NULL)
|
||||||
public class Type extends UUIDGenericDataSoftDelete {
|
public class Type extends GenericDataSoftDelete {
|
||||||
@Column(nullable = false, length = 0)
|
@Column(nullable = false, length = 0)
|
||||||
@Schema(description = "Name of the media (this represent the title)")
|
@Schema(description = "Name of the media (this represent the title)")
|
||||||
public String name;
|
public String name;
|
||||||
@Column(length = 0)
|
@Column(length = 0)
|
||||||
@Schema(description = "Description of the media")
|
@Schema(description = "Description of the media")
|
||||||
public String description;
|
public String description;
|
||||||
@Schema(description = "List of Id of the sopecific covers")
|
@Schema(description = "List of Id of the specific covers")
|
||||||
@DataJson()
|
@DataJson()
|
||||||
public List<UUID> covers = null;
|
public List<UUID> covers = null;
|
||||||
}
|
}
|
||||||
|
@ -24,10 +24,10 @@ public class UserMediaAdvancement extends GenericDataSoftDelete {
|
|||||||
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Media.class)
|
@ManyToOne(fetch = FetchType.LAZY, targetEntity = Media.class)
|
||||||
public long mediaId;
|
public long mediaId;
|
||||||
@Column(nullable = false)
|
@Column(nullable = false)
|
||||||
@Schema(description = "Percent of admencement in the media")
|
@Schema(description = "Percent of advancement in the media")
|
||||||
public float percent;
|
public float percent;
|
||||||
@Column(nullable = false)
|
@Column(nullable = false)
|
||||||
@Schema(description = "Number of second of admencement in the media")
|
@Schema(description = "Number of second of advancement in the media")
|
||||||
public int time;
|
public int time;
|
||||||
@Column(nullable = false)
|
@Column(nullable = false)
|
||||||
@Schema(description = "Number of time this media has been read")
|
@Schema(description = "Number of time this media has been read")
|
||||||
|
9
front/package-lock.json
generated
9
front/package-lock.json
generated
@ -20,6 +20,7 @@
|
|||||||
"@angular/platform-browser-dynamic": "^17.2.0",
|
"@angular/platform-browser-dynamic": "^17.2.0",
|
||||||
"@angular/router": "^17.2.0",
|
"@angular/router": "^17.2.0",
|
||||||
"rxjs": "^7.8.1",
|
"rxjs": "^7.8.1",
|
||||||
|
"zod": "3.22.4",
|
||||||
"zone.js": "^0.14.4"
|
"zone.js": "^0.14.4"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
@ -17101,6 +17102,14 @@
|
|||||||
"url": "https://github.com/sponsors/sindresorhus"
|
"url": "https://github.com/sponsors/sindresorhus"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/zod": {
|
||||||
|
"version": "3.22.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/zod/-/zod-3.22.4.tgz",
|
||||||
|
"integrity": "sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==",
|
||||||
|
"funding": {
|
||||||
|
"url": "https://github.com/sponsors/colinhacks"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/zone.js": {
|
"node_modules/zone.js": {
|
||||||
"version": "0.14.4",
|
"version": "0.14.4",
|
||||||
"resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.14.4.tgz",
|
"resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.14.4.tgz",
|
||||||
|
@ -27,7 +27,8 @@
|
|||||||
"@angular/platform-browser-dynamic": "^17.2.0",
|
"@angular/platform-browser-dynamic": "^17.2.0",
|
||||||
"@angular/router": "^17.2.0",
|
"@angular/router": "^17.2.0",
|
||||||
"rxjs": "^7.8.1",
|
"rxjs": "^7.8.1",
|
||||||
"zone.js": "^0.14.4"
|
"zone.js": "^0.14.4",
|
||||||
|
"zod": "3.22.4"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@angular-devkit/build-angular": "^17.2.0",
|
"@angular-devkit/build-angular": "^17.2.0",
|
||||||
|
108
front/src/app/model/server-karideo-api.ts
Normal file
108
front/src/app/model/server-karideo-api.ts
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
/**
|
||||||
|
* Interface of the server (auto-generated code)
|
||||||
|
*/
|
||||||
|
import { z as zod } from "zod";
|
||||||
|
|
||||||
|
export const GenericTiming = zod.object({
|
||||||
|
// Create time of the object
|
||||||
|
createdAt: zod.date().readonly().optional(),
|
||||||
|
// When update the object
|
||||||
|
updatedAt: zod.date().readonly().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const UUIDGenericData = GenericTiming.extend({
|
||||||
|
// Unique UUID of the object
|
||||||
|
id: zod.string().uuid().readonly().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const UUIDGenericDataSoftDelete = UUIDGenericData.extend({
|
||||||
|
// Deleted state
|
||||||
|
deleted: zod.boolean().readonly().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const Data = UUIDGenericDataSoftDelete.extend({
|
||||||
|
// Sha512 of the data
|
||||||
|
sha512: zod.string().max(128).optional(),
|
||||||
|
// Mime -type of the media
|
||||||
|
mimeType: zod.string().max(128).optional(),
|
||||||
|
// Size in Byte of the data
|
||||||
|
size: zod.bigint().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const GenericData = GenericTiming.extend({
|
||||||
|
// Unique Id of the object
|
||||||
|
id: zod.bigint().readonly().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const GenericDataSoftDelete = GenericData.extend({
|
||||||
|
// Deleted state
|
||||||
|
deleted: zod.boolean().readonly().optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const Media = GenericDataSoftDelete.extend({
|
||||||
|
name: zod.string().optional(),
|
||||||
|
description: zod.string().optional(),
|
||||||
|
dataId: zod.string().uuid().optional(),
|
||||||
|
typeId: zod.bigint().optional(),
|
||||||
|
seriesId: zod.bigint().optional(),
|
||||||
|
seasonId: zod.bigint().optional(),
|
||||||
|
episode: zod.number().safe().optional(),
|
||||||
|
date: zod.number().safe().optional(),
|
||||||
|
time: zod.number().safe().optional(),
|
||||||
|
ageLimit: zod.number().safe().optional(),
|
||||||
|
covers: zod.array(zod.string().uuid()).optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const Type = GenericDataSoftDelete.extend({
|
||||||
|
// Name of the media (this represent the title)
|
||||||
|
name: zod.string().optional(),
|
||||||
|
// Description of the media
|
||||||
|
description: zod.string().optional(),
|
||||||
|
// List of Id of the specific covers
|
||||||
|
covers: zod.array(zod.string().uuid()).optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const Series = GenericDataSoftDelete.extend({
|
||||||
|
// Name of the media (this represent the title)
|
||||||
|
name: zod.string().optional(),
|
||||||
|
// Description of the media
|
||||||
|
description: zod.string().optional(),
|
||||||
|
// series parent ID
|
||||||
|
parentId: zod.bigint().optional(),
|
||||||
|
// List of Id of the specific covers
|
||||||
|
covers: zod.array(zod.string().uuid()).optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const Season = GenericDataSoftDelete.extend({
|
||||||
|
// Name of the media (this represent the title)
|
||||||
|
name: zod.string().optional(),
|
||||||
|
// Description of the media
|
||||||
|
description: zod.string().optional(),
|
||||||
|
// series parent ID
|
||||||
|
parentId: zod.bigint().optional(),
|
||||||
|
// List of Id of the specific covers
|
||||||
|
covers: zod.array(zod.string().uuid()).optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const User = GenericDataSoftDelete.extend({
|
||||||
|
login: zod.string().max(128).optional(),
|
||||||
|
lastConnection: zod.date().optional(),
|
||||||
|
admin: zod.boolean(),
|
||||||
|
blocked: zod.boolean(),
|
||||||
|
removed: zod.boolean(),
|
||||||
|
covers: zod.array(zod.bigint()).optional()
|
||||||
|
});
|
||||||
|
|
||||||
|
export const UserMediaAdvancement = GenericDataSoftDelete.extend({
|
||||||
|
// Foreign Key Id of the user
|
||||||
|
userId: zod.bigint(),
|
||||||
|
// Id of the media
|
||||||
|
mediaId: zod.bigint(),
|
||||||
|
// Percent of advancement in the media
|
||||||
|
percent: zod.number(),
|
||||||
|
// Number of second of advancement in the media
|
||||||
|
time: zod.number().safe(),
|
||||||
|
// Number of time this media has been read
|
||||||
|
count: zod.number().safe()
|
||||||
|
});
|
||||||
|
|
@ -3,7 +3,6 @@ import { isNumberFinite, isNumber } from "common/utils";
|
|||||||
|
|
||||||
export interface UserMediaAdvancement {
|
export interface UserMediaAdvancement {
|
||||||
id: number;
|
id: number;
|
||||||
|
|
||||||
// Id of the media
|
// Id of the media
|
||||||
mediaId?: number;
|
mediaId?: number;
|
||||||
// Percent of advancement in the media
|
// Percent of advancement in the media
|
||||||
|
@ -324,12 +324,6 @@ export class VideoScene implements OnInit {
|
|||||||
this.startHideTimer();
|
this.startHideTimer();
|
||||||
this.playVideo = false;
|
this.playVideo = false;
|
||||||
this.displayVolumeMenu = false;
|
this.displayVolumeMenu = false;
|
||||||
|
|
||||||
/*
|
|
||||||
if(this.isFullScreen === true) {
|
|
||||||
this.isFullScreen = false;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
changeStateToPlay() {
|
changeStateToPlay() {
|
||||||
|
Loading…
Reference in New Issue
Block a user