Former-commit-id: a539740f3c
pull/7/head
Jens Pelzetter 2020-12-03 21:10:14 +01:00
parent b6b7d61b90
commit b987fd763d
23 changed files with 109 additions and 112 deletions

View File

@ -29,7 +29,7 @@ public class ContentSectionImExporter
private ContentSectionRepository sectionRepository; private ContentSectionRepository sectionRepository;
@Override @Override
protected Class<ContentSection> getEntityClass() { public Class<ContentSection> getEntityClass() {
return ContentSection.class; return ContentSection.class;
} }

View File

@ -19,7 +19,7 @@ import javax.enterprise.context.RequestScoped;
public class ArticleImExporter extends AbstractContentItemImExporter<Article> { public class ArticleImExporter extends AbstractContentItemImExporter<Article> {
@Override @Override
protected Class<Article> getEntityClass() { public Class<Article> getEntityClass() {
return Article.class; return Article.class;
} }

View File

@ -19,7 +19,7 @@ import javax.enterprise.context.RequestScoped;
public class EventImExporter extends AbstractContentItemImExporter<Event> { public class EventImExporter extends AbstractContentItemImExporter<Event> {
@Override @Override
protected Class<Event> getEntityClass() { public Class<Event> getEntityClass() {
return Event.class; return Event.class;
} }

View File

@ -20,7 +20,7 @@ public class MultiPartArticleImExporter
extends AbstractContentItemImExporter<MultiPartArticle> { extends AbstractContentItemImExporter<MultiPartArticle> {
@Override @Override
protected Class<MultiPartArticle> getEntityClass() { public Class<MultiPartArticle> getEntityClass() {
return MultiPartArticle.class; return MultiPartArticle.class;
} }

View File

@ -19,7 +19,7 @@ import javax.enterprise.context.RequestScoped;
public class NewsImExporter extends AbstractContentItemImExporter<News> { public class NewsImExporter extends AbstractContentItemImExporter<News> {
@Override @Override
protected Class<News> getEntityClass() { public Class<News> getEntityClass() {
return News.class; return News.class;
} }

View File

@ -48,8 +48,7 @@ public class CategorizationImExporter
private Instance<CategorizationImExporterDependenciesProvider> dependenciesProviders; private Instance<CategorizationImExporterDependenciesProvider> dependenciesProviders;
@Override @Override
protected Class<Categorization> getEntityClass() { public Class<Categorization> getEntityClass() {
return Categorization.class; return Categorization.class;
} }

View File

@ -42,7 +42,7 @@ public class CategoryImExporter extends AbstractEntityImExporter<Category> {
private CategoryRepository categoryRepository; private CategoryRepository categoryRepository;
@Override @Override
protected Class<Category> getEntityClass() { public Class<Category> getEntityClass() {
return Category.class; return Category.class;
} }

View File

@ -41,7 +41,7 @@ public class DomainImExporter extends AbstractEntityImExporter<Domain> {
private DomainRepository domainRepository; private DomainRepository domainRepository;
@Override @Override
protected Class<Domain> getEntityClass() { public Class<Domain> getEntityClass() {
return Domain.class; return Domain.class;
} }

View File

@ -46,7 +46,7 @@ public class DomainOwnershipImExporter
private EntityManager entityManager; private EntityManager entityManager;
@Override @Override
protected Class<DomainOwnership> getEntityClass() { public Class<DomainOwnership> getEntityClass() {
return DomainOwnership.class; return DomainOwnership.class;
} }

View File

@ -39,8 +39,7 @@ public class ResourceTypeImExporter
private ResourceTypeRepository repository; private ResourceTypeRepository repository;
@Override @Override
protected Class<ResourceType> getEntityClass() { public Class<ResourceType> getEntityClass() {
return ResourceType.class; return ResourceType.class;
} }

View File

@ -53,7 +53,7 @@ public abstract class AbstractEntityImExporter<T extends Exportable> {
* *
* @return The Entity class which is handled by the implementation. * @return The Entity class which is handled by the implementation.
*/ */
protected abstract Class<T> getEntityClass(); public abstract Class<T> getEntityClass();
/** /**
* A set of entities which should be processed before this implementation is * A set of entities which should be processed before this implementation is

View File

@ -75,6 +75,23 @@ public class ImportExport {
@Any @Any
private Instance<AbstractEntityImExporter<?>> imExporters; private Instance<AbstractEntityImExporter<?>> imExporters;
public List<EntityImExporterTreeNode> getExportableEntityTypes() {
try {
final EntityImExporterTreeManager treeManager
= new EntityImExporterTreeManager();
final List<EntityImExporterTreeNode> tree = treeManager
.generateTree(
imExporters
.stream()
.collect(Collectors.toList())
);
return tree;
} catch (DependencyException ex) {
throw new UnexpectedErrorException(ex);
}
}
/** /**
* Exports the provided entities. The export will be written to a to the * Exports the provided entities. The export will be written to a to the
* {@code exports} directory in the CCM files directory. If {@code split} is * {@code exports} directory in the CCM files directory. If {@code split} is
@ -151,84 +168,6 @@ public class ImportExport {
entry.getValue()); entry.getValue());
} }
} }
public List<String> getExportableEntityTypes() {
return imExporters
.stream()
.map(imexporter -> imexporter.getEntityClass().getName())
.sorted()
.collect(Collectors.toList());
}
@SuppressWarnings("unchecked")
private JsonArrayBuilder createExportedEntities(
final String exportName,
final String type,
final List<Exportable> entities) {
final JsonArrayBuilder filesArrayBuilder = Json.createArrayBuilder();
final Class<? extends Exportable> clazz;
try {
clazz = (Class<? extends Exportable>) Class.forName(type);
} catch (ClassNotFoundException ex) {
throw new UnexpectedErrorException(ex);
}
final Instance<AbstractEntityImExporter<?>> instance = imExporters
.select(new ProcessesLiteral(clazz));
final AbstractEntityImExporter<?> imExporter;
if (instance.isUnsatisfied()) {
throw new UnexpectedErrorException(String.format(
"No EntityImExporter for entity type \"%s\" available.",
type));
} else if (instance.isAmbiguous()) {
throw new UnexpectedErrorException(String.format(
"Instance reference for EntityImExporter for entity "
+ "type \"%s\" is ambiguous.",
type));
} else {
imExporter = instance.get();
}
for (Exportable entity : entities) {
final String filename = String.format("%s.json", entity.getUuid());
final OutputStream outputStream;
try {
outputStream = ccmFiles.createOutputStream(String.format(
"exports/%s/%s/%s",
exportName,
type,
filename));
filesArrayBuilder.add(filename);
} catch (FileAccessException
| InsufficientPermissionsException ex) {
throw new UnexpectedErrorException(ex);
}
final String exportedEntity;
try {
exportedEntity = imExporter.exportEntity(entity);
} catch (ExportException ex) {
throw new UnexpectedErrorException(ex);
}
try (final OutputStreamWriter writer = new OutputStreamWriter(
outputStream, StandardCharsets.UTF_8)) {
writer.write(exportedEntity);
} catch (IOException ex) {
throw new UnexpectedErrorException(ex);
}
// try (JsonWriter writer = Json.createWriter(outputStream)) {
// writer.writeObject(exportedEntity);
// }
}
return filesArrayBuilder;
}
/** /**
* Imports all entities from the files in the {@link imports} directory * Imports all entities from the files in the {@link imports} directory
@ -261,15 +200,15 @@ public class ImportExport {
throw new UnexpectedErrorException(ex); throw new UnexpectedErrorException(ex);
} }
final List<AbstractEntityImExporter<?>> imExportersList
= new ArrayList<>();
imExporters.forEach(imExporter -> imExportersList.add(imExporter));
try { try {
final EntityImExporterTreeManager treeManager final EntityImExporterTreeManager treeManager
= new EntityImExporterTreeManager(); = new EntityImExporterTreeManager();
final List<EntityImExporterTreeNode> tree = treeManager final List<EntityImExporterTreeNode> tree = treeManager
.generateTree(imExportersList); .generateTree(
imExporters
.stream()
.collect(Collectors.toList())
);
final List<EntityImExporterTreeNode> orderedNodes = treeManager final List<EntityImExporterTreeNode> orderedNodes = treeManager
.orderImExporters(tree); .orderImExporters(tree);
@ -347,8 +286,6 @@ public class ImportExport {
.lines() .lines()
.collect(Collectors.joining("\n")); .collect(Collectors.joining("\n"));
// final JsonReader reader = Json.createReader(inputStream);
// final JsonObject data = reader.readObject();
imExporter.importEntity(data); imExporter.importEntity(data);
} catch (IOException } catch (IOException
@ -380,6 +317,71 @@ public class ImportExport {
.collect(Collectors.toList()); .collect(Collectors.toList());
} }
@SuppressWarnings("unchecked")
private JsonArrayBuilder createExportedEntities(
final String exportName,
final String type,
final List<Exportable> entities) {
final Class<? extends Exportable> clazz;
try {
clazz = (Class<? extends Exportable>) Class.forName(type);
} catch (ClassNotFoundException ex) {
throw new UnexpectedErrorException(ex);
}
final Instance<AbstractEntityImExporter<?>> instance = imExporters
.select(new ProcessesLiteral(clazz));
final AbstractEntityImExporter<?> imExporter;
if (instance.isUnsatisfied()) {
throw new UnexpectedErrorException(String.format(
"No EntityImExporter for entity type \"%s\" available.",
type));
} else if (instance.isAmbiguous()) {
throw new UnexpectedErrorException(String.format(
"Instance reference for EntityImExporter for entity "
+ "type \"%s\" is ambiguous.",
type));
} else {
imExporter = instance.get();
}
final JsonArrayBuilder filesArrayBuilder = Json.createArrayBuilder();
for (Exportable entity : entities) {
final String filename = String.format("%s.json", entity.getUuid());
final OutputStream outputStream;
try {
outputStream = ccmFiles.createOutputStream(String.format(
"exports/%s/%s/%s",
exportName,
type,
filename));
filesArrayBuilder.add(filename);
} catch (FileAccessException
| InsufficientPermissionsException ex) {
throw new UnexpectedErrorException(ex);
}
final String exportedEntity;
try {
exportedEntity = imExporter.exportEntity(entity);
} catch (ExportException ex) {
throw new UnexpectedErrorException(ex);
}
try (final OutputStreamWriter writer = new OutputStreamWriter(
outputStream, StandardCharsets.UTF_8)) {
writer.write(exportedEntity);
} catch (IOException ex) {
throw new UnexpectedErrorException(ex);
}
}
return filesArrayBuilder;
}
private boolean isImportArchive(final String path) { private boolean isImportArchive(final String path) {
final String manifestPath = String.format("imports/%s/ccm-export.json", final String manifestPath = String.format("imports/%s/ccm-export.json",

View File

@ -46,7 +46,7 @@ public class GroupImExporter extends AbstractEntityImExporter<Group> {
private GroupRepository groupRepository; private GroupRepository groupRepository;
@Override @Override
protected Class<Group> getEntityClass() { public Class<Group> getEntityClass() {
return Group.class; return Group.class;
} }

View File

@ -43,8 +43,7 @@ public class GroupMembershipImExporter
private EntityManager entityManager; private EntityManager entityManager;
@Override @Override
protected Class<GroupMembership> getEntityClass() { public Class<GroupMembership> getEntityClass() {
return GroupMembership.class; return GroupMembership.class;
} }

View File

@ -41,7 +41,7 @@ public class PermissionImExporter extends AbstractEntityImExporter<Permission>{
private PermissionRepository permissionRepository; private PermissionRepository permissionRepository;
@Override @Override
protected Class<Permission> getEntityClass() { public Class<Permission> getEntityClass() {
return Permission.class; return Permission.class;
} }

View File

@ -39,8 +39,7 @@ public class RoleImExporter extends AbstractEntityImExporter<Role> {
private RoleRepository roleRepository; private RoleRepository roleRepository;
@Override @Override
protected Class<Role> getEntityClass() { public Class<Role> getEntityClass() {
return Role.class; return Role.class;
} }

View File

@ -42,8 +42,7 @@ public class RoleMembershipImExporter
private EntityManager entityManager; private EntityManager entityManager;
@Override @Override
protected Class<RoleMembership> getEntityClass() { public Class<RoleMembership> getEntityClass() {
return RoleMembership.class; return RoleMembership.class;
} }

View File

@ -46,7 +46,7 @@ public class UserImExporter extends AbstractEntityImExporter<User> {
private UserRepository userRepository; private UserRepository userRepository;
@Override @Override
protected Class<User> getEntityClass() { public Class<User> getEntityClass() {
return User.class; return User.class;
} }

View File

@ -45,7 +45,7 @@ public class AssignableTaskImExporter
private AssignableTaskRepository assignableTaskRepository; private AssignableTaskRepository assignableTaskRepository;
@Override @Override
protected Class<AssignableTask> getEntityClass() { public Class<AssignableTask> getEntityClass() {
return AssignableTask.class; return AssignableTask.class;
} }

View File

@ -45,7 +45,7 @@ public class TaskAssignmentImExporter
private EntityManager entityManager; private EntityManager entityManager;
@Override @Override
protected Class<TaskAssignment> getEntityClass() { public Class<TaskAssignment> getEntityClass() {
return TaskAssignment.class; return TaskAssignment.class;
} }

View File

@ -43,7 +43,7 @@ public class TaskCommentImExporter extends AbstractEntityImExporter<TaskComment>
private TaskCommentRepository taskCommentRepository; private TaskCommentRepository taskCommentRepository;
@Override @Override
protected Class<TaskComment> getEntityClass() { public Class<TaskComment> getEntityClass() {
return TaskComment.class; return TaskComment.class;
} }

View File

@ -45,7 +45,7 @@ public class TaskDependencyImExporter
private EntityManager entityManager; private EntityManager entityManager;
@Override @Override
protected Class<TaskDependency> getEntityClass() { public Class<TaskDependency> getEntityClass() {
return TaskDependency.class; return TaskDependency.class;
} }

View File

@ -42,7 +42,7 @@ public class WorkflowImExporter extends AbstractEntityImExporter<Workflow> {
private WorkflowRepository workflowRepository; private WorkflowRepository workflowRepository;
@Override @Override
protected Class<Workflow> getEntityClass() { public Class<Workflow> getEntityClass() {
return Workflow.class; return Workflow.class;
} }