Fix the security issue
[clamp.git] / src / main / java / org / onap / clamp / clds / dao / CldsServiceDataMapper.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP CLAMP
4  * ================================================================================
5  * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights
6  *                             reserved.
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END============================================
20  * ===================================================================
21  * 
22  */
23
24 package org.onap.clamp.clds.dao;
25
26 import com.att.eelf.configuration.EELFLogger;
27 import com.att.eelf.configuration.EELFManager;
28
29 import java.io.IOException;
30 import java.sql.ResultSet;
31 import java.sql.SQLException;
32 import java.util.ArrayList;
33
34 import org.apache.commons.io.serialization.ValidatingObjectInputStream;
35 import org.onap.clamp.clds.model.CldsServiceData;
36 import org.onap.clamp.clds.model.CldsVfData;
37 import org.onap.clamp.clds.model.CldsVfKPIData;
38 import org.onap.clamp.clds.model.CldsVfcData;
39 import org.springframework.jdbc.core.RowMapper;
40
41 /**
42  * Generic mapper for CldsDBServiceCache.
43  */
44 public final class CldsServiceDataMapper implements RowMapper<CldsServiceData> {
45
46     protected static final EELFLogger logger = EELFManager.getInstance().getLogger(CldsDao.class);
47
48     @Override
49     public CldsServiceData mapRow(ResultSet rs, int rowNum) throws SQLException {
50         CldsServiceData cldsServiceData = new CldsServiceData();
51         try (ValidatingObjectInputStream oip = new ValidatingObjectInputStream(rs.getBlob(4).getBinaryStream())) {
52             oip.accept(CldsServiceData.class, ArrayList.class, CldsVfData.class, CldsVfcData.class,
53                     CldsVfKPIData.class);
54             cldsServiceData = (CldsServiceData) oip.readObject();
55             cldsServiceData.setAgeOfRecord(rs.getLong(5));
56         } catch (IOException | ClassNotFoundException e) {
57             logger.error("Error caught while deserializing cldsServiceData from database", e);
58             return null;
59         }
60         return cldsServiceData;
61     }
62 }