use of nikita.common.model.noark5.v4.metadata.DocumentType in project nikita-noark5-core by HiOA-ABI.
the class DocumentTypeService method findByCode.
/**
* retrieve all documentType that have a particular code.
* <br>
* Note, this will be replaced by OData search.
*
* @param code
* @return A list of documentType objects wrapped as a MetadataHateoas
* object
*/
@Override
public MetadataHateoas findByCode(String code) {
MetadataHateoas metadataHateoas = new MetadataHateoas((List<INikitaEntity>) (List) documentTypeRepository.findByCode(code), DOCUMENT_TYPE);
metadataHateoasHandler.addLinks(metadataHateoas, new Authorisation());
return metadataHateoas;
}
use of nikita.common.model.noark5.v4.metadata.DocumentType in project nikita-noark5-core by HiOA-ABI.
the class DocumentTypeService method createNewDocumentType.
// All CREATE operations
/**
* Persists a new documentType object to the database.
*
* @param documentType documentType object with values set
* @return the newly persisted documentType object wrapped as a
* MetadataHateoas object
*/
@Override
public MetadataHateoas createNewDocumentType(DocumentType documentType) {
documentType.setDeleted(false);
documentType.setOwnedBy(SecurityContextHolder.getContext().getAuthentication().getName());
MetadataHateoas metadataHateoas = new MetadataHateoas(documentTypeRepository.save(documentType));
metadataHateoasHandler.addLinks(metadataHateoas, new Authorisation());
return metadataHateoas;
}
use of nikita.common.model.noark5.v4.metadata.DocumentType in project nikita-noark5-core by HiOA-ABI.
the class DocumentTypeService method handleUpdate.
/**
* Update a documentType identified by its systemId
* <p>
* Copy the values you are allowed to change, code and description
*
* @param documentType
* @return the updated documentType
*/
@Override
public MetadataHateoas handleUpdate(String systemId, Long version, DocumentType documentType) {
DocumentType existingDocumentType = getDocumentTypeOrThrow(systemId);
// Copy all the values you are allowed to copy ....
if (null != existingDocumentType.getCode()) {
existingDocumentType.setCode(existingDocumentType.getCode());
}
if (null != existingDocumentType.getDescription()) {
existingDocumentType.setDescription(existingDocumentType.getDescription());
}
// Note this can potentially result in a NoarkConcurrencyException
// exception
existingDocumentType.setVersion(version);
MetadataHateoas documentTypeHateoas = new MetadataHateoas(documentTypeRepository.save(existingDocumentType));
metadataHateoasHandler.addLinks(documentTypeHateoas, new Authorisation());
applicationEventPublisher.publishEvent(new AfterNoarkEntityUpdatedEvent(this, existingDocumentType));
return documentTypeHateoas;
}
use of nikita.common.model.noark5.v4.metadata.DocumentType in project nikita-noark5-core by HiOA-ABI.
the class DocumentTypeService method findAll.
// All READ operations
/**
* Retrieve a list of all documentType objects
*
* @return list of documentType objects wrapped as a MetadataHateoas object
*/
@Override
public MetadataHateoas findAll() {
MetadataHateoas metadataHateoas = new MetadataHateoas((List<INikitaEntity>) (List) documentTypeRepository.findAll(), DOCUMENT_TYPE);
metadataHateoasHandler.addLinks(metadataHateoas, new Authorisation());
return metadataHateoas;
}
use of nikita.common.model.noark5.v4.metadata.DocumentType in project nikita-noark5-core by HiOA-ABI.
the class DocumentDescriptionDeserializer method deserialize.
@Override
public DocumentDescription deserialize(JsonParser jsonParser, DeserializationContext dc) throws IOException {
StringBuilder errors = new StringBuilder();
DocumentDescription documentDescription = new DocumentDescription();
ObjectNode objectNode = mapper.readTree(jsonParser);
// Deserialise general record properties
CommonUtils.Hateoas.Deserialize.deserialiseNoarkSystemIdEntity(documentDescription, objectNode, errors);
CommonUtils.Hateoas.Deserialize.deserialiseNoarkCreateEntity(documentDescription, objectNode, errors);
CommonUtils.Hateoas.Deserialize.deserialiseNoarkTitleDescriptionEntity(documentDescription, objectNode, errors);
// Deserialize documentType
JsonNode currentNode = objectNode.get(N5ResourceMappings.DOCUMENT_DESCRIPTION_DOCUMENT_TYPE);
if (null != currentNode) {
documentDescription.setDocumentType(currentNode.textValue());
objectNode.remove(N5ResourceMappings.DOCUMENT_DESCRIPTION_DOCUMENT_TYPE);
}
// Deserialize documentStatus
currentNode = objectNode.get(N5ResourceMappings.DOCUMENT_DESCRIPTION_STATUS);
if (null != currentNode) {
documentDescription.setDocumentStatus(currentNode.textValue());
objectNode.remove(N5ResourceMappings.DOCUMENT_DESCRIPTION_STATUS);
}
// Deserialize associatedWithRecordAs
currentNode = objectNode.get(N5ResourceMappings.DOCUMENT_DESCRIPTION_ASSOCIATED_WITH_RECORD_AS);
if (null != currentNode) {
documentDescription.setAssociatedWithRecordAs(currentNode.textValue());
objectNode.remove(N5ResourceMappings.DOCUMENT_DESCRIPTION_ASSOCIATED_WITH_RECORD_AS);
}
// Deserialize documentNumber
currentNode = objectNode.get(N5ResourceMappings.DOCUMENT_DESCRIPTION_DOCUMENT_NUMBER);
if (null != currentNode) {
documentDescription.setDocumentNumber(Integer.valueOf(currentNode.intValue()));
objectNode.remove(N5ResourceMappings.DOCUMENT_DESCRIPTION_DOCUMENT_NUMBER);
}
// Deserialize associationDate
documentDescription.setAssociationDate(CommonUtils.Hateoas.Deserialize.deserializeDate(N5ResourceMappings.DOCUMENT_DESCRIPTION_ASSOCIATION_DATE, objectNode, errors));
// Deserialize associatedBy
currentNode = objectNode.get(N5ResourceMappings.DOCUMENT_DESCRIPTION_ASSOCIATED_BY);
if (null != currentNode) {
documentDescription.setAssociatedBy(currentNode.textValue());
objectNode.remove(N5ResourceMappings.DOCUMENT_DESCRIPTION_ASSOCIATED_BY);
}
// Deserialize storageLocation
currentNode = objectNode.get(N5ResourceMappings.STORAGE_LOCATION);
if (null != currentNode) {
documentDescription.setStorageLocation(currentNode.textValue());
objectNode.remove(N5ResourceMappings.STORAGE_LOCATION);
}
// Deserialize general documentDescription properties
CommonUtils.Hateoas.Deserialize.deserialiseDocumentMedium(documentDescription, objectNode, errors);
// If there are additional throw a malformed input exception
if (objectNode.size() != 0) {
errors.append("The dokumentbeskrivelse you tried to create is malformed. The " + "following fields are not recognised as dokumentbeskrivelse fields[" + CommonUtils.Hateoas.Deserialize.checkNodeObjectEmpty(objectNode) + "]. ");
}
if (0 < errors.length())
throw new NikitaMalformedInputDataException(errors.toString());
return documentDescription;
}
Aggregations