2 * ============LICENSE_START========================================================================
3 * ONAP : tr-069-adapter
4 * =================================================================================================
5 * Copyright (C) 2020 CommScope Inc Intellectual Property.
6 * =================================================================================================
7 * This tr-069-adapter software file is distributed by CommScope Inc under the Apache License,
8 * Version 2.0 (the "License"); you may not use this file except in compliance with the License. You
9 * may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
14 * either express or implied. See the License for the specific language governing permissions and
15 * limitations under the License.
16 * ===============LICENSE_END=======================================================================
20 package org.commscope.tr069adapter.config.controllers;
22 import java.util.Arrays;
23 import java.util.List;
24 import java.util.Optional;
26 import org.commscope.tr069adapter.acs.common.dto.ConfigurationData;
27 import org.commscope.tr069adapter.config.constants.ConfigurationServiceConstant;
28 import org.commscope.tr069adapter.config.exceptions.InvalidConfigurationServiceException;
29 import org.commscope.tr069adapter.config.service.ConfigurationDataService;
30 import org.slf4j.Logger;
31 import org.slf4j.LoggerFactory;
32 import org.springframework.beans.factory.annotation.Autowired;
33 import org.springframework.util.StringUtils;
34 import org.springframework.web.bind.annotation.GetMapping;
35 import org.springframework.web.bind.annotation.PostMapping;
36 import org.springframework.web.bind.annotation.RequestParam;
37 import org.springframework.web.bind.annotation.RestController;
38 import org.springframework.web.multipart.MultipartFile;
41 public class ConfugurationDataController {
42 private final Logger logger = LoggerFactory.getLogger(this.getClass());
45 ConfigurationDataService configDataService;
47 @GetMapping("/isActive")
48 public String getMessage() {
49 return "Application is running";
52 @PostMapping("/getConfig")
53 public ConfigurationData viewConfigurationData(@RequestParam String macId,
54 @RequestParam String swVersion, @RequestParam String hwVersion)
55 throws InvalidConfigurationServiceException {
56 macId = macId.replaceAll("[\n|\r|\t]", "_");
57 logger.info("Processing request to get configuration data for device {}", macId);
58 Optional<ConfigurationData> configData =
59 configDataService.getConfigurationData(macId, swVersion, hwVersion);
60 if (configData.isPresent()) {
61 return configData.get();
63 logger.info("Configuration data doesn't exist for device {}", macId);
67 @PostMapping("/importConfig")
68 public String uploadMultipleFiles(@RequestParam("files") MultipartFile[] files)
69 throws InvalidConfigurationServiceException {
71 if (null == files || files.length == 0) {
72 logger.info("No file given for import");
73 return "No file given for import";
76 List<MultipartFile> fileList = Arrays.asList(files);
78 MultipartFile file = fileList.get(0);
79 String fileName = StringUtils.cleanPath(file.getOriginalFilename());
81 logger.debug("Importing file {}", fileName);
82 if (!fileName.endsWith(ConfigurationServiceConstant.CONFIG_FILE_EXTENSION)) {
83 throw new InvalidConfigurationServiceException("Unsupported file format for file " + fileName
84 + ". Only XML file is supported. Ignoring file import for file " + fileName);
88 configDataService.saveConfigFileContents(file);
89 } catch (InvalidConfigurationServiceException ex) {
90 throw new InvalidConfigurationServiceException(
91 "Error occurred while import file " + fileName + ". Cause : " + ex.getMessage());
92 } catch (Exception ex) {
93 throw new InvalidConfigurationServiceException(
94 "UNKNOWN error occurred while import file " + fileName + ". Cause : " + ex.getMessage());
97 return "File " + fileName + " imported successfully";