summaryrefslogtreecommitdiffstats
path: root/openecomp-be/api/openecomp-sdc-rest-webapp/vendor-license-rest/vendor-license-rest-services/src/main/java/org/openecomp/sdcrests/vendorlicense/rest/mapping/MapLimitRequestDtoToLimitEntity.java
blob: 7f48ece1cf37822d4e97091d60c73a2081cdf6e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
package org.openecomp.sdcrests.vendorlicense.rest.mapping;

import org.openecomp.sdc.common.errors.CoreException;
import org.openecomp.sdc.common.errors.ErrorCode;
import org.openecomp.sdc.datatypes.error.ErrorLevel;
import org.openecomp.sdc.logging.context.impl.MdcDataErrorMessage;
import org.openecomp.sdc.logging.types.LoggerConstants;
import org.openecomp.sdc.logging.types.LoggerServiceName;
import org.openecomp.sdc.logging.types.LoggerTragetServiceName;
import org.openecomp.sdc.vendorlicense.dao.types.AggregationFunction;
import org.openecomp.sdc.vendorlicense.dao.types.EntitlementMetric;
import org.openecomp.sdc.vendorlicense.dao.types.EntitlementTime;
import org.openecomp.sdc.vendorlicense.dao.types.LimitEntity;
import org.openecomp.sdc.vendorlicense.errors.LimitErrorBuilder;
import org.openecomp.sdc.vendorlicense.errors.VendorLicenseErrorCodes;
import org.openecomp.sdc.vendorsoftwareproduct.errors.ImageErrorBuilder;
import org.openecomp.sdcrests.mapping.MappingBase;
import org.openecomp.sdcrests.vendorlicense.types.LimitRequestDto;
import org.openecomp.sdc.vendorlicense.dao.types.LimitType;


public class MapLimitRequestDtoToLimitEntity extends MappingBase<LimitRequestDto, LimitEntity> {
  @Override
  public void doMapping(LimitRequestDto source, LimitEntity target) {
    target.setName(source.getName());
    target.setDescription(source.getDescription());
    try {
      LimitType type = LimitType.valueOf(source.getType());
      target.setType(type);
    }
    catch (IllegalArgumentException exception) {
      throwInvalidValueError("type", VendorLicenseErrorCodes.LIMIT_INVALID_TYPE);
    }

    try {
      EntitlementMetric metric = EntitlementMetric.valueOf(source.getMetric());
      target.setMetric(metric);
    }
    catch (IllegalArgumentException exception) {
      throwInvalidValueError("metric", VendorLicenseErrorCodes.LIMIT_INVALID_METRIC);
    }

    try {
      AggregationFunction function = source.getAggregationFunction() != null ?
              AggregationFunction.valueOf(source.getAggregationFunction()) : null;
      target.setAggregationFunction(function);
    }
    catch (IllegalArgumentException exception) {
      throwInvalidValueError("aggregationFunction",
          VendorLicenseErrorCodes.LIMIT_INVALID_AGGREGATIONFUNCTION);
    }

    try {
      EntitlementTime time = source.getTime() != null ?
              EntitlementTime.valueOf(source.getTime()) : null;
      target.setTime(time);
    }
    catch (IllegalArgumentException exception) {
      throwInvalidValueError("time", VendorLicenseErrorCodes.LIMIT_INVALID_TIME);
    }

    target.setValue(source.getValue());
    target.setUnit(source.getUnit());

  }

  private void throwInvalidValueError(String attribute, String vendorLicenseErrorCode) {
    ErrorCode errorCode = LimitErrorBuilder.getInvalidValueErrorBuilder(attribute,
        vendorLicenseErrorCode);
    MdcDataErrorMessage.createErrorMessageAndUpdateMdc(LoggerConstants.TARGET_ENTITY_DB,
        LoggerServiceName.Create_LIMIT.toString(), ErrorLevel.ERROR.name(),
        errorCode.id(), errorCode.message() );
    throw new CoreException(errorCode);
  }
}