2 * ============LICENSE_START=======================================================
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
20 package org.onap.datalake.feeder.controller;
22 import java.io.IOException;
23 import java.util.List;
26 import javax.servlet.http.HttpServletResponse;
28 import org.onap.datalake.feeder.domain.Db;
29 import org.onap.datalake.feeder.domain.Topic;
30 import org.onap.datalake.feeder.repository.TopicRepository;
31 import org.onap.datalake.feeder.service.DbService;
32 import org.onap.datalake.feeder.service.DmaapService;
33 import org.onap.datalake.feeder.service.TopicService;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
36 import org.springframework.beans.factory.annotation.Autowired;
37 import org.springframework.http.MediaType;
38 import org.springframework.validation.BindingResult;
39 import org.springframework.web.bind.annotation.DeleteMapping;
40 import org.springframework.web.bind.annotation.GetMapping;
41 import org.springframework.web.bind.annotation.PathVariable;
42 import org.springframework.web.bind.annotation.PostMapping;
43 import org.springframework.web.bind.annotation.PutMapping;
44 import org.springframework.web.bind.annotation.RequestBody;
45 import org.springframework.web.bind.annotation.RequestMapping;
46 import org.springframework.web.bind.annotation.ResponseBody;
47 import org.springframework.web.bind.annotation.RestController;
49 import io.swagger.annotations.ApiOperation;
52 * This controller manages topic settings.
54 * Topic "_DL_DEFAULT_" acts as the default. For example, if a topic's
55 * enabled=null, _DL_DEFAULT_.enabled is used for that topic. All the settings
56 * are saved in database. topic "_DL_DEFAULT_" is populated at setup by a DB
64 @RequestMapping(value = "/topics", produces = { MediaType.APPLICATION_JSON_VALUE }) //, consumes= {MediaType.APPLICATION_JSON_UTF8_VALUE})
65 public class TopicController {
67 private final Logger log = LoggerFactory.getLogger(this.getClass());
70 private DmaapService dmaapService;
73 private TopicRepository topicRepository;
76 private TopicService topicService;
79 private DbService dbService;
81 @GetMapping("/dmaap/")
83 @ApiOperation(value = "List all topic names in DMaaP.")
84 public List<String> listDmaapTopics() throws IOException {
85 return dmaapService.getTopics();
90 @ApiOperation(value = "List all topics' settings.")
91 public Iterable<Topic> list() throws IOException {
92 Iterable<Topic> ret = topicRepository.findAll();
96 @GetMapping("/{topicName}")
98 @ApiOperation(value = "Get a topic's settings.")
99 public Topic getTopic(@PathVariable("topicName") String topicName) throws IOException {
100 Topic topic = topicService.getTopic(topicName);
104 @GetMapping("/{topicName}/dbs")
106 @ApiOperation(value = "Get all DBs in a topic.")
107 public Set<Db> getTopicDbs(@PathVariable("topicName") String topicName) throws IOException {
108 Topic topic = topicService.getTopic(topicName);
109 Set<Db> dbs = topic.getDbs();
113 //This is not a partial update: old topic is wiped out, and new topic is created based on the input json.
114 //One exception is that old DBs are kept
117 @ApiOperation(value = "Update a topic.")
118 public Topic updateTopic(@RequestBody Topic topic, BindingResult result, HttpServletResponse response) throws IOException {
120 if (result.hasErrors()) {
121 sendError(response, 400, "Error parsing Topic: " + result.toString());
125 Topic oldTopic = getTopic(topic.getName());
126 if (oldTopic == null) {
127 sendError(response, 404, "Topic not found " + topic.getName());
130 if (!topicService.istDefaultTopic(topic)) {
131 Topic defaultTopic = topicService.getDefaultTopic();
132 topic.setDefaultTopic(defaultTopic);
135 topic.setDbs(oldTopic.getDbs());
136 topicRepository.save(topic);
143 @ApiOperation(value = "Create a new topic.")
144 public Topic createTopic(@RequestBody Topic topic, BindingResult result, HttpServletResponse response) throws IOException {
146 if (result.hasErrors()) {
147 sendError(response, 400, "Error parsing Topic: " + result.toString());
151 Topic oldTopic = getTopic(topic.getName());
152 if (oldTopic != null) {
153 sendError(response, 400, "Topic already exists " + topic.getName());
156 if (!topicService.istDefaultTopic(topic)) {
157 Topic defaultTopic = topicService.getDefaultTopic();
158 topic.setDefaultTopic(defaultTopic);
161 topicRepository.save(topic);
166 @DeleteMapping("/{topicName}/db/{dbName}")
168 @ApiOperation(value = "Delete a DB from a topic.")
169 public Set<Db> deleteDb(@PathVariable("topicName") String topicName, @PathVariable("dbName") String dbName, HttpServletResponse response) throws IOException {
170 Topic topic = topicService.getTopic(topicName);
171 Set<Db> dbs = topic.getDbs();
172 dbs.remove(new Db(dbName));
174 topicRepository.save(topic);
175 return topic.getDbs();
178 @PutMapping("/{topicName}/db/{dbName}")
180 @ApiOperation(value = "Add a DB to a topic.")
181 public Set<Db> addDb(@PathVariable("topicName") String topicName, @PathVariable("dbName") String dbName, HttpServletResponse response) throws IOException {
182 Topic topic = topicService.getTopic(topicName);
183 Set<Db> dbs = topic.getDbs();
185 Db db = dbService.getDb(dbName);
188 topicRepository.save(topic);
189 return topic.getDbs();
192 private void sendError(HttpServletResponse response, int sc, String msg) throws IOException {
194 response.sendError(sc, msg);