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 enabled=null, _DL_DEFAULT_.enabled is used for that topic. 
 
  55  * All the settings are saved in database. 
 
  56  * topic "_DL_DEFAULT_" is populated at setup by a DB script.
 
  63 @RequestMapping(value = "/topics", produces = { MediaType.APPLICATION_JSON_VALUE })//, consumes= {MediaType.APPLICATION_JSON_UTF8_VALUE})
 
  64 public class TopicController {
 
  66         private final Logger log = LoggerFactory.getLogger(this.getClass());
 
  69         private DmaapService dmaapService;
 
  72         private TopicRepository topicRepository;
 
  75         private TopicService topicService;
 
  78         private DbService dbService;
 
  80         @GetMapping("/dmaap/")
 
  82         @ApiOperation(value="List all topics in DMaaP.")
 
  83         public List<String> listDmaapTopics() throws IOException {
 
  84                 return dmaapService.getTopics();
 
  89         @ApiOperation(value="List all topics' details.")
 
  90         public Iterable<Topic> list() throws IOException {
 
  91                 Iterable<Topic> ret = topicRepository.findAll();
 
  95         @GetMapping("/{topicName}")
 
  97         @ApiOperation(value="Get a topic's details.")
 
  98         public Topic getTopic(@PathVariable("topicName") String topicName) throws IOException {
 
  99                 Topic topic = topicService.getTopic(topicName);
 
 103         @GetMapping("/{topicName}/dbs")
 
 105         @ApiOperation(value="Get all DBs in a topic.")
 
 106         public Set<Db> getTopicDbs(@PathVariable("topicName") String topicName) throws IOException {
 
 107                 Topic topic = topicService.getTopic(topicName);
 
 108                 Set<Db> dbs = topic.getDbs();
 
 112         //This is not a partial update: old topic is wiped out, and new topic is created based on the input json. 
 
 113         //One exception is that old DBs are kept
 
 116         @ApiOperation(value="Update a topic.")
 
 117         public Topic updateTopic(@RequestBody Topic topic, BindingResult result, HttpServletResponse response) throws IOException {
 
 119                 if (result.hasErrors()) {
 
 120                         sendError(response, 400, "Error parsing Topic: "+result.toString());
 
 124                 Topic oldTopic = getTopic(topic.getName());
 
 125                 if (oldTopic == null) {
 
 126                         sendError(response, 404, "Topic not found "+topic.getName());
 
 129                         if(!topic.isDefault()) {
 
 130                                 Topic defaultTopic = topicService.getDefaultTopic();
 
 131                                 topic.setDefaultTopic(defaultTopic);
 
 134                         topic.setDbs(oldTopic.getDbs());
 
 135                         topicRepository.save(topic);
 
 142         @ApiOperation(value="Create a new topic.")
 
 143         public Topic createTopic(@RequestBody Topic topic, BindingResult result, HttpServletResponse response) throws IOException {
 
 145                 if (result.hasErrors()) {
 
 146                         sendError(response, 400, "Error parsing Topic: "+result.toString());
 
 150                 Topic oldTopic = getTopic(topic.getName());
 
 151                 if (oldTopic != null) {
 
 152                         sendError(response, 400, "Topic already exists "+topic.getName());
 
 155                         if(!topic.isDefault()) {
 
 156                                 Topic defaultTopic = topicService.getDefaultTopic();
 
 157                                 topic.setDefaultTopic(defaultTopic);
 
 160                         topicRepository.save(topic);
 
 165         @DeleteMapping("/{topicName}/db/{dbName}")
 
 167         @ApiOperation(value="Delete a DB from a topic.")
 
 168         public Set<Db> deleteDb(@PathVariable("topicName") String topicName, @PathVariable("dbName") String dbName, HttpServletResponse response) throws IOException {
 
 169                 Topic topic = topicService.getTopic(topicName);
 
 170                 Set<Db> dbs = topic.getDbs();
 
 171                 dbs.remove(new Db(dbName));
 
 173                 topicRepository.save(topic);
 
 174                 return topic.getDbs();           
 
 177         @PutMapping("/{topicName}/db/{dbName}")
 
 179         @ApiOperation(value="Add a DB to a topic.")
 
 180         public Set<Db> addDb(@PathVariable("topicName") String topicName, @PathVariable("dbName") String dbName, HttpServletResponse response) throws IOException {
 
 181                 Topic topic = topicService.getTopic(topicName);
 
 182                 Set<Db> dbs = topic.getDbs();           
 
 184                 Db db = dbService.getDb(dbName);                
 
 187                 topicRepository.save(topic);
 
 188                 return topic.getDbs();           
 
 191         private void sendError(HttpServletResponse response, int sc, String msg) throws IOException {
 
 193                 response.sendError(sc, msg);