f08a994d05412771be962b437032c30f68fcfb17
[dcaegen2/services.git] /
1 /*
2 * ============LICENSE_START=======================================================
3 * ONAP : DataLake
4 * ================================================================================
5 * Copyright 2019 China Mobile
6 *=================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 *     http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
19 */
20 package org.onap.datalake.feeder.controller;
21
22 import java.io.IOException;
23 import java.util.ArrayList;
24 import java.util.List;
25 import java.util.Set;
26
27 import javax.servlet.http.HttpServletResponse;
28
29 import org.onap.datalake.feeder.domain.Db;
30 import org.onap.datalake.feeder.domain.Topic;
31 import org.onap.datalake.feeder.controller.domain.PostReturnBody;
32 import org.onap.datalake.feeder.dto.TopicConfig;
33 import org.onap.datalake.feeder.repository.DbRepository;
34 import org.onap.datalake.feeder.repository.TopicRepository;
35 import org.onap.datalake.feeder.service.DbService;
36 import org.onap.datalake.feeder.service.DmaapService;
37 import org.onap.datalake.feeder.service.TopicService;
38 import org.slf4j.Logger;
39 import org.slf4j.LoggerFactory;
40 import org.springframework.beans.factory.annotation.Autowired;
41 import org.springframework.http.MediaType;
42 import org.springframework.validation.BindingResult;
43 import org.springframework.web.bind.annotation.DeleteMapping;
44 import org.springframework.web.bind.annotation.GetMapping;
45 import org.springframework.web.bind.annotation.PathVariable;
46 import org.springframework.web.bind.annotation.PostMapping;
47 import org.springframework.web.bind.annotation.PutMapping;
48 import org.springframework.web.bind.annotation.RequestBody;
49 import org.springframework.web.bind.annotation.RequestMapping;
50 import org.springframework.web.bind.annotation.ResponseBody;
51 import org.springframework.web.bind.annotation.RestController;
52
53 import io.swagger.annotations.ApiOperation;
54
55 /**
56  * This controller manages topic settings.
57  * 
58  * Topic "_DL_DEFAULT_" acts as the default. For example, if a topic's
59  * enabled=null, _DL_DEFAULT_.enabled is used for that topic. All the settings
60  * are saved in database. topic "_DL_DEFAULT_" is populated at setup by a DB
61  * script.
62  * 
63  * @author Guobiao Mo
64  * @contributor Kate Hsuan @ QCT
65  */
66
67 @RestController
68 @RequestMapping(value = "/topics", produces = { MediaType.APPLICATION_JSON_VALUE })//, consumes= {MediaType.APPLICATION_JSON_UTF8_VALUE})
69 public class TopicController {
70
71         private final Logger log = LoggerFactory.getLogger(this.getClass());
72
73         @Autowired
74         private DmaapService dmaapService;
75
76         @Autowired
77         private TopicRepository topicRepository;
78
79         @Autowired
80         private TopicService topicService;
81
82         @GetMapping("/dmaap/")
83         @ResponseBody
84         @ApiOperation(value = "List all topic names in DMaaP.")
85         public List<String> listDmaapTopics() {
86                 return dmaapService.getTopics();
87         }
88
89         @GetMapping("")
90         @ResponseBody
91         @ApiOperation(value="List all topics in database")
92         public List<String> list() {
93                 Iterable<Topic> ret = topicRepository.findAll();
94                 List<String> retString = new ArrayList<>();
95                 for(Topic item : ret)
96                 {
97                         if(!topicService.istDefaultTopic(item))
98                                 retString.add(item.getName());
99                 }
100                 return retString;
101         }
102
103         @PostMapping("")
104         @ResponseBody
105         @ApiOperation(value="Create a new topic.")
106         public PostReturnBody<TopicConfig> createTopic(@RequestBody TopicConfig topicConfig, BindingResult result, HttpServletResponse response) throws IOException {
107
108                 if (result.hasErrors()) {
109                         sendError(response, 400, "Error parsing Topic: "+result.toString());
110                         return null;
111                 }
112                 Topic oldTopic = topicService.getTopic(topicConfig.getName());
113                 if (oldTopic != null) {
114                         sendError(response, 400, "Topic already exists "+topicConfig.getName());
115                         return null;
116                 } else {
117                         PostReturnBody<TopicConfig> retBody = new PostReturnBody<>();
118                         Topic wTopic = topicService.fillTopicConfiguration(topicConfig);
119                         if(wTopic.getTtl() == 0)
120                                 wTopic.setTtl(3650);
121                         topicRepository.save(wTopic);
122                         mkPostReturnBody(retBody, 200, wTopic);
123                         return retBody;
124                 }
125         }
126
127         @GetMapping("/{topicName}")
128         @ResponseBody
129         @ApiOperation(value="Get a topic's settings.")
130         public TopicConfig getTopic(@PathVariable("topicName") String topicName, HttpServletResponse response) throws IOException {
131                 Topic topic = topicService.getTopic(topicName);
132                 if(topic == null) {
133                         sendError(response, 404, "Topic not found");
134                         return null;
135                 }
136                 return topic.getTopicConfig();
137         }
138
139         //This is not a partial update: old topic is wiped out, and new topic is created based on the input json.
140         //One exception is that old DBs are kept
141         @PutMapping("/{topicName}")
142         @ResponseBody
143         @ApiOperation(value="Update a topic.")
144         public PostReturnBody<TopicConfig> updateTopic(@PathVariable("topicName") String topicName, @RequestBody TopicConfig topicConfig, BindingResult result, HttpServletResponse response) throws IOException {
145
146                 if (result.hasErrors()) {
147                         sendError(response, 400, "Error parsing Topic: "+result.toString());
148                         return null;
149                 }
150
151                 if(!topicName.equals(topicConfig.getName()))
152                 {
153                         sendError(response, 400, "Topic name mismatch" + topicName + topicConfig.getName());
154                         return null;
155                 }
156
157                 Topic oldTopic = topicService.getTopic(topicConfig.getName());
158                 if (oldTopic == null) {
159                         sendError(response, 404, "Topic not found "+topicConfig.getName());
160                         return null;
161                 } else {
162                         PostReturnBody<TopicConfig> retBody = new PostReturnBody<>();
163                         topicService.fillTopicConfiguration(topicConfig, oldTopic);
164                         topicRepository.save(oldTopic);
165                         mkPostReturnBody(retBody, 200, oldTopic);
166                         return retBody;
167                 }
168         }
169
170         private void mkPostReturnBody(PostReturnBody<TopicConfig> retBody, int statusCode, Topic topic)
171         {
172         retBody.setStatusCode(statusCode);
173         retBody.setReturnBody(topic.getTopicConfig());
174         }
175         
176         private void sendError(HttpServletResponse response, int sc, String msg) throws IOException {
177                 log.info(msg);
178                 response.sendError(sc, msg);            
179         }
180 }