blob: 89b9a941d65e25c89adec691f5d1b73b2a7d915d [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache license, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the license for the specific language governing permissions and
* limitations under the license.
*/
package org.apache.logging.log4j.catalog.controller;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.catalog.api.Event;
import org.apache.logging.log4j.catalog.jpa.converter.EventConverter;
import org.apache.logging.log4j.catalog.jpa.converter.EventModelConverter;
import org.apache.logging.log4j.catalog.jpa.model.EventModel;
import org.apache.logging.log4j.catalog.jpa.service.EventService;
import org.modelmapper.ModelMapper;
import org.modelmapper.TypeToken;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.PostConstruct;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
/**
* Catalog Product controller
*/
@RequestMapping(value = "/api/events")
@RestController
public class EventController {
private static final Logger LOGGER = LogManager.getLogger();
private final ModelMapper modelMapper = new ModelMapper();
@Autowired
private EventService eventService;
@Autowired
private EventModelConverter eventModelConverter;
@Autowired
private EventConverter eventConverter;
@PostConstruct
public void init() {
modelMapper.addConverter(eventModelConverter);
}
@PostMapping(value = "/list")
public ResponseEntity<Map<String, Object>> eventList(@RequestParam(value="jtStartIndex", required=false) Integer startIndex,
@RequestParam(value="jtPageSize", required=false) Integer pageSize,
@RequestParam(value="jtSorting", required=false) String sorting) {
Type listType = new TypeToken<List<Event>>() {}.getType();
Map<String, Object> response = new HashMap<>();
try {
List<Event> events;
if (startIndex == null || pageSize == null) {
events = modelMapper.map(eventService.getEvents(), listType);
} else {
int startPage = 0;
if (startIndex > 0) {
startPage = startIndex / pageSize;
}
String sortColumn = "name";
String sortDirection = "ASC";
if (sorting != null) {
String[] sortInfo = sorting.split(" ");
sortColumn = sortInfo[0];
if (sortInfo.length > 0) {
sortDirection = sortInfo[1];
}
}
events = modelMapper.map(eventService.getEvents(startPage, pageSize, sortColumn, sortDirection), listType);
}
if (events == null) {
events = new ArrayList<>();
}
response.put("Result", "OK");
response.put("Records", events);
} catch (Exception ex) {
response.put("Result", "FAILURE");
response.put("Message", ex.getMessage());
}
return new ResponseEntity<>(response, HttpStatus.OK);
}
@PostMapping(value = "/create")
public ResponseEntity<Map<String, Object>> createEvent(@RequestBody Event event) {
Map<String, Object> response = new HashMap<>();
try {
EventModel model = eventConverter.convert(event);
event = eventModelConverter.convert(eventService.saveEvent(model));
response.put("Result", "OK");
response.put("Records", event);
} catch (Exception ex) {
response.put("Result", "FAILURE");
response.put("Message", ex.getMessage());
LOGGER.warn("Unable to create event named {}", event.getName(), ex);
}
return new ResponseEntity<>(response, HttpStatus.OK);
}
@PostMapping(value = "/update")
public ResponseEntity<Map<String, Object>> updateEvent(@RequestBody Event event) {
Map<String, Object> response = new HashMap<>();
try {
EventModel model = eventConverter.convert(event);
event = eventModelConverter.convert(eventService.saveEvent(model));
response.put("Result", "OK");
response.put("Records", event);
} catch (Exception ex) {
response.put("Result", "FAILURE");
response.put("Message", ex.getMessage());
LOGGER.warn("Unable to update event named {}", event.getName(), ex);
}
return new ResponseEntity<>(response, HttpStatus.OK);
}
@PostMapping(value = "/delete")
public ResponseEntity<Map<String, Object>> deleteEvent(@RequestBody Long eventId) {
Map<String, Object> response = new HashMap<>();
try {
eventService.deleteEvent(eventId);
response.put("Result", "OK");
} catch (Exception ex) {
response.put("Result", "FAILURE");
response.put("Message", ex.getMessage());
}
return new ResponseEntity<>(response, HttpStatus.OK);
}
@PostMapping(value = "/attributes/list")
public ResponseEntity<Map<String, Object>> attributeList(@RequestParam("eventId") Long eventId) {
Map<String, Object> response = new HashMap<>();
try {
Optional<EventModel> optional = eventService.getEvent(eventId);
if (optional.isPresent()) {
Event event = eventModelConverter.convert(optional.get());
response.put("Result", "OK");
if (event != null && event.getAttributes() != null) {
response.put("Records", event.getAttributes());
} else {
response.put("Records", new ArrayList<>());
}
} else {
response.put("Result", "OK");
response.put("Records", new ArrayList<>());
}
} catch (Exception ex) {
response.put("Result", "FAILURE");
}
return new ResponseEntity<>(response, HttpStatus.OK);
}
}