commented the testing case
This commit is contained in:
parent
478a4c157e
commit
fc9e82b6a6
|
@ -44,18 +44,22 @@ import com.liferay.portal.kernel.log.LogFactoryUtil;
|
|||
|
||||
/**
|
||||
* Endpoint for sending update records information to GRSF KnowledgeBase.
|
||||
*
|
||||
* @author Costantino Perciante at ISTI-CNR (costantino.perciante@isti.cnr.it)
|
||||
*/
|
||||
public class GRSFNotificationService extends RemoteServiceServlet implements GRSFManageWidgetService {
|
||||
|
||||
private static final long serialVersionUID = -4534905087994875893L;
|
||||
private static final Log logger = LogFactoryUtil.getLog(GRSFNotificationService.class);
|
||||
//private static final Logger logger = LoggerFactory.getLogger(GRSFNotificationService.class);
|
||||
// private static final Logger logger =
|
||||
// LoggerFactory.getLogger(GRSFNotificationService.class);
|
||||
|
||||
/**
|
||||
* Instanciate the ckan util library.
|
||||
* Since it needs the scope, we need to check if it is null or not
|
||||
* @param discoverScope if you want to the discover the utils library in this specified scope
|
||||
* Instanciate the ckan util library. Since it needs the scope, we need to check
|
||||
* if it is null or not
|
||||
*
|
||||
* @param discoverScope if you want to the discover the utils library in this
|
||||
* specified scope
|
||||
* @return DataCatalogue object
|
||||
* @throws Exception
|
||||
*/
|
||||
|
@ -63,7 +67,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
String currentScope = Utils.getCurrentContext(getThreadLocalRequest(), true);
|
||||
DataCatalogue instance = null;
|
||||
try {
|
||||
String scopeInWhichDiscover = discoverScope != null && !discoverScope.isEmpty() ? discoverScope : currentScope;
|
||||
String scopeInWhichDiscover = discoverScope != null && !discoverScope.isEmpty() ? discoverScope
|
||||
: currentScope;
|
||||
logger.debug("Discovering ckan utils library into scope " + scopeInWhichDiscover);
|
||||
instance = DataCatalogueFactory.getFactory().getUtilsPerScope(scopeInWhichDiscover);
|
||||
} catch (Exception e) {
|
||||
|
@ -74,117 +79,118 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
}
|
||||
|
||||
@Override
|
||||
public ManageProductBean getProductBeanById(String productIdentifier, boolean requestForRevertingMerge) throws Exception {
|
||||
public ManageProductBean getProductBeanById(String productIdentifier, boolean requestForRevertingMerge)
|
||||
throws Exception {
|
||||
|
||||
ManageProductBean toReturn = null;
|
||||
|
||||
// check into user's session first
|
||||
HttpSession httpSession = getThreadLocalRequest().getSession();
|
||||
|
||||
// testing case...
|
||||
if(!Utils.isIntoPortal()){
|
||||
|
||||
Thread.sleep(2000);
|
||||
|
||||
toReturn = new ManageProductBean();
|
||||
toReturn.setCatalogueIdentifier(UUID.randomUUID().toString());
|
||||
List<ConnectedBean> connectTo = new ArrayList<>();
|
||||
// these are the records alread connected
|
||||
connectTo.add(new ConnectedBean(
|
||||
"uuid-of-a-connected-bean",
|
||||
"Random description",
|
||||
"Random shortName",
|
||||
"Random Title",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-of-a-connected-bean",
|
||||
"semantic identifier of the record",
|
||||
"Fishery"
|
||||
));
|
||||
toReturn.setCurrentConnections(connectTo);
|
||||
|
||||
// these are the "suggested connections"
|
||||
List<ConnectedBean> suggestionsForConnections = new ArrayList<>();
|
||||
suggestionsForConnections.add(new ConnectedBean(
|
||||
"uuid-of-a-connected-bean-suggested",
|
||||
"Random description",
|
||||
"Random shortName",
|
||||
"Random Title",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-of-a-connected-bean-suggested",
|
||||
"semantic identifier of the record suggested for connection",
|
||||
"Fishery"
|
||||
));
|
||||
toReturn.setSuggestedByKnowledgeBaseConnections(suggestionsForConnections);
|
||||
toReturn.setDomain("Stock");
|
||||
toReturn.setCurrentGrsfType("Assessment Unit");
|
||||
toReturn.setKnowledgeBaseId("91f1e413-dc9f-3b4e-b1c5-0e8560177253");
|
||||
toReturn.setShortName("Widow rockfish - US West Coast");
|
||||
toReturn.setShortNameUpdated("Widow rockfish - US West Coast");
|
||||
toReturn.setTitle("sebastes entomelas FAO 77 FAO 67");
|
||||
toReturn.setTraceabilityFlag(true);
|
||||
toReturn.setCurrentStatus(Status.Pending);
|
||||
toReturn.setSemanticIdentifier("asfis:WRO+fao:67;FAO");
|
||||
ArrayList<SourceRecord> sources = new ArrayList<SourceRecord>();
|
||||
sources.add(new SourceRecord("RAM", "http://www.google.it"));
|
||||
sources.add(new SourceRecord("FIRMS", "http://www.google.it"));
|
||||
sources.add(new SourceRecord("FishSource", "http://www.google.it"));
|
||||
toReturn.setSources(sources);
|
||||
List<SimilarGRSFRecord> similarGrsfRecords = new ArrayList<SimilarGRSFRecord>();
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-1",
|
||||
"description similar record",
|
||||
"short name similar record 1",
|
||||
"title similar record 1",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-1",
|
||||
"semantic identifier record 1",
|
||||
"Stock 1"
|
||||
));
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-2",
|
||||
"description similar record",
|
||||
"short name similar record 2",
|
||||
"title similar record 2",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-2",
|
||||
"semantic identifier record 2",
|
||||
"Stock 2"
|
||||
));
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-3",
|
||||
"description similar record",
|
||||
"short name similar record 3",
|
||||
"title similar record 3",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-3",
|
||||
"semantic identifier record 3",
|
||||
"Stock 3"
|
||||
));
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-4",
|
||||
"description similar record",
|
||||
"short name similar record 4",
|
||||
"title similar record 4",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-4",
|
||||
"semantic identifier record 4",
|
||||
"Stock 4"
|
||||
));
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-5",
|
||||
"description similar record",
|
||||
"short name similar record 5",
|
||||
"title similar record 5",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-5",
|
||||
"semantic identifier record 5",
|
||||
"Stock 5"
|
||||
));
|
||||
similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
"uuid-similar-record-6",
|
||||
"description similar record",
|
||||
"short name similar record 6",
|
||||
"title similar record 6",
|
||||
"http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-6",
|
||||
"semantic identifier record 6",
|
||||
"Stock 6"
|
||||
));
|
||||
toReturn.setSimilarGrsfRecords(similarGrsfRecords);
|
||||
|
||||
}else{
|
||||
// // testing case...
|
||||
// if(!Utils.isIntoPortal()){
|
||||
//
|
||||
// Thread.sleep(2000);
|
||||
//
|
||||
// toReturn = new ManageProductBean();
|
||||
// toReturn.setCatalogueIdentifier(UUID.randomUUID().toString());
|
||||
// List<ConnectedBean> connectTo = new ArrayList<>();
|
||||
// // these are the records alread connected
|
||||
// connectTo.add(new ConnectedBean(
|
||||
// "uuid-of-a-connected-bean",
|
||||
// "Random description",
|
||||
// "Random shortName",
|
||||
// "Random Title",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-of-a-connected-bean",
|
||||
// "semantic identifier of the record",
|
||||
// "Fishery"
|
||||
// ));
|
||||
// toReturn.setCurrentConnections(connectTo);
|
||||
//
|
||||
// // these are the "suggested connections"
|
||||
// List<ConnectedBean> suggestionsForConnections = new ArrayList<>();
|
||||
// suggestionsForConnections.add(new ConnectedBean(
|
||||
// "uuid-of-a-connected-bean-suggested",
|
||||
// "Random description",
|
||||
// "Random shortName",
|
||||
// "Random Title",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-of-a-connected-bean-suggested",
|
||||
// "semantic identifier of the record suggested for connection",
|
||||
// "Fishery"
|
||||
// ));
|
||||
// toReturn.setSuggestedByKnowledgeBaseConnections(suggestionsForConnections);
|
||||
// toReturn.setDomain("Stock");
|
||||
// toReturn.setCurrentGrsfType("Assessment Unit");
|
||||
// toReturn.setKnowledgeBaseId("91f1e413-dc9f-3b4e-b1c5-0e8560177253");
|
||||
// toReturn.setShortName("Widow rockfish - US West Coast");
|
||||
// toReturn.setShortNameUpdated("Widow rockfish - US West Coast");
|
||||
// toReturn.setTitle("sebastes entomelas FAO 77 FAO 67");
|
||||
// toReturn.setTraceabilityFlag(true);
|
||||
// toReturn.setCurrentStatus(Status.Pending);
|
||||
// toReturn.setSemanticIdentifier("asfis:WRO+fao:67;FAO");
|
||||
// ArrayList<SourceRecord> sources = new ArrayList<SourceRecord>();
|
||||
// sources.add(new SourceRecord("RAM", "http://www.google.it"));
|
||||
// sources.add(new SourceRecord("FIRMS", "http://www.google.it"));
|
||||
// sources.add(new SourceRecord("FishSource", "http://www.google.it"));
|
||||
// toReturn.setSources(sources);
|
||||
// List<SimilarGRSFRecord> similarGrsfRecords = new ArrayList<SimilarGRSFRecord>();
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-1",
|
||||
// "description similar record",
|
||||
// "short name similar record 1",
|
||||
// "title similar record 1",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-1",
|
||||
// "semantic identifier record 1",
|
||||
// "Stock 1"
|
||||
// ));
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-2",
|
||||
// "description similar record",
|
||||
// "short name similar record 2",
|
||||
// "title similar record 2",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-2",
|
||||
// "semantic identifier record 2",
|
||||
// "Stock 2"
|
||||
// ));
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-3",
|
||||
// "description similar record",
|
||||
// "short name similar record 3",
|
||||
// "title similar record 3",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-3",
|
||||
// "semantic identifier record 3",
|
||||
// "Stock 3"
|
||||
// ));
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-4",
|
||||
// "description similar record",
|
||||
// "short name similar record 4",
|
||||
// "title similar record 4",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-4",
|
||||
// "semantic identifier record 4",
|
||||
// "Stock 4"
|
||||
// ));
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-5",
|
||||
// "description similar record",
|
||||
// "short name similar record 5",
|
||||
// "title similar record 5",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-5",
|
||||
// "semantic identifier record 5",
|
||||
// "Stock 5"
|
||||
// ));
|
||||
// similarGrsfRecords.add(new SimilarGRSFRecord(
|
||||
// "uuid-similar-record-6",
|
||||
// "description similar record",
|
||||
// "short name similar record 6",
|
||||
// "title similar record 6",
|
||||
// "http://data.d4science.org/ctlg/GRSF_Admin/uuid-similar-record-6",
|
||||
// "semantic identifier record 6",
|
||||
// "Stock 6"
|
||||
// ));
|
||||
// toReturn.setSimilarGrsfRecords(similarGrsfRecords);
|
||||
//
|
||||
// }else{
|
||||
|
||||
String scopePerCurrentUrl = Utils.getScopeFromClientUrl(getThreadLocalRequest());
|
||||
DataCatalogue catalogue = getCatalogue(scopePerCurrentUrl);
|
||||
|
@ -202,25 +208,29 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
Map<String, String> extrasAsMap = record.getExtrasAsHashMap();
|
||||
|
||||
String systemType = extrasAsMap.get(Constants.SYSTEM_TYPE_CUSTOM_KEY);
|
||||
if(systemType == null || systemType.isEmpty() || systemType.equals(Constants.SYSTEM_TYPE_FOR_SOURCES_VALUE))
|
||||
if (systemType == null || systemType.isEmpty() || systemType.equals(Constants.SYSTEM_TYPE_LEGACY_RECORD))
|
||||
throw new NoGRSFRecordException("This is not a GRSF Record");
|
||||
|
||||
boolean isStock = record.getExtrasAsHashMap().get(Constants.DOMAIN_CUSTOM_KEY).contains(Product_Type.STOCK.getOrigName());
|
||||
boolean isStock = record.getExtrasAsHashMap().get(Constants.DOMAIN_CUSTOM_KEY)
|
||||
.contains(Product_Type.STOCK.getOrigName());
|
||||
|
||||
// fetch map for namespaces
|
||||
Map<String, String> fieldsNamespacesMap =
|
||||
Utils.getFieldToFieldNameSpaceMapping(httpSession, isStock ?
|
||||
Constants.GENERIC_RESOURCE_NAME_MAP_KEY_NAMESPACES_STOCK : Constants.GENERIC_RESOURCE_NAME_MAP_KEY_NAMESPACES_FISHERY);
|
||||
Map<String, String> fieldsNamespacesMap = Utils.getFieldToFieldNameSpaceMapping(httpSession,
|
||||
isStock ? Constants.GENERIC_RESOURCE_NAME_MAP_KEY_NAMESPACES_STOCK
|
||||
: Constants.GENERIC_RESOURCE_NAME_MAP_KEY_NAMESPACES_FISHERY);
|
||||
|
||||
// get extras as pairs
|
||||
List<CkanPair> extrasAsPairs = record.getExtras();
|
||||
Map<String, List<String>> extrasWithoutNamespaces = Utils.replaceFieldsKey(extrasAsPairs, fieldsNamespacesMap);
|
||||
Map<String, List<String>> extrasWithoutNamespaces = Utils.replaceFieldsKey(extrasAsPairs,
|
||||
fieldsNamespacesMap);
|
||||
String catalogueIdentifier = record.getId();
|
||||
String description = record.getNotes();
|
||||
Status status = Status.fromString(extrasWithoutNamespaces.get(Constants.STATUS_OF_THE_GRSF_RECORD_CUSTOM_KEY).get(0));
|
||||
Status status = Status
|
||||
.fromString(extrasWithoutNamespaces.get(Constants.STATUS_OF_THE_GRSF_RECORD_CUSTOM_KEY).get(0));
|
||||
|
||||
if (status.equals(Status.To_be_Merged) && !requestForRevertingMerge)
|
||||
throw new GRSFRecordAlreadyManagedStatusException(Status.To_be_Merged, "The record is locked due to a merge request in progress!");
|
||||
throw new GRSFRecordAlreadyManagedStatusException(Status.To_be_Merged,
|
||||
"The record is locked due to a merge request in progress!");
|
||||
|
||||
String uuidKB = extrasWithoutNamespaces.get(Constants.UUID_KB_CUSTOM_KEY).get(0);
|
||||
String grsfDomain = extrasWithoutNamespaces.get(Constants.DOMAIN_CUSTOM_KEY).get(0);
|
||||
|
@ -228,10 +238,14 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
String shortName = extrasWithoutNamespaces.get(Constants.SHORT_NAME_CUSTOM_KEY).get(0);
|
||||
String grsfType = extrasWithoutNamespaces.get(Constants.GRSF_TYPE_CUSTOM_KEY).get(0);
|
||||
String recordUrl = extrasWithoutNamespaces.get(Constants.ITEM_URL_FIELD).get(0);
|
||||
String grsfName = extrasWithoutNamespaces.get(grsfDomain.contains(Product_Type.STOCK.getOrigName()) ? Constants.STOCK_NAME_CUSTOM_KEY : Constants.FISHERY_NAME_CUSTOM_KEY).get(0);
|
||||
String grsfName = extrasWithoutNamespaces
|
||||
.get(grsfDomain.contains(Product_Type.STOCK.getOrigName()) ? Constants.STOCK_NAME_CUSTOM_KEY
|
||||
: Constants.FISHERY_NAME_CUSTOM_KEY)
|
||||
.get(0);
|
||||
boolean traceabilityFlag = false;
|
||||
try {
|
||||
traceabilityFlag = extrasWithoutNamespaces.get(Constants.TRACEABILITY_FLAG_CUSTOM_KEY).get(0).equalsIgnoreCase("true");
|
||||
traceabilityFlag = extrasWithoutNamespaces.get(Constants.TRACEABILITY_FLAG_CUSTOM_KEY).get(0)
|
||||
.equalsIgnoreCase("true");
|
||||
} catch (Exception e) {
|
||||
logger.warn("Unable to fetch traceability flag. Setting it to false", e);
|
||||
}
|
||||
|
@ -243,14 +257,19 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
logger.warn("Unable to fetch sdg flag. Setting it to false", e);
|
||||
}
|
||||
|
||||
// Get similar GRSF records, if any (each of which should have name, description, url and id(i.e semantic identifier))
|
||||
List<String> similarGrsfRecordsAsStrings = extrasWithoutNamespaces.containsKey(Constants.SIMILAR_GRSF_RECORDS_CUSTOM_KEY) ? extrasWithoutNamespaces.get(Constants.SIMILAR_GRSF_RECORDS_CUSTOM_KEY): null;
|
||||
// Get similar GRSF records, if any (each of which should have name,
|
||||
// description, url and id(i.e semantic identifier))
|
||||
List<String> similarGrsfRecordsAsStrings = extrasWithoutNamespaces
|
||||
.containsKey(Constants.SIMILAR_GRSF_RECORDS_CUSTOM_KEY)
|
||||
? extrasWithoutNamespaces.get(Constants.SIMILAR_GRSF_RECORDS_CUSTOM_KEY)
|
||||
: null;
|
||||
|
||||
List<SimilarGRSFRecord> similarRecords = new ArrayList<SimilarGRSFRecord>(0);
|
||||
if (similarGrsfRecordsAsStrings != null && !similarGrsfRecordsAsStrings.isEmpty()) {
|
||||
if (!similarGrsfRecordsAsStrings.get(0).equals(Constants.NO_SIMILAR_GRSF_RECORDS)) {
|
||||
for (String similarGRSFRecord : similarGrsfRecordsAsStrings) {
|
||||
similarRecords.add(Utils.similarGRSFRecordFromJson(similarGRSFRecord, catalogue, username, httpSession));
|
||||
similarRecords.add(
|
||||
Utils.similarGRSFRecordFromJson(similarGRSFRecord, catalogue, username, httpSession));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -258,14 +277,16 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
logger.debug("SimilarGRSFRecords are " + similarRecords);
|
||||
|
||||
// get connected records (and the proposed ones)
|
||||
List<String> connectedBeanUrls =
|
||||
extrasWithoutNamespaces.containsKey(Constants.CONNECTED_CUSTOM_KEY) ? extrasWithoutNamespaces.get(Constants.CONNECTED_CUSTOM_KEY): null;
|
||||
List<String> connectedBeanUrls = extrasWithoutNamespaces.containsKey(Constants.CONNECTED_CUSTOM_KEY)
|
||||
? extrasWithoutNamespaces.get(Constants.CONNECTED_CUSTOM_KEY)
|
||||
: null;
|
||||
|
||||
List<ConnectedBean> connectedBeans = new ArrayList<ConnectedBean>(0);
|
||||
if (connectedBeanUrls != null && !connectedBeanUrls.isEmpty()) {
|
||||
if (!connectedBeanUrls.get(0).equals(Constants.NO_CONNECTED_RECORDS)) {
|
||||
for (String connectedBean : connectedBeanUrls) {
|
||||
ConnectedBean builtBean = Utils.connectedBeanRecordFromUrl(connectedBean, catalogue, username, httpSession);
|
||||
ConnectedBean builtBean = Utils.connectedBeanRecordFromUrl(connectedBean, catalogue, username,
|
||||
httpSession);
|
||||
if (builtBean != null)
|
||||
connectedBeans.add(builtBean);
|
||||
}
|
||||
|
@ -276,15 +297,18 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
|
||||
// get the connections the knowledge base suggests
|
||||
List<ConnectedBean> suggestedConnectionsByKnowledgeBase = new ArrayList<ConnectedBean>(0);
|
||||
List<String> exploitedResourcesUrls = isStock ?
|
||||
extrasWithoutNamespaces.containsKey(Constants.EXPLOITING_FISHERY_CUSTOM_KEY) ?
|
||||
extrasWithoutNamespaces.get(Constants.EXPLOITING_FISHERY_CUSTOM_KEY) : null:
|
||||
extrasWithoutNamespaces.containsKey(Constants.RESOURCES_EXPLOITED_CUSTOM_KEY) ?
|
||||
extrasWithoutNamespaces.get(Constants.RESOURCES_EXPLOITED_CUSTOM_KEY) : null;
|
||||
List<String> exploitedResourcesUrls = isStock
|
||||
? extrasWithoutNamespaces.containsKey(Constants.EXPLOITING_FISHERY_CUSTOM_KEY)
|
||||
? extrasWithoutNamespaces.get(Constants.EXPLOITING_FISHERY_CUSTOM_KEY)
|
||||
: null
|
||||
: extrasWithoutNamespaces.containsKey(Constants.RESOURCES_EXPLOITED_CUSTOM_KEY)
|
||||
? extrasWithoutNamespaces.get(Constants.RESOURCES_EXPLOITED_CUSTOM_KEY)
|
||||
: null;
|
||||
|
||||
if (exploitedResourcesUrls != null && !exploitedResourcesUrls.isEmpty()) {
|
||||
for (String exploited : exploitedResourcesUrls) {
|
||||
ConnectedBean builtBean = Utils.connectedBeanRecordFromUrl(exploited, catalogue, username, httpSession);
|
||||
ConnectedBean builtBean = Utils.connectedBeanRecordFromUrl(exploited, catalogue, username,
|
||||
httpSession);
|
||||
if (builtBean != null)
|
||||
suggestedConnectionsByKnowledgeBase.add(builtBean);
|
||||
}
|
||||
|
@ -301,14 +325,12 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
}
|
||||
|
||||
// set the values
|
||||
toReturn = new ManageProductBean(
|
||||
semanticId, catalogueIdentifier, uuidKB, grsfType,
|
||||
grsfDomain, shortName, description, grsfName,traceabilityFlag, sdgFlag,
|
||||
status, recordUrl, sources, similarRecords,
|
||||
toReturn = new ManageProductBean(semanticId, catalogueIdentifier, uuidKB, grsfType, grsfDomain, shortName,
|
||||
description, grsfName, traceabilityFlag, sdgFlag, status, recordUrl, sources, similarRecords,
|
||||
connectedBeans, suggestedConnectionsByKnowledgeBase);
|
||||
|
||||
}
|
||||
}
|
||||
// }
|
||||
|
||||
logger.debug("Returning item bean " + toReturn);
|
||||
return toReturn;
|
||||
|
@ -317,7 +339,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
@Override
|
||||
public boolean isAdminUser() {
|
||||
try {
|
||||
Boolean inSession = (Boolean)getThreadLocalRequest().getSession().getAttribute(Constants.GRSF_ADMIN_SESSION_KEY);
|
||||
Boolean inSession = (Boolean) getThreadLocalRequest().getSession()
|
||||
.getAttribute(Constants.GRSF_ADMIN_SESSION_KEY);
|
||||
if (inSession != null)
|
||||
return inSession;
|
||||
else {
|
||||
|
@ -338,7 +361,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
return toSetInSession;
|
||||
}
|
||||
} catch (Exception e) {
|
||||
logger.error("Failed to check if the user belongs to team " + Constants.GRSF_CATALOGUE_EDITOR_ROLE + " or " + Constants.GRSF_CATALOGUE_REVIEWER_ROLE +"!", e);
|
||||
logger.error("Failed to check if the user belongs to team " + Constants.GRSF_CATALOGUE_EDITOR_ROLE + " or "
|
||||
+ Constants.GRSF_CATALOGUE_REVIEWER_ROLE + "!", e);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
@ -360,7 +384,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
String username = Utils.getCurrentUser(getThreadLocalRequest()).getUsername();
|
||||
|
||||
// check if the base url of the service is in session
|
||||
String keyPerContext = CatalogueUtilMethods.concatenateSessionKeyScope(Constants.GRSF_UPDATER_SERVICE, context);
|
||||
String keyPerContext = CatalogueUtilMethods.concatenateSessionKeyScope(Constants.GRSF_UPDATER_SERVICE,
|
||||
context);
|
||||
HttpServletRequest threadRequest = getThreadLocalRequest();
|
||||
String baseUrl = (String) threadRequest.getSession().getAttribute(keyPerContext);
|
||||
if (baseUrl == null || baseUrl.isEmpty()) {
|
||||
|
@ -400,8 +425,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
String adminInUrl = "costantino.perciante";
|
||||
String adminInUrlFullName = "Costantino Perciante";
|
||||
long timestamp = System.currentTimeMillis() - 1000 * (long) (Math.random() * 10 * 60 * 60);
|
||||
return new RevertableOperationInfo(
|
||||
baseUrl, fullName, usernameCurrent, uuid, adminInUrlFullName, adminInUrl, timestamp, RevertableOperations.MERGE);
|
||||
return new RevertableOperationInfo(baseUrl, fullName, usernameCurrent, uuid, adminInUrlFullName, adminInUrl,
|
||||
timestamp, RevertableOperations.MERGE);
|
||||
}
|
||||
|
||||
PortalContext pContext = PortalContext.getConfiguration();
|
||||
|
@ -423,10 +448,14 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
// decrypt the url
|
||||
RevertOperationUrl decryptedUrl = new RevertOperationUrl(encryptedUrl);
|
||||
String userNameadminInUrl = decryptedUrl.getAdmin(); // this is the username
|
||||
String fullNameadminInUrl = new LiferayUserManager().getUserByUsername(userNameadminInUrl).getFullname(); // this is the fullname
|
||||
String fullNameadminInUrl = new LiferayUserManager().getUserByUsername(userNameadminInUrl).getFullname(); // this
|
||||
// is
|
||||
// the
|
||||
// fullname
|
||||
String uuid = decryptedUrl.getUuid();
|
||||
|
||||
logger.info("User " + username + " has requested to invert an operation on record with id " + uuid + " and admin in url is " + userNameadminInUrl);
|
||||
logger.info("User " + username + " has requested to invert an operation on record with id " + uuid
|
||||
+ " and admin in url is " + userNameadminInUrl);
|
||||
|
||||
// we need to check the timestamp (it has 24h validity)
|
||||
boolean isValidTimestamp = decryptedUrl.isTimestampValid();
|
||||
|
@ -442,26 +471,26 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
|
||||
// check current record status
|
||||
if (!currentStatus.equals(Status.To_be_Merged.getOrigName()))
|
||||
throw new Exception("Record '" + dataset.getTitle() + "' (" + recordUrl + ") is no longer involved in a merge operation!");
|
||||
throw new Exception("Record '" + dataset.getTitle() + "' (" + recordUrl
|
||||
+ ") is no longer involved in a merge operation!");
|
||||
|
||||
// check if it is a reviewer, than he can do what he wants (no matter the admin)
|
||||
if (isReviewer) {
|
||||
return new RevertableOperationInfo(recordUrl,
|
||||
fullName, username, uuid, fullNameadminInUrl, userNameadminInUrl, decryptedUrl.getTimestamp(), decryptedUrl.getOperation());
|
||||
return new RevertableOperationInfo(recordUrl, fullName, username, uuid, fullNameadminInUrl,
|
||||
userNameadminInUrl, decryptedUrl.getTimestamp(), decryptedUrl.getOperation());
|
||||
} else {
|
||||
|
||||
if (!username.equals(userNameadminInUrl))
|
||||
throw new Exception("You are not the editor allowed to perform this operation!");
|
||||
else
|
||||
return new RevertableOperationInfo(recordUrl,
|
||||
fullName, username, uuid, fullNameadminInUrl, userNameadminInUrl, decryptedUrl.getTimestamp(), decryptedUrl.getOperation());
|
||||
return new RevertableOperationInfo(recordUrl, fullName, username, uuid, fullNameadminInUrl,
|
||||
userNameadminInUrl, decryptedUrl.getTimestamp(), decryptedUrl.getOperation());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean performRevertOperation(RevertableOperationInfo rInfo)
|
||||
throws Exception {
|
||||
public Boolean performRevertOperation(RevertableOperationInfo rInfo) throws Exception {
|
||||
|
||||
if (!Utils.isIntoPortal()) {
|
||||
// random result
|
||||
|
@ -483,7 +512,8 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
|
||||
try (CloseableHttpClient httpClient = HttpClientBuilder.create().build();) {
|
||||
|
||||
String keyPerContext = CatalogueUtilMethods.concatenateSessionKeyScope(Constants.GRSF_UPDATER_SERVICE, context);
|
||||
String keyPerContext = CatalogueUtilMethods.concatenateSessionKeyScope(Constants.GRSF_UPDATER_SERVICE,
|
||||
context);
|
||||
String baseUrl = (String) getThreadLocalRequest().getSession().getAttribute(keyPerContext);
|
||||
if (baseUrl == null || baseUrl.isEmpty()) {
|
||||
baseUrl = GRSFUpdaterServiceClient.discoverEndPoint(context);
|
||||
|
@ -496,8 +526,7 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
Utils.revertOperation(httpClient, baseUrl, threadRequest, rInfo, token, context,
|
||||
PortalContext.getConfiguration().getCurrentGroupId(threadRequest));
|
||||
|
||||
}
|
||||
catch(Exception e){
|
||||
} catch (Exception e) {
|
||||
logger.error("Unable to revert operation ", e);
|
||||
throw e;
|
||||
}
|
||||
|
@ -506,6 +535,7 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
|
||||
/**
|
||||
* Check if the current user is an editor
|
||||
*
|
||||
* @param username
|
||||
* @param teamRoles
|
||||
* @return true if he/she is an editor, false otherwise
|
||||
|
@ -523,6 +553,7 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
|
||||
/**
|
||||
* Check if the current user is a reviewer
|
||||
*
|
||||
* @param username
|
||||
* @param teamRoles
|
||||
* @return true if he/she is an reviewer, false otherwise
|
||||
|
@ -539,8 +570,7 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
}
|
||||
|
||||
@Override
|
||||
public String checkIdentifierExists(String id)
|
||||
throws Exception {
|
||||
public String checkIdentifierExists(String id) throws Exception {
|
||||
String scopePerCurrentUrl = Utils.getScopeFromClientUrl(getThreadLocalRequest());
|
||||
DataCatalogue catalogue = getCatalogue(scopePerCurrentUrl);
|
||||
String username = Utils.getCurrentUser(getThreadLocalRequest()).getUsername();
|
||||
|
@ -555,8 +585,7 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
}
|
||||
|
||||
@Override
|
||||
public String checkIdentifierExistsInDomain(String id,
|
||||
String acceptedDomain) throws Exception {
|
||||
public String checkIdentifierExistsInDomain(String id, String acceptedDomain) throws Exception {
|
||||
|
||||
if (!Utils.isIntoPortal()) {
|
||||
boolean throwException = Math.random() > 0.5;
|
||||
|
@ -583,11 +612,12 @@ public class GRSFNotificationService extends RemoteServiceServlet implements GRS
|
|||
String domain = extras.get(Constants.DOMAIN_CUSTOM_KEY);
|
||||
String url = extras.get(Constants.ITEM_URL_FIELD);
|
||||
|
||||
if(systemType.equals(Constants.SYSTEM_TYPE_FOR_SOURCES_VALUE))
|
||||
if (systemType.equals(Constants.SYSTEM_TYPE_LEGACY_RECORD))
|
||||
throw new Exception("This record is not a GRSF record!");
|
||||
|
||||
if (!acceptedDomain.equalsIgnoreCase(domain))
|
||||
throw new Exception("You are suggesting a " + domain + " record instead of a " + acceptedDomain + " record!");
|
||||
throw new Exception(
|
||||
"You are suggesting a " + domain + " record instead of a " + acceptedDomain + " record!");
|
||||
|
||||
return url;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue