From 7a2d49a7f97d85aa63fed68eae4b874ab038a2fd Mon Sep 17 00:00:00 2001 From: Alex Ormenisan Date: Mon, 15 Aug 2022 15:13:24 +0200 Subject: [PATCH 1/4] [HOPSWORKS-3297] not supported exception --- .../hopsworks/api/dataset/DatasetBuilder.java | 23 +++++++------ .../api/dataset/DatasetResource.java | 19 ++++++----- .../api/dataset/inode/InodeBuilder.java | 19 ++++++----- .../api/dataset/tags/DatasetTagsResource.java | 13 +++---- .../FeaturestoreKeywordResource.java | 7 ++-- .../api/featurestore/FeaturestoreService.java | 3 +- .../featureview/FeatureViewBuilder.java | 7 ++-- .../featureview/FeatureViewResource.java | 11 +++--- .../tag/FeatureStoreTagResource.java | 13 +++---- .../TrainingDatasetDTOBuilder.java | 9 ++--- .../TrainingDatasetResource.java | 4 +-- .../modelregistry/ModelRegistryBuilder.java | 4 +-- .../modelregistry/ModelRegistryResource.java | 4 +-- .../ModelRegistryTagResource.java | 13 +++---- .../modelregistry/models/ModelsBuilder.java | 7 ++-- .../modelregistry/models/ModelsResource.java | 6 ++-- .../api/provenance/ops/ProvLinksBuilder.java | 2 +- .../hops/hopsworks/api/tags/TagBuilder.java | 9 ++--- .../hopsworks/api/tags/TagSchemasBuilder.java | 9 ++--- .../api/tags/TagSchemasResource.java | 9 ++--- .../keyword/KeywordControllerCommunity.java | 33 ++++++++++++++++++ .../keyword/KeywordControllerIface.java | 34 +++++++------------ .../ops/ProvOpsControllerIface.java | 31 ++++++----------- .../provenance/ops/ProvOpsControllerImpl.java | 29 ++++++++++++++++ .../hopsworks/common/tags/TagController.java | 28 ++++++++------- .../common/tags/TagControllerIface.java | 13 +++---- .../common/tags/TagSchemasController.java | 28 ++++++++------- .../tags/TagSchemasControllerIface.java | 13 +++---- .../hops/hopsworks/restutils/RESTCodes.java | 2 +- 29 files changed, 235 insertions(+), 167 deletions(-) diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetBuilder.java index f17fa2fa45..30dca85e9a 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetBuilder.java @@ -30,6 +30,7 @@ import io.hops.hopsworks.common.dataset.util.DatasetPath; import io.hops.hopsworks.common.hdfs.inode.InodeController; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.dataset.Dataset; @@ -116,7 +117,7 @@ public DatasetDTO expand(DatasetDTO dto, ResourceRequest resourceRequest) { private DatasetDTO build(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { expand(dto, resourceRequest); if (dto.isExpand()) { Dataset dataset = datasetPath.getDataset(); @@ -167,13 +168,13 @@ private DatasetDTO build(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resour } public DatasetDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { return build(uriInfo, resourceRequest, user, datasetPath, null, null, false); } public DatasetDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, String parentPath, Users dirOwner, boolean expandSharedWith) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { DatasetDTO dto = new DatasetDTO(); uri(dto, uriInfo); build(dto, uriInfo, resourceRequest, user, datasetPath, parentPath, dirOwner); @@ -190,7 +191,7 @@ public DatasetDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Users public DatasetDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { DatasetDTO dto = new DatasetDTO(); uriItems(dto, uriInfo, datasetPath); return build(dto, uriInfo, resourceRequest, user, datasetPath, parentPath, dirOwner); @@ -206,7 +207,7 @@ public DatasetDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, U */ public DatasetDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Project accessProject, Users user, String name) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Dataset dataset = datasetController.getByProjectAndDsName(accessProject, null, name); if (dataset == null) { throw new DatasetException(RESTCodes.DatasetErrorCode.DATASET_NOT_FOUND, Level.FINE); @@ -225,7 +226,7 @@ public DatasetDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Projec */ public DatasetDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, ResourceRequest sharedDatasetResourceRequest, Project project, Users user) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Inode parent = project.getInode(); datasetHelper.checkResourceRequestLimit(resourceRequest, parent.getChildrenNum()); String parentPath = inodeController.getPath(parent); @@ -237,7 +238,7 @@ public DatasetDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, private DatasetDTO items(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, ResourceRequest sharedDatasetResourceRequest, Project accessProject, Users user, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { uri(dto, uriInfo); expand(dto, resourceRequest); if (dto.isExpand()) { @@ -253,7 +254,7 @@ private DatasetDTO items(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resour // datasets in the project private DatasetDTO ownItems(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, Project accessProject, Users user, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { AbstractFacade.CollectionInfo collectionInfo = datasetFacade.findAllDatasetByProject(null, null, resourceRequest.getFilter(), resourceRequest.getSort(), accessProject); dto.setCount(collectionInfo.getCount()); @@ -264,7 +265,7 @@ private DatasetDTO ownItems(DatasetDTO dto, UriInfo uriInfo, ResourceRequest res // shared datasets private DatasetDTO sharedItems(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, Project accessProject, Users user, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { AbstractFacade.CollectionInfo collectionInfo = datasetSharedWithFacade.findAllDatasetByProject(null, null, resourceRequest.getFilter(), resourceRequest.getSort(), accessProject); dto.setCount(collectionInfo.getCount()); @@ -275,7 +276,7 @@ private DatasetDTO sharedItems(DatasetDTO dto, UriInfo uriInfo, ResourceRequest // create dto from a list of dataset private DatasetDTO datasetItems(DatasetDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, List datasets, Project accessProject, Users user, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { if (datasets != null && !datasets.isEmpty()) { for(Dataset dataset : datasets) { DatasetPath datasetPath = datasetHelper.getTopLevelDatasetPath(accessProject, dataset); @@ -290,7 +291,7 @@ private DatasetDTO datasetSharedWithItems(DatasetDTO dto, UriInfo uriInfo, Resou Project accessProject, Users user, List datasetSharedWithList, String parentPath, Users dirOwner) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { if (datasetSharedWithList != null && !datasetSharedWithList.isEmpty()) { for(DatasetSharedWith datasetSharedWith : datasetSharedWithList) { DatasetPath datasetPath = datasetHelper.getTopLevelDatasetPath(accessProject, datasetSharedWith); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetResource.java index 3e9efa1068..c0ec8a5bee 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/DatasetResource.java @@ -40,6 +40,7 @@ import io.hops.hopsworks.common.provenance.core.dto.ProvTypeDTO; import io.hops.hopsworks.exceptions.DatasetException; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.HopsSecurityException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.ProjectException; @@ -153,7 +154,7 @@ public Response get(@BeanParam Pagination pagination, @BeanParam DatasetBeanParam datasetBeanParam, @Context HttpServletRequest req, @Context UriInfo uriInfo, @Context SecurityContext sc) - throws ProjectException, DatasetException, MetadataException, SchematizedTagException { + throws ProjectException, DatasetException, MetadataException, SchematizedTagException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.DATASET); resourceRequest.setOffset(pagination.getOffset()); @@ -191,7 +192,7 @@ public Response getByPath(@PathParam("path") String path, @Context UriInfo uriInfo, @Context HttpServletRequest req, @Context SecurityContext sc) - throws DatasetException, ProjectException, MetadataException, SchematizedTagException { + throws DatasetException, ProjectException, MetadataException, SchematizedTagException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.INODES); resourceRequest.setExpansions(datasetExpansionBeanParam.getResources()); @@ -247,8 +248,8 @@ public Response postByPath(@Context UriInfo uriInfo, @Context SecurityContext sc @QueryParam("destination_path") String destPath, @QueryParam("destination_type") DatasetType destDatasetType, @DefaultValue("READ_ONLY") @QueryParam("permission") DatasetAccessPermission permission) - throws DatasetException, ProjectException, HopsSecurityException, ProvenanceException, MetadataException, - SchematizedTagException, FeaturestoreException { + throws DatasetException, ProjectException, HopsSecurityException, ProvenanceException, MetadataException, + SchematizedTagException, FeaturestoreException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); DatasetPath datasetPath; DatasetPath distDatasetPath; @@ -288,7 +289,8 @@ public Response postByPath(@Context UriInfo uriInfo, @Context SecurityContext sc resourceRequest = new ResourceRequest(ResourceRequest.Name.INODES); Inode inode = inodeController.getInodeAtPath(datasetPath.getFullPath().toString()); datasetPath.setInode(inode); - InodeDTO dto = inodeBuilder.buildStat(uriInfo, resourceRequest, user, datasetPath, inode); + InodeDTO dto; + dto = inodeBuilder.buildStat(uriInfo, resourceRequest, user, datasetPath, inode); return Response.created(dto.getHref()).entity(dto).build(); } case COPY: @@ -380,7 +382,8 @@ public Response update(@PathParam("path") String path, @QueryParam("type") Datas @QueryParam("target_project") String targetProjectName, @Context UriInfo uriInfo, @Context SecurityContext sc) - throws DatasetException, ProjectException, MetadataException, SchematizedTagException, FeaturestoreException { + throws ProjectException, DatasetException, SchematizedTagException, GenericException, MetadataException, + FeaturestoreException { Project project = this.getProject(); DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.DATASET); @@ -394,8 +397,8 @@ public Response update(@PathParam("path") String path, @QueryParam("type") Datas break; case SHARE_PERMISSION: checkIfDataOwner(project, user); - datasetController.updateSharePermission(datasetPath.getDataset(), datasetPermissions, project, targetProjectName - , user); + datasetController.updateSharePermission(datasetPath.getDataset(), datasetPermissions, project, + targetProjectName, user); dto = datasetBuilder.build(uriInfo, resourceRequest, user, datasetPath, null, null, false); break; case DESCRIPTION: diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/inode/InodeBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/inode/InodeBuilder.java index 2bb8f388cb..4c7699f192 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/inode/InodeBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/inode/InodeBuilder.java @@ -30,6 +30,7 @@ import io.hops.hopsworks.common.dataset.FilePreviewMode; import io.hops.hopsworks.common.util.Settings; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.hdfs.inode.Inode; @@ -101,7 +102,7 @@ private InodeDTO expand(InodeDTO dto, ResourceRequest resourceRequest) { public InodeDTO buildStat(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, Inode inode, Users dirOwner) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { InodeDTO dto = new InodeDTO(); uri(dto, uriInfo, inode); expand(dto, resourceRequest); @@ -130,7 +131,7 @@ public InodeDTO buildResource(UriInfo uriInfo, Project project, DatasetPath data */ public InodeDTO buildStat(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, Inode inode) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { InodeDTO dto = new InodeDTO(); uri(dto, uriInfo); expand(dto, resourceRequest); @@ -144,7 +145,7 @@ public InodeDTO buildStat(UriInfo uriInfo, ResourceRequest resourceRequest, User public InodeDTO buildBlob(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, Inode inode, FilePreviewMode mode) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { InodeDTO dto = new InodeDTO(); uri(dto, uriInfo); expand(dto, resourceRequest); @@ -168,7 +169,7 @@ public InodeDTO buildBlob(UriInfo uriInfo, ResourceRequest resourceRequest, User * @return */ public InodeDTO buildStat(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { Inode inode = datasetPath.getInode(); if (inode == null) { throw new DatasetException(RESTCodes.DatasetErrorCode.PATH_NOT_FOUND, Level.FINE); @@ -187,7 +188,7 @@ public InodeDTO buildStat(UriInfo uriInfo, ResourceRequest resourceRequest, User */ public InodeDTO buildBlob(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, FilePreviewMode mode) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { Inode inode = datasetPath.getInode(); if (inode == null) { throw new DatasetException(RESTCodes.DatasetErrorCode.PATH_NOT_FOUND, Level.FINE); @@ -206,7 +207,7 @@ public InodeDTO buildBlob(UriInfo uriInfo, ResourceRequest resourceRequest, User * @return */ public InodeDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { Inode parent = datasetPath.getInode(); if (parent == null) { throw new DatasetException(RESTCodes.DatasetErrorCode.PATH_NOT_FOUND, Level.FINE); @@ -219,7 +220,7 @@ public InodeDTO buildItems(UriInfo uriInfo, ResourceRequest resourceRequest, Use private InodeDTO build(UriInfo uriInfo, InodeDTO dto, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, Inode parent) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { uri(dto, uriInfo); Users dirOwner = userFacade.findByUsername(parent.getHdfsUser().getUsername()); datasetHelper.checkResourceRequestLimit(resourceRequest, parent.getChildrenNum()); @@ -229,7 +230,7 @@ private InodeDTO build(UriInfo uriInfo, InodeDTO dto, ResourceRequest resourceRe private InodeDTO items(UriInfo uriInfo, InodeDTO dto, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, Inode parent, Users dirOwner) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { expand(dto, resourceRequest); AbstractFacade.CollectionInfo collectionInfo; if (dto.isExpand()) { @@ -243,7 +244,7 @@ private InodeDTO items(UriInfo uriInfo, InodeDTO dto, ResourceRequest resourceRe private InodeDTO items(UriInfo uriInfo, InodeDTO dto, ResourceRequest resourceRequest, Users user, DatasetPath datasetPath, List inodes, Users dirOwner) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { if (inodes != null && !inodes.isEmpty()) { for(Inode inode : inodes) { dto.addItem(buildStat(uriInfo, resourceRequest, user, datasetPath, inode, dirOwner)); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/tags/DatasetTagsResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/tags/DatasetTagsResource.java index a612ed686d..a2ac1003ad 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/tags/DatasetTagsResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/dataset/tags/DatasetTagsResource.java @@ -28,6 +28,7 @@ import io.hops.hopsworks.common.dataset.util.DatasetPath; import io.hops.hopsworks.common.tags.AttachTagResult; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.jwt.annotation.JWTRequired; @@ -102,7 +103,7 @@ public Response putTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType, @ApiParam(value = "Value to set for the tag") String value) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); @@ -130,7 +131,7 @@ public Response bulkPutTags(@Context SecurityContext sc, @Context UriInfo uriInf @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType, TagsDTO tags) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); @@ -170,7 +171,7 @@ public Response getTags(@Context SecurityContext sc, @Context UriInfo uriInfo, @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAGS); @@ -195,7 +196,7 @@ public Response getTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, SchematizedTagException, MetadataException { + throws DatasetException, SchematizedTagException, MetadataException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); @@ -218,7 +219,7 @@ public Response deleteTags(@Context SecurityContext sc, @Context HttpServletRequest req, @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); @@ -242,7 +243,7 @@ public Response deleteTag(@Context SecurityContext sc, @PathParam("schemaName") String schemaName, @PathParam("path") String path, @QueryParam("datasetType") DatasetType datasetType) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { DatasetPath datasetPath = datasetHelper.getDatasetPath(project, path, datasetType); Users user = jWTHelper.getUserPrincipal(sc); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreKeywordResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreKeywordResource.java index fe6133635b..b0d300fdf9 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreKeywordResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreKeywordResource.java @@ -27,6 +27,7 @@ import io.hops.hopsworks.common.featurestore.keyword.KeywordDTO; import io.hops.hopsworks.common.featurestore.trainingdatasets.TrainingDatasetController; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.jwt.annotation.JWTRequired; import io.hops.hopsworks.persistence.entity.featurestore.Featurestore; @@ -116,7 +117,7 @@ public void setFeatureView(String name, Integer version) throws FeaturestoreExce public Response getKeywords(@Context SecurityContext sc, @Context HttpServletRequest req, @Context UriInfo uriInfo) - throws FeaturestoreException, MetadataException { + throws FeaturestoreException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.KEYWORDS); @@ -147,7 +148,7 @@ public Response getKeywords(@Context SecurityContext sc, public Response replaceKeywords(@Context SecurityContext sc, @Context HttpServletRequest req, @Context UriInfo uriInfo, KeywordDTO keywordDTO) - throws FeaturestoreException, MetadataException { + throws FeaturestoreException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.KEYWORDS); @@ -178,7 +179,7 @@ public Response deleteKeywords(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @QueryParam("keyword") String keyword) - throws FeaturestoreException, MetadataException { + throws FeaturestoreException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.KEYWORDS); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreService.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreService.java index 28ccffa1b7..68a36a817b 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreService.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/FeaturestoreService.java @@ -36,6 +36,7 @@ import io.hops.hopsworks.common.featurestore.settings.FeaturestoreClientSettingsDTO; import io.hops.hopsworks.common.util.Settings; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.jwt.annotation.JWTRequired; import io.hops.hopsworks.persistence.entity.project.Project; import io.hops.hopsworks.persistence.entity.user.security.apiKey.ApiScope; @@ -297,7 +298,7 @@ public FsQueryConstructorResource constructQuery() { @ApiOperation(value = "Get available keywords for the featurestore", response = KeywordDTO.class) public Response getUsedKeywords(@Context SecurityContext sc, @Context HttpServletRequest req, - @Context UriInfo uriInfo) throws FeaturestoreException { + @Context UriInfo uriInfo) throws FeaturestoreException, GenericException { List keywords = keywordControllerIface.getUsedKeywords(); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.KEYWORDS); KeywordDTO dto = featurestoreKeywordBuilder.build(uriInfo, resourceRequest, project, keywords); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewBuilder.java index c3fa27348b..0c4fe23d7d 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewBuilder.java @@ -39,6 +39,7 @@ import io.hops.hopsworks.common.hdfs.Utils; import io.hops.hopsworks.exceptions.DatasetException; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.exceptions.ServiceException; @@ -127,7 +128,8 @@ private void setQuery(Project project, Users user, QueryDTO queryDTO, FeatureVie public FeatureViewDTO build(List featureViews, ResourceRequest resourceRequest, Project project, Users user, UriInfo uriInfo) - throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException { + throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException, + GenericException { FeatureViewDTO featureViewDTO = new FeatureViewDTO(); featureViewDTO.setHref(uriInfo.getRequestUri()); @@ -147,7 +149,8 @@ public FeatureViewDTO build(List featureViews, ResourceRequest reso public FeatureViewDTO build(FeatureView featureView, ResourceRequest resourceRequest, Project project, Users user, UriInfo uriInfo) - throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException { + throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException, + GenericException { FeatureViewDTO base = convertToDTO(featureView); if (resourceRequest != null) { if (resourceRequest.contains(ResourceRequest.Name.QUERY_STRING)) { diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewResource.java index 06f7393e50..184e651774 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/featureview/FeatureViewResource.java @@ -26,6 +26,7 @@ import io.hops.hopsworks.common.featurestore.featureview.FeatureViewController; import io.hops.hopsworks.exceptions.DatasetException; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.ProvenanceException; import io.hops.hopsworks.exceptions.SchematizedTagException; @@ -99,7 +100,7 @@ public Response create( @Context UriInfo uriInfo, FeatureViewDTO featureViewDTO) throws FeaturestoreException, ProvenanceException, ServiceException, IOException, - SchematizedTagException, MetadataException, DatasetException { + SchematizedTagException, MetadataException, DatasetException, GenericException { if (featureViewDTO == null) { throw new IllegalArgumentException("Input JSON for creating a new Feature View cannot be null"); } @@ -136,7 +137,7 @@ public Response getAll( @BeanParam FeatureViewBeanParam param ) throws FeaturestoreException, ServiceException, MetadataException, DatasetException, - SchematizedTagException { + SchematizedTagException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = makeResourceRequest(param); List featureViews = featureViewController.getByFeatureStore(featurestore, @@ -169,7 +170,7 @@ public Response getByName( @PathParam("name") String name ) throws FeaturestoreException, ServiceException, MetadataException, DatasetException, - SchematizedTagException { + SchematizedTagException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = makeResourceRequest(param); List featureViews = featureViewController.getByNameAndFeatureStore(name, featurestore, @@ -205,7 +206,7 @@ public Response getByNameVersion( @PathParam("version") Integer version ) throws FeaturestoreException, ServiceException, MetadataException, DatasetException, - SchematizedTagException { + SchematizedTagException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = makeResourceRequest(param); FeatureView featureView = featureViewController.getByNameVersionAndFeatureStore(name, version, featurestore); @@ -290,7 +291,7 @@ public Response update( @PathParam("version") Integer version, FeatureViewDTO featureViewDTO) throws FeaturestoreException, ServiceException, - SchematizedTagException, MetadataException, DatasetException { + SchematizedTagException, MetadataException, DatasetException, GenericException { if (featureViewDTO == null) { throw new IllegalArgumentException("Input JSON for updating a Feature View cannot be null"); } diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/tag/FeatureStoreTagResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/tag/FeatureStoreTagResource.java index f7312e8e3c..f516dda839 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/tag/FeatureStoreTagResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/tag/FeatureStoreTagResource.java @@ -28,6 +28,7 @@ import io.hops.hopsworks.common.tags.TagControllerIface; import io.hops.hopsworks.common.tags.TagsDTO; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.jwt.annotation.JWTRequired; @@ -112,7 +113,7 @@ public Response putTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name, @ApiParam(value = "Value to set for the tag") String value) - throws MetadataException, SchematizedTagException, DatasetException { + throws MetadataException, SchematizedTagException, DatasetException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); AttachTagResult result = tagController.upsert(user, getDatasetPath(), name, value); @@ -139,7 +140,7 @@ public Response putTag(@Context SecurityContext sc, public Response bulkPutTags(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, TagsDTO tags) - throws MetadataException, SchematizedTagException, DatasetException { + throws MetadataException, SchematizedTagException, DatasetException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); AttachTagResult result; @@ -175,7 +176,7 @@ private Map tagsToMap(TagsDTO tags) { public Response getTags(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAGS); @@ -198,7 +199,7 @@ public Response getTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAGS); @@ -218,7 +219,7 @@ public Response getTag(@Context SecurityContext sc, @Context UriInfo uriInfo, allowedUserRoles = {"HOPS_ADMIN", "HOPS_USER", "HOPS_SERVICE_USER"}) public Response deleteTags(@Context SecurityContext sc, @Context HttpServletRequest req) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); tagController.deleteAll(user, getDatasetPath()); @@ -237,7 +238,7 @@ public Response deleteTags(@Context SecurityContext sc, public Response deleteTag(@Context SecurityContext sc, @Context HttpServletRequest req, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); tagController.delete(user, getDatasetPath(), name); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetDTOBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetDTOBuilder.java index a60f50c934..11cfce4c46 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetDTOBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetDTOBuilder.java @@ -28,6 +28,7 @@ import io.hops.hopsworks.common.featurestore.trainingdatasets.TrainingDatasetDTO; import io.hops.hopsworks.exceptions.DatasetException; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.exceptions.ServiceException; @@ -63,8 +64,8 @@ public class TrainingDatasetDTOBuilder { public TrainingDatasetDTO build(Users user, Project project, TrainingDataset trainingDataset, UriInfo uriInfo,ResourceRequest resourceRequest) throws - FeaturestoreException, ServiceException, SchematizedTagException, MetadataException, DatasetException, - IOException { + FeaturestoreException, ServiceException, SchematizedTagException, MetadataException, DatasetException, + IOException, GenericException { TrainingDatasetDTO trainingDatasetDTO = trainingDatasetController.convertTrainingDatasetToDTO(user, project, trainingDataset, true); if (resourceRequest != null) { @@ -93,8 +94,8 @@ public TrainingDatasetDTO build(Users user, Project project, TrainingDataset tra public TrainingDatasetDTO build(Users user, Project project, List trainingDatasets, UriInfo uriInfo, ResourceRequest resourceRequest) - throws FeaturestoreException, ServiceException, SchematizedTagException, MetadataException, DatasetException, - IOException { + throws FeaturestoreException, ServiceException, SchematizedTagException, MetadataException, DatasetException, + IOException, GenericException { TrainingDatasetDTO trainingDatasetDTO = new TrainingDatasetDTO(); trainingDatasetDTO.setCount((long) trainingDatasets.size()); trainingDatasetDTO.setHref(uriInfo.getRequestUri()); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetResource.java index 99ad971b4c..3530a44eba 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/featurestore/trainingdataset/TrainingDatasetResource.java @@ -146,7 +146,7 @@ public Response getAll( @BeanParam TrainingDatasetExpansionBeanParam param ) throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException, - IOException { + IOException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); List trainingDatasets = trainingDatasetController.getTrainingDatasetByFeatureView(featureView); @@ -178,7 +178,7 @@ public Response getByVersion( @PathParam("version") Integer version ) throws FeaturestoreException, ServiceException, MetadataException, DatasetException, SchematizedTagException, - IOException { + IOException, GenericException { Users user = jWTHelper.getUserPrincipal(sc); TrainingDataset trainingDataset = trainingDatasetController.getTrainingDatasetByFeatureViewAndVersion(featureView, version); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryBuilder.java index b2c16bb61f..fca81baded 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryBuilder.java @@ -69,7 +69,7 @@ public ModelRegistryDTO expand(ModelRegistryDTO dto, ResourceRequest resourceReq //Build collection public ModelRegistryDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, Project project) - throws GenericException, ModelRegistryException, SchematizedTagException, MetadataException { + throws GenericException, ModelRegistryException, SchematizedTagException, MetadataException { ModelRegistryDTO dto = new ModelRegistryDTO(); uri(dto, uriInfo, project); expand(dto, resourceRequest); @@ -99,7 +99,7 @@ public ModelRegistryDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, //Build specific public ModelRegistryDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, Users user, Project userProject, Project modelRegistryProject) throws GenericException, ModelRegistryException, - SchematizedTagException, MetadataException { + SchematizedTagException, MetadataException { ModelRegistryDTO dto = new ModelRegistryDTO(); uri(dto, uriInfo, userProject, modelRegistryProject); expand(dto, resourceRequest); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryResource.java index 9f2662e5f8..8c611cfb1d 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryResource.java @@ -89,7 +89,7 @@ public Response getAll( @BeanParam Pagination pagination, @Context UriInfo uriInfo, @Context SecurityContext sc) throws GenericException, ModelRegistryException, SchematizedTagException, - MetadataException { + MetadataException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.MODELREGISTRIES); resourceRequest.setExpansions(modelRegistryBeanParam.getExpansions().getResources()); @@ -114,7 +114,7 @@ public Response get ( @BeanParam Pagination pagination, @Context UriInfo uriInfo, @Context SecurityContext sc) throws GenericException, ModelRegistryException, SchematizedTagException, - MetadataException { + MetadataException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.MODELREGISTRIES); resourceRequest.setExpansions(modelRegistryBeanParam.getExpansions().getResources()); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryTagResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryTagResource.java index 2533a6fcec..fdc337a057 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryTagResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/ModelRegistryTagResource.java @@ -28,6 +28,7 @@ import io.hops.hopsworks.common.tags.TagControllerIface; import io.hops.hopsworks.common.tags.TagsDTO; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.jwt.annotation.JWTRequired; @@ -111,7 +112,7 @@ public Response putTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name, @ApiParam(value = "Value to set for the tag") String value) - throws MetadataException, SchematizedTagException, DatasetException { + throws MetadataException, SchematizedTagException, DatasetException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); AttachTagResult result = tagController.upsert(user, getDatasetPath(), name, value); @@ -138,7 +139,7 @@ public Response putTag(@Context SecurityContext sc, public Response bulkPutTags(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, TagsDTO tags) - throws MetadataException, SchematizedTagException, DatasetException { + throws MetadataException, SchematizedTagException, DatasetException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); AttachTagResult result; @@ -174,7 +175,7 @@ public Response bulkPutTags(@Context SecurityContext sc, @Context UriInfo uriInf public Response getTags(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAGS); @@ -197,7 +198,7 @@ public Response getTag(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name, @BeanParam TagsExpansionBeanParam tagsExpansionBeanParam) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAGS); @@ -217,7 +218,7 @@ public Response getTag(@Context SecurityContext sc, @Context UriInfo uriInfo, allowedUserRoles = {"HOPS_ADMIN", "HOPS_USER", "HOPS_SERVICE_USER"}) public Response deleteTags(@Context SecurityContext sc, @Context HttpServletRequest req) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); tagController.deleteAll(user, getDatasetPath()); @@ -236,7 +237,7 @@ public Response deleteTags(@Context SecurityContext sc, public Response deleteTag(@Context SecurityContext sc, @Context HttpServletRequest req, @ApiParam(value = "Name of the tag", required = true) @PathParam("name") String name) - throws DatasetException, MetadataException { + throws DatasetException, MetadataException, GenericException { Users user = jwtHelper.getUserPrincipal(sc); tagController.delete(user, getDatasetPath(), name); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsBuilder.java index 0a81f3dfdc..2d3eb097af 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsBuilder.java @@ -30,7 +30,6 @@ import io.hops.hopsworks.common.dataset.FilePreviewMode; import io.hops.hopsworks.common.dataset.util.DatasetHelper; import io.hops.hopsworks.common.dataset.util.DatasetPath; -import io.hops.hopsworks.common.featurestore.FeaturestoreFacade; import io.hops.hopsworks.common.hdfs.HdfsUsersController; import io.hops.hopsworks.common.provenance.core.Provenance; import io.hops.hopsworks.common.provenance.state.ProvStateParamBuilder; @@ -88,8 +87,6 @@ public class ModelsBuilder { @EJB private ProjectTeamFacade projectTeamFacade; @EJB - private FeaturestoreFacade featurestoreFacade; - @EJB private ModelsController modelsController; @EJB private InodeBuilder inodeBuilder; @@ -138,7 +135,7 @@ public ModelDTO build(UriInfo uriInfo, Project userProject, Project modelRegistryProject ) - throws ModelRegistryException, GenericException, SchematizedTagException, MetadataException { + throws ModelRegistryException, GenericException, SchematizedTagException, MetadataException { ModelDTO dto = new ModelDTO(); uri(dto, uriInfo, userProject, modelRegistryProject); expand(dto, resourceRequest); @@ -194,7 +191,7 @@ public ModelDTO build(UriInfo uriInfo, Project modelRegistryProject, ProvStateDTO fileProvenanceHit, String modelsFolder) throws DatasetException, ModelRegistryException, SchematizedTagException, - MetadataException { + MetadataException, GenericException { ModelDTO modelDTO = new ModelDTO(); uri(modelDTO, uriInfo, userProject, modelRegistryProject, fileProvenanceHit); if (expand(modelDTO, resourceRequest).isExpand()) { diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsResource.java index a2948e84b9..7d95cd2451 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/modelregistry/models/ModelsResource.java @@ -122,7 +122,7 @@ public Response getAll( @BeanParam ModelsBeanParam modelsBeanParam, @Context UriInfo uriInfo, @Context SecurityContext sc) - throws ModelRegistryException, GenericException, SchematizedTagException, MetadataException { + throws ModelRegistryException, GenericException, SchematizedTagException, MetadataException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.MODELS); resourceRequest.setOffset(pagination.getOffset()); @@ -148,8 +148,8 @@ public Response get ( @BeanParam ModelsBeanParam modelsBeanParam, @Context UriInfo uriInfo, @Context SecurityContext sc) - throws ProvenanceException, ModelRegistryException, DatasetException, GenericException, - SchematizedTagException, MetadataException { + throws ProvenanceException, ModelRegistryException, DatasetException, GenericException, + SchematizedTagException, MetadataException { Users user = jwtHelper.getUserPrincipal(sc); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.MODELS); resourceRequest.setExpansions(modelsBeanParam.getExpansions().getResources()); diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/provenance/ops/ProvLinksBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/provenance/ops/ProvLinksBuilder.java index 89f7c1c80a..b5d66a2ba9 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/provenance/ops/ProvLinksBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/provenance/ops/ProvLinksBuilder.java @@ -35,7 +35,7 @@ public class ProvLinksBuilder { private ProvOpsControllerIface opsProvCtrl; public ProvLinksDTO build(Project project, ProvLinksBeanParams opsParams, PaginationParams pagParams) - throws ProvenanceException, GenericException { + throws ProvenanceException, GenericException { ProvLinksParamBuilder paramBuilder = new ProvLinksParamBuilder() .onlyApps(opsParams.isOnlyApps()) .linkType(opsParams.isFullLink()) diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagBuilder.java index 161027e527..a04634e0ea 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagBuilder.java @@ -20,6 +20,7 @@ import io.hops.hopsworks.common.tags.TagControllerIface; import io.hops.hopsworks.common.tags.TagsDTO; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.user.Users; @@ -40,7 +41,7 @@ public class TagBuilder { private TagSchemasBuilder tagSchemasBuilder; public TagsDTO build(TagUri tagUri, ResourceRequest resourceRequest, Users user, DatasetPath path) - throws DatasetException, MetadataException, SchematizedTagException { + throws DatasetException, MetadataException, SchematizedTagException, GenericException { TagsDTO dto = tagUri.addUri(new TagsDTO(), path); if (resourceRequest != null && resourceRequest.contains(ResourceRequest.Name.TAGS)) { Map tags = tagController.getAll(user, path); @@ -58,7 +59,7 @@ public TagsDTO build(TagUri tagUri, ResourceRequest resourceRequest, Users user, public TagsDTO build(TagUri tagUri, ResourceRequest resourceRequest, Users user, DatasetPath path, String name) - throws SchematizedTagException, DatasetException, MetadataException { + throws SchematizedTagException, DatasetException, MetadataException, GenericException { TagsDTO dto = tagUri.addUri(new TagsDTO(), path, name); if (resourceRequest != null && resourceRequest.contains(ResourceRequest.Name.TAGS)) { String value = tagController.get(user, path, name); @@ -72,7 +73,7 @@ public TagsDTO build(TagUri tagUri, ResourceRequest resourceRequest, Users user, @Deprecated public TagsDTO buildAsMap(TagUri tagUri, ResourceRequest resourceRequest, Users user, DatasetPath path, String name) - throws SchematizedTagException, DatasetException, MetadataException { + throws SchematizedTagException, DatasetException, MetadataException, GenericException { TagsDTO dto = tagUri.addUri(new TagsDTO(), path, name); if (resourceRequest != null && resourceRequest.contains(ResourceRequest.Name.TAGS)) { TagsDTO item = tagUri.addUri(new TagsDTO(), path, name); @@ -104,7 +105,7 @@ public TagsDTO build(TagUri tagUri, DatasetPath path, Map tags) private TagsDTO buildFull(TagsDTO dto, TagUri tagUri, ResourceRequest resourceRequest, String name, String value) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { buildBase(dto, name, value); dto.setSchema(tagSchemasBuilder.build(tagUri.getUriInfo(), resourceRequest, name)); return dto; diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasBuilder.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasBuilder.java index e0843daa79..60fa57bda5 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasBuilder.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasBuilder.java @@ -21,6 +21,7 @@ import io.hops.hopsworks.common.dao.featurestore.tag.TagSchemasFacade; import io.hops.hopsworks.common.tags.SchemaDTO; import io.hops.hopsworks.common.tags.TagSchemasControllerIface; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.featurestore.tag.TagSchemas; import io.hops.hopsworks.restutils.RESTCodes; @@ -58,7 +59,7 @@ public SchemaDTO uriItems(SchemaDTO dto, UriInfo uriInfo, TagSchemas tag) { } public SchemaDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, String value) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { TagSchemas tag = tagSchemasFacade.findByName(value); if(tag == null) { throw new SchematizedTagException(RESTCodes.SchematizedTagErrorCode.TAG_SCHEMA_NOT_FOUND, Level.FINE); @@ -68,7 +69,7 @@ public SchemaDTO build(UriInfo uriInfo, ResourceRequest resourceRequest, String } public SchemaDTO build(UriInfo uriInfo, ResourceRequest resourceRequest) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { SchemaDTO dto = new SchemaDTO(); uri(dto, uriInfo); AbstractFacade.CollectionInfo collectionInfo = tagSchemasFacade.findAll(resourceRequest.getOffset(), @@ -78,7 +79,7 @@ public SchemaDTO build(UriInfo uriInfo, ResourceRequest resourceRequest) } private SchemaDTO items(SchemaDTO dto, UriInfo uriInfo, ResourceRequest resourceRequest, - List items) throws SchematizedTagException { + List items) throws SchematizedTagException, GenericException { ObjectMapper objectMapper = new ObjectMapper(); for(TagSchemas tag : items) { dto.addItem(buildItem(uriInfo, resourceRequest, tag, objectMapper)); @@ -88,7 +89,7 @@ private SchemaDTO items(SchemaDTO dto, UriInfo uriInfo, ResourceRequest resource private SchemaDTO buildItem(UriInfo uriInfo, ResourceRequest resourceRequest, TagSchemas tag, ObjectMapper objectMapper) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { SchemaDTO dto = new SchemaDTO(); uriItems(dto, uriInfo, tag); if (resourceRequest != null && resourceRequest.contains(ResourceRequest.Name.TAG_SCHEMAS)) { diff --git a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasResource.java b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasResource.java index bd106bff26..b02400e3a6 100644 --- a/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasResource.java +++ b/hopsworks-api/src/main/java/io/hops/hopsworks/api/tags/TagSchemasResource.java @@ -21,6 +21,7 @@ import io.hops.hopsworks.common.api.ResourceRequest; import io.hops.hopsworks.common.tags.SchemaDTO; import io.hops.hopsworks.common.tags.TagSchemasControllerIface; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.jwt.annotation.JWTRequired; import io.hops.hopsworks.persistence.entity.user.security.apiKey.ApiScope; @@ -72,7 +73,7 @@ public class TagSchemasResource { public Response getAll(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @BeanParam Pagination pagination, - @BeanParam TagsBeanParam tagsBeanParam) throws SchematizedTagException { + @BeanParam TagsBeanParam tagsBeanParam) throws SchematizedTagException, GenericException { ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAG_SCHEMAS); resourceRequest.setOffset(pagination.getOffset()); @@ -93,7 +94,7 @@ public Response getAll(@Context SecurityContext sc, @Context UriInfo uriInfo, public Response get(@Context SecurityContext sc, @Context UriInfo uriInfo, @Context HttpServletRequest req, @PathParam("name") String schemaName) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAG_SCHEMAS); SchemaDTO dto = tagSchemasBuilder.build(uriInfo, resourceRequest, schemaName); @@ -107,7 +108,7 @@ public Response get(@Context SecurityContext sc, @Context UriInfo uriInfo, public Response post(@Context SecurityContext sc, @Context UriInfo uriInfo, @QueryParam("name") String schemaName, String schema) - throws SchematizedTagException { + throws SchematizedTagException, GenericException { tagSchemasController.create(schemaName, schema); ResourceRequest resourceRequest = new ResourceRequest(ResourceRequest.Name.TAG_SCHEMAS); @@ -121,7 +122,7 @@ public Response post(@Context SecurityContext sc, @Context UriInfo uriInfo, @JWTRequired(acceptedTokens={Audience.API, Audience.JOB}, allowedUserRoles={"HOPS_ADMIN"}) @ApiKeyRequired( acceptedScopes = {ApiScope.FEATURESTORE}, allowedUserRoles={"HOPS_ADMIN"}) public Response delete(@Context SecurityContext sc, @Context UriInfo uriInfo, - @PathParam("name") String schemaName) { + @PathParam("name") String schemaName) throws GenericException { tagSchemasController.delete(schemaName); return Response.noContent().build(); diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerCommunity.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerCommunity.java index 65a5a07369..99bc56f96d 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerCommunity.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerCommunity.java @@ -17,10 +17,43 @@ package io.hops.hopsworks.common.featurestore.keyword; import io.hops.hopsworks.common.integrations.CommunityStereotype; +import io.hops.hopsworks.exceptions.GenericException; +import io.hops.hopsworks.persistence.entity.featurestore.featuregroup.Featuregroup; +import io.hops.hopsworks.persistence.entity.featurestore.featureview.FeatureView; +import io.hops.hopsworks.persistence.entity.featurestore.trainingdataset.TrainingDataset; +import io.hops.hopsworks.persistence.entity.project.Project; +import io.hops.hopsworks.persistence.entity.user.Users; +import io.hops.hopsworks.restutils.RESTCodes; import javax.ejb.Stateless; +import java.util.List; +import java.util.logging.Level; @Stateless @CommunityStereotype public class KeywordControllerCommunity implements KeywordControllerIface { + @Override + public List getAll(Project project, Users user, Featuregroup featureGroup, TrainingDataset trainingDataset, + FeatureView featureView) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public List replaceKeywords(Project project, Users user, Featuregroup featureGroup, + TrainingDataset trainingDataset, FeatureView featureView, List keywords) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public List deleteKeywords(Project project, Users user, Featuregroup featureGroup, + TrainingDataset trainingDataset, FeatureView featureView, List keywords) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public List getUsedKeywords() throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerIface.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerIface.java index 7f3b16502c..b42cc9707e 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerIface.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/featurestore/keyword/KeywordControllerIface.java @@ -17,6 +17,7 @@ package io.hops.hopsworks.common.featurestore.keyword; import io.hops.hopsworks.exceptions.FeaturestoreException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.persistence.entity.featurestore.featuregroup.Featuregroup; import io.hops.hopsworks.persistence.entity.featurestore.featureview.FeatureView; @@ -28,25 +29,16 @@ public interface KeywordControllerIface { - default List getAll(Project project, Users user, Featuregroup featureGroup, TrainingDataset trainingDataset, - FeatureView featureView) - throws FeaturestoreException, MetadataException { - throw new IllegalArgumentException("API not supported in the community edition"); - } - - default List replaceKeywords(Project project, Users user, Featuregroup featureGroup, - TrainingDataset trainingDataset, FeatureView featureView, List keywords) - throws FeaturestoreException, MetadataException { - throw new IllegalArgumentException("API not supported in the community edition"); - } - - default List deleteKeywords(Project project, Users user, Featuregroup featureGroup, - TrainingDataset trainingDataset, FeatureView featureView, List keywords) - throws FeaturestoreException, MetadataException { - throw new IllegalArgumentException("API not supported in the community edition"); - } - - default List getUsedKeywords() throws FeaturestoreException { - throw new IllegalArgumentException("API not supported in the community edition"); - } + List getAll(Project project, Users user, Featuregroup featureGroup, TrainingDataset trainingDataset, + FeatureView featureView) throws FeaturestoreException, MetadataException, GenericException; + + List replaceKeywords(Project project, Users user, Featuregroup featureGroup, TrainingDataset trainingDataset, + FeatureView featureView, List keywords) + throws FeaturestoreException, MetadataException, GenericException; + + List deleteKeywords(Project project, Users user, Featuregroup featureGroup, TrainingDataset trainingDataset, + FeatureView featureView, List keywords) + throws FeaturestoreException, MetadataException, GenericException; + + List getUsedKeywords() throws FeaturestoreException, GenericException; } \ No newline at end of file diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerIface.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerIface.java index 4314e800e6..8bf78b9f86 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerIface.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerIface.java @@ -20,28 +20,17 @@ import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.ProvenanceException; import io.hops.hopsworks.persistence.entity.project.Project; -import io.hops.hopsworks.restutils.RESTCodes; - -import java.util.logging.Level; public interface ProvOpsControllerIface { - default ProvOpsDTO provFileOpsList(Project project, ProvOpsParamBuilder params) - throws ProvenanceException, GenericException { - throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.FINE); - } - - default ProvOpsDTO provFileOpsCount(Project project, ProvOpsParamBuilder params) - throws ProvenanceException, GenericException { - throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.FINE); - } - - default ProvOpsDTO provFileOpsAggs(Project project, ProvOpsParamBuilder params) - throws ProvenanceException, GenericException { - throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.FINE); - } + ProvOpsDTO provFileOpsList(Project project, ProvOpsParamBuilder params) + throws ProvenanceException, GenericException; + + ProvOpsDTO provFileOpsCount(Project project, ProvOpsParamBuilder params) + throws ProvenanceException, GenericException; - default ProvLinksDTO provLinks(Project project, ProvLinksParamBuilder params, boolean filterAlive) - throws ProvenanceException, GenericException { - throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.FINE); - } + ProvOpsDTO provFileOpsAggs(Project project, ProvOpsParamBuilder params) + throws ProvenanceException, GenericException; + + ProvLinksDTO provLinks(Project project, ProvLinksParamBuilder params, boolean filterAlive) + throws ProvenanceException, GenericException; } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerImpl.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerImpl.java index e49b134f19..b778b3e620 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerImpl.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/provenance/ops/ProvOpsControllerImpl.java @@ -16,13 +16,42 @@ package io.hops.hopsworks.common.provenance.ops; import io.hops.hopsworks.common.integrations.CommunityStereotype; +import io.hops.hopsworks.common.provenance.ops.dto.ProvLinksDTO; +import io.hops.hopsworks.common.provenance.ops.dto.ProvOpsDTO; +import io.hops.hopsworks.exceptions.GenericException; +import io.hops.hopsworks.persistence.entity.project.Project; +import io.hops.hopsworks.restutils.RESTCodes; import javax.ejb.Stateless; import javax.ejb.TransactionAttribute; import javax.ejb.TransactionAttributeType; +import java.util.logging.Level; @Stateless @CommunityStereotype @TransactionAttribute(TransactionAttributeType.NEVER) public class ProvOpsControllerImpl implements ProvOpsControllerIface { + @Override + public ProvOpsDTO provFileOpsList(Project project, ProvOpsParamBuilder params) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public ProvOpsDTO provFileOpsCount(Project project, ProvOpsParamBuilder params) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public ProvOpsDTO provFileOpsAggs(Project project, ProvOpsParamBuilder params) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } + + @Override + public ProvLinksDTO provLinks(Project project, ProvLinksParamBuilder params, boolean filterAlive) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); + } } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagController.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagController.java index ee0a164382..1a11d29f9f 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagController.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagController.java @@ -17,44 +17,48 @@ import io.hops.hopsworks.common.dataset.util.DatasetPath; import io.hops.hopsworks.common.integrations.CommunityStereotype; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.persistence.entity.user.Users; +import io.hops.hopsworks.restutils.RESTCodes; import javax.ejb.Stateless; import javax.ejb.TransactionAttribute; import javax.ejb.TransactionAttributeType; import java.util.Map; +import java.util.logging.Level; @Stateless @CommunityStereotype @TransactionAttribute(TransactionAttributeType.NOT_SUPPORTED) public class TagController implements TagControllerIface { @Override - public String get(Users user, DatasetPath path, String name) { - throw new IllegalArgumentException("API not supported in the community edition"); + public String get(Users user, DatasetPath path, String name) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public Map getAll(Users user, DatasetPath path) { - throw new IllegalArgumentException("API not supported in the community edition"); + public Map getAll(Users user, DatasetPath path) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public AttachTagResult upsert(Users user, DatasetPath path, String name, String value) { - throw new IllegalArgumentException("API not supported in the community edition"); + public AttachTagResult upsert(Users user, DatasetPath path, String name, String value) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public AttachTagResult upsertAll(Users user, DatasetPath path, Map newTags) { - throw new IllegalArgumentException("API not supported in the community edition"); + public AttachTagResult upsertAll(Users user, DatasetPath path, Map newTags) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public void delete(Users user, DatasetPath path, String name) { - throw new IllegalArgumentException("API not supported in the community edition"); + public void delete(Users user, DatasetPath path, String name) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public void deleteAll(Users user, DatasetPath path) { - throw new IllegalArgumentException("API not supported in the community edition"); + public void deleteAll(Users user, DatasetPath path) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagControllerIface.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagControllerIface.java index a635dfc15c..3612a1d6b6 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagControllerIface.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagControllerIface.java @@ -17,6 +17,7 @@ import io.hops.hopsworks.common.dataset.util.DatasetPath; import io.hops.hopsworks.exceptions.DatasetException; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.MetadataException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.user.Users; @@ -25,20 +26,20 @@ public interface TagControllerIface { String get(Users user, DatasetPath path, String name) - throws DatasetException, MetadataException, SchematizedTagException; + throws DatasetException, MetadataException, SchematizedTagException, GenericException; Map getAll(Users user, DatasetPath path) - throws DatasetException, MetadataException; + throws DatasetException, MetadataException, GenericException; AttachTagResult upsert(Users user, DatasetPath path, String name, String value) - throws MetadataException, SchematizedTagException; + throws MetadataException, SchematizedTagException, GenericException; AttachTagResult upsertAll(Users user, DatasetPath path, Map newTags) - throws MetadataException, SchematizedTagException; + throws MetadataException, SchematizedTagException, GenericException; void delete(Users user, DatasetPath path, String name) - throws DatasetException, MetadataException; + throws DatasetException, MetadataException, GenericException; void deleteAll(Users user, DatasetPath path) - throws MetadataException, DatasetException; + throws MetadataException, DatasetException, GenericException; } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasController.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasController.java index 2d8766ee48..e2f90e02ef 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasController.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasController.java @@ -18,41 +18,45 @@ import com.fasterxml.jackson.databind.ObjectMapper; import io.hops.hopsworks.common.integrations.CommunityStereotype; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.persistence.entity.featurestore.tag.TagSchemas; +import io.hops.hopsworks.restutils.RESTCodes; import javax.ejb.Stateless; import javax.ejb.TransactionAttribute; import javax.ejb.TransactionAttributeType; import java.util.Map; +import java.util.logging.Level; @Stateless @CommunityStereotype @TransactionAttribute(TransactionAttributeType.NOT_SUPPORTED) public class TagSchemasController implements TagSchemasControllerIface { @Override - public void create(String name, String schema) { - throw new IllegalArgumentException("API not supported in the community edition"); + public void create(String name, String schema) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public void delete(String name) { - throw new IllegalArgumentException("API not supported in the community edition"); + public void delete(String name) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public void delete(TagSchemas tag) { - throw new IllegalArgumentException("API not supported in the community edition"); + public void delete(TagSchemas tag) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public Map getAll() { - throw new IllegalArgumentException("API not supported in the community edition"); + public Map getAll() throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public boolean schemaHasNestedTypes(String schema) { - throw new IllegalArgumentException("API not supported in the community edition"); + public boolean schemaHasNestedTypes(String schema) throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } @Override - public boolean schemaHasAdditionalRules(String name, String schema, ObjectMapper objectMapper) { - throw new IllegalArgumentException("API not supported in the community edition"); + public boolean schemaHasAdditionalRules(String name, String schema, ObjectMapper objectMapper) + throws GenericException { + throw new GenericException(RESTCodes.GenericErrorCode.ENTERPRISE_FEATURE, Level.INFO); } } diff --git a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasControllerIface.java b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasControllerIface.java index c626ebb68e..4e3107f746 100644 --- a/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasControllerIface.java +++ b/hopsworks-common/src/main/java/io/hops/hopsworks/common/tags/TagSchemasControllerIface.java @@ -17,18 +17,19 @@ package io.hops.hopsworks.common.tags; import com.fasterxml.jackson.databind.ObjectMapper; +import io.hops.hopsworks.exceptions.GenericException; import io.hops.hopsworks.exceptions.SchematizedTagException; import io.hops.hopsworks.persistence.entity.featurestore.tag.TagSchemas; import java.util.Map; public interface TagSchemasControllerIface { - void create(String name, String schema) throws SchematizedTagException; - void delete(String name); - void delete(TagSchemas tag); - Map getAll(); + void create(String name, String schema) throws SchematizedTagException, GenericException; + void delete(String name) throws GenericException; + void delete(TagSchemas tag) throws GenericException; + Map getAll() throws GenericException; - boolean schemaHasNestedTypes(String schema) throws SchematizedTagException; + boolean schemaHasNestedTypes(String schema) throws SchematizedTagException, GenericException; boolean schemaHasAdditionalRules(String name, String schema, ObjectMapper objectMapper) - throws SchematizedTagException; + throws SchematizedTagException, GenericException; } diff --git a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java index ea93f8de20..411d74f6bd 100644 --- a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java +++ b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java @@ -800,7 +800,7 @@ public enum GenericErrorCode implements RESTErrorCode { SECURITY_EXCEPTION(8, "A Java security error occurred.", Response.Status.INTERNAL_SERVER_ERROR), ENDPOINT_ANNOTATION_MISSING(9, "The requested endpoint did not have any project role annotation", Response.Status.SERVICE_UNAVAILABLE), - ENTERPRISE_FEATURE(10, "This feature is only available in the enterprise edition", Response.Status.BAD_REQUEST), + ENTERPRISE_FEATURE(10, "This feature is only available in the enterprise edition", Response.Status.NOT_IMPLEMENTED), NOT_AUTHORIZED_TO_ACCESS(11, "Project not accessible to user", Response.Status.BAD_REQUEST); private Integer code; From b4c8bfba7738ea93559764bf12d1cc4f1420e089 Mon Sep 17 00:00:00 2001 From: Alex Ormenisan Date: Fri, 9 Sep 2022 13:52:24 +0200 Subject: [PATCH 2/4] missing CORS class --- .../hopsworks/filters/AllowCORSFilter.java | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java diff --git a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java new file mode 100644 index 0000000000..16de653db1 --- /dev/null +++ b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java @@ -0,0 +1,35 @@ +/* + * This file is part of Hopsworks + * Copyright (C) 2020, Logical Clocks AB. All rights reserved + * + * Hopsworks is free software: you can redistribute it and/or modify it under the terms of + * the GNU Affero General Public License as published by the Free Software Foundation, + * either version 3 of the License, or (at your option) any later version. + * + * Hopsworks is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; + * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR + * PURPOSE. See the GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License along with this program. + * If not, see . + */ +package io.hops.hopsworks.filters; + +import javax.ws.rs.container.ContainerRequestContext; +import javax.ws.rs.container.ContainerResponseContext; +import javax.ws.rs.container.ContainerResponseFilter; +import javax.ws.rs.ext.Provider; +import java.io.IOException; + +@Provider +public class AllowCORSFilter implements ContainerResponseFilter { + + @Override + public void filter(ContainerRequestContext request, ContainerResponseContext response) throws IOException { + response.getHeaders().add("Access-Control-Allow-Origin", "*"); + response.getHeaders().add("Access-Control-Allow-Headers", "origin, content-type, accept, authorization"); + response.getHeaders().add("Access-Control-Expose-Headers", "authorization"); + response.getHeaders().add("Access-Control-Allow-Credentials", "true"); + response.getHeaders().add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD"); + } +} From 2a96fb727ee287557d4a65d921d18e2b01ca7ce2 Mon Sep 17 00:00:00 2001 From: Alex Ormenisan Date: Fri, 23 Sep 2022 17:41:07 +0200 Subject: [PATCH 3/4] fix license --- .../main/java/io/hops/hopsworks/filters/AllowCORSFilter.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java index 16de653db1..1ca223b775 100644 --- a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java +++ b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/filters/AllowCORSFilter.java @@ -1,6 +1,6 @@ /* * This file is part of Hopsworks - * Copyright (C) 2020, Logical Clocks AB. All rights reserved + * Copyright (C) 2022, Hopsworks AB. All rights reserved * * Hopsworks is free software: you can redistribute it and/or modify it under the terms of * the GNU Affero General Public License as published by the Free Software Foundation, From cf5f25a44d762bf13e973ca334547f65be4e22ab Mon Sep 17 00:00:00 2001 From: Alex Ormenisan Date: Thu, 29 Sep 2022 16:00:40 +0200 Subject: [PATCH 4/4] unsupported operation exception --- .../UnsupportedOperationException.java | 43 +++++++++++++++++++ .../hops/hopsworks/restutils/RESTCodes.java | 36 +++++++++++++++- 2 files changed, 78 insertions(+), 1 deletion(-) create mode 100644 hopsworks-rest-utils/src/main/java/io/hops/hopsworks/exceptions/UnsupportedOperationException.java diff --git a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/exceptions/UnsupportedOperationException.java b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/exceptions/UnsupportedOperationException.java new file mode 100644 index 0000000000..2e206ef84c --- /dev/null +++ b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/exceptions/UnsupportedOperationException.java @@ -0,0 +1,43 @@ +/* + * This file is part of Hopsworks + * Copyright (C) 2022, Hopsworks AB. All rights reserved + * + * Hopsworks is free software: you can redistribute it and/or modify it under the terms of + * the GNU Affero General Public License as published by the Free Software Foundation, + * either version 3 of the License, or (at your option) any later version. + * + * Hopsworks is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; + * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR + * PURPOSE. See the GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License along with this program. + * If not, see . + */ +package io.hops.hopsworks.exceptions; + +import io.hops.hopsworks.restutils.RESTCodes; +import io.hops.hopsworks.restutils.RESTException; + +import java.util.logging.Level; + +public class UnsupportedOperationException extends RESTException { + + public UnsupportedOperationException(RESTCodes.UnsupportedOperationErrorCode code, Level level) { + super(code, level); + } + + public UnsupportedOperationException(RESTCodes.UnsupportedOperationErrorCode code, Level level, String usrMsg) { + super(code, level, usrMsg); + } + + public UnsupportedOperationException(RESTCodes.UnsupportedOperationErrorCode code, Level level, String usrMsg, + String devMsg) { + super(code, level, usrMsg, devMsg); + } + + public UnsupportedOperationException(RESTCodes.UnsupportedOperationErrorCode code, Level level, String usrMsg, + String devMsg, Throwable throwable) { + super(code, level, usrMsg, devMsg, throwable); + } + +} diff --git a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java index 411d74f6bd..8384100503 100644 --- a/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java +++ b/hopsworks-rest-utils/src/main/java/io/hops/hopsworks/restutils/RESTCodes.java @@ -800,7 +800,6 @@ public enum GenericErrorCode implements RESTErrorCode { SECURITY_EXCEPTION(8, "A Java security error occurred.", Response.Status.INTERNAL_SERVER_ERROR), ENDPOINT_ANNOTATION_MISSING(9, "The requested endpoint did not have any project role annotation", Response.Status.SERVICE_UNAVAILABLE), - ENTERPRISE_FEATURE(10, "This feature is only available in the enterprise edition", Response.Status.NOT_IMPLEMENTED), NOT_AUTHORIZED_TO_ACCESS(11, "Project not accessible to user", Response.Status.BAD_REQUEST); private Integer code; @@ -2355,4 +2354,39 @@ public int getRange() { return range; } } + + public enum UnsupportedOperationErrorCode implements RESTErrorCode { + ENTERPRISE_FEATURE(1, "This feature is only available in the enterprise edition", Response.Status.NOT_IMPLEMENTED); + + private Integer code; + private String message; + private Response.Status respStatus; + public final int range = 400000; + + UnsupportedOperationErrorCode(Integer code, String message, Response.Status respStatus) { + this.code = range + code; + this.message = message; + this.respStatus = respStatus; + } + + @Override + public Integer getCode() { + return code; + } + + @Override + public String getMessage() { + return message; + } + + public Response.StatusType getRespStatus() { + return respStatus; + } + + @Override + public int getRange() { + return range; + } + } + }