/* * Copyright 2014 the original author or authors. * * Licensed 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 de.codecentric.boot.admin.registry.web; import java.util.Collection; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import de.codecentric.boot.admin.model.Application; import de.codecentric.boot.admin.registry.ApplicationRegistry; import de.codecentric.boot.admin.web.AdminController; /** * REST controller for controlling registration of managed applications. */ @AdminController @ResponseBody @RequestMapping("/api/applications") public class RegistryController { private static final Logger LOGGER = LoggerFactory.getLogger(RegistryController.class); private final ApplicationRegistry registry; public RegistryController(ApplicationRegistry registry) { this.registry = registry; } /** * Register an application within this admin application. * * @param application The application infos. * @return The registered application. */ @RequestMapping(method = RequestMethod.POST) public ResponseEntity<Application> register(@RequestBody Application application) { Application applicationWithSource = Application.copyOf(application).withSource("http-api") .build(); LOGGER.debug("Register application {}", applicationWithSource.toString()); Application registeredApp = registry.register(applicationWithSource); return ResponseEntity.status(HttpStatus.CREATED).body(registeredApp); } /** * List all registered applications with name * * @param name the name to search for * @return List */ @RequestMapping(method = RequestMethod.GET) public Collection<Application> applications( @RequestParam(value = "name", required = false) String name) { LOGGER.debug("Deliver registered applications with name={}", name); if (name == null || name.isEmpty()) { return registry.getApplications(); } else { return registry.getApplicationsByName(name); } } /** * Get a single application out of the registry. * * @param id The application identifier. * @return The registered application. */ @RequestMapping(value = "/{id}", method = RequestMethod.GET) public ResponseEntity<?> get(@PathVariable String id) { LOGGER.debug("Deliver registered application with ID '{}'", id); Application application = registry.getApplication(id); if (application != null) { return ResponseEntity.ok(application); } else { return ResponseEntity.notFound().build(); } } /** * Unregister an application within this admin application. * * @param id The application id. * @return the unregistered application. */ @RequestMapping(value = "/{id}", method = RequestMethod.DELETE) public ResponseEntity<?> unregister(@PathVariable String id) { LOGGER.debug("Unregister application with ID '{}'", id); Application application = registry.deregister(id); if (application != null) { return ResponseEntity.ok(application); } else { return ResponseEntity.notFound().build(); } } }