-
-
-
+
+
+ Could not open project : {{projectName}}
+
+
+
+
+
+
+
+
+
+
+ Describe your Vorto Model
+
+ Hint: Press Ctrl + Space for Content Assist
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ |
+
+
+ Name |
+ Details |
+
+
+
+
+ {{ model.id.name }} |
+
+
+
+
+ |
+
+
+
+
+
+
+ |
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/server/devtool/src/main/resources/static/templates/project-template.html b/server/devtool/src/main/resources/static/templates/project-template.html
new file mode 100644
index 0000000000..1793c172a6
--- /dev/null
+++ b/server/devtool/src/main/resources/static/templates/project-template.html
@@ -0,0 +1,70 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/ProjectRepositoryServiceTest.java b/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/ProjectRepositoryServiceTest.java
new file mode 100644
index 0000000000..edd01e778c
--- /dev/null
+++ b/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/ProjectRepositoryServiceTest.java
@@ -0,0 +1,59 @@
+package org.eclipse.vorto.server.devtool.service;
+
+import static org.junit.Assert.assertNotNull;
+import static org.mockito.Mockito.when;
+
+import org.eclipse.vorto.editor.web.resource.WebEditorResourceSetProvider;
+import org.eclipse.vorto.server.devtool.exception.ProjectAlreadyExistsException;
+import org.eclipse.vorto.server.devtool.exception.ProjectNotFoundException;
+import org.eclipse.vorto.server.devtool.service.impl.ProjectRepositoryServiceImpl;
+import org.eclipse.xtext.web.server.model.IWebResourceSetProvider;
+import org.junit.Before;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+import org.mockito.Mock;
+import org.mockito.MockitoAnnotations;
+
+import com.google.inject.Injector;
+
+public class ProjectRepositoryServiceTest {
+
+ @InjectMocks
+ private IProjectRepositoryService projectRepositoryService = new ProjectRepositoryServiceImpl();
+
+ @Mock
+ private IProjectRespositoryDAO projectRespositoryDAO;
+
+ @Mock
+ private Injector injector;
+
+ @Mock
+ private WebEditorResourceSetProvider webEditorResourceSetProvider;
+
+ private String sessionId = "sessionId";
+ private String projectName = "Project";
+
+ @Before
+ public void initMocks() {
+ MockitoAnnotations.initMocks(this);
+ }
+
+ @Test(expected = ProjectAlreadyExistsException.class)
+ public void checkProjectExistsTest() throws ProjectAlreadyExistsException{
+ when(injector.getInstance(IWebResourceSetProvider.class)).thenReturn(webEditorResourceSetProvider);
+ when(projectRespositoryDAO.projectExists(projectName, sessionId)).thenReturn(true);
+ projectRepositoryService.createProject(sessionId, projectName);
+ }
+
+ @Test(expected = ProjectNotFoundException.class)
+ public void openNonExistantProjectTest() throws ProjectNotFoundException{
+ when(projectRespositoryDAO.openProject(projectName, sessionId)).thenReturn(null);
+ projectRepositoryService.openProject(sessionId, projectName);
+ }
+
+ @Test
+ public void getProjectListTest() throws ProjectNotFoundException{
+ assertNotNull(projectRepositoryService.getProjects(sessionId));
+ }
+
+}
diff --git a/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/impl/ProjectRepositoryDAOTest.java b/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/impl/ProjectRepositoryDAOTest.java
new file mode 100644
index 0000000000..8f55f55c32
--- /dev/null
+++ b/server/devtool/src/test/java/org/eclipse/vorto/server/devtool/service/impl/ProjectRepositoryDAOTest.java
@@ -0,0 +1,56 @@
+package org.eclipse.vorto.server.devtool.service.impl;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertNull;
+import static org.junit.Assert.assertTrue;
+
+import org.eclipse.vorto.server.devtool.models.Project;
+import org.junit.Test;
+import org.mockito.InjectMocks;
+
+public class ProjectRepositoryDAOTest {
+
+ @InjectMocks
+ private MapProjectRespositoryDAOImpl projectRepositoryDAO = new MapProjectRespositoryDAOImpl();
+
+ private String sessionId = "sessionId";
+ private String projectName = "Project";
+
+ @Test
+ public void uniqueProjectNameTest(){
+ Project project1 = new Project(projectName);
+ projectRepositoryDAO.createProject(project1, sessionId);
+ assertEquals(1, projectRepositoryDAO.getProjects(sessionId).size());
+ Project project2 = new Project(projectName);
+ projectRepositoryDAO.createProject(project2, sessionId);
+ assertEquals(1, projectRepositoryDAO.getProjects(sessionId).size());
+ }
+
+ @Test
+ public void checkProjectExistsTest(){
+ Project project1 = new Project(projectName);
+ projectRepositoryDAO.createProject(project1, sessionId);
+ assertTrue(projectRepositoryDAO.projectExists(projectName, sessionId));
+ assertFalse(projectRepositoryDAO.projectExists(Long.toString(System.currentTimeMillis()), sessionId));
+ }
+
+
+ @Test
+ public void openProjectTest(){
+ Project project1 = new Project(projectName);
+ projectRepositoryDAO.createProject(project1, sessionId);
+ assertNotNull(projectRepositoryDAO.openProject(projectName, sessionId));
+ assertNull((projectRepositoryDAO.openProject(Long.toString(System.currentTimeMillis()), sessionId)));
+ }
+
+ @Test
+ public void getProjectsTest(){
+ Project project1 = new Project(projectName);
+ projectRepositoryDAO.createProject(project1, sessionId);
+ assertEquals(1, projectRepositoryDAO.getProjects(sessionId).size());
+ assertEquals(projectName, projectRepositoryDAO.getProjects(sessionId).get(0).getProjectName());
+ }
+
+}
diff --git a/server/pom.xml b/server/pom.xml
index 27fd7ef854..50f06f4620 100644
--- a/server/pom.xml
+++ b/server/pom.xml
@@ -44,6 +44,7 @@
generators
repo
+ devtool
diff --git a/server/repo/pom.xml b/server/repo/pom.xml
index b84cbcec88..5542fbb85a 100644
--- a/server/repo/pom.xml
+++ b/server/repo/pom.xml
@@ -17,6 +17,7 @@
repo-core
repo-ui
+ repo-http-models
diff --git a/server/repo/repo-core/pom.xml b/server/repo/repo-core/pom.xml
index e116ae193d..64affaca14 100644
--- a/server/repo/repo-core/pom.xml
+++ b/server/repo/repo-core/pom.xml
@@ -67,6 +67,11 @@
org.eclipse.vorto
org.eclipse.vorto.core
+
+ org.eclipse.vorto
+ repo-http-models
+ ${project.version}
+
org.eclipse.vorto
org.eclipse.vorto.editor
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/DefaultRepositoryManager.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/DefaultRepositoryManager.java
index 0bb0fce94c..b0510de254 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/DefaultRepositoryManager.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/DefaultRepositoryManager.java
@@ -11,8 +11,8 @@
import javax.jcr.RepositoryException;
import javax.jcr.Session;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.service.FatalModelRepositoryException;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.service.IRepositoryManager;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/IModelParser.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/IModelParser.java
index 5b42988c9d..0beca4c225 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/IModelParser.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/IModelParser.java
@@ -16,7 +16,7 @@
import java.io.InputStream;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelResource;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/JcrModelRepository.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/JcrModelRepository.java
index d0362d4f63..8e09c735b4 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/JcrModelRepository.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/JcrModelRepository.java
@@ -47,14 +47,14 @@
import org.apache.commons.io.FilenameUtils;
import org.apache.commons.io.IOUtils;
import org.apache.log4j.Logger;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.internal.service.utils.ModelReferencesHelper;
import org.eclipse.vorto.repository.internal.service.utils.ModelSearchUtil;
import org.eclipse.vorto.repository.internal.service.validation.DuplicateModelValidation;
import org.eclipse.vorto.repository.internal.service.validation.ModelReferencesValidation;
import org.eclipse.vorto.repository.model.ModelEMFResource;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.ModelType;
import org.eclipse.vorto.repository.model.UploadModelResult;
import org.eclipse.vorto.repository.model.User;
import org.eclipse.vorto.repository.notification.INotificationService;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/ModelParserFactory.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/ModelParserFactory.java
index 6c320a6826..6b4f0cddb6 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/ModelParserFactory.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/ModelParserFactory.java
@@ -14,17 +14,17 @@
*/
package org.eclipse.vorto.repository.internal.service;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.internal.service.emf.DatatypeModelParser;
import org.eclipse.vorto.repository.internal.service.emf.FunctionblockModelParser;
import org.eclipse.vorto.repository.internal.service.emf.InformationModelParser;
import org.eclipse.vorto.repository.internal.service.emf.MappingModelParser;
-import org.eclipse.vorto.repository.model.ModelType;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
*/
public class ModelParserFactory {
-
+
public static IModelParser getParser(String fileName) {
if (fileName.endsWith(ModelType.Datatype.getExtension())) {
return new DatatypeModelParser(fileName);
@@ -34,7 +34,7 @@ public static IModelParser getParser(String fileName) {
return new InformationModelParser(fileName);
} else if (fileName.endsWith(ModelType.Mapping.getExtension())) {
return new MappingModelParser(fileName);
- }else {
+ } else {
throw new UnsupportedOperationException("File cannot be parsed, because it is not supported");
}
}
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/emf/AbstractModelParser.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/emf/AbstractModelParser.java
index 52a9d3cff4..6b9b296a7e 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/emf/AbstractModelParser.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/emf/AbstractModelParser.java
@@ -23,11 +23,11 @@
import org.eclipse.emf.common.util.URI;
import org.eclipse.emf.ecore.resource.Resource;
import org.eclipse.vorto.core.api.model.model.Model;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.internal.service.IModelParser;
import org.eclipse.vorto.repository.model.ModelEMFResource;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.ModelType;
import org.eclipse.vorto.repository.validation.ValidationException;
import org.eclipse.xtext.linking.impl.XtextLinkingDiagnostic;
import org.eclipse.xtext.resource.XtextResource;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/generation/GenerationDelegateProxyService.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/generation/GenerationDelegateProxyService.java
index 781111799c..7103439468 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/generation/GenerationDelegateProxyService.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/generation/GenerationDelegateProxyService.java
@@ -23,12 +23,12 @@
import java.util.Map;
import java.util.Set;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.model.GeneratedOutput;
import org.eclipse.vorto.repository.model.Generator;
import org.eclipse.vorto.repository.model.GeneratorServiceInfo;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.ModelType;
import org.eclipse.vorto.repository.model.ServiceClassifier;
import org.eclipse.vorto.repository.service.GenerationException;
import org.eclipse.vorto.repository.service.GeneratorAlreadyExistsException;
@@ -198,4 +198,4 @@ public int compare(Generator o1, Generator o2) {
return result;
}
-}
+}
\ No newline at end of file
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/sequencer/ModelSequencer.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/sequencer/ModelSequencer.java
index b4effc2dcc..c7593fe5ac 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/sequencer/ModelSequencer.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/sequencer/ModelSequencer.java
@@ -25,10 +25,10 @@
import javax.jcr.RepositoryException;
import javax.jcr.Value;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.internal.service.ModelParserFactory;
import org.eclipse.vorto.repository.internal.service.utils.ModelReferencesHelper;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
import org.modeshape.common.util.CheckArg;
import org.modeshape.jcr.api.nodetype.NodeTypeManager;
import org.modeshape.jcr.api.sequencer.Sequencer;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/BulkUploadHelper.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/BulkUploadHelper.java
index 3786b588b0..bb409a2150 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/BulkUploadHelper.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/BulkUploadHelper.java
@@ -29,12 +29,13 @@
import org.apache.commons.io.FileUtils;
import org.apache.commons.io.FilenameUtils;
import org.apache.commons.io.IOUtils;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.internal.service.ModelParserFactory;
import org.eclipse.vorto.repository.internal.service.validation.BulkModelDuplicateIdValidation;
import org.eclipse.vorto.repository.internal.service.validation.BulkModelReferencesValidation;
import org.eclipse.vorto.repository.internal.service.validation.DuplicateModelValidation;
import org.eclipse.vorto.repository.model.ModelEMFResource;
-import org.eclipse.vorto.repository.model.ModelResource;
+
import org.eclipse.vorto.repository.model.UploadModelResult;
import org.eclipse.vorto.repository.service.FatalModelRepositoryException;
import org.eclipse.vorto.repository.service.IModelRepository;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/ModelReferencesHelper.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/ModelReferencesHelper.java
index ae9e6fbede..afbd5ba33d 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/ModelReferencesHelper.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/utils/ModelReferencesHelper.java
@@ -17,7 +17,7 @@
import java.util.ArrayList;
import java.util.List;
-import org.eclipse.vorto.repository.model.ModelId;
+import org.eclipse.vorto.http.model.ModelId;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelDuplicateIdValidation.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelDuplicateIdValidation.java
index 9aa31f948d..00740eabd4 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelDuplicateIdValidation.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelDuplicateIdValidation.java
@@ -19,8 +19,8 @@
import java.util.Set;
import java.util.stream.Collectors;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.validation.ValidationException;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelReferencesValidation.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelReferencesValidation.java
index 65aadb8965..7d3617a1f7 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelReferencesValidation.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/BulkModelReferencesValidation.java
@@ -19,9 +19,9 @@
import java.util.Set;
import java.util.stream.Collectors;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.internal.service.validation.exception.CouldNotResolveReferenceException;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.validation.ValidationException;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/DuplicateModelValidation.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/DuplicateModelValidation.java
index 3261b9d68b..e4ec1d9475 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/DuplicateModelValidation.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/DuplicateModelValidation.java
@@ -14,7 +14,7 @@
*/
package org.eclipse.vorto.repository.internal.service.validation;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.validation.IModelValidator;
import org.eclipse.vorto.repository.validation.ValidationException;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/ModelReferencesValidation.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/ModelReferencesValidation.java
index b143d6e783..0ddee5a801 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/ModelReferencesValidation.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/ModelReferencesValidation.java
@@ -17,9 +17,9 @@
import java.util.ArrayList;
import java.util.List;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.internal.service.validation.exception.CouldNotResolveReferenceException;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.validation.IModelValidator;
import org.eclipse.vorto.repository.validation.ValidationException;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/exception/CouldNotResolveReferenceException.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/exception/CouldNotResolveReferenceException.java
index 159a18d3bb..ae00d05fe4 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/exception/CouldNotResolveReferenceException.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/internal/service/validation/exception/CouldNotResolveReferenceException.java
@@ -17,8 +17,8 @@
import java.util.List;
import java.util.Objects;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.validation.ValidationException;
public class CouldNotResolveReferenceException extends ValidationException {
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/Comment.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/Comment.java
index 057005ff90..03de780bde 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/Comment.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/Comment.java
@@ -24,6 +24,8 @@
import javax.persistence.Id;
import javax.validation.constraints.NotNull;
+import org.eclipse.vorto.http.model.ModelId;
+
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
*/
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelEMFResource.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelEMFResource.java
index 20f78ff11f..ffee056b58 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelEMFResource.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelEMFResource.java
@@ -26,6 +26,9 @@
import org.eclipse.vorto.core.api.model.mapping.MappingModel;
import org.eclipse.vorto.core.api.model.model.Model;
import org.eclipse.vorto.core.api.model.model.ModelReference;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelHandle.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelHandle.java
index 429f8e850a..d59fa1b1ed 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelHandle.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelHandle.java
@@ -14,7 +14,7 @@
*/
package org.eclipse.vorto.repository.model;
-import org.eclipse.vorto.repository.model.ModelId;
+import org.eclipse.vorto.http.model.ModelId;
/**
* Model class to hold file handle id and associated model details.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelUploadHandle.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelUploadHandle.java
index f9a113e364..21fe98d444 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelUploadHandle.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelUploadHandle.java
@@ -14,6 +14,9 @@
*/
package org.eclipse.vorto.repository.model;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelType;
+
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
*/
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/UploadModelResult.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/UploadModelResult.java
index f4e1d5a992..df6f2a711c 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/UploadModelResult.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/UploadModelResult.java
@@ -19,6 +19,8 @@
import java.util.List;
import java.util.Objects;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.internal.service.validation.exception.CouldNotResolveReferenceException;
import org.eclipse.vorto.repository.validation.ValidationException;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ZipData.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ZipData.java
index a1177a4052..d8eaf216df 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ZipData.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ZipData.java
@@ -14,6 +14,9 @@
*/
package org.eclipse.vorto.repository.model;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelType;
+
import com.google.common.base.Objects;
/**
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/notification/message/CheckinMessage.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/notification/message/CheckinMessage.java
index d2c6fb049a..95c45c7177 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/notification/message/CheckinMessage.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/notification/message/CheckinMessage.java
@@ -14,12 +14,12 @@
*/
package org.eclipse.vorto.repository.notification.message;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.User;
-
import java.util.HashMap;
import java.util.Map;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.repository.model.User;
+
public class CheckinMessage extends AbstractMessage {
private ModelResource modelResource;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/CommentService.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/CommentService.java
index 9371b3d305..e2f29c28ba 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/CommentService.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/CommentService.java
@@ -19,9 +19,9 @@
import javax.jcr.PathNotFoundException;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.internal.service.CommentRepository;
import org.eclipse.vorto.repository.model.Comment;
-import org.eclipse.vorto.repository.model.ModelId;
import org.eclipse.vorto.repository.model.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ICommentService.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ICommentService.java
index 23f931f1a9..3fde180d63 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ICommentService.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ICommentService.java
@@ -16,8 +16,8 @@
import java.util.List;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.model.Comment;
-import org.eclipse.vorto.repository.model.ModelId;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IGeneratorService.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IGeneratorService.java
index a9b574b84c..e6cd2379f5 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IGeneratorService.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IGeneratorService.java
@@ -18,9 +18,9 @@
import java.util.Map;
import java.util.Set;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.model.GeneratedOutput;
import org.eclipse.vorto.repository.model.GeneratorServiceInfo;
-import org.eclipse.vorto.repository.model.ModelId;
import org.eclipse.vorto.repository.model.ServiceClassifier;
/**
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IModelRepository.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IModelRepository.java
index 80e051d5cc..305c246256 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IModelRepository.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IModelRepository.java
@@ -16,8 +16,8 @@
import java.util.List;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.model.UploadModelResult;
/**
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IRepositoryManager.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IRepositoryManager.java
index e8b5276b2f..e7a2d0233f 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IRepositoryManager.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/IRepositoryManager.java
@@ -2,7 +2,8 @@
import java.io.InputStream;
-import org.eclipse.vorto.repository.model.ModelId;
+import org.eclipse.vorto.http.model.ModelId;
+
public interface IRepositoryManager {
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ModelReferentialIntegrityException.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ModelReferentialIntegrityException.java
index a13fa93413..07c11358d6 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ModelReferentialIntegrityException.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/service/ModelReferentialIntegrityException.java
@@ -17,7 +17,7 @@
import java.util.ArrayList;
import java.util.List;
-import org.eclipse.vorto.repository.model.ModelId;
+import org.eclipse.vorto.http.model.ModelId;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/IModelValidator.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/IModelValidator.java
index f32cc36b2e..09fb6835d3 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/IModelValidator.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/IModelValidator.java
@@ -14,7 +14,7 @@
*/
package org.eclipse.vorto.repository.validation;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelResource;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/ValidationException.java b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/ValidationException.java
index eb80c06a5b..9a1bc1e57a 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/ValidationException.java
+++ b/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/validation/ValidationException.java
@@ -14,7 +14,7 @@
*/
package org.eclipse.vorto.repository.validation;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelResource;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
diff --git a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/ModelRepositoryTest.java b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/ModelRepositoryTest.java
index ce060ae5e0..cd4fa113bf 100644
--- a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/ModelRepositoryTest.java
+++ b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/ModelRepositoryTest.java
@@ -27,9 +27,9 @@
import java.util.Collection;
import org.apache.commons.io.IOUtils;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.ModelType;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.model.UploadModelResult;
import org.eclipse.vorto.repository.model.User;
import org.eclipse.vorto.repository.service.IModelRepository.ContentType;
diff --git a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/NotificationServiceTest.java b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/NotificationServiceTest.java
index 308fbb3eb7..c8b489425b 100644
--- a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/NotificationServiceTest.java
+++ b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/NotificationServiceTest.java
@@ -19,9 +19,9 @@
import java.util.Date;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
-import org.eclipse.vorto.repository.model.ModelType;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelType;
import org.eclipse.vorto.repository.model.User;
import org.eclipse.vorto.repository.notification.EmailNotificationService;
import org.eclipse.vorto.repository.notification.message.CheckinMessage;
diff --git a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/RepositoryAdminTest.java b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/RepositoryAdminTest.java
index 582b4cc1bb..c386a5dcb3 100644
--- a/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/RepositoryAdminTest.java
+++ b/server/repo/repo-core/src/test/java/org/eclipse/vorto/repository/service/RepositoryAdminTest.java
@@ -6,8 +6,9 @@
import static org.junit.Assert.fail;
import org.apache.commons.io.IOUtils;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.internal.service.DefaultRepositoryManager;
-import org.eclipse.vorto.repository.model.ModelId;
+
import org.junit.Test;
import org.springframework.core.io.ClassPathResource;
diff --git a/server/repo/repo-http-models/pom.xml b/server/repo/repo-http-models/pom.xml
new file mode 100644
index 0000000000..a17f5b3954
--- /dev/null
+++ b/server/repo/repo-http-models/pom.xml
@@ -0,0 +1,19 @@
+
+ 4.0.0
+
+ org.eclipse.vorto
+ repo
+ 0.9.0-SNAPSHOT
+
+ repo-http-models
+ jar
+
+
+
+ com.google.guava
+ guava
+ 18.0
+
+
+
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelId.java b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelId.java
similarity index 99%
rename from server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelId.java
rename to server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelId.java
index 540c0b9089..f3e5af1513 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelId.java
+++ b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelId.java
@@ -12,8 +12,7 @@
* Contributors:
* Bosch Software Innovations GmbH - Please refer to git log
*/
-package org.eclipse.vorto.repository.model;
-
+package org.eclipse.vorto.http.model;
import java.util.Iterator;
import java.util.StringTokenizer;
@@ -178,4 +177,4 @@ public String getPrettyFormat() {
public String getFileName() {
return namespace.replace(".", "_")+"-"+name+"-"+version.replace(".", "_");
}
-}
+}
\ No newline at end of file
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelResource.java b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelResource.java
similarity index 98%
rename from server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelResource.java
rename to server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelResource.java
index abe3ae8fbb..3b45fea982 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelResource.java
+++ b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelResource.java
@@ -12,7 +12,7 @@
* Contributors:
* Bosch Software Innovations GmbH - Please refer to git log
*/
-package org.eclipse.vorto.repository.model;
+package org.eclipse.vorto.http.model;
import java.util.ArrayList;
import java.util.Date;
@@ -164,4 +164,4 @@ public void addTargetPlatform(String targetPlatform) {
}
}
-}
+}
\ No newline at end of file
diff --git a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelType.java b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelType.java
similarity index 97%
rename from server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelType.java
rename to server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelType.java
index ff36092911..eb606e1a24 100644
--- a/server/repo/repo-core/src/main/java/org/eclipse/vorto/repository/model/ModelType.java
+++ b/server/repo/repo-http-models/src/main/java/org/eclipse/vorto/http/model/ModelType.java
@@ -12,7 +12,7 @@
* Contributors:
* Bosch Software Innovations GmbH - Please refer to git log
*/
-package org.eclipse.vorto.repository.model;
+package org.eclipse.vorto.http.model;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.
@@ -47,4 +47,4 @@ public static ModelType fromFileName(String fileName) {
throw new IllegalArgumentException(fileName);
}
}
-}
+}
\ No newline at end of file
diff --git a/server/repo/repo-ui/pom.xml b/server/repo/repo-ui/pom.xml
index 5e7850ef5c..4b43d922e0 100644
--- a/server/repo/repo-ui/pom.xml
+++ b/server/repo/repo-ui/pom.xml
@@ -19,6 +19,11 @@
repo-core
${project.version}
+
+ org.eclipse.vorto
+ repo-http-models
+ ${project.version}
+
diff --git a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/AdminController.java b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/AdminController.java
index a71720b42f..b8fd8bf511 100644
--- a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/AdminController.java
+++ b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/AdminController.java
@@ -9,7 +9,7 @@
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.io.IOUtils;
-import org.eclipse.vorto.repository.model.ModelId;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.service.IRepositoryManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.access.annotation.Secured;
diff --git a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelGenerationController.java b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelGenerationController.java
index d7d375560a..a84038a406 100644
--- a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelGenerationController.java
+++ b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelGenerationController.java
@@ -27,9 +27,9 @@
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.io.IOUtils;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.model.GeneratedOutput;
import org.eclipse.vorto.repository.model.GeneratorServiceInfo;
-import org.eclipse.vorto.repository.model.ModelId;
import org.eclipse.vorto.repository.model.ServiceClassifier;
import org.eclipse.vorto.repository.service.IGeneratorService;
import org.slf4j.Logger;
diff --git a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelRepositoryController.java b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelRepositoryController.java
index 086af54a2e..e34e2d66ed 100644
--- a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelRepositoryController.java
+++ b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/ModelRepositoryController.java
@@ -26,8 +26,8 @@
import org.apache.commons.io.IOUtils;
import org.apache.log4j.Logger;
-import org.eclipse.vorto.repository.model.ModelId;
-import org.eclipse.vorto.repository.model.ModelResource;
+import org.eclipse.vorto.http.model.ModelId;
+import org.eclipse.vorto.http.model.ModelResource;
import org.eclipse.vorto.repository.service.IModelRepository;
import org.eclipse.vorto.repository.service.IModelRepository.ContentType;
import org.eclipse.vorto.repository.service.ModelNotFoundException;
diff --git a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/comment/CommentController.java b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/comment/CommentController.java
index b248af0c8f..a8c0ce7068 100644
--- a/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/comment/CommentController.java
+++ b/server/repo/repo-ui/src/main/java/org/eclipse/vorto/repository/web/comment/CommentController.java
@@ -18,8 +18,8 @@
import javax.validation.Valid;
+import org.eclipse.vorto.http.model.ModelId;
import org.eclipse.vorto.repository.model.Comment;
-import org.eclipse.vorto.repository.model.ModelId;
import org.eclipse.vorto.repository.service.ICommentService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
@@ -35,8 +35,8 @@
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
-import io.swagger.annotations.ApiResponses;
import io.swagger.annotations.ApiResponse;
+import io.swagger.annotations.ApiResponses;
/**
* @author Alexander Edelmann - Robert Bosch (SEA) Pte. Ltd.