Refactor config-response-parsing.service

This commit is contained in:
Giuseppe Digilio
2017-11-07 14:40:57 +01:00
parent 96c65bc42b
commit 380faf8468

View File

@@ -14,15 +14,17 @@ export class ConfigResponseParsingService implements ResponseParsingService {
parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse { parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse {
if (isNotEmpty(data.payload) && isNotEmpty(data.payload._links)) { if (isNotEmpty(data.payload) && isNotEmpty(data.payload._links)) {
let configDefinition; let configDefinition;
let payload;
let type;
if (isNotEmpty(data.payload._embedded) && Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) { if (isNotEmpty(data.payload._embedded) && Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
const type = Object.keys(data.payload._embedded)[0]; type = Object.keys(data.payload._embedded)[0];
const serializer = new DSpaceRESTv2Serializer(ConfigObjectFactory.getConstructor(type)); payload = data.payload._embedded[Object.keys(data.payload._embedded)[0]];
configDefinition = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
} else { } else {
const serializer = new DSpaceRESTv2Serializer(ConfigObjectFactory.getConstructor(data.payload.type)); type = data.payload.type;
configDefinition = serializer.deserialize(data.payload); payload = [data.payload];
} }
const serializer = new DSpaceRESTv2Serializer(ConfigObjectFactory.getConstructor(type));
configDefinition = serializer.deserializeArray(payload);
return new ConfigSuccessResponse(configDefinition, data.statusCode); return new ConfigSuccessResponse(configDefinition, data.statusCode);
} else { } else {
return new ErrorResponse( return new ErrorResponse(