Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adeguamento swagger #144

Merged
merged 3 commits into from
Oct 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 32 additions & 0 deletions src/main/java/it/gov/innovazione/ndc/Application.java
Original file line number Diff line number Diff line change
@@ -1,12 +1,44 @@
package it.gov.innovazione.ndc;

import io.swagger.v3.oas.annotations.OpenAPIDefinition;
import io.swagger.v3.oas.annotations.info.Contact;
import io.swagger.v3.oas.annotations.info.Info;
import io.swagger.v3.oas.annotations.info.License;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;

import java.time.Clock;

@SpringBootApplication
@OpenAPIDefinition(
info = @Info(
title = "Schema - Semantic Backend",
version = "0.0.1",
description = """
This API exposes information from Schema, the National Data Catalog for Semantic Interoperability including the REST API
for accessing controlled vocabularies.


It is used as a backend service for the [schema.gov.it](https://schema.gov.it) website and to expose functionalities in
an interoperable way.


Provided information can be used to discover ontologies, controlled vocabularies and schemas indexed by Schema, and to
ease the creation of semantically interoperable digital services such as web forms and APIs.


**This API is a beta release, and it can change in the future during the consolidation phase of Schema.**""",
contact = @Contact(
name = "Dipartimento per la Trasformazione digitale",
email = "[email protected]"),
license = @License(
name = " BSD-3-Clause",
url = "https://opensource.org/licenses/BSD-3-Clause"),
summary = "Expose ontology, controlled vocabularies and schemas information from Schema."


))
public class Application {

public static void main(String[] args) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package it.gov.innovazione.ndc.alerter.controller;


import io.swagger.v3.oas.annotations.Operation;
import it.gov.innovazione.ndc.alerter.data.EntityService;
import it.gov.innovazione.ndc.alerter.dto.SlimPager;
import it.gov.innovazione.ndc.alerter.entities.Nameable;
Expand All @@ -27,6 +28,10 @@ public abstract class AbstractCrudController<T extends Nameable, D extends Namea
abstract EntityService<T, D> getEntityService();

@GetMapping
@Operation(
operationId = "getAll",
description = "Get all entities",
summary = "Get all entities")
public SlimPager<D> getPaginated(Pageable pageable) {
return toSlimPager(getEntityService().getPaginated(pageable));
}
Expand All @@ -50,12 +55,20 @@ private SlimPager<D> toSlimPager(Page<D> paginated) {
}

@GetMapping("{id}")
@Operation(
operationId = "getOne",
description = "Get one entity",
summary = "Get one entity")
public D getOne(@PathVariable String id) {
return getEntityService().getById(id);
}

@PostMapping
@ResponseStatus(CREATED)
@Operation(
operationId = "create",
description = "Create a new entity",
summary = "Create a new entity")
public D create(@Valid @RequestBody D dto) {
handlePreCreate(dto);
D createdEntity = getEntityService().create(dto);
Expand All @@ -73,6 +86,10 @@ protected void handlePostCreate(D createdEntity) {

@PatchMapping
@ResponseStatus(CREATED)
@Operation(
operationId = "update",
description = "Update an entity",
summary = "Update an entity")
public D update(@Valid @RequestBody D dto) {
handlePreUpdate(dto);
D updatedDto = getEntityService().update(dto);
Expand All @@ -90,6 +107,10 @@ protected void handlePostUpdate(D updatedDto) {

@DeleteMapping("{id}")
@ResponseStatus(CREATED)
@Operation(
operationId = "delete",
description = "Delete an entity",
summary = "Delete an entity")
public void delete(@PathVariable String id) {
handlePreDelete(id);
D deletedDto = getEntityService().delete(id);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import it.gov.innovazione.ndc.gen.dto.Problem;
import it.gov.innovazione.ndc.model.Builders;
import lombok.RequiredArgsConstructor;
Expand All @@ -15,27 +17,33 @@

@RestController
@RequiredArgsConstructor
@Tag(name = "status", description = "Entry point for application status")
public class ApplicationStatusController {

private final HealthEndpoint healthEndpoint;

@GetMapping("/status")
@Operation(
operationId = "checkStatus",
description = "Check if the application is available and healthy",
tags = {"status"},
summary = "Check the application status")
public ResponseEntity<Problem> getStatus() {
Status status = healthEndpoint.health().getStatus();
if (status != Status.UP) {
Problem response = Builders.problem()
.status(INTERNAL_SERVER_ERROR)
.title("Application is not available")
.build();
.status(INTERNAL_SERVER_ERROR)
.title("Application is not available")
.build();
return ResponseEntity
.status(INTERNAL_SERVER_ERROR)
.contentType(MediaType.APPLICATION_PROBLEM_JSON)
.body(response);
.status(INTERNAL_SERVER_ERROR)
.contentType(MediaType.APPLICATION_PROBLEM_JSON)
.body(response);
}
return ResponseEntity.status(OK.value())
.contentType(MediaType.APPLICATION_PROBLEM_JSON)
.body(Builders.problem()
.status(OK)
.title("Application is available").build());
.contentType(MediaType.APPLICATION_PROBLEM_JSON)
.body(Builders.problem()
.status(OK)
.title("Application is available").build());
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.media.Content;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.responses.ApiResponse;
import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpStatus;
Expand All @@ -16,8 +20,20 @@
@RequestMapping("check-url")
@Slf4j
public class CheckUrlController {

@GetMapping
@SneakyThrows
@Operation(
operationId = "checkUrl",
description = "Check if the passed URL is available",
summary = "Check the URL status",
responses = {
@ApiResponse(responseCode = "200", description = "The URL is available",
content = @Content(schema = @Schema(implementation = HttpStatus.class))),
@ApiResponse(responseCode = "404", description = "The URL is not available",
content = @Content(schema = @Schema(implementation = HttpStatus.class))),
@ApiResponse(responseCode = "500", description = "The URL is not available",
content = @Content(schema = @Schema(implementation = HttpStatus.class)))})
public ResponseEntity<?> check(@RequestParam String url) {
log.info("Checking url {}", url);
HttpURLConnection huc = (HttpURLConnection) new URL(url).openConnection();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import it.gov.innovazione.ndc.eventhandler.NdcEventPublisher;
import it.gov.innovazione.ndc.eventhandler.event.ConfigService;
import it.gov.innovazione.ndc.harvester.service.ActualConfigService;
Expand Down Expand Up @@ -32,6 +33,10 @@ public class ConfigurationController {
private final NdcEventPublisher eventPublisher;

@GetMapping
@Operation(
operationId = "getConfig",
description = "Get the configuration for a repository",
summary = "Get the configuration for a repository")
public Map<ActualConfigService.ConfigKey, ConfigService.ConfigEntry> getConfig(
@PathVariable String repoId) {
if (repoId.equals("ndc")) {
Expand All @@ -42,6 +47,10 @@ public Map<ActualConfigService.ConfigKey, ConfigService.ConfigEntry> getConfig(

@PostMapping
@ResponseStatus(CREATED)
@Operation(
operationId = "setConfig",
description = "Set the configuration for a repository",
summary = "Set the configuration for a repository")
public void setConfig(
@PathVariable String repoId,
@RequestBody Map<ActualConfigService.ConfigKey, Object> config,
Expand All @@ -55,6 +64,10 @@ public void setConfig(

@PutMapping("/{configKey}")
@ResponseStatus(ACCEPTED)
@Operation(
operationId = "updateRepository",
description = "Update a configuration key for a repository",
summary = "Update a configuration key for a repository")
public void updateRepository(
@PathVariable String repoId,
@PathVariable ActualConfigService.ConfigKey configKey,
Expand All @@ -69,6 +82,10 @@ public void updateRepository(

@DeleteMapping("/{configKey}")
@ResponseStatus(ACCEPTED)
@Operation(
operationId = "deleteRepository",
description = "Delete a configuration key for a repository",
summary = "Delete a configuration key for a repository")
public void deleteRepository(
@PathVariable String repoId,
@PathVariable ActualConfigService.ConfigKey configKey,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import it.gov.innovazione.ndc.alerter.entities.EventCategory;
import it.gov.innovazione.ndc.alerter.entities.Severity;
import it.gov.innovazione.ndc.alerter.event.AlertableEvent;
Expand Down Expand Up @@ -40,6 +41,10 @@ public class HarvestJobController {
private final NdcEventPublisher eventPublisher;

@PostMapping("jobs/harvest")
@Operation(
operationId = "startHarvestJob",
description = "Start a new harvest job",
summary = "Start a new harvest job")
public List<JobExecutionResponse> startHarvestJob(@RequestParam(required = false, defaultValue = "false") Boolean force) {
log.info("Starting Harvest job at " + LocalDateTime.now());
List<JobExecutionResponse> harvest = harvesterJob.harvest(force);
Expand All @@ -53,16 +58,28 @@ public List<JobExecutionResponse> startHarvestJob(@RequestParam(required = false
}

@GetMapping("jobs/harvest/run")
@Operation(
operationId = "getHarvestRuns",
description = "Get all harvest runs",
summary = "Get all harvest runs")
public List<HarvesterRun> getAllRuns() {
return harvesterRunService.getAllRuns();
}

@GetMapping("jobs/harvest/running")
@Operation(
operationId = "getRunningInstances",
description = "Get all running instances",
summary = "Get all running instances")
public List<RunningInstance> getAllRunningInstance() {
return harvesterRunService.getAllRunningInstances();
}

@DeleteMapping("jobs/harvest/run")
@Operation(
operationId = "deletePendingRuns",
description = "Delete all pending runs",
summary = "Delete all pending runs")
public void deletePendingRuns() {
harvesterRunService.deletePendingRuns();
eventPublisher.publishAlertableEvent(
Expand All @@ -73,6 +90,10 @@ public void deletePendingRuns() {
}

@PostMapping(value = "jobs/harvest", params = "repositoryId")
@Operation(
operationId = "harvestRepositories",
description = "Harvest a specific repository",
summary = "Harvest a specific repository")
public JobExecutionResponse harvestRepositories(
@RequestParam("repositoryId") String repositoryId,
@RequestParam(required = false, defaultValue = "") String revision,
Expand All @@ -90,6 +111,10 @@ public JobExecutionResponse harvestRepositories(

@PostMapping("jobs/clear")
@ResponseStatus(HttpStatus.ACCEPTED)
@Operation(
operationId = "clearRepo",
description = "Clear a repository",
summary = "Clear a repository")
public void clearRepo(@RequestParam("repo_url") String repoUrl) {
if (StringUtils.isEmpty(repoUrl)) {
throw new IllegalArgumentException("repo_url is required");
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import it.gov.innovazione.ndc.alerter.entities.EventCategory;
import it.gov.innovazione.ndc.alerter.entities.Severity;
import it.gov.innovazione.ndc.alerter.event.DefaultAlertableEvent;
Expand Down Expand Up @@ -43,13 +44,21 @@ public class RepositoryController {
private final NdcEventPublisher eventPublisher;

@GetMapping
@Operation(
operationId = "getAllRepositories",
description = "Get all repositories",
summary = "Get all repositories")
public List<Repository> getAllRepositories() {
return repositoryService.getActiveRepos();
}

@PostMapping
@ResponseStatus(CREATED)
@SneakyThrows
@Operation(
operationId = "createRepository",
description = "Create a new repository",
summary = "Create a new repository")
public void createRepository(
@RequestBody CreateRepository repository,
Principal principal) {
Expand Down Expand Up @@ -86,6 +95,10 @@ private void assertValidUrl(@RequestBody CreateRepository repository) throws Bad

@PatchMapping("/{id}")
@SneakyThrows
@Operation(
operationId = "updateRepository",
description = "Update a repository",
summary = "Update a repository")
public ResponseEntity<Void> updateRepository(
@PathVariable String id,
@RequestBody CreateRepository repository,
Expand Down Expand Up @@ -119,6 +132,10 @@ public ResponseEntity<Void> updateRepository(

@DeleteMapping("/{id}")
@SneakyThrows
@Operation(
operationId = "deleteRepository",
description = "Delete a repository",
summary = "Delete a repository")
public ResponseEntity<?> deleteRepository(
@PathVariable String id,
Principal principal) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package it.gov.innovazione.ndc.controller;

import io.swagger.v3.oas.annotations.Operation;
import it.gov.innovazione.ndc.service.ValidationService;
import it.gov.innovazione.ndc.validator.ValidationResultDto;
import lombok.RequiredArgsConstructor;
Expand All @@ -18,6 +19,10 @@ public class ValidationController {
private final ValidationService validationService;

@PostMapping
@Operation(
operationId = "validateFile",
description = "Validate the file representing a semantic asset",
summary = "Validate the file")
public ResponseEntity<ValidationResultDto> validateFile(@RequestParam(value = "type") String assetType,
@RequestParam(value = "file") MultipartFile file) {
return AppJsonResponse.ok(validationService.validate(file, assetType));
Expand Down
5 changes: 2 additions & 3 deletions src/main/resources/application.properties
Original file line number Diff line number Diff line change
Expand Up @@ -25,9 +25,8 @@ harvester.controlled-vocabulary.scanner.skip-words=transparency-obligation-organ

harvester.auth.user=${HARVESTER_USER:harv-user}
harvester.auth.password=${HARVESTER_PASSWORD:harv-password}

springdoc.api-docs.enabled=false
springdoc.swagger-ui.url=/openapi.yaml
springdoc.api-docs.enabled=true
#springdoc.swagger-ui.url=/openapi.yaml
#Disable restrictions on multipart requests to validate semantic assets files
spring.servlet.multipart.max-file-size=-1
spring.servlet.multipart.max-request-size=-1
Expand Down
Loading