001/*- 002 * #%L 003 * Smile CDR - CDR 004 * %% 005 * Copyright (C) 2016 - 2025 Smile CDR, Inc. 006 * %% 007 * All rights reserved. 008 * #L% 009 */ 010package ca.cdr.api.persistence.megascale; 011 012import ca.cdr.api.model.json.IModelJson; 013import com.fasterxml.jackson.annotation.JsonProperty; 014import io.swagger.v3.oas.annotations.media.Schema; 015import org.apache.commons.lang3.Validate; 016 017import java.util.ArrayList; 018import java.util.List; 019 020/** 021 * Hook method return value for the 022 * {@link ca.cdr.api.fhir.interceptor.CdrPointcut#STORAGE_MEGASCALE_PROVIDE_DB_INFO} 023 * pointcut. 024 * 025 * @since 2023.02.R01 026 */ 027@Schema( 028 name = "MegaScaleCredentialResponse", 029 description = "Response object for a MegaScale database credential request") 030public class MegaScaleCredentialResponseJson implements IModelJson { 031 032 @JsonProperty("databaseUrl") 033 @Schema(description = "The JDBC database connection URL") 034 private String myDatabaseUrl; 035 036 @JsonProperty("databaseUsername") 037 @Schema(description = "The JDBC database connection username") 038 private String myDatabaseUsername; 039 040 @JsonProperty("databasePassword") 041 @Schema(description = "The JDBC database connection password") 042 private String myDatabasePassword; 043 044 @JsonProperty("databaseInitializationStatements") 045 @Schema( 046 description = "Any statements returned here will be issued to the database as raw SQL " 047 + "if the database is found to be empty, immediately after the Smile CDR " 048 + "database schema is initialized.") 049 private List<String> myDatabaseInitializationStatements; 050 051 /** 052 * Constructor 053 */ 054 public MegaScaleCredentialResponseJson() { 055 super(); 056 } 057 058 /** 059 * Constructor 060 * 061 * @param theDatabaseUrl The JDBC URL 062 * @param theDatabaseUsername The JDBC username 063 * @param theDatabasePassword The JDBC password 064 */ 065 public MegaScaleCredentialResponseJson( 066 String theDatabaseUrl, String theDatabaseUsername, String theDatabasePassword) { 067 myDatabaseUrl = theDatabaseUrl; 068 myDatabaseUsername = theDatabaseUsername; 069 myDatabasePassword = theDatabasePassword; 070 } 071 072 /** 073 * Any statements returned here will be issued to the database as raw SQL 074 * if the database is found to be empty, immediately after the Smile CDR 075 * database schema is initialized. 076 * 077 * @param theSql The raw SQL statement to execute. 078 */ 079 public void addDatabaseInitializationStatement(String theSql) { 080 Validate.notBlank(theSql, "theSql must not be blank"); 081 getDatabaseInitializationStatements().add(theSql); 082 } 083 084 public List<String> getDatabaseInitializationStatements() { 085 if (myDatabaseInitializationStatements == null) { 086 myDatabaseInitializationStatements = new ArrayList<>(); 087 } 088 return myDatabaseInitializationStatements; 089 } 090 091 public void setDatabaseInitializationStatements(List<String> theDatabaseInitializationStatements) { 092 myDatabaseInitializationStatements = theDatabaseInitializationStatements; 093 } 094 095 public String getDatabaseUrl() { 096 return myDatabaseUrl; 097 } 098 099 public void setDatabaseUrl(String theDatabaseUrl) { 100 myDatabaseUrl = theDatabaseUrl; 101 } 102 103 public String getDatabaseUsername() { 104 return myDatabaseUsername; 105 } 106 107 public void setDatabaseUsername(String theDatabaseUsername) { 108 myDatabaseUsername = theDatabaseUsername; 109 } 110 111 public String getDatabasePassword() { 112 return myDatabasePassword; 113 } 114 115 public void setDatabasePassword(String theDatabasePassword) { 116 myDatabasePassword = theDatabasePassword; 117 } 118}