Skip to content

Commit

Permalink
Search with AQL
Browse files Browse the repository at this point in the history
  • Loading branch information
askask committed Nov 7, 2024
1 parent 5e102bf commit bef75bf
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 0 deletions.
11 changes: 11 additions & 0 deletions src/main/java/org/highmed/numportal/domain/dto/QueryDto.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package org.highmed.numportal.domain.dto;

import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.validation.constraints.NotNull;
import lombok.Data;

@Data
@Schema
public class QueryDto {
@NotNull private String aql;
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,6 @@
@Data
@ConfigurationProperties(prefix = "feature")
public class FeatureProperties {

private boolean searchWithAql = false;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
package org.highmed.numportal.web.controller;

import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.security.SecurityRequirement;
import jakarta.validation.Valid;
import lombok.AllArgsConstructor;
import org.ehrbase.openehr.sdk.response.dto.QueryResponseData;
import org.highmed.numportal.domain.dto.QueryDto;
import org.highmed.numportal.service.ehrbase.EhrBaseService;
import org.highmed.numportal.service.logger.AuditLog;
import org.highmed.numportal.web.config.Role;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.http.ResponseEntity;
import org.springframework.security.access.prepost.PreAuthorize;
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.RestController;

@RestController
@AllArgsConstructor
@RequestMapping(value = "/query", produces = "application/json")
@SecurityRequirement(name = "security_auth")
@ConditionalOnProperty(value = "feature.search-with-aql", havingValue = "true")
public class QueryController {

private final EhrBaseService ehrBaseService;

@AuditLog
@PostMapping("execute")
@Operation(description = "Executes an AQL query")
@PreAuthorize(Role.MANAGER)
public ResponseEntity<QueryResponseData> executeManagerProject(
@RequestBody @Valid QueryDto queryDto) {
return ResponseEntity.ok(
ehrBaseService.executePlainQuery(queryDto.getAql())
);
}
}
1 change: 1 addition & 0 deletions src/main/resources/application-local.yml
Original file line number Diff line number Diff line change
Expand Up @@ -107,3 +107,4 @@ user-service:
delete-users-cron: 0 0 5 * * *

feature:
search-with-aql: off

0 comments on commit bef75bf

Please sign in to comment.